data:image/s3,"s3://crabby-images/bc033/bc033f6f0f875e7be7329fd6b8c861fb70aa5538" alt="Holtek HT32F54231 User Manual Download Page 508"
Rev. 1.00
508 of 576
January 28, 2022
32-Bit Arm
®
Cortex
®
-M0+ MCU
HT32F54231/HT32F54241/HT32F54243/HT32F54253
24 Peripheral Direct Memory
Access (PDMA)
Table 62. PDMA Channel Assignments
IP
(x = 0, 1)
(y = 0, 1, 2, 3)
(z = 0, 1, 2)
PDMA Channel Number
CH0
CH1
CH2
CH3
CH4
CH5
ADC
ADC
SPIx
SPI0_RX
SPI0_TX
SPI1_RX
SPI1_TX
USARTx
USR0_RX
USR0_TX
USR1_RX
USR1_TX
UARTy
UR2_RX
UR2_TX
UR0_RX
UR0_TX
UR1_RX
UR3_RX
UR1_TX
UR3_TX
I
2
Cz
I2C2_RX
I2C2_TX
I2C0_RX
I2C1_RX
I2C0_TX
I2C1_TX
MCTM
MT_CH0
MT_TRIG
MT_CH1
MT_CH2
MT_CH3
MT_UEV2
MT_UEV1
GPTM
GT_CH1
GT_CH3
GT_CH2
GT_UEV
GT_CH0
GT_TRIG
Channel Transfer
A PDMA channel transfer is split into multiple block transactions with PDMA arbitration occurring
at the end of each block transaction. Although these channel transfers can all be activated, there
is only one block transaction being transferred through the bus at a time. The channel transfer
sequence depends upon the channel priority setting of each PDMA channel. The total transfer size
is calculated from the block transaction count and block size. The block size is equal to the product
of the block length and data bit width. For an efficient transfer, it is recommended that the block
length is set as a multiple of 4.
The total transfer data size calculation is shown as the following equation:
A PDMA channel total transfer data size = Block transaction count × (Block length × Data width)
Channel Priority
The PDMA provides four priority levels, known as very high, high, medium and low, which can
be configured by the application software. The PDMA also provides two methods to determine
the channel priority. One is determined by application software configuration and the other is
determined by the fixed hardware channel number. The PDMA arbitration processor will first
check the software configuring channel priority level used to request the PDMA to provide the
data transfer services. If more than one channel has the same priority, the channel with a smaller
channel number will have priority over one with a larger channel number after arbitration.
Note that the highest priority channel will not occupy the PDMA service all the time when other
lower priority channel requests are pending. The highest priority channel will be skipped for one
block transaction time duration after one block transaction is complete. Then a block transaction
requested by the second priority channel will be performed. After a block transaction of the second
priority channel is complete, the PDMA arbitration processor will re-check all of the requested
channel priority with the exception of the second priority channel since the second priority
channel will be excluded after the end of a block transaction. Therefore, a block data transaction
of the higher priority channel will be serviced and this channel will be excluded from the priority
arbitration at the end of the block transaction. The PDMA will keep transferring the data using the
method described above until all of the requested channel data transfer is complete. Refer to the
accompanying figure for an example which shows the PDMA channel arbitration and scheduling.