|  | 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. | 
|  |  | 
|  |  | 
|  |  |