# Chapter 8 DMA Controller (DMAC)

# 8.1 Overview

DMAC does not support TrustZone technology and work under non-secure state only.

DMAC is mainly used for data transfer of the following slaves: I2S0, SD/MMC, SDIO, eMMC, UARTO, UART1, UART2, SPI0.

Following table shows the DMAC request mapping scheme.

|            | Table 8-1DMAC Request Map | <u> </u>   |
|------------|---------------------------|------------|
| Req number | Source                    | Polarity   |
| 0          | I2S_2ch_ tx               | High level |
| 1          | I2S_2ch_ rx               | High level |
| 2          | UART0 tx                  | High level |
| 3          | UART0 rx                  | High level |
| 4          | UART1 tx                  | High level |
| 5          | UART1 rx                  | High level |
| 6          | UART2 tx                  | High level |
| 7          | UART2 rx                  | High level |
| 8          | SPI tx                    | High level |
| 9          | SPI rx                    | High level |
| 10         | SD/MMC                    | High level |
| 11         | SDIO                      | High level |
| 12         | eMMC                      | High level |
| 13         | SPDIF                     | High level |
| 14         | I2S_8ch tx                | High level |
| 15         | I2S_8ch rx                | High level |

Table 9 1DMAC Dequest Manning Table

DMACsupports the following features:

- Supports 15 peripheral request.
- Up to 64bits data size.
- 8 channel at the same time.
- Up to burst 16.
- 1 interrupts output and 1 abort output.
- Supports 32 MFIFO depth.

# 8.2 Block Diagram

Figure 8-1 shows the block diagram of DMAC.



# **8.3 Function Description**

# 8.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 supports 8 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.

## 8.3.2 Operating states

Figure shows the operating states for the DMA manager thread and DMA channel threads.



Fig. 8-2 DMAC 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.

# 8.4 Register Description

### 8.4.1 Register summary

| Name               | Offset | Size | Reset<br>Value | Description                           |
|--------------------|--------|------|----------------|---------------------------------------|
| DMAC_DSR           | 0x0000 | W    | 0x0            | DMA Status Register.                  |
| DMAC_DPC           | 0x0004 | W    | 0×0            | DMA Program Counter<br>Register.      |
| -                  | -      | -    | -              | reserved                              |
| DMAC_INTEN         | 0x0020 | W    | 0x0            | Interrupt Enable Register             |
| DMAC_EVENT_RI<br>S | 0x0024 | W    | 0x0            | Event Status Register.                |
| DMAC_INTMIS        | 0x0028 | W    | 0x0            | Interrupt Status Register             |
| DMAC_INTCLR        | 0x002C | W    | 0x0            | Interrupt Clear Register              |
| DMAC_FSRD          | 0x0030 | W    | 0x0            | Fault Status DMA Manager<br>Register. |
| DMAC_FSRC          | 0x0034 | W    | 0x0            | Fault Status DMA Channel<br>Register. |
| DMAC_FTRD          | 0x0038 | W    | 0x0            | Fault Type DMA Manager<br>Register.   |
| -                  | -      | -    | -              | reserved                              |

