Generic Channels
5-13
System DMA Controller
To avoid the reload of a configuration when the MPU programs the channel,
the MPU can use the autoinitialization bits of the DMA_CCR register, which are
described in Table 5–3.
Table 5–3. Autoinitialization Configuration Bits Summary
AUTOINIT
END_PROG
REPEAT
Autoinitialization Behavior
0
x
x
No autoinitialization
1
0
0
At the end of current transfer, channel waits until END_PROG = 1
to load the programming register set in its working register set.
1
1
0
At the end of current transfer, channel immediately loads the
programming register set in its working register set
1
x
1
programming register set in its working register set.
5.3.1.6
Priorities Between Channels
Each channel can be given a low- or high-priority level. When a DMA port
receives requests from several channels, it looks at their priorities:
-
Requests from high-priority channels are served first.
-
Requests from low-priority channels are served only if there are no
requests from high-priority channels on the port. This can occur if there are
no high-priority channels activated, if the high-priority channels are stalled
(by a slow source or destination), or if the high-priority channels are
waiting for a synchronization event.
-
Requests of the same priority level are served in a round-robin manner
(time division multiplex).
5.3.2
Addressing Modes
Figure 5–6 provides an example of address index management. In this
example, Element Size = 4, Element Index = 3, Frame Size = 2, and
Frame Index = 5.
An addressing mode is an address computation algorithm a DMA channel can
use to know where to access data. The system DMA has four addressing
modes: constant, post-incremented, indexed, and double-indexed.