
9
DMAC
9-29
32176 Group User’s Manual (Rev.1.01)
9.3 Functional Description of the DMAC
Figure 9.3.4 Example of How Addresses Are Incremented in 32-channel Ring Buffer Mode
<When transfer size = 8 bits>
Transfer count
Transfer address
1
H'0080 1000
2
H'0080 1001
3
H'0080 1002
31
H'0080 101E
32
H'0080 101F
↓
1
H'0080 1000
2
H'0080 1001
<When transfer size = 16 bits>
Transfer count
Transfer address
1
H'0080 1000
2
H'0080 1002
3
H'0080 1004
31
H'0080 103C
32
H'0080 103E
1
H'0080 1000
2
H'0080 1002
|
(7) Ring buffer mode
When ring buffer mode is selected, transfer begins from the transfer start address and after performing
transfers 32 times, control returns to the transfer start address, from which transfer operation is repeated. In
this case, however, the five low-order bits of the ring buffer start address must always be B’00000 (if transfer
size = 16 bits, the six low-order bits must be B’000000).
The following describes how addresses are incremented in ring buffer mode.
[1] When the transfer size is 8 bits
The 27 high-order bits of the transfer start address are fixed, and the five low-order bits are incremented
by one at a time. When as transfer proceeds the five low-order bits reach B’11111, they are recycled to
B’00000 by the next increment operation, thus returning to the start address again.
[2] When the transfer size is 16 bits
The 26 high-order bits of the transfer start address are fixed, and the six low-order bits are incremented
by two at a time. When as transfer proceeds the six low-order bits reach B’111110, they are recycled to
B’000000 by the next increment operation, thus returning to the start address again.
If the source address has been set to be incremented, it is the source address that recycles to the start
address; if the destination address has been set to be incremented, it is the destination address that recycles
to the start address. If both source and destination addresses have been set to be incremented, both ad-
dresses recycle to the start address. However, the start address on either side must have their five low-order
bits initially set to B’00000 (if transfer size = 16 bits, the six low-order bits must be B’000000).
During ring buffer mode, the transfer count register is ignored. Once DMA operation starts, the counter operates
in free-run mode, and the transfer continues until the transfer enable bit is cleared to "0" (to disable transfer).