mirror of https://gitee.com/openkylin/linux.git
47 lines
1.6 KiB
ReStructuredText
47 lines
1.6 KiB
ReStructuredText
|
==============
|
||
|
Audio Clocking
|
||
|
==============
|
||
|
|
||
|
This text describes the audio clocking terms in ASoC and digital audio in
|
||
|
general. Note: Audio clocking can be complex!
|
||
|
|
||
|
|
||
|
Master Clock
|
||
|
------------
|
||
|
|
||
|
Every audio subsystem is driven by a master clock (sometimes referred to as MCLK
|
||
|
or SYSCLK). This audio master clock can be derived from a number of sources
|
||
|
(e.g. crystal, PLL, CPU clock) and is responsible for producing the correct
|
||
|
audio playback and capture sample rates.
|
||
|
|
||
|
Some master clocks (e.g. PLLs and CPU based clocks) are configurable in that
|
||
|
their speed can be altered by software (depending on the system use and to save
|
||
|
power). Other master clocks are fixed at a set frequency (i.e. crystals).
|
||
|
|
||
|
|
||
|
DAI Clocks
|
||
|
----------
|
||
|
The Digital Audio Interface is usually driven by a Bit Clock (often referred to
|
||
|
as BCLK). This clock is used to drive the digital audio data across the link
|
||
|
between the codec and CPU.
|
||
|
|
||
|
The DAI also has a frame clock to signal the start of each audio frame. This
|
||
|
clock is sometimes referred to as LRC (left right clock) or FRAME. This clock
|
||
|
runs at exactly the sample rate (LRC = Rate).
|
||
|
|
||
|
Bit Clock can be generated as follows:-
|
||
|
|
||
|
- BCLK = MCLK / x, or
|
||
|
- BCLK = LRC * x, or
|
||
|
- BCLK = LRC * Channels * Word Size
|
||
|
|
||
|
This relationship depends on the codec or SoC CPU in particular. In general
|
||
|
it is best to configure BCLK to the lowest possible speed (depending on your
|
||
|
rate, number of channels and word size) to save on power.
|
||
|
|
||
|
It is also desirable to use the codec (if possible) to drive (or master) the
|
||
|
audio clocks as it usually gives more accurate sample rates than the CPU.
|
||
|
|
||
|
|
||
|
|