

set on this failure branch, then the ARM platform is interrupted immediately, and the channel process is also immediately terminated in the presence of a workload-detected NAND error bit.

Note that each word of the three-word DMA command structure corresponds to a PIO register of the DMA that is accessible on the APBH bus. Normally, the DMA copies the next command structure onto these registers for processing at the start of each command by following the value of the pointer previously loaded into the NEXTCMD\_ADDR register.

To start DMA processing for the first command, initialize the PIO registers of the desired channel, as follows:

- First, load the next command address register with a pointer to the first command to be loaded.
- Then, write 1 to the counting semaphore register. This causes the DMA to schedule the targeted channel for the DMA command structure load, just as if it had finished its previous command.

## 14.5 APBH Memory Map/Register Definition

### APBH Hardware Register Format Summary

**APBH memory map**

| Absolute address (hex) | Register name                                                     | Width (in bits) | Access | Reset value | Section/ page              |
|------------------------|-------------------------------------------------------------------|-----------------|--------|-------------|----------------------------|
| 11_0000                | AHB to APBH Bridge Control and Status Register 0 (APBH_CTRL0)     | 32              | R/W    | E000_0000h  | <a href="#">14.5.1/604</a> |
| 11_0004                | AHB to APBH Bridge Control and Status Register 0 (APBH_CTRL0_SET) | 32              | R/W    | E000_0000h  | <a href="#">14.5.1/604</a> |
| 11_0008                | AHB to APBH Bridge Control and Status Register 0 (APBH_CTRL0_CLR) | 32              | R/W    | E000_0000h  | <a href="#">14.5.1/604</a> |
| 11_000C                | AHB to APBH Bridge Control and Status Register 0 (APBH_CTRL0_TOG) | 32              | R/W    | E000_0000h  | <a href="#">14.5.1/604</a> |
| 11_0010                | AHB to APBH Bridge Control and Status Register 1 (APBH_CTRL1)     | 32              | R/W    | 0000_0000h  | <a href="#">14.5.2/606</a> |
| 11_0014                | AHB to APBH Bridge Control and Status Register 1 (APBH_CTRL1_SET) | 32              | R/W    | 0000_0000h  | <a href="#">14.5.2/606</a> |
| 11_0018                | AHB to APBH Bridge Control and Status Register 1 (APBH_CTRL1_CLR) | 32              | R/W    | 0000_0000h  | <a href="#">14.5.2/606</a> |

*Table continues on the next page...*

## APBH memory map (continued)

| Absolute address (hex) | Register name                                                           | Width (in bits) | Access | Reset value | Section/page |
|------------------------|-------------------------------------------------------------------------|-----------------|--------|-------------|--------------|
| 11_001C                | AHB to APBH Bridge Control and Status Register 1 (APBH_CTRL1_TOG)       | 32              | R/W    | 0000_0000h  | 14.5.2/606   |
| 11_0020                | AHB to APBH Bridge Control and Status Register 2 (APBH_CTRL2)           | 32              | R/W    | 0000_0000h  | 14.5.3/609   |
| 11_0024                | AHB to APBH Bridge Control and Status Register 2 (APBH_CTRL2_SET)       | 32              | R/W    | 0000_0000h  | 14.5.3/609   |
| 11_0028                | AHB to APBH Bridge Control and Status Register 2 (APBH_CTRL2_CLR)       | 32              | R/W    | 0000_0000h  | 14.5.3/609   |
| 11_002C                | AHB to APBH Bridge Control and Status Register 2 (APBH_CTRL2_TOG)       | 32              | R/W    | 0000_0000h  | 14.5.3/609   |
| 11_0030                | AHB to APBH Bridge Channel Register (APBH_CHANNEL_CTRL)                 | 32              | R/W    | 0000_0000h  | 14.5.4/614   |
| 11_0034                | AHB to APBH Bridge Channel Register (APBH_CHANNEL_CTRL_SET)             | 32              | R/W    | 0000_0000h  | 14.5.4/614   |
| 11_0038                | AHB to APBH Bridge Channel Register (APBH_CHANNEL_CTRL_CLR)             | 32              | R/W    | 0000_0000h  | 14.5.4/614   |
| 11_003C                | AHB to APBH Bridge Channel Register (APBH_CHANNEL_CTRL_TOG)             | 32              | R/W    | 0000_0000h  | 14.5.4/614   |
| 11_0040                | AHB to APBH DMA Device Assignment Register (APBH_DEVSEL)                | 32              | R/W    | 0000_0000h  | 14.5.5/615   |
| 11_0050                | AHB to APBH DMA burst size (APBH_DMA_BURST_SIZE)                        | 32              | R/W    | 0055_5555h  | 14.5.6/616   |
| 11_0060                | AHB to APBH DMA Debug Register (APBH_DEBUG)                             | 32              | R/W    | 0000_0000h  | 14.5.7/617   |
| 11_0100                | APBH DMA Channel n Current Command Address Register (APBH_CH0_CURCMDAR) | 32              | R/W    | 0000_0000h  | 14.5.8/618   |
| 11_0110                | APBH DMA Channel n Next Command Address Register (APBH_CH0_NXTCMDAR)    | 32              | R/W    | 0000_0000h  | 14.5.9/619   |
| 11_0120                | APBH DMA Channel n Command Register (APBH_CH0_CMD)                      | 32              | R/W    | 0000_0000h  | 14.5.10/619  |
| 11_0130                | APBH DMA Channel n Buffer Address Register (APBH_CH0_BAR)               | 32              | R/W    | 0000_0000h  | 14.5.11/621  |
| 11_0140                | APBH DMA Channel n Semaphore Register (APBH_CH0_SEMA)                   | 32              | R/W    | 0000_0000h  | 14.5.12/622  |
| 11_0150                | AHB to APBH DMA Channel n Debug Information (APBH_CH0_DEBUG1)           | 32              | R/W    | 00A0_0000h  | 14.5.13/623  |
| 11_0160                | AHB to APBH DMA Channel n Debug Information (APBH_CH0_DEBUG2)           | 32              | R/W    | 0000_0000h  | 14.5.14/626  |
| 11_0170                | APBH DMA Channel n Current Command Address Register (APBH_CH1_CURCMDAR) | 32              | R/W    | 0000_0000h  | 14.5.8/618   |
| 11_0180                | APBH DMA Channel n Next Command Address Register (APBH_CH1_NXTCMDAR)    | 32              | R/W    | 0000_0000h  | 14.5.9/619   |
| 11_0190                | APBH DMA Channel n Command Register (APBH_CH1_CMD)                      | 32              | R/W    | 0000_0000h  | 14.5.10/619  |
| 11_01A0                | APBH DMA Channel n Buffer Address Register (APBH_CH1_BAR)               | 32              | R/W    | 0000_0000h  | 14.5.11/621  |

Table continues on the next page...

## APBH memory map (continued)

| Absolute address (hex) | Register name                                                           | Width (in bits) | Access | Reset value | Section/ page                |
|------------------------|-------------------------------------------------------------------------|-----------------|--------|-------------|------------------------------|
| 11_01B0                | APBH DMA Channel n Semaphore Register (APBH_CH1_SEMA)                   | 32              | R/W    | 0000_0000h  | <a href="#">14.5.12/ 622</a> |
| 11_01C0                | AHB to APBH DMA Channel n Debug Information (APBH_CH1_DEBUG1)           | 32              | R/W    | 00A0_0000h  | <a href="#">14.5.13/ 623</a> |
| 11_01D0                | AHB to APBH DMA Channel n Debug Information (APBH_CH1_DEBUG2)           | 32              | R/W    | 0000_0000h  | <a href="#">14.5.14/ 626</a> |
| 11_01E0                | APBH DMA Channel n Current Command Address Register (APBH_CH2_CURCMDAR) | 32              | R/W    | 0000_0000h  | <a href="#">14.5.8/618</a>   |
| 11_01F0                | APBH DMA Channel n Next Command Address Register (APBH_CH2_NXTCMDAR)    | 32              | R/W    | 0000_0000h  | <a href="#">14.5.9/619</a>   |
| 11_0200                | APBH DMA Channel n Command Register (APBH_CH2_CMD)                      | 32              | R/W    | 0000_0000h  | <a href="#">14.5.10/ 619</a> |
| 11_0210                | APBH DMA Channel n Buffer Address Register (APBH_CH2_BAR)               | 32              | R/W    | 0000_0000h  | <a href="#">14.5.11/ 621</a> |
| 11_0220                | APBH DMA Channel n Semaphore Register (APBH_CH2_SEMA)                   | 32              | R/W    | 0000_0000h  | <a href="#">14.5.12/ 622</a> |
| 11_0230                | AHB to APBH DMA Channel n Debug Information (APBH_CH2_DEBUG1)           | 32              | R/W    | 00A0_0000h  | <a href="#">14.5.13/ 623</a> |
| 11_0240                | AHB to APBH DMA Channel n Debug Information (APBH_CH2_DEBUG2)           | 32              | R/W    | 0000_0000h  | <a href="#">14.5.14/ 626</a> |
| 11_0250                | APBH DMA Channel n Current Command Address Register (APBH_CH3_CURCMDAR) | 32              | R/W    | 0000_0000h  | <a href="#">14.5.8/618</a>   |
| 11_0260                | APBH DMA Channel n Next Command Address Register (APBH_CH3_NXTCMDAR)    | 32              | R/W    | 0000_0000h  | <a href="#">14.5.9/619</a>   |
| 11_0270                | APBH DMA Channel n Command Register (APBH_CH3_CMD)                      | 32              | R/W    | 0000_0000h  | <a href="#">14.5.10/ 619</a> |
| 11_0280                | APBH DMA Channel n Buffer Address Register (APBH_CH3_BAR)               | 32              | R/W    | 0000_0000h  | <a href="#">14.5.11/ 621</a> |
| 11_0290                | APBH DMA Channel n Semaphore Register (APBH_CH3_SEMA)                   | 32              | R/W    | 0000_0000h  | <a href="#">14.5.12/ 622</a> |
| 11_02A0                | AHB to APBH DMA Channel n Debug Information (APBH_CH3_DEBUG1)           | 32              | R/W    | 00A0_0000h  | <a href="#">14.5.13/ 623</a> |
| 11_02B0                | AHB to APBH DMA Channel n Debug Information (APBH_CH3_DEBUG2)           | 32              | R/W    | 0000_0000h  | <a href="#">14.5.14/ 626</a> |
| 11_02C0                | APBH DMA Channel n Current Command Address Register (APBH_CH4_CURCMDAR) | 32              | R/W    | 0000_0000h  | <a href="#">14.5.8/618</a>   |
| 11_02D0                | APBH DMA Channel n Next Command Address Register (APBH_CH4_NXTCMDAR)    | 32              | R/W    | 0000_0000h  | <a href="#">14.5.9/619</a>   |
| 11_02E0                | APBH DMA Channel n Command Register (APBH_CH4_CMD)                      | 32              | R/W    | 0000_0000h  | <a href="#">14.5.10/ 619</a> |
| 11_02F0                | APBH DMA Channel n Buffer Address Register (APBH_CH4_BAR)               | 32              | R/W    | 0000_0000h  | <a href="#">14.5.11/ 621</a> |
| 11_0300                | APBH DMA Channel n Semaphore Register (APBH_CH4_SEMA)                   | 32              | R/W    | 0000_0000h  | <a href="#">14.5.12/ 622</a> |

