

# **The McASP Primer**

#### Bonus material: 48 kHz frame sync, Audio FIFO configuration



- Keep in mind that McASP only has integer clock dividers.
- Work backwards, starting with the frame sync, since that is your target. AFSX/AFSR = 48 kHz (fs). What must be the frequency of the ACLKX/R?
- In the case of I2S, we have two slots per frame. Each slot consists of 32 bits; Even if the data payload is only 16 bits or 24 bits, we'll encapsulate it within a 32-bit word. Based on this logic, we need a bit clock (ACLKX/ACLKR) of:



- Keep in mind that McASP only has integer clock dividers.
- Work backwards, starting with the frame sync, since that is your target. AFSX/AFSR = 48 kHz (fs). What must be the frequency of the ACLKX/R?
- In the case of I2S, we have two slots per frame. Each slot consists of 32 bits; Even if the data payload is only 16 bits or 24 bits, we'll encapsulate it within a 32-bit word. Based on this logic, we need a bit clock (ACLKX/ACLKR) of:

2 slots \* 32 bits per slot \* 48 kHz = 3.072 MHz



- So far, we have:
  - AFSX/AFSR = 48 kHz
  - ACLKX/ACLKR = 3.072 MHz
  - AHCLKX/AHCLKR = ???



- So far, we have:
  - AFSX/AFSR = 48 kHz
  - ACLKX/ACLKR = 3.072 MHz
  - AHCLKX/AHCLKR = ???
- The master clock is typically required to be a multiple of the sample rate fs: 128fs, 256fs, or 512fs. Therefore, the master clock must run at:

6.144 MHz (128fs), 12.288 MHz (256fs), or 24.576 MHz (512fs)



- So far, we have:
  - AFSX/AFSR = 48 kHz
  - ACLKX/ACLKR = 3.072 MHz
  - AHCLKX/AHCLKR = ???
- The master clock is typically required to be a multiple of the sample rate fs: 128fs, 256fs, or 512fs. Therefore, the master clock must run at:

6.144 MHz (128fs), 12.288 MHz (256fs), or 24.576 MHz (512fs)

- In order to generate all audio clocks internally, AUXCLK must be running at one of these three frequencies.
- If one of the above AUXCLK rates is not available, then an external master clock must be provided to AHCLKX or AHCLKR. The bit clock divider and frame sync generator may then be used to generate the desired clocks.





• When enabling the FIFO, you must set WNUMDMA equal to the number of transmit serializers in use. You set RNUMDMA equal to the number of receive serializers in use.



- When enabling the FIFO, you must set WNUMDMA equal to the number of transmit serializers in use. You set RNUMDMA equal to the number of receive serializers in use.
- WNUMEVT should be a multiple of the number of transmit serializers. RNUMEVT should be a multiple of the number of receive serializers.



- When enabling the FIFO, you must set WNUMDMA equal to the number of transmit serializers in use. You set RNUMDMA equal to the number of receive serializers in use.
- WNUMEVT should be a multiple of the number of transmit serializers. RNUMEVT should be a multiple of the number of receive serializers.
- WNUMEVT/RNUMEVT should be configured large enough to allow for the CPU/DMA to burst many samples at once, though it should be small enough so as to avoid over/underflows. Often these are configured equal to half the FIFO depth. For example, for a 64-word FIFO, it is common to configure WNUMEVT=RNUMEVT=32.



- When enabling the FIFO, you must set WNUMDMA equal to the number of transmit serializers in use. You set RNUMDMA equal to the number of receive serializers in use.
- WNUMEVT should be a multiple of the number of transmit serializers. RNUMEVT should be a multiple of the number of receive serializers.
- WNUMEVT/RNUMEVT should be configured large enough to allow for the CPU/DMA to burst many samples at once, though it should be small enough so as to avoid over/underflows. Often these are configured equal to half the FIFO depth. For example, for a 64-word FIFO, it is common to configure WNUMEVT=RNUMEVT=32.
- The DMA needs to be configured such that in response to an AFIFO event it transfers WNUMEVT/RNUMEVT words. A common configuration for devices with EDMA would be to configure the transfer as AB-synchronized with ACNT=4 and BCNT=WNUMEVT (or RNUMEVT).



#### For more information

- McASP Design Guide: Tips, Tricks, and Practical Examples <u>http://www.ti.com/lit/sprack0</u>
- For questions about this training, refer to the E2E Community Forums at <u>http://e2e.ti.com</u>