|           |        | r        | 1   | 1                            |
|-----------|--------|----------|-----|------------------------------|
| DMAC_FTR0 | 0x0040 | W        | 0x0 | Fault type for DMA Channel 0 |
| DMAC_FTR1 | 0x0044 | W        | 0x0 | Fault type for DMA Channel 1 |
| DMAC_FTR2 | 0x0048 | W        | 0x0 | Fault type for DMA Channel 2 |
| DMAC_FTR3 | 0x004C | W        | 0x0 | Fault type for DMA Channel 3 |
| DMAC_FTR4 | 0x0050 | W        | 0x0 | Fault type for DMA Channel 4 |
| DMAC_FTR5 | 0x0054 | W        | 0x0 | Fault type for DMA Channel 5 |
| DMAC_FTR6 | 0x0058 | W        | 0x0 | Fault type for DMA Channel 6 |
| DMAC FTR7 | 0x005C | W        | 0x0 | Fault type for DMA Channel 7 |
| -         | -      | -        | -   | reserved                     |
|           |        |          |     | Channel Status for DMA       |
| DMAC_CSR0 | 0x0100 | W        | 0x0 | Channel 0                    |
|           |        |          |     | Channel Status for DMA       |
| DMAC_CSR1 | 0x0108 | W        | 0x0 | Channel 1                    |
|           |        |          |     | Channel Status for DMA       |
| DMAC_CSR2 | 0x0110 | W        | 0x0 | Channel 2                    |
|           |        |          |     | Channel Status for DMA       |
| DMAC_CSR3 | 0x0118 | W        | 0x0 | Channel 3                    |
|           |        |          |     |                              |
| DMAC_CSR4 | 0x0120 | W        | 0x0 |                              |
|           |        |          |     | Channel 4                    |
| DMAC_CSR5 | 0x0128 | W        | 0x0 | Channel Status for DMA       |
|           |        |          |     | Channel 5                    |
| DMAC_CSR6 | 0x0130 | W        | 0x0 | Channel Status for DMA       |
|           |        |          |     | Channel 6                    |
| DMAC_CSR7 | 0x0138 | W        | 0x0 | Channel Status for DMA       |
|           |        |          |     | Channel 7                    |
| DMAC_CPC0 | 0x0104 | W        | 0x0 | Channel PC for DMA Channel 0 |
| DMAC_CPC1 | 0x010c | W        | 0x0 | Channel PC for DMA Channel 1 |
| DMAC_CPC2 | 0x0114 | W        | 0x0 | Channel PC for DMA Channel 2 |
| DMAC_CPC3 | 0x011c | W        | 0x0 | Channel PC for DMA Channel 3 |
| DMAC_CPC4 | 0x0124 | W        | 0x0 | Channel PC for DMA Channel 4 |
| DMAC_CPC5 | 0x012c | W        | 0x0 | Channel PC for DMA Channel 5 |
| DMAC_CPC6 | 0x0134 | W        | 0x0 | Channel PC for DMA Channel 6 |
| DMAC_CPC7 | 0x013c | W        | 0x0 | Channel PC for DMA Channel 7 |
|           | 0.0400 |          | 00  | Source Address for DMA       |
| DMAC_SAR0 | 0x0400 | W        | 0x0 | Channel 0                    |
|           | 0.400  |          |     | Source Address for DMA       |
| DMAC_SAR1 | 0x0420 | W        | 0x0 | Channel 1                    |
|           |        |          |     | Source Address for DMA       |
| DMAC_SAR2 | 0x0440 | W        | 0x0 | Channel 2                    |
|           |        |          |     | Source Address for DMA       |
| DMAC_SAR3 | 0x0460 | W        | 0x0 | Channel 3                    |
|           |        |          |     | Source Address for DMA       |
| DMAC_SAR4 | 0x0480 | W        | 0x0 | Channel 4                    |
|           |        |          |     | Source Address for DMA       |
| DMAC_SAR5 | 0x04A0 | W        | 0x0 | Channel 5                    |
|           |        |          |     |                              |
| DMAC_SAR6 | 0x04C0 | W        | 0x0 |                              |
|           |        |          |     | Channel 6                    |
| DMAC_SAR7 | 0x04E0 | W        | 0x0 | Source Address for DMA       |
|           |        | <b> </b> |     | Channel 7                    |
| DMAC_DAR0 | 0x0404 | W        | 0x0 | Dest Address for DMAChannel  |
|           |        |          |     | 0                            |
| DMAC DAR1 | 0x0424 | W        | 0x0 | Dest Address for DMAChannel  |
|           |        |          |     | 1                            |

|            | 0.0444 |   |     | Dest Address for DMAChannel          |
|------------|--------|---|-----|--------------------------------------|
| DMAC_DAR2  | 0x0444 | W | 0x0 | 2                                    |
| DMAC_DAR3  | 0x0464 | W | 0x0 | Dest Address for DMAChannel 3        |
| DMAC_DAR4  | 0x0484 | W | 0x0 | Dest Address for DMAChannel<br>4     |
| DMAC_DAR5  | 0x04A4 | W | 0x0 | Dest Address for DMAChannel<br>5     |
| DMAC_DAR6  | 0x04C4 | W | 0x0 | Dest Address for DMAChannel<br>6     |
| DMAC_DAR7  | 0x04E4 | W | 0x0 | Dest Address for DMAChannel<br>7     |
| DMAC_CCR0  | 0x0408 | W | 0x0 | Channel Control for DMA<br>Channel 0 |
| DMAC_CCR1  | 0x0428 | W | 0x0 | Channel Control for DMA<br>Channel 1 |
| DMAC_CCR2  | 0x0448 | W | 0x0 | Channel Control for DMA<br>Channel 2 |
| DMAC_CCR3  | 0x0468 | W | 0x0 | Channel Control for DMA<br>Channel 3 |
| DMAC_CCR4  | 0x0488 | W | 0x0 | Channel Control for DMA<br>Channel 4 |
| DMAC_CCR5  | 0x04a8 | W | 0x0 | Channel Control for DMA<br>Channel 5 |
| DMAC_CCR6  | 0x04c8 | W | 0x0 | Channel Control for DMA<br>Channel 6 |
| DMAC_CCR7  | 0x04e8 | w | 0x0 | Channel Control for DMA<br>Channel 7 |
| DMAC_LC0_0 | 0x040C | W | 0×0 | Loop Counter 0 for DMA<br>Channel 0  |
| DMAC_LC0_1 | 0x042C | w | 0x0 | Loop Counter 0 for DMA<br>Channel 1  |
| DMAC_LC0_2 | 0x044C | W | 0x0 | Loop Counter 0 for DMA<br>Channel 2  |
| DMAC_LC0_3 | 0x046C | W | 0x0 | Loop Counter 0 for DMA<br>Channel 3  |
| DMAC_LC0_4 | 0x048C | W | 0x0 | Loop Counter 0 for DMA<br>Channel 4  |
| DMAC_LC0_5 | 0x04AC | W | 0x0 | Loop Counter 0 for DMA<br>Channel 5  |
| DMAC_LC0_6 | 0x04CC | W | 0x0 | Loop Counter 0 for DMA<br>Channel 6  |
| DMAC_LC0_7 | 0x04EC | W | 0x0 | Loop Counter 0 for DMA<br>Channel 7  |
| DMAC_LC1_0 | 0x0410 | W | 0x0 | Loop Counter 1 for DMA<br>Channel 0  |
| DMAC_LC1_1 | 0x0430 | W | 0x0 | Loop Counter 1 for DMA<br>Channel 1  |
| DMAC_LC1_2 | 0x0450 | W | 0×0 | Loop Counter 1 for DMA<br>Channel 2  |
| DMAC_LC1_3 | 0x0470 | W | 0×0 | Loop Counter 1 for DMA<br>Channel 3  |
| DMAC_LC1_4 | 0x0490 | W | 0x0 | Loop Counter 1 for DMA               |