Table continues on the next page...

**APBH memory map (continued)**

| Absolute address (hex) | Register name                                                           | Width (in bits) | Access | Reset value | Section/page                |
|------------------------|-------------------------------------------------------------------------|-----------------|--------|-------------|-----------------------------|
| 11_0310                | AHB to APBH DMA Channel n Debug Information (APBH_CH4_DEBUG1)           | 32              | R/W    | 00A0_0000h  | <a href="#">14.5.13/623</a> |
| 11_0320                | AHB to APBH DMA Channel n Debug Information (APBH_CH4_DEBUG2)           | 32              | R/W    | 0000_0000h  | <a href="#">14.5.14/626</a> |
| 11_0330                | APBH DMA Channel n Current Command Address Register (APBH_CH5_CURCMDAR) | 32              | R/W    | 0000_0000h  | <a href="#">14.5.8/618</a>  |
| 11_0340                | APBH DMA Channel n Next Command Address Register (APBH_CH5_NXTCMDAR)    | 32              | R/W    | 0000_0000h  | <a href="#">14.5.9/619</a>  |
| 11_0350                | APBH DMA Channel n Command Register (APBH_CH5_CMD)                      | 32              | R/W    | 0000_0000h  | <a href="#">14.5.10/619</a> |
| 11_0360                | APBH DMA Channel n Buffer Address Register (APBH_CH5_BAR)               | 32              | R/W    | 0000_0000h  | <a href="#">14.5.11/621</a> |
| 11_0370                | APBH DMA Channel n Semaphore Register (APBH_CH5_SEMA)                   | 32              | R/W    | 0000_0000h  | <a href="#">14.5.12/622</a> |
| 11_0380                | AHB to APBH DMA Channel n Debug Information (APBH_CH5_DEBUG1)           | 32              | R/W    | 00A0_0000h  | <a href="#">14.5.13/623</a> |
| 11_0390                | AHB to APBH DMA Channel n Debug Information (APBH_CH5_DEBUG2)           | 32              | R/W    | 0000_0000h  | <a href="#">14.5.14/626</a> |
| 11_03A0                | APBH DMA Channel n Current Command Address Register (APBH_CH6_CURCMDAR) | 32              | R/W    | 0000_0000h  | <a href="#">14.5.8/618</a>  |
| 11_03B0                | APBH DMA Channel n Next Command Address Register (APBH_CH6_NXTCMDAR)    | 32              | R/W    | 0000_0000h  | <a href="#">14.5.9/619</a>  |
| 11_03C0                | APBH DMA Channel n Command Register (APBH_CH6_CMD)                      | 32              | R/W    | 0000_0000h  | <a href="#">14.5.10/619</a> |
| 11_03D0                | APBH DMA Channel n Buffer Address Register (APBH_CH6_BAR)               | 32              | R/W    | 0000_0000h  | <a href="#">14.5.11/621</a> |
| 11_03E0                | APBH DMA Channel n Semaphore Register (APBH_CH6_SEMA)                   | 32              | R/W    | 0000_0000h  | <a href="#">14.5.12/622</a> |
| 11_03F0                | AHB to APBH DMA Channel n Debug Information (APBH_CH6_DEBUG1)           | 32              | R/W    | 00A0_0000h  | <a href="#">14.5.13/623</a> |
| 11_0400                | AHB to APBH DMA Channel n Debug Information (APBH_CH6_DEBUG2)           | 32              | R/W    | 0000_0000h  | <a href="#">14.5.14/626</a> |
| 11_0410                | APBH DMA Channel n Current Command Address Register (APBH_CH7_CURCMDAR) | 32              | R/W    | 0000_0000h  | <a href="#">14.5.8/618</a>  |
| 11_0420                | APBH DMA Channel n Next Command Address Register (APBH_CH7_NXTCMDAR)    | 32              | R/W    | 0000_0000h  | <a href="#">14.5.9/619</a>  |
| 11_0430                | APBH DMA Channel n Command Register (APBH_CH7_CMD)                      | 32              | R/W    | 0000_0000h  | <a href="#">14.5.10/619</a> |
| 11_0440                | APBH DMA Channel n Buffer Address Register (APBH_CH7_BAR)               | 32              | R/W    | 0000_0000h  | <a href="#">14.5.11/621</a> |
| 11_0450                | APBH DMA Channel n Semaphore Register (APBH_CH7_SEMA)                   | 32              | R/W    | 0000_0000h  | <a href="#">14.5.12/622</a> |
| 11_0460                | AHB to APBH DMA Channel n Debug Information (APBH_CH7_DEBUG1)           | 32              | R/W    | 00A0_0000h  | <a href="#">14.5.13/623</a> |

Table continues on the next page...

## APBH memory map (continued)

| Absolute address (hex) | Register name                                                            | Width (in bits) | Access | Reset value | Section/ page                |
|------------------------|--------------------------------------------------------------------------|-----------------|--------|-------------|------------------------------|
| 11_0470                | AHB to APBH DMA Channel n Debug Information (APBH_CH7_DEBUG2)            | 32              | R/W    | 0000_0000h  | <a href="#">14.5.14/ 626</a> |
| 11_0480                | APBH DMA Channel n Current Command Address Register (APBH_CH8_CURCMDAR)  | 32              | R/W    | 0000_0000h  | <a href="#">14.5.8/618</a>   |
| 11_0490                | APBH DMA Channel n Next Command Address Register (APBH_CH8_NXTCMDAR)     | 32              | R/W    | 0000_0000h  | <a href="#">14.5.9/619</a>   |
| 11_04A0                | APBH DMA Channel n Command Register (APBH_CH8_CMD)                       | 32              | R/W    | 0000_0000h  | <a href="#">14.5.10/ 619</a> |
| 11_04B0                | APBH DMA Channel n Buffer Address Register (APBH_CH8_BAR)                | 32              | R/W    | 0000_0000h  | <a href="#">14.5.11/ 621</a> |
| 11_04C0                | APBH DMA Channel n Semaphore Register (APBH_CH8_SEMA)                    | 32              | R/W    | 0000_0000h  | <a href="#">14.5.12/ 622</a> |
| 11_04D0                | AHB to APBH DMA Channel n Debug Information (APBH_CH8_DEBUG1)            | 32              | R/W    | 00A0_0000h  | <a href="#">14.5.13/ 623</a> |
| 11_04E0                | AHB to APBH DMA Channel n Debug Information (APBH_CH8_DEBUG2)            | 32              | R/W    | 0000_0000h  | <a href="#">14.5.14/ 626</a> |
| 11_04F0                | APBH DMA Channel n Current Command Address Register (APBH_CH9_CURCMDAR)  | 32              | R/W    | 0000_0000h  | <a href="#">14.5.8/618</a>   |
| 11_0500                | APBH DMA Channel n Next Command Address Register (APBH_CH9_NXTCMDAR)     | 32              | R/W    | 0000_0000h  | <a href="#">14.5.9/619</a>   |
| 11_0510                | APBH DMA Channel n Command Register (APBH_CH9_CMD)                       | 32              | R/W    | 0000_0000h  | <a href="#">14.5.10/ 619</a> |
| 11_0520                | APBH DMA Channel n Buffer Address Register (APBH_CH9_BAR)                | 32              | R/W    | 0000_0000h  | <a href="#">14.5.11/ 621</a> |
| 11_0530                | APBH DMA Channel n Semaphore Register (APBH_CH9_SEMA)                    | 32              | R/W    | 0000_0000h  | <a href="#">14.5.12/ 622</a> |
| 11_0540                | AHB to APBH DMA Channel n Debug Information (APBH_CH9_DEBUG1)            | 32              | R/W    | 00A0_0000h  | <a href="#">14.5.13/ 623</a> |
| 11_0550                | AHB to APBH DMA Channel n Debug Information (APBH_CH9_DEBUG2)            | 32              | R/W    | 0000_0000h  | <a href="#">14.5.14/ 626</a> |
| 11_0560                | APBH DMA Channel n Current Command Address Register (APBH_CH10_CURCMDAR) | 32              | R/W    | 0000_0000h  | <a href="#">14.5.8/618</a>   |
| 11_0570                | APBH DMA Channel n Next Command Address Register (APBH_CH10_NXTCMDAR)    | 32              | R/W    | 0000_0000h  | <a href="#">14.5.9/619</a>   |
| 11_0580                | APBH DMA Channel n Command Register (APBH_CH10_CMD)                      | 32              | R/W    | 0000_0000h  | <a href="#">14.5.10/ 619</a> |
| 11_0590                | APBH DMA Channel n Buffer Address Register (APBH_CH10_BAR)               | 32              | R/W    | 0000_0000h  | <a href="#">14.5.11/ 621</a> |
| 11_05A0                | APBH DMA Channel n Semaphore Register (APBH_CH10_SEMA)                   | 32              | R/W    | 0000_0000h  | <a href="#">14.5.12/ 622</a> |
| 11_05B0                | AHB to APBH DMA Channel n Debug Information (APBH_CH10_DEBUG1)           | 32              | R/W    | 00A0_0000h  | <a href="#">14.5.13/ 623</a> |
| 11_05C0                | AHB to APBH DMA Channel n Debug Information (APBH_CH10_DEBUG2)           | 32              | R/W    | 0000_0000h  | <a href="#">14.5.14/ 626</a> |

