AM62Px MCU+ SDK  10.01.00
UDMA Chaining

Introduction

UDMA chaining sample application performs a chain of block copy transfer using channel global trigger. Channel 0 completion triggers Channel 1 transfer: CH0 -> CH1.

The application opens and configures two BCDMA channel using SysConfig.

The first channel doesn't user a global trigger and each channel triggers the next channel's global trigger through the channel's TR event register.

A channel's source buffer is previous channel's destination buffer. This ensures that chaining trigger works in a synchronized manner when the memory compare matches.

The transfer completion is based on last channel's DMA completion event. Once the transfer it completes, it does cache operation for data coherency and compares the source and destination buffers for any data mismatch.

Supported Combinations

Parameter Value
CPU + OS wkup-r5fss0-0 freertos
Toolchain ti-arm-clang
Board am62px-sk
Example folder examples/drivers/udma/udma_chaining

Steps to Run the Example

  • When using CCS projects to build, import the CCS project for the required combination and build it using the CCS project menu (see Using SDK with CCS Projects).
  • When using makefiles to build, note the required combination and build using make command (see Using SDK with Makefiles)
Attention
As the wake-up R5 is the device manager, it needs to be started by the SBL. So it can not be loaded through CCS. It should be flashed and booted through SBL.

See Also

UDMA

Sample Output

Shown below is a sample output when the application is run,

[UDMA] Chaining application started ...
All tests have passed!!