High Performance and Low-power Processor for Digital Media Application

|                         |        |   |     | Channel 4                           |
|-------------------------|--------|---|-----|-------------------------------------|
| DMAC_LC1_5              | 0x04B0 | W | 0x0 | Loop Counter 1 for DMA<br>Channel 5 |
| DMAC_LC1_6              | 0x04D0 | W | 0x0 | Loop Counter 1 for DMA<br>Channel 6 |
| DMAC_LC1_7              | 0x04F0 | W | 0x0 | Loop Counter 1 for DMA<br>Channel 7 |
| -                       | -      | - | -   | reserved                            |
| DMAC_DBGST<br>DMAC_ATUS | 0x0D00 | W | 0x0 | Debug Status Register.              |
| DMAC_DBGCMD             | 0x0D04 | W | 0x0 | Debug Command Register.             |
| DMAC_DBGINST<br>0       | 0x0D08 | W | 0x0 | Debug Instruction-0 Register.       |
| DMAC_DBGINST            | 0x0D0C | W | 0x0 | Debug Instruction-1 Register.       |
| DMAC_CR0                | 0x0E00 | W |     | Configuration Register 0.           |
| DMAC_CR1                | 0x0E04 | W |     | Configuration Register 1.           |
| DMAC_CR2                | 0x0E08 | W |     | Configuration Register 2.           |
| DMAC_CR3                | 0x0E0C | W |     | Configuration Register 3.           |
| DMAC_CR4                | 0x0E10 | W |     | Configuration Register 4.           |
| DMAC_CRDn               | 0x0E14 | W |     | Configuration Register Dn.          |
| DMAC_WD                 | 0X0E80 | W |     | Watchdog Register                   |

Notes:

Size: B - Byte (8 bits) access, HW - Half WORD (16 bits) access, W -WORD (32 bits) access

# 8.4.2 Detail Register Description

### DMAC\_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:<br>0 = DMA manager operates in the Secure state<br>1 = DMA manager operates in the Non-secure state.                                          |
| 8:4   | R    | 0x0         | When the DMA manager thread executes a<br>DMAWFE instruction, it waits for the following<br>event to occur:<br>b00000 = event[0]<br>b00001 = event[1]<br>b00010 = event[2]<br><br>b11111 = event[31]. |
| 3:0   | R    | 0x0         | The operating state of the DMA manager:<br>b0000 = Stopped<br>b0001 = Executing<br>b0010 = Cache miss<br>b0011 = Updating PC<br>b0100 = Waiting for event                                             |

|  | b0101-b1110 = reserved |
|--|------------------------|
|  | b1111 = Faulting.      |

#### DMAC\_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\_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<br>DMAC responds when it executes DMASEV:<br>Bit [N] = 0 If the DMAC executes DMASEV for<br>the event-interrupt resource N then the DMAC<br>signals event N to all of the threads. Set bit [N]<br>to 0 if your system design does not use irq[N] to<br>signal an interrupt request.<br>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\_EVENT\_RIS

Address:Operational Base+0x24

Event-Interrupt Raw Status Register

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                             |
|------|------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | R    |                    | Returns the status of the event-interrupt resources:<br>Bit $[N] = 0$ Event N is inactive or irq $[N]$ is LOW.<br>Bit $[N] = 1$ Event N is active or irq $[N]$ is HIGH. |

#### DMAC\_INTMIS

Address:Operational Base+0x28 Interrupt Status Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                 |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | R    | 0x0         | Provides the status of the interrupts that are<br>active in the DMAC:<br>Bit $[N] = 0$ Interrupt N is inactive and therefore<br>irq $[N]$ is LOW.<br>Bit $[N] = 1$ Interrupt N is active and therefore<br>irq $[N]$ is HIGH |

### DMAC\_INTCLR

Address:Operational Base+0x2c

Interrupt Clear Register

| Bit  | Attr | Reset Value | Description                                                                                 |
|------|------|-------------|---------------------------------------------------------------------------------------------|
| 31:0 | W    | 0x0         | Controls the clearing of the irq outputs:<br>Bit $[N] = 0$ The status of irq $[N]$ does not |

|  | change.<br>Bit [N] = 1 The DMAC sets irq[N] LOW if the<br>INTEN Register programs the DMAC to signal an<br>interrupt.<br>Otherwise, the status of irq[N] does not change. |
|--|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|--|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

### DMAC\_FSRD

Address:Operational Base+0x30 Fault Status DMA Manager Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                        |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | R    | 0x0         | Provides the fault status of the DMA manager.<br>Read as:<br>0 = the DMA manager thread is not in the<br>Faulting state<br>1 = the DMA manager thread is in the Faulting<br>state. |

## DMAC\_FSRC