Table continues on the next page...

**APBH memory map (continued)**

| Absolute address (hex) | Register name                                                            | Width (in bits) | Access | Reset value | Section/ page               |
|------------------------|--------------------------------------------------------------------------|-----------------|--------|-------------|-----------------------------|
| 11_05D0                | APBH DMA Channel n Current Command Address Register (APBH_CH11_CURCMDAR) | 32              | R/W    | 0000_0000h  | <a href="#">14.5.8/618</a>  |
| 11_05E0                | APBH DMA Channel n Next Command Address Register (APBH_CH11_NXTCMDAR)    | 32              | R/W    | 0000_0000h  | <a href="#">14.5.9/619</a>  |
| 11_05F0                | APBH DMA Channel n Command Register (APBH_CH11_CMD)                      | 32              | R/W    | 0000_0000h  | <a href="#">14.5.10/619</a> |
| 11_0600                | APBH DMA Channel n Buffer Address Register (APBH_CH11_BAR)               | 32              | R/W    | 0000_0000h  | <a href="#">14.5.11/621</a> |
| 11_0610                | APBH DMA Channel n Semaphore Register (APBH_CH11_SEMA)                   | 32              | R/W    | 0000_0000h  | <a href="#">14.5.12/622</a> |
| 11_0620                | AHB to APBH DMA Channel n Debug Information (APBH_CH11_DEBUG1)           | 32              | R/W    | 00A0_0000h  | <a href="#">14.5.13/623</a> |
| 11_0630                | AHB to APBH DMA Channel n Debug Information (APBH_CH11_DEBUG2)           | 32              | R/W    | 0000_0000h  | <a href="#">14.5.14/626</a> |
| 11_0640                | APBH DMA Channel n Current Command Address Register (APBH_CH12_CURCMDAR) | 32              | R/W    | 0000_0000h  | <a href="#">14.5.8/618</a>  |
| 11_0650                | APBH DMA Channel n Next Command Address Register (APBH_CH12_NXTCMDAR)    | 32              | R/W    | 0000_0000h  | <a href="#">14.5.9/619</a>  |
| 11_0660                | APBH DMA Channel n Command Register (APBH_CH12_CMD)                      | 32              | R/W    | 0000_0000h  | <a href="#">14.5.10/619</a> |
| 11_0670                | APBH DMA Channel n Buffer Address Register (APBH_CH12_BAR)               | 32              | R/W    | 0000_0000h  | <a href="#">14.5.11/621</a> |
| 11_0680                | APBH DMA Channel n Semaphore Register (APBH_CH12_SEMA)                   | 32              | R/W    | 0000_0000h  | <a href="#">14.5.12/622</a> |
| 11_0690                | AHB to APBH DMA Channel n Debug Information (APBH_CH12_DEBUG1)           | 32              | R/W    | 00A0_0000h  | <a href="#">14.5.13/623</a> |
| 11_06A0                | AHB to APBH DMA Channel n Debug Information (APBH_CH12_DEBUG2)           | 32              | R/W    | 0000_0000h  | <a href="#">14.5.14/626</a> |
| 11_06B0                | APBH DMA Channel n Current Command Address Register (APBH_CH13_CURCMDAR) | 32              | R/W    | 0000_0000h  | <a href="#">14.5.8/618</a>  |
| 11_06C0                | APBH DMA Channel n Next Command Address Register (APBH_CH13_NXTCMDAR)    | 32              | R/W    | 0000_0000h  | <a href="#">14.5.9/619</a>  |
| 11_06D0                | APBH DMA Channel n Command Register (APBH_CH13_CMD)                      | 32              | R/W    | 0000_0000h  | <a href="#">14.5.10/619</a> |
| 11_06E0                | APBH DMA Channel n Buffer Address Register (APBH_CH13_BAR)               | 32              | R/W    | 0000_0000h  | <a href="#">14.5.11/621</a> |
| 11_06F0                | APBH DMA Channel n Semaphore Register (APBH_CH13_SEMA)                   | 32              | R/W    | 0000_0000h  | <a href="#">14.5.12/622</a> |
| 11_0700                | AHB to APBH DMA Channel n Debug Information (APBH_CH13_DEBUG1)           | 32              | R/W    | 00A0_0000h  | <a href="#">14.5.13/623</a> |
| 11_0710                | AHB to APBH DMA Channel n Debug Information (APBH_CH13_DEBUG2)           | 32              | R/W    | 0000_0000h  | <a href="#">14.5.14/626</a> |
| 11_0720                | APBH DMA Channel n Current Command Address Register (APBH_CH14_CURCMDAR) | 32              | R/W    | 0000_0000h  | <a href="#">14.5.8/618</a>  |

Table continues on the next page...

## APBH memory map (continued)

| Absolute address (hex) | Register name                                                            | Width (in bits) | Access | Reset value | Section/ page                |
|------------------------|--------------------------------------------------------------------------|-----------------|--------|-------------|------------------------------|
| 11_0730                | APBH DMA Channel n Next Command Address Register (APBH_CH14_NXTCMDAR)    | 32              | R/W    | 0000_0000h  | <a href="#">14.5.9/619</a>   |
| 11_0740                | APBH DMA Channel n Command Register (APBH_CH14_CMD)                      | 32              | R/W    | 0000_0000h  | <a href="#">14.5.10/ 619</a> |
| 11_0750                | APBH DMA Channel n Buffer Address Register (APBH_CH14_BAR)               | 32              | R/W    | 0000_0000h  | <a href="#">14.5.11/ 621</a> |
| 11_0760                | APBH DMA Channel n Semaphore Register (APBH_CH14_SEMA)                   | 32              | R/W    | 0000_0000h  | <a href="#">14.5.12/ 622</a> |
| 11_0770                | AHB to APBH DMA Channel n Debug Information (APBH_CH14_DEBUG1)           | 32              | R/W    | 00A0_0000h  | <a href="#">14.5.13/ 623</a> |
| 11_0780                | AHB to APBH DMA Channel n Debug Information (APBH_CH14_DEBUG2)           | 32              | R/W    | 0000_0000h  | <a href="#">14.5.14/ 626</a> |
| 11_0790                | APBH DMA Channel n Current Command Address Register (APBH_CH15_CURCMDAR) | 32              | R/W    | 0000_0000h  | <a href="#">14.5.8/618</a>   |
| 11_07A0                | APBH DMA Channel n Next Command Address Register (APBH_CH15_NXTCMDAR)    | 32              | R/W    | 0000_0000h  | <a href="#">14.5.9/619</a>   |
| 11_07B0                | APBH DMA Channel n Command Register (APBH_CH15_CMD)                      | 32              | R/W    | 0000_0000h  | <a href="#">14.5.10/ 619</a> |
| 11_07C0                | APBH DMA Channel n Buffer Address Register (APBH_CH15_BAR)               | 32              | R/W    | 0000_0000h  | <a href="#">14.5.11/ 621</a> |
| 11_07D0                | APBH DMA Channel n Semaphore Register (APBH_CH15_SEMA)                   | 32              | R/W    | 0000_0000h  | <a href="#">14.5.12/ 622</a> |
| 11_07E0                | AHB to APBH DMA Channel n Debug Information (APBH_CH15_DEBUG1)           | 32              | R/W    | 00A0_0000h  | <a href="#">14.5.13/ 623</a> |
| 11_07F0                | AHB to APBH DMA Channel n Debug Information (APBH_CH15_DEBUG2)           | 32              | R/W    | 0000_0000h  | <a href="#">14.5.14/ 626</a> |
| 11_0800                | APBH Bridge Version Register (APBH_VERSION)                              | 32              | R/W    | 0301_0000h  | <a href="#">14.5.15/ 627</a> |

## 14.5.1 AHB to APBH Bridge Control and Status Register 0 (APBH\_CTRL0n)

The APBH CTRL 0 provides overall control of the AHB to APBH bridge and DMA.

This register contains module softreset, clock gating, channel clock gating/freeze bits.

Address: 11\_0000h base + 0h offset + (4d × i), where i=0d to 3d

| Bit   | 31     | 30      | 29            | 28           | 27 | 26 | 25 | 24 |  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|--------|---------|---------------|--------------|----|----|----|----|--|----|----|----|----|----|----|----|----|
| R     | SFTRST | CLKGATE | AHB_BURST8_EN | APB_BURST_EN |    |    |    |    |  |    |    |    |    |    |    |    |    |
| W     |        |         |               |              |    |    |    |    |  |    |    |    |    |    |    |    |    |
| Reset | 1      | 1       | 1             | 0            | 0  | 0  | 0  | 0  |  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15     | 14      | 13            | 12           | 11 | 10 | 9  | 8  |  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| R     |        |         |               |              |    |    |    |    |  |    |    |    |    |    |    |    |    |
| W     |        |         |               |              |    |    |    |    |  |    |    |    |    |    |    |    |    |
| Reset | 0      | 0       | 0             | 0            | 0  | 0  | 0  | 0  |  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

### APBH\_CTRL0n field descriptions

