User manual

Table Of Contents
Zynq-7000 AP SoC Technical Reference Manual www.xilinx.com 250
UG585 (v1.11) September 27, 2016
Chapter 9
DMA Controller
9.1 Introduction
The DMA controller (DMAC) uses a 64-bit AXI master interface operating at the CPU_2x clock rate to
perform DMA data transfers to/from system memories and PL peripherals. The transfers are
controlled by the DMA instruction execution engine. The DMA engine runs on a small instruction set
that provides a flexible method of specifying DMA transfers. This method provides greater flexibility
than the capabilities of DMA controller methods.
The program code for the DMA engine is written by software in to a region of system memory that
is accessed by the controller using its AXI master interface. The DMA engine instruction set includes
instructions for DMA transfers and management instructions to control the system.
The controller can be configured with up to eight DMA channels. Each channel corresponds to a
thread running on the DMA engine’s processor. When a DMA thread executes a load or store
instruction, the DMA Engine pushes the memory request to the relevant read or write queue. The
DMA controller uses these queues to buffer AXI read/write transactions. The controller contains a
multi-channel FIFO (MFIFO) to store data during the DMA transfers. The program code running on
the DMA engine processor views the MFIFO as containing a set of variable-depth parallel FIFOs for
DMA read and write transactions. The program code must manage the MFIFO so that the total depth
of all of the DMA FIFOs does not exceed the 1,024-byte MFIFO.
The DMAC is able to move large amounts of data without processor intervention. The source and
destination memory can be anywhere in the system (PS or PL). The memory map for the DMAC
includes DDR, OCM, linear addressed Quad-SPI read memory, SMC memory and PL peripherals or
memory attached to an M_GP_AXI interface.
The flow control method for transfers with PS memories use the AXI interconnect. Accesses with PL
peripherals can use the AXI flow control or the DMAC’s PL Peripheral Request Interface. There are no
peripheral request interfaces directed to the PS I/O Peripherals (IOPs). For the PL peripheral AXI
transactions, software running on a CPU is used in a programmed IO method using interrupts or
status polling.
The controller has two sets of control and status registers. One set is accessible in secure mode and
the other in non-secure mode. Software accesses these registers via the controller’s 32-bit APB slave
interface. The entire controller is either operated in secure or non-secure mode; there is no mixing of
modes on a channel basis. Security configuration changes are controlled by slcr registers and require
a controller reset to take effect.