| DMAC_FSRC<br>Address:Operational Base+0><br>Fault Status DMA Channel Re |      |                    |                                                                                                                                                                                                              |
|-------------------------------------------------------------------------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                                                     | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                  |
| 31:0                                                                    | R    | 0x0                | Each bit provides the fault status of the corresponding channel. Read as:<br>Bit [N] = 0 No fault is present on DMA channel N.<br>Bit [N] = 1 DMA channel N is in the Faulting or Faulting completing state. |

#### DMAC\_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<br>the erroneous instruction was read from the<br>system memory or from the debug interface:<br>0 = instruction that generated an abort was read<br>from system memory<br>1 = instruction that generated an abort was read<br>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:<br>0 = OKAY response<br>1 = EXOKAY, SLVERR, or DECERR response                                                                                                                  |
| 15:6  | -    | -           | reserved                                                                                                                                                                                                                                                                                                 |
| 5     | R    | 0x0         | Indicates if the DMA manager was attempting to<br>execute DMAWFE or DMASEV with inappropriate<br>security permissions:<br>0 = DMA manager has appropriate security to<br>execute DMAWFE or DMASEV<br>1 = a DMA manager thread in the Non-secure<br>state attempted to execute either:                    |

| Rockchip<br><sub>端芯微电子</sub> RK3128 | Technical Reference Manual Rev 1.0 |
|-------------------------------------|------------------------------------|
|-------------------------------------|------------------------------------|

| -   |   |     | 1                                                                                                                                                                                                                                                                                                                      |
|-----|---|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |   |     | <ul> <li>DMAWFE to wait for a secure event</li> </ul>                                                                                                                                                                                                                                                                  |
|     |   |     | <ul> <li>DMASEV to create a secure event or secure</li> </ul>                                                                                                                                                                                                                                                          |
|     |   |     | interrupt                                                                                                                                                                                                                                                                                                              |
| 4   | R | 0x0 | ndicates if the DMA manager was attempting to<br>execute DMAGO with inappropriate security<br>permissions:<br>0 = DMA manager has appropriate security to<br>execute DMAGO<br>1 = a DMA manager thread in the Non-secure<br>state attempted to execute DMAGO to create a<br>DMA channel operating in the Secure state. |
| 3:2 | - | -   | reserved                                                                                                                                                                                                                                                                                                               |
| 1   | R | 0x0 | Indicates if the DMA manager was attempting to<br>execute an instruction operand that was not<br>valid for the configuration of the DMAC:<br>0 = valid operand<br>1 = invalid operand.                                                                                                                                 |
| 0   | R | 0x0 | Indicates if the DMA manager was attempting to<br>execute an undefined instruction:<br>0 = defined instruction<br>1 = undefined instruction.                                                                                                                                                                           |

### DMAC\_FTR0~DMAC\_FTR7

Address:Operational Base+0x40

Öperational Base+0x44 Operational Base+0x48 Operational Base+0x4C Operational Base+0x50 Operational Base+0x54 Operational Base+0x58 Operational Base+0x5C Fault Type DMA Channel Register

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | R    | 0×0         | Indicates if the DMA channel has locked-up<br>because of resource starvation:<br>0 = DMA channel has adequate resources<br>1 = DMA channel has locked-up because of<br>insufficient resources.<br>This fault is an imprecise abort                                                                                                                                                                     |
| 30    | R    | 0x0         | If the DMA channel aborts, this bit indicates if<br>the erroneous instruction was read from the<br>system memory or from the debug interface:<br>0 = instruction that generated an abort was read<br>from system memory<br>1 = instruction that generated an abort was read<br>from the debug interface.<br>This fault is an imprecise abort but the bit is only<br>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:<br>0 = OKAY response                                                                                                                                                                                                                                                            |

|       | r |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|---|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |   |     | 1 = EXOKAY, SLVERR, or DECERR response.<br>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:<br>0 = OKAY response<br>1 = EXOKAY, SLVERR, or DECERR response.<br>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:<br>0 = OKAY response<br>1 = EXOKAY, SLVERR, or DECERR response.<br>This fault is a precise abort.                                                                                                                                                                                                                                                    |
| 15:14 | - | -   | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 13    | R | 0x0 | Indicates if the MFIFO did not contain the data to<br>enable the DMAC to perform the DMAST:<br>0 = MFIFO contains all the data to enable the<br>DMAST to complete<br>1 = previous DMALDs have not put enough data<br>in the MFIFO to enable the DMAST to complete.<br>This fault is a precise abort.                                                                                                                                                                                 |
| 12    | R | 0x0 | Indicates if the MFIFO prevented the DMA<br>channel thread from executing DMALD or<br>DMAST. Depending on the instruction:<br>DMALD 0 = MFIFO contains sufficient space<br>1 = MFIFO is too small to hold the data that<br>DMALD requires.<br>DMAST 0 = MFIFO contains sufficient data<br>1 = MFIFO is too small to store the data to<br>enable DMAST to complete.<br>This fault is an imprecise abort                                                                               |
| 11:8  | - |     | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 7     | R | 0×0 | Indicates if a DMA channel thread, in the<br>Non-secure state, attempts to program the<br>CCRn Register to perform a secure read or<br>secure write:<br>0 = a DMA channel thread in the Non-secure<br>state is not violating the security permissions<br>1 = a DMA channel thread in the Non-secure<br>state attempted to perform a secure read or<br>secure write.<br>This fault is a precise abort                                                                                 |
| 6     | R | 0x0 | <ul> <li>Indicates if a DMA channel thread, in the Non-secure state, attempts to execute DMAWFP, DMALDP, DMASTP, or DMAFLUSHP with inappropriate security permissions:</li> <li>0 = a DMA channel thread in the Non-secure state is not violating the security permissions</li> <li>1 = a DMA channel thread in the Non-secure state attempted to execute either:</li> <li>DMAWFP to wait for a secure peripheral</li> <li>DMALDP or DMASTP to notify a secure peripheral</li> </ul> |