| Field            | Description                                                                                                                                                                                                                                                                                                   |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 SFTRST        | Set this bit to zero to enable normal APBH DMA operation. Set this bit to one (default) to disable clocking with the APBH DMA and hold it in its reset (lowest power) state. This bit can be turned on and then off to reset the APBH DMA block to its default state.                                         |
| 30 CLKGATE       | This bit must be set to zero for normal operation. When set to one it gates off the clocks to the block.                                                                                                                                                                                                      |
| 29 AHB_BURST8_EN | Set this bit to one (default) to enable AHB 8-beat burst. Set to zero to disable 8-beat burst on AHB interface.                                                                                                                                                                                               |
| 28 APB_BURST_EN  | Set this bit to one to enable apb master do a continuous transfers when a device request a burst dma. Set to zero will treat a burst dma request as 4/8 individual requests.                                                                                                                                  |
| 27–16 RSVD0      | This field is reserved.<br>Reserved, always set to zero.                                                                                                                                                                                                                                                      |
| CLKGATE_CHANNEL  | These bits must be set to zero for normal operation of each channel. When set to one they gate off the individual clocks to the channels.<br><br>0x0001 NAND0 —<br>0x0002 NAND1 —<br>0x0004 NAND2 —<br>0x0008 NAND3 —<br>0x0010 NAND4 —<br>0x0020 NAND5 —<br>0x0040 NAND6 —<br>0x0080 NAND7 —<br>0x0100 SSP — |

## 14.5.2 AHB to APBH Bridge Control and Status Register 1 (APBH\_CTRL1n)

The APBH CTRL one provides overall control of the interrupts generated by the AHB to APBH DMA. This register contains the per channel interrupt status bits and the per channel interrupt enable bits. Each channel has a dedicated interrupt vector in the vectored interrupt controller.

### EXAMPLE

```
BF_WR(APBH_CTRL1, CH5_CMDCMPLT_IRQ, 0); // use bitfield write macro
BF_APBH_CTRL1.CH5_CMDCMPLT_IRQ = 0; // or, assign to register
struct's bitfield
```

Address: 11\_0000h base + 10h offset + (4d × i), where i=0d to 3d

| Bit   | 31                   | 30                   | 29                   | 28                   | 27                   | 26                   | 25                  | 24                  | 23                  | 22                  | 21                  | 20                  | 19                  | 18                  | 17                  | 16                  |
|-------|----------------------|----------------------|----------------------|----------------------|----------------------|----------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|
| Reset | 0                    | 0                    | 0                    | 0                    | 0                    | 0                    | 0                   | 0                   | 0                   | 0                   | 0                   | 0                   | 0                   | 0                   | 0                   | 0                   |
| R     | CH15_CMDCMPLT_IRQ_EN | CH14_CMDCMPLT_IRQ_EN | CH13_CMDCMPLT_IRQ_EN | CH12_CMDCMPLT_IRQ_EN | CH11_CMDCMPLT_IRQ_EN | CH10_CMDCMPLT_IRQ_EN | CH9_CMDCMPLT_IRQ_EN | CH8_CMDCMPLT_IRQ_EN | CH7_CMDCMPLT_IRQ_EN | CH6_CMDCMPLT_IRQ_EN | CH5_CMDCMPLT_IRQ_EN | CH4_CMDCMPLT_IRQ_EN | CH3_CMDCMPLT_IRQ_EN | CH2_CMDCMPLT_IRQ_EN | CH1_CMDCMPLT_IRQ_EN | CH0_CMDCMPLT_IRQ_EN |
| W     | CH15_CMDCMPLT_IRQ    | CH14_CMDCMPLT_IRQ    | CH13_CMDCMPLT_IRQ    | CH12_CMDCMPLT_IRQ    | CH11_CMDCMPLT_IRQ    | CH10_CMDCMPLT_IRQ    | CH9_CMDCMPLT_IRQ    | CH8_CMDCMPLT_IRQ    | CH7_CMDCMPLT_IRQ    | CH6_CMDCMPLT_IRQ    | CH5_CMDCMPLT_IRQ    | CH4_CMDCMPLT_IRQ    | CH3_CMDCMPLT_IRQ    | CH2_CMDCMPLT_IRQ    | CH1_CMDCMPLT_IRQ    | CH0_CMDCMPLT_IRQ    |
| Bit   | 15                   | 14                   | 13                   | 12                   | 11                   | 10                   | 9                   | 8                   | 7                   | 6                   | 5                   | 4                   | 3                   | 2                   | 1                   | 0                   |
| Reset | 0                    | 0                    | 0                    | 0                    | 0                    | 0                    | 0                   | 0                   | 0                   | 0                   | 0                   | 0                   | 0                   | 0                   | 0                   | 0                   |

### APBH\_CTRL1n field descriptions

| Field                      | Description                                                                              |
|----------------------------|------------------------------------------------------------------------------------------|
| 31<br>CH15_CMDCMPLT_IRQ_EN | Setting this bit enables the generation of an interrupt request for APBH DMA channel 15. |
| 30<br>CH14_CMDCMPLT_IRQ_EN | Setting this bit enables the generation of an interrupt request for APBH DMA channel 14. |

Table continues on the next page...

**APBH\_CTRL1n field descriptions (continued)**

| Field                              | Description                                                                              |
|------------------------------------|------------------------------------------------------------------------------------------|
| 29<br>CH13_<br>CMDCMPLT_<br>IRQ_EN | Setting this bit enables the generation of an interrupt request for APBH DMA channel 13. |
| 28<br>CH12_<br>CMDCMPLT_<br>IRQ_EN | Setting this bit enables the generation of an interrupt request for APBH DMA channel 12. |
| 27<br>CH11_<br>CMDCMPLT_<br>IRQ_EN | Setting this bit enables the generation of an interrupt request for APBH DMA channel 11. |
| 26<br>CH10_<br>CMDCMPLT_<br>IRQ_EN | Setting this bit enables the generation of an interrupt request for APBH DMA channel 10. |
| 25<br>CH9_<br>CMDCMPLT_<br>IRQ_EN  | Setting this bit enables the generation of an interrupt request for APBH DMA channel 9.  |
| 24<br>CH8_<br>CMDCMPLT_<br>IRQ_EN  | Setting this bit enables the generation of an interrupt request for APBH DMA channel 8.  |
| 23<br>CH7_<br>CMDCMPLT_<br>IRQ_EN  | Setting this bit enables the generation of an interrupt request for APBH DMA channel 7.  |
| 22<br>CH6_<br>CMDCMPLT_<br>IRQ_EN  | Setting this bit enables the generation of an interrupt request for APBH DMA channel 6.  |
| 21<br>CH5_<br>CMDCMPLT_<br>IRQ_EN  | Setting this bit enables the generation of an interrupt request for APBH DMA channel 5.  |
| 20<br>CH4_<br>CMDCMPLT_<br>IRQ_EN  | Setting this bit enables the generation of an interrupt request for APBH DMA channel 4.  |
| 19<br>CH3_<br>CMDCMPLT_<br>IRQ_EN  | Setting this bit enables the generation of an interrupt request for APBH DMA channel 3.  |
| 18<br>CH2_<br>CMDCMPLT_<br>IRQ_EN  | Setting this bit enables the generation of an interrupt request for APBH DMA channel 2.  |

*Table continues on the next page...*

**APBH\_CTRL1n field descriptions (continued)**

| Field                             | Description                                                                                                                                                                                 |
|-----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17<br>CH1_<br>CMDCMPLT_<br>IRQ_EN | Setting this bit enables the generation of an interrupt request for APBH DMA channel 1.                                                                                                     |
| 16<br>CH0_<br>CMDCMPLT_<br>IRQ_EN | Setting this bit enables the generation of an interrupt request for APBH DMA channel 0.                                                                                                     |
| 15<br>CH15_<br>CMDCMPLT_<br>IRQ   | Interrupt request status bit for APBH DMA Channel 15. This sticky bit is set by DMA hardware and reset by software. It is ANDed with its corresponding enable bit to generate an interrupt. |
| 14<br>CH14_<br>CMDCMPLT_<br>IRQ   | Interrupt request status bit for APBH DMA Channel 14. This sticky bit is set by DMA hardware and reset by software. It is ANDed with its corresponding enable bit to generate an interrupt. |
| 13<br>CH13_<br>CMDCMPLT_<br>IRQ   | Interrupt request status bit for APBH DMA Channel 13. This sticky bit is set by DMA hardware and reset by software. It is ANDed with its corresponding enable bit to generate an interrupt. |
| 12<br>CH12_<br>CMDCMPLT_<br>IRQ   | Interrupt request status bit for APBH DMA Channel 12. This sticky bit is set by DMA hardware and reset by software. It is ANDed with its corresponding enable bit to generate an interrupt. |
| 11<br>CH11_<br>CMDCMPLT_<br>IRQ   | Interrupt request status bit for APBH DMA Channel 11. This sticky bit is set by DMA hardware and reset by software. It is ANDed with its corresponding enable bit to generate an interrupt. |
| 10<br>CH10_<br>CMDCMPLT_<br>IRQ   | Interrupt request status bit for APBH DMA Channel 10. This sticky bit is set by DMA hardware and reset by software. It is ANDed with its corresponding enable bit to generate an interrupt. |
| 9<br>CH9_<br>CMDCMPLT_<br>IRQ     | Interrupt request status bit for APBH DMA Channel 9. This sticky bit is set by DMA hardware and reset by software. It is ANDed with its corresponding enable bit to generate an interrupt.  |
| 8<br>CH8_<br>CMDCMPLT_<br>IRQ     | Interrupt request status bit for APBH DMA Channel 8. This sticky bit is set by DMA hardware and reset by software. It is ANDed with its corresponding enable bit to generate an interrupt.  |
| 7<br>CH7_<br>CMDCMPLT_<br>IRQ     | Interrupt request status bit for APBH DMA channel 7. This sticky bit is set by DMA hardware and reset by software. It is ANDed with its corresponding enable bit to generate an interrupt.  |
| 6<br>CH6_<br>CMDCMPLT_<br>IRQ     | Interrupt request status bit for APBH DMA channel 6. This sticky bit is set by DMA hardware and reset by software. It is ANDed with its corresponding enable bit to generate an interrupt.  |

*Table continues on the next page...*

**APBH\_CTRL1n field descriptions (continued)**

