# Chapter 10 DMA Controller for Bus System (DMAC\_BUS) ## 10.1 Overview This device supports 2 Direct Memory Access (DMA) tops, one for cpu system (DMAC\_BUS), and the other one for Peripheral system (PERI\_DMAC).Both of these two dma support transfers between memory and memory, peripheral and memory. DMAC\_BUS supports TrustZone technology and is under secure state after reset. The secure state can be changed by configuring TZPC module. DMAC\_BUS is mainly used for data transfer of the following slaves: I2S0/I2S1/SPDIF/UART0/Embedded SRAM and transfer data from/to external DDR SDRAM. Following table shows the DMAC\_BUS peripheral request mapping scheme. Table 10-1 DMAC\_BUS Request Mapping Table | Req number | Source | Polarity | |------------|-------------|------------| | 0 | I2S tx | High level | | 1 | I2S rx | High level | | 2 | SPDIF | High level | | 3 | SPDIF (8ch) | High level | | 4 | UART DBG tx | High level | | 5 | UART DBG rx | High level | DMAC\_BUS supports the following features: - Supports Trustzone technology - Supports 6 peripheral request - Up to 64bits data size - 5 channel at the same time - Up to burst 16 - 10 interrupt output and 1 abort output - Supports 32 MFIFO depth # 10.2 Block Diagram Figure 10-1 shows the block diagram of DMAC\_BUS Fig. 10-1 Block diagram of DMAC\_BUS As the DMAC\_BUS supports Trustzone technology, so dual APB interfaces enable the operation of the DMAC\_BUS to be partitioned into the secure state and Non-secure state. You can use the APB interfaces to access status registers and also directly execute instructions in the DMAC\_BUS. The default interface after reset is secure apb interface. # 10.3 Function Description #### 10.3.1 Introduction The DMAC contains an instruction processing block that enables it to process program code that controls a DMA transfer. The program code is stored in a region of system memory that the DMAC accesses using its AXI interface. The DMAC stores instructions temporarily in a cache. DMAC\_BUS supports 6 channels, each channel capable of supporting a single concurrent thread of DMA operation. In addition, a single DMA manager thread exists, and you can use it to initialize the DMA channel threads. The DMAC executes up to one instruction for each AXI clock cycle. To ensure that it regularly executes each active thread, it alternates by processing the DMA manager thread and then a DMA channel thread. It uses a round-robin process when selecting the next active DMA channel thread to execute. The DMAC uses variable-length instructions that consist of one to six bytes. It provides a separate Program Counter (PC) register for each DMA channel. When a thread requests an instruction from an address, the cache performs a look-up. If a cache hit occurs, then the cache immediately provides the data. Otherwise, the thread is stalled while the DMAC uses the AXI interface to perform a cache line fill. If an instruction is greater than 4 bytes, or spans the end of a cache line, the DMAC performs multiple cache accesses to fetch the instruction. When a cache line fill is in progress, the DMAC enables other threads to access the cache, but if another cache miss occurs, this stalls the pipeline until the first line fill is complete. When a DMA channel thread executes a load or store instruction, the DMAC adds the instruction to the relevant read or write queue. The DMAC uses these queues as an instruction storage buffer prior to it issuing the instructions on the AXI bus. The DMAC also contains a Multi First-In-First-Out (MFIFO) data buffer that it uses to store data that it reads, or writes, during a DMA transfer. # 10.3.2 Operating states Figure shows the operating states for the DMA manager thread and DMA channel threads. Fig. 10-2 DMAC\_BUS operation states #### Note: arcs with no letter designator indicate state transitions for the DMA manager and DMA channel threads, otherwise use is restricted as follows: C DMA channel threads only. M DMA manager thread only. After the DMAC exits from reset, it sets all DMA channel threads to the stopped state, and the status of boot\_from\_pc(tie-off interface of dmac) controls the DMA manager thread state: boot\_from\_pc is LOW :DMA manager thread moves to the Stopped state. boot\_from\_pc is HIGH :DMA manager thread moves to the Executing state. # 10.4 Register Description # 10.4.1 Register summary | Name | Offset | Size | Reset<br>Value | Description | | | | |------------------------|--------|------|----------------|---------------------------------------|--|--|--| | DMAC_BUS_DSR | 0x0000 | W | 0x0 | DMA Status Register. | | | | | DMAC_BUS_DPC | 0x0004 | W | 0x0 | DMA Program Counter<br>Register. | | | | | - | | - ' | - | reserved | | | | | DMAC_BUS_INTE N | 0x0020 | W | 0x0 | Interrupt Enable Register | | | | | DMAC_BUS_EVE<br>NT_RIS | 0x0024 | W | 0x0 | Event Status Register. | | | | | DMAC_BUS_INT<br>MIS | 0x0028 | W | 0x0 | Interrupt Status Register | | | | | DMAC_BUS_INTC<br>LR | 0x002C | W | 0x0 | Interrupt Clear Register | | | | | DMAC_BUS_FSR<br>D | 0x0030 | W | 0x0 | Fault Status DMA Manager<br>Register. | | | | | DMAC_BUS_FSR<br>C | 0x0034 | W | 0x0 | Fault Status DMA Channel Register. | | | | | DMAC_BUS_FTR<br>D | 0x0038 | W | 0x0 | Fault Type DMA Manager<br>Register. | | | | | - | - | - | - | reserved | | | | | DMAC_BUS_FTR0 | 0x0040 | W | 0x0 | Fault type for DMA Channel 0 | | | | | DMAC BUS_FIR2 0x0048 W 0x0 Fault type for DMA Channel 2 DMAC BUS_FIR3 0x0048 W 0x0 Fault type for DMA Channel 2 DMAC BUS_FIR3 0x0050 W 0x0 Fault type for DMA Channel 3 DMAC BUS_FIR5 0x0054 W 0x0 Fault type for DMA Channel 4 DMAC BUS_FIR5 0x0054 W 0x0 Fault type for DMA Channel 5 - - - - reserved DMAC_BUS_CSR 0x0100 W 0x0 Channel Status for DMA Channel 3 DMAC_BUS_CSR 0x0110 W 0x0 Channel Status for DMA Channel 3 DMAC_BUS_CSR 0x0118 W 0x0 Channel Status for DMA Channel 3 DMAC_BUS_CSR 0x0128 W 0x0 Channel Status for DMA Channel 4 DMAC_BUS_CCSR 0x0128 W 0x0 Channel Status for DMA Channel 2 DMAC_BUS_CCPC 0x0104 W 0x0 Channel Status for DMA Channel 9 DMAC_BUS_CCPC 0x010c W 0x0 Channel PC for DMA Channel | | | | | I = 1, | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|----------|-------------|------|-------------------------------| | DMAC_BUS_FTR3 0x004C W 0x0 Fault type for DMA Channel 3 DMAC_BUS_FTR5 0x0054 W 0x0 Fault type for DMA Channel 4 Fault type for DMA Channel 5 Fault type for DMA Channel 5 Fault type for DMA Channel 6 Fault type for DMA Channel 6 Fault type for DMA Channel 6 Fault type for DMA Channel 6 Fault type for DMA Channel 7 Fault type for DMA Channel 7 Fault type for DMA Channel 8 Fault type for DMA Channel 8 Fault type for DMA Channel 9 Ch | DMAC_BUS_FTR1 | 0x0044 | W | 0x0 | Fault type for DMA Channel 1 | | DMAC_BUS_FTR4 0x0050 W 0x0 Fault type for DMA Channel 4 DMAC_BUS_FTR5 0x0054 W 0x0 Fault type for DMA Channel 5 - - - - - - DMAC_BUS_CSR 0x0100 W 0x0 Channel Status for DMA Channel 1 DMAC_BUS_CSR 0x0110 W 0x0 Channel Status for DMA Channel 2 DMAC_BUS_CSR 0x0118 W 0x0 Channel Status for DMA Channel 3 DMAC_BUS_CSR 0x0120 W 0x0 Channel Status for DMA Channel 3 DMAC_BUS_CCR 0x0128 W 0x0 Channel Status for DMA Channel 5 DMAC_BUS_CCPC 0x0104 W 0x0 Channel Status for DMA Channel 7 DMAC_BUS_CCPC 0x0104 W 0x0 Channel PC for DMA Channel 0 DMAC_BUS_CCPC 0x0110 W 0x0 Channel PC for DMA Channel 1 DMAC_BUS_CPC 0x0114 W 0x0 Channel PC for DMA Channel 2 DMAC_BUS_CPC 0x0124 W 0x0 Channel PC for DMA | | | | | | | DMAC_BUS_FTR5 0x0054 W 0x0 Fault type for DMA Channel 5 DMAC_BUS_CSR 0x0100 W 0x0 Channel 7 Channel 7 DMAC_BUS_CSR DMAC_BUS_CSR 0x0100 W 0x0 Channel 7 Channel 7 Channel 7 Channel 7 DMAC_BUS_CSR 0x0110 W 0x0 Channel 2 3 Channel 2 Channel 3 Channel 2 Channel 3 Channel 3 Channel 3 Channel 3 Channel 2 Channel 3 Channel 2 Channel 2 Channel 3 Channel 2 <td></td> <td></td> <td></td> <td></td> <td></td> | | | | | | | DMAC_BUS_CSR | DMAC_BUS_FTR4 | 0x0050 | | 0x0 | | | DMAC_BUS_CSR<br>0 0x0100 W 0x0 Channel Channel Channel Channel Channel Status for DMA Channel 1 DMAC_BUS_CSR<br>1 0x0108 W 0x0 Channel Status for DMA Channel 2 DMAC_BUS_CSR<br>2 0x0110 W 0x0 Channel Status for DMA Channel 2 DMAC_BUS_CSR<br>4 0x0118 W 0x0 Channel Status for DMA Channel 3 DMAC_BUS_CSR<br>4 0x0120 W 0x0 Channel Status for DMA Channel 3 DMAC_BUS_CSR<br>4 0x0128 W 0x0 Channel Status for DMA Channel 3 DMAC_BUS_CPC<br>0 0x0104 W 0x0 Channel PC for DMA Channel 0 DMAC_BUS_CPC<br>1 0x0104 W 0x0 Channel PC for DMA Channel 1 DMAC_BUS_CPC<br>2 0x0114 W 0x0 Channel PC for DMA Channel 1 DMAC_BUS_CPC<br>2 0x0112 W 0x0 Channel PC for DMA Channel 3 DMAC_BUS_CPC<br>4 0x0122 W 0x0 Channel PC for DMA Channel 3 DMAC_BUS_SAR<br>0 0x0400 W 0x0 Channel PC for DMA Channel 5 DMAC_BUS_SAR<br>2 <td>DMAC_BUS_FTR5</td> <td>0x0054</td> <td>W</td> <td>0x0</td> <td>Fault type for DMA Channel 5</td> | DMAC_BUS_FTR5 | 0x0054 | W | 0x0 | Fault type for DMA Channel 5 | | 0 0X0100 W 0X0 Channel 0 Channel 1 Channel 1 DMAC_BUS_CSR 0x0110 W 0x0 Channel Status for DMA Channel 1 DMAC_BUS_CSR 2 0x0110 W 0x0 Channel Status for DMA Channel 3 DMAC_BUS_CSR 3 0x0120 W 0x0 Channel Status for DMA Channel 3 DMAC_BUS_CSR 4 0x0128 W 0x0 Channel Status for DMA Channel 4 DMAC_BUS_CPC 0x0104 W 0x0 Channel Status for DMA Channel 5 DMAC_BUS_CPC 0x0104 W 0x0 Channel PC for DMA Channel 0 DMAC_BUS_CPC 0x0104 W 0x0 Channel PC for DMA Channel 0 DMAC_BUS_CPC 0x0114 W 0x0 Channel PC for DMA Channel 1 DMAC_BUS_CPC 0x0124 W 0x0 Channel PC for DMA Channel 2 DMAC_BUS_CPC 0x0124 W 0x0 Channel PC for DMA Channel 3 DMAC_BUS_SAR 0x0400 W 0x0 Channel PC for DMA Channel 5 DMAC_BUS_SAR 0x0440 W 0x0 Channel PC for DMA Channel 5 DMAC_BUS_SAR 0x0440 W 0x0 </td <td>-</td> <td>-</td> <td>ı</td> <td>-</td> <td>reserved</td> | - | - | ı | - | reserved | | 0 0X0100 W 0X0 Channel 0 Channel 1 Channel 1 DMAC_BUS_CSR 0x0110 W 0x0 Channel Status for DMA Channel 1 DMAC_BUS_CSR 2 0x0110 W 0x0 Channel Status for DMA Channel 3 DMAC_BUS_CSR 3 0x0120 W 0x0 Channel Status for DMA Channel 3 DMAC_BUS_CSR 4 0x0128 W 0x0 Channel Status for DMA Channel 4 DMAC_BUS_CPC 0x0104 W 0x0 Channel Status for DMA Channel 5 DMAC_BUS_CPC 0x0104 W 0x0 Channel PC for DMA Channel 0 DMAC_BUS_CPC 0x0104 W 0x0 Channel PC for DMA Channel 0 DMAC_BUS_CPC 0x0114 W 0x0 Channel PC for DMA Channel 1 DMAC_BUS_CPC 0x0124 W 0x0 Channel PC for DMA Channel 2 DMAC_BUS_CPC 0x0124 W 0x0 Channel PC for DMA Channel 3 DMAC_BUS_SAR 0x0400 W 0x0 Channel PC for DMA Channel 5 DMAC_BUS_SAR 0x0440 W 0x0 Channel PC for DMA Channel 5 DMAC_BUS_SAR 0x0440 W 0x0 </td <td>DMAC BUS CSR</td> <td>0.0100</td> <td>147</td> <td>0.0</td> <td>Channel Status for DMA</td> | DMAC BUS CSR | 0.0100 | 147 | 0.0 | Channel Status for DMA | | DMAC_BUS_CSR 1 0x0108 W 0x0 Channel Status for DMA Channel 1 DMAC_BUS_CSR 2 0x0110 W 0x0 Channel Status for DMA Channel 2 DMAC_BUS_CSR 3 0x0118 W 0x0 Channel Status for DMA Channel 3 DMAC_BUS_CSR 4 0x0120 W 0x0 Channel Status for DMA Channel 3 DMAC_BUS_CSR 5 0x0128 W 0x0 Channel Status for DMA Channel 5 DMAC_BUS_CPC 0 0x0104 W 0x0 Channel PC for DMA Channel 0 DMAC_BUS_CPC 0 0x0104 W 0x0 Channel PC for DMA Channel 0 DMAC_BUS_CPC 0 0x0114 W 0x0 Channel PC for DMA Channel 1 DMAC_BUS_CPC 0 0x011c W 0x0 Channel PC for DMA Channel 2 DMAC_BUS_CPC 0 0x0124 W 0x0 Channel PC for DMA Channel 3 DMAC_BUS_SAR 0 0x0400 W 0x0 Channel PC for DMA Channel 3 DMAC_BUS_SAR 0x0440 W 0x0 Channel PC for DMA Channel 5 DMAC_BUS_SAR 0x0440 W 0x0 Source Addres | | 0X0100 | VV | UXU | | | 1 | DMAC BUS CSR | | | | | | DMAC_BUS_CSR 0x0110 W 0x0 Channel Status for DMA Channel 2 DMAC_BUS_CSR 0x0118 W 0x0 Channel Status for DMA Channel 3 DMAC_BUS_CSR 0x0120 W 0x0 Channel Status for DMA Channel 3 DMAC_BUS_CSR 0x0128 W 0x0 Channel Status for DMA Channel 5 DMAC_BUS_CPC 0x0104 W 0x0 Channel PC for DMA Channel 0 DMAC_BUS_CPC 0x010c W 0x0 Channel PC for DMA Channel 1 DMAC_BUS_CPC 0x011d W 0x0 Channel PC for DMA Channel 1 DMAC_BUS_CPC 0x011c W 0x0 Channel PC for DMA Channel 2 DMAC_BUS_CPC 0x012d W 0x0 Channel PC for DMA Channel 3 DMAC_BUS_SAR 0x0400 W 0x0 Channel PC for DMA Channel 3 DMAC_BUS_SAR 0x0440 W 0x0 Channel PC for DMA Channel 5 DMAC_BUS_SAR 0x0440 W 0x0 Channel PC for DMA Channel 5 DMAC_BUS_SAR 0x0440 W 0x0 Sourc | | 0x0108 | W | 0x0 | | | DMAC_BUS_CPC Ox0114 W | | | | | | | DMAC_BUS_CSR 0x0118 W 0x0 Channel Status for DMA Channel 3 DMAC_BUS_CSR 0x0120 W 0x0 Channel Status for DMA Channel 4 DMAC_BUS_CSR 0x0128 W 0x0 Channel Status for DMA Channel 5 DMAC_BUS_CPC 0x0104 W 0x0 Channel PC for DMA Channel 0 DMAC_BUS_CPC 0x010c W 0x0 Channel PC for DMA Channel 0 DMAC_BUS_CPC 0x0114 W 0x0 Channel PC for DMA Channel 1 DMAC_BUS_CPC 0x011c W 0x0 Channel PC for DMA Channel 3 DMAC_BUS_CPC 0x012d W 0x0 Channel PC for DMA Channel 3 DMAC_BUS_SAR 0x0400 W 0x0 Channel PC for DMA Channel 3 DMAC_BUS_SAR 0x0400 W 0x0 Channel PC for DMA Channel 3 DMAC_BUS_SAR 0x0420 W 0x0 Channel PC for DMA Channel 5 DMAC_BUS_SAR 0x0440 W 0x0 Source Address for DMA Channel 5 DMAC_BUS_SAR 0x0440 W 0x0 Sourc | | 0x0110 | W | 0x0 | | | 3 | | | | | | | DMAC_BUS_CSR | | 0x0118 | W | 0x0 | | | 4 0x0120 W 0x0 Channel 4 DMAC_BUS_CSR 5 0x0128 W 0x0 Channel Status for DMA Channel 5 DMAC_BUS_CPC 0 0x0104 W 0x0 Channel PC for DMA Channel 0 DMAC_BUS_CPC 1 0x010c W 0x0 Channel PC for DMA Channel 1 DMAC_BUS_CPC 2 0x0114 W 0x0 Channel PC for DMA Channel 2 DMAC_BUS_CPC 3 0x011c W 0x0 Channel PC for DMA Channel 3 DMAC_BUS_CPC 4 0x012d W 0x0 Channel PC for DMA Channel 4 DMAC_BUS_CPC 5 0x012c W 0x0 Channel PC for DMA Channel 4 DMAC_BUS_SAR 0x0400 0x0400 W 0x0 Source Address for DMA Channel 5 DMAC_BUS_SAR 1 0x0420 W 0x0 Source Address for DMA Channel 1 DMAC_BUS_SAR 2 0x0440 W 0x0 Source Address for DMA Channel 2 DMAC_BUS_SAR 3 0x0460 W 0x0 Source Address for DMA Channel 2 DMAC_BUS_DAR 3 0x0440 W 0x0 So | | | | | | | DMAC_BUS_CPC DMAC_BUS_SAR DMAC_BUS_DAR DMAC_ | DMAC_BUS_CSR | 0x0120 | \٨/ | 0×0 | | | DMAC_BUS_CPC DMAC_BUS_SAR DMAC_BUS_DAR DMAC_ | 4 | 0.0120 | V V | 0.00 | Channel 4 | | DMAC_BUS_CPC 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | DMAC_BUS_CSR | 0v0120 | ۱۸/ | 0.40 | Channel Status for DMA | | DMAC_BUS_CPC DMAC_BUS_SAR DMAC_BUS_DAR DMAC_BUS_CCR DMACABUS DMA | 5 | UXU128 | VV | UXU | Channel 5 | | DMAC_BUS_CPC DMAC_BUS_SAR DMAC_BUS_DAR DMAC_BUS_CCR DMACABUS DMA | DMAC BUS CPC | 0.0101 | | 0 0 | | | DMAC_BUS_CPC 1 DMAC_BUS_CPC 2 DMAC_BUS_CPC 2 DMAC_BUS_CPC 3 DMAC_BUS_CPC 3 DMAC_BUS_CPC 3 DMAC_BUS_CPC 3 DMAC_BUS_CPC 3 DMAC_BUS_CPC 4 DMAC_BUS_CPC 5 DMAC_BUS_CPC 5 DMAC_BUS_SAR 0 0x0420 DMAC_BUS_SAR 1 DMAC_BUS_SAR 3 DMAC_BUS_SAR 3 DMAC_BUS_SAR 4 DMAC_BUS_SAR 4 DMAC_BUS_SAR 3 DMAC_BUS_SAR 4 DMAC_BUS_SAR 5 DMAC_BUS_SAR 0x0440 W 0x0 DMAC_BUS_SAR 3 DMAC_BUS_SAR 4 DMAC_BUS_SAR 4 DMAC_BUS_SAR 5 DMAC_BUS_SAR 4 DMAC_BUS_SAR 5 DMAC_BUS_SAR 5 DMAC_BUS_SAR 6 DMAC_BUS_SAR 6 DMAC_BUS_SAR 7 DMAC_BUS_DAR DMAC_BUS_CCR 7 DMAC DM | | 0x0104 | W | 0x0 | Channel PC for DMA Channel 0 | | DMAC_BUS_CPC DMAC_BUS_CPC Nov0114 W 0x0 Channel PC for DMA Channel 2 DMAC_BUS_CPC CALL DMAC_BUS_CPC DMAC_BUS_CPC CALL DMAC_BUS_CPC CALL DMAC_BUS_CPC CALL DMAC_BUS_CPC CALL DMAC_BUS_CPC CALL DMAC_BUS_CPC CALL DMAC_BUS_SAR CALL DMAC_BUS_SAR CALL CALL DMAC_BUS_SAR CALL CALL CALL CALL CALL CALL CALL CA | - | | | | A (2) Y | | DMAC_BUS_CPC 2 DMAC_BUS_CPC 3 DMAC_BUS_CPC 3 DMAC_BUS_CPC 4 0x011c W 0x0 Channel PC for DMA Channel 2 Channel PC for DMA Channel 3 DMAC_BUS_CPC 4 DMAC_BUS_CPC 5 0x012c W 0x0 Channel PC for DMA Channel 4 DMAC_BUS_SAR 0x0400 W 0x0 Channel PC for DMA Channel 5 DMAC_BUS_SAR 0x0400 W 0x0 Channel PC for DMA Channel 5 Source Address for DMA Channel 0 Source Address for DMA Channel 1 Channel 1 DMAC_BUS_SAR 1 DMAC_BUS_SAR 0x0440 W 0x0 Source Address for DMA Channel 2 DMAC_BUS_SAR 3 DMAC_BUS_SAR 0x0440 W 0x0 Source Address for DMA Channel 3 Source Address for DMA Channel 3 Source Address for DMA Channel 3 DMAC_BUS_SAR 0x0460 W 0x0 Source Address for DMA Channel 4 DMAC_BUS_SAR 0x0480 W 0x0 Source Address for DMA Channel 5 DMAC_BUS_DAR 0x0440 W 0x0 Dest Address for DMAChannel 5 DMAC_BUS_DAR 0x0404 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x0404 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x0404 W 0x0 Dest Address for DMAChannel 3 DMAC_BUS_DAR 0x0404 W 0x0 Dest Address for DMAChannel 3 DMAC_BUS_DAR 0x0404 W 0x0 Dest Address for DMAChannel 3 DMAC_BUS_DAR 0x0404 W 0x0 Dest Address for DMAChannel 3 DMAC_BUS_DAR 0x0404 W 0x0 Dest Address for DMAChannel 3 DMAC_BUS_DAR 0x0404 W 0x0 Dest Address for DMAChannel 3 DMAC_BUS_DAR 0x0404 W 0x0 Dest Address for DMAChannel 3 DMAC_BUS_DAR 0x0404 W 0x0 Dest Address for DMAChannel 3 DMAC_BUS_DAR 0x0404 W 0x0 Dest Address for DMAChannel 4 DMAC_BUS_DAR 0x0404 W 0x0 Dest Address for DMAChannel 5 DMAC_BUS_DAR 0x0404 W 0x0 Dest Address for DMAChannel 5 DMAC_BUS_DAR 0x0404 W 0x0 Dest Address for DMAChannel 5 DMAC_BUS_DAR 0x0404 W 0x0 Dest Address for DMAChannel 5 DMAC_BUS_DAR 0x0404 W 0x0 Dest Address for DMAChannel 5 DMAC_BUS_DAR 0x0404 W 0x0 Dest Address for DMAChannel 5 DMAC_BUS_DAR 0x0404 W 0x0 Dest Address for DMAChannel 6 DMAC_BUS_DAR 0x0404 W 0x0 Dest Address for DMAChannel 6 DMAC_BUS_DAR 0x0404 W 0x0 Dest Address for DMAChannel 6 DMAC_BUS_DAR 0x0404 W 0x0 Dest Address for DMAChannel 6 DMAC_BUS_DAR 0x0404 W 0x0 Dest Address for DMAChannel 6 DMAC_BUS_DAR 0x0404 W 0x0 DMAC_BUS_DA | I . — — | 0x010c | W | 0x0 | Channel PC for DMA Channel 1 | | DMAC_BUS_CPC DMAC_BUS_CPC DMAC_BUS_CPC DMAC_BUS_CPC DMAC_BUS_CPC DMAC_BUS_CPC S DMAC_BUS_CPC S DMAC_BUS_SAR Ox0400 DMAC_BUS_SAR S DMAC_BUS_SAR Ox0420 DMAC_BUS_SAR S DMAC_BUS_SAR Ox0440 DMAC_BUS_SAR S DMAC_BUS_SAR Ox0440 DMAC_BUS_SAR S DMAC_BUS_SAR Ox0440 DMAC_BUS_SAR S DMAC_BUS_SAR Ox0440 DMAC_BUS_SAR S DMAC_BUS_SAR Ox0460 DMAC_BUS_SAR S DMAC_BUS_SAR Ox0480 DMAC_BUS_SAR S DMAC_BUS_SAR S DMAC_BUS_SAR Ox0440 DMAC_BUS_SAR S DMAC_BUS_SAR Ox0440 DMAC_BUS_SAR S DMAC_BUS_SAR Ox0460 DMAC_BUS_SAR S DMAC_BUS_SAR Ox0440 DMAC_BUS_SAR S DMAC_BUS_SAR Ox0440 DMAC_BUS_SAR S DMAC_BUS_SAR Ox0440 DMAC_BUS_CAR Ox0440 DMAC_BUS_CAR Ox0440 DMAC_BUS_CAR Ox0440 DMAC_BUS_DAR Ox0440 DMAC_BUS_DAR Ox0444 D | | | | | • | | DMAC_BUS_CPC 3 DMAC_BUS_CPC 4 0x0124 W 0x0 Channel PC for DMA Channel 3 DMAC_BUS_CPC 5 0x012c W 0x0 Channel PC for DMA Channel 4 DMAC_BUS_SAR 0 0x0400 W 0x0 DMAC_BUS_SAR 0 0x0420 W 0x0 Source Address for DMA Channel 0 Source Address for DMA Channel 1 Source Address for DMA Channel 2 DMAC_BUS_SAR 0x0440 W 0x0 DMAC_BUS_SAR 0x0440 W 0x0 Source Address for DMA Channel 2 Source Address for DMA Channel 3 Source Address for DMA Channel 3 Source Address for DMA Channel 3 Source Address for DMA Channel 3 Source Address for DMA Channel 3 Source Address for DMA Channel 4 Source Address for DMA Channel 4 Source Address for DMA Channel 5 DMAC_BUS_SAR 0x0480 W 0x0 DMAC_BUS_SAR 0x0480 W 0x0 DMAC_BUS_DAR 0x0404 W 0x0 Dest Address for DMAChannel 0 DMAC_BUS_DAR 0x0424 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x0444 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x0464 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x0464 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x0464 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x0464 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x04 | | 0x0114 | W | 0x0 | Channel PC for DMA Channel 2 | | DMAC_BUS_SAR Ox0440 W Ox0 Source Address for DMA Channel 3 DMAC_BUS_SAR Ox0440 W Ox0 Source Address for DMA Channel 1 DMAC_BUS_SAR Ox0420 W Ox0 Source Address for DMA Channel 1 DMAC_BUS_SAR Ox0440 W Ox0 Source Address for DMA Channel 1 DMAC_BUS_SAR Ox0440 W Ox0 Source Address for DMA Channel 1 DMAC_BUS_SAR Ox0440 W Ox0 Source Address for DMA Channel 2 DMAC_BUS_SAR Ox0460 W Ox0 Source Address for DMA Channel 3 DMAC_BUS_SAR Ox0480 W Ox0 Source Address for DMA Channel 3 DMAC_BUS_SAR Ox0440 W Ox0 Source Address for DMA Channel 3 DMAC_BUS_SAR Ox0480 W Ox0 Source Address for DMA Channel 4 DMAC_BUS_SAR Ox0440 W Ox0 Dest Address for DMA Channel 5 DMAC_BUS_DAR Ox0404 W Ox0 Dest Address for DMAChannel 1 DMAC_BUS_DAR Ox0424 W Ox0 Dest Address for DMAChannel 1 DMAC_BUS_DAR Ox0444 W Ox0 Dest Address for DMAChannel 2 DMAC_BUS_DAR Ox0464 W Ox0 Dest Address for DMAChannel 3 DMAC_BUS_DAR Ox0464 W Ox0 Dest Address for DMAChannel 3 DMAC_BUS_DAR Ox0464 W Ox0 Dest Address for DMAChannel 3 DMAC_BUS_DAR Ox0464 W Ox0 Dest Address for DMAChannel 3 DMAC_BUS_DAR Ox0464 W Ox0 Dest Address for DMAChannel 3 DMAC_BUS_DAR Ox0484 W Ox0 Dest Address for DMAChannel 4 DMAC_BUS_DAR Ox0484 W Ox0 Dest Address for DMAChannel 5 DMAC_BUS_DAR Ox0484 W Ox0 Dest Address for DMAChannel 5 DMAC_BUS_DAR Ox0484 W Ox0 Dest Address for DMAChannel 5 DMAC_BUS_DAR Ox0484 W Ox0 Dest Address for DMAChannel 5 DMAC_BUS_DAR Ox0488 W Ox0 Channel Control for DMA | | | | | X | | DMAC_BUS_CPC DMAC_BUS_CPC DMAC_BUS_SAR O DMAC_BUS_DAR DMAC_BUS_CCR O DMAC_BUS_CCR O DMAC_BUS_CCR O DMAC_BUS_CCR O DMAC_BUS_CCR O DMAC Channel Control for DMA | | 0x011c | W | 0x0 | Channel PC for DMA Channel 3 | | DMAC_BUS_SAR | | | | | | | DMAC_BUS_CPC 0x012c W 0x0 Channel PC for DMA Channel 5 DMAC_BUS_SAR 0x0400 W 0x0 Source Address for DMA Channel 0 DMAC_BUS_SAR 0x0420 W 0x0 Source Address for DMA Channel 1 DMAC_BUS_SAR 0x0440 W 0x0 Source Address for DMA Channel 2 DMAC_BUS_SAR 0x0460 W 0x0 Source Address for DMA Channel 3 DMAC_BUS_SAR 0x0480 W 0x0 Source Address for DMA Channel 3 DMAC_BUS_SAR 0x04a0 W 0x0 Source Address for DMA Channel 4 DMAC_BUS_DAR 0x04a0 W 0x0 Dest Address for DMA Channel 5 DMAC_BUS_DAR 0x0404 W 0x0 Dest Address for DMA Channel 1 DMAC_BUS_DAR 0x0424 W 0x0 Dest Address for DMA Channel 2 DMAC_BUS_DAR 0x0464 W 0x0 Dest Address for DMA Channel 3 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMA Channel 4 DMAC_BUS_DAR 0x0484 W 0x0 | DMAC_BUS_CPC | 0x0124 | \٨/ | 0×0 | Channel PC for DMA Channel 4 | | DMAC_BUS_SAR 0x0440 W 0x0 Source Address for DMA Channel 1 DMAC_BUS_SAR 0x0440 W 0x0 Source Address for DMA Channel 1 DMAC_BUS_SAR 0x0440 W 0x0 Source Address for DMA Channel 2 DMAC_BUS_SAR 0x0460 W 0x0 Source Address for DMA Channel 2 DMAC_BUS_SAR 0x0460 W 0x0 Source Address for DMA Channel 3 DMAC_BUS_SAR 0x0480 W 0x0 Source Address for DMA Channel 3 DMAC_BUS_SAR 0x0480 W 0x0 Source Address for DMA Channel 4 DMAC_BUS_SAR 0x0440 W 0x0 Source Address for DMA Channel 5 DMAC_BUS_DAR 0x0440 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x0424 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x0444 W 0x0 Dest Address for DMAChannel 2 DMAC_BUS_DAR 0x0464 W 0x0 Dest Address for DMAChannel 3 DMAC_BUS_DAR 0x0464 W 0x0 Dest Address for DMAChannel 3 DMAC_BUS_DAR 0x0464 W 0x0 Dest Address for DMAChannel 4 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 5 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 5 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 5 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 5 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 5 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 5 DMAC_BUS_DAR 0x0488 W 0x0 Channel Control for DMA | 4 | 0.0121 | • • • | ONO | Chamier Color Drive Chamier 1 | | DMAC_BUS_SAR 0x0400 W 0x0 Source Address for DMA Channel 0 DMAC_BUS_SAR 1 0x0420 W 0x0 Source Address for DMA Channel 1 DMAC_BUS_SAR 2 0x0440 W 0x0 Source Address for DMA Channel 2 DMAC_BUS_SAR 3 0x0460 W 0x0 Source Address for DMA Channel 3 DMAC_BUS_SAR 0x0480 W 0x0 Source Address for DMA Channel 3 DMAC_BUS_SAR 0x0480 W 0x0 Source Address for DMA Channel 4 DMAC_BUS_SAR 0x0480 W 0x0 Source Address for DMA Channel 5 DMAC_BUS_DAR 0x0440 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x0424 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x0444 W 0x0 Dest Address for DMAChannel 2 DMAC_BUS_DAR 0x0444 W 0x0 Dest Address for DMAChannel 2 DMAC_BUS_DAR 0x0464 W 0x0 Dest Address for DMAChannel 3 DMAC_BUS_DAR 0x0464 W 0x0 Dest Address for DMAChannel 3 DMAC_BUS_DAR 0x0464 W 0x0 Dest Address for DMAChannel 4 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 5 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 5 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 5 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 5 DMAC_BUS_CCR 0x0408 W 0x0 Channel Control for DMA | DMAC_BUS_CPC | 0v012c | ۱۸/ | 0×0 | Channel BC for DMA Channel 5 | | DMAC_BUS_DAR Ox0420 W Ox0 Channel 0 DMAC_BUS_SAR 1 DMAC_BUS_SAR 2 DMAC_BUS_SAR 3 DMAC_BUS_SAR 4 DMAC_BUS_DAR 5 DMAC_BUS_DAR 1 DMAC_BUS_DAR 1 DMAC_BUS_DAR 2 DMAC_BUS_DAR 3 DMAC_BUS_DAR 3 DMAC_BUS_DAR 3 DMAC_BUS_DAR 4 DMAC_BUS_DAR 4 DMAC_BUS_DAR 5 DMAC_BUS_DAR 5 DMAC_BUS_DAR 6 DMAC_BUS_DAR 7 DMAC_BUS_CCR DMAC_BUS_ | 5 | 0.0120 | VV | 0.00 | Chairle FC 101 DMA Chairle 3 | | DMAC_BUS_SAR 1 0x0420 W 0x0 Source Address for DMA Channel 1 DMAC_BUS_SAR 2 0x0440 W 0x0 Source Address for DMA Channel 2 DMAC_BUS_SAR 3 0x0460 W 0x0 Source Address for DMA Channel 3 DMAC_BUS_SAR 4 0x0480 W 0x0 Source Address for DMA Channel 3 DMAC_BUS_SAR 0x0480 W 0x0 Source Address for DMA Channel 4 DMAC_BUS_SAR 0x04a0 W 0x0 Source Address for DMA Channel 5 DMAC_BUS_DAR 0x04a0 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x0424 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x0444 W 0x0 Dest Address for DMAChannel 2 DMAC_BUS_DAR 0x0444 W 0x0 Dest Address for DMAChannel 2 DMAC_BUS_DAR 0x0464 W 0x0 Dest Address for DMAChannel 3 DMAC_BUS_DAR 0x0464 W 0x0 Dest Address for DMAChannel 3 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 4 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 4 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 5 DMAC_BUS_CCR 0x0488 W 0x0 Channel Control for DMA | DMAC_BUS_SAR | 0,0400 | 147 | 00 | Source Address for DMA | | 10x0420W0x0Channel 1DMAC_BUS_SAR<br>20x0440W0x0Source Address for DMA<br>Channel 2DMAC_BUS_SAR<br>30x0460W0x0Source Address for DMA<br>Channel 3DMAC_BUS_SAR<br>40x0480W0x0Source Address for DMA<br>Channel 4DMAC_BUS_SAR<br>50x04a0W0x0Source Address for DMA<br>Channel 5DMAC_BUS_DAR<br>00x0404W0x0Dest Address for DMAChannel<br>0DMAC_BUS_DAR<br>20x0424W0x0Dest Address for DMAChannel<br>1DMAC_BUS_DAR<br>30x0444W0x0Dest Address for DMAChannel<br>2DMAC_BUS_DAR<br>40x0464W0x0Dest Address for DMAChannel<br>3DMAC_BUS_DAR<br>40x0484W0x0Dest Address for DMAChannel<br>4DMAC_BUS_DAR<br>50x04a4W0x0Dest Address for DMAChannel<br>4DMAC_BUS_CCR0x04a4W0x0Dest Address for DMAChannel<br>5DMAC_BUS_CCR0x04a8W0x0Dest Address for DMAChannel<br>5 | 0 | UXU4UU | VV | UXU | Channel 0 | | 10x0420W0x0Channel 1DMAC_BUS_SAR<br>20x0440W0x0Source Address for DMA<br>Channel 2DMAC_BUS_SAR<br>30x0460W0x0Source Address for DMA<br>Channel 3DMAC_BUS_SAR<br>40x0480W0x0Source Address for DMA<br>Channel 4DMAC_BUS_SAR<br>50x04a0W0x0Source Address for DMA<br>Channel 5DMAC_BUS_DAR<br>00x0404W0x0Dest Address for DMAChannel<br>0DMAC_BUS_DAR<br>20x0424W0x0Dest Address for DMAChannel<br>1DMAC_BUS_DAR<br>30x0444W0x0Dest Address for DMAChannel<br>2DMAC_BUS_DAR<br>40x0464W0x0Dest Address for DMAChannel<br>3DMAC_BUS_DAR<br>40x0484W0x0Dest Address for DMAChannel<br>4DMAC_BUS_DAR<br>50x04a4W0x0Dest Address for DMAChannel<br>4DMAC_BUS_CCR0x04a4W0x0Dest Address for DMAChannel<br>5DMAC_BUS_CCR0x04a8W0x0Dest Address for DMAChannel<br>5 | DMAC BUS SAR | 0.0400 | | | Source Address for DMA | | DMAC_BUS_SAR 2 0x0440 W 0x0 Source Address for DMA Channel 2 DMAC_BUS_SAR 3 0x0460 W 0x0 Source Address for DMA Channel 3 DMAC_BUS_SAR 0x0480 W 0x0 Source Address for DMA Channel 3 DMAC_BUS_SAR 0x0480 W 0x0 Source Address for DMA Channel 4 DMAC_BUS_SAR 0x04a0 W 0x0 Source Address for DMA Channel 5 DMAC_BUS_DAR 0x0440 W 0x0 Dest Address for DMAChannel 0 DMAC_BUS_DAR 0x0424 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x0444 W 0x0 Dest Address for DMAChannel 2 DMAC_BUS_DAR 0x0464 W 0x0 Dest Address for DMAChannel 3 DMAC_BUS_DAR 0x0464 W 0x0 Dest Address for DMAChannel 3 DMAC_BUS_DAR 0x0464 W 0x0 Dest Address for DMAChannel 3 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 4 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 5 DMAC_BUS_CCR 0x0408 W 0x0 Channel Control for DMA | | 0x0420 | W | 0x0 | | | DMAC_BUS_SAR | | | | | | | DMAC_BUS_SAR 3 0x0460 W 0x0 Source Address for DMA Channel 3 DMAC_BUS_SAR 4 0x0480 W 0x0 Source Address for DMA Channel 4 DMAC_BUS_SAR 5 0x04a0 W 0x0 Source Address for DMA Channel 4 DMAC_BUS_SAR 0x04a0 W 0x0 Dest Address for DMA Channel 5 DMAC_BUS_DAR 0x0404 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x0424 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x0444 W 0x0 Dest Address for DMAChannel 2 DMAC_BUS_DAR 0x0464 W 0x0 Dest Address for DMAChannel 3 DMAC_BUS_DAR 0x0464 W 0x0 Dest Address for DMAChannel 3 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 3 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 4 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 5 DMAC_BUS_CCR 0x0408 W 0x0 Channel Control for DMA | | 0x0440 | W | 0x0 | | | DMAC_BUS_SAR Ox0480 W Ox0 Channel 3 Source Address for DMA Channel 4 DMAC_BUS_SAR Ox04a0 W Ox0 Source Address for DMA Channel 4 Source Address for DMA Channel 5 DMAC_BUS_DAR Ox0404 W Ox0 Dest Address for DMAChannel Ox0424 DMAC_BUS_DAR Ox0444 W Ox0 Dest Address for DMAChannel Ox0424 DMAC_BUS_DAR Ox0444 W Ox0 Dest Address for DMAChannel Ox0464 DMAC_BUS_DAR Ox0464 W Ox0 Dest Address for DMAChannel Ox0464 DMAC_BUS_DAR Ox0464 W Ox0 Dest Address for DMAChannel Ox0464 DMAC_BUS_DAR Ox0484 W Ox0 Dest Address for DMAChannel Ox0484 DMAC_BUS_DAR Ox0484 DMAC_BUS_DAR Ox0484 DMAC_BUS_CCR Ox0408 DMAC_BUS_CCR Ox0408 Channel 3 Channel Control for DMA Channel Channel Control for DMA Channel Ox0408 Channel 3 Channel Control for DMA Channel | | A 1 | | | | | DMAC_BUS_SAR 4 0x0480 W 0x0 Source Address for DMA Channel 4 DMAC_BUS_SAR 5 0x04a0 W 0x0 Source Address for DMA Channel 5 DMAC_BUS_DAR 0x0404 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x0424 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x0444 W 0x0 Dest Address for DMAChannel 2 DMAC_BUS_DAR 0x0464 W 0x0 Dest Address for DMAChannel 3 DMAC_BUS_DAR 0x0464 W 0x0 Dest Address for DMAChannel 3 DMAC_BUS_DAR 0x0464 W 0x0 Dest Address for DMAChannel 3 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 4 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 5 DMAC_BUS_CCR 0x0408 W 0x0 Channel Control for DMA | | 0x0460 | W | 0x0 | | | 40x0480W0x0Channel 4DMAC_BUS_SAR<br>50x04a0W0x0Source Address for DMA<br>Channel 5DMAC_BUS_DAR<br>00x0404W0x0Dest Address for DMAChannel<br>0DMAC_BUS_DAR<br>20x0424W0x0Dest Address for DMAChannel<br>1DMAC_BUS_DAR<br>30x0444W0x0Dest Address for DMAChannel<br>2DMAC_BUS_DAR<br>40x0464W0x0Dest Address for DMAChannel<br>3DMAC_BUS_DAR<br>40x0484W0x0Dest Address for DMAChannel<br>4DMAC_BUS_DAR<br>50x04a4W0x0Dest Address for DMAChannel<br>4DMAC_BUS_CCR<br>DMAC_BUS_CCR0x0408W0x0Dest Address for DMAChannel<br>5DMAC_BUS_CCR<br>DMAC_BUS_CCR0x0408W0x0Channel Control for DMA | | | | | | | DMAC_BUS_DAR 0x04a0 W 0x0 Source Address for DMA Channel 5 DMAC_BUS_DAR 0x0404 W 0x0 Dest Address for DMAChannel 0 DMAC_BUS_DAR 0x0424 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x0444 W 0x0 Dest Address for DMAChannel 2 DMAC_BUS_DAR 0x0444 W 0x0 Dest Address for DMAChannel 2 DMAC_BUS_DAR 0x0464 W 0x0 Dest Address for DMAChannel 3 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 4 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 4 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 5 DMAC_BUS_CCR 0x0408 W 0x0 Channel Control for DMA | | 0x0480 | W | 0x0 | | | DMAC_BUS_DAR 0x0404 W 0x0 Dest Address for DMAChannel 0 DMAC_BUS_DAR 0x0424 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x0424 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x0444 W 0x0 Dest Address for DMAChannel 2 DMAC_BUS_DAR 0x0464 W 0x0 Dest Address for DMAChannel 3 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 4 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 4 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 5 DMAC_BUS_CCR 0x0408 W 0x0 Channel Control for DMA | | | | | i | | DMAC_BUS_DAR 0x0404 W 0x0 Dest Address for DMAChannel 0 DMAC_BUS_DAR 1 0x0424 W 0x0 Dest Address for DMAChannel 1 DMAC_BUS_DAR 0x0444 W 0x0 Dest Address for DMAChannel 2 DMAC_BUS_DAR 0x0464 W 0x0 Dest Address for DMAChannel 3 DMAC_BUS_DAR 0x0464 W 0x0 Dest Address for DMAChannel 3 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 4 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 5 DMAC_BUS_CCR 0x0408 W 0x0 Channel Control for DMAChannel 5 | | 0x04a0 | w | 0x0 | | | 00x0404W0x00DMAC_BUS_DAR<br>10x0424W0x0Dest Address for DMAChannel<br>1DMAC_BUS_DAR<br>30x0444W0x0Dest Address for DMAChannel<br>2DMAC_BUS_DAR<br>40x0464W0x0Dest Address for DMAChannel<br>3DMAC_BUS_DAR<br>40x0484W0x0Dest Address for DMAChannel<br>4DMAC_BUS_DAR<br>50x04a4W0x0Dest Address for DMAChannel<br>5DMAC_BUS_CCR0x04a8W0x0Channel Control for DMA | | one rue | | | | | DMAC_BUS_DAR 1 0x0424 W 0x0 Dest Address for DMAChannel 1 Dest Address for DMAChannel 2 Dest Address for DMAChannel 2 Dest Address for DMAChannel 2 Dest Address for DMAChannel 3 Dest Address for DMAChannel 3 Dest Address for DMAChannel 4 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 4 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 5 DMAC_BUS_CCR 0x0408 W 0x0 Channel Control for DMA | DMAC_BUS_DAR | 0×0404 | <b>\</b> \\ | 0~0 | Dest Address for DMAChannel | | 1 DMAC_BUS_DAR 2 DMAC_BUS_DAR 3 DMAC_BUS_DAR 0x0464 W 0x0 DMAC_BUS_DAR 0x0464 W 0x0 DMAC_BUS_DAR 0x0484 W 0x0 DMAC_BUS_DAR 0x0484 W 0x0 DMAC_BUS_DAR 0x0484 W 0x0 DMAC_BUS_DAR 0x0484 W 0x0 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 4 DMAC_BUS_CCR 0x0408 W 0x0 Channel Control for DMA | 0 | 0,0404 | VV | 0.00 | 0 | | DMAC_BUS_DAR 0x0444 W 0x0 Dest Address for DMAChannel 2 DMAC_BUS_DAR 0x0464 W 0x0 Dest Address for DMAChannel 3 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 4 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 5 DMAC_BUS_CCR 0x0408 W 0x0 Channel Control for DMA | DMAC_BUS_DAR | 0,0424 | ۱۸/ | 0.40 | Dest Address for DMAChannel | | DMAC_BUS_DAR 0x0464 W 0x0 Dest Address for DMAChannel 3 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 4 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 4 DMAC_BUS_DAR 0x04a4 W 0x0 Dest Address for DMAChannel 5 DMAC_BUS_CCR 0x0408 W 0x0 Channel Control for DMA | 1 | UXU424 | VV | UXU | 1 | | DMAC_BUS_DAR 0x0464 W 0x0 Dest Address for DMAChannel 3 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 4 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 4 DMAC_BUS_DAR 0x04a4 W 0x0 Dest Address for DMAChannel 5 DMAC_BUS_CCR 0x0408 W 0x0 Channel Control for DMA | DMAC BUS DAR | | | | Dest Address for DMAChannel | | DMAC_BUS_DAR 0x0464 W 0x0 Dest Address for DMAChannel 3 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 4 DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 5 DMAC_BUS_CCR 0x0408 W 0x0 Channel Control for DMA | I | 0x0444 | W | 0x0 | | | 3UXU464WUXUDMAC_BUS_DAR<br>40x0484W0x0Dest Address for DMAChannel<br>4DMAC_BUS_DAR<br>50x04a4W0x0Dest Address for DMAChannel<br>5DMAC_BUS_CCR0x0408W0x0Channel Control for DMA | | | | | _ | | DMAC_BUS_DAR 0x0484 W 0x0 Dest Address for DMAChannel 4 DMAC_BUS_DAR 0x04a4 W 0x0 Dest Address for DMAChannel 5 DMAC_BUS_CCR 0x0408 W 0x0 Channel Control for DMA | | 0x0464 | W | 0x0 | | | DMAC_BUS_CCR | | | | | | | DMAC_BUS_DAR 0x04a4 W 0x0 Dest Address for DMAChannel 5 DMAC_BUS_CCR 0x0408 W 0x0 Channel Control for DMA | | 0x0484 | W | 0x0 | | | 5 DMAC_BUS_CCR Ox0408 W Ox0 5 Channel Control for DMA | | | | | | | DMAC_BUS_CCR OxO408 W OxO Channel Control for DMA | | 0x04a4 | W | 0x0 | | | | | | | | | | 0 Channel 0 | | 0x0408 | W | 0×0 | | | | 0 | 2//3/100 | •• | | Channel 0 | | DMAC_BUS_CCR 0x DMAC_BUS_CCR 0x DMAC_BUS_CCR 0x | <ul><li>(0428)</li><li>(0448)</li><li>(0468)</li><li>(0488)</li></ul> | W<br>W | 0x0<br>0x0 | Channel Control for DMA Channel 1 Channel Control for DMA Channel 2 | |---------------------------------------------------|-----------------------------------------------------------------------|--------|------------|---------------------------------------------------------------------| | DMAC_BUS_CCR 0x DMAC_BUS_CCR 0x | (0468 | | 0x0 | | | DMAC_BUS_CCR 0x DMAC_BUS_CCR 0x | | W | | COMMENT | | DMAC_BUS_CCR Ox | ·0488 | | 0x0 | Channel Control for DMA<br>Channel 3 | | 4 | 10400 | W | 0x0 | Channel Control for DMA<br>Channel 4 | | DMAC_BUS_CCR 0x | (04a8 | W | 0x0 | Channel Control for DMA<br>Channel 5 | | DMAC BUS LCO | (040C | W | 0x0 | Loop Counter 0 for DMA<br>Channel 0 | | DMAC_BUS_LCO_ 0x | (042C | W | 0x0 | Loop Counter 0 for DMA<br>Channel 1 | | DMAC_BUS_LCO_ 0x | (044C | W | 0x0 | Loop Counter 0 for DMA<br>Channel 2 | | 3 | 046C | W | 0x0 | Loop Counter 0 for DMA Channel 3 | | 4 | 048C | W | 0x0 | Loop Counter 0 for DMA<br>Channel 4 | | 5 | 04aC | W | 0x0 | Loop Counter 0 for DMA Channel 5 | | DMAC_BUS_LC1_ 0x | 0410 | W | 0x0 | Loop Counter 1 for DMA Channel 0 | | DMAC_BUS_LC1_ 0x | (0430 | W | 0x0 | Loop Counter 1 for DMA<br>Channel 1 | | DMAC_BUS_LC1_ 0x | (0450 | W | 0x0 | Loop Counter 1 for DMA<br>Channel 2 | | DMAC_BUS_LC1_ 0x | (0470 | W | 0x0 | Loop Counter 1 for DMA Channel 3 | | DMAC_BUS_LC1_ 0x | (0490 | W | 0x0 | Loop Counter 1 for DMA<br>Channel 4 | | DMAC_BUS_LC1_ 0x | 04b0 | W | 0x0 | Loop Counter 1 for DMA Channel 5 | | | | | - | reserved | | DMAC_BUS_DBG | | | | | | ST<br>DMAC_BUS_ATU<br>S | (0D00 | W | 0x0 | Debug Status Register. | | DMAC BUS DBG | 0D04 | W | 0x0 | Debug Command Register. | | DMAC BUS DBG | 0D08 | W | 0x0 | Debug Instruction-0 Register. | | DMAC BUS DBG | (0D0C | W | 0x0 | Debug Instruction-1 Register. | | | 0E00 | W | | Configuration Register 0. | | | 0E04 | W | | Configuration Register 1. | | DMAC_BUS_CR2 0x | 0E08 | W | | Configuration Register 2. | | | OE0C | W | | Configuration Register 3. | | DMAC_BUS_CR4 0x | 0E10 | W | | Configuration Register 4. | | DMAC BUS CRD | (0E14 | W | | Configuration Register Dn. | | | 0E80 | W | 0x0 | Watchdog Register. | Notes: Size: **B** - Byte (8 bits) access, **HW** - Half WORD (16 bits) access, **W** -WORD (32 bits) access # 10.4.2 Detail Register Description ## DMAC\_BUS\_DSR Address:Operational Base+0x0 DMA Manager Status Register | Bit | Attr | Reset Value | Description | |-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31:10 | - | - | Reserved | | 9 | R | 0x0 | Provides the security status of the DMA manager thread: 0 = DMA manager operates in the Secure state 1 = DMA manager operates in the Non-secure state. | | 8:4 | R | 0x0 | When the DMA manager thread executes a DMAWFE instruction, it waits for the following event to occur: b00000 = event[0] b00001 = event[1] b00010 = event[2] b11111 = event[31]. | | 3:0 | R | 0x0 | The operating state of the DMA manager: b0000 = Stopped b0001 = Executing b0010 = Cache miss b0011 = Updating PC b0100 = Waiting for event b0101-b1110 = reserved b1111 = Faulting. | ## DMAC\_BUS\_DPC Address:Operational Base+0x4 DMA Program Counter Register | Bit | Attr | <b>Reset Value</b> | Description | |------|------|--------------------|--------------------------------------------| | 31:0 | R | 0x0 | Program counter for the DMA manager thread | ## DMAC\_BUS\_INTEN Address: Operational Base+0x20 Interrupt Enable Register | Bit | Attr | Reset Value | Description | |------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31:0 | RW | 0x0 | Program the appropriate bit to control how the DMAC responds when it executes DMASEV: Bit [N] = 0 If the DMAC executes DMASEV for the event-interrupt resource N then the DMAC signals event N to all of the threads. Set bit [N] to 0 if your system design does not use irq[N] to signal an interrupt request. | | | | | Bit [N] = 1 If the DMAC executes DMASEV for<br>the event-interrupt resource N then the DMAC<br>sets irq[N] HIGH. Set bit [N] to 1 if your system<br>designer requires irq[N] to signal an interrupt<br>request. | ## DMAC\_BUS\_EVENT\_RIS Address:Operational Base+0x24 Event-Interrupt Raw Status Register | Bit # | Attr | Reset Value | Description | |-------|------|-------------|-------------| |-------|------|-------------|-------------| | | | | Returns | the | status | of | the | event-interrupt | |------|---|------|-----------|-----|-----------|-----|--------|-------------------| | 31:0 | D | 0x0 | resources | s: | | | | | | 31.0 | 1 | 0.00 | Bit [N] = | 0 E | vent N is | ina | ctive | or irq[N] is LOW. | | | | | Bit [N] = | 1 E | vent N is | act | tive o | r irq[N] is HIGH. | ## **DMAC\_BUS\_INTMIS** Address:Operational Base+0x28 Interrupt Status Register | Bit | Attr | <b>Reset Value</b> | Description | |------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31:0 | R | 0x0 | Provides the status of the interrupts that are active in the DMAC: Bit $[N] = 0$ Interrupt N is inactive and therefore $irq[N]$ is LOW. Bit $[N] = 1$ Interrupt N is active and therefore $irq[N]$ is HIGH | ## DMAC\_BUS\_INTCLR Address:Operational Base+0x2c Interrupt Clear Register | Bit | Attr | Reset Value | Description | |------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31:0 | w | 0x0 | Controls the clearing of the irq outputs: Bit [N] = 0 The status of irq[N] does not change. Bit [N] = 1 The DMAC sets irq[N] LOW if the INTEN Register programs the DMAC to signal an interrupt. Otherwise, the status of irq[N] does not change. | ## DMAC\_BUS\_FSRD Address:Operational Base+0x30 Fault Status DMA Manager Register | Bit | Attr | <b>Reset Value</b> | Description | |------|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31:0 | R | 0x0 | Provides the fault status of the DMA manager. Read as: 0 = the DMA manager thread is not in the Faulting state 1 = the DMA manager thread is in the Faulting state. | # DMAC\_BUS\_FSRC Address:Operational Base+0x34 Fault Status DMA Channel Register | Bit | Attr | <b>Reset Value</b> | Description | |------|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31:0 | R | 0x0 | Each bit provides the fault status of the corresponding channel. Read as: Bit [N] = 0 No fault is present on DMA channel N. Bit [N] = 1 DMA channel N is in the Faulting or Faulting completing state. | ## DMAC\_BUS\_FTRD Address: Operational Base+0x38 Fault Type DMA Manager Register | Bit | Attr | Reset Value | Description | |-----|------|-------------|----------------------------------------------------------------------------------------------| | 31 | - | - | reserved | | 30 | R | 0x0 | If the DMA manager aborts, this bit indicates if the erroneous instruction was read from the | | | 1 | 1 | | |-------|---|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | system memory or from the debug interface: 0 = instruction that generated an abort was read from system memory 1 = instruction that generated an abort was read | | | | | from the debug interface. | | 29:17 | - | - | reserved | | 16 | R | 0x0 | Indicates the AXI response that the DMAC receives on the RRESP bus, after the DMA manager performs an instruction fetch: 0 = OKAY response 1 = EXOKAY, SLVERR, or DECERR response | | 15:6 | - | - | reserved | | 5 | R | 0x0 | Indicates if the DMA manager was attempting to execute DMAWFE or DMASEV with inappropriate security permissions: 0 = DMA manager has appropriate security to execute DMAWFE or DMASEV 1 = a DMA manager thread in the Non-secure state attempted to execute either: • DMAWFE to wait for a secure event • DMASEV to create a secure event or secure interrupt | | 4 | R | 0x0 | ndicates if the DMA manager was attempting to execute DMAGO with inappropriate security permissions: 0 = DMA manager has appropriate security to execute DMAGO 1 = a DMA manager thread in the Non-secure state attempted to execute DMAGO to create a DMA channel operating in the Secure state. | | 3:2 | - | - | reserved | | 1 | R | 0x0 | Indicates if the DMA manager was attempting to execute an instruction operand that was not valid for the configuration of the DMAC: 0 = valid operand 1 = invalid operand. | | 0 | R | 0x0 | Indicates if the DMA manager was attempting to execute an undefined instruction: 0 = defined instruction 1 = undefined instruction. | # DMAC\_BUS\_FTR0~DMAC\_BUS\_FTR5 Address:Operational Base+0x40 Operational Base+0x44 Operational Base+0x48 Operational Base+0x4c Operational Base+0x50 Operational Base+0x54 Fault Type DMA Channel Register | rault i | ype DM | A Channel Regis | ster | |---------|--------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Attr | Reset Value | Description | | 31 | R | 0x0 | Indicates if the DMA channel has locked-up because of resource starvation: 0 = DMA channel has adequate resources 1 = DMA channel has locked-up because of insufficient resources. This fault is an imprecise abort | | | | Г | | |-------|---|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 30 | R | 0x0 | If the DMA channel aborts, this bit indicates if the erroneous instruction was read from the system memory or from the debug interface: 0 = instruction that generated an abort was read from system memory 1 = instruction that generated an abort was read from the debug interface. This fault is an imprecise abort but the bit is only valid when a precise abort occurs. | | 29:19 | - | - | reserved | | 18 | R | 0x0 | Indicates the AXI response that the DMAC receives on the RRESP bus, after the DMA channel thread performs a data read: 0 = OKAY response 1 = EXOKAY, SLVERR, or DECERR response. This fault is an imprecise abort | | 17 | R | 0x0 | Indicates the AXI response that the DMAC receives on the BRESP bus, after the DMA channel thread performs a data write: 0 = OKAY response 1 = EXOKAY, SLVERR, or DECERR response. This fault is an imprecise abort. | | 16 | R | 0x0 | Indicates the AXI response that the DMAC receives on the RRESP bus, after the DMA channel thread performs an instruction fetch: 0 = OKAY response 1 = EXOKAY, SLVERR, or DECERR response. This fault is a precise abort. | | 15:14 | - | - | reserved | | 13 | R | 0x0 | Indicates if the MFIFO did not contain the data to enable the DMAC to perform the DMAST: 0 = MFIFO contains all the data to enable the DMAST to complete 1 = previous DMALDs have not put enough data in the MFIFO to enable the DMAST to complete. This fault is a precise abort. | | 12 | R | 0x0 | Indicates if the MFIFO prevented the DMA channel thread from executing DMALD or DMAST. Depending on the instruction: DMALD 0 = MFIFO contains sufficient space 1 = MFIFO is too small to hold the data that DMALD requires. DMAST 0 = MFIFO contains sufficient data 1 = MFIFO is too small to store the data to enable DMAST to complete. This fault is an imprecise abort | | 11:8 | - | - | reserved | | 7 | R | 0x0 | Indicates if a DMA channel thread, in the Non-secure state, attempts to program the CCRn Register to perform a secure read or secure write: 0 = a DMA channel thread in the Non-secure state is not violating the security permissions 1 = a DMA channel thread in the Non-secure state attempted to perform a secure read or secure write. This fault is a precise abort | | 6 | R | 0x0 | Indicates if a DMA channel thread, in the Non-secure state, attempts to execute DMAWFP, DMALDP, DMASTP, or DMAFLUSHP with inappropriate security permissions: 0 = a DMA channel thread in the Non-secure state is not violating the security permissions 1 = a DMA channel thread in the Non-secure state attempted to execute either: • DMAWFP to wait for a secure peripheral • DMALDP or DMASTP to notify a secure peripheral • DMAFLUSHP to flush a secure peripheral. This fault is a precise abort. | |-----|---|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 5 | R | 0x0 | Indicates if the DMA channel thread attempts to execute DMAWFE or DMASEV with inappropriate security permissions: 0 = a DMA channel thread in the Non-secure state is not violating the security permissions 1 = a DMA channel thread in the Non-secure state attempted to execute either: • DMAWFE to wait for a secure event • DMASEV to create a secure event or secure interrupt. This fault is a precise abort. | | 4:2 | - | - | reserved | | 1 | R | 0×0 | Indicates if the DMA channel thread was attempting to execute an instruction operand that was not valid for the configuration of the DMAC: 0 = valid operand 1 = invalid operand. This fault is a precise abort. | | 0 | R | 0x0 | Indicates if the DMA channel thread was attempting to execute an undefined instruction: 0 = defined instruction 1 = undefined instruction. This fault is a precise abort | # DMAC\_BUS\_CSR0~DMAC\_BUS\_CSR5 Address:Operational Base+0x100 Operational Base+0x108 Operational Base+0x110 Operational Base+0x118 Operational Base+0x120 Operational Base+0x128 Channel Status Registers | Bit | Attr | <b>Reset Value</b> | Description | |-------|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31:22 | - | - | reserved | | 21 | R | 0x0 | The channel non-secure bit provides the security of the DMA channel: 0 = DMA channel operates in the Secure state 1 = DMA channel operates in the Non-secure state | | 20:16 | - | - | reserved | | 15 | R | 0x0 | When the DMA channel thread executes DMAWFP this bit indicates if the periph operand was set: | | | 1 | | T | |------|---|-----------------|------------------------------------------------------| | | | | 0 = DMAWFP executed with the periph operand | | | | | not set | | | | | 1 = DMAWFP executed with the periph operand | | | | | set | | | | | When the DMA channel thread executes | | | | | DMAWFP this bit indicates if the burst or single | | | | | operand were set: | | 14 | R | 0x0 | 0 = DMAWFP executed with the single operand | | | | | set | | | | | 1 = DMAWFP executed with the burst operand | | | | | set. | | 13:9 | _ | - | reserved | | | | | If the DMA channel is in the Waiting for event | | | | | state or the Waiting for peripheral state then | | | | | these bits | | | | | indicate the event or peripheral number that the | | | | | channel is waiting for: | | | | | b00000 = DMA channel is waiting for event, or | | | | | peripheral, 0 | | | | | b00001 = DMA channel is waiting for event, or | | 8:4 | R | 0x0 | peripheral, 1 | | | | | b00010 = DMA channel is waiting for event, or | | | | | peripheral, 2 | | | | | periprieral, 2 | | | | | · X \ | | | | | | | | | | b11111 = DMA channel is waiting for event, or | | | | | peripheral, 31 | | | 1 | | The channel status encoding is: | | | | | b0000 = Stopped | | | | | b0000 = Stopped<br>b0001 = Executing | | | | | b0001 = Executing<br>b0010 = Cache miss | | | | | b0010 = Cache miss<br>b0011 = Updating PC | | | | | b0101 = Opdating FC<br>b0100 = Waiting for event | | | | A | b0100 = Walting for event<br>b0101 = At barrier | | 3:0 | R | 0x0 | b0101 = At barrier<br>b0110 = reserved | | 5.0 | | | b0110 = reserved<br> b0111 = Waiting for peripheral | | | | 41 | b0111 = Walting for peripheral<br> b1000 = Killing | | | | | | | | | $C \rightarrow$ | b1001 = Completing<br>b1010-b1101 = reserved | | | | | | | | | | b1110 = Faulting completing | | | | | b1111 = Faulting | ## DMAC\_BUS\_CPC0~DMAC\_BUS\_CPC5 Address: Operational Base+0x104 Operational Base+0x10c Operational Base+0x114 Operational Base+0x11c Operational Base+0x124 Operational Base+0x12c Channel Program Counter Registers | Bit | Attr | Reset Value | Description | |------|------|-------------|----------------------------------------------| | 31:0 | R | 0x0 | Program counter for the DMA channel n thread | # DMAC\_BUS\_SAR0~DMAC\_BUS\_SAR5 Address:Operational Base+0x400 Operational Base+0x420 Operational Base+0x440 Operational Base+0x460 Operational Base+0x480 Operational Base+0x4a0 Source Address Registers | Bit | Attr | <b>Reset Value</b> | Description | |------|------|--------------------|----------------------------------------------| | 31:0 | R | 0x0 | Address of the source data for DMA channel n | ## DMAC\_BUS\_DAR0~DMAC\_BUS\_DAR5 Address:Operational Base+0x404 Operational Base+0x424 Operational Base+0x444 Operational Base+0x464 Operational Base+0x484 Operational Base+0x4a4 DestinationAddress Registers | Bit | Attr | <b>Reset Value</b> | Description | |------|------|--------------------|------------------------------------------------| | 31:0 | R | 0x0 | Address of the Destinationdata for DMA channel | #### DMAC\_BUS\_CCR0~DMAC\_BUS\_CCR5 Address:Operational Base+0x408 Operational Base+0x428 Operational Base+0x448 Operational Base+0x468 Operational Base+0x488 Operational Base+0x4a8 **Channel Control Registers** | Bit | Attr | Reset Value | Description | |-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31:28 | - | - | reserved | | 27:25 | R | 0x0 | Programs the state of AWCACHE[3,1:0]a when the DMAC writes the destination data. Bit [27] 0 = AWCACHE[3] is LOW 1 = AWCACHE[3] is HIGH. Bit [26] 0 = AWCACHE[1] is LOW 1 = AWCACHE[1] is HIGH. Bit [25] 0 = AWCACHE[0] is LOW 1 = AWCACHE[0] is HIGH | | 24:22 | R | 0x0 | Programs the state of AWPROT[2:0]a when the DMAC writes the destination data. Bit [24] 0 = AWPROT[2] is LOW 1 = AWPROT[2] is HIGH. Bit [23] 0 = AWPROT[1] is LOW 1 = AWPROT[1] is HIGH. Bit [22] 0 = AWPROT[0] is LOW 1 = AWPROT[0] is HIGH | | 21:18 | R | 0x0 | For each burst, these bits program the number of data transfers that the DMAC performs when it writes the destination data: b0000 = 1 data transfer b0001 = 2 data transfers b0010 = 3 data transfers b1111 = 16 data transfers. The total number of bytes that the DMAC writes | | | | | and of the METEO 1 11 1 DICCO | |-------|---|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | out of the MFIFO when it executes a DMAST | | | | | instruction is the product of dst_burst_len and | | | | | dst_burst_size | | | | | For each beat within a burst, it programs the number of bytes that the DMAC writes to the destination: b000 = writes 1 byte per beat b001 = writes 2 bytes per beat | | 17:15 | R | 0x0 | b010 = writes 4 bytes per beat b011 = writes 8 bytes per beat b100 = writes 16 bytes per beat b101-b111 = reserved. The total number of bytes that the DMAC writes out of the MFIFO when it executes a DMAST instruction is the product of dst_burst_len and dst_burst_size. | | | | | Programs the burst type that the DMAC performs when it writes the destination data: | | 14 | R | 0x0 | 0 = Fixed-address burst. The DMAC signals AWBURST[0] LOW. | | | | | 1 = Incrementing-address burst. The DMAC signals AWBURST[0] HIGH. | | | | | Set the bits to control the state of ARCACHE[2:0]a when the DMAC reads the | | 13:11 | R | 0x0 | source data. Bit [13] 0 = ARCACHE[2] is LOW 1 = ARCACHE[2] is HIGH. Bit [12] 0 = ARCACHE[1] is LOW 1 = ARCACHE[1] is HIGH. Bit [11] 0 = ARCACHE[0] is LOW 1 = ARCACHE[0] is HIGH. | | 10:8 | R | 0x0 | Programs the state of ARPROT[2:0]a when the DMAC reads the source data. Bit [10] 0 = ARPROT[2] is LOW 1 = ARPROT[2] is HIGH. Bit [9] 0 = ARPROT[1] is LOW 1 = ARPROT[1] is HIGH. Bit [8] 0 = ARPROT[0] is LOW 1 = ARPROT[0] is HIGH. | | | S | 0 1 | For each burst, these bits program the number of data transfers that the DMAC performs when it reads the source data: b0000 = 1 data transfer b0001 = 2 data transfers b0010 = 3 data transfers | | 7:4 | R | 0x0 | ·<br>· | | | | | b1111 = 16 data transfers. The total number of bytes that the DMAC reads into the MFIFO when it executes a DMALD instruction is the product of src_burst_len and src_burst_size | | 3:1 | R | 0x0 | For each beat within a burst, it programs the number of bytes that the DMAC reads from the source: b000 = reads 1 byte per beat | | | | | b001 = reads 2 bytes per beat | |---|---|-------|-----------------------------------------------| | | | | b010 = reads 4 bytes per beat | | | | | b011 = reads 8 bytes per beat | | | | | b100 = reads 16 bytes per beat | | | | | b101-b111 = reserved. | | | | | The total number of bytes that the DMAC reads | | | | | into the MFIFO when it executes a DMALD | | | | | instruction | | | | | is the product of src_burst_len and | | | | | src_burst_size | | | | | Programs the burst type that the DMAC | | | | R 0x0 | performs when it reads the source data: | | 0 | D | | 0 = Fixed-address burst. The DMAC signals | | U | K | | ARBURST[0] LOW. | | | | | 1 = Incrementing-address burst. The DMAC | | | | | signals ARBURST[0] HIGH | ## DMAC\_BUS\_LCO\_0~DMAC\_BUS\_LCO\_5 Address:Operational Base+0x40c Operational Base+0x42c Operational Base+0x44c Operational Base+0x46c Operational Base+0x48c Operational Base+0x4ac Loop Counter 0 Registers | Bit | Attr | <b>Reset Value</b> | Description | |------|------|--------------------|---------------------------| | 31:8 | - | - | reserved | | 7:0 | R | 0x0 | Loop counter 0 iterations | ## DMAC\_BUS\_LC1\_0~DMAC\_BUS\_LC1\_5 Address: Operational Base+0x410 Operational Base+0x430 Operational Base+0x450 Operational Base+0x470 Operational Base+0x490 Operational Base+0x4b0 Loop Counter 1 Registers | Bit | Attr | Reset Value | Description | |------|------|-------------|---------------------------| | 31:8 | - | - 6 | reserved | | 7:0 | R | 0x0 | Loop counter 1 iterations | ## DMAC\_BUS\_DBGSTATUS Address:Operational Base+0xd00 Debug Status Register | Bit | Attr | <b>Reset Value</b> | Description | |------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31:2 | ı | - | reserved | | 1:0 | R | 0x0 | The debug encoding is as follows: b00 = execute the instruction that the DBGINST [1:0] Registers contain b01 = reserved b10 = reserved b11 = reserved. | #### DMAC\_BUS\_DBGCMD Address: Operational Base+0xd04 **Debug Command Register** | Bit Attr Reset Value Description | | |----------------------------------|--| |----------------------------------|--| | 31:2 | ı | - | reserved | |------|---|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------| | 1:0 | W | 0x0 | The debug encoding is as follows: b00 = execute the instruction that the DBGINST [1:0] Registers contain b01 = reserved b10 = reserved b11 = reserved | # DMAC\_BUS\_DBGINSTO Address:Operational Base+0xd08 Debug Instruction-0 Register | Bit | Attr | Reset Value | Description | |-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------| | 31:24 | W | 0x0 | Instruction byte 1 | | 23:16 | W | 0x0 | Instruction byte 0 | | 15:11 | - | - | reserved | | 10:8 | W | 0x0 | DMA channel number:<br>b000 = DMA channel 0<br>b001 = DMA channel 1<br>b010 = DMA channel 2<br><br>b111 = DMA channel 7 | | 7:1 | - | - | reserved | | 0 | W | 0x0 | The debug thread encoding is as follows: 0 = DMA manager thread 1 = DMA channel. | ## DMAC\_BUS\_DBGINST1 Address:Operational Base+0xd0c Debug Instruction-1 Register | Bit | Attr | <b>Reset Value</b> | Description | |-------|------|--------------------|--------------------| | 31:24 | W | 0x0 | Instruction byte 5 | | 23:16 | W | 0x0 | Instruction byte 4 | | 15:8 | W | 0x0 | Instruction byte 3 | | 7:0 | W | 0x0 | Instruction byte 2 | ## DMAC\_BUS\_CR0 Address:Operational Base+0xe00 Configuration Register 0 | Connig | Configuration Register U | | | |--------|--------------------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Attr | <b>Reset Value</b> | Description | | 31:22 | ı | | reserved | | | 0 | 0 × | Number of interrupt outputs that the DMAC provides: b00000 = 1 interrupt output, irq[0] | | 21:17 | R | 0x2 | b00001 = 2 interrupt outputs, irq[1:0]<br>b00010 = 3 interrupt outputs, irq[2:0] | | | | | | | | | | b11111 = 32 interrupt outputs, irq[31:0]. | | 16:12 | R | 0x7 | Number of peripheral request interfaces that the DMAC provides: b00000 = 1 peripheral request interface b00001 = 2 peripheral request interfaces b00010 = 3 peripheral request interfaces | | | | | | | | | | b11111 = 32 peripheral request interfaces. | |------|---|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 11:7 | _ | _ | reserved | | | | | Number of DMA channels that the DMAC | | 6:4 | R | 0x5 | supports:<br>b000 = 1 DMA channel<br>b001 = 2 DMA channels<br>b010 = 3 DMA channels | | | | | ·<br>· | | | | | b111 = 8 DMA channels. | | 3 | - | - | reserved | | 2 | R | 0x0 | Indicates the status of the boot_manager_ns signal when the DMAC exited from reset: 0 = boot_manager_ns was LOW 1 = boot_manager_ns was HIGH. | | 1 | R | 0x0 | Indicates the status of the boot_from_pc signal when the DMAC exited from reset: 0 = boot_from_pc was LOW 1 = boot_from_pc was HIGH | | 0 | R | 0x1 | Supports peripheral requests: 0 = the DMAC does not provide a peripheral request interface 1 = the DMAC provides the number of peripheral request interfaces that the num_periph_req field specifies. | # DMAC\_BUS\_CR1 Address:Operational Base+0xe04 Configuration Register 1 | Configuration Register 1 | | | | |--------------------------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Attr | Reset Value | Description | | 31:8 | - | - | reserved | | 7:4 | R | 0x5 | [7:4] num_i-cache_lines Number of i-cache lines: b0000 = 1 i-cache line b0001 = 2 i-cache lines b0010 = 3 i-cache lines b1111 = 16 i-cache lines. | | 3 | - | - ( ) | reserved | | 2:0 | R | 0x7 | The length of an i-cache line:<br>b000-b001 = reserved<br>b010 = 4 bytes<br>b011 = 8 bytes<br>b100 = 16 bytes<br>b101 = 32 bytes<br>b110-b111 = reserved | ## DMAC\_BUS\_CR2 Address:Operational Base+0xe08 Configuration Register 2 | Bit | it Attr Reset Value Description | | | | | | | |------|---------------------------------|-----|------------------------------------------------|--|--|--|--| | 31:0 | R | 0x0 | Provides the value of boot_addr[31:0] when the | | | | | | 31.0 | | UXU | DMAC exited from reset | | | | | ## DMAC\_BUS\_CR3 Address:Operational Base+0xe0c Configuration Register 3 | Bit | Attr | <b>Reset Value</b> | Description | | | | | | |------|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | 31:0 | R | 0x0 | Provides the security state of an event-interrupt resource: Bit [N] = 0 Assigns event <n> or irq[N] to the Secure state. Bit [N] = 1 Assigns event<n> or irq[N] to the Non-secure state.</n></n> | | | | | | # DMAC\_BUS\_CR4 Address:Operational Base+0xe10 Configuration Register 4 | Bit | Attr | Reset Value | Description | | | | | | |------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | 31:0 | R | 0x6 | Provides the security state of the peripheral request interfaces: Bit [N] = 0 Assigns peripheral request interface N to the Secure state. Bit [N] = 1 Assigns peripheral request interface N to the Non-secure state | | | | | | ## DMAC\_BUS\_CRDn Address:Operational Base+0xe14 DMA Configuration Register | Bit | Attr | Reset Value | | | | | | | | |-------|------|--------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | 31:30 | - | - | reserved | | | | | | | | 29:20 | R | 0x20 The number of lines that the data contains: b0000000000 = 1 line b000000001 = 2 lines b111111111 = 1024 lines | | | | | | | | | 19:16 | R | 0x9 | The depth of the read queue: b0000 = 1 line b0001 = 2 lines b1111 = 16 lines. | | | | | | | | 15 | | - | reserved | | | | | | | | 14:12 | R | Read issuing capability that programs number of outstanding read transactions: b000 = 1 b001 = 2 b111 = 8 | | | | | | | | | 11:8 | R | The depth of the write queue: $b0000 = 1 \text{ line}$ $b0001 = 2 \text{ lines}$ $b1111 = 16 \text{ lines}.$ | | | | | | | | | 7 | - | - | reserved | | | | | | | | 6:4 | R | 0x3 | Write issuing capability that programs the number of outstanding write transactions: $b000 = 1$ $b001 = 2$ $b111 = 8$ | | | | | | | | 3 | - | - | reserved | |-----|---|-----|-------------------------------------------------------------------------------------------------------------------------------------------| | 2:0 | | 0x3 | The data bus width of the AXI interface: b000 = reserved b001 = reserved b010 = 32-bit b011 = 64-bit b100 = 128-bit b101-b111 = reserved. | #### DMAC\_BUS\_WD Address: Operational Base+0xe80 DMA Watchdog Register | | | y regiotei | | |-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Attr | Reset Value | Description | | - | - | - | reserved | | 0 | RW | 0x0 | Controls how the DMAC responds when it detects a lock-up condition: 0 = the DMAC aborts all of the contributing DMA channels and sets irq_abort HIGH 1 = the DMAC sets irq_abort HIGH. | # 10.5 Timing Diagram Following picture shows the relationship between dma\_req and dma\_ack. Fig. 10-3 DMAC\_BUS request and acknowledge timing # 10.6 Interface Description DMAC\_BUS has the following tie-off signals. It can be configured by GRF register or TZPC register. (Please refer to these two chapters to find how to configure) | interface | Reset value | Control source | |-----------------|-------------|-------------------| | boot_addr | 0x0 | Secure GRF | | boot_from_pc | 0x0 | Secure GRF | | boot_manager_ns | 0x0 | Secure GRF / TZPC | | boot_irq_ns | 0x0 | Secure GRF / TZPC | | boot periph ns | 0x0 | TZPC | #### boot\_addr Configures the address location that contains the first instruction the DMAC executes, when it exits from reset. ## boot\_from\_pc Controls the location in which the DMAC executes its initial instruction, after it exits from reset: - 0 = DMAC waits for an instruction from either APB interface - 1 = DMA manager thread executes the instruction that is located at the address that #### boot\_manager\_ns When the DMAC exits from reset, this signal controls the security state of the DMA manager thread: 0 = assigns DMA manager to the Secure state 1 = assigns DMA manager to the Non-secure state. #### boot\_irq\_ns Controls the security state of an event-interrupt resource, when the DMAC exits from reset: ``` boot_irq_ns[x] is LOW ``` The DMAC assigns event<x> or irq[x] to the Secure state. boot\_irq\_ns[x] is HIGH The DMAC assigns event<x> or irq[x] to the Non-secure state. ## boot\_periph\_ns Controls the security state of a peripheral request interface, when the DMAC exits from reset: ``` boot_periph_ns[x] is LOW ``` The DMAC assigns peripheral request interface x to the Secure state. boot periph ns[x] is HIGH The DMAC assigns peripheral request interface x to the Non-secure state. # 10.7 Application Notes ## 10.7.1 Using the APB slave interfaces You must ensure that you use the appropriate APB interface, depending on the security state in which the boot\_manager\_ns initializes the DMAC to operate. For example, if the DMAC is in the secure state, you must issue the instruction using the secure APB interface, otherwise the DMAC ignores the instruction. You can use the secure APB interface, or the non-secure APB interface, to start or restart a DMA channel when the DMAC is in the Non-secure state. The necessary steps to start a DMA channel thread using the debug instruction registers as following: - 1. Create a program for the DMA channel. - 2. Store the program in a region of system memory. - 3. Poll the DBGSTATUS Register to ensure that debug is idle, that is, the dbgstatus bit is 0. - 4. Write to the DBGINSTO Register and enter the: - Instruction byte 0 encoding for DMAGO. - Instruction byte 1 encoding for DMAGO. - Debug thread bit to 0. This selects the DMA manager thread. - 5. Write to the DBGINST1 Register with the DMAGO instruction byte [5:2] data, see Debug Instruction-1 Register o. You must set these four bytes to the address of the first instruction in the program, that was written to system memory in step 2. - 6. Writing zero to the DBGCMD Register. The DMAC starts the DMA channel thread and sets the dbgstatus bit to 1. ### 10.7.2 Security usage When the DMAC exits from reset, the status of the configuration signals that tie-off signals which descripted in chapter 10.6. ### DMA manager thread is in the secure state If the DNS bit is 0, the DMA manager thread operates in the secure state and it only performs secure instruction fetches. When a DMA manager thread in the secure state processes: #### **DMAGO** It uses the status of the ns bit, to set the security state of the DMA channel thread by writing to the CNS bit for that channel. #### **DMAWFE** It halts execution of the thread until the event occurs. When the event occurs, the DMAC continues execution of the thread, irrespective of the security state of the corresponding INS bit. #### **DMASEV** It sets the corresponding bit in the INT\_EVENT\_RIS Register, irrespective of the security state of the corresponding INS bit. ### DMA manager thread is in the Non-secure state If the DNS bit is 1, the DMA manager thread operates in the Non-secure state, and it only performs non-secure instruction fetches. When a DMA manager thread in the Non-secure state processes: #### **DMAGO** The DMAC uses the status of the ns bit, to control if it starts a DMA channel thread. If: ns = 0 The DMAC does not start a DMA channel thread and instead it: - 1. Executes a NOP. - 2. Sets the FSRD Register, see Fault Status DMA Manager - 3. Sets the dmago\_err bit in the FTRD Register, see Fault Type DMA Manager Register. - 4. Moves the DMA manager to the Faulting state. ns = 1 The DMAC starts a DMA channel thread in the Non-secure state and programs the CNS bit to be non-secure. #### **DMAWFE** The DMAC uses the status of the corresponding INS bit, in the CR3 Register, to control if it waits for the event. If: INS = 0 The event is in the Secure state. The DMAC: - 1. Executes a NOP. - 2. Sets the FSRD Register, see Fault Status DMA Manager Register. - 3. Sets the mgr\_evnt\_err bit in the FTRD Register, see Fault Type DMA Manager Register. - 4. Moves the DMA manager to the Faulting state. INS = 1 The event is in the Non-secure state. The DMAC halts execution of the thread and waits for the event to occur. #### **DMASEV** The DMAC uses the status of the corresponding INS bit, in the CR3Register, to control if it creates the event-interrupt. If: INS = 0 The event-interrupt resource is in the Secure state. The DMAC: - 1. Executes a NOP. - 2. Sets the FSRD Register, see Fault Status DMA Manager Register. - 3. Sets the mgr\_evnt\_err bit in the FTRD Register, see Fault Type DMA Manager Register. - 4. Moves the DMA manager to the Faulting state. INS = 1 The event-interrupt resource is in the Non-secure state. The DMAC creates the event-interrupt. #### DMA channel thread is in the secure state When the CNS bit is 0, the DMA channel thread is programmed to operate in the Secure state and it only performs secure instruction fetches. When a DMA channel thread in the secure state processes the following instructions: #### **DMAWFE** The DMAC halts execution of the thread until the event occurs. When the event occurs, the DMAC continues execution of the thread, irrespective of the security state of the corresponding INS bit, in the CR3 Register. #### **DMASEV** The DMAC creates the event-interrupt, irrespective of the security state of the corresponding INS bit, in the CR3 Register. #### **DMAWFP** The DMAC halts execution of the thread until the peripheral signals a DMA request. When this occurs, the DMAC continues execution of the thread, irrespective of the security state of the corresponding PNS bit, in the CR4 Register. #### DMALDP, DMASTP The DMAC sends a message to the peripheral to communicate that data transfer is complete, irrespective of the security state of the corresponding PNS bit, in the CR4 Register. #### **DMAFLUSHP** The DMAC clears the state of the peripheral and sends a message to the peripheral to resend its level status, irrespective of the security state of the corresponding PNS bit, in the CR4 Register. When a DMA channel thread is in the Secure state, it enables the DMAC to perform secure and non-secure AXI accesses #### DMA channel thread is in the Non-secure state When the CNS bit is 1, the DMA channel thread is programmed to operate in the Non-secure state and it only performs non-secure instruction fetches. When a DMA channel thread in the Non-secure state processes the following instructions: #### **DMAWFE** The DMAC uses the status of the corresponding INS bit, in the CR3 Register, to control if it waits for the event. If: INS = 0 The event is in the Secure state. The DMAC: - 1. Executes a NOP. - 2. Sets the appropriate bit in the FSRC Register that corresponds to the DMA channel number. See Fault Status DMA Channel Register. - 3. Sets the ch\_evnt\_err bit in the FTRn Register, see Fault Type DMA Channel Registers. - 4. Moves the DMA channel to the Faulting completing state. INS = 1 The event is in the Non-secure state. The DMAC halts execution of the thread and waits for the event to occur. #### **DMASEV** The DMAC uses the status of the corresponding INS bit, in the CR3 Register, to control if it creates the event. If: INS = 0 The event-interrupt resource is in the Secure state. The DMAC: - 1. Executes a NOP. - 2. Sets the appropriate bit in the FSRC Register that corresponds to the DMA channel number. See Fault Status DMA Channel Register. - 3. Sets the ch\_evnt\_err bit in the FTRn Register, see Fault Type DMA Channel Registers . - 4. Moves the DMA channel to the Faulting completing state. INS = 1 The event-interrupt resource is in the Non-secure state. The DMAC creates the event-interrupt. #### **DMAWFP** The DMAC uses the status of the corresponding PNS bit, in the CR4 Register, to control if it waits for the peripheral to signal a request. If: PNS = 0 The peripheral is in the Secure state. The DMAC: - 1. Executes a NOP. - 2. Sets the appropriate bit in the FSRC Register that corresponds to the DMA channel number. See Fault Status DMA Channel Register. - 3. Sets the ch\_periph\_err bit in the FTRn Register, see Fault Type DMA Channel Registers. - 4. Moves the DMA channel to the Faulting completing state. PNS = 1 The peripheral is in the Non-secure state. The DMAC halts execution of the thread and waits for the peripheral to signal a request. #### **DMALDP, DMASTP** The DMAC uses the status of the corresponding PNS bit, in the CR4 Register, to control if it sends an acknowledgement to the peripheral. If: PNS = 0 The peripheral is in the Secure state. The DMAC: 1. Executes a NOP. - 2. Sets the appropriate bit in the FSRC Register that corresponds to the DMA channel number. See Fault Status DMA Channel Register. - 3. Sets the chaperipherr bit in the FTRn Register, see Fault Type DMA Channel Registers. - 4. Moves the DMA channel to the Faulting completing state. PNS = 1 The peripheral is in the Non-secure state. The DMAC sends a message to the peripheral to communicate when the data transfer is complete. #### **DMAFLUSHP** The DMAC uses the status of the corresponding PNS bit, in the CR4 Register, to control if it sends a flush request to the peripheral. If: PNS = 0 The peripheral is in the Secure state. The DMAC: - 1. Executes a NOP. - 2. Sets the appropriate bit in the FSRC Register that corresponds to the DMA channel number. See Fault Status DMA Channel Registe. - 3. Sets the ch\_periph\_err bit in the FTRn Register, see Fault Type DMA Channel Registers. - 4. Moves the DMA channel to the Faulting completing state. PNS = 1 The peripheral is in the Non-secure state. The DMAC clears the state of the peripheral and sends a message to the peripheral to resend its level status. When a DMA channel thread is in the Non-secure state, and a DMAMOV CCR instruction attempts to program the channel to perform a secure AXI transaction, the DMAC: - 1. Executes a DMANOP. - 2. Sets the appropriate bit in the FSRC Register that corresponds to the DMA channel number. See Fault Status DMA Channel Registe. - 3. Sets the chirdwright err bit in the FTRn Register, see Fault Type DMA Channel Registers. - 4. Moves the DMA channel thread to the Faulting completing state. ## **10.7.3 Programming restrictions** #### Fixed unaligned bursts The DMAC does not support fixed unaligned bursts. If you program the following conditions, the DMAC treats this as a programming error: Unaligned read - src inc field is 0 in the CCRn Register - the SARn Register contains an address that is not aligned to the size of data that the src\_burst\_size field contain Unaligned write - dst\_inc field is 0 in the CCRn Register - the DARn Register contains an address that is not aligned to the size of data that the dst\_burst\_size field contains #### **Endian swap size restrictions** If you program the endian\_swap\_size field in the CCRn Register, to enable a DMA channel to perform an endian swap then you must set the corresponding SARn Register and the corresponding DARn Register to contain an address that is aligned to the value that the endian swap size field contains. #### Updating DMA channel control registers during a DMA cyclerestrictions Prior to the DMAC executing a sequence of DMALD and DMAST instructions, the values you program in to the CCRn Register, SARn Register, and DARn Register control the data byte lane manipulation that the DMAC performs when it transfers the data from the source address to the destination address. You'd better not update these registers during a DMA cycle. #### Resource sharing between DMA channels DMA channel programs share the MFIFO data storage resource. You must not start a set ofconcurrently running DMA channel programs with a resource requirement that exceeds the configured size of the MFIFO. If you exceed this limit then the DMAC might lock up and generate a Watchdog abort. ## 10.7.4 Unaligned transfers may be corrupted For a configuration with more than one channel, if any of channels 1 to 7 is performing transfers between certain types of misaligned source and destination addresses, then the output data may be corrupted by the action of channel 0. Data corruption might occur if all of the following are true: - 1. Two beats of AXI read data are received for one of channels 1 to 7. - 2. Source and destination address alignments mean that each read data beat is split across two lines in the data buffer (see Splitting data, below). - 3. There is one idle cycle between the two read data beats . - 4. Channel 0 performs an operation that updates channel control information during this idle cycle (see Updates to channel control information, below) ### Splitting data Depending upon the programmed values for the DMA transfer, one beat of read data from the AXI interface mneed to be split across two lines in the internal data buffer. This occurs when the read data beat contains datbytes which will be written to addresses that wrap around at the AXI interface data width, so that these bytes could not be transferred by a single AXI write data beat of the full interface width. Most applications of DMA-330 do not split data in this way, so are NOT vulnerable to data corruption from thisdefect. The following cases are NOT vulnerable to data corruption because they do not split data: - Byte lane offset between source and destination addresses is 0 When source and destination addresses have the same byte lane alignment, the offset is 0 and a wrap operation that splits data cannot occur. - Byte lane offset between source and destination addresses is a multiple of source size | Source size in CCRn | Allowed offset between SARn and DARn | |---------------------|--------------------------------------| | SS8 | any offset allowed. | | SS16 | 0,2,4,6,8,10,12,14 | | SS32 | 0,4,8,12 | | SS64 | 0.8 | ## 10.7.5 Interrupt shares between channel. As the DMAC\_BUS does not record which channel (or list of channels) have asserted an interrupt. So it will depend on your program and whether any of the visible information for that program can be used to determine progress, and help identify the interrupt source. There are 4 likely information sources that can be used to determine the progress made by a program: - Program counter (PC) - Source address - Destination address - Loop counters (LC) For example, a program might emit an interrupt each time that it iterates around a loop. In this case, the interrupt service routine (ISR) would need to store the loop value of each channel when it is called, and then compare against the new value when it is next called. A change in value would indicate that the program has progressed. The ISR must be carefully written to ensure that no interrupts are lost. The sequence of operations is as follows: - 1. Disable interrupts - 2. Immediately clear the interrupt in DMA-330 - 3. Check the relevant registers for both channels to determine which must be serviced - 4. Take appropriate action for the channels - 5. Re-enable interrupts and exit ISR #### 10.7.6 Instruction sets Table 10-2 DMAC Instruction sets | Mnemonic | Instruction | Thread usage: • M = DMA manager | |-----------|-----------------------------|---------------------------------| | | | • C = DMA channel | | DMAADDH | Add Halfword | C | | DMAEND | End | M/C | | DMAFLUSHP | Flush and notify Peripheral | C | | DMAGO | Go | M | | DMAKILL | Kill | С | | DMALD | Load | С | | DMALDP | Load Peripheral | С | | DMALP | Loop | С | | DMALPEND | Loop End | С | | DMALPFE | Loop Forever | С | | DMAMOV | Move | С | | DMANOP | No operation | M/C | | DMARMB | Read Memory Barrier | С | | DMASEV | Send Event | M/C | | DMAST | Store | С | | DMASTP | Store and notify Peripheral | С | | DMASTZ | Store Zero | С | | DMAWFE | Wai t For Event M | M/C | | DMAWFP | Wait For Peripheral | С | | DMAWMB | Write Memory Barrier | С | | DMAADNH | Add Negative Halfword | С | #### 10.7.7 Assembler directives In this document, only DMMADNH instruction is took as an example to show the way the instruction assembled. For the other instructions, please refer to pl330\_trm.pdf. #### **DMAADNH** Add Negative Halfword adds an immediate negative 16-bit value to the SARn Register or D ARn Register, for the DMA channel thread. This enables the DMAC to support 2D DMA oper ations, or reading or writing an area of memory in adifferent order to naturally incrementing addresses. See Source Address Registers and Destination Address Registers. The immediate unsigned 16-bit value is one-extended to 32 bits, to create a value that is t he two's complement representation of a negative number between -65536 and -1, before the DMAC adds it to the address using 32-bit addition. The DMAC discards the carry bit so t hat addresses wrap from 0xFFFFFFFF to 0x00000000. The net effect is to subtract between 65536 and 1 from the current value in the Source or Destination Address Register. Following table shows the instruction encoding. | Imm[15:8] | Imm[7:0] | 0 | 1 | 0 | 1 | 1 | 1 | ra | 0 | |-----------------------------------------|----------|---|---|---|---|---|---|----|---| | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | _ | _ | | _ | _ | _ | | _ | #### **Assembler syntax** DMAADNH <address register>, <16-bit immediate> where: <address\_register> Selects the address register to use. It must be either: SAR SARn Register and sets ra to 0. DAR DARn Register and sets ra to 1. <16-bit immediate> The immediate value to be added to the <address\_register>. You should specify the 16-bit immediate as the number that is to be represented in the inst ruction encoding. For example, DMAADNH DAR, 0xFFF0 causes the value 0xFFFFFFF0 to be added to the current value of the Destination Address Register, effectively subtracting 16 fr om the DAR. You can only use this instruction in a DMA channel thread. ### 10.7.8 MFIFO usage For MFIFO usage , please refer to pl330\_trm.pdf