| 5                   | R | 0x0 | <ul> <li>DMAFLUSHP to flush a secure peripheral.<br/>This fault is a precise abort.</li> <li>Indicates if the DMA channel thread attempts to<br/>execute DMAWFE or DMASEV with inappropriate<br/>security permissions:</li> <li>a DMA channel thread in the Non-secure<br/>state is not violating the security permissions</li> <li>a DMA channel thread in the Non-secure<br/>state attempted to execute either:</li> </ul> |
|---------------------|---|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     |   |     | <ul> <li>DMAWFE to wait for a secure event</li> <li>DMASEV to create a secure event or secure interrupt.</li> <li>This fault is a precise abort.</li> </ul>                                                                                                                                                                                                                                                                  |
| 4:2                 | - | -   | reserved                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 1                   | R | 0x0 | Indicates if the DMA channel thread was<br>attempting to execute an instruction operand<br>that was not valid for the configuration of the<br>DMAC:<br>0 = valid operand<br>1 = invalid operand.<br>This fault is a precise abort.                                                                                                                                                                                           |
| 0                   | R | 0x0 | Indicates if the DMA channel thread was<br>attempting to execute an undefined instruction:<br>0 = defined instruction<br>1 = undefined instruction.<br>This fault is a precise abort                                                                                                                                                                                                                                         |
| DMAC_CSR0~DMAC_CSR7 |   |     |                                                                                                                                                                                                                                                                                                                                                                                                                              |

# DMAC\_CSR0~DMAC\_CSR7

| Address:Operational Base+0x100 |
|--------------------------------|
| Operational Base+0x108         |
| Operational Base+0x110         |
| Operational Base+0x118         |
| Operational Base+0x120         |
| Operational Base+0x128         |
| Operational Base+0x130         |
| Operational Base+0x138         |
| Channel Status Registers       |

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                         |
|-------|------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22 | -    |                    | reserved                                                                                                                                                                                                            |
| 21    | R    | 0x0                | The channel non-secure bit provides the security<br>of the DMA channel:<br>0 = DMA channel operates in the Secure state<br>1 = DMA channel operates in the Non-secure<br>state                                      |
| 20:16 | -    | -                  | reserved                                                                                                                                                                                                            |
| 15    | R    | 0x0                | When the DMA channel thread executes<br>DMAWFP this bit indicates if the periph operand<br>was set:<br>0 = DMAWFP executed with the periph operand<br>not set<br>1 = DMAWFP executed with the periph operand<br>set |
| 14    | R    | 0x0                | When the DMA channel thread executes DMAWFP this bit indicates if the burst or single                                                                                                                               |

|      | 1 |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|---|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |   |     | <pre>operand were set:<br/>0 = DMAWFP executed with the single operand<br/>set<br/>1 = DMAWFP executed with the burst operand<br/>set.</pre>                                                                                                                                                                                                                                                                                                                        |
| 13:9 | - | -   | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 8:4  | R | 0x0 | If the DMA channel is in the Waiting for event<br>state or the Waiting for peripheral state then<br>these bits indicate the event or peripheral<br>number that the channel is waiting for:<br>b00000 = DMA channel is waiting for event, or<br>peripheral, 0<br>b00001 = DMA channel is waiting for event, or<br>peripheral, 1<br>b00010 = DMA channel is waiting for event, or<br>peripheral, 2<br>b11111 = DMA channel is waiting for event, or<br>peripheral, 31 |
| 3:0  | R | 0x0 | The channel status encoding is:<br>b0000 = Stopped<br>b0001 = Executing<br>b0010 = Cache miss<br>b0011 = Updating PC<br>b0100 = Waiting for event<br>b0101 = At barrier<br>b0110 = reserved<br>b0111 = Waiting for peripheral<br>b1000 = Killing<br>b1001 = Completing<br>b1010-b1101 = reserved<br>b1110 = Faulting completing<br>b1111 = Faulting                                                                                                                 |

### DMAC\_CPC0~DMAC\_CPC7

Address:Operational Base+0x104 Operational Base+0x10C Operational Base+0x114 Operational Base+0x112 Operational Base+0x124 Operational Base+0x122 Operational Base+0x134 Operational Base+0x132 Channel Program Counter Registers

| Bit  | Attr | <b>Reset Value</b> | Description                                  |  |  |
|------|------|--------------------|----------------------------------------------|--|--|
| 31:0 | R    | 0x0                | Program counter for the DMA channel n thread |  |  |

### DMAC\_SAR0~DMAC\_SAR7

Address:Operational Base+0x400 Operational Base+0x420 Operational Base+0x440 Operational Base+0x460 Operational Base+0x480 Operational Base+0x4A0 Operational Base+0x4C0 Operational Base+0x4E0

#### Source Address Registers

| Bit  | Attr | <b>Reset Value</b> | Description                                  |
|------|------|--------------------|----------------------------------------------|
| 31:0 | R    | 0x0                | Address of the source data for DMA channel n |