| Field                         | Description                                                                                                                                                                                |
|-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5<br>CH5_<br>CMDCMPLT_<br>IRQ | Interrupt request status bit for APBH DMA channel 5. This sticky bit is set by DMA hardware and reset by software. It is ANDed with its corresponding enable bit to generate an interrupt. |
| 4<br>CH4_<br>CMDCMPLT_<br>IRQ | Interrupt request status bit for APBH DMA channel 4. This sticky bit is set by DMA hardware and reset by software. It is ANDed with its corresponding enable bit to generate an interrupt. |
| 3<br>CH3_<br>CMDCMPLT_<br>IRQ | Interrupt request status bit for APBH DMA channel 3. This sticky bit is set by DMA hardware and reset by software. It is ANDed with its corresponding enable bit to generate an interrupt. |
| 2<br>CH2_<br>CMDCMPLT_<br>IRQ | Interrupt request status bit for APBH DMA channel 2. This sticky bit is set by DMA hardware and reset by software. It is ANDed with its corresponding enable bit to generate an interrupt. |
| 1<br>CH1_<br>CMDCMPLT_<br>IRQ | Interrupt request status bit for APBH DMA channel 1. This sticky bit is set by DMA hardware and reset by software. It is ANDed with its corresponding enable bit to generate an interrupt. |
| 0<br>CH0_<br>CMDCMPLT_<br>IRQ | Interrupt request status bit for APBH DMA channel 0. This sticky bit is set by DMA hardware and reset by software. It is ANDed with its corresponding enable bit to generate an interrupt. |

### 14.5.3 AHB to APBH Bridge Control and Status Register 2 (APBH\_CTRL2n)

The APBH CTRL 2 provides channel error interrupts generated by the AHB to APBH DMA. This register contains the per channel interrupt status bits and the per channel interrupt enable bits. Each channel has a dedicated interrupt vector in the vectored interrupt controller.

#### EXAMPLE

```
BF_WR(APBH_CTRL1, CH5_CMDCMPLT_IRQ, 0); // use bitfield write macro
BF_APBH_CTRL1.CH5_CMDCMPLT_IRQ = 0; // or, assign to register
struct's bitfield
```

## APBH Memory Map/Register Definition

Address: 11\_0000h base + 20h offset + (4d × i), where i=0d to 3d

| Bit   | 31                | 30                | 29                | 28                | 27                | 26                | 25               | 24               | 23               | 22               | 21               | 20               | 19               | 18               | 17               | 16               |
|-------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|------------------|------------------|------------------|------------------|------------------|------------------|------------------|------------------|
| R     | CH15_ERROR_STATUS | CH14_ERROR_STATUS | CH13_ERROR_STATUS | CH12_ERROR_STATUS | CH11_ERROR_STATUS | CH10_ERROR_STATUS | CH9_ERROR_STATUS | CH8_ERROR_STATUS | CH7_ERROR_STATUS | CH6_ERROR_STATUS | CH5_ERROR_STATUS | CH4_ERROR_STATUS | CH3_ERROR_STATUS | CH2_ERROR_STATUS | CH1_ERROR_STATUS | CH0_ERROR_STATUS |
| W     |                   |                   |                   |                   |                   |                   |                  |                  |                  |                  |                  |                  |                  |                  |                  |                  |
| Reset | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                | 0                | 0                | 0                | 0                | 0                | 0                | 0                | 0                | 0                |
| Bit   | 15                | 14                | 13                | 12                | 11                | 10                | 9                | 8                | 7                | 6                | 5                | 4                | 3                | 2                | 1                | 0                |
| R     | CH15_ERROR_IRQ    | CH14_ERROR_IRQ    | CH13_ERROR_IRQ    | CH12_ERROR_IRQ    | CH11_ERROR_IRQ    | CH10_ERROR_IRQ    | CH9_ERROR_IRQ    | CH8_ERROR_IRQ    | CH7_ERROR_IRQ    | CH6_ERROR_IRQ    | CH5_ERROR_IRQ    | CH4_ERROR_IRQ    | CH3_ERROR_IRQ    | CH2_ERROR_IRQ    | CH1_ERROR_IRQ    | CH0_ERROR_IRQ    |
| W     |                   |                   |                   |                   |                   |                   |                  |                  |                  |                  |                  |                  |                  |                  |                  |                  |
| Reset | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                | 0                | 0                | 0                | 0                | 0                | 0                | 0                | 0                | 0                |

### APBH\_CTRL2n field descriptions

| Field                   | Description                                                                                               |
|-------------------------|-----------------------------------------------------------------------------------------------------------|
| 31<br>CH15_ERROR_STATUS | Error status bit for APBH DMA Channel 15. Valid when corresponding Error IRQ is set.<br>1 - AHB bus error |

Table continues on the next page...

**APBH\_CTRL2n field descriptions (continued)**

| Field                   | Description                                                                                                                                                                                                                                                                                             |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                         | 0 - channel early termination.<br><br>0x0 <b>TERMINATION</b> — An early termination from the device causes error IRQ.<br>0x1 <b>BUS_ERROR</b> — An AHB bus error causes error IRQ.                                                                                                                      |
| 30<br>CH14_ERROR_STATUS | Error status bit for APBH DMA Channel 14. Valid when corresponding Error IRQ is set.<br><br>1 - AHB bus error<br><br>0 - channel early termination.<br><br>0x0 <b>TERMINATION</b> — An early termination from the device causes error IRQ.<br>0x1 <b>BUS_ERROR</b> — An AHB bus error causes error IRQ. |
| 29<br>CH13_ERROR_STATUS | Error status bit for APBH DMA Channel 13. Valid when corresponding Error IRQ is set.<br><br>1 - AHB bus error<br><br>0 - channel early termination.<br><br>0x0 <b>TERMINATION</b> — An early termination from the device causes error IRQ.<br>0x1 <b>BUS_ERROR</b> — An AHB bus error causes error IRQ. |
| 28<br>CH12_ERROR_STATUS | Error status bit for APBH DMA Channel 12. Valid when corresponding Error IRQ is set.<br><br>1 - AHB bus error<br><br>0 - channel early termination.<br><br>0x0 <b>TERMINATION</b> — An early termination from the device causes error IRQ.<br>0x1 <b>BUS_ERROR</b> — An AHB bus error causes error IRQ. |
| 27<br>CH11_ERROR_STATUS | Error status bit for APBH DMA Channel 11. Valid when corresponding Error IRQ is set.<br><br>1 - AHB bus error<br><br>0 - channel early termination.<br><br>0x0 <b>TERMINATION</b> — An early termination from the device causes error IRQ.<br>0x1 <b>BUS_ERROR</b> — An AHB bus error causes error IRQ. |
| 26<br>CH10_ERROR_STATUS | Error status bit for APBH DMA Channel 10. Valid when corresponding Error IRQ is set.<br><br>1 - AHB bus error<br><br>0 - channel early termination.<br><br>0x0 <b>TERMINATION</b> — An early termination from the device causes error IRQ.<br>0x1 <b>BUS_ERROR</b> — An AHB bus error causes error IRQ. |
| 25<br>CH9_ERROR_STATUS  | Error status bit for APBH DMA Channel 9. Valid when corresponding Error IRQ is set.<br><br>1 - AHB bus error<br><br>0 - channel early termination.<br><br>0x0 <b>TERMINATION</b> — An early termination from the device causes error IRQ.<br>0x1 <b>BUS_ERROR</b> — An AHB bus error causes error IRQ.  |
| 24<br>CH8_ERROR_STATUS  | Error status bit for APBH DMA Channel 8. Valid when corresponding Error IRQ is set.<br><br>1 - AHB bus error<br><br>0 - channel early termination.                                                                                                                                                      |

*Table continues on the next page...*

## APBH\_CTRL2n field descriptions (continued)

| Field                  | Description                                                                                                                                                                                                                                                                                    |
|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                        | 0x0 <b>TERMINATION</b> — An early termination from the device causes error IRQ.<br>0x1 <b>BUS_ERROR</b> — An AHB bus error causes error IRQ.                                                                                                                                                   |
| 23<br>CH7_ERROR_STATUS | Error status bit for APBX DMA Channel 7. Valid when corresponding Error IRQ is set.<br>1 - AHB bus error<br>0 - channel early termination.<br><br>0x0 <b>TERMINATION</b> — An early termination from the device causes error IRQ.<br>0x1 <b>BUS_ERROR</b> — An AHB bus error causes error IRQ. |
| 22<br>CH6_ERROR_STATUS | Error status bit for APBX DMA Channel 6. Valid when corresponding Error IRQ is set.<br>1 - AHB bus error<br>0 - channel early termination.<br><br>0x0 <b>TERMINATION</b> — An early termination from the device causes error IRQ.<br>0x1 <b>BUS_ERROR</b> — An AHB bus error causes error IRQ. |
| 21<br>CH5_ERROR_STATUS | Error status bit for APBX DMA Channel 5. Valid when corresponding Error IRQ is set.<br>1 - AHB bus error<br>0 - channel early termination.<br><br>0x0 <b>TERMINATION</b> — An early termination from the device causes error IRQ.<br>0x1 <b>BUS_ERROR</b> — An AHB bus error causes error IRQ. |
| 20<br>CH4_ERROR_STATUS | Error status bit for APBX DMA Channel 4. Valid when corresponding Error IRQ is set.<br>1 - AHB bus error<br>0 - channel early termination.<br><br>0x0 <b>TERMINATION</b> — An early termination from the device causes error IRQ.<br>0x1 <b>BUS_ERROR</b> — An AHB bus error causes error IRQ. |
| 19<br>CH3_ERROR_STATUS | Error status bit for APBX DMA Channel 3. Valid when corresponding Error IRQ is set.<br>1 - AHB bus error<br>0 - channel early termination.<br><br>0x0 <b>TERMINATION</b> — An early termination from the device causes error IRQ.<br>0x1 <b>BUS_ERROR</b> — An AHB bus error causes error IRQ. |
| 18<br>CH2_ERROR_STATUS | Error status bit for APBX DMA Channel 2. Valid when corresponding Error IRQ is set.<br>1 - AHB bus error<br>0 - channel early termination.<br><br>0x0 <b>TERMINATION</b> — An early termination from the device causes error IRQ.<br>0x1 <b>BUS_ERROR</b> — An AHB bus error causes error IRQ. |
| 17<br>CH1_ERROR_STATUS | Error status bit for APBX DMA Channel 1. Valid when corresponding Error IRQ is set.<br>1 - AHB bus error<br>0 - channel early termination.<br><br>0x0 <b>TERMINATION</b> — An early termination from the device causes error IRQ.<br>0x1 <b>BUS_ERROR</b> — An AHB bus error causes error IRQ. |