#### DMAC\_DAR0~DMAC\_DAR7

| Addres | s:Oper                                          | ational Base+0> | x404  |  |  |
|--------|-------------------------------------------------|-----------------|-------|--|--|
|        | Ope                                             | rational Base+0 | )x424 |  |  |
|        | Ope                                             | rational Base+0 | )x444 |  |  |
|        | Operational Base+0x464                          |                 |       |  |  |
|        | Operational Base+0x484                          |                 |       |  |  |
|        | Operational Base+0x4A4                          |                 |       |  |  |
|        | Operational Base+0x4C4                          |                 |       |  |  |
|        | Operational Base+0x4E4                          |                 |       |  |  |
| Destin | DestinationAddress Registers                    |                 |       |  |  |
| Bit    |                                                 |                 |       |  |  |
| 21.0   | Address of the Destination data for DMA channel |                 |       |  |  |

n

DMAC\_CCR0~DMAC\_CCR7 Address:Operational Base+0x408

0x0

31:0 R

Operational Base+0x428 Operational Base+0x448 Operational Base+0x468 Operational Base+0x488 Operational Base+0x4A8 Operational Base+0x4C8 Operational Base+0x4E8

Channel Control Registers

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                               |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | -    | -           | reserved                                                                                                                                                                                                                                                                  |
| 27:25 | R    | 0×0         | Programs the state of AWCACHE[3,1:0]a when<br>the DMAC writes the destination data.<br>Bit [27] 0 = AWCACHE[3] is LOW<br>1 = AWCACHE[3] is HIGH.<br>Bit [26] 0 = AWCACHE[1] is LOW<br>1 = AWCACHE[1] is HIGH.<br>Bit [25] 0 = AWCACHE[0] is LOW<br>1 = AWCACHE[0] is HIGH |
| 24:22 | R    | 0x0         | Programs the state of AWPROT[2:0]a when the<br>DMAC writes the destination data.<br>Bit [24] 0 = AWPROT[2] is LOW<br>1 = AWPROT[2] is HIGH.<br>Bit [23] 0 = AWPROT[1] is LOW<br>1 = AWPROT[1] is HIGH.<br>Bit [22] 0 = AWPROT[0] is LOW<br>1 = AWPROT[0] is HIGH          |
| 21:18 | R    | 0x0         | For each burst, these bits program the number<br>of data transfers that the DMAC performs when<br>it writes the destination data:<br>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  |
|       |   |      | 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                  |
|       |   |      | b010 = writes 4 bytes per beat                  |
| 17:15 | R | 0x0  | 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       |
|       |   | 0,10 | 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           |
|       |   |      | source data.                                    |
|       |   |      | Bit $[13]$ 0 = ARCACHE $[2]$ is LOW             |
| 13:11 | R | 0x0  | 1 = ARCACHE[2] is HIGH.                         |
|       |   |      | Bit [12] 0 = ARCACHE[1] is LOW                  |
|       |   |      | 1 = ARCACHE[1] is HIGH.                         |
|       |   |      | Bit $[11]$ 0 = ARCACHE $[0]$ is LOW             |
|       | C |      | 1 = ARCACHE[0] is HIGH.                         |
|       |   |      | Programs the state of ARPROT[2:0]a when the     |
|       |   |      | DMAC reads the source data.                     |
|       |   |      | Bit $[10]$ 0 = ARPROT[2] is LOW                 |
|       |   |      |                                                 |
| 10:8  | R | 0x0  | 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.                          |
|       |   |      | For each burst, these bits program the number   |
|       |   |      | of data transfers that the DMAC performs when   |
|       |   |      | it reads the source data:                       |
| 7.4   |   | 0.40 | b0000 = 1 data transfer                         |
| 7:4   | R | 0x0  | b0001 = 2 data transfers                        |
|       |   |      | b0010 = 3 data transfers                        |
|       |   |      |                                                 |
|       |   |      |                                                 |
| L     |   | I    | •                                               |

|     |   |     | b1111 = 16 data transfers.<br>The total number of bytes that the DMAC reads<br>into the MFIFO when it executes a DMALD<br>instruction is the product of src_burst_len and<br>src_burst_size                                                                                                                                                                                                                                                                             |
|-----|---|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:1 | R | 0x0 | For each beat within a burst, it programs the<br>number of bytes that the DMAC reads from the<br>source:<br>b000 = reads 1 byte per beat<br>b001 = reads 2 bytes per beat<br>b010 = reads 4 bytes per beat<br>b011 = reads 8 bytes per beat<br>b100 = reads 16 bytes per beat<br>b101-b111 = reserved.<br>The total number of bytes that the DMAC reads<br>into the MFIFO when it executes a DMALD<br>instruction is the product of src_burst_len and<br>src_burst_size |
| 0   | R | 0x0 | Programs the burst type that the DMAC<br>performs when it reads the source data:<br>0 = Fixed-address burst. The DMAC signals<br>ARBURST[0] LOW.<br>1 = Incrementing-address burst. The DMAC<br>signals ARBURST[0] HIGH                                                                                                                                                                                                                                                 |

#### DMAC\_LC0\_0~DMAC\_LC0\_7

Address:Operational Base+0x40c Operational Base+0x42C Operational Base+0x44C Operational Base+0x44C Operational Base+0x46C Operational Base+0x48C Operational Base+0x4AC Operational Base+0x4CC Operational Base+0x4EC Loop Counter 0 Registers

| Bit  | Attr | <b>Reset Value</b> | Description               |
|------|------|--------------------|---------------------------|
| 31:8 | - (  | · · · ·            | reserved                  |
| 7:0  | R    | 0x0                | Loop counter 0 iterations |

# DMAC\_LC1\_0~DMAC\_LC1\_7

| Address:Operational Base+0x410 |  |
|--------------------------------|--|
| Operational Base+0x430         |  |
| Operational Base+0x450         |  |
| Operational Base+0x470         |  |
| Operational Base+0x490         |  |
| Operational Base+0x4B0         |  |
| Operational Base+0x4D0         |  |
| Operational Base+0x4F0         |  |
|                                |  |

Loop Counter 1 Registers

| Bit  | Attr | <b>Reset Value</b> | Description |
|------|------|--------------------|-------------|
| 31:8 | -    | -                  | reserved    |

| 7:0 | R | 0x0 | Loop counter 1 iterations |
|-----|---|-----|---------------------------|

#### DMAC\_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:<br>b00 = execute the instruction that the DBGINST<br>[1:0] Registers contain<br>b01 = reserved<br>b10 = reserved<br>b11 = reserved. |

#### DMAC\_DBGCMD

Address:Operational Base+0xD04 Debug Command Register

| Bit    | Attr | Reset Value | Description                                                                                                                                                          |
|--------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 - | -    | -           | reserved                                                                                                                                                             |
| 1:0 V  | N    | 0x0         | The debug encoding is as follows:<br>b00 = execute the instruction that the DBGINST<br>[1:0] Registers contain<br>b01 = reserved<br>b10 = reserved<br>b11 = reserved |

### DMAC\_DBGINST0

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                                                                                                      |
| 17: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:<br>0 = DMA manager thread<br>1 = DMA channel.                                  |

#### DMAC\_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\_CR0

Address:Operational Base+0xE00 Configuration Register 0

| -              |
|----------------|
|                |
| at the DMAC    |
| -              |
| ]              |
| 1:0]           |
| 2:0]           |
|                |
|                |
|                |
| ı[31:0].       |
| faces that the |
|                |
| erface         |
| erfaces        |
| erfaces        |
|                |
|                |
|                |
| terfaces.      |
|                |
| the DMAC       |
|                |
|                |
|                |
|                |
|                |
|                |
|                |
|                |
|                |
| _manager_ns    |
| reset:         |
|                |
|                |
| om_pc signal   |
|                |
|                |
|                |
|                |
| a peripheral   |
|                |
| of peripheral  |
| n_periph_req   |
|                |
|                |

## DMAC\_CR1

Address:Operational Base+0xE04 Configuration Register 1

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:8 | -    | -           | reserved    |

| 7:4 | R | 0x5 | <pre>[7:4] num_i-cache_lines Number of i-cache<br/>lines:<br/>b0000 = 1 i-cache line<br/>b0001 = 2 i-cache lines<br/>b0010 = 3 i-cache lines<br/><br/>b1111 = 16 i-cache lines.</pre> |
|-----|---|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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\_CR2

Address:Operational Base+0xE08

| Bit  |   | Reset Value | Description                                                           |
|------|---|-------------|-----------------------------------------------------------------------|
| 31:0 | R | 0x0         | Provides the value of boot_addr[31:0] when the DMAC exited from reset |

### DMAC\_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<br>resource:<br>Bit [N] = 0 Assigns event <n> or irq[N] to the<br/>Secure state.<br/>Bit [N] = 1 Assigns event<n> or irq[N] to the<br/>Non-secure state.</n></n> |

#### DMAC\_CR4

Address:Operational Base+0xE10 Configuration Register 4

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                             |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | Ř    | 0x6         | Provides the security state of the peripheral<br>request interfaces:<br>Bit $[N] = 0$ Assigns peripheral request interface<br>N to the Secure state.<br>Bit $[N] = 1$ Assigns peripheral request interface<br>N to the Non-secure state |

#### DMAC\_CRDn

Address:Operational Base+0xE14 DMA Configuration Register

| Bit   | Attr | Reset Value | Description                                                                                          |
|-------|------|-------------|------------------------------------------------------------------------------------------------------|
| 31:30 | -    | -           | reserved                                                                                             |
| 29:20 | R    | 0x20        | The number of lines that the data buffer<br>contains:<br>b000000000 = 1 line<br>b000000001 = 2 lines |