*Table continues on the next page...*

**APBH\_CTRL2n field descriptions (continued)**

| Field                  | Description                                                                                                                                                                                                                                                                                            |
|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16<br>CH0_ERROR_STATUS | Error status bit for APBX DMA Channel 0. Valid when corresponding Error IRQ is set.<br><br>1 - AHB bus error<br><br>0 - channel early termination.<br><br>0x0 <b>TERMINATION</b> — An early termination from the device causes error IRQ.<br>0x1 <b>BUS_ERROR</b> — An AHB bus error causes error IRQ. |
| 15<br>CH15_ERROR_IRQ   | Error interrupt status bit for APBH DMA Channel 15. This sticky bit is set by DMA hardware and reset by software. It is ORed with the corresponding cmdcmplt irq to generate an irq to ARM.                                                                                                            |
| 14<br>CH14_ERROR_IRQ   | Error interrupt status bit for APBH DMA Channel 14. This sticky bit is set by DMA hardware and reset by software. It is ORed with the corresponding cmdcmplt irq to generate an irq to ARM.                                                                                                            |
| 13<br>CH13_ERROR_IRQ   | Error interrupt status bit for APBH DMA Channel 13. This sticky bit is set by DMA hardware and reset by software. It is ORed with the corresponding cmdcmplt irq to generate an irq to ARM.                                                                                                            |
| 12<br>CH12_ERROR_IRQ   | Error interrupt status bit for APBH DMA Channel 12. This sticky bit is set by DMA hardware and reset by software. It is ORed with the corresponding cmdcmplt irq to generate an irq to ARM.                                                                                                            |
| 11<br>CH11_ERROR_IRQ   | Error interrupt status bit for APBH DMA Channel 11. This sticky bit is set by DMA hardware and reset by software. It is ORed with the corresponding cmdcmplt irq to generate an irq to ARM.                                                                                                            |
| 10<br>CH10_ERROR_IRQ   | Error interrupt status bit for APBH DMA Channel 10. This sticky bit is set by DMA hardware and reset by software. It is ORed with the corresponding cmdcmplt irq to generate an irq to ARM.                                                                                                            |
| 9<br>CH9_ERROR_IRQ     | Error interrupt status bit for APBH DMA Channel 9. This sticky bit is set by DMA hardware and reset by software. It is ORed with the corresponding cmdcmplt irq to generate an irq to ARM.                                                                                                             |
| 8<br>CH8_ERROR_IRQ     | Error interrupt status bit for APBH DMA Channel 8. This sticky bit is set by DMA hardware and reset by software. It is ORed with the corresponding cmdcmplt irq to generate an irq to ARM.                                                                                                             |
| 7<br>CH7_ERROR_IRQ     | Error interrupt status bit for APBX DMA Channel 7. This sticky bit is set by DMA hardware and reset by software. It is ORed with the corresponding cmdcmplt irq to generate an irq to ARM.                                                                                                             |
| 6<br>CH6_ERROR_IRQ     | Error interrupt status bit for APBX DMA Channel 6. This sticky bit is set by DMA hardware and reset by software. It is ORed with the corresponding cmdcmplt irq to generate an irq to ARM.                                                                                                             |
| 5<br>CH5_ERROR_IRQ     | Error interrupt status bit for APBX DMA Channel 5. This sticky bit is set by DMA hardware and reset by software. It is ORed with the corresponding cmdcmplt irq to generate an irq to ARM.                                                                                                             |
| 4<br>CH4_ERROR_IRQ     | Error interrupt status bit for APBX DMA Channel 4. This sticky bit is set by DMA hardware and reset by software. It is ORed with the corresponding cmdcmplt irq to generate an irq to ARM.                                                                                                             |
| 3<br>CH3_ERROR_IRQ     | Error interrupt status bit for APBX DMA Channel 3. This sticky bit is set by DMA hardware and reset by software. It is ORed with the corresponding cmdcmplt irq to generate an irq to ARM.                                                                                                             |
| 2<br>CH2_ERROR_IRQ     | Error interrupt status bit for APBX DMA Channel 2. This sticky bit is set by DMA hardware and reset by software. It is ORed with the corresponding cmdcmplt irq to generate an irq to ARM.                                                                                                             |

*Table continues on the next page...*

## APBH CTRL2n field descriptions (continued)

| Field              | Description                                                                                                                                                                                |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1<br>CH1_ERROR_IRQ | Error interrupt status bit for APBX DMA Channel 1. This sticky bit is set by DMA hardware and reset by software. It is ORed with the corresponding cmdcmplt irq to generate an irq to ARM. |
| 0<br>CH0_ERROR_IRQ | Error interrupt status bit for APBX DMA Channel 0. This sticky bit is set by DMA hardware and reset by software. It is ORed with the corresponding cmdcmplt irq to generate an irq to ARM. |

#### **14.5.4 AHB to APBH Bridge Channel Register (APBH CHANNEL CTRL $n$ )**

The APBH CHANNEL CTRL provides reset/freeze control of each DMA channel. This register contains individual channel reset/freeze bits.

Address: 11 0000h base + 30h offset + (4d × i), where i=0d to 3d

## APBH CHANNEL CTRL $n$ field descriptions

| Field                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–16<br>RESET_CHANNEL | <p>Setting a bit in this field causes the DMA controller to take the corresponding channel through its reset state. The bit is reset after the channel resources are cleared.</p> <p>0x0001 <b>NAND0</b> —<br/>     0x0002 <b>NAND1</b> —<br/>     0x0004 <b>NAND2</b> —<br/>     0x0008 <b>NAND3</b> —<br/>     0x0010 <b>NAND4</b> —<br/>     0x0020 <b>NAND5</b> —<br/>     0x0040 <b>NAND6</b> —<br/>     0x0080 <b>NAND7</b> —<br/>     0x0100 <b>SSP</b> —</p> |
| FREEZE_CHANNEL         | <p>Setting a bit in this field will freeze the DMA channel associated with it. This field is a direct input to the DMA channel arbiter. When frozen, the channel is denied access to the central DMA resources.</p> <p>0x0001 <b>NAND0</b> —<br/>     0x0002 <b>NAND1</b> —<br/>     0x0004 <b>NAND2</b> —<br/>     0x0008 <b>NAND3</b> —<br/>     0x0010 <b>NAND4</b> —<br/>     0x0020 <b>NAND5</b> —<br/>     0x0040 <b>NAND6</b> —</p>                           |

*Table continues on the next page...*

**APBH\_CHANNEL\_CTRLn field descriptions (continued)**

| Field | Description                                  |
|-------|----------------------------------------------|
|       | 0x0080 <b>NAND7</b> —<br>0x0100 <b>SSP</b> — |

### 14.5.5 AHB to APBH DMA Device Assignment Register (APBH\_DEVSEL)

This register allows reassignment of the APBH device connected to the DMA Channels.

In this chip, APBH DMA channel resource is enough for high speed peripherals, so this register is of no use and reserved.

Address: 11\_0000h base + 40h offset = 11\_0040h

| Bit    | 31       | 30       | 29       | 28       | 27       | 26       | 25       | 24       | 23       | 22       | 21       | 20       | 19       | 18       | 17       | 16       |
|--------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|
| R<br>W | Reserved |
| Reset  | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        |
| Bit    | 15       | 14       | 13       | 12       | 11       | 10       | 9        | 8        | 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0        |
| R<br>W | Reserved |
| Reset  | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        |

**APBH\_DEVSEL field descriptions**

| Field         | Description                          |
|---------------|--------------------------------------|
| 31–30<br>CH15 | This field is reserved.<br>Reserved. |
| 29–28<br>CH14 | This field is reserved.<br>Reserved. |
| 27–26<br>CH13 | This field is reserved.<br>Reserved. |
| 25–24<br>CH12 | This field is reserved.<br>Reserved. |
| 23–22<br>CH11 | This field is reserved.<br>Reserved. |
| 21–20<br>CH10 | This field is reserved.<br>Reserved. |
| 19–18<br>CH9  | This field is reserved.<br>Reserved. |
| 17–16<br>CH8  | This field is reserved.<br>Reserved. |
| 15–14<br>CH7  | This field is reserved.<br>Reserved. |
| 13–12<br>CH6  | This field is reserved.<br>Reserved. |

Table continues on the next page...

**APBH\_DEVSEL field descriptions (continued)**

| Field        | Description                          |
|--------------|--------------------------------------|
| 11–10<br>CH5 | This field is reserved.<br>Reserved. |
| 9–8<br>CH4   | This field is reserved.<br>Reserved. |
| 7–6<br>CH3   | This field is reserved.<br>Reserved. |
| 5–4<br>CH2   | This field is reserved.<br>Reserved. |
| 3–2<br>CH1   | This field is reserved.<br>Reserved. |
| CH0          | This field is reserved.<br>Reserved. |

**14.5.6 AHB to APBH DMA burst size (APBH\_DMA\_BURST\_SIZE)**

This register programs the apbh burst size of the APBH DMA devices when a DMA burst request is issued.

This register provides a mechanism for assigning the device.

Address: 11\_0000h base + 50h offset = 11\_0050h

| Bit    | 31       | 30       | 29       | 28       | 27       | 26       | 25       | 24       | 23       | 22       | 21       | 20       | 19       | 18  | 17  | 16 |
|--------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|-----|-----|----|
| R<br>W | Reserved | CH8 |     |    |
| Reset  | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 1        | 0        | 1        | 0        | 1   | 0   | 1  |
| Bit    | 15       | 14       | 13       | 12       | 11       | 10       | 9        | 8        | 7        | 6        | 5        | 4        | 3        | 2   | 1   | 0  |
| R<br>W | CH7      |          | CH6      |          | CH5      |          | CH4      |          | CH3      |          | CH2      |          | CH1      |     | CH0 |    |
| Reset  | 0        | 1        | 0        | 1        | 0        | 1        | 0        | 1        | 0        | 1        | 0        | 1        | 0        | 1   | 0   | 1  |

**APBH\_DMA\_BURST\_SIZE field descriptions**

| Field         | Description                          |
|---------------|--------------------------------------|
| 31–30<br>CH15 | This field is reserved.<br>Reserved. |
| 29–28<br>CH14 | This field is reserved.<br>Reserved. |
| 27–26<br>CH13 | This field is reserved.<br>Reserved. |
| 25–24<br>CH12 | This field is reserved.<br>Reserved. |
| 23–22<br>CH11 | This field is reserved.<br>Reserved. |

*Table continues on the next page...*

**APBH\_DMA\_BURST\_SIZE field descriptions (continued)**

| Field         | Description                                                                                      |
|---------------|--------------------------------------------------------------------------------------------------|
| 21–20<br>CH10 | This field is reserved.<br>Reserved.                                                             |
| 19–18<br>CH9  | This field is reserved.<br>Reserved.                                                             |
| 17–16<br>CH8  | DMA burst size for SSP.<br><br>0x0 <b>BURST0</b> —<br>0x1 <b>BURST4</b> —<br>0x2 <b>BURST8</b> — |
| 15–14<br>CH7  | DMA burst size for GPMI channel 7. Do not change. GPMI only support burst size 4.                |
| 13–12<br>CH6  | DMA burst size for GPMI channel 6. Do not change. GPMI only support burst size 4.                |
| 11–10<br>CH5  | DMA burst size for GPMI channel 5. Do not change. GPMI only support burst size 4.                |
| 9–8<br>CH4    | DMA burst size for GPMI channel 4. Do not change. GPMI only support burst size 4.                |
| 7–6<br>CH3    | DMA burst size for GPMI channel 3. Do not change. GPMI only support burst size 4.                |
| 5–4<br>CH2    | DMA burst size for GPMI channel 2. Do not change. GPMI only support burst size 4.                |
| 3–2<br>CH1    | DMA burst size for GPMI channel 1. Do not change. GPMI only support burst size 4.                |
| CH0           | DMA burst size for GPMI channel 0. Do not change. GPMI only support burst size 4.                |

**14.5.7 AHB to APBH DMA Debug Register (APBH\_DEBUG)**

This register is for debug purpose.

The debug register is for internal use only. Not recommend for customer usage.

Address: 11\_0000h base + 60h offset = 11\_0060h



**APBH\_DEBUG field descriptions**

| Field              | Description                                                                                                                      |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31–1<br>-          | This field is reserved.<br>Reserved, always set to zero.                                                                         |
| 0<br>GPMI_ONE_FIFO | Set to One and the 8 GPMI channels will share the DMA FIFO, and when set to zero, the 8 GPMI channels will use its own DMA FIFO. |

### 14.5.8 APBH DMA Channel n Current Command Address Register (APBH\_CHn\_CURCMDAR)

The APBH DMA channel n current command address register points to the multiword command that is currently being executed. Commands are threaded on the command address.

APBH DMA Channel n is controlled by a variable sized command structure. This register points to the command structure currently being executed.

#### EXAMPLE

```
pCurCmd = (apbh_chn_cmd_t *) APBH_CHn_CURCMDAR_RD(0); // read the whole
register, since there is only one field
pCurCmd = (apbh_chn_cmd_t *) BF_RDn(APBH_CHn_CURCMDAR, 0, CMD_ADDR); // or, use multi-
register bitfield read macro
pCurCmd = (apbh_chn_cmd_t *) APBH_CHn_CURCMDAR(0).CMD_ADDR; // or, assign from
bitfield of indexed register's struct
```

Address: 11\_0000h base + 100h offset + (112d × i), where i=0d to 15d

**APBH\_CHn\_CURCMDAR field descriptions**

| Field    | Description                                                           |
|----------|-----------------------------------------------------------------------|
| CMD_ADDR | Pointer to command structure currently being processed for channel n. |

### 14.5.9 APBH DMA Channel n Next Command Address Register (APBH\_CHn\_NXTCMDAR)

The APBH DMA Channel n Next Command Address register contains the address of the next multiword command to be executed. Commands are threaded on the command address. Set CHAIN to 1 in the DMA command word to process command lists.

APBH DMA Channel n is controlled by a variable sized command structure. Software loads this register with the address of the first command structure to process and increments the Channel n semaphore to start processing. This register points to the next command structure to be executed when the current command is completed.

#### EXAMPLE

```
APBH_CHn_NXTCMDAR_WR(0, (reg32_t) pCommandTwoStructure);           // write the entire
register, since there is only one field
BF_WRN(APBH_CHn_NXTCMDAR, 0, (reg32_t) pCommandTwoStructure);       // or, use multi-
register bitfield write macro
APBH_CHn_NXTCMDAR(0).CMD_ADDR = (reg32_t) pCommandTwoStructure;    // or, assign to bitfield
of indexed register's struct
```

Address: 11\_0000h base + 110h offset + (112d × i), where i=0d to 15d

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15       | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| R   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CMD_ADDR |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

**APBH\_CHn\_NXTCMDAR field descriptions**

| Field    | Description                                      |
|----------|--------------------------------------------------|
| CMD_ADDR | Pointer to next command structure for channel n. |

### 14.5.10 APBH DMA Channel n Command Register (APBH\_CHn\_CMD)

The APBH DMA Channel n command register specifies the DMA transaction to perform for the current command chain item.

The command register controls the overall operation of each DMA command for this channel. It includes the number of bytes to transfer to or from the device, the number of APB PIO command words included with this command structure, whether to interrupt at command completion, whether to chain an additional command to the end of this one and whether this transfer is a read or write DMA transfer.

## EXAMPLE

```

apbh_chn_cmd_t dma_cmd;
dma_cmd.XFER_COUNT = 512;           // transfer 512 bytes
dma_cmd.COMMAND = BV_APBH_CHn_CMD_COMMAND__DMA_WRITE; // transfer to system memory from
peripheral device
dma_cmd.CHAIN = 1;                 // chain an additional command
structure on to the list
dma_cmd.IRQONCMPLT = 1;           // generate an interrupt on
completion of this command structure

```

Address: 11\_0000h base + 120h offset + (112d × i), where i=0d to 15d



**APBH\_CHn\_CMD field descriptions**

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–16 XFER_COUNT  | This field indicates the number of bytes to transfer to or from the appropriate PIO register in the GPMI0 device. A value of 0 indicates a 64 KBytes transfer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 15–12 CMDWORDS    | This field indicates the number of command words to send to the GPMI0, starting with the base PIO address of the GPMI0 control register and incrementing from there. Zero means transfer NO command words                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 11–9 -            | This field is reserved.<br>Reserved, always set to zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 8 HALTONTERMINATE | A value of one indicates that the channel will immediately terminate the current descriptor and halt the DMA channel if a terminate signal is set. A value of 0 will still cause an immediate terminate of the channel if the terminate signal is set, but the channel will continue as if the count had been exhausted, meaning it will honor IRQONCMPLT, CHAIN, SEMAPHORE, and WAIT4ENDCMD.                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 7 WAIT4ENDCMD     | A value of one indicates that the channel will wait for the end of command signal to be sent from the APBH device to the DMA before starting the next DMA command.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 6 SEMAPHORE       | A value of one indicates that the channel will decrement its semaphore at the completion of the current command structure. If the semaphore decrements to zero, then this channel stalls until software increments it again.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 5 NANDWAIT4READY  | A value of one indicates that the NAND DMA channel will wait until the NAND device reports "ready" before executing the command. It is ignored for non-NAND DMA channels.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 4 NANDLOCK        | A value of one indicates that the NAND DMA channel will remain "locked" in the arbiter at the expense of other NAND DMA channels. It is ignored for non-NAND DMA channels.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 3 IRQONCMPLT      | A value of one indicates that the channel will cause the interrupt status bit to be set upon completion of the current command, i.e. after the DMA transfer is complete.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 2 CHAIN           | A value of one indicates that another command is chained onto the end of the current command structure. At the completion of the current command, this channel will follow the pointer in APBH_CHn_CMDAR to find the next command.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| COMMAND           | <p>This bitfield indicates the type of current command:</p> <ul style="list-style-type: none"> <li>0x0 <b>NO_DMA_XFER</b> — Perform any requested PIO word transfers but terminate command before any DMA transfer.</li> <li>0x1 <b>DMA_WRITE</b> — Perform any requested PIO word transfers and then perform a DMA transfer from the peripheral for the specified number of bytes.</li> <li>0x2 <b>DMA_READ</b> — Perform any requested PIO word transfers and then perform a DMA transfer to the peripheral for the specified number of bytes.</li> <li>0x3 <b>DMA_SENSE</b> — Perform any requested PIO word transfers and then perform a conditional branch to the next chained device. Follow the NEXCMD_ADDR pointer if the peripheral sense is true. Follow the BUFFER_ADDRESS as a chain pointer if the peripheral sense line is false.</li> </ul> |

### 14.5.11 APBH DMA Channel n Buffer Address Register (APBH\_CHn\_BAR)

The APBH DMA Channel n buffer address register contains a pointer to the data buffer for the transfer. For immediate forms, the data is taken from this register. This is a byte address which means transfers can start on any byte boundary.

## APBH Memory Map/Register Definition

This register holds a pointer to the data buffer in system memory. After the command values have been read into the DMA controller and the device controlled by this channel, then the DMA transfer will begin, to or from the buffer pointed to by this register.

### EXAMPLE

```
apbh_chn_bar_t dma_data;
dma_data.ADDRESS = (reg32_t) pDataBuffer;
```

Address: 11\_0000h base + 130h offset + (112d × i), where i=0d to 15d

| Bit   | 31      | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|---------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| R     | ADDRESS |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| W     |         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |

#### APBH\_CHn\_BAR field descriptions

| Field   | Description                                                             |
|---------|-------------------------------------------------------------------------|
| ADDRESS | Address of system memory buffer to be read or written over the AHB bus. |

## 14.5.12 APBH DMA Channel n Semaphore Register (APBH\_CHn\_SEMA)

The APBH DMA Channel n semaphore register is used to synchronize the ARM platform instruction stream and the DMA chain processing state.

Each DMA channel has an 8 bit counting semaphore that is used to synchronize between the program stream and the DMA chain processing. DMA processing continues until the DMA attempts to decrement a semaphore that has already reached a value of zero. When the attempt is made, the DMA channel is stalled until software increments the semaphore count.