|       |          |          | b111111111 = 1024 lines                               |  |
|-------|----------|----------|-------------------------------------------------------|--|
|       |          |          | The depth of the read queue:                          |  |
|       |          |          | b0000 = 1 line                                        |  |
| 10.10 |          |          | b0001 = 2 lines                                       |  |
| 19:16 | R        | 0x9      |                                                       |  |
|       |          |          | •                                                     |  |
|       |          |          | h1111 10 lines                                        |  |
| 1 -   | _        |          | b1111 = 16 lines.                                     |  |
| 15    | -        | -        | reserved                                              |  |
|       |          |          | Read issuing capability that programs the             |  |
|       |          |          | number of outstanding read transactions:              |  |
| 14:12 | R        | 0x4      | b000 = 1                                              |  |
|       |          |          | b001 = 2                                              |  |
|       |          |          |                                                       |  |
|       |          |          | b111 = 8                                              |  |
|       |          |          | The depth of the write queue: $b0000 = 1$ line        |  |
| 11.0  | <b>D</b> | 07       |                                                       |  |
| 11:8  | R        | 0x7      | b0001 = 2 lines                                       |  |
|       |          |          | $\frac{1}{1111} = 16 \text{ lines}$                   |  |
| 7     | _        | _        | b1111 = 16 lines.                                     |  |
| /     | -        | -        |                                                       |  |
|       |          |          | Write issuing capability that programs the            |  |
|       |          |          | number of outstanding write transactions:<br>b000 = 1 |  |
| 6:4   | R        | 0x3      | b000 = 1<br>b001 = 2                                  |  |
|       |          |          |                                                       |  |
|       |          |          | b111 = 8                                              |  |
| 3     | -        |          | reserved                                              |  |
| 5     |          |          | The data bus width of the AXI interface:              |  |
|       |          | •        | b000 = reserved                                       |  |
|       |          |          | b000 = reserved                                       |  |
| 2:0   |          | 0x3      | b010 = 32-bit                                         |  |
| 2.5   |          |          | b010 = 52 bit                                         |  |
|       |          |          | b100 = 128-bit                                        |  |
|       | 1        | $1 \cup$ | b101-b111 = reserved.                                 |  |
| II    |          |          |                                                       |  |
|       |          | Y        |                                                       |  |
|       |          |          |                                                       |  |

# DMAC\_WD

Address:Operational Base+0xE80 DMA Watchdog Register

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                  |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | -    | -           | reserved                                                                                                                                                                                     |
| 0    | RW   | 0x0         | Controls how the DMAC responds when it detects a lock-up condition:<br>0 = the DMAC aborts all of the contributing DMA channels and sets irq_abort HIGH<br>1 = the DMAC sets irq_abort HIGH. |

# 8.5 Timing Diagram

Following picture shows the relationship between dma\_req and dma\_ack.

| Rockchip<br><sup>KK3128</sup> | Technical Referer | ice Manual | Rev 1.0 |
|-------------------------------|-------------------|------------|---------|
| clk                           |                   |            |         |
| dma_req                       |                   |            |         |
| dma_ack                       |                   |            |         |

Fig. 8-3 DMAC0 request and acknowledge timing

# 8.6 Interface Description

DMAC has the following tie-off signals. It can be configured by GRF register. (Please refer to the chapter to find how to configure)

| DMAC            |             |                |
|-----------------|-------------|----------------|
| interface       | Reset value | Control source |
| boot_addr       | 0x0         | GRF            |
| boot_from_pc    | 0x0         | GRF            |
| boot_manager_ns | 0x0         | GRF            |
| boot_irq_ns     | 0xf         | GRF            |
| boot_periph_ns  | 0xfffff     | GRF            |

#### 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=\mathsf{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.

# 8.7 Application Notes

# 8.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.

# 8.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 DMAchannel 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, tocontrol 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 TypeDMA 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 DMACcreates 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 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 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 ch\_rdwr\_err bit in the FTRn Register, see Fault Type DMA Channel Registers.

4. Moves the DMA channel thread to the Faulting completing state.

# 8.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 of concurrently 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.

## 8.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:

Two beats of AXI read data are received for one of channels 1 to 7.
 Source and destination address alignments mean that each read data beat is split across two lines in the data buffer (see Splitting data, below).
 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                                  |

# 8.7.5 Interrupt shares between channel.

As the DMAC0 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

8.7.6 Instruction sets

| Table 8-2 DMAC Instruction sets |                             |                   |  |  |
|---------------------------------|-----------------------------|-------------------|--|--|
| Mnemonic                        | Instruction                 | Thread usage:     |  |  |
|                                 |                             | • M = DMA manager |  |  |
|                                 |                             | • C = DMA channel |  |  |
| DMAADDH                         | Add Halfword                | С                 |  |  |
| DMAEND                          | End                         | M/C               |  |  |
| DMAFLUSHP                       | Flush and notify Peripheral | С                 |  |  |
| DMAGO                           | Go                          | Μ                 |  |  |
| 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       | С                 |  |  |

## 8.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 DARn Register, for the DMA channel thread. This enables the DMA C to support 2D DMA operations, or reading or writing an area of memory in a different order to naturally incrementing addresses. See Source Address Regis ters and Destination Address Registers.

The immediate unsigned 16-bit value is one-extended to 32 bits, to create a v alue that is the two's complement representation of a negative number betwe en -65536 and -1, before the DMAC adds it to the address using 32-bit additio n. The DMAC discards the carry bit so that addresses wrap from 0xFFFFFFF t o 0x00000000. The net effect is to subtract between 65536 and 1 from the cu rrent 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 |
|-----------|----------|---|---|---|---|---|---|----|---|
|           |          |   |   |   |   |   |   |    |   |

#### 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 represen ted in the instruction encoding. For example, DMAADNH DAR, 0xFFF0 causes t he value 0xFFFFFF0 to be added to the current value of the Destination Addr ess Register, effectively subtracting 16 from the DAR.

You can only use this instruction in a DMA channel thread.

# 8.7.8 MFIFO usage

For MFIFO usage , please refer to pl330\_trm.pdf