### EXAMPLE

```
BF_WR(APBH_CHn_SEMA, 0, INCREMENT_SEMA, 2); // increment semaphore by two
current_sema = BF_RD(APBH_CHn_SEMA, 0, PHORE); // get instantaneous value
```

Address: 11\_0000h base + 140h offset + (112d × i), where i=0d to 15d

| Bit   | 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21    | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13       | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5              | 4 | 3 | 2 | 1 | 0 |
|-------|----------|----|----|----|----|----|----|----|----|----|-------|----|----|----|----|----|----|----|----------|----|----|----|---|---|---|---|----------------|---|---|---|---|---|
| R     | Reserved |    |    |    |    |    |    |    |    |    | PHORE |    |    |    |    |    |    |    | Reserved |    |    |    |   |   |   |   | INCREMENT_SEMA |   |   |   |   |   |
| W     |          |    |    |    |    |    |    |    |    |    |       |    |    |    |    |    |    |    |          |    |    |    |   |   |   |   |                |   |   |   |   |   |
| Reset | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0     | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0        | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0              | 0 | 0 | 0 | 0 |   |

**APBH\_CHn\_SEMA field descriptions**

| Field          | Description                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–24<br>-     | This field is reserved.<br>Reserved, always set to zero.                                                                                                                                                                                                                                                                                                                                                         |
| 23–16<br>PHORE | This read-only field shows the current (instantaneous) value of the semaphore counter.                                                                                                                                                                                                                                                                                                                           |
| 15–8<br>-      | This field is reserved.<br>Reserved, always set to zero.                                                                                                                                                                                                                                                                                                                                                         |
| INCREMENT_SEMA | The value written to this field is added to the semaphore count in an atomic way such that simultaneous software adds and DMA hardware subtracts happening on the same clock are protected. This bit field reads back a value of 0x00. Writing a value of 0x02 increments the semaphore count by two, unless the DMA channel decrements the count on the same clock, then the count is incremented by a net one. |

**14.5.13 AHB to APBH DMA Channel n Debug Information  
(APBH\_CHn\_DEBUG1)**

This register gives debug visibility into the APBH DMA Channel n state machine and controls.

This register allows debug visibility of the APBH DMA Channel n.

## APBH Memory Map/Register Definition

Address: 11\_0000h base + 150h offset + (112d × i), where i=0d to 15d

| Bit   | 31  | 30    | 29   | 28  | 27       | 26    | 25       | 24               | 23            | 22           | 21            | 20           | 19       | 18 | 17 | 16           |
|-------|-----|-------|------|-----|----------|-------|----------|------------------|---------------|--------------|---------------|--------------|----------|----|----|--------------|
| R     | REQ | BURST | KICK | END | Reserved | READY | Reserved | NEXTCMDADDRVALID | RD_FIFO_EMPTY | RD_FIFO_FULL | WR_FIFO_EMPTY | WR_FIFO_FULL | Reserved |    |    |              |
| W     |     |       |      |     |          |       |          |                  |               |              |               |              |          |    |    |              |
| Reset | 0   | 0     | 0    | 0   | 0        | 0     | 0        | 0                | 1             | 0            | 1             | 0            | 0        | 0  | 0  | 0            |
| Bit   | 15  | 14    | 13   | 12  | 11       | 10    | 9        | 8                | 7             | 6            | 5             | 4            | 3        | 2  | 1  | 0            |
| R     |     |       |      |     |          |       |          |                  |               |              |               |              |          |    |    | STATEMACHINE |
| W     |     |       |      |     |          |       |          |                  |               |              |               |              |          |    |    |              |
| Reset | 0   | 0     | 0    | 0   | 0        | 0     | 0        | 0                | 0             | 0            | 0             | 0            | 0        | 0  | 0  | 0            |

**APBH\_CHn\_DEBUG1 field descriptions**

| Field                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>REQ              | This bit reflects the current state of the DMA Request Signal from the APB device                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 30<br>BURST            | This bit reflects the current state of the DMA Burst Signal from the APB device                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 29<br>KICK             | This bit reflects the current state of the DMA Kick Signal sent to the APB Device                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 28<br>END              | This bit reflects the current state of the DMA End Command Signal sent from the APB Device                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 27<br>SENSE            | This field is reserved.<br>This bit is reserved for this DMA Channel and always reads 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 26<br>READY            | This bit is reserved for this DMA Channel and always reads 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 25<br>LOCK             | This field is reserved.<br>This bit is reserved for this Channel and always reads 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 24<br>NEXTCMDADDRVALID | This bit reflects the internal bit which indicates whether the channel's next command address is valid.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 23<br>RD_FIFO_EMPTY    | This bit reflects the current state of the DMA Channel's Read FIFO Empty signal.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 22<br>RD_FIFO_FULL     | This bit reflects the current state of the DMA Channel's Read FIFO Full signal.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 21<br>WR_FIFO_EMPTY    | This bit reflects the current state of the DMA Channel's Write FIFO Empty signal.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 20<br>WR_FIFO_FULL     | This bit reflects the current state of the DMA Channel's Write FIFO Full signal.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 19–5<br>RSVD1          | This field is reserved.<br>Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| STATEMACHINE           | PIO Display of the DMA Channel n state machine state.<br><br>0x00 <b>IDLE</b> — This is the idle state of the DMA state machine.<br>0x01 <b>REQ_CMD1</b> — State in which the DMA is waiting to receive the first word of a command.<br>0x02 <b>REQ_CMD3</b> — State in which the DMA is waiting to receive the third word of a command.<br>0x03 <b>REQ_CMD2</b> — State in which the DMA is waiting to receive the second word of a command.<br>0x04 <b>XFER_DECODE</b> — The state machine processes the descriptor command field in this state and branches accordingly.<br>0x05 <b>REQ_WAIT</b> — The state machine waits in this state for the PIO APB cycles to complete.<br>0x06 <b>REQ_CMD4</b> — State in which the DMA is waiting to receive the fourth word of a command, or waiting to receive the PIO words when PIO count is greater than 1.<br>0x07 <b>PIO_REQ</b> — This state determines whether another PIO cycle needs to occur before starting DMA transfers.<br>0x08 <b>READ_FLUSH</b> — During a read transfers, the state machine enters this state waiting for the last bytes to be pushed out on the APB.<br>0x09 <b>READ_WAIT</b> — When an AHB read request occurs, the state machine waits in this state for the AHB transfer to complete.<br>0x0C <b>WRITE</b> — During DMA Write transfers, the state machine waits in this state until the AHB master arbiter accepts the request from this channel.<br>0x0D <b>READ_REQ</b> — During DMA Read transfers, the state machine waits in this state until the AHB master arbiter accepts the request from this channel. |

*Table continues on the next page...*

**APBH\_CHn\_DEBUG1 field descriptions (continued)**

| Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | <p>0x0E <b>CHECK_CHAIN</b> — Upon completion of the DMA transfers, this state checks the value of the Chain bit and branches accordingly.</p> <p>0x0F <b>XFER_COMPLETE</b> — The state machine goes to this state after the DMA transfers are complete, and determines what step to take next.</p> <p>0x14 <b>TERMINATE</b> — When a terminate signal is set, the state machine enters this state until the current AHB transfer is completed.</p> <p>0x15 <b>WAIT_END</b> — When the Wait for Command End bit is set, the state machine enters this state until the DMA device indicates that the command is complete.</p> <p>0x1C <b>WRITE_WAIT</b> — During DMA Write transfers, the state machine waits in this state until the AHB master completes the write to the AHB memory space.</p> <p>0x1D <b>HALT_AFTER_TERM</b> — If HALTONTERMINATE is set and a terminate signal is set, the state machine enters this state and effectively halts. A channel reset is required to exit this state</p> <p>0x1E <b>CHECK_WAIT</b> — If the Chain bit is a 0, the state machine enters this state and effectively halts.</p> <p>0x1F <b>WAIT_READY</b> — When the NAND Wait for Ready bit is set, the state machine enters this state until the GPMI device indicates that the external device is ready.</p> |

### 14.5.14 AHB to APBH DMA Channel n Debug Information (APBH\_CHn\_DEBUG2)

This register gives debug visibility for the APB and AHB byte counts for DMA Channel n.

This register allows debug visibility of the APBH DMA Channel n.

Address: 11\_0000h base + 160h offset + (112d × i), where i=0d to 15d

| Bit | 31        | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16        | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|-----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| R   |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     | APB_BYTES |    |    |    |    |    |    |    |    |    |    |    |    |    |    | AHB_BYTES |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| W   |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**APBH\_CHn\_DEBUG2 field descriptions**

| Field              | Description                                                                                              |
|--------------------|----------------------------------------------------------------------------------------------------------|
| 31–16<br>APB_BYTES | This value reflects the current number of APB bytes remaining to be transferred in the current transfer. |
| AHB_BYTES          | This value reflects the current number of AHB bytes remaining to be transferred in the current transfer. |

### 14.5.15 APBH Bridge Version Register (APBH\_VERSION)

This register always returns a known read value for debug purposes it indicates the version of the block.

This register indicates the RTL version in use.

#### EXAMPLE

```
if (APBH_VERSION.B.MAJOR != 3)
    Error();
```

Address: 11\_0000h base + 800h offset = 11\_0800h

| Bit   | 31    | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|-------|----|----|----|----|----|----|----|-------|----|----|----|----|----|----|----|------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| R     | MAJOR |    |    |    |    |    |    |    | MINOR |    |    |    |    |    |    |    | STEP |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| W     |       |    |    |    |    |    |    |    |       |    |    |    |    |    |    |    |      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0     | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 0     | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0    | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |

#### APBH\_VERSION field descriptions

| Field          | Description                                                          |
|----------------|----------------------------------------------------------------------|
| 31–24<br>MAJOR | Fixed read-only value reflecting the MAJOR field of the RTL version. |
| 23–16<br>MINOR | Fixed read-only value reflecting the MINOR field of the RTL version. |
| STEP           | Fixed read-only value reflecting the stepping of the RTL version.    |

