



# DesignWare Cores DesignWare DW\_axi\_dmac Databook

---

**DW\_axi\_dmac – A415-0**

Synopsys confidential document, provided to Blue Ocean Smart under NDA, do not redistribute

## Copyright Notice and Proprietary Information

© 2018 Synopsys, Inc. All rights reserved. This Synopsys software and all associated documentation are proprietary to Synopsys, Inc. and may only be used pursuant to the terms and conditions of a written license agreement with Synopsys, Inc. All other use, reproduction, modification, or distribution of the Synopsys software or the associated documentation is strictly prohibited.

### Destination Control Statement

All technical data contained in this publication is subject to the export control laws of the United States of America. Disclosure to nationals of other countries contrary to United States law is prohibited. It is the reader's responsibility to determine the applicable regulations and to comply with them.

### Disclaimer

SYNOPSYS, INC., AND ITS LICENSORS MAKE NO WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, WITH REGARD TO THIS MATERIAL, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.

### Trademarks

Synopsys and certain Synopsys product names are trademarks of Synopsys, as set forth at <https://www.synopsys.com/company/legal/trademarks-brands.html>

All other product or company names may be trademarks of their respective owners.

### Third-Party Links

Any links to third-party websites included in this document are for your convenience only. Synopsys does not endorse and is not responsible for such websites and their practices, including privacy practices, availability, and content.

Synopsys, Inc.  
690 E. Middlefield Road  
Mountain View, CA 94043  
[www.synopsys.com](http://www.synopsys.com)

# Contents

|                                                      |          |
|------------------------------------------------------|----------|
| Revision History .....                               | 7        |
| <b>Preface .....</b>                                 | <b>9</b> |
| Organization .....                                   | 9        |
| Related Documentation .....                          | 10       |
| Web Resources .....                                  | 10       |
| Customer Support .....                               | 10       |
| <b>Chapter 1</b>                                     |          |
| Product Overview .....                               | 13       |
| 1.1 DesignWare System Overview .....                 | 13       |
| 1.2 General Product Description .....                | 15       |
| 1.2.1 DW_axi_dmac Block Diagram .....                | 15       |
| 1.3 Features .....                                   | 16       |
| 1.3.1 General Features .....                         | 16       |
| 1.3.2 Channel Buffering .....                        | 17       |
| 1.3.3 Channel Control .....                          | 17       |
| 1.3.4 Flow Control .....                             | 18       |
| 1.3.5 Handshaking Interface .....                    | 18       |
| 1.3.6 Interrupt Outputs .....                        | 18       |
| 1.3.7 Bus Interface .....                            | 18       |
| 1.3.8 Unsupported Features .....                     | 19       |
| 1.4 Terminology .....                                | 19       |
| 1.5 Standards Compliance .....                       | 23       |
| 1.6 Verification Environment Overview .....          | 23       |
| 1.7 Licenses .....                                   | 23       |
| 1.8 Where To Go From Here .....                      | 23       |
| <b>Chapter 2</b>                                     |          |
| Functional Description .....                         | 25       |
| 2.1 Data Flow .....                                  | 26       |
| 2.2 Clocks and Resets .....                          | 28       |
| 2.3 Slave Bus Interface .....                        | 29       |
| 2.4 Master Interface .....                           | 29       |
| 2.5 Arbitration Scheme .....                         | 30       |
| 2.5.1 Single Arbiter Scheme .....                    | 30       |
| 2.5.2 Multi-Arbiter Scheme .....                     | 32       |
| 2.5.3 Locks and Grants .....                         | 35       |
| 2.5.4 Priority for Different Accesses .....          | 35       |
| 2.5.5 Same Channel Transfer, Fetch, and Access ..... | 35       |

|                                                                               |     |
|-------------------------------------------------------------------------------|-----|
| 2.6 Channel Locking . . . . .                                                 | 36  |
| 2.6.1 Enabling Channel Locking . . . . .                                      | 36  |
| 2.6.2 Clearing Channel Locking . . . . .                                      | 36  |
| 2.6.3 Possible Deadlock Conditions . . . . .                                  | 36  |
| 2.7 Endian Scheme . . . . .                                                   | 38  |
| 2.8 Interrupt Interface . . . . .                                             | 44  |
| 2.9 Single Transaction Region . . . . .                                       | 46  |
| 2.10 Handshaking Interface . . . . .                                          | 48  |
| 2.10.1 Hardware Handshaking . . . . .                                         | 48  |
| 2.10.2 Software Handshaking . . . . .                                         | 59  |
| 2.11 Flow Control Configurations . . . . .                                    | 59  |
| 2.12 Early Terminated Burst Transaction . . . . .                             | 62  |
| 2.13 Transfer Control . . . . .                                               | 63  |
| 2.13.1 Single Block Transfer . . . . .                                        | 63  |
| 2.13.2 Multiblock Transfer . . . . .                                          | 63  |
| 2.14 AXI Unaligned Transfer Support . . . . .                                 | 69  |
| 2.14.1 Description of AXI Unaligned Transfers . . . . .                       | 69  |
| 2.14.2 AXI Unaligned Transfer Examples . . . . .                              | 72  |
| 2.15 Channel Suspend, Disable, and Abort . . . . .                            | 89  |
| 2.15.1 Channel Suspend . . . . .                                              | 89  |
| 2.15.2 Channel Suspend and Resume . . . . .                                   | 90  |
| 2.15.3 Channel Suspend and Disable Prior to Transfer Completion . . . . .     | 90  |
| 2.15.4 Channel Disable Prior to Transfer Completion without Suspend . . . . . | 91  |
| 2.15.5 Abnormal Channel Abort . . . . .                                       | 92  |
| 2.16 Debug Interface . . . . .                                                | 92  |
| 2.16.1 Slave Interface and DMAC Core Status Indication . . . . .              | 92  |
| 2.16.2 DMAC Hold Control . . . . .                                            | 92  |
| 2.16.3 Error Handling . . . . .                                               | 93  |
| 2.17 Context Sensitive Low Power Option . . . . .                             | 94  |
| 2.17.1 DMA Channel Context Sensitive Low Power Technique . . . . .            | 95  |
| 2.17.2 Slave Bus Interface Context Sensitive Low Power Technique . . . . .    | 96  |
| 2.17.3 AXI Master Interface Context Sensitive Low Power Technique . . . . .   | 97  |
| 2.17.4 Global Context Sensitive Low Power Technique . . . . .                 | 98  |
| <b>Chapter 3</b>                                                              |     |
| Parameter Descriptions . . . . .                                              | 99  |
| 3.1 Top Level Parameters . . . . .                                            | 100 |
| 3.2 Master Interface Configuration Parameters . . . . .                       | 104 |
| 3.3 Slave Interface Configuration Parameters . . . . .                        | 107 |
| 3.4 Clocking Parameters . . . . .                                             | 108 |
| 3.5 Low Power Configuration Parameters . . . . .                              | 113 |
| 3.6 Channel x Configuration Parameters . . . . .                              | 115 |
| <b>Chapter 4</b>                                                              |     |
| Signal Descriptions . . . . .                                                 | 123 |
| 4.1 Core Clock and Reset Signals . . . . .                                    | 125 |
| 4.2 Test Interface Signals . . . . .                                          | 126 |
| 4.3 AHB Signals . . . . .                                                     | 127 |
| 4.4 Master Interface (for i = 1; i <= DMAX_NUM_MASTER_IF) Signals . . . . .   | 130 |

|                                                                           |     |
|---------------------------------------------------------------------------|-----|
| 4.5 Hardware Handshaking Signals .....                                    | 141 |
| 4.6 Debug Interface Signals .....                                         | 144 |
| 4.7 Interrupt Interface Signals .....                                     | 153 |
| 4.8 Low Power Interface Signals .....                                     | 154 |
| <b>Chapter 5</b>                                                          |     |
| Register Descriptions .....                                               | 159 |
| 5.1 DW_axi_dmac_mem_map/Common_Registers_Address_Block Registers .....    | 162 |
| 5.1.1 DMAC_IDREG .....                                                    | 163 |
| 5.1.2 DMAC_COMPVERREG .....                                               | 164 |
| 5.1.3 DMAC_CFGREG .....                                                   | 165 |
| 5.1.4 DMAC_CHENREG .....                                                  | 167 |
| 5.1.5 DMAC_CHENREG2 .....                                                 | 196 |
| 5.1.6 DMAC_CHSUSPREG .....                                                | 224 |
| 5.1.7 DMAC_CHABORTREG .....                                               | 265 |
| 5.1.8 DMAC_INTSTATUSREG .....                                             | 308 |
| 5.1.9 DMAC_INTSTATUSREG2 .....                                            | 311 |
| 5.1.10 DMAC_COMMONREG_INTCLEARREG .....                                   | 319 |
| 5.1.11 DMAC_COMMONREG_INTSTATUS_ENABLEREG .....                           | 322 |
| 5.1.12 DMAC_COMMONREG_INTSIGNAL_ENABLEREG .....                           | 326 |
| 5.1.13 DMAC_COMMONREG_INTSTATUSREG .....                                  | 330 |
| 5.1.14 DMAC_RESETREG .....                                                | 335 |
| 5.1.15 DMAC_LOWPOWER_CFGREG .....                                         | 336 |
| 5.2 DW_axi_dmac_mem_map/Channelx_Registers_Address_Block Registers .....  | 339 |
| 5.2.1 CHx_SAR (for x = 1; x <= DMAX_NUM_CHANNELS) .....                   | 341 |
| 5.2.2 CHx_DAR (for x = 1; x <= DMAX_NUM_CHANNELS) .....                   | 342 |
| 5.2.3 CHx_BLOCK_TS (for x = 1; x <= DMAX_NUM_CHANNELS) .....              | 343 |
| 5.2.4 CHx_CTL (for x = 1; x <= DMAX_NUM_CHANNELS) .....                   | 345 |
| 5.2.5 CHx_CFG (for x = 1; x <= DMAX_NUM_CHANNELS) .....                   | 359 |
| 5.2.6 CHx_CFG2 (for x = 1; x <= DMAX_NUM_CHANNELS) .....                  | 371 |
| 5.2.7 CHx_LL_P (for x = 1; x <= DMAX_NUM_CHANNELS) .....                  | 383 |
| 5.2.8 CHx_STATUSREG (for x = 1; x <= DMAX_NUM_CHANNELS) .....             | 385 |
| 5.2.9 CHx_SWHSSRCREG (for x = 1; x <= DMAX_NUM_CHANNELS) .....            | 387 |
| 5.2.10 CHx_SWHSDSTREG (for x = 1; x <= DMAX_NUM_CHANNELS) .....           | 391 |
| 5.2.11 CHx_BLK_TFR_RESUMEREQREG (for x = 1; x <= DMAX_NUM_CHANNELS) ..... | 396 |
| 5.2.12 CHx_AXI_IDREG (for x = 1; x <= DMAX_NUM_CHANNELS) .....            | 398 |
| 5.2.13 CHx_AXI_QOSREG (for x = 1; x <= DMAX_NUM_CHANNELS) .....           | 401 |
| 5.2.14 CHx_SSTAT (for x = 1; x <= DMAX_NUM_CHANNELS) .....                | 403 |
| 5.2.15 CHx_DSTAT (for x = 1; x <= DMAX_NUM_CHANNELS) .....                | 405 |
| 5.2.16 CHx_SSTATAR (for x = 1; x <= DMAX_NUM_CHANNELS) .....              | 407 |
| 5.2.17 CHx_DSTATAR (for x = 1; x <= DMAX_NUM_CHANNELS) .....              | 408 |
| 5.2.18 CHx_INTSTATUS_ENABLEREG (for x = 1; x <= DMAX_NUM_CHANNELS) .....  | 409 |
| 5.2.19 CHx_INTSTATUS (for x = 1; x <= DMAX_NUM_CHANNELS) .....            | 423 |
| 5.2.20 CHx_INTSIGNAL_ENABLEREG (for x = 1; x <= DMAX_NUM_CHANNELS) .....  | 441 |
| 5.2.21 CHx_INTCLEARREG (for x = 1; x <= DMAX_NUM_CHANNELS) .....          | 455 |
| <b>Chapter 6</b>                                                          |     |
| Internal Parameter Descriptions .....                                     | 465 |
| <b>Chapter 7</b>                                                          |     |

|                                                                                |     |
|--------------------------------------------------------------------------------|-----|
| Programming the DW_axi_dmac .....                                              | 467 |
| 7.1 Programming Flow for Shadow-Register-Based Multi-Block Transfer .....      | 467 |
| 7.2 Programming Flow for Linked-List-Based Multi-Block Transfer .....          | 470 |
| 7.3 Programming Flow for Single Block Transfer .....                           | 470 |
| Chapter 8                                                                      |     |
| Verification .....                                                             | 473 |
| 8.1 Overview of SV-UVM Tests .....                                             | 473 |
| 8.2 Overview of DW_axi_dmac Testbench .....                                    | 474 |
| Chapter 9                                                                      |     |
| Integration Considerations .....                                               | 477 |
| 9.1 Performance .....                                                          | 477 |
| 9.1.1 Power Consumption, Frequency, and Area Results .....                     | 477 |
| 9.2 4K Boundary Crossing .....                                                 | 479 |
| 9.3 Read Accesses .....                                                        | 479 |
| 9.3.1 Slave Interface Clock is Synchronous to the DW_axi_dmac Core Clock ..... | 479 |
| 9.3.2 Slave Interface Clock is Asynchronous to DW_axi_dmac Core Clock .....    | 480 |
| 9.4 Write Accesses .....                                                       | 482 |
| 9.4.1 Slave Interface Clock is Synchronous to DW_axi_dmac Core Clock .....     | 482 |
| 9.4.2 Slave Interface Clock is Asynchronous to DW_axi_dmac Core Clock .....    | 482 |
| 9.5 Consecutive Write-Read .....                                               | 483 |
| 9.6 Accessing Top-Level Constraints .....                                      | 484 |
| Appendix A                                                                     |     |
| Synchronizer Methods .....                                                     | 485 |
| A.1 Synchronizers used in DW_axi_dmac .....                                    | 486 |
| A.2 Synchronizer 1: Simple Double Register Synchronizer .....                  | 487 |
| A.3 Synchronizer 2: Dual Clock Pulse Synchronizer .....                        | 488 |
| A.4 Synchronizer 3: Pulse Synchronizer with Acknowledge .....                  | 489 |
| A.5 Synchronizer 4: Reset Sequence Synchronizer .....                          | 490 |
| A.6 Synchronizer 5: Dual Clock FIFO Controller with Static Flags .....         | 491 |
| Appendix B                                                                     |     |
| Glossary .....                                                                 | 493 |
| Index .....                                                                    | 497 |

# Revision History

This section tracks the significant documentation changes that occur from release-to-release and during a release from version 1.00a-ea01 onward.

| Date          | Version | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| February 2018 | 1.02a   | <p><b>Added:</b></p> <ul style="list-style-type: none"> <li>■ “AXI Unaligned Transfer Support” on page 69</li> <li>■ “Context Sensitive Low Power Option” on page 94</li> <li>■ “Asynchronous Hardware Handshake Support” on page 59</li> <li>■ “Single Arbiter Scheme” on page 30</li> <li>■ “Multi-Arbiter Scheme” on page 32</li> </ul> <p><b>Updated:</b></p> <ul style="list-style-type: none"> <li>■ Release version and date</li> <li>■ Synthesis Results in “Performance” on page 477</li> <li>■ “Signal Descriptions” on page 105, “Parameter Descriptions” on page 99, and “Register Descriptions” on page 159 auto-extracted from the RTL with change bars</li> </ul> <p><b>Removed:</b></p> <ul style="list-style-type: none"> <li>■ Removed Chapter 2 Building and Verifying a Component or Subsystem from the databook and added the contents in the newly created user guide</li> <li>■ Running Leda on Generated Code with coreConsultant section</li> <li>■ Removed all instances of Leda</li> </ul> |

| Date         | Version    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| March 2016   | 1.01a      | <ul style="list-style-type: none"> <li>■ Revision version change for 2016.03a release</li> <li>■ Added “Running SpyGlass® Lint and SpyGlass® CDC” on page 28</li> <li>■ Added “Running SpyGlass on Generated Code with coreAssembler” on page 35</li> <li>■ “Signal Descriptions” on page 105, “Parameter Descriptions” on page 99, and “Register Descriptions” on page 159 auto-extracted from the RTL</li> <li>■ Added “Internal Parameter Descriptions” on page 465</li> <li>■ Removed “Narrow transfers” from “Unsupported Features” on page 19</li> <li>■ Modified gate count in Table 9-2 Area Results for DW_axi_dmac with tsmc28nm and DMAX_CHx_MULTI_BLK_TYPE set to 1</li> <li>■ Added Appendix A, “Synchronizer Methods”</li> <li>■ Updated area and power numbers in “Performance” on page 477</li> <li>■ Added “Programming Flow for Single Block Transfer” on page 470</li> </ul> |
| October 2014 | 1.00a      | <ul style="list-style-type: none"> <li>■ 2014.10a GA release</li> <li>■ Included these sections in the “Verification” chapter: <ul style="list-style-type: none"> <li>- “Overview of SV-UVM Tests”</li> <li>- “Overview of DW_axi_dmac Testbench”</li> </ul> </li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| August 2014  | 1.00a-ea04 | Added the Clock Parameters block in “Signal Descriptions” on page 105.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| July 2014    | 1.00a-ea03 | <ul style="list-style-type: none"> <li>■ Modified the Integration Considerations chapter</li> <li>■ Modified description for the DMAX_LLI_ENDIAN_SELECTION_PIN_EN parameter</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| June 2014    | 1.00a-ea02 | <ul style="list-style-type: none"> <li>■ Modified address range for the Undefined Register Space in “Parameter Descriptions” on page 99.</li> <li>■ Added two configuration parameters: <ul style="list-style-type: none"> <li>- DMAX_MSTIF1_OSRLMT</li> <li>- DMAX_MSTIF2_OSRLMT</li> </ul> </li> <li>■ Modified reset values for the following registers: <ul style="list-style-type: none"> <li>- DMAC_CommonReg_IntSignal_EnableReg</li> <li>- DMAC_CommonReg_IntStatus_EnableReg</li> <li>- CHx_IntStatus_EnableReg</li> <li>- CHx_IntSignal_EnableReg</li> </ul> </li> </ul>                                                                                                                                                                                                                                                                                                              |
| April 2014   | 1.00a-ea01 | <ul style="list-style-type: none"> <li>■ Changing the Behaviour of Abnormal Channel Abort</li> <li>■ Channel Abort feature now supported, removing all the Notes related to that.</li> <li>■ Added a new section in Debug Interface</li> <li>■ Added Description in section CHx_IntStatusReg</li> <li>■ Removing the Note from Software Handshaking chapter</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| March 2014   | 1.00a-ea00 | Initial release                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

# Preface

---

This databook provides information that you need to interface the DesignWare AXI Central Direct Memory Access (DMA) Controller, referred to as DW\_axi\_dmac throughout the remainder of this databook.

DW\_axi\_dmac is a highly configurable, highly programmable, high-performance multi-master multi-channel DMA Controller with AXI as the bus interface for data transfer. This component conforms to the AMBA Specification, Revision 2.0 and AMBA AXI Protocol Specification, Version 3.0, and 4.0 from ARM.

The information in this databook includes a functional description, signal and parameter descriptions, and a memory map. Also provided are an overview of the component testbench, a description of the tests that are run to verify the coreKit, and synthesis information for the component.

## Organization

The chapters of this databook are organized as follows:

- Chapter 1, “[Product Overview](#)” provides a system overview, a component block diagram, basic features, and an overview of the verification environment.
- Chapter 2, “[Functional Description](#)” describes the functional operation of the DW\_axi\_dmac.
- Chapter 3, “[Parameter Descriptions](#)” identifies the configurable parameters supported by the DW\_axi\_dmac.
- Chapter 4, “[Signal Descriptions](#)” provides a list and description of the DW\_axi\_dmac signals.
- Chapter 5, “[Register Descriptions](#)” describes the programmable registers of the DW\_axi\_dmac.
- Chapter 6, “[Internal Parameter Descriptions](#)” provides a list of internal parameter descriptions that might be indirectly referenced in expressions in the Signals, Registers, and Parameters chapters.
- Chapter 7, “[Programming the DW\\_axi\\_dmac](#)” provides information needed to program the configured DW\_axi\_dmac.
- Chapter 8, “[Verification](#)” provides information on verifying the configured DW\_axi\_dmac.
- Chapter 9, “[Integration Considerations](#)” includes information you need to integrate the configured DW\_axi\_dmac into your design.
- Appendix A, “[Synchronizer Methods](#)” documents the synchronizer methods (blocks of synchronizer functionality) used in DW\_axi\_dmac to cross clock boundaries.
- Appendix B, “[Glossary](#)” provides a glossary of general terms.

## Related Documentation

- [Using DesignWare Library IP in coreAssembler](#) – Contains information on getting started with using DesignWare SIP components for AMBA 2 and AMBA 3 AXI components within coreTools
- [coreAssembler User Guide](#) – Contains information on using coreAssembler
- [coreConsultant User Guide](#) – Contains information on using coreConsultant

To see a complete listing of documentation within the DesignWare Synthesizable Components for AMBA 2, see, the [Guide to Documentation for DesignWare Synthesizable Components for AMBA 2 and AMBA 3 AXI](#).

## Web Resources

- DesignWare IP product information: <http://www.designware.com>
- Your custom DesignWare IP page: <http://www.mydesignware.com>
- Documentation through SolvNet: <http://solvnet.synopsys.com> (Synopsys password required)
- Synopsys Common Licensing (SCL): <http://www.synopsys.com/keys>

## Customer Support

To obtain support for your product:

- First, prepare the following debug information, if applicable:
  - For environment setup problems or failures with configuration, simulation, or synthesis that occur within coreConsultant or coreAssembler, use the following menu entry:

File > Build Debug Tar-file

Check all the boxes in the dialog box that apply to your issue. This menu entry gathers all the Synopsys product data needed to begin debugging an issue and writes it to the file *<core tool startup directory>/debug.tar.gz*.
  - For simulation issues outside of coreConsultant or coreAssembler:
    - Create a waveforms file (such as VPD or VCD)
    - Identify the hierarchy path to the DesignWare instance
    - Identify the timestamp of any signals or locations in the waveforms that are not understood
- Then, contact Support Center, with a description of your question and supply the requested information, using one of the following methods:
  - For fastest response, use the SolvNet website. If you fill in your information as explained, your issue is automatically routed to a support engineer who is experienced with your product. The **Sub Product** entry is critical for correct routing.

Go to <http://solvnet.synopsys.com/EnterACall> and click **Open A Support Case** to enter a call. Provide the requested information, including:

- **Product:** DesignWare Library IP
- **Sub Product 1:** AMBA
- **Product Version:** *<product version number>*
- **Problem Type:**

- **Issue Severity:**
- **Problem Title:** Provide short title of the problem
- **Description:** For simulation issues, include the timestamp of any signals or locations in waveforms that are not understood

After creating the case, attach any debug files you created in the previous step.

- Or, send an e-mail message to [support\\_center@synopsys.com](mailto:support_center@synopsys.com) (your email will be queued and then, on a first-come, first-served basis, manually routed to the correct support engineer):
  - Include the Product name, Sub Product name, and Tool Version number in your e-mail (as identified earlier) so it can be routed correctly.
  - For simulation issues, include the timestamp of any signals or locations in waveforms that are not understood
  - Attach any debug files you created in the previous step.
- Or, telephone your local support center:
  - North America:  
Call 1-800-245-8005 from 7 AM to 5:30 PM Pacific time, Monday through Friday.
  - All other countries:  
<https://www.synopsys.com/support/global-support-centers.html>

Synopsys confidential document, provided to Blue Ocean Smart under NDA, do not redistribute

# Product Overview

This chapter provides a basic overview of the DW\_axi\_dmac, which is a highly configurable, highly programmable, high performance, multimaster multichannel DMA Controller with AXI as the bus interface for data transfer.

## 1.1 DesignWare System Overview

The Synopsys DesignWare Synthesizable Components environment is a parameterizable bus system containing AMBA version 2.0-compliant AHB (Advanced High-performance Bus) and APB (Advanced Peripheral Bus) components, and AMBA version 3.0-compliant and 4.0-compliant AXI (Advanced eXtensible Interface) components.

[Figure 1-1](#) illustrates one example of this environment, including the AXI bus, the AHB bus, and the APB bus. Included in this subsystem are synthesizable IP for AXI/AHB/APB peripherals, bus bridges, and an AXI interconnect and AHB bus fabric. Also included are verification IP for AXI/AHB/APB master/slave models and bus monitors. In order to display the databook for a DW\_\* component, click on the corresponding component object in the illustration.



Links resolve only if you are viewing this databook from your \$DESIGNWARE\_HOME tree, and to only those components that are installed in the tree.

**Figure 1-1 Example of DW\_axi\_dmac in a Complete System**

You can connect, configure, synthesize, and verify the DW\_axi\_dmac within a DesignWare subsystem using coreAssembler, documentation for which is available on the web in the [coreAssembler User Guide](#).

If you want to configure, synthesize, and verify a single component such as the DW\_axi\_dmac component, you might prefer to use coreConsultant, documentation for which is available in the [coreConsultant User Guide](#).

## 1.2 General Product Description

The Synopsys DW\_axi\_dmac conforms to the AMBA Specification, Revision 2.0 and the AMBA AXI Protocol Specification, Version 2.0 from ARM.

### 1.2.1 DW\_axi\_dmac Block Diagram

shows the top-level architecture of the DW\_axi\_dmac.

**Figure 1-2 Top-Level Architecture of the DW\_axi\_dmac**



## 1.3 Features

The DW\_axi\_dmac supports the following features:

### 1.3.1 General Features

- Independent core, slave interface and master interface clocks
- Shutting down the slave interface clock
  - Master can shut down the slave interface clock when the slvif\_busy output is de-asserted.
  - Master must restart the clock before trying to access the slave interface again.
- Individually shutting down the master interface clocks when no peripheral is active
- Up to eight channels, one per source and destination pair, configurable in coreConsultant
- Data transfers in one direction only (each channel is unidirectional)
- Up to two AXI master interfaces, configurable in coreConsultant
  - Two master interfaces for multilayer support
  - Multiple AXI masters increase bus performance by allowing direct connection of peripherals on different AXI interconnects
  - Support for different ACLK on different AMBA layers
- Memory-to-memory, memory-to-peripheral, peripheral-to-memory, and peripheral-to-peripheral DMA transfers
- AMBA 3 AXI/AMBA 4 AXI-compliant master interface
- AHB/AXI4-Lite/APB3 slave interface for programming the DMA controller
  - Only AHB supported in this version
  - AHB slave interface supports only SINGLE transfers ( $hburst = 3'b000$ ).
- AXI master data bus width up to 512 bits (for both AXI master interfaces), configurable in coreConsultant
- Endian mode can be selected statically or dynamically for AXI master interfaces, configurable in coreConsultant
- Input pin to dynamically select endian scheme
- Independent control for endian scheme of linked list access on master interfaces, configurable in coreConsultant
- Optional identification register, configurable in coreConsultant
- Channel locking support
  - Supports locking of the internal channel arbitration for the master bus interface at different transfer hierarchy
- DMAC status indication outputs
- Idle/busy indication

- DMA hold function
- Output pin indicates the last write transfer at DMA transaction level
- Multiple levels of DMA transfer hierarchy
  - DMA transfer split into transaction, block, and complete DMA transfer levels
- Support for AXI unaligned transfers
- Support for Context Sensitive Low Power Option

### 1.3.2 Channel Buffering

- Single FIFO per channel
- FIFO depth, configurable in coreConsultant
- Automatic packing/unpacking of data to fit FIFO width

### 1.3.3 Channel Control

- Programmable transfer type for each channel (memory-to-memory, memory-to-peripheral, peripheral-to-memory and peripheral-to-peripheral)
- Single or multiple DMA transactions
- Programmable multiple transaction size for each channel
- Programmable maximum AMBA burst transfer size for each channel, configurable in coreConsultant
- Channel disabling without data loss
- Channel suspend and resume
- Programmable channel priority
- Locking of internal channel arbitration for master bus interface at different transfer hierarchy
- Programmable multiblock transfer using linked list, contiguous address, auto reload, and shadow register methods
- Dynamic extension of linked list
- Independent configuration of SRC/DST multiblock transfer type
- Multiple state machines, one for each channel SRC and DST
- Separate state machines for data and LLI access
- Control signals, such as cache and protection, programmable per DMA block
- Programmable transfer length (block length)
- Error status register to ease debugging during error events

### 1.3.4 Flow Control

- Programmable flow control at DMA transfer level
  - If the size of the block transfer is known prior to DMA initialization, the DMA controller is a flow controller at the DMA block transfer level.
  - If the size of the DMA block transfer is unknown prior to the DMA initialization Peripheral, either source or destination is the flow controller for undefined length (demand mode) DMA block transfers.

### 1.3.5 Handshaking Interface

- Programmable software and hardware handshaking interfaces for non-memory peripherals
- Up to 16 hardware handshaking interfaces/peripherals, configurable in coreConsultant
- Enabling/disabling of individual handshake interfaces
- Programmable mapping between peripherals and channels; many-to-one mapping with only one peripheral active at a time
- Memory mapped registers to control DMA transfer in software handshaking mode

### 1.3.6 Interrupt Outputs

- Combined and separate interrupt outputs
- Interrupt generation on
  - DMA transfer completion
  - Block transfer completion
  - Single or multiple transaction completion
  - Error condition
  - Channel suspend or disable
- Interrupt enabling and masking

### 1.3.7 Bus Interface

- AMBA 3 AXI and AMBA 4 AXI protocols for master interface and AHB, AXI4-Lite, and APB 3 protocols for slave interface
- Data bus width up to 512 bits for master interface, configurable in coreConsultant
- Outstanding transactions on master interface
- Setting outstanding transaction limit per channel on the master interface
- Configurable AXI transfer width
- Out-of-order transaction support for different channels connected on same master interface  
Transactions of a particular channel are always initiated in order.

- Increment and fixed address transfers on master interface
- Source and destination data transfer addresses; must be aligned to respective transfer widths
- Data bus width of 32/64 bits for slave interface, configurable in coreConsultant
- Transfer size (width) used for slave interface; must be same as data bus width

### 1.3.8 Unsupported Features

The following features are not supported in this release:

- AXI 3 locked transfers (bus locking)
- Bus locking on master interface in AXI 3 mode
- Wrap address transfers

## 1.4 Terminology

The following terms are concise definitions of the DMA concepts used throughout this document.

- **Source peripheral** – Device on an AXI layer from which the DW\_axi\_dmac reads data. The DW\_axi\_dmac then stores the data in the channel FIFO. The source peripheral teams up with a destination peripheral to form a channel.
- **Destination peripheral** – Device to which the DW\_axi\_dmac writes the stored data from the FIFO (data is previously read from the source peripheral).
- **Memory** – Source or destination that is always ready for a DMA transfer and does not require a handshaking interface to interact with the DW\_axi\_dmac.
- **Channel** – Read/write data path between a source peripheral on one configured AXI layer and a destination peripheral on the same or a different AXI layer that occurs through the channel FIFO. If the source peripheral is not memory, then a source handshaking interface is assigned to the channel. If the destination peripheral is not memory, then a destination handshaking interface is assigned to the channel. Source and destination handshaking interfaces can be assigned dynamically by programming the channel registers.
- **Master interface** – DW\_axi\_dmac is a master on the AXI bus, reading data from the source and writing it to the destination over the AXI bus. It is possible to have up to two master interfaces, so that up to two independent source and destination channels can operate simultaneously. Each channel has to arbitrate for the master interface. If the source and destination peripherals reside on different AXI layers, there must be multiple master interfaces.
- **Slave interface** – The AHB/AXI4-Lite/APB3 interface over which the DW\_axi\_dmac is programmed. The slave interface can be on the same layer as any of the master interfaces, or it can be on a separate layer.
- **Handshaking interface** – A set of signals or software registers that conform to a protocol to perform a handshake between the DW\_axi\_dmac and the source or destination peripheral. A handshake helps to control the transfer of a single or burst transaction between the DW\_axi\_dmac and the peripheral. This interface is used to request, acknowledge, and control a DW\_axi\_dmac transaction. A channel can receive a request through one of two types of handshaking interface: hardware or software.

- **Hardware handshaking interface** – Uses hardware signals to control the transfer of a single or burst transaction between the DW\_axi\_dmac and the source or destination peripheral. The simple use of the hardware handshaking interface is when the interrupt line from the peripheral is tied to the “dma\_req” input of the hardware handshaking interface; other interface signals are ignored.
- **Software handshaking interface** – Uses software registers to control transferring a single or burst transaction between the DW\_axi\_dmac and the source or destination peripheral. In this mode, no special DW\_axi\_dmac handshaking signals are needed on the I/O of the peripheral. This mode is useful for interfacing an existing peripheral to the DW\_axi\_dmac without modifying it.
- **Flow controller** – Device (either the DW\_axi\_dmac, or a source or destination peripheral) that determines the length of a DMA block transfer and terminates it. If the length of a block is known before enabling the channel, then the DW\_axi\_dmac should be programmed as the flow controller. If the length of a block is not known prior to enabling the channel, the source or destination peripheral should terminate the block transfer. In this mode, the peripheral (source/destination) is the flow controller.
- **Transfer hierarchy** – Transfers are split into a maximum of four levels: DMA transfer level, block transfer level, transaction level, and AXI transfer level. This is done to minimize the effect of the scenario where the channel is granted to a particular set of peripherals, but a peripheral does not have enough data to transfer continuously. In such a scenario, the channel can not be given to any other peripheral, which reduces the performance.

[Figure 1-3](#) illustrates the hierarchy between DMA transfers, block transfers, transactions (single or burst), and AMBA AXI transfers (single or burst) for non-memory peripherals.

[Figure 1-4](#) illustrates the hierarchy between DMA transfers, block transfers, and AMBA AXI transfers (single or burst) for memory peripherals.



**Note** There is no transaction level for memory peripherals, as a memory is assumed to be always ready for data transfer.

**Figure 1-3 DMA Transfer Hierarchy for Non-Memory Peripherals****Figure 1-4 DMA Transfer Hierarchy for Memory Peripherals**

- **Transaction** – Basic unit of a DW\_axi\_dmac transfer, as determined by either the hardware or the software handshaking interface. A transaction is relevant only for transfers between the DW\_axi\_dmac and a source or destination peripheral if the peripheral is a non-memory device. There are two types of transactions:
  - **Single transaction** – Length of a single transaction is always 1 and it is converted to an INCR AXI transfer of burst length 1.
  - **Burst transaction** – Length of a burst transaction is programmed into the DW\_axi\_dmac. A burst transaction is converted into a sequence of AXI burst transfers. The burst transaction length is under program control and normally bears some relationship to the FIFO sizes in the DW\_axi\_dmac and in the source and destination peripherals.
- **Block** – A block of DW\_axi\_dmac data, the amount of which is the block length and is determined by the flow controller. For transfers between the DW\_axi\_dmac and memory, a block is broken directly into a sequence of burst transfers. For transfers between the DW\_axi\_dmac and a non-memory peripheral, a block is broken into a sequence of DW\_axi\_dmac transactions. These are in turn broken into a sequence of AXI transfers.
- **DMA transfer** – Software controls the number of blocks in a DW\_axi\_dmac transfer. Once the DMA transfer has completed, the hardware within the DW\_axi\_dmac disables the channel and can generate an interrupt to signal the DMA transfer completion. The channel can then be reprogrammed for a new DMA transfer.
  - **Single-block DMA transfer** – Consists of a single block.
  - **Multi-block DMA transfer** – A DMA transfer may consist of multiple DMA blocks. Multi-block DMA transfers are supported through block chaining (linked list pointers), auto-reloading of channel registers, shadow registers, and contiguous blocks. The source and destination can independently select which method to use.
    - **Linked lists (block chaining)** – A linked list pointer (LLP) points to the location in system memory where the next linked list item (LLI) exists. The LLI is a set of registers that describes the next block (block descriptor) and an LLP register. The DW\_axi\_dmac fetches the LLI at the beginning of every block when block chaining is enabled. LLI access always uses the burst size (arsize/awsize) that is the same as the data bus width and cannot be changed or programmed to anything other than this. Burst length (awlen/arlen) is chosen based on the data bus width so that the access does not cross one complete LLI structure of 64 bytes. DW\_axi\_dmac fetches the entire LLI (40 bytes) in one AXI burst, if the burst length is not limited by other settings.
    - **Auto-reloading** – DW\_axi\_dmac automatically reloads the channel registers at the end of each block to the value that was set when the channel was first enabled.
    - **Contiguous blocks** – Address between successive blocks is selected to be a continuation from the end of the previous block.
    - **Shadow register** - DW\_axi\_dmac automatically loads the channel registers from the contents of shadow register set at the end of each block. Software can program the shadow registers with the values corresponding to the next block transfer when the current block transfer is in progress.
- **Channel locking** – Software can program a channel to keep the AXI master interface by locking arbitration of the master bus interface for the duration of a DMA transfer, block transfer, or transaction (single or burst).

## 1.5 Standards Compliance

The Synopsys DW\_axi\_dmac conforms to the AMBA Specification, *AMBA Specification, Revision 2.0* from ARM. Readers are assumed to be familiar with this specification.

## 1.6 Verification Environment Overview

The DW\_axi\_dmac must support an extensive verification environment, which sets up and invokes the selected simulation tool to execute tests that verify the functionality of the configured component and allows you to analyze the results of the simulation.

“Verification” on page 473 discusses the specific procedures for verifying the DW\_axi\_dmac.

## 1.7 Licenses

Before you begin using the DW\_axi\_dmac, you must have a valid license. For more information, see the “Licenses” section in *DesignWare Synthesizable Components for AMBA 2, AMBA 3 AXI, and AMBA 4 AXI Installation Guide*.

## 1.8 Where To Go From Here

At this point, you may want to get started working with the DW\_axi\_dmac component within a subsystem or by itself. Synopsys provides several tools within its coreTools suite of products for the purposes of configuration, synthesis, and verification of single or multiple synthesizable IP components—coreConsultant and coreAssembler. For information on the different coreTools, see *Guide to coreTools Documentation*.

For more information about configuring, synthesizing, and verifying just your DW\_axi\_dmac component, see “Overview of the coreConsultant Configuration and Integration Process” on page 26.

For more information about implementing your DW\_axi\_dmac component within a DesignWare subsystem using coreAssembler, see “Overview of the coreAssembler Configuration and Integration Process” on page 32.

Synopsys confidential document, provided to Blue Ocean Smart under NDA, do not redistribute

# 2

## Functional Description

---

This chapter describes the functional details of the DW\_axi\_dmac component. DW\_axi\_dmac is a highly configurable, highly programmable, high-performance multi-master multi-channel DMA Controller with AXI as the bus interface for data transfer.

This chapter included the following topics:

- “Data Flow” on page 26
- “Clocks and Resets” on page 28
- “Slave Bus Interface” on page 29
- “Master Interface” on page 29
- “Arbitration Scheme” on page 30
- “Channel Locking” on page 36
- “Endian Scheme” on page 38
- “Interrupt Interface” on page 44
- “Single Transaction Region” on page 46
- “Handshaking Interface” on page 48
- “Flow Control Configurations” on page 59
- “Early Terminated Burst Transaction” on page 62
- “Transfer Control” on page 63
- “AXI Unaligned Transfer Support” on page 69
- “Channel Suspend, Disable, and Abort” on page 89
- “Debug Interface” on page 92
- “Context Sensitive Low Power Option” on page 94

## 2.1 Data Flow

**Figure 2-1** shows the flow of data in the DW\_axi\_dmac in a scenario when the source and destination peripherals are on the same AXI layer, while **Figure 2-2** shows the flow of data when the source and destination peripherals are on different AXI layers. In both scenarios, the source peripheral uses a hardware handshaking interface and the destination peripheral uses a software handshaking interface. If these peripherals are memory, handshaking interfaces are not used.

**Figure 2-1 DW\_axi\_dmac Flow Diagram when Source and Destination Peripherals on Same AXI Layer**



**Figure 2-2 DW\_axi\_dmac Flow Diagram when Source and Destination Peripherals on Different AXI Layers**

## 2.2 Clocks and Resets

DW\_axi\_dmac design supports different modes of clocking based on the value of DMAX\_SLVIF\_CLOCK\_MODE, DMAX\_MSTIF1\_CLOCK\_MODE, and DMAX\_MSTIF2\_CLOCK\_MODE coreConsultant parameters. There can be a maximum of four clocks in the design; DW\_axi\_dmac internally takes care of the clock domain crossing requirements.

There can be one to four reset inputs to DW\_axi\_dmac:

- Slave interface – one reset
- Master 1 and 2 interfaces – one reset each
- One core reset input based on the values of the following coreConsultant parameters:
  - DMAX\_SLVIF\_CLOCK\_MODE,
  - DMAX\_MSTIF1\_CLOCK\_MODE, AND
  - DMAX\_MSTIF2\_CLOCK\_MODE

It is assumed that all reset inputs are asserted and de-asserted at the same time with de-assertion synchronous to the corresponding clocks. De-assertion may not be exactly at the same time as there may be delays associated with respect to the synchronization to each clock domain. All resets can be derived from a single reset input.



**Note** DW\_axi\_dmac does not support asserting only of a few resets (not all) or asserting resets at different times (with a delay between each); doing so results in unpredictable behavior.

DW\_axi\_dmac supports a soft reset, which is set using the DMAC\_RST field in the DMAC\_ResetReg register. The soft reset procedure is as follows.

1. Software writes 1 to the DMAC\_ResetReg.DMAC\_RST bit to reset the DW\_axi\_dmac  
Software polls the DMAC\_ResetReg.DMAC\_RST bit until it is seen as 0, which confirms the reset.
2. DW\_axi\_dmac resets all the modules in different clock domains except for the slave bus interface module.  
The Slave bus interface module is not reset because software is polling the DMAC\_ResetReg.DMAC\_RST field.
3. DW\_axi\_dmac clears the DMAC\_ResetReg.DMAC\_RST bit to 0.



**Note** Software is not allowed to write 0 to the DMAC\_ResetReg.DMAC\_RST field. A reset does not guarantee the completion of the data transfer for ongoing or posted requests. If a reset is asserted in between transfers, it might result in AXI protocol violations.

## 2.3 Slave Bus Interface

Slave Bus Interface Module implements the logic to access the internal registers of DW\_axi\_dmac by an external AHB/AXI4-Lite/APB3 Master. This module supports only the little-endian scheme for data transfer. The Slave Bus Interface module supports a 32- or 64-bit data bus width (the APB3 interface supports only 32 bits).

The Slave Bus Interface can be configured to operate on a different clock than the DW\_axi\_dmac core clock (`dmac_core_clock`), which can be configured by setting of the `DMAX_SLVIF_CLOCK_MODE` parameter in `coreConsultant`. If `DMAX_SLVIF_CLOCK_MODE` is set to 1, the Slave Bus Interface module operates on either `hclk`, `aclk`, or `pclk` depending on the protocol used for this interface. The DW\_axi\_dmac design takes care of the clock domain crossing in this situation.

For more details about configuration and programming of this module, see [Chapter 3, “Parameter Descriptions”](#), [Chapter 4, “Signal Descriptions”](#), and [Chapter 5, “Register Descriptions”](#).



**Note** The current version of DW\_axi\_dmac supports only the AHB protocol for the slave bus interface; AXI4-Lite and APB3 support is deferred to future versions.

## 2.4 Master Interface

The master interface implements the transfer of data on the AXI bus. The AXI protocol can be either AXI3 or AXI4, which is configurable in `coreConsultant`. DW\_axi\_dmac supports a maximum of two master interfaces, which operate independently to transfer data between peripherals and memories. Both master interfaces must use the same AXI protocol. Address and Data bus widths of master interfaces are configurable in `coreConsultant`, but both master interfaces use the same configuration.

The master interface implements all five channels specified in the AXI protocol:

- Write address
- Write data
- Write response
- Read address
- Read data

The master interface implements different FIFOs for temporary storage of data transferred between external memories or peripherals through different channels in DW\_axi\_dmac core.

The Master interface can be configured to operate on a different clock than the DW\_axi\_dmac core clock (`dmac_core_clock`), which can be configured by setting `DMAX_MSTIFN_CLOCK_MODE` parameter in `coreConsultant`. If `DMAX_MSTIFN_CLOCK_MODE` is set to 1, the Master Interface module operates on `aclk_mN`. The DW\_axi\_dmac design takes care of the clock domain crossing in this case.

The master interface implements logic to convert between big-endian and little-endian format. The endian scheme used for the big-endian format is the Byte Invariant (BE-8) method, which is the big-endian format supported by the AXI protocol. DW\_axi\_dmac enables you to use the little-endian scheme for LLI fetch and LLI write-back, irrespective of the endian format used for data transfer on that particular master interface.

For more information about configuring or programming the Master interface, see [Chapter 3, “Parameter Descriptions”](#), [Chapter 4, “Signal Descriptions”](#), and [Chapter 5, “Register Descriptions”](#).

DW\_axi\_dmac supports a maximum of eight channels, which can be assigned to either of the master interfaces, based on a well-defined, programmable arbitration scheme for accessing the master interface. Apart from channel source and destination peripherals, LLI fetch and LLI write-back operations also need access to the master interface. DW\_axi\_dmac implements a programmable arbitration scheme which is explained in the following section.

## 2.5 Arbitration Scheme

DMA transfers can be split into the following transfer hierarchy levels:

- Transaction level (only applicable for non-memory peripherals)
- Block level
- Complete DMA transfer level
- AXI transfer level

DW\_axi\_dmac implements a dynamic priority and fair-among-equals arbitration scheme, with options for channel locking at different DMA transfer hierarchy levels.

The number of priority levels available is the same as the number of enabled channels and the priority value is programmable for each channel in the channel configuration register, CHx\_CFG. Multiple channels can be given the same priority level, however, some priority levels remain unused. A priority of 7 is the highest priority, and 0 is the lowest.

Dynamic priority and fair-among-equals arbitration is a two-tier arbitration scheme which works as follows:

- The first-tier arbitration uses the priority inputs of the requests and decides which one of the requesting clients is issued the grant signal. The request with the highest priority is granted access to the AXI channel on the master interface.
- If two or more requests to the arbiter have the same programmed priority value, the second-tier arbitration, based on the fair-among-equals scheme, is used. In this scheme, the grant is issued fairly among actively requesting clients with the same priority level.

### 2.5.1 Single Arbiter Scheme

In Single Arbiter scheme, the arbitration of the read requests from source, destination, and LLI state machine is performed by using the Single Arbiter. The read requests from a channel to the arbiter consists of the following requests:

- Source Data and SSTAT Read Request
- Destination DSTAT Read Request
- LLI Descriptor Read Request (Optional, available only when (DMAX\_HAS\_LLI\_PARAM=1))

The Single arbiter scheme performs the arbitration between these read requests from all channels based on the Dynamic priority (first-tier arbitration) and fair-among-equals (second-tier arbitration) scheme described in “[Arbitration Scheme](#)” on page 30. The granted read request gets the access to the AXI Master Interface. The block diagram of the Single Arbiter Scheme - Read Arbiter is as shown in [Figure 2-3](#).

**Figure 2-3 Single Arbiter Scheme - Read Arbiter**

Where,  $x = \text{DMAX\_NUM\_CHANNELS}$  that is configured number of Channels.

Similarly, the arbitration of write requests from destination and LLI state machine is performed using the Single Arbiter. The write requests from a channel to arbiter consists of the following:

- Destination Data Write Request
- LLI Descriptor Write-Back Request (Optional, available only when ( $\text{DMAX\_HAS\_LLI\_PARAM}=1$ ) and ( $\text{DMAX\_CHx\_LLI\_WB\_EN}=1$ ))

The Single arbiter scheme performs the arbitration between these write requests from all channels based on the Dynamic priority (first-tier arbitration) and fair-among-equals (second-tier arbitration) scheme. The granted write request gets the access to the AXI Master Interface. The block diagram of the Single Arbiter Scheme - Write Arbiter is as shown in [Figure 2-4](#).

**Figure 2-4 Single Arbiter Scheme - Write Arbiter**

Where,  $x = \text{DMAX\_NUM\_CHANNELS}$  that is configured number of channels.

If the number of channels that is `DMAX_NUM_CHANNELS` are less than or equal to 8, then `DW_axi_dmac` is configured with Single Arbiter Scheme that is `DMAX_MULT_ARB_EN` is always hardcoded to 0. If the number channels are greater than 8, then `DW_axi_dmac` can be configured with Single Arbiter Scheme (`DMAX_MULT_ARB_EN = 0`) or Multi-Arbiter Scheme (`DMAX_MULT_ARB_EN = 1`).

## 2.5.2 Multi-Arbiter Scheme

When the number of channels are greater than 8, to meet higher QoR (timing) requirement (if required) - the Multi-Arbiter Scheme is introduced, which is a configurable feature through the `DMAX_MULT_ARB_EN` parameter. This Multi-Arbiter scheme uses the two-stage arbitration architecture. The first-stage has multiple arbiters with each having up to 8 Channels related to read or write requests with registered grant outputs. For the definition of read or write requests for a channel, see “[Single Arbiter Scheme](#)” on page [30](#). The second-stage has single arbiter with grant outputs from each of the first-stage arbiter as request input to the second-stage arbiter. The grant output of the second-stage arbiter is not registered. The Multi-Arbiter scheme splits the single arbiter into multiple smaller arbiters as shown in [Figure 2-5](#) and [Figure 2-6](#). This helps in improving the overall QoR of the `DW_axi_dmac`.

The block diagram of Multi-Arbiter Scheme - Read Arbiter is as shown in [Figure 2-5](#). Each of the Read Arbiter arbitrates using Dynamic priority (first-tier arbitration) and fair-among-equals (second-tier arbitration) scheme at the individual arbiter level.

**Figure 2-5 Multi-Arbiter Scheme - Read Arbiter**

Where,  $\text{NUM\_OF\_ARB} = \text{DMAX\_NUM\_CHANNELS}/8 + \text{DMAX\_NUM\_CHANNELS}\%8$

The block diagram of Multi-Arbiter Scheme - Write Arbiter is as shown in [Figure 2-6](#). Each of the Write Arbiter arbitrates using Dynamic priority (first-tier arbitration) and fair-among-equals (second-tier arbitration) scheme at the individual arbiter level.

**Figure 2-6 Multi-Arbiter Scheme - Write Arbiter**



Where,  $\text{NUM\_OF\_ARB} = \text{DMAX\_NUM\_CHANNELS}/8 + \text{DMAX\_NUM\_CHANNELS}\%8$

The following table shows few example of Multi-Arbiter scheme organization with different number of channels configured.

**Table 2-1 Multi-Arbiter Scheme - Arbiter Organization**

| DMAX_NUM_C CHANNELS | Number of First-Stage Arbiters (NUM_OF_ARB) | Number of read/write requests per First-Stage Arbiter                                                     | Number of requests for Second-Stage Arbiter |
|---------------------|---------------------------------------------|-----------------------------------------------------------------------------------------------------------|---------------------------------------------|
| 32                  | 4                                           | All 4 Arbiters receives request from 8 Channels                                                           | 4                                           |
| 27                  | 4                                           | First 3 Arbiters receives request from 8 Channels<br>Last Arbiter receives request from 3 Channels        | 4                                           |
| 21                  | 3                                           | First 2 Arbiters receives request from 8 Channels<br>Last Arbiter receives request from 5 Channels        | 3                                           |
| 12                  | 2                                           | First Arbiter receives request from 8 Channels<br>Second or last Arbiter receives request from 4 Channels | 2                                           |

### 2.5.3 Locks and Grants

The lock input of the arbiter enables a request, despite other requests, to be given an exclusive grant for the duration of the corresponding lock input. After a client receives the grant, it can lock out other clients from the arbitration process by setting the corresponding lock input.

DW\_axi\_dmac design allows a channel to be locked to the arbiter at the transaction (only applicable for non-memory peripherals), block, or complete DMA transfer level. By default, DW\_axi\_dmac locks the arbiter for one complete AXI transfer. If channel locking is enabled at a higher level—for a transaction, block, or complete DMA transfer—the channel that locked the arbiter gets access to the master interface until the end of locking period, and requests from other channels during this time are ignored.

### 2.5.4 Priority for Different Accesses

If the source, destination, and linked list peripherals of different channels with the same priority value are connected on the same master interface, the priority for different accesses are as follows:

- For AXI Read Channel
  - Linked List fetch > Source Data Transfer/Source Status fetch/Destination Status fetch
- For AXI Write Channel
  - Destination Data Transfer > Linked List Write-back (CHx\_LL\_P\_STATUS, Source and Destination Status)

### 2.5.5 Same Channel Transfer, Fetch, and Access

Source data transfer, destination data transfer, linked list fetch, and linked list status write back access for a particular channel generally happens sequentially as follows.

Linked list fetch > Source data transfer and destination data transfer > Source status fetch and destination status fetch > linked list write back

There is no need for arbitration between different accesses in this case.

## 2.6 Channel Locking

DMA transfers can be split into the following transfer hierarchy levels:

- Complete transfer level
- Block level
- Transaction level (only applicable for non-memory peripherals)
- AXI transfer level

DW\_axi\_dmac allows a channel to be locked to the arbiter during memory-to-memory transfers at block and complete DMA transfer levels. If channel locking is enabled on a block or at the complete DMA transfer level, the channel that locked the arbiter gets access to the master interface until the end of the locking period, and requests from other channels during this time are ignored.

### 2.6.1 Enabling Channel Locking

Channel locking can be implemented in the following scenarios.

- If channel locking is enabled at a particular transfer hierarchy and it is a memory-to-memory transfer, the locking of the corresponding channel to the AXI channels of the master interface is established.
- Transfer is a memory-to-memory transfer.



Hardware does not check for the validity of the channel locking setting, therefore, the software must enable the channel locking only for memory-to-memory transfers at block or DMA transfer levels. Illegal programming of channel locking might result in unpredictable behavior.

### 2.6.2 Clearing Channel Locking

Channel locking is cleared when DW\_axi\_dmac suspends, disables, or aborts the channel upon request from software, or DW\_axi\_dmac disables the channel upon receiving an error response on the master interface.

The ChLock\_Cleared\_IntStat bit in the CHx\_IntStatusReg register is set to 1 if DW\_axi\_dmac clears the channel locking due to an error response received on the master interface, or if software suspends, disables, or aborts the channel. Additionally, the ChLock\_Cleared\_IntStat is cleared at the end of each block or DMA transfer if channel locking is enabled on DMA block level or transfer level, respectively.

### 2.6.3 Possible Deadlock Conditions

A deadlock condition can occur when multiple channels are enabled concurrently on a master interface and one of these channels has obtained a read lock on the master interface and the remaining channels are locked out from proceeding with a DMA transfer. While programming, you must ensure that sure deadlock do not occur. A deadlock can occur only for configurations where the number of masters are equal to 2 (DMAC\_NUM\_MASTER\_IF = 2) and the number of channels are more than 1 (DMAC\_NUM\_CHANNELS > 1).

**Figure 2-7** illustrates a scenario in which the read channel is locked out for subsequent read requests.

### Figure 2-7 Scenario 1: Deadlock Condition

| Channel 1 Programming Instructions |                                    | Channel 2 Programming Instructions |                                    |
|------------------------------------|------------------------------------|------------------------------------|------------------------------------|
| CH1_CTL.SMS= 1                     | Source on Master Interface 2       | CH2_CTL.SMS= 0                     | Source on Master Interface 1       |
| CH1_CTL.DMS=0                      | Destination on Master Interface 1  | CH2_CTL.DMS=0                      | Destination on Master interface 1  |
| CH1_LLP.LMS=0                      | LLI on Master interface 1          | CH2_LLP.LMS=1                      | LLI on Master interface 2          |
| CH1_CFG.LOCK_CH_L=01               | Locking over complete DMA transfer | CH2_CFG.LOCK_CH_L=01               | Locking over complete DMA transfer |
| CH1_CFG.LOCK_CH=1                  | Locking enabled                    | CH2_CFG.LOCK_CH=1                  | Locking enabled                    |



- ① LL1 in both Channels 1 and 2 request lock for Master interface 1 and 2 read address channels, respectively.  
Request granted for complete DMA transfer as no other channel is active.
- ② After sometime, if:
  - Source of Channel 1 requests for Master 2 read channel
  - Source of Channel 2 requests for Master 1 read channel
- ③ Deadlock occurs as the master read address channels are locked with different channels.

**Figure 2-8** illustrates another scenario in which the read channel is locked out for subsequent read requests.

**Figure 2-8 Scenario 2: Deadlock Condition**

| Channel 1 Programming Instructions |                                        | Channel 2 Programming Instructions |                                        |
|------------------------------------|----------------------------------------|------------------------------------|----------------------------------------|
| CH1_CTL.SMS= 0                     | Source on Master interface 1           | CH2_CTL.SMS= 1                     | Source on Master interface 2           |
| CH1_CTL.DMS=1                      | Destination on Master interface 2      | CH2_CTL.DMS=0                      | Destination on Master interface 1      |
| CH1_CTL.DST_STAT_EN=1              | Destination on Status Fetch is enabled | CH2_CTL.DST_STAT_EN=1              | Destination on Status Fetch is enabled |
| CH1_LL.P.LMS=0                     | LLI on Master interface 1              | CH2_LL.P.LMS=1                     | LLI on Master interface 2              |
| CH1_CFG.LOCK_CH_L=01               | Locking over complete DMA transfer     | CH2_CFG.LOCK_CH_L=01               | Locking over complete DMA transfer     |
| CH1_CFG.LOCK_CH=1                  | Locking enabled                        | CH2_CFG.LOCK_CH=1                  | Locking enabled                        |



- ① Master interface 1 read and write address channels locked by Channel 1 and Channel 2, respectively.
- ② Master interface 2 read and write address channels locked by Channel 1 and Channel 2 respectively.
- ③ At the end of first block, if:
  - Destination of Channel 1 requests Master 2 read channel for status fetch
  - Destination of Channel 2 requests Master 1 read channel for status fetch
- ④ Deadlock occurs as both master read address channels are locked by different channels.

## 2.7 Endian Scheme

DW\_axi\_dmac supports little-endian and big-endian format for data access on the AXI master interface. The endian scheme used for the big-endian format is the Byte Invariant (BE-8) method, which is the format supported by the AXI protocol. If the AXI master interface is configured for the big-endian format, big-endian BE-8-to-little-endian conversion is done for AXI read data and little-endian-to-big-endian BE-8 conversion is done for AXI write data.

The following figures show the conversion process between big-endian BE-8 and little-endian data appearing on the AXI master bus for different data bus width and transfer size combinations.

**Figure 2-9 BE-LE Conversion Using BE-8 (Byte Invariant) Method for 32-Bit Data Bus (Byte Access)**



**Figure 2-10 BE-LE Conversion Using BE-8 (Byte Invariant) Method for 32-Bit Data Bus (Half Word Access)**



**Figure 2-11 BE-LE Conversion Using BE-8 (Byte Invariant) Method for 32-Bit Data Bus (Word Access)**



**Figure 2-12 BE-LE Conversion Using BE-8 (Byte Invariant) Method for 64-Bit Data Bus (Byte Access)****Figure 2-13 BE-LE Conversion Using BE-8 (Byte Invariant) Method for 64-Bit Data Bus (Half Word Access)****Figure 2-14 BE-LE Conversion Using BE-8 (Byte Invariant) Method for 64-Bit Data Bus (Word Access)**

**Figure 2-15 BE-LE Conversion Using BE-8 (Byte Invariant) Method for 64-Bit Data Bus (Double Word Access)****Figure 2-16 BE-LE Conversion Using BE-8 (Byte Invariant) Method for 128-Bit Data Bus (Byte Access)****Figure 2-17 BE-LE Conversion Using BE-8 (Byte Invariant) Method for 128-Bit Data Bus (Half Word Access)**

**Figure 2-18 BE-LE Conversion Using BE-8 (Byte Invariant) Method for 128-Bit Data Bus (Word Access)****Figure 2-19 BE-LE Conversion Using BE-8 (Byte Invariant) Method for 128-Bit Data Bus (Double Word Access)****Figure 2-20 BE-LE Conversion Using BE-8 (Byte Invariant) Method for 128-Bit Data Bus (128-Bit Access)**

A similar scheme is used for other transfer sizes as well. In general, the data bus is grouped in terms of transfer size and bytes within each group are swapped such that the lower byte becomes the higher byte, and the higher byte becomes the lower byte.

The endian scheme used for the source and destination data transfer, LLI fetch, and status and control write-back access on the master interfaces is decided by the value of the respective coreConsultant parameters and the I/O signals. Table 2-2 shows all possible combinations of the endian scheme on the master interface.

**Table 2-2** Endian Formats Supported on Master Interface

| DMAX_STATIC_ENDIAN_SELECT_MSTIF | DMAX_ENDIAN_FORMAT_MSTIF | dmac_endian_format_mstif1/2 | Endian Scheme Used for SRC/DST Data Access on M1/M2 Master Interface | DMAX_LLI_ENDIAN_SELECTION_PIN_EN | dmac_le_select_llii_mstif1/2 | Endian Scheme Used for LLI Fetch/ Status and Control Write Back Access on M1/M2 Master Interface |
|---------------------------------|--------------------------|-----------------------------|----------------------------------------------------------------------|----------------------------------|------------------------------|--------------------------------------------------------------------------------------------------|
| 1                               | 0                        | X                           | Little-Endian                                                        | X                                | X                            | Little-Endian                                                                                    |
| 1                               | 1                        | X                           | Big-Endian BE-8                                                      | 0                                | X                            | Big-Endian BE-8                                                                                  |
|                                 |                          |                             |                                                                      | 1                                | 0                            | Big-Endian BE-8                                                                                  |
|                                 |                          |                             |                                                                      |                                  | 1                            | Little-Endian                                                                                    |
| 0                               | X                        | 0                           | Little-Endian                                                        | X                                | X                            | Little-Endian                                                                                    |
| 0                               | X                        | 1                           | Big-Endian BE-8                                                      | 0                                | X                            | Big-Endian BE-8                                                                                  |
|                                 |                          |                             |                                                                      | 1                                | 0                            | Big-Endian BE-8                                                                                  |
|                                 |                          |                             |                                                                      |                                  | 1                            | Little-Endian                                                                                    |

## 2.8 Interrupt Interface

DW\_axi\_dmac supports combined and individual interrupt outputs configurable in coreConsultant. The polarity of the interrupt (Active High/Active Low) can be configured in coreConsultant. Interrupt outputs, by default, are synchronous to the core clock (dmac\_core\_clock), but they can be synchronized to the slave interface clock using the DMAX\_INTR\_SYNC2SLVCLK parameter in coreConsultant. If this parameter is set to 1, interrupt outputs are synchronous to hclk/aclk/pclk based on the protocol used for the slave interface. DW\_axi\_dmac manages the clock domain synchronization requirements in this configuration.

DW\_axi\_dmac has different registers to support the interrupt interface. Software can read these registers to understand the source of the interrupt and take appropriate actions.



**Note** DW\_axi\_dmac supports synchronizing the interrupt outputs to the Slave Interface clock domain. The synchronization mechanism is not captured in [Figure 2-21](#).

[Figure 2-21](#) shows the interrupt generation mechanism in DW\_axi\_dmac.

**Figure 2-21 DW\_axi\_dmac Interrupt Generation**

## 2.9 Single Transaction Region

In certain cases, a DMA block transfer cannot complete using only burst transactions. Typically this occurs when the block size is not a multiple of the burst transaction length. In these cases, the block transfer uses burst transactions up to the point where the amount of data left to complete the block is less than the amount of data in a burst transaction. At this point, the DW\_axi\_dmac samples the `dma_single` status flag and completes the block transfer using single transactions. The peripheral asserts a single status flag to indicate to the DW\_axi\_dmac that there is enough data or space to complete a single transaction from or to the source or destination peripheral.

For hardware handshaking, the single status flag is a signal on the hardware handshaking interface. For software handshaking, the single status flag is one bit in the software handshaking interface register.

The single transaction region is the time interval where the DW\_axi\_dmac uses single transactions to complete the block transfer; burst transactions are used only outside this region.

The following terms are used for explaining single transaction region.

- Source single transaction size in bytes:

$$\text{src\_single\_size\_bytes} = \text{CHx\_CTL.SRC\_TR\_WIDTH}/8$$

- Source burst transaction size in bytes:

$$\text{src\_burst\_size\_bytes} = \text{CHx\_CTL.SRC\_MSIZE} * \text{src\_single\_size\_bytes}$$

- Destination single transaction size in bytes:

$$\text{dst\_single\_size\_bytes} = \text{CHx\_CTL.DST\_TR\_WIDTH}/8$$

- Destination burst transaction size in bytes:

$$\text{dst\_burst\_size\_bytes} = \text{CHx\_CTL.DST\_MSIZE} * \text{dst\_single\_size\_bytes}$$

- Block size in bytes:

- If DW\_axi\_dmac is flow controller – With the DW\_axi\_dmac as the flow controller, the processor programs the DW\_axi\_dmac with the number of data items (block size) of source transfer width (`CHx_CTL.SRC_TR_WIDTH`) to be transferred by the DW\_axi\_dmac in a block transfer; this is programmed into the `CHx_BLOCK_TS.BLOCK_TS` field. Therefore, the total number of bytes to be transferred in a block is:

$$\text{blk\_size\_bytes\_dma} = \text{CHx\_BLOCK\_TS.BLOCK\_TS} * \text{src\_single\_size\_bytes}$$

- If source peripheral is flow controller

$$\text{blk\_size\_bytes\_src} = (\text{Number of source burst transactions in block} * \text{src\_burst\_size\_bytes}) + (\text{Number of source single transactions in block} * \text{src\_single\_size\_bytes})$$

- If destination peripheral is block flow controller

$$\text{blk\_size\_bytes\_dst} = (\text{Number of destination burst transactions in block} * \text{dst\_burst\_size\_bytes}) + (\text{Number of destination single transactions in block} * \text{dst\_single\_size\_bytes})$$

The single transaction region applies only to a peripheral that is not the flow controller. The precise definition of when this region is entered depends on what acts as the flow controller.

- If the DW\_axi\_dmac is the flow controller:
  - The source peripheral enters the single transaction region when the number of bytes left to complete in the source block transfer is less than `src_burst_size_bytes`.  
If `blk_size_bytes_dma/src_burst_size_bytes` is an integer, then the source peripheral never enters this region, and the source block transfer uses only burst transactions.
  - The destination peripheral enters the single transaction region when the number of bytes left to complete in the destination block transfer is less than `dst_burst_size_bytes`.  
If `blk_size_bytes_dma/dst_burst_size_bytes` is an integer, then the destination peripheral never enters this region, and the destination block transfer uses only burst transactions.
- If either the source or the destination peripheral is the flow controller:
  - Single transaction region is not applicable for the flow controller peripheral.
  - If the source peripheral is the flow controller, the destination peripheral enters the single transaction region when the flow control peripheral – that is, the source – signals the last transaction in the block and when the amount of data left to be transferred in the destination block is less than the value specified by `dst_burst_size_bytes`.
  - If the destination peripheral is the flow controller, the source peripheral enters the single transaction region when the flow control peripheral – that is, the destination – signals the last transaction in the block and when the amount of data left to be transferred in the source block is less than the value specified by `src_burst_size_bytes`.



If a peripheral is not the flow controller, DW\_axi\_dmac ignores `dma_single` input outside the single transaction region.

## 2.10 Handshaking Interface

Handshaking interfaces are used at the transaction level to control the flow of single or burst transactions. The operation of the handshaking interface depends on whether the peripheral or the DW\_axi\_dmac is the flow controller. The peripheral uses the handshaking interface to indicate to the DW\_axi\_dmac that it is ready to transfer or accept data over the AXI bus.

DW\_axi\_dmac supports a maximum of 16 hardware handshaking interfaces, which are configurable in coreConsultant. The type of handshaking interface used (software or hardware) is independently programmable for each channel source and destination in the channel configuration register, CHx\_CFG. Software handshaking is accomplished through memory-mapped registers, while hardware handshaking is accomplished using a dedicated handshaking interface.

### 2.10.1 Hardware Handshaking

The following set of I/O signals are used for hardware handshaking.

- **dma\_req** – Burst transaction request input from peripheral. The functionality of this signal depends on whether the peripheral is the flow controller or not.
  - **If peripheral is not flow controller** – The DW\_axi\_dmac always interprets the dma\_req signal as a burst transaction request, regardless of the level of dma\_single. Once dma\_req is asserted, it must remain asserted until dma\_ack is asserted. When the peripheral that is driving dma\_req determines that dma\_ack is asserted, it must de-assert dma\_req. If an active level on dma\_req is detected in the single transaction region, then the block transfer is completed using an early terminated burst transaction.
  - **If peripheral is flow controller** – An active level on dma\_req initiates a transaction request. The type of transaction – whether single or burst – is qualified by the dma\_single input. Once dma\_req is asserted, it must remain asserted until dma\_ack is asserted. When the peripheral that is driving dma\_req determines that “dma\_ack” is asserted, it must de-assert dma\_req.
- **dma\_single** - Single transaction request input from peripheral. The functionality of this signal depends on whether the peripheral is the flow controller or not.
  - **If peripheral is not flow controller** – The dma\_single signal is a status signal that is asserted by a source or destination peripheral when it can transmit or accept at least one source or destination data item; otherwise it is cleared. This signal is sampled by the DW\_axi\_dmac only in the single transaction region of the block transfer. Outside this region, dma\_single is ignored and all transactions are burst transactions, which means DW\_axi\_dmac waits for dma\_req to be asserted. Once dma\_single is asserted, it must remain asserted until dma\_ack is asserted. When the peripheral that is driving dma\_single determines that dma\_ack is asserted, it must de-assert dma\_single.
  - **If peripheral is flow controller** – The dma\_single signal is asserted by a source or destination peripheral to request a single transaction. If dma\_single is asserted in the same clock cycle as dma\_req is asserted, a single transaction is requested by the peripheral. If dma\_single is de-asserted, the peripheral is requesting a burst transaction. Once dma\_single is asserted, it must remain asserted until dma\_ack is asserted. When the peripheral that is driving dma\_single determines that dma\_ack is asserted, it must de-assert dma\_single.

- **dma\_last** - The last transaction in a block request from a peripheral. The functionality of this signal depends on whether the peripheral is the flow controller or not.
  - **If peripheral is not flow controller** – The dma\_last signal is not relevant and it is ignored.
  - **If peripheral is flow controller** – The peripheral asserts dma\_last on the same cycle as dma\_req is asserted in order to signal that this transaction request is the last in the block and the block transfer is complete after this transaction is complete. If dma\_single is high in the same cycle as dma\_last (and dma\_req) is asserted, the last transaction is a single transaction. If dma\_single is low in the same cycle as dma\_last (and dma\_req) is asserted, the last transaction is a burst transaction. Once dma\_last is asserted, it must remain asserted until dma\_ack is asserted. When the peripheral that is driving dma\_last determines that dma\_ack is asserted, it must de-assert dma\_last.
- **dma\_ack** - DW\_axi\_dmac acknowledges signal output to the peripheral. The functionality of this signal depends on whether the peripheral is the flow controller or not.
  - **If peripheral is not flow controller** – The dma\_ack signal is asserted after the last AXI data transfer in the current transaction (single or burst) to the peripheral has completed. For a single transaction, dma\_ack remains asserted until the peripheral de-asserts dma\_single (that is, dma\_ack is de-asserted one dmac\_core\_clock cycle after the de-assertion of dma\_single). For a burst transaction, dma\_ack remains asserted until the peripheral de-asserts dma\_req (that is, dma\_ack is de-asserted one dmac\_core\_clock cycle after the de-assertion of dma\_req).
  - **If peripheral is flow controller** – The dma\_ack signal is asserted after the last AXI data transfer in the current transaction (single or burst) to the peripheral has completed. It forms a handshaking loop with dma\_req and remains asserted until the peripheral de-asserts dma\_req (that is, dma\_ack is de-asserted one dmac\_core\_clock cycle after the de-assertion of dma\_req).
- **dma\_finish** - This is the DW\_axi\_dmac block transfer complete indication signal output to the peripheral. The dma\_finish signal is asserted to signal block completion. This uses the same timing as dma\_ack and forms a handshaking loop with dma\_req and/or dma\_single.

Figure 2-22 shows the hardware handshaking interface between a destination or source peripheral and DW\_axi\_dmac.

**Figure 2-22 Hardware Handshaking Interface****Peripheral not Flow controller****Peripheral is Flow controller****Note**

- Once a peripheral asserts `dma_req`, `dma_single`, or `dma_last`, de-asserting the signal before the DW\_axi\_dmac asserts `dma_ack` is not allowed. Doing so might result in unpredictable behavior.
- Irrespective of who is the flow controller and whether the peripheral is in Single Transaction Region, `dma_req`, `dma_single`, and `dma_last` signals must be de-asserted once DW\_axi\_dmac asserts `dma_ack`. It is recommended that you follow this requirement, otherwise, unpredictable behavior may occur.

**Table 2-3** shows all possible combinations of Flow Controller and Hardware Handshaking Interface signal values.

**Table 2-3 Flow Controller and Hardware Handshaking Interface**

| Peripheral Flow Controller? | Peripheral in Single Transaction Region? | dma_req | dma_single | dma_last | DW_axi_dmac Action                                                                                                                                                                                                                                                                                      |
|-----------------------------|------------------------------------------|---------|------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| No                          | No                                       | 0       | 0          | X        | Not a valid transaction request                                                                                                                                                                                                                                                                         |
|                             |                                          | 0       | 1          | X        | Not a valid transaction request.<br>If peripheral is not Flow Controller, "dma_single" is not sampled by DW_axi_dmac outside Single Transaction Region.                                                                                                                                                 |
|                             |                                          | 1       | X          | X        | Burst transaction request.<br>If peripheral is not Flow Controller, "dma_single" is not sampled by DW_axi_dmac outside Single Transaction Region.<br>If peripheral is not the flow controller, "dma_last" does not have any relevance and it is ignored.                                                |
|                             | Yes                                      | 0       | 0          | X        | Not a valid transaction request.                                                                                                                                                                                                                                                                        |
|                             |                                          | 0       | 1          | X        | Single Transaction request.<br>DW_axi_dmac initiates AXI burst of burst length 1.<br>If peripheral is not the flow controller, "dma_last" does not have any relevance and it is ignored.                                                                                                                |
|                             |                                          | 1       | 0          | X        | Burst Transaction request.<br>DW_axi_dmac initiates AXI burst of burst length needed to complete the transaction (AXI burst length <= transaction size). This is called Early Burst Termination.<br>If peripheral is not the flow controller, "dma_last" does not have any relevance and it is ignored. |
|                             |                                          | 1       | 1          | X        | Burst Transaction request.<br>DW_axi_dmac initiates AXI burst of burst length needed to complete the transaction (AXI burst length <= transaction size). This is called Early Burst Termination.<br>If peripheral is not the flow controller, "dma_last" does not have any relevance and it is ignored. |

**Table 2-3 Flow Controller and Hardware Handshaking Interface (Continued)**

| Peripheral Flow Controller? | Peripheral in Single Transaction Region?                               | dma_req | dma_single | dma_last | DW_axi_dmac Action                                                                                                                                                                                                                                           |
|-----------------------------|------------------------------------------------------------------------|---------|------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Yes                         | Single Transaction Region is not applicable to Flow Control Peripheral | 0       | 0          | X        | Not a valid transaction request.                                                                                                                                                                                                                             |
|                             |                                                                        | 0       | 1          | X        | Not a valid transaction request.<br>If peripheral is flow controller, “dma_req” MUST be asserted to initiate a transaction. DW_axi_dmac waits till “dma_req” is asserted.<br>The type of transaction - single or burst - is qualified by “dma_single” input. |
|                             |                                                                        | 1       | 0          | 0        | Burst transaction request (not the last transaction).                                                                                                                                                                                                        |
|                             |                                                                        | 1       | 0          | 1        | Last Burst transaction request.                                                                                                                                                                                                                              |
|                             |                                                                        | 1       | 1          | 0        | Single transaction request (not the last transaction).                                                                                                                                                                                                       |
|                             |                                                                        | 1       | 1          | 1        | Last single transaction request.                                                                                                                                                                                                                             |

### 2.10.1.1 Hardware Handshaking Transaction Examples

This section provides various examples of hardware handshaking scenarios, as follows:

- “Burst Transaction – DMA Flow Controller” on page 52
- “Back-to-Back Burst Transaction – DMA Flow Controller” on page 53
- “Single Transaction – DMA Flow Controller” on page 54
- “Burst Followed by Back-to-Back Single Transaction – DMA Flow Controller” on page 55
- “Early Terminated Burst Transaction – DMA Flow Controller” on page 55
- “Burst Transaction Ignored During Active Single Transaction – DMA Flow Controller” on page 56
- “Burst Transaction Followed by Single Transaction – Peripheral Flow Controller” on page 57
- “Back-to-Back Single Transaction – Peripheral Flow Controller” on page 58

#### Burst Transaction – DMA Flow Controller

Figure 2-23 shows the timing diagram of a burst transaction. Because the peripheral is outside the Single Transaction Region, DW\_axi\_dmac does not sample dma\_single[0].

The handshaking loop is as follows:

- dma\_req asserted by peripheral
- dma\_ack asserted by DW\_axi\_dmac
- dma\_req de-asserted by peripheral
- dma\_ack de-asserted by DW\_axi\_dmac

**Figure 2-23 Burst Transaction****Back-to-Back Burst Transaction – DMA Flow Controller**

Figure 2-24 shows the timing diagram of a back-to-back burst transaction. Because the peripheral is outside the Single Transaction Region, DW\_axi\_dmac does not sample **dma\_single[0]**. The second burst terminates the block, and **dma\_finish[0]** is asserted to indicate the block completion.

**Figure 2-24 Back-to-Back Burst Transaction**



There are two things to note when designing the hardware handshaking interface:

- Once asserted, the dma\_req burst request signal must remain asserted until the corresponding dma\_ack signal is received, even if the condition that generates dma\_req in the peripheral is False.
- The dma\_req signal must be de-asserted when dma\_ack is asserted, even if the condition that generates dma\_req in the peripheral is true.

## Single Transaction – DMA Flow Controller

[Figure 2-25](#) shows a single transaction that occurs in the Single Transaction Region. The handshaking loop is as follows:

- dma\_single asserted by peripheral
- dma\_ack asserted by DW\_axi\_dmac
- dma\_single de-asserted by peripheral
- dma\_ack de-asserted by DW\_axi\_dmac

**Figure 2-25 Single Transaction**



## Burst Followed by Back-to-Back Single Transaction – DMA Flow Controller

After the first burst transaction, the peripheral enters the Single Transaction Region and DW\_axi\_dmac starts sampling the dma\_single. The second single transaction terminates the block transfer; dma\_finish[0] is asserted to indicate block completion. [Figure 2-26](#) illustrates this scenario.

**Figure 2-26** Burst Followed by Back-to-Back Single Transaction



## Early Terminated Burst Transaction – DMA Flow Controller

In the Single Transaction Region, if an active level on dma\_req and dma\_single occur on the same cycle — or if the active level on dma\_single occurs in same cycle as dma\_req - then the burst transaction takes precedence over the single transaction, and the block would be completed using an early terminated burst transaction.

In [Figure 2-27](#), after the first burst DW\_axi\_dmac enters the single transaction region and samples dma\_single[0] at T1 after that. When one single transaction is done, at time T2 dma\_req[0] is asserted which results in an early terminated burst, hence completing the block indicated by dma\_finish[0].

**Figure 2-27 Early Terminated Burst Transfer****Burst Transaction Ignored During Active Single Transaction – DMA Flow Controller**

As illustrated in [Figure 2-28](#), after the first burst transaction completes, the peripheral is in the Single Transaction Region and DW\_axi\_dmac samples that **dma\_single[0]** is asserted at T1. The **dma\_req[0]** signal is triggered in the middle of this single transaction at time T2. This burst transaction request is ignored and is not serviced. An active edge on **dma\_req[0]** is re-generated and sampled by DW\_axi\_dmac at time T3. This burst transaction completes the block transfer using an Early-Terminated Burst Transaction.

**Figure 2-28 Burst Transaction Ignored During Active Single Transaction**

## Burst Transaction Followed by Single Transaction – Peripheral Flow Controller

Figure 2-29 shows a burst transaction followed by a single transaction, where the single transaction is the last in the block. On clock edge T1, DW\_axi\_dmac samples that dma\_req[0] is asserted, and dma\_single[0] and dma\_last[0] are de-asserted. This is a request for a burst transaction, which is not the last transaction in the block.

On clock edge T2, DW\_axi\_dmac samples that dma\_req[0], dma\_single[0], and dma\_last[0] are all asserted. This is a request for a single transaction, which is the last transaction in the block.

The handshaking loop is as follows:

- dma\_req along with dma\_single and dma\_last asserted by peripheral
- dma\_ack along with dma\_finish asserted by DW\_axi\_dmac
- dma\_req, dma\_single and dma\_last de-asserted by peripheral
- dma\_ack and dma\_finish de-asserted by DW\_axi\_dmac

**Figure 2-29 Burst Followed by Single Transaction (last in block)**



## Back-to-Back Single Transaction – Peripheral Flow Controller

Figure 2-30 shows a back-to-back single transaction, where the last single transaction is the last transaction in the block.

**Figure 2-30 Back-to-Back Single Transaction – Peripheral Flow Controller**



### 2.10.1.2 Peripheral Interrupt Request Interface

This is a simplified version of the hardware handshaking interface. In this mode:

- The interrupt line from the peripheral is tied to the `dma_req` input.
- The `dma_single` input is tied low.
- The `dma_last` input is tied low.
- The `dma_ack` and `dma_finish` outputs are ignored (unconnected).

This interface can be used when the slave peripheral does not have hardware handshaking signals. To the DW\_axi\_dmac, this is the same situation as the case of the Hardware Handshaking Interface when the peripheral is not the flow controller.

The peripheral can never be the flow controller because it cannot connect to the `dma_last` signal. The interrupt line from the peripheral is tied to the `dma_req` line and the timing of the interrupt line from the peripheral must be the same as the `dma_req` line as the case of the Hardware Handshaking Interface when the peripheral is not the flow controller.

Because the peripheral does not sample the `dma_ack` line, the handshaking loop is as follows:

1. Peripheral generates an interrupt that asserts “`dma_req`”.
2. DW\_axi\_dmac completes the burst transaction and generates an end-of-burst transaction interrupt, SRC\_TransComp/DST\_TransComp. Global Interrupt must be enabled in `DMAC_CfgReg` register and the corresponding channel's transaction completion indication interrupt must be enabled in `CHx_IntStatus_EnableReg` and `CHx_IntSignal_EnableReg` registers.
3. The interrupt service routine clears the interrupt in the peripheral so that the “`dma_req`” is de-asserted.

### 2.10.1.3 Asynchronous Hardware Handshake Support

The DW\_axi\_dmac supports hardware handshaking interface, that controls the flow of single or burst transactions. This hardware handshaking interface can be configured as synchronous or asynchronous with respect to dmac\_core\_clock. The DW\_axi\_dmac core provides the following configuration parameters that allows you to enable asynchronous hardware handshake interface. These parameters also allows you to configure each hardware handshaking interface as synchronous or asynchronous with respect to dmac\_core\_clock signal.

- DMAX\_ASYNC\_HS\_EN - Includes/Excludes Asynchronous DMA Handshake Support
- DMAX\_HS\_SAME\_ASYNC\_CLK - All DMA Handshake interface has the same asynchronous clock
- DMAX\_HS(y)\_ASYNC\_CLK - DMA Handshake interface y has asynchronous clock, where,  
 $y = 1\dots\text{DMAX\_NUM\_HS\_IF}$

All assertion and de-assertion requirements related to dma\_req, dma\_single, and dma\_last are still applicable. See the section “[Hardware Handshaking](#)” on page [48](#).

### 2.10.2 Software Handshaking

When the slave peripheral requires the DW\_axi\_dmac to perform a DMA transaction, it communicates this request by sending an interrupt to the CPU or interrupt controller. The interrupt service routine then uses the software handshaking registers to initiate and control a DMA transaction. A group of software registers is used to implement the software handshaking interface. The HS\_SEL\_SRC/HS\_SEL\_DST bit in the channel configuration register CHx\_CFG must be set to enable software handshaking.

The following registers are used for software handshaking:

- CHx\_SWHSSrcReg – Software Handshake Register for Source of Channel x
- CHx\_SWHSDstReg – Software Handshake Register for Destination of Channel x

DW\_axi\_dmac clears the active request bits in SWHSSrcReg to 0 when the corresponding source transaction is completed. Similarly, active request bits in SWHSDstReg are cleared to 0 when the destination transaction is completed.



**Note** The functionality of the software handshaking register bits are same as that of the corresponding hardware handshaking signals except that there are no register fields corresponding to dma\_ack and dma\_finish signals.

### Suspension of Transfer While Using Software Handshaking

If software handshaking is used for a source and/or destination peripheral, the DMA transfer automatically stalls after completion of the requested source and/or destination transaction. The DW\_axi\_dmac does not proceed with the transfer until the hardware detects that software has set CHx\_SWHSSrcReg.SWHS\_SglReq\_Src and/or CHx\_SWHSDstReg.SWHS\_SglReq\_Dst bit to 1.

## 2.11 Flow Control Configurations

The transfer type and flow control configurations are decided by the value of the TT\_FC field in the CHx\_CFG register, which is programmable for a particular DMA transfer.

Figure 2-31 indicates different flow control configurations using hardware handshaking interfaces (a simplified version of the interface is shown). These scenarios can also be used for software handshaking, which uses software registers instead of hardware signals.



**Figure 2-31 DW\_axi\_dmac Flow Control Configuration**

## 2.12 Early Terminated Burst Transaction

When a source or destination peripheral is in the single transaction region, a burst transaction can still be requested. However, in this case, `src_burst_size_bytes` or `dst_burst_size_bytes` is greater than the number of bytes left to complete the source or destination block transfer at the time the burst transaction is triggered. In this case, the burst transaction is started and “early-terminated” at block completion without transferring the programmed amount of data. Only the amount of data required to complete the block transfer is transferred.

An early terminated burst transaction occurs only when the peripheral is not the flow controller.

- If the source peripheral is the flow controller and it does not have enough data for a burst transfer towards the end of a transaction, it asserts `dma_single` until it signals the last transaction by asserting `dma_last` along with `dma_single`. (The destination peripheral might enter the single transaction region at this point.)
- If the destination peripheral is in the single transaction region and the destination peripheral still requests a burst transaction by asserting `dma_req`, then DW\_axi\_dmac starts a burst transaction and early terminates it at block completion without transferring the programmed amount (`CHx_CTL.DST_MSIZE`) of data.
- If the destination peripheral is the flow controller and it does not have enough data for a burst transfer towards the end of transaction, it asserts `dma_single` until it signals the last transaction by asserting `dma_last` along with `dma_single`. (The source peripheral might enter the single transaction region at this point.)
- If the source peripheral is in the single transaction region and the source peripheral still requests a burst transaction by asserting `dma_req`, then DW\_axi\_dmac starts a burst transaction and early terminates it at block completion without transferring the programmed amount (`CHx_CTL.SRC_MSIZE`) of data.



**Note** When the destination peripheral is the flow controller, there can be data loss if the following conditions are met:

- $\text{CHx_CTL.SRC\_TR\_WIDTH} > \text{CHx_CTL.DST\_TR\_WIDTH}$
- $\text{blk\_size\_bytes\_dst/src\_single\_size\_bytes} \neq \text{integer}$

The amount of data lost is:

$\text{src\_single\_size\_bytes} - \text{dst\_single\_size\_bytes}$

## 2.13 Transfer Control

Transfer control logic facilitates the data transfer from a source peripheral of the channel to the destination peripheral. It interacts with multiple other modules, such as the channel source and destination state machine, linked list control logic, channel registers, channel FIFO control logic and so on.

Data from the source peripheral is temporarily stored in the channel FIFO before being sent to the destination peripheral. DW\_axi\_dmac implements the logic needed to pack and unpack data to fit the FIFO configuration, if source and destination peripherals use different transfer size (arsize, awsize) for data transfer.

### 2.13.1 Single Block Transfer

If a DMA transfer consists of a single block, the software sets the multi-block type bits of both source and destination peripherals in the CHx\_CFG register to 2'b00. In this case, the DW\_axi\_dmac disables the channel once the block transfer corresponding to the block length programmed in CHx\_BLOCK\_TS register is completed.

The CHx\_IntStatusReg register is updated with the status corresponding to the completed block transfer. The CHx\_IntStatusReg register is updated based on the settings of the CHx\_IntMaskReg register and interrupts are generated based on the settings of the CHx\_IntMaskReg, DMAC\_IntMaskReg, and DMAC\_CfgReg registers.

### 2.13.2 Multiblock Transfer

If DW\_axi\_dmac is programmed for multiblock transfers, the CHx\_SAR and CHx\_DAR registers are reprogrammed using either of the following methods on successive blocks of a multiblock transfer:

- Contiguous Address
- Auto Reloading
- Shadow Register
- Linked List

The CHx\_CTL and CHx\_BLOCK\_TS registers are reprogrammed using either of the following methods on successive blocks of a multiblock transfer:

- Auto Reloading
- Shadow Register
- Linked List

The CHx\_IntStatusReg register is updated with the status corresponding to the completed block transfer. The CHx\_IntStatusReg register is updated based on the settings of the CHx\_IntMaskReg and interrupts are generated based on the settings of the CHx\_IntMaskReg, DMAC\_IntMaskReg, and DMAC\_CfgReg registers.



- If the coreConsultant parameter DMAx\_CHx\_MULTI\_BLK\_EN is set to 0, the logic for multiblock transfer is disabled and only single block transfers are allowed.
- If a multiblock transfer is enabled, there must be at least two blocks in the complete DMA transfer for Contiguous Address and Auto-Reloading-based multiblock transfers. Otherwise, it will result in unpredictable behavior.

The register update method for multiblock transfers depends on the value of the multiblock type bits in the CHx\_CFG register. All possible combinations of the multiblock register update methods are captured in the following table.

**Table 2-4 Register Update Methods for Multiblock Transfer**

| DMAx_CHx_MULTI_BLK_EN | SRC_MLTBLK_TYPE | DST_MLTBLK_TYPE | Register Update Method      |                             |                             |                             | Multiblock Transfer Type (MLTBLK_TFR_TYPE) | Remarks                                  |
|-----------------------|-----------------|-----------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|--------------------------------------------|------------------------------------------|
|                       |                 |                 | CHx_SAR                     | CHx_DAR                     | CHx_CTL                     | CHx_BLOCK_TS                |                                            |                                          |
| 0                     | X X             | X X             | No update                   | No update                   | No update                   | No update                   | -                                          | Single block                             |
| 1                     | 0 0             | 0 0             | No update                   | No update                   | No update                   | No update                   | -                                          | Single block or last block of multiblock |
| 1                     | 0 0             | 0 1             | Contiguous                  | Reloaded from initial value | Reloaded from initial value | Reloaded from initial value | 1                                          | -                                        |
| 1                     | 0 0             | 1 0             | Contiguous                  | Loaded from shadow register | Loaded from shadow register | Loaded from shadow register | 2                                          |                                          |
| 1                     | 0 1             | 0 0             | Reloaded from initial value | Contiguous                  | Reloaded from initial value | Reloaded from initial value | 3                                          | -                                        |
| 1                     | 0 1             | 0 1             | Reloaded from initial value | 4                                          | -                                        |
| 1                     | 0 1             | 1 0             | Reloaded from initial value | Loaded from shadow register | Loaded from shadow register | Loaded from shadow register | 5                                          | -                                        |
| 1                     | 1 0             | 0 0             | Loaded from shadow register | Contiguous                  | Loaded from shadow register | Loaded from shadow register | 6                                          | -                                        |
| 1                     | 1 0             | 0 1             | Loaded from shadow register | Reloaded from initial value | Loaded from shadow register | Loaded from shadow register | 7                                          | -                                        |
| 1                     | 1 0             | 1 0             | Loaded from shadow register | 8                                          | -                                        |
| 1                     | 0 0             | 1 1             | Contiguous                  | Loaded from next LLI        | Loaded from next LLI        | Loaded from next LLI        | 9                                          | -                                        |
| 1                     | 0 1             | 1 1             | Reloaded from initial value | Loaded from next LLI        | Loaded from next LLI        | Loaded from next LLI        | 10                                         | -                                        |
| 1                     | 1 1             | 0 0             | Loaded from next LLI        | Contiguous                  | Loaded from next LLI        | Loaded from next LLI        | 11                                         | -                                        |

**Table 2-4 Register Update Methods for Multiblock Transfer (Continued)**

| DMAx_CHx_MULTI_BLK_EN | Multiblock Type Bits in CHx_CFG Register | Register Update Method |                             |                             |                      |                      |              | Multiblock Transfer Type (MLTBLK_TFR_TYPE)                             | Remarks |
|-----------------------|------------------------------------------|------------------------|-----------------------------|-----------------------------|----------------------|----------------------|--------------|------------------------------------------------------------------------|---------|
|                       |                                          | SRC_MLTBLK_TYPE        | DST_MLTBLK_TYPE             | CHx_SAR                     | CHx_DAR              | CHx_CTL              | CHx_BLOCK_TS |                                                                        |         |
| 1                     | 1 1                                      | 0 1                    | Loaded from next LLI        | Reloaded from initial value | Loaded from next LLI | Loaded from next LLI | 12           | -                                                                      |         |
| 1                     | 1 1                                      | 1 1                    | Loaded from next LLI        | Loaded from next LLI        | Loaded from next LLI | Loaded from next LLI | 13           | -                                                                      |         |
| 1                     | 1 0                                      | 1 1                    | Loaded from shadow register | Loaded from next LLI        | Loaded from next LLI | Loaded from next LLI | -            | Invalid programming.<br>SLVIF_MultiBlkType_ER R interrupt is generated |         |
| 1                     | 1 1                                      | 1 0                    | Loaded from next LLI        | Loaded from shadow register | Loaded from next LLI | Loaded from next LLI | -            | Invalid programming.<br>SLVIF_MultiBlkType_ER R interrupt is generated |         |

### 2.13.2.1 Contiguous Address

In this case, the address between successive blocks is selected as a continuation from the end of the previous block. Enabling the source or destination address to be contiguous between blocks is a function of CHx\_CTL.SRC\_MLTBLK\_TYPE and CHx\_CTL.DST\_MLTBLK\_TYPE register fields.

CHx\_SAR and CHx\_DAR updates cannot be selected to be contiguous at the same time. If required, this functionality can be achieved indirectly, by using linked lists. To do this, set up the LLI.CHx\_SAR address of the next block descriptor to be one greater than the end address of the previous block. Similarly, set up the LLI.CHx\_DAR address of the next block descriptor to be one greater than the end address of the previous block.



If a Contiguous-Address-based multiblock transfer is enabled, there must be at least two blocks in the complete DMA transfer. Otherwise, it will result in unpredictable behavior.

### 2.13.2.2 Auto Reloading

In this case, the channel transfer control registers are reloaded with their initial values at the completion of each block and these values are used for the new block. Some or all of the CHx\_SAR, CHx\_DAR, CHx\_BLOCK\_TS, and CHx\_CTL channel registers are reloaded from their initial value at the start of a new block transfer, depending on the multi-block transfer type selected for source and destination peripherals.

The DW\_axi\_dmac does not proceed to the next block transfer until software clears the corresponding channel's block transfer complete interrupt by writing 1 to the corresponding bit in the DMAC\_IntClear\_Reg register if this interrupt is not masked off.



**Note** If Auto-Reloading-based multi-block transfer is enabled, there should be at least 2 blocks in the complete DMA transfer. Otherwise, it will result in unpredictable behavior.

### 2.13.2.3 Shadow Register

In this case, the channel transfer control registers are loaded from their corresponding shadow registers at the completion of each block and these values are used for the new block. Some or all of the CHx\_SAR, CHx\_DAR, CHx\_BLOCK\_TS, and CHx\_CTL channel registers are loaded from their corresponding shadow registers at the start of a new block transfer, depending on the multiblock transfer type selected for source and destination peripherals.

A separate memory map is not defined for the shadow register access. Software always writes to the CHx\_SAR, CHx\_DAR, CHx\_BLOCK\_TS, and CHx\_CTL registers irrespective of the type of multiblock transfer used. If a shadow-register-based multiblock transfer is used for a source or destination transfer, DW\_axi\_dmac internally routes the data to the corresponding shadow registers. DW\_axi\_dmac copies the shadow register contents to CHx\_SAR, CHx\_DAR, CHx\_BLOCK\_TS, and CHx\_CTL registers before starting a new block transfer.

Read operations to the CHx\_SAR, CHx\_DAR, CHx\_BLOCK\_TS, and CHx\_CTL registers always return the data corresponding to the current block transfer and not the shadow register contents (which corresponds to the next block).

For shadow-register-based multiblock transfer, the ShadowReg\_Or\_LLI\_Valid bit in the CHx\_CTL register indicates whether the shadow register contents are valid or not. Zero indicates that the shadow register contents are invalid, while 1 indicates that the shadow register contents are valid. If this bit is read as zero during a shadow register fetch phase, DW\_axi\_dmac discards the shadow register contents and generates a ShadowReg\_Or\_LLI\_Invalid\_ERR interrupt. DW\_axi\_dmac waits until the software writes any value to the CHx\_BLK\_TFR\_ResumeReqReg register to indicate valid shadow register availability, before attempting another shadow register fetch operation to continue the next block transfer.



**Note** If the coreConsultant parameter DMAx\_CHx\_SHADOW\_REG\_EN is set to 0, shadow-register-based multi-block transfer is disabled and only other methods of multi-block transfers are allowed.

For more information about programming the Shadow Register, see “[Programming Flow for Shadow-Register-Based Multi-Block Transfer](#)” on page [467](#).

#### 2.13.2.4 Linked List

In this case, the DW\_axi\_dmac reprograms the channel transfer control registers prior to the start of each block, by fetching the block descriptor for that block from system memory. This is known as an LLI update. DW\_axi\_dmac block chaining uses a linked list pointer register (CHx\_LL\_P) to store the address in memory of the next linked list item. Each LLI contains the following block descriptors:

- CHx\_SAR
- CHx\_DAR
- CHx\_BLOCK\_TS
- CHx\_CTL
- CHx\_LL\_P

To set up block chaining, a sequence of linked lists should be programmed in memory. DW\_axi\_dmac allows dynamic extension of linked lists, which eliminates the need for creating the entire linked list in the system memory in advance. The CHx\_CTL.ShadowReg\_Or\_LLI\_Valid and CHx\_CTL.LLI\_Last fields of the LLI are used to achieve this functionality.

For linked-list-based multi-block transfers, the ShadowReg\_Or\_LLI\_Valid bit of the LLI.CHx\_CTL register indicates whether the linked list item fetched from the memory is valid or not. If this bit is set to 0, it indicates the LLI is invalid, while 1 indicates the LLI is valid. If the LLI is invalid, DW\_axi\_dmac discards the LLI and generates an LLI Error interrupt (if the corresponding channel error interrupt mask bit is set to 0). This error condition causes the DW\_axi\_dmac to halt the corresponding channel gracefully.

DW\_axi\_dmac waits till software writes any value to the CHx\_BLK\_TFR\_ResumeReqReg register to indicate the availability of a valid LLI, before attempting another LLI read operation.



**Note** In the case of LLI pre-fetching, the ShadowReg\_Or\_LLI\_Invalid\_ERR interrupt is not generated even if the ShadowReg\_Or\_LLI\_Valid bit is set to 0 for the pre-fetched LLI. In this case, DW\_axi\_dmac re-attempts the LLI fetch operation after completing the current block transfer. DW\_axi\_dmac generates a ShadowReg\_Or\_LLI\_Invalid\_ERR interrupt only if the ShadowReg\_Or\_LLI\_Valid bit is still set to 0.

LLI access always uses a burst size (arsize or awsize) that is the same as the data bus width and cannot be changed or programmed to anything other than this. Burst length (awlen or arlen) is chosen based on the data bus width so that the access does not cross one complete LLI structure of 64 bytes. DW\_axi\_dmac fetches the entire LLI (40 bytes) in one AXI burst, if the burst length is not limited by other setting.

If the status write back option is enabled, DW\_axi\_dmac writes back CHx\_CTL, CHx\_LL\_P\_STATUS, CHx\_SSTAT, and CHx\_DSTAT information to the location defined for this field, which is from address [CHx\_LL\_P] + 0x20 to [CHx\_LL\_P] + 0x34. The CHx\_SSTAT and CHx\_DSTAT write back can be independently enabled or disabled in coreConsultant and by programming the corresponding field in the

CHx\_CTL register. If CHx\_SSTAT and/or CHx\_DSTAT write back is not enabled, DW\_axi\_dmac de-asserts the write data strobes corresponding to these write operations.



- CHx\_LL\_P\_STATUS[63] and CHx\_LL\_P\_STATUS[62] indicates DMA\_TFR\_DONE and BLOCK\_TFR\_DONE status respectively and these are the last fields to be updated during LLI write-back. Software should wait until BLOCK\_TFR\_DONE bit is set to 1 before reading CHx\_SSTAT and CHx\_DSTAT information. DMA\_TFR\_DONE bit will be set to 1 along with BLOCK\_TFR\_DONE bit after transferring the last block in DMA transfer.
- LLI.CHx\_CTL.ShadowReg\_Or\_LLI\_Valid bit will be 0 after the LLI write-back operation.

**Figure 2-32 DW\_axi\_dmac Linked List Item (Descriptor)**

|      |    |                                        |   |
|------|----|----------------------------------------|---|
| 0x3C | 31 | Reserved                               | 0 |
| 0x38 | 31 | Reserved                               | 0 |
| 0x34 | 31 | CHx_LL_P_STATUS [63:32]                | 0 |
| 0x30 | 31 | CHx_LL_P_STATUS [31:0]                 | 0 |
| 0x2C | 31 | Write back for CHx_DSTAT               | 0 |
| 0x28 | 31 | Write back for CHx_SSTAT               | 0 |
| 0x24 | 31 | CHx_CTL [63:32]                        | 0 |
| 0x20 | 31 | CHx_CTL [31:0]                         | 0 |
| 0x1C | 31 | CHx_LL [63:32]                         | 0 |
| 0x18 | 31 | CHx_LL [31:5]      6   5      Reserved | 0 |
| 0x14 | 31 | Reserved                               | 0 |
| 0x10 | 31 | CHx_BLOCK_TS [31:0]                    | 0 |
| 0x0C | 31 | CHx_DAR [63:32]                        | 0 |
| 0x08 | 31 | CHx_DAR [31:0]                         | 0 |
| 0x04 | 31 | CHx_SAR [63:32]                        | 0 |
| 0x00 | 31 | CHx_SAR [31:0]                         | 0 |

**Figure 2-33 CHx\_LL\_P\_STATUS Write-Back Field of LLI**

| 63                                      | 62 61    | 47 46                                            | 32 31    | 22 21                                               | 0 |
|-----------------------------------------|----------|--------------------------------------------------|----------|-----------------------------------------------------|---|
| Status Indication<br>CHx_IntStatus[1:0] | Reserved | Data left in Channel FIFO<br>(CHx_Status[46:32]) | Reserved | Completed Block Transfer Size<br>(CHx_Status[21:0]) |   |

For more information about programming linked-list-based multi-block transfers, see “[Programming Flow for Linked-List-Based Multi-Bock Transfer](#)” on page [470](#).

### 2.13.2.5 Suspension of Transfers Between Blocks

At the end of every block transfer, a Block Transfer Done Interrupt is asserted if:

- Global Interrupt is enabled (DMAC\_CfgReg.INT\_EN = 1)
- The channel block transfer completion interrupt is enabled  
(CHx\_InStatus\_EnableReg.Enable\_BLOCK\_TFR\_DONE\_IntStat = 1 AND  
CHx\_IntSignal\_EnableReg.Enable\_BLOCK\_TFR\_DONE\_IntSignal = 1 AND  
CHx\_CTL.IOC\_BLKTFR = 1)

For Contiguous Address and Auto-Reloading-based multiblock transfers (neither source nor destination peripheral uses Shadow Register or Linked-List-based multiblock transfers), the DMA transfer automatically stalls after the Block Transfer Done Interrupt is asserted, if the Block Transfer Done Interrupt is enabled and unmasked. The DW\_axi\_dmac does not proceed to the next block transfer until a write to the appropriate field in CHx\_IntClearReg register, done by software to clear the channel Block Transfer Done Interrupt, is detected by hardware.

Channel suspension between blocks is used to ensure that the Block Transfer Done ISR (Interrupt Service Routine) of the next-to-last block is serviced before the start of the final block commences. This ensures that the ISR has cleared the CHx\_CFG.SRC\_MLTBLK\_TYPE and/or CHx\_CFG.DST\_MLTBLK\_TYPE bits before completion of the final block. The CHx\_CFG.SRC\_MLTBLK\_TYPE and/or CHx\_CFG.DST\_MLTBLK\_TYPE bits should be cleared in the Block Transfer Done ISR for the next-to-last block transfer.

### 2.13.2.6 End of Multi-Block Transfers

If either source or destination peripheral uses Shadow Register or Linked-List-based multi-block transfers, the corresponding last block indication bit, ShadowReg\_Or\_LLI\_Last, in the CHx\_CTL\_ShadowReg / LLI.CHx\_CTL register indicates whether the current block is the last block in the transfer or not. If this bit is set to 1 for the current block, the DW\_axi\_dmac understands that the current block is the final block in the transfer and completes the DMA transfer operation at the end of current block transfer.

For Contiguous Address and Auto-Reloading-based multiblock transfers (if neither source nor destination peripheral uses Shadow Register or Linked-List-based multi-block transfers), if the corresponding multi-block type selection bits namely CHx\_CFG.SRC\_MLTBLK\_TYPE and/or CHx\_CFG.DST\_MLTBLK\_TYPE bits are 2'b00 at the end of a block transfer, the DW\_axi\_dmac understands that the previous block was the final block in the transfer and completes the DMA transfer operation.

## 2.14 AXI Unaligned Transfer Support

The DW\_axi\_dmac supports the generation of unaligned DMA transfers on the AXI master interfaces. This feature can be enabled through a configurable parameter DMAX\_UNALIGNED\_XFER\_EN.

The DW\_axi\_dmac component supports backward compatibility in such a way that even if this feature is not required, the old drivers and register programming works without any change.

### 2.14.1 Description of AXI Unaligned Transfers

The unaligned memory accesses are common in the AXI-based systems, where the memory access address is not aligned to the natural boundary of the transfer width. The DW\_axi\_dmac supports the generation of the unaligned memory DMA transfers on the AXI master interface. This feature support eliminates the following restrictions for the memory accesses:

- **Source AXI data transfers** - SAR addresses must align to the source transfer width that is CHx\_CTL.SRC\_TR\_WIDTH (AXI bus arsize)
- **Destination AXI data transfers** - DAR addresses must align to the destination transfer width that is CHx\_CTL.DST\_TR\_WIDTH (AXI bus awsize)

Thus, user can program CHx\_SAR and CHx\_DAR registers with any address, and it can be unaligned or aligned to the source or destination transfer width for memory accesses. The unaligned access is supported for combinations of CHx\_CFG.TT\_FC where the memory access is involved (MEM\_TO\_PER\_DMPC, PER\_TO\_MEM\_DMPC, PER\_TO\_MEM\_SRC, MEM\_TO\_PER\_DST).

DW\_axi\_dmac handles the packing and the unpacking of the data considering the unaligned offset at both source and destination transfers. The data received from the unaligned source transaction is packed to align with FIFO width, and then it is stored in the FIFO. At the destination end, the data is read from the FIFO and unpacked based on the CHx\_DAR register and destination transfer width. The invalid bytes of the destination transfer are invalidated by driving the respective write strobes to 0. The following section provides more details about unaligned transfer based on DMA, source, or destination as a flow controller.

#### 2.14.1.1 DW\_axi\_dmac as a Flow Controller

The definition of the CHx\_BLOCK\_TS register remains the same that is the number programmed into BLOCK\_TS field indicates the total number of data width CHx\_CTL.SRC\_TR\_WIDTH to be transferred in a DMA block transfer. If the source address is unaligned, then the unaligned bytes in the source are considered to derive at the total bytes transferred in a DMA block transfer.

The equation to calculate the total number of valid bytes transferred in a block for an unaligned transfer is as follows:

`blk_size_bytes_dma_u = (CHx_BLOCK_TS.BLOCK_TS * src_single_size_bytes) - Source Unaligned bytes`

- The DW\_axi\_dmac fetches the blk\_size\_bytes\_dma\_u bytes of data from the source and transfers all bytes to the destination based on the CHx\_DAR register.
- The destination unaligned bytes does not increase or decrease the valid number of bytes transferred in a DMA block. Only the source unaligned bytes affect the total number of bytes transferred in a DMA block.
- The unaligned transfer is supported for combinations of Transfer Type and Flow Controller wherever memory is involved (MEM\_TO\_MEM\_DMPC, MEM\_TO\_PER\_DMPC, PER\_TO\_MEM\_DMPC).
- When Multi Block Type is contiguous for either source or destination, initial address of the subsequent block is computed as below (Unaligned nature of the SAR/DAR also result in subsequent block initial address to be unaligned):
  - **Source Contiguous:** Next CHx\_SAR = Current CHx\_SAR + blk\_size\_bytes\_dma\_u
  - **Destination Contiguous:** Next CHx\_DAR = Current CHx\_DAR + blk\_size\_bytes\_dma\_u + Destination Unaligned bytes

#### 2.14.1.2 Source is the Flow Controller

The equation to calculate the total number of valid bytes transferred in a block transfer for an unaligned transfer is as follows:

$\text{blk\_size\_bytes\_src\_u} = (\text{Number of source burst transactions in block} * \text{src\_burst\_size\_bytes}) + (\text{Number of source single transactions in block} * \text{src\_single\_size\_bytes}) - \text{Source Unaligned bytes}$

- The DW\_axi\_dmac fetches the blk\_size\_bytes\_src\_u bytes of data from the source and transfers all bytes to the destination based on the CHx\_DAR register.
- The destination unaligned bytes does not increase or decrease the valid number of bytes transferred in DMA block. Only the source unaligned bytes affect the total number of bytes transferred in a DMA block.
- The unaligned transfer is supported for combinations of Transfer Type and Flow Controller wherever a memory is involved - PER\_TO\_MEM\_SRC, when the source is the Flow Controller.
- When Multi Block Type is Contiguous for either source or destination, initial address the subsequent block is computed as below (Unaligned nature of the SAR/DAR also results in sub-sequent block initial address to be unaligned):
  - **Source Contiguous:** Next CHx\_SAR = Current CHx\_SAR + blk\_size\_bytes\_src\_u
  - **Destination Contiguous:** Next CHx\_DAR = Current CHx\_DAR + blk\_size\_bytes\_src\_u + Destination Unaligned bytes

#### 2.14.1.3 Destination is the Flow Controller

The equation to calculate the total number of valid bytes transferred in a block transfer for an unaligned transfer is as follows:

$\text{blk\_size\_bytes\_dst\_u} = (\text{Number of destination burst transactions in block} * \text{dst\_burst\_size\_bytes}) + (\text{Number of destination single transactions in block} * \text{dst\_single\_size\_bytes}) - \text{Destination Unaligned bytes}$

- The DW\_axi\_dmac always provides the blk\_size\_bytes\_dst\_u bytes of data to the destination.
- If source address is unaligned, then DW\_axi\_dmac fetches an additional src\_single\_size\_bytes to compensate the source unaligned bytes and to provide blk\_size\_bytes\_dst\_u bytes to the destination for a block.
  - Along with that, in few scenarios when destination is unaligned, then DW\_axi\_dmac fetches  $\text{ceil}(\text{Destination Unaligned bytes}/\text{src\_single\_size\_bytes})$  amount of additional data from the source.
  - For example, if CHx\_CTL.SRC\_TR\_WIDTH = 64 bit, CHx\_CTL.DST\_TR\_WIDTH = 64 bit, CHx\_CFG.TT\_FC = MEM\_TO\_PER\_DST, CHx\_CTL.DST\_MSIZE = 16 data items, CHx\_SAR = 0x1007 (source is unaligned), and CHx\_DAR = 0xF008 (destination is aligned).
    - Number of bytes to be fetched from Source for a destination request (DST\_REQ\_DATA)
 
$$\begin{aligned} &= \text{CHx\_CTL.DST\_MSIZE} * \text{CHx\_CTL.DST\_TR\_WIDTH} \\ &= 16 * 8 \\ &= 128 \text{ bytes} \end{aligned}$$
    - Data can be fetched from the source for the first destination request
 
$$\begin{aligned} &= (\text{DST\_REQ\_DATA}/\text{CHx\_CTL.SRC\_TR\_WIDTH}) * \text{CHx\_CTL.SRC\_TR\_WIDTH} - \text{source unaligned bytes} \\ &= (128/8) * 8 - 7 \\ &= 121 \text{ bytes} \end{aligned}$$

From the previous example, source needs to fetch 7 more bytes of data for the first destination request - because of the unaligned source transfer. Hence, DW\_axi\_dmac fetches an additional src\_single\_size\_bytes (CHx\_CTL.SRC\_TR\_WIDTH) of data to compensate unaligned bytes.

- The unaligned transfer is supported for combinations of Transfer Type and Flow Controller wherever a memory is involved - MEM\_TO\_PER\_DST, when Destination is the Flow Controller.
- When Multi Block Type is Contiguous for either source or destination, initial address the subsequent block is computed based on the following formula (Unaligned nature of the SAR/DAR also result in subsequent block initial address to be unaligned):
  - **Source Contiguous:** Next CHx\_SAR = Current CHx\_SAR (Aligned) + blk\_size\_bytes\_dst\_u + Source Unaligned bytes
  - **Destination Contiguous:** Next CHx\_DAR = Current CHx\_DAR + blk\_size\_bytes\_dst\_u

## 2.14.2 AXI Unaligned Transfer Examples

Following examples explain how the unaligned transfers on the source and destination are handled, with the different configuration and programming options.

- Configuration parameters:
  - DMAx\_M\_DATA\_WIDTH - AXI Master interface data bus width.
  - DMAx\_CH(x)\_FIFO\_WIDTH (internal parameter) - channel x FIFO width, function of (DMAx\_M\_DATA\_WIDTH, DMAx\_CHx\_STW, DMAx\_CHx\_DTW).
  - DMAx\_STATIC\_ENDIAN\_SELECT\_MSTIF and DMAx\_ENDIAN\_FORMAT\_MSTIF – endianness selection
- Programming registers:
  - CHx\_SAR - Source Address Register of DMA transfer
  - CHx\_DAR – Destination Address Register of DMA transfer
  - CHx\_CTL.SRC\_MSIZE – Source Burst Transaction Length. Each of width CHx\_CTL.SRC\_TR\_WIDTH
  - CHx\_CTL.DST\_MSIZE – Destination Burst Transaction Length. Each of width CHx\_CTL.DST\_TR\_WIDTH
  - CHx\_CTL.SRC\_TR\_WIDTH - Source Transfer Width (arsize).
  - CHx\_CTL.DST\_TR\_WIDTH - Destination Transfer Width (awsze).
  - CHx\_CFG.TT\_FC – Transfer Type and Flow Control.

### Assumptions

In the following examples, it is assumed that,

- Each row of the DMA burst/single transaction can be accomplished either through a single AXI transfer or a burst transfer based on the DMAx\_CHx\_MAX\_AMBA\_BURST\_LENGTH and CHx\_CTL.ARLEN/CHx\_CTL.AWLEN.
- The unaligned transfers shown in these examples are only the DMA Burst/Single transactions corresponding to a particular block. The whole DMA transfers may have multiple blocks.

- The default endianness is from little-endian to little-endian unless it is explicitly specified otherwise.
- For information on the number of bytes transferred in a DMA transfer, see the section “[AXI Unaligned Transfer Support](#)” on page [69](#).

## Conventions

Following are the conventions used for the bytes of the DMA transfer.

---

|                                                                                   |                                                                                |
|-----------------------------------------------------------------------------------|--------------------------------------------------------------------------------|
|  | Invalid byte of the AXI DMA Transfer                                           |
|  | Valid byte of the DMA transfer with N as the byte address for source transfers |

---



If the source and/or destination transfers are unaligned, then AXI burst type must be INCR for both source and destination transfers (CHx\_CTL.SINC/DINC to be programmed as 0). In this case, burst type cannot be programmed to FIXED for both source and destination. At the system level FIXED unaligned transfer support is not required because of the following reasons:

- FIXED transfers are directed to the FIFOs. But these FIFOs does not have strobe signals to selectively write the bytes.
- Unaligned FIXED transfer has deep impact on the system bandwidth utilization, and hence the system performance.

For example, if the source transfer width is 512 and the source is unaligned by 63. Then each of the AXI beat received has only one byte. This results in major impact on the bandwidth utilization.

### 2.14.2.1 Example 1

Assume that,

- the source address is unaligned to the source transfer width
- the destination address is unaligned to the destination transfer width

Table [Table 2-5](#) describes all major DMA parameter settings considered for this example.

**Table 2-5 Example 1 - Configuration and Programming Options**

| Configuration/Programming      | Value | Description |
|--------------------------------|-------|-------------|
| <b>Configuration Parameter</b> |       |             |
| DMAX_M_DATA_WIDTH              | 64    | 64 bit      |
| DMAX_CH(x)_FIFO_WIDTH          | 64    | 64 bit      |
| <b>Programming Register</b>    |       |             |

**Table 2-5 Example 1 - Configuration and Programming Options**

| Configuration/Programming | Value  | Description                              |
|---------------------------|--------|------------------------------------------|
| CHx_SAR                   | 0x0001 | Unaligned source address                 |
| CHx_DAR                   | 0x9007 | Unaligned destination address            |
| CHx_CTL.SRC_MSIZE         | 3b001  | Source burst transaction length = 4      |
| CHx_CTL.DST_MSIZE         | 3b001  | Destination burst transaction length = 4 |
| CHx_CTL.SRC_TR_WIDTH      | 0x3    | Source Transfer Width is 64 bits         |
| CHx_CTL.DST_TR_WIDTH      | 0x3    | Destination Transfer Width is 64 bits    |

**Figure 2-34 Example 1 - Unaligned DMA Transfer Handling**

In this example, the single source burst transaction gets converted to multiple burst/single transaction - even though the following programming options remain the same:

- Source and destination transaction length
- Source and destination transfer widths are same

This is due to the unaligned source address. [Figure 2-35](#) shows the source transfer where the source address 0x0001 is unaligned. This unaligned source transfer has 4 beats, with the AWSIZE of 3 that is 8 bytes. In the first data beat received, the least significant byte is ignored as the address is unaligned with one byte. All other bytes are packed into FIFO as shown in [Figure 2-34](#).

**Figure 2-35 Example 1 - Unaligned Source Transfer Waveform**

Figure 2-36 shows the destination transfer where the destination address is unaligned - 0x9007. This unaligned destination transfer has 5 beats, with the AWSIZE of 3 that is 8 bytes. In the first write data beat generated, only the most significant data byte is valid as the address is unaligned with 7 bytes, and the write strobe is asserted as 0x80 (as only most significant byte is valid). For all the other write data beats, write strobe is asserted as 0xFF as all bytes are valid - except for the last write data beat. For the last write data beat, only lower 6 data bytes are valid and the other two bytes are invalid - hence strobe is asserted as 0x3F.

**Figure 2-36 Example 1 - Unaligned Destination Transfer Waveform**

### 2.14.2.2 Example 2

Assume that

- the source address is unaligned to source transfer width
- destination address is aligned to the destination transfer width

[Table 2-6](#) describes all major DMA parameter settings considered for this example.

**Table 2-6 Example 2 - Configuration and Programming Options**

| Configuration/Programming      | Value | Description |
|--------------------------------|-------|-------------|
| <b>Configuration Parameter</b> |       |             |
| DMAX_M_DATA_WIDTH              | 64    | 64 bit      |
| DMAX_CH(x)_FIFO_WIDTH          | 64    | 64 bit      |
| <b>Programming Register</b>    |       |             |

**Table 2-6 Example 2 - Configuration and Programming Options**

| Configuration/Programming | Value  | Description                              |
|---------------------------|--------|------------------------------------------|
| CHx_SAR                   | 0x0007 | Unaligned source address                 |
| CHx_DAR                   | 0x9008 | Aligned destination address              |
| CHx_CTL.SRC_MSIZE         | 3b001  | Source burst transaction length = 4      |
| CHx_CTL.DST_MSIZE         | 3b001  | Destination burst transaction length = 4 |
| CHx_CTL.SRC_TR_WIDTH      | 0x3    | Source Transfer Width is 64 bits         |
| CHx_CTL.DST_TR_WIDTH      | 0x3    | Destination Transfer Width is 64 bits    |

**Figure 2-37 Example 2 - Unaligned DMA Transfer Handling**

### 2.14.2.3 Example 3

Assume that,

- the source address is aligned to source transfer width
- destination address is unaligned to the destination transfer width

Table [Table 2-7](#) describes all major DMA parameter settings considered for this example.

**Table 2-7 Example 3 - Configuration and Programming Options**

| Configuration/Programming      | Value  | Description                              |
|--------------------------------|--------|------------------------------------------|
| <b>Configuration Parameter</b> |        |                                          |
| DMAX_M_DATA_WIDTH              | 64     | 64 bit                                   |
| DMAX_CH(x)_FIFO_WIDTH          | 64     | 64 bit                                   |
| <b>Programming Register</b>    |        |                                          |
| CHx_SAR                        | 0x0000 | Aligned source address                   |
| CHx_DAR                        | 0x9005 | Unaligned destination address            |
| CHx_CTL.SRC_MSIZE              | 3b001  | Source burst transaction length = 4      |
| CHx_CTL.DST_MSIZE              | 3b001  | Destination burst transaction length = 4 |

**Table 2-7 Example 3 - Configuration and Programming Options**

| Configuration/Programming | Value | Description                           |
|---------------------------|-------|---------------------------------------|
| CHx_CTL.SRC_TR_WIDTH      | 0x3   | Source Transfer Width is 64 bits      |
| CHx_CTL.DST_TR_WIDTH      | 0x3   | Destination Transfer Width is 64 bits |

**Figure 2-38 Example 3 - Unaligned DMA Transfer Handling**

#### 2.14.2.4 Example 4

Assume that,

- the source address is unaligned to the source transfer width,
- the destination address is also unaligned to the destination transfer width
- the source transfer width is not the same as the master interface data bus width with multiple source burst/single DMA transactions

Table [Table 2-8](#) describes all major DMA parameter settings considered for this example.

**Table 2-8 Example 4 - Configuration and Programming Options**

| Configuration/Programming      | Value  | Description                              |
|--------------------------------|--------|------------------------------------------|
| <b>Configuration Parameter</b> |        |                                          |
| DMAX_M_DATA_WIDTH              | 64     | 64 bit                                   |
| DMAX_CH(x)_FIFO_WIDTH          | 64     | 64 bit                                   |
| <b>Programming Register</b>    |        |                                          |
| CHx_SAR                        | 0x0003 | Unaligned source address                 |
| CHx_DAR                        | 0x9002 | Unaligned destination address            |
| CHx_CTL.SRC_MSIZE              | 3b001  | Source burst transaction length = 4      |
| CHx_CTL.DST_MSIZE              | 3b001  | Destination burst transaction length = 4 |
| CHx_CTL.SRC_TR_WIDTH           | 0x2    | Source Transfer Width is 32 bits         |

**Table 2-8 Example 4 - Configuration and Programming Options**

| Configuration/Programming | Value | Description                           |
|---------------------------|-------|---------------------------------------|
| CHx_CTL.DST_TR_WIDTH      | 0x3   | Destination Transfer Width is 64 bits |

**Figure 2-39 Example 4 - Unaligned DMA Transfer Handling**

### 2.14.2.5 Example 5

Assume that,

- the source address is unaligned to the source transfer width
- the destination address is also unaligned to the destination transfer width
- the destination transfer width is not the same as the master interface data bus width with multiple destination burst/single DMA transactions

Table Table 2-9 describes all major DMA parameter settings considered for this example.

**Table 2-9 Example 5 - Configuration and Programming Options**

| Configuration/Programming      | Value  | Description              |
|--------------------------------|--------|--------------------------|
| <b>Configuration Parameter</b> |        |                          |
| DMAX_M_DATA_WIDTH              | 64     | 64 bit                   |
| DMAX_CH(x)_FIFO_WIDTH          | 64     | 64 bit                   |
| <b>Programming Register</b>    |        |                          |
| CHx_SAR                        | 0x0006 | Unaligned source address |

**Table 2-9 Example 5 - Configuration and Programming Options**

| Configuration/Programming | Value  | Description                              |
|---------------------------|--------|------------------------------------------|
| CHx_DAR                   | 0x9005 | Unaligned destination address            |
| CHx_CTL.SRC_MSIZE         | 3b001  | Source burst transaction length = 4      |
| CHx_CTL.DST_MSIZE         | 3b001  | Destination burst transaction length = 4 |
| CHx_CTL.SRC_TR_WIDTH      | 0x3    | Source Transfer Width is 64 bits         |
| CHx_CTL.DST_TR_WIDTH      | 0x2    | Destination Transfer Width is 32 bits    |

**Figure 2-40 Example 5 - Unaligned DMA Transfer Handling**



### 2.14.2.6 Example 6

Assume that.

- the source address is unaligned to source transfer width
  - the destination address is also unaligned to the destination transfer width
  - both the source and the destination transfer widths are not the same as the master interface data bus width with multiple source burst/single DMA transactions.

Table 2-10 describes all major DMA parameter settings considered for this example.

**Table 2-10 Example 6 - Configuration and Programming Options**

| Configuration/Programming      | Value | Description |
|--------------------------------|-------|-------------|
| <b>Configuration Parameter</b> |       |             |
| DMAX_M_DATA_WIDTH              | 64    | 64 bit      |

**Table 2-10 Example 6 - Configuration and Programming Options**

| Configuration/Programming   | Value  | Description                              |
|-----------------------------|--------|------------------------------------------|
| DMAX_CH(x)_FIFO_WIDTH       | 64     | 64 bit                                   |
| <b>Programming Register</b> |        |                                          |
| CHx_SAR                     | 0x0003 | Unaligned source address                 |
| CHx_DAR                     | 0x900E | Unaligned destination address            |
| CHx_CTL.SRC_MSIZE           | 3b001  | Source burst transaction length = 4      |
| CHx_CTL.DST_MSIZE           | 3b001  | Destination burst transaction length = 4 |
| CHx_CTL.SRC_TR_WIDTH        | 0x2    | Source Transfer Width is 32 bits         |
| CHx_CTL.DST_TR_WIDTH        | 0x2    | Destination Transfer Width is 32 bits    |

**Figure 2-41 Example 6 - Unaligned DMA Transfer Handling**

### 2.14.2.7 Example 7

Assume that,

- the source address is unaligned to source transfer width
- the destination address is also unaligned to the destination transfer width
- both the source and the destination transfer widths are not the same as the master interface data bus width with multiple source burst/single DMA transactions

Table Table 2-11 describes all major DMA parameter settings considered for this example.

**Table 2-11 Example 7- Configuration and Programming Options**

| Configuration/Programming      | Value  | Description                              |
|--------------------------------|--------|------------------------------------------|
| <b>Configuration Parameter</b> |        |                                          |
| DMAX_M_DATA_WIDTH              | 128    | 128 bit                                  |
| DMAX_CH(x)_FIFO_WIDTH          | 128    | 128 bit                                  |
| <b>Programming Register</b>    |        |                                          |
| CHx_SAR                        | 0x0001 | Unaligned source address                 |
| CHx_DAR                        | 0x900B | Unaligned destination address            |
| CHx_CTL.SRC_MSIZE              | 3b002  | Source burst transaction length = 8      |
| CHx_CTL.DST_MSIZE              | 3b001  | Destination burst transaction length = 4 |
| CHx_CTL.SRC_TR_WIDTH           | 0x2    | Source Transfer Width is 32 bits         |
| CHx_CTL.DST_TR_WIDTH           | 0x3    | Destination Transfer Width is 64 bits    |

**Figure 2-42 Example 7 - Unaligned DMA Transfer Handling**



### 2.14.2.8 Example 8

Assume that,

- the source address is unaligned to the source transfer width
  - the destination address is aligned to destination transfer width
  - the source and the destination endianness is big-endian

Table Table 2-12 describes all major DMA parameter settings considered for this example.

**Table 2-12 Example 8 - Configuration and Programming Options**

| Configuration/Programming      | Value  | Description                              |
|--------------------------------|--------|------------------------------------------|
| <b>Configuration Parameter</b> |        |                                          |
| DMAX_M_DATA_WIDTH              | 64     | 64 bit                                   |
| DMAX_CH(x)_FIFO_WIDTH          | 64     | 64 bit                                   |
| <b>Programming Register</b>    |        |                                          |
| CHx_SAR                        | 0x0001 | Unaligned source address                 |
| CHx_DAR                        | 0x9008 | Aligned destination address              |
| CHx_CTL.SRC_MSIZEx             | 3b001  | Source burst transaction length = 4      |
| CHx_CTL.DST_MSIZEx             | 3b001  | Destination burst transaction length = 4 |
| CHx_CTL.SRC_TR_WIDTH           | 0x3    | Source Transfer Width is 64 bits         |
| CHx_CTL.DST_TR_WIDTH           | 0x3    | Destination Transfer Width is 64 bits    |

**Figure 2-43 Example 8 - Unaligned DMA Transfer Handling**

### 2.14.2.9 Example 9

Assume that,

- the source address is unaligned to the source transfer width
- the destination address is also unaligned to the destination transfer width
- the source and the destination endianness is big-endian

Table [Table 2-13](#) describes all major DMA parameter settings considered for this example.

**Table 2-13 Example 9 - Configuration and Programming Options**

| Configuration/Programming      | Value | Description |
|--------------------------------|-------|-------------|
| <b>Configuration Parameter</b> |       |             |
| DMAX_M_DATA_WIDTH              | 64    | 64 bit      |

**Table 2-13 Example 9 - Configuration and Programming Options**

| Configuration/Programming   | Value  | Description                              |
|-----------------------------|--------|------------------------------------------|
| DMAX_CH(x)_FIFO_WIDTH       | 64     | 64 bit                                   |
| <b>Programming Register</b> |        |                                          |
| CHx_SAR                     | 0x0001 | Unaligned source address                 |
| CHx_DAR                     | 0x9001 | Unaligned destination address            |
| CHx_CTL.SRC_MSIZE           | 3b001  | Source burst transaction length = 4      |
| CHx_CTL.DST_MSIZE           | 3b001  | Destination burst transaction length = 4 |
| CHx_CTL.SRC_TR_WIDTH        | 0x3    | Source Transfer Width is 64 bits         |
| CHx_CTL.DST_TR_WIDTH        | 0x3    | Destination Transfer Width is 64 bits    |

**Figure 2-44 Example 9 - Unaligned DMA Transfer Handling**

### 2.14.2.10 Example 10

Assume that,

- the source address is aligned to the source transfer width
- the destination address is unaligned to the destination transfer width
- the source and the destination endianness is big-endian

Table Table 2-14 describes all major DMA parameter settings considered for this example.

**Table 2-14 Example 10 - Configuration and Programming Options**

| Configuration/Programming      | Value  | Description            |
|--------------------------------|--------|------------------------|
| <b>Configuration Parameter</b> |        |                        |
| DMAX_M_DATA_WIDTH              | 64     | 64 bit                 |
| DMAX_CH(x)_FIFO_WIDTH          | 64     | 64 bit                 |
| <b>Programming Register</b>    |        |                        |
| CHx_SAR                        | 0x0000 | Aligned source address |

**Table 2-14 Example 10 - Configuration and Programming Options**

| Configuration/Programming | Value  | Description                              |
|---------------------------|--------|------------------------------------------|
| CHx_DAR                   | 0x9001 | Unaligned destination address            |
| CHx_CTL.SRC_MSIZE         | 3b001  | Source burst transaction length = 4      |
| CHx_CTL.DST_MSIZE         | 3b001  | Destination burst transaction length = 4 |
| CHx_CTL.SRC_TR_WIDTH      | 0x3    | Source Transfer Width is 64 bits         |
| CHx_CTL.DST_TR_WIDTH      | 0x3    | Destination Transfer Width is 64 bits    |

**Figure 2-45 Example 10 - Unaligned DMA Transfer Handling**

### 2.14.2.11 Example 11

Assume that,

- the source address is unaligned to the source transfer width
- the destination address is also unaligned to the destination transfer width
- the source transfer width is not the same as the master interface data bus width with multiple source burst/single DMA transactions
- the source and destination endianness is big-endian

Table [Table 2-15](#) describes all major DMA parameter settings considered for this example.

**Table 2-15 Example 11 - Configuration and Programming Options**

| Configuration/Programming      | Value  | Description              |
|--------------------------------|--------|--------------------------|
| <b>Configuration Parameter</b> |        |                          |
| DMAX_M_DATA_WIDTH              | 64     | 64 bit                   |
| DMAX_CH(x)_FIFO_WIDTH          | 64     | 64 bit                   |
| <b>Programming Register</b>    |        |                          |
| CHx_SAR                        | 0x0003 | Unaligned source address |

**Table 2-15 Example 11 - Configuration and Programming Options**

| Configuration/Programming | Value  | Description                              |
|---------------------------|--------|------------------------------------------|
| CHx_DAR                   | 0x9002 | Unaligned destination address            |
| CHx_CTL.SRC_MSIZE         | 3b001  | Source burst transaction length = 4      |
| CHx_CTL.DST_MSIZE         | 3b001  | Destination burst transaction length = 4 |
| CHx_CTL.SRC_TR_WIDTH      | 0x2    | Source Transfer Width is 32 bits         |
| CHx_CTL.DST_TR_WIDTH      | 0x3    | Destination Transfer Width is 64 bits    |

**Figure 2-46 Example 11 - Unaligned DMA Transfer Handling**

In “Example 11”, the data byte-3 is packed with data byte-4, 5, and 6 to form a data item of source transfer width. This data item is used to perform the little-endian conversion as shown in the Figure 2-14 that is all bytes of the data item are flipped. Similar operation is continued, on the subsequent bytes.

BE-LE Conversion Using BE-8 (Byte Invariant) Method for 64-Bit Data Bus (Word Access)

### 2.14.2.12 Example 12

Assume that,

- the source address is unaligned to the source transfer width
- the destination address is also unaligned to the destination transfer width
- the source and the destination transfer widths are not the same as the master interface data bus width
- the source and the destination endianness is big-endian

Table Table 2-16 describes all major DMA parameter settings considered for this example.

**Table 2-16 Example 12 - Configuration and Programming Options**

| Configuration/Programming      | Value  | Description                              |
|--------------------------------|--------|------------------------------------------|
| <b>Configuration Parameter</b> |        |                                          |
| DMAX_M_DATA_WIDTH              | 64     | 64 bit                                   |
| DMAX_CH(x)_FIFO_WIDTH          | 64     | 64 bit                                   |
| <b>Programming Register</b>    |        |                                          |
| CHx_SAR                        | 0x0003 | Unaligned source address                 |
| CHx_DAR                        | 0x900E | Unaligned destination address            |
| CHx_CTL.SRC_MSIZEx             | 3b001  | Source burst transaction length = 4      |
| CHx_CTL.DST_MSIZEx             | 3b001  | Destination burst transaction length = 4 |
| CHx_CTL.SRC_TR_WIDTH           | 0x2    | Source Transfer Width is 32 bits         |
| CHx_CTL.DST_TR_WIDTH           | 0x2    | Destination Transfer Width is 32 bits    |

**Figure 2-47 Example 12 - Unaligned DMA Transfer Handling**

In “Example 12”, the data byte-3 is packed with data byte-4, 5, and 6 to form a data item of source transfer width. This data item is used to perform the big-endian conversion (As per the [Figure 2-14](#)) that is all bytes of the data item are flipped. Similar operation is continued, on the subsequent bytes.

## 2.15 Channel Suspend, Disable, and Abort

Under normal operation, software enables a channel by writing a 1 to the channel enable register, DMAC\_ChEnReg.CH\_EN, and hardware disables a channel on transfer completion by clearing the DMAC\_ChEnReg.CH\_EN register.

Software can suspend, disable, or abort a channel before a transfer completes. The suspend, disable, and abort procedures are explained in the following sections.

### 2.15.1 Channel Suspend

To suspend a channel during DMA transfer:

1. Software writes a 1 to the channel suspend bit CH\_SUSP in the channel enable register, DMAC\_ChEnReg.
2. DW\_axi\_dmac gracefully halts all transfers from the source peripheral, after completing all AXI transfers initiated on the source peripheral.
3. DW\_axi\_dmac sets CHx\_IntStatusReg.CH\_SRC\_SUSPENDED bit to 1 to indicate that source data transfer is suspended and generates the interrupt if it is not masked off.



If the channel FIFO is full and the destination peripheral is not requesting data transfer, DW\_axi\_dmac cannot receive any more data on the corresponding master interface, which could lead to a deadlock.

- The requests initiated by source/destination/LLI state machines and present in the Master Interface Read Address Channel and Write Address Channel FIFOs to be sent on the AXI Master Interface will be sent on the AXI Master Interface even if the Channel Suspend request is initiated. Based on the Master Interface Read Address and Write Address Channel FIFO depth configuration, maximum 8 read/write requests may be initiated and DW\_axi\_dmac waits for the data/response for these requests also before suspending the channel.

- 
4. DW\_axi\_dmac transfers all the data in channel FIFO to destination peripheral.

When CHx\_CTL.SRC\_TR\_WIDTH < CHx\_CTL.DST\_TR\_WIDTH and the DMAC\_ChEnReg.CH\_SUSP bit is high, there may still be data in the channel FIFO, but not enough to form a single transfer of CHx\_CTL.DST\_TR\_WIDTH. The data remaining in the channel FIFO will be transferred to destination if channel is resumed later which results in filling of more data in channel FIFO.

5. DW\_axi\_dmac clears channel locking and resets the channel locking settings in the CHx\_CFG register.
6. DW\_axi\_dmac sets the CHx\_IntStatusReg.ChLock\_Cleared bit to 1 to indicate that channel locking is cleared.
7. DW\_axi\_dmac sets the CHx\_IntStatusReg.CH\_SUSPENDED bit to 1 to indicate that the channel is suspended.
8. DW\_axi\_dmac generates a CH\_SUSPENDED interrupt (if it is not masked off).

After a channel suspend, software may either resume the channel after some time, or disable the channel.

### 2.15.2 Channel Suspend and Resume

To suspend and resume a channel:

1. Follow [steps 1 to 4 in Channel Suspend](#).
2. Software writes a 0 to the channel suspend bit CH\_SUSP in the channel enable register, DMAC\_ChEnReg.
3. DW\_axi\_dmac resumes the DMA transfer from the point where it got suspended.

**Note**

Once software initiates the channel suspend procedure by writing a 1 to the channel suspend bit DMAC\_ChEnReg.CH\_SUSP, writing 0 to DMAC\_ChEnReg.CH\_SUSP bit to resume the channel before DW\_axi\_dmac asserts CHx\_IntStatusReg.CH\_SUSPENDED bit is not allowed. DW\_axi\_dmac ignores this write operation.

### 2.15.3 Channel Suspend and Disable Prior to Transfer Completion

To suspend and disable a channel:

1. Follow [steps 1 to 4 in Channel Suspend](#).
2. To disable the suspended channel using software, write a 0 to the channel enable bit (CH\_EN) in the channel enable register (DMAC\_ChEnReg) after DW\_axi\_dmac asserts the CHx\_IntStatusReg.CH\_SUSPENDED bit to 1 to indicate that channel is suspended.

When CHx\_CTL.SRC\_TR\_WIDTH < CHx\_CTL.DST\_TR\_WIDTH and the DMAC\_ChEnReg.CH\_SUSP bit is high, there may still be data in the channel FIFO, but not enough to form a single transfer of CHx\_CTL.DST\_TR\_WIDTH.

In this scenario, once the channel is disabled, the remaining data in the channel FIFO is not transferred to the destination peripheral and is lost.

3. DW\_axi\_dmac sets the CHx\_IntStatusReg.CH\_DISABLED bit to 1 to indicate that the channel is disabled.
4. DW\_axi\_dmac generates a CH\_DISABLED interrupt (if it is not masked off).
5. DW\_axi\_dmac clears the DMAC\_ChEnReg.CH\_EN bit to 0.

## 2.15.4 Channel Disable Prior to Transfer Completion without Suspend

To disable a channel without suspending:

1. Software writes a 0 to the channel enable bit CH\_EN in the channel enable register, DMAC\_ChEnReg.
2. DW\_axi\_dmac gracefully halts all transfers from the source peripheral, after completing all AXI transfers initiated on the source peripheral.



- If the channel FIFO is full and the destination peripheral is not requesting data transfer, DW\_axi\_dmac cannot receive any more data on the corresponding master interface, which could lead to a deadlock.
- The requests initiated by source/destination/LLI state machines and present in the Master Interface Read Address Channel and Write Address Channel FIFOs to be sent on the AXI Master Interface will be sent on the AXI Master Interface even if the Channel Suspend request is initiated. Based on the Master Interface Read Address and Write Address Channel FIFO depth configuration, maximum 8 read/write requests may be initiated and DW\_axi\_dmac waits for the data/response for these requests also before suspending the channel.

3. DW\_axi\_dmac transfers all the data in the channel FIFO to the destination peripheral.

If CHx\_CTL.SRC\_TR\_WIDTH is less than CHx\_CTL.DST\_TR\_WIDTH and the DMAC\_ChEnReg.CH\_EN bit is low, there may still be data in the channel FIFO, but not enough to form a single transfer of CHx\_CTL.DST\_TR\_WIDTH.

In this scenario, once the channel is disabled, the remaining data in the channel FIFO is not transferred to the destination peripheral and is lost.

4. DW\_axi\_dmac clears channel locking and resets the channel locking settings in the CHx\_CFG register.
5. DW\_axi\_dmac sets the CHx\_IntStatusReg.ChLock\_Cleared bit to 1 to indicate that channel locking is cleared.
6. DW\_axi\_dmac sets the CHx\_IntStatusReg.CH\_DISABLED bit to 1 to indicate that the channel is disabled.
7. DW\_axi\_dmac generates a CH\_DISABLED interrupt (if it is not masked off).
8. DW\_axi\_dmac clears the DMAC\_ChEnReg.CH\_EN bit to 0.



Once software initiates a channel disable procedure by writing a 0 to the channel enable bit DMAC\_ChEnReg.CH\_EN, writing a 1 to the DMAC\_ChEnReg.CH\_EN bit to re-enable the channel before DW\_axi\_dmac asserts the CHx\_IntStatusReg.CH\_DISABLED bit is not allowed. DW\_axi\_dmac ignores this write operation.

## 2.15.5 Abnormal Channel Abort

Aborting a channel is not a recommended procedure. This procedure should be used only when software wants to disable a channel without resetting the entire DW\_axi\_dmac, for example, if a particular channel hangs due to not receiving a response from the corresponding handshaking interface. Before aborting a channel, it is recommended that you first attempt to disable a channel.

To abort a channel:

1. Software writes a 1 to the channel abort bit CH\_ABORT in the channel enable register, DMAC\_ChEnReg.
2. DW\_axi\_dmac gracefully halts all transfers from the source/destination peripheral after completing all AXI transfers initiated on the source/destination peripheral.
3. The data in Channel FIFO is flushed and essentially be lost.
4. DW\_axi\_dmac clears channel locking and resets the channel locking settings in the CHx\_CFG register.
5. DW\_axi\_dmac sets CHx\_IntStatusReg.ChLock\_Cleared bit to 1 to indicate that channel locking is cleared.
6. DW\_axi\_dmac sets CHx\_IntStatusReg.CH\_ABORTED bit to 1 to indicate that channel is aborted.
7. DW\_axi\_dmac generates CH\_ABORTED interrupt if it is not masked off.
8. DW\_axi\_dmac clears DMAC\_ChEnReg.CH\_EN bit to 0.

## 2.16 Debug Interface

The Debug Interface in DW\_axi\_dmac consists of Status Indication signals and DMAC Hold Control signals.

### 2.16.1 Slave Interface and DMAC Core Status Indication

DW\_axi\_dmac supports status indication using two signals on the I/O: slvif\_busy and dmac\_busy.

- slvif\_busy – indicates whether the Slave Interface is busy. This signal is asserted High if there is an active transfer on the slave interface.
- dmac\_busy – indicates whether the DMAC Core is busy or not. This signal is asserted High if any of the channels in DW\_axi\_dmac are in a non-idle state. A non-idle state of the channel corresponds to the following cases.
  - There is an active transfer on the Master Interface (including posted requests) corresponding to one or multiple Channels.
  - Any of the Channels are about to initiate a transfer, which might correspond to waiting for the grant of the master interface from the arbiter.

### 2.16.2 DMAC Hold Control

DW\_axi\_dmac supports freezing an operation. This is supported using two signals on the I/O, dmac\_hold\_req and dmac\_hold\_ack. The dmac\_hold\_req signal is the request to put DW\_axi\_dmac in hold

(freeze) mode. Asserting this request puts the entire DW\_axi\_dmac in freeze mode without violating the AXI protocol. DW\_axi\_dmac asserts dmac\_hold\_ack after entering the hold mode.

To put DW\_axi\_dmac in hold mode:

1. External device (master) asserts dmac\_hold\_req to put DW\_axi\_dmac in hold mode.
2. DW\_axi\_dmac halts all transfers from the source peripheral of all channels.
  - DW\_axi\_dmac does not initiate any new read request on the AXI read address channel.
  - DW\_axi\_dmac de-asserts arvalid\_mN output once arready\_mN is received.
  - DW\_axi\_dmac de-asserts rready\_mN output so that no new data is received on the AXI read data channel and hence no new data is written to the channel FIFO.



**Note** There may be outstanding read requests of different channels on the master interfaces, for which data transfer is not completed. This can lead to timeout issues in the interconnect.

3. DW\_axi\_dmac halts all transfers to the destination peripheral of all channels, which means the following is true:
  - DW\_axi\_dmac does not initiate any new write request on AXI write address channel.
  - DW\_axi\_dmac de-asserts awvalid\_mN and wvalid\_mN output when awready\_mN and wready\_mN is received.
  - DW\_axi\_dmac de-asserts bready\_mN output when data transfer on the AXI write data channel is completed.



**Note** There may be write requests from many channels on the master interfaces, waiting for a response. This can lead to timeout issues in the interconnect.

4. The channel FIFOs are not guaranteed to be emptied. There may still be data in the channel FIFO after entering the hold mode.
5. DW\_axi\_dmac asserts dmac\_hold\_ack to indicate the entry to hold mode.
6. To exit the DMAC hold mode, dmac\_hold\_req can be de-asserted after DW\_axi\_dmac asserts dmac\_hold\_ack.
7. After dmac\_hold\_req is de-asserted, DW\_axi\_dmac de-asserts dmac\_hold\_ack.



**Note** When a DMAC hold request is initiated by asserting dmac\_hold\_req, de-asserting dmac\_hold\_req to exit the DMAC hold mode before DW\_axi\_dmac asserts dmac\_hold\_ack is not allowed. DW\_axi\_dmac ignores this operation.

### 2.16.3 Error Handling

DW\_axi\_dmac can receive an error response from a source peripheral, a destination peripheral, or an LLP peripheral. Upon occurrence of an error in an AXI transfer (source or destination data transfer or status fetch, LLI fetch, or LLI write-back), the following occurs:

1. DMA transfer in progress stops gracefully.
2. If channel locking to arbiter is enabled at any transfer level, the locking is cleared.
3. Error Status bits in CHx\_IntStatusReg register is updated if not masked off.
4. Source/Destination Transaction Completion, Block Transfer Completion and DMA Transfer Completion Status bits in CHx\_IntStatusReg register is cleared to 0 if not masked off.
5. Interrupt Status registers are updated and an interrupt is issued, if not masked.
6. Relevant channel is disabled and CH\_DISABLED Status bit is set to 1.

If an error occurs on a source or destination peripheral, the steps that need to access that peripheral are not performed. If multiple channels are enabled, only the channel where the AXI error was detected is disabled.

The FIFO pointers are reset, therefore, the previous FIFO contents become inaccessible and are overwritten once the channel is re-enabled to start a new sequence. There is no support for automatically resuming the transfer from the point where the error occurred, and the full or partial block transfer has to be re-initiated by the software in order to be successfully completed.

If hardware handshaking is enabled for source or destination, the DW\_axi\_dmac does not signal the end of a transfer. If a request from a peripheral is active when the error occurs (that is, dma\_req is high), the channel is disabled without the DMA ever asserting dma\_ack and dma\_finish. The hardware handshake interface on the peripheral side has to be re-initiated by the CPU upon detection of the error interrupt. The dma\_req signal needs to be brought low before the channel is re-enabled and then brought high when the channel has been enabled.

If software handshaking is enabled for SRC/DST, the DW\_axi\_dmac does not signal the end of a transfer. In practice, this means that if a request from a peripheral is active when the error occurs (all or some of SWHS\_Req\_Src, SWHS\_SglReq\_Src, SWHS\_Lst\_Src, SWHS\_Req\_Dst, SWHS\_SglReq\_Dst, SWHS\_Lst\_Dst bits are high), the channel is disabled without the DMA ever clearing the request bits to 0 in CHx\_SWHSSrcReg and/or CHx\_SWHSDstReg register.

## 2.17 Context Sensitive Low Power Option

In order to meet high performance bandwidth requirements of the system, the DMA controller must be operated at high frequency. This increases the overall power consumption of the DMA controller. Thus, it becomes very important to reduce the power consumption at the architecture level. This section describes the architectural low power technique incorporated in the DW\_axi\_dmac.

The DW\_axi\_dmac supports the Context Sensitive Low Power option, which is an intelligent low power logic that automatically senses the idle periods in multiple DMA channels, Slave Bus Interface, and AXI Master Interface channels under various scenarios. This cuts-off the clock to these modules, and reduces overall power consumption significantly. The logic is quick enough to provide the clocks back to these modules when any activity is detected without compromising on the performance.

This Context Sensitive Low Power option is enabled through the configuration parameter DMAX\_CSLP\_EN. You can enable or disable this Context Sensitive Low Power Technique option for DMA channels, Slave Bus interface, and AXI Master interfaces through the following parameters:

- DMA Channels Context Sensitive Low Power Technique - DMAX\_CHNL\_CSLP\_EN
- Slave Bus Interface Context Sensitive Low Power Technique - DMAX\_SBIU\_CSLP\_EN
- AXI Master Interface Context Sensitive Low Power Technique - DMAX\_MXIF\_CSLP\_EN

The following sections describe the Context Sensitive Low Power Techniques used in the DMA Channel, Slave Bus Interface, and AXI Master Interface modules.

### 2.17.1 DMA Channel Context Sensitive Low Power Technique

The DMA Channel is the major module responsible for controlling the operations such as

- Reading the data from the source
- Temporary storage of the read data in the Channel FIFO
- Writing the data to the destination
- Handling the miscellaneous operation such as interrupt handling, handshake handling
- Channel specific-register read and write operation
- LLI fetch and Write back operation
- Channel Suspend operation
- Channel abort operation and so on

Due to all these operations, this module consumes major area share, and hence it consumes more power than any other module in DW\_axi\_dmac. Thus, it becomes very important to optimize the power in this module.

The Context Sensitive Low Power option monitors the activity on the DMA Channel by using a DMA Channel Low Power state machine. Whenever the DMA Channel low power condition is detected, DMA Channel low power delay counter starts. The Channel Low Power state machine waits until the DMA Channel delay counter expires, after the counter expires, the DMA Channel enters the Low Power state by gating the `dma_core_clk`. It remains in this state until any activity is detected on the DMA Channel. In certain scenarios, if an activity is detected when the DMA Channel low power delay counter is running, then DMA Channel delay counter is resets and stops until the low power condition is detected again.

Following are the conditions used to determine whether DMA Channel is idle:

- The DW\_axi\_dmac comes out of the reset and no channel-specific registers are being written or read.
- The DMA Channel is configured for the DMA operation and the channel is enabled - DMA Channel waits for any activity on the handshaking interface either through the handshaking signals or through the channel-specific software handshaking registers.
- The DMA Channel is configured for the DMA operation and the channel is enabled - DMA Channel source, destination, or LLI state machine has requested for the AXI master interface, but it is waiting for grant from the AXI master interface arbiter (because Other DMA Channels Source, Destination, and LLI state machines also competing for the AXI Master interface grant).
- The DMA Channel is disabled between the successive DMA blocks or Channel disable prior to the transfer completion with or without channel suspend (See “[Channel Suspend, Disable, and Abort](#)” on page [89](#)).
- The DMA Channel is suspended based on the Channel Suspend procedures described in the section “[Channel Suspend, Disable, and Abort](#)” on page [89](#)
- The DMA Channel is aborted based on the Abnormal Channel Abort procedure described in the section “[Channel Suspend, Disable, and Abort](#)” on page [89](#)

- The entire DMAC is disabled through DMAC\_CFGREG.DMAC\_EN bit.
- After the DMAC software reset DMAC\_RESETREG.DMAC\_RST is asserted.

Based on the previously described idle conditions the DMA Channel low power counter starts. If the DMA Channel low power delay counter expires, the corresponding DMA Channel enters the low power state.

Following are conditions under which the DMA Channel exits the low power state:

- Any read/write transaction occurs to any of the DMA Channel-specific registers (like CHx\_SAR, CHx\_DAR, CHx\_BLOCK\_TS, CHx\_CTL, CHx\_CFG and so on).
- An activity on the handshaking interface is detected either through the handshaking signals or through the channel specific software handshaking registers.
- The DMA Channel source, destination, or LLI state machine has been granted with access to the AXI Master interface.
- Clearing of Channel-specific interrupts by writing into the CHx\_INTCLEARREG register.
- On the rising or falling edge of the Channel enable DMAC\_CHENREG.CHx\_EN or DMAC\_CFGREG.DMAC\_EN.
- On the rising or falling edge of the Channel suspend or Channel abort.
- On assertion of DMAC software reset

The Context Sensitive Low Power option can be enabled through the configuration parameter DMAX\_CHNL\_CSLP\_EN. The DMA Channel low power delay counter load value can be configured through the DMAC\_LOWPOWER\_CFGREG.CHNL\_LPDLY register field. The parameter DMAX\_GLCH\_LPDLY is used to configure the default load value of the DMAC\_LOWPOWER\_CFGREG.CHNL\_LPDLY field.

## 2.17.2 Slave Bus Interface Context Sensitive Low Power Technique

The Slave Bus Interface module is used to access the internal registers of DW\_axi\_dmac by an external AHB Master interface. The Context Sensitive Low Power option is implemented to optimize the power consumption in the Slave Bus Interface module.

The Context Sensitive Low Power option monitors the activity on the Slave Bus Interface and based on based on the SBIU state machine. Whenever the Slave Bus Interface low power condition is detected, (that is when no AHB read or write transfers are in progress and SBIU state machine is in IDLE) SBIU low power delay counter is started. When the SBIU low power delay counter expires the Slave Bus Interface module enters the Low Power state by gating the hclk or dma\_core\_clk (based on the Clock Mode configuration). It remains in this state until an active read or write transaction is detected on the Slave Bus Interface. In certain scenarios, if an active transaction is detected when SBIU low power delay counter running, then SBIU delay counter is reset and stopped until the low power condition is detected again.

If a read or write transaction is detected, when Slave Bus Interface module is in low power state, then the context sensitive low power logic responds immediately to exit the low power state by un-gating the hclk or dma\_core\_clk. Since the low power exit operation occurs within a clock cycle, following are the major advantage of this architecture:

- No additional registers required to buffer the transaction control information
- No wait cycle insertion required

Condition when the Slave Bus Interface module enters the Low Power state:

- No active AHB read or write transaction is in progress and SBIU low power delay counter has been expired

Condition when the Slave Bus Interface module exits the Low Power state:

- Any AHB read or write transaction is initiated

The Context Sensitive Low Power option can be enabled through the configuration parameter DMAX\_SBIU\_CSPL\_EN. The SBIU low power delay counter load value can be configured through the DMAC\_LOWPOWER\_CFGREG.SBIU\_LPDLY register field. The parameter DMAX\_SBIU\_LPDLY is used to configure the default load value of the DMAC\_LOWPOWER\_CFGREG.SBIU\_LPDLY field.

### 2.17.3 AXI Master Interface Context Sensitive Low Power Technique

The AXI Master Interface module implements the AXI bus to transfer the data between the memories and peripherals. Since the AXI bus operates at the high frequency to address the bandwidth requirement, which leads to the increased power consumption. The Context Sensitive Low Power option is implemented in AXI Master interface to optimize the power consumption in the AXI Master Interface module.

The Context Sensitive Low Power option is implemented for each of the following AXI Channels separately:

- Write address Channel
- Write data Channel
- Write response Channel
- Read address Channel
- Read data Channel

Whenever the AXI Channel low power condition is detected, the respective AXI Channel low power delay counter starts. The AXI Low Power logic waits until the AXI Channel delay counter expires, after the counter expires the AXI Channel enters the Low Power state by gating the aclk\_mi and/or dma\_core\_clk (based on the Clock Mode configuration). It remains in this state until any activity is detected on the respective AXI Channel. In certain scenarios, if an activity is detected when the AXI Channel low power delay counter is running, then AXI Channel delay counter is reset and stopped until the low power condition is detected again.

Following is the condition used to determine whether AXI Channel is Idle:

- AXI Channel FIFO is empty and no data to perform the AXI transfers
- Clock Mode Synchronous: The FIFO flag is empty in the dma\_core\_clk domain
- Clock Mode Asynchronous: The FIFO flags from both the dma\_core\_clk and aclk\_mi domain are empty

Following are the conditions under which the DMA Channel exits the low power state:

- The data is pushed into the AXI Channel FIFO:
  - **AW Channel, W Channel, AR Channel:** The low power logic is quick enough to exit the low power state as soon as it detects the push from the DMA Channel. This logic ensures that additional buffering is not required to avoid the loss of the push due to the delay in exiting the

low power state. As mentioned earlier, low power logic is implemented separately for each of these AXI channels.

- **B Channel, R Channel:** The low power logic is quick enough to exit the low power state as soon as it detects the push from the AXI Channel based bvalid/rvalid logic. This logic makes sure that additional buffering is not required to avoid the loss of the push due to the delay in exiting the low power state. As mentioned earlier, low power logic is implemented separately for each of these AXI channels.
- DMAC software reset is asserted

The Context Sensitive Low Power option can be enabled through the configuration parameter DMAX\_MXIF\_CSLP\_EN. The AXI Channel low power delay counter load value can be configured through the DMAC\_LOWPOWER\_CFGREG.MXIF\_LPDLY register field. The parameter DMAX\_MXIF\_LPDLY is used to configure the default load value of the DMAC\_LOWPOWER\_CFGREG.MXIF\_LPDLY field.

#### 2.17.4 Global Context Sensitive Low Power Technique

The Global Context Sensitive Low Power technique implements the low power option based on the DMA Channel, Slave Bus Interface, and AXI Master Interface idle condition. If all the mentioned modules indicate that the DW\_axi\_dmac is in Idle, then a Global low power delay counter is started. The Global Context Sensitive Low power logic waits until the low power delay counter expires, after the counter expires the DW\_axi\_dmac enters the Low Power state by gating the clocks to all modules like dma\_core\_clk, hclk, and/or aclk\_mi (based on the Clock Mode configuration). It remains in low power state until any activity is detected on any of one of the module mentioned previously.

In certain scenarios, if an activity is detected when the Global low power delay counter is running, then Global delay counter is reset and stopped until the low power condition is again detected.

The Context Sensitive Low Power option can be enabled through the configuration parameter DMAX\_CSLP\_EN. The Global low power delay counter load value can be configured through the DMAC\_LOWPOWER\_CFGREG.GLBL\_LPDLY register field. The parameter DMAX\_GLCH\_LPDLY is used to configure the default load value of the DMAC\_LOWPOWER\_CFGREG.GLBL\_LPDLY field.

# 3

## Parameter Descriptions

---

This chapter details all the configuration parameters. You can use the coreConsultant GUI configuration reports to determine the complete configuration state of the core. Some expressions might refer to TCL functions or procedures (sometimes identified as <functionof>) that coreConsultant uses to make calculations. The exact formula used by these TCL functions is not provided in this chapter. However, when you configure the core in coreConsultant, all TCL functions and parameters are evaluated completely; and the resulting values are displayed where appropriate in the coreConsultant GUI reports.

These tables define all of the user configuration options for this component.

- Top Level Parameters on [page 100](#)
- Master Interface Configuration on [page 104](#)
- Slave Interface Configuration on [page 107](#)
- Clocking on [page 108](#)
- Low Power Configuration on [page 113](#)
- Channel x Configuration on [page 115](#)

## 3.1 Top Level Parameters

**Table 3-1 Top Level Parameters**

| Label                            | Description                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Top Level Parameters             |                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| AXI DMAC ID                      | <p>A 64-bit value that is hardwired and read back by a read to the DW_axi_dmac ID Register (DMAC_IDReg).</p> <p><b>Values:</b> 0x0, ..., 0xffffffffffffffffff</p> <p><b>Default Value:</b> 0x0</p> <p><b>Enabled:</b> Always</p> <p><b>Parameter Name:</b> DMAX_ID_NUM</p>                                                                                                                                                            |
| Number of DMA Channels           | <p>Creates the specified number of DW_axi_dmac channels, each of which is unidirectional and transfers data from the channel source to the channel destination. The channel source and destination AXI layer, system address, and handshaking interface are under software control.</p> <p><b>Values:</b> 1, ..., 32</p> <p><b>Default Value:</b> 1</p> <p><b>Enabled:</b> Always</p> <p><b>Parameter Name:</b> DMAX_NUM_CHANNELS</p> |
| Number of Handshaking Interfaces | <p>Creates the specified number of hardware handshaking interfaces. DW_axi_dmac can be programmed to assign a handshaking interface for each channel source and destination. If 0 is selected, then no hardware handshaking signals are present on the I/O.</p> <p><b>Values:</b> 0, ..., 64</p> <p><b>Default Value:</b> 2</p> <p><b>Enabled:</b> Always</p> <p><b>Parameter Name:</b> DMAX_NUM_HS_IF</p>                            |

**Table 3-1 Top Level Parameters (Continued)**

| Label                                                    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Interrupt Pins to Appear as Outputs?                     | <p>Selects which interrupt-related signals appear as outputs on the design.</p> <ul style="list-style-type: none"> <li>■ COMBINED_ONLY: Only "intr" output exist.<br/>Bitwise OR of all bits of DMAC_IntStatusReg register is driven onto "intr" output.</li> <li>■ CHANNEL_AND_COMMONREG: "intr_ch" and "intr_cmnreg" outputs exist.<br/>Bitwise OR of all the corresponding channel bits of DMAC_IntStatusReg register is driven onto the respective "intr_ch" output.<br/>Bitwise OR of all the bits of DMAC_CommonReg_IntStatusReg register is driven onto the respective "intr_cmnreg" output.</li> <li>■ ALL_INTERRUPT_OUTPUTS: "intr", "intr_ch" and "intr_cmnreg" outputs exist.<br/>Bitwise OR of all bits of DMAC_IntStatusReg register is driven onto "intr" output.<br/>Bitwise OR of all the corresponding channel bits of DMAC_IntStatusReg register is driven onto the respective "intr_ch" output.<br/>Bitwise OR of all the bits of DMAC_CommonReg_IntStatusReg register is driven onto the respective "intr_cmnreg" output.</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ COMBINED ONLY (0)</li> <li>■ CHANNEL AND COMMONREG (1)</li> <li>■ ALL INTERRUPTS OUTPUTS (2)</li> </ul> <p><b>Default Value:</b> COMBINED ONLY</p> <p><b>Enabled:</b> Always</p> <p><b>Parameter Name:</b> DMAX_INTR_IO_TYPE</p> |
| Include Status Indication Output on Slave Bus Interface? | <p>By default, this option creates a slave interface status indication (Busy/Idle) signals on the I/O, which is synchronous to the slave interface clock. When you set this option to False (0), the signal is not included on the I/O.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ No (0)</li> <li>■ Yes (1)</li> </ul> <p><b>Default Value:</b> No</p> <p><b>Enabled:</b> Always</p> <p><b>Parameter Name:</b> DMAX_SLVIF_STATUS_OP_EN</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Include DMAC Internal Status Indication Output?          | <p>By default, this option creates a DMAC internal status indication (Busy/Idle) signal on the I/O, which is synchronous to dmac_core_clock. When you set this option to False (0), the signal is not included on the I/O.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ No (0)</li> <li>■ Yes (1)</li> </ul> <p><b>Default Value:</b> No</p> <p><b>Enabled:</b> Always</p> <p><b>Parameter Name:</b> DMAX_CORE_STATUS_OP_EN</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

**Table 3-1 Top Level Parameters (Continued)**

| Label                                                          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Include DMAC Hold Request Input & Hold Acknowledgement Output? | <p>When set to Yes (1), this option creates a DMAC Hold Request Input signal (dmac_hold_req) and DMAC Hold Acknowledgement Output signal (dmac_hol_ack) on the I/O, which are synchronous to dmac_core_clock. When you set this option to False (0), this signal is not included on the I/O.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ No (0)</li> <li>■ Yes (1)</li> </ul> <p><b>Default Value:</b> No</p> <p><b>Enabled:</b> Always</p> <p><b>Parameter Name:</b> DMAX_HOLD_IO_EN</p>                                                                                     |
| Enable Unaligned Transfer Support?                             | <p>When set to Yes (1), this parameter enables the unaligned transfer support on CHx_SAR and CHx_DAR. This reduces the software overhead of converting the unaligned address to aligned address.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ No (0)</li> <li>■ Yes (1)</li> </ul> <p><b>Default Value:</b> No</p> <p><b>Enabled:</b> Always</p> <p><b>Parameter Name:</b> DMAX_UNALIGNED_XFER_EN</p>                                                                                                                                                                          |
| Enable Multi-Arbiter Feature?                                  | <p>When set to Yes (1), Multi-arbiter feature is enabled. This feature implements the Multiple Stage Arbiter Architecture (Multi-Arbiter) to arbitrate the requests from source, destination, and LLI state machine to access an AXI Master interface. Enabling this feature helps to improve the QoR for the implemented design.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ No (0)</li> <li>■ Yes (1)</li> </ul> <p><b>Default Value:</b> (DMAX_NUM_CHANNELS&gt;8) ? 1 : 0</p> <p><b>Enabled:</b> DMAX_NUM_CHANNELS&gt;8</p> <p><b>Parameter Name:</b> DMAX_MULT_ARB_EN</p> |
| Include Channel Abort Feature?                                 | <p>When set to Yes (1), enables logic to support Channel Abort feature in DW_axi_dmac.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ No (0)</li> <li>■ Yes (1)</li> </ul> <p><b>Default Value:</b> No</p> <p><b>Enabled:</b> Always</p> <p><b>Parameter Name:</b> DMAX_CH_ABORT_EN</p>                                                                                                                                                                                                                                                                                          |

**Table 3-1 Top Level Parameters (Continued)**

| Label                                                              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Include Transfer Completion Indication Signal on Master Interface? | <p>When set to Yes (1), enables the additional handshaking signal last_write_mi on all AXI master interfaces.</p> <p>The last_write_mi signal is asserted on last data phase of every destination block transfer and remains asserted until the last data phase completes.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ No (0)</li> <li>■ Yes (1)</li> </ul> <p><b>Default Value:</b> No</p> <p><b>Enabled:</b> Always</p> <p><b>Parameter Name:</b> DMAX_ENABLE_LAST_WRITE</p> |
| Include Debug Ports?                                               | <p>When set to Yes (1), enables debug_* ports in DW_axi_dmac.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ No (0)</li> <li>■ Yes (1)</li> </ul> <p><b>Default Value:</b> DMAX_CSLP_EN == 1 ? 1 : 0</p> <p><b>Enabled:</b> Always</p> <p><b>Parameter Name:</b> DMAX_DEBUG_PORTS_EN</p>                                                                                                                                                                                          |

## 3.2 Master Interface Configuration Parameters

**Table 3-2 Master Interface Configuration Parameters**

| Label                                                                                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|--------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Master Interface Configuration                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| DW_axi_dmac Master Interface Protocol                                                | <p>The protocol used for the AXI Master Interface.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ AXI3 (0)</li> <li>■ AXI4 (1)</li> </ul> <p><b>Default Value:</b> AXI3</p> <p><b>Enabled:</b> Always</p> <p><b>Parameter Name:</b> DMAX_MSTIF_MODE</p>                                                                                                                                                                                                                                                                                                                                                                |
| Enable QoS feature?                                                                  | <p>When set to Yes (1), enables the QoS signals in the AXI4 interface.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ No (0)</li> <li>■ Yes (1)</li> </ul> <p><b>Default Value:</b> No</p> <p><b>Enabled:</b> DMAX_MSTIF_MODE==1</p> <p><b>Parameter Name:</b> DMAX_HAS_QOS</p>                                                                                                                                                                                                                                                                                                                                        |
| Number of AXI Master Interfaces                                                      | <p>Creates the specified number of AXI master interfaces. A channel source or destination device can be programmed to be on any of the configured AXI layers attached to the AXI master interface. This setting determines if AXI master 2 interface signal set is present on the I/O. AXI master interface signals are always present.</p> <p><b>Values:</b> 1, 2</p> <p><b>Default Value:</b> 1</p> <p><b>Enabled:</b> Always</p> <p><b>Parameter Name:</b> DMAX_NUM_MASTER_IF</p>                                                                                                                                                       |
| Master Interface i Outstanding Request Limit<br>(for i = 1; i <= DMAX_NUM_MASTER_IF) | <p>The maximum number of active write requests that can be generated by an AXI Master interface (i) without sending the respective write data. This parameter is used to select the depth of a FIFO, which tracks the write data transferred on AXI Master interface for the active AXI write requests.</p> <p><b>Note:</b> AXI outstanding write/read requests are controlled through the programming registers CHx_CFG.SRC_OSR_LMT and CHx_CFG.DST_OSR_LMT.</p> <p><b>Values:</b> 16, 32, 48, 64, 80, 96, 112, 128</p> <p><b>Default Value:</b> 16</p> <p><b>Enabled:</b> Always</p> <p><b>Parameter Name:</b> DMAX_MSTIF(i)_OSR_LMT</p> |

**Table 3-2 Master Interface Configuration Parameters (Continued)**

| Label                                                                               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Statically Configure Endian Scheme of Master Interfaces?                            | <p>The endian scheme of the DW_axi_dmac master interfaces can be configured statically through coreConsultant or dynamically through pins on the I/O.</p> <ul style="list-style-type: none"> <li>■ For the static case, there is a single coreConsultant parameter that controls the endianness of all AXI master interfaces.</li> <li>■ For the dynamic case, there is an individual pin for each of the AXI master interfaces.</li> </ul> <p>When set to Yes (1), the endianness is configured based on the value of DMAX_ENDIAN_FORMAT_MSTIF; otherwise it is configured based on the value of input pin, dmac_endian_format_mstif_m(i).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ No (0)</li> <li>■ Yes (1)</li> </ul> <p><b>Default Value:</b> Yes</p> <p><b>Enabled:</b> Always</p> <p><b>Parameter Name:</b> DMAX_STATIC_ENDIAN_SELECT_MSTIF</p>                                                                                                                                                                                                                                                                                                                                     |
| Include Little Endian Scheme Selection Pin for LLI Access on AXI Master Interfaces? | <p>When set to Yes (1), enables additional inputs are enabled to control the endian scheme used for LLI access. An individual pin is added for each AXI Master interface. LLI access on each AXI Master interface can be independently configured to support Big Endian scheme (BE-8) based on the endian scheme selected for that particular master interface or Little Endian scheme irrespective of the endian scheme selected for that particular master interface.</p> <ul style="list-style-type: none"> <li>■ 0: Endian scheme used for LLI access is the same as that used for data access for M1/M2 interfaces.</li> <li>■ 1: Endian scheme used for LLI access is the same as that used for data access for M1/M2 interfaces.</li> </ul> <p>or</p> <ul style="list-style-type: none"> <li>■ Little Endian method is used for LLI access irrespective of the endian scheme used for data access depending on the value of dmac_le_select_lll_mstif_m(i) input.</li> </ul> <p><b>Values:</b> 0, 1</p> <p><b>Default Value:</b> 0</p> <p><b>Enabled:</b> !(DMAX_STATIC_ENDIAN_SELECT_MSTIF == 1) &amp;&amp; (DMAX_ENDIAN_FORMAT_MSTIF ==0)</p> <p><b>Parameter Name:</b> DMAX_LLI_ENDIAN_SELECTION_PIN_EN</p> |

**Table 3-2 Master Interface Configuration Parameters (Continued)**

| Label                               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Master Interface Endian Format?     | <p>DMAX_ENDIAN_FORMAT_MSTIF values for different AXI master interface endian formats are as follows.</p> <ul style="list-style-type: none"> <li>■ 0: LittleEndian</li> <li>■ 1: BigEndian BE-8</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ LittleEndian (0)</li> <li>■ BigEndian BE-8 (1)</li> </ul> <p><b>Default Value:</b> LittleEndian</p> <p><b>Enabled:</b> DMAX_STATIC_ENDIAN_SELECT_MSTIF == 1</p> <p><b>Parameter Name:</b> DMAX_ENDIAN_FORMAT_MSTIF</p>                                         |
| Master Interface Address Bus Width  | <p>AXI Master 1 interface address bus width.</p> <p><b>Values:</b> 32, ..., 64</p> <p><b>Default Value:</b> 32</p> <p><b>Enabled:</b> Always</p> <p><b>Parameter Name:</b> DMAX_M_ADDR_WIDTH</p>                                                                                                                                                                                                                                                                                                                                        |
| Master Interface Data Bus Width     | <p>AXI Master interface data bus width.</p> <p><b>Values:</b> 32, 64, 128, 256, 512</p> <p><b>Default Value:</b> 32</p> <p><b>Enabled:</b> Always</p> <p><b>Parameter Name:</b> DMAX_M_DATA_WIDTH</p>                                                                                                                                                                                                                                                                                                                                   |
| Master Interface ID Bus Width       | <p>AXI master interface ID bus width (common for awid_m(i), arid_m(i), wid_m(i), bid_m(i) and rid_m(i)).</p> <p><b>Note:</b> The Minimum value of DMAC_M_ID_WIDTH is equal to <math>\log_2(DMAX\_NUM\_CHANNELS)</math> if multi-block transfer type is hardcoded to non-linked-list-based schemes, otherwise <math>[\log_2(DMAX\_NUM\_CHANNELS)] + 1</math>.</p> <p><b>Values:</b> 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12</p> <p><b>Default Value:</b> 6</p> <p><b>Enabled:</b> Always</p> <p><b>Parameter Name:</b> DMAX_M_ID_WIDTH</p> |
| Master Interface Burst Length Width | <p>AXI master interface Burst Length (arlen(i)/awlen(i)) width.</p> <p><b>Values:</b> 4, 5, 6, 7, 8</p> <p><b>Default Value:</b> 4</p> <p><b>Enabled:</b> Always</p> <p><b>Parameter Name:</b> DMAX_M_BURSTLEN_WIDTH</p>                                                                                                                                                                                                                                                                                                                |

### 3.3 Slave Interface Configuration Parameters

**Table 3-3 Slave Interface Configuration Parameters**

| Label                                                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Slave Interface Configuration                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| DW_axi_dmac Slave Interface Protocol                    | <p>The protocol is used for Slave Bus Interface.<br/> <i>Only AHB is supported in this version.</i></p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ AHB (0)</li> <li>■ AXI4-Lite (1)</li> <li>■ APB3 (2)</li> </ul> <p><b>Default Value:</b> AHB</p> <p><b>Enabled:</b> 0</p> <p><b>Parameter Name:</b> DMAX_SLVIF_MODE</p>                                                                                                                                                 |
| Synchronize Interrupt Outputs to Slave Interface Clock? | <p>By default, interrupt output is synchronous to dmac_core_clock. When this parameter is set to Yes (1), the interrupt output pins are synchronous to slave Interface clock. In this case, additional synchronizers are added inside DW_axi_dmac.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ No (0)</li> <li>■ Yes (1)</li> </ul> <p><b>Default Value:</b> No</p> <p><b>Enabled:</b> DMAX_SLVIF_CLOCK_MODE!=0</p> <p><b>Parameter Name:</b> DMAX_INTR_SYNC2SLVCLK</p> |
| Slave Interface Data Bus Width                          | <p>Specifies the data bus width for the AHB/APB3/AXI4-Lite slave interface.</p> <p><b>Values:</b> 32, 64</p> <p><b>Default Value:</b> 32</p> <p><b>Enabled:</b> Always</p> <p><b>Parameter Name:</b> DMAX_S_DATA_WIDTH</p>                                                                                                                                                                                                                                                                     |

## 3.4 Clocking Parameters

**Table 3-4 Clocking Parameters**

| Label                                     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Synchronization options                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| DW_axi_dmac Slave Interface Clocking Mode | <p>Selects the relationship between the slave interface clock (AHB/AXI4-Lite/APB3) and the Core clock.</p> <ul style="list-style-type: none"> <li>■ 0: Slave interface clock is synchronous to the core clock.</li> <li>■ 1: Slave interface clock is asynchronous to the core clock.</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ Synchronous (0)</li> <li>■ Asynchronous (1)</li> </ul> <p><b>Default Value:</b> Synchronous</p> <p><b>Enabled:</b> Always</p> <p><b>Parameter Name:</b> DMAX_SLVIF_CLOCK_MODE</p>                                                                                                                                            |
| Slave to Core Synchronization Depth       | <p>Defines the number of synchronization register stages for signals passing from the DW_axi_dmac Slave clock domain to the DW_axi_dmac Core Clock domain.</p> <ul style="list-style-type: none"> <li>■ 1: Two-stage synchronization. First stage - negative edge; Second stage - positive edge.</li> <li>■ 2: Two-stage synchronization, both stages positive edge.</li> <li>■ 3: Three-stage synchronization, all stages positive edge.</li> <li>■ 4: Four-stage synchronization, all stages positive edge.</li> </ul> <p><b>Values:</b> 1, 2, 3, 4</p> <p><b>Default Value:</b> 2</p> <p><b>Enabled:</b> DMAX_SLVIF_CLOCK_MODE==1</p> <p><b>Parameter Name:</b> DMAX_S_2_C_SYNC_DEPTH</p> |
| Core to Slave Synchronization Depth       | <p>Defines the number of synchronization register stages for signals passing from the DW_axi_dmac Core Clock Domain to the Slave clock domain.</p> <ul style="list-style-type: none"> <li>■ 1: Two-stage synchronization. First stage - negative edge; Second stage - positive edge.</li> <li>■ 2: Two-stage synchronization, both stages positive edge.</li> <li>■ 3: Three-stage synchronization, all stages positive edge.</li> <li>■ 4: Four-stage synchronization, all stages positive edge.</li> </ul> <p><b>Values:</b> 1, 2, 3, 4</p> <p><b>Default Value:</b> 2</p> <p><b>Enabled:</b> DMAX_SLVIF_CLOCK_MODE==1</p> <p><b>Parameter Name:</b> DMAX_C_2_S_SYNC_DEPTH</p>             |

**Table 3-4 Clocking Parameters (Continued)**

| Label                                                                                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DW_axi_dmac Master i Interface Clocking Mode<br>(for i = 1; i <= DMAX_NUM_MASTER_IF) | <p>Selects the relationship between the Master i Interface clock (aclk_m(i)) and the Core clock.</p> <ul style="list-style-type: none"> <li>■ 0: Master i interface clock is synchronous to the core clock.</li> <li>■ 1: Master i interface clock is asynchronous to the core clock.</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ Synchronous (0)</li> <li>■ Asynchronous (1)</li> </ul> <p><b>Default Value:</b> Synchronous</p> <p><b>Enabled:</b> Always</p> <p><b>Parameter Name:</b> DMAX_MSTIF(i)_CLOCK_MODE</p>                                                                                                                                                    |
| Master i to Core Synchronization Depth<br>(for i = 1; i <= DMAX_NUM_MASTER_IF)       | <p>Defines the number of synchronization register stages for signals passing from the DW_axi_dmac Master i clock domain to the DW_axi_dmac Core Clock domain.</p> <ul style="list-style-type: none"> <li>■ 1: Two-stage synchronization: First stage - negative edge; Second stage - positive edge.</li> <li>■ 2: Two-stage synchronization, both stages positive edge.</li> <li>■ 3: Three-stage synchronization, all stages positive edge.</li> <li>■ 4: Four-stage synchronization, all stages positive edge.</li> </ul> <p><b>Values:</b> 1, 2, 3, 4</p> <p><b>Default Value:</b> 2</p> <p><b>Enabled:</b> DMAX_MSTIF(i)_CLOCK_MODE == 1</p> <p><b>Parameter Name:</b> DMAX_M(i)_2_C_SYNC_DEPTH</p> |
| Core to Master i Synchronization Depth<br>(for i = 1; i <= DMAX_NUM_MASTER_IF)       | <p>Defines the number of synchronization register stages for signals passing from the DW_axi_dmac Core Clock domain to the Master i clock domain.</p> <ul style="list-style-type: none"> <li>■ 1: Two-stage synchronization: First stage - negative edge; Second stage - positive edge.</li> <li>■ 2: Two-stage synchronization, both stages positive edge.</li> <li>■ 3: Three-stage synchronization, all stages positive edge.</li> <li>■ 4: Four-stage synchronization, all stages positive edge.</li> </ul> <p><b>Values:</b> 1, 2, 3, 4</p> <p><b>Default Value:</b> 2</p> <p><b>Enabled:</b> DMAX_MSTIF(i)_CLOCK_MODE == 1</p> <p><b>Parameter Name:</b> DMAX_C_2_M(i)_SYNC_DEPTH</p>             |

**Table 3-4 Clocking Parameters (Continued)**

| Label                                                  | Description                                                                                                                                                                                                                                                                                                                                                                         |
|--------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Synchronizer FIFO Depths of Master Interface           |                                                                                                                                                                                                                                                                                                                                                                                     |
| Master Interface Read/Write Address Channel FIFO Depth | <p>AXI master interface read/write address channel FIFO depth. Setting appropriate value based on the system requirement allows some logic optimization of the implementation.</p> <p><b>Values:</b> 4, 8</p> <p><b>Default Value:</b> 4</p> <p><b>Enabled:</b> DMAX_MSTIF1_CLOCK_MODE == 1    DMAX_MSTIF2_CLOCK_MODE == 1</p> <p><b>Parameter Name:</b> DMAX_M_ADDR_FIFO_DEPTH</p> |
| Master Interface Read/Write Data Channel FIFO Depth    | <p>AXI master interface read/write data channel FIFO depth. Setting appropriate value based on the system requirement allows some logic optimization of the implementation.</p> <p><b>Values:</b> 4, 8</p> <p><b>Default Value:</b> 4</p> <p><b>Enabled:</b> DMAX_MSTIF1_CLOCK_MODE == 1    DMAX_MSTIF2_CLOCK_MODE == 1</p> <p><b>Parameter Name:</b> DMAX_M_DATA_FIFO_DEPTH</p>    |
| Master Interface Write Response Channel FIFO Depth     | <p>AXI master interface write response channel FIFO depth. Setting appropriate value based on the system requirement allows some logic optimization of the implementation.</p> <p><b>Values:</b> 4, 8</p> <p><b>Default Value:</b> 4</p> <p><b>Enabled:</b> DMAX_MSTIF1_CLOCK_MODE == 1    DMAX_MSTIF2_CLOCK_MODE == 1</p> <p><b>Parameter Name:</b> DMAX_M_BRESP_FIFO_DEPTH</p>    |
| Asynchronous Handshake Synchronization Options         |                                                                                                                                                                                                                                                                                                                                                                                     |
| Include Asynchronous DMA Handshake Support?            | <p>When set to Yes (1), allows you to include or exclude asynchronous DMA handshake support.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ No (0)</li> <li>■ Yes (1)</li> </ul> <p><b>Default Value:</b> No</p> <p><b>Enabled:</b> DMAX_NUM_HS_IF &gt; 0</p> <p><b>Parameter Name:</b> DMAX_ASYNC_HS_EN</p>                                                    |

**Table 3-4 Clocking Parameters (Continued)**

| Label                                                    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| All DMA Handshake Interface has Same Asynchronous Clock? | <p>When set to Yes (1), configures whether all DMA handshake interface has the same asynchronous clock.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ No (0)</li> <li>■ Yes (1)</li> </ul> <p><b>Default Value:</b> Yes</p> <p><b>Enabled:</b> DMAX_ASYNC_HS_EN == 1</p> <p><b>Parameter Name:</b> DMAX_HS_SAME_ASYNC_CLK</p>                                                                                                                                                                                                                                                                                                                                                    |
| Handshake to Core Synchronization Depth                  | <p>Defines the number of synchronization register stages for signals passing from the DW_axi_dmac handshake interface clock domain to the DW_axi_dmac Core Clock Domain.</p> <ul style="list-style-type: none"> <li>■ 1: Two-stage synchronization: First stage - negative edge; Second stage - positive edge.</li> <li>■ 2: Two-stage synchronization, both stages positive edge.</li> <li>■ 3: Three-stage synchronization, all stages positive edge.</li> <li>■ 4: Four-stage synchronization, all stages positive edge</li> </ul> <p><b>Values:</b> 1, 2, 3, 4</p> <p><b>Default Value:</b> 2</p> <p><b>Enabled:</b> DMAX_ASYNC_HS_EN==1</p> <p><b>Parameter Name:</b> DMAX_HS_2_C_SYNC_DEPTH</p> |
| Core to Handshake Synchronization Depth                  | <p>Defines the number of synchronization register stages for signals passing from the DW_axi_dmac Core Clock domain to handshake interface clock domain.</p> <ul style="list-style-type: none"> <li>■ 1: Two-stage synchronization: First stage - negative edge; Second stage - positive edge.</li> <li>■ 2: Two-stage synchronization, both stages positive edge.</li> <li>■ 3: Three-stage synchronization, all stages positive edge.</li> <li>■ 4: Four-stage synchronization, all stages positive edge</li> </ul> <p><b>Values:</b> 1, 2, 3, 4</p> <p><b>Default Value:</b> 2</p> <p><b>Enabled:</b> DMAX_ASYNC_HS_EN==1</p> <p><b>Parameter Name:</b> DMAX_C_2_HS_SYNC_DEPTH</p>                 |

**Table 3-4 Clocking Parameters (Continued)**

| Label                                                                                | Description                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DMAX_HS(y)_ASYNC_CLK                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                      |
| DMA Handshake interface y has asynchronous clock?<br>(for y = 1; y <= DMA_NUM_HS_IF) | <p>The DMA handshake interface y has asynchronous clock.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ false (0)</li> <li>■ true (1)</li> </ul> <p><b>Default Value:</b> (DMAX_HS_SAME_ASYNC_CLK==1) ? 1 : 0</p> <p><b>Enabled:</b> (DMAX_ASYNC_HS_EN == 1) &amp;&amp; (DMAX_HS_SAME_ASYNC_CLK == 0) &amp;&amp; (DMAX_NUM_HS_IF &gt;= y)</p> <p><b>Parameter Name:</b> DMAX_HS(y)_ASYNC_CLK</p> |

## 3.5 Low Power Configuration Parameters

**Table 3-5 Low Power Configuration Parameters**

| Label                                                                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Low Power Configuration                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Include Context Sensitive Low Power Feature?                         | <p>When set to Yes (1), allows you to include Context Sensitive Low Power feature. If enabled, it includes Global Context Sensitive Low Power feature and allows other Context Sensitive Low Power feature to be implemented optionally. Enabling this feature saves significant amount of power, with minimal area consumption.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ No (0)</li> <li>■ Yes (1)</li> </ul> <p><b>Default Value:</b> No</p> <p><b>Enabled:</b> Always</p> <p><b>Parameter Name:</b> DMAX_CSLP_EN</p> |
| Include Context Sensitive Low Power Feature in DMA Channels?         | <p>When set to Yes (1), includes the logic that implements Context Sensitive Low Power feature in DMA Channels.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ No (0)</li> <li>■ Yes (1)</li> </ul> <p><b>Default Value:</b> No</p> <p><b>Enabled:</b> DMAX_CSLP_EN == 1</p> <p><b>Parameter Name:</b> DMAX_CHNL_CSLP_EN</p>                                                                                                                                                                                                  |
| Include Context Sensitive Low Power Feature in Slave Bus Interface?  | <p>When set to Yes (1), includes the logic that implements Context Sensitive Low Power feature in Slave Bus Interface.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ No (0)</li> <li>■ Yes (1)</li> </ul> <p><b>Default Value:</b> No</p> <p><b>Enabled:</b> DMAX_CSLP_EN == 1</p> <p><b>Parameter Name:</b> DMAX_SBIU_CSLP_EN</p>                                                                                                                                                                                           |
| Include Context Sensitive Low Power Feature in AXI Master Interface? | <p>Include or exclude logic that implements Context Sensitive Low Power feature in Master Bus Interface.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ No (0)</li> <li>■ Yes (1)</li> </ul> <p><b>Default Value:</b> No</p> <p><b>Enabled:</b> DMAX_CSLP_EN == 1</p> <p><b>Parameter Name:</b> DMAX_MXIF_CSLP_EN</p>                                                                                                                                                                                                         |

**Table 3-5 Low Power Configuration Parameters (Continued)**

| Label                                                                | Description                                                                                                                                                                                                                                                                    |
|----------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Width of Global and DMA Channel Low Power Delay Counter              | <p>Defines the width of the Global and DMA Channel Low Power Delay Counter.</p> <p><b>Values:</b> 4, 5, 6, 7, 8</p> <p><b>Default Value:</b> 4</p> <p><b>Enabled:</b> DMAX_CSLP_EN == 1    DMAX_CHNL_CSLP_EN == 1</p> <p><b>Parameter Name:</b> DMAX_GLCH_LPDLY_WIDTH</p>      |
| Width of SBIU Low Power Delay Counter                                | <p>Defines the width of the SBIU Low Power Delay Counter.</p> <p><b>Values:</b> 4, 5, 6, 7, 8</p> <p><b>Default Value:</b> 4</p> <p><b>Enabled:</b> DMAX_SBIU_CSLP_EN == 1</p> <p><b>Parameter Name:</b> DMAX_SBIU_LPDLY_WIDTH</p>                                             |
| Width of AXI Master Interface Low Power Delay Counter                | <p>Defines the width of the AXI Master Interface Low Power Delay Counter.</p> <p><b>Values:</b> 4, 5, 6, 7, 8</p> <p><b>Default Value:</b> 4</p> <p><b>Enabled:</b> DMAX_MXIF_CSLP_EN == 1</p> <p><b>Parameter Name:</b> DMAX_MXIF_LPDLY_WIDTH</p>                             |
| Default load value of Global and DMA Channel Low Power Delay Counter | <p>Defines the default load value of the Global and DMA Channel Low Power Delay Counter.</p> <p><b>Values:</b> 4, ..., 255</p> <p><b>Default Value:</b> 4</p> <p><b>Enabled:</b> DMAX_CSLP_EN == 1    DMAX_CHNL_CSLP_EN == 1</p> <p><b>Parameter Name:</b> DMAX_GLCH_LPDLY</p> |
| Default load value of SBIU Low Power Delay Counter                   | <p>Defines the default load value of the SBIU Low Power Delay Counter.</p> <p><b>Values:</b> 4, ..., 255</p> <p><b>Default Value:</b> 4</p> <p><b>Enabled:</b> DMAX_SBIU_CSLP_EN == 1</p> <p><b>Parameter Name:</b> DMAX_SBIU_LPDLY</p>                                        |
| Default load value of AXI Master Interface Low Power Delay Counter   | <p>Defines the default load value of the AXI Master Interface Low Power Delay Counter.</p> <p><b>Values:</b> 4, ..., 255</p> <p><b>Default Value:</b> 4</p> <p><b>Enabled:</b> DMAX_MXIF_CSLP_EN == 1</p> <p><b>Parameter Name:</b> DMAX_MXIF_LPDLY</p>                        |

## 3.6 Channel x Configuration Parameters

**Table 3-6 Channel x Configuration Parameters**

| Label                                                                                       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Channel x Configuration                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Channel x FIFO Depth<br>(for x = 1; x <= DMAX_NUM_CHANNELS)                                 | <p>Channel x FIFO depth. Setting appropriate value based on the system requirement allows some logic optimization of the implementation.</p> <p><b>Values:</b> 4, 8, 16, 32, 64, 128, 256</p> <p><b>Default Value:</b> 8</p> <p><b>Enabled:</b> Always</p> <p><b>Parameter Name:</b> DMAX_CH(x)_FIFO_DEPTH</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Maximum Value of Burst Transaction Size<br>(for x = 1; x <= DMAX_NUM_CHANNELS)              | <p>Maximum value of burst transaction size that can be programmed for channel x (CH(x)_CTL.SRC_MSIZE and CH(x)_CTL.DST_MSIZE).</p> <p>Setting appropriate value based on the system requirement allows some logic optimization of the implementation.</p> <p><b>Values:</b> 1, 4, 8, 16, 32, 64, 128, 256, 512, 1024</p> <p><b>Default Value:</b> 8</p> <p><b>Enabled:</b> Always</p> <p><b>Parameter Name:</b> DMAX_CH(x)_MAX_MSIZE</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Maximum Value of Block Size in Source Transfer Width<br>(for x = 1; x <= DMAX_NUM_CHANNELS) | <p>The description of this parameter is dependent on what is assigned as the flow controller.</p> <ul style="list-style-type: none"> <li>■ If DW_axi_dmac is the flow controller: Maximum block size, in multiples of source transfer width (CH(x)_BLOCK_TS.BLOCK_TS), that can be programmed for channel x. A programmed value greater than this results in inconsistent behavior.</li> <li>■ If source/destination peripheral assigned as flow controller: In this case, the blocks can be greater than DMAX_CH(x)_MAX_BLOCK_TS in size, but the logic that keeps track of the size of a block saturates at DMAX_CH(x)_MAX_BLOCK_TS. This does not result in erroneous behavior, but a read back by software of the block size is incorrect when the block size exceeds the saturated value.</li> </ul> <p>Setting appropriate value based on the system requirement allows some logic optimization of the implementation.</p> <p><b>Values:</b> 3, 7, 15, 31, 63, 127, 255, 511, 1023, 2047, 4095, 8191, 16383, 32767, 65535, 131071, 262143, 524287, 1048575, 2097151, 4194303</p> <p><b>Default Value:</b> 31</p> <p><b>Enabled:</b> Always</p> <p><b>Parameter Name:</b> DMAX_CH(x)_MAX_BLOCK_TS</p> |

**Table 3-6 Channel x Configuration Parameters (Continued)**

| Label                                                                                                                             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                          |      |                  |     |      |                      |     |      |                      |     |      |                          |     |        |                      |     |        |                          |     |             |                      |     |             |                          |     |             |             |
|-----------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|------|------------------|-----|------|----------------------|-----|------|----------------------|-----|------|--------------------------|-----|--------|----------------------|-----|--------|--------------------------|-----|-------------|----------------------|-----|-------------|--------------------------|-----|-------------|-------------|
| Maximum Value of AMBA Burst Length<br>(for x = 1; x <= DMAX_NUM_CHANNELS)                                                         | <p>Maximum AMBA Burst Length for Channel x. Setting appropriate value based on the system requirement allows some logic optimization of the implementation by reducing the internal FIFO depth requirement.</p> <p><b>Dependencies:</b></p> <ul style="list-style-type: none"> <li>■ DMAX_CH(x)_MAX_AMBA_BURST_LENGTH &lt;= DMAX_CH(x)_MAX_BLOCK_TS</li> <li>■ DMAX_CH(x)_MAX_AMBA_BURST_LENGTH &lt;= DMAX_CH(x)_MAX_MSIZE</li> </ul> <p><b>Values:</b> 1, 4, 8, 16, 32, 64, 128, 256</p> <p><b>Default Value:</b> 8</p> <p><b>Enabled:</b> Always</p> <p><b>Parameter Name:</b> DMAX_CH(x)_MAX_AMBA_BURST_LENGTH</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                          |      |                  |     |      |                      |     |      |                      |     |      |                          |     |        |                      |     |        |                          |     |             |                      |     |             |                          |     |             |             |
| Include Logic to Enable Channel Locking on Channel x?<br>(for x = 1; x <= DMAX_NUM_CHANNELS)                                      | <p>When set to Yes (1), includes logic to enable channel locking on channel x. When set to 1, the software can program the DW_axi_dmac to lock the arbitration for the master bus interface over the DMA transfer, block transfer, or transaction. When set to No (0), this option allows some logic optimization of the implementation.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ No (0)</li> <li>■ Yes (1)</li> </ul> <p><b>Default Value:</b> No</p> <p><b>Enabled:</b> Always</p> <p><b>Parameter Name:</b> DMAX_CH(x)_LOCK_EN</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                          |      |                  |     |      |                      |     |      |                      |     |      |                          |     |        |                      |     |        |                          |     |             |                      |     |             |                          |     |             |             |
| Hardcode Channel x's transfer Type and Flow Control Device to Allow for Logic Optimization<br>(for x = 1; x <= DMAX_NUM_CHANNELS) | <p>Hardcodes the transfer type and flow control peripheral for the channel x. If NO_HARDCODE is selected, then the transfer type and flow control device is not hardcoded, and software selects the transfer type and flow control device for a DMA transfer.</p> <p>Hardcoding the transfer type and flow control device allows some logic optimization of the implementation.</p> <p><b>TT_FC Flow Controller Transfer Type</b></p> <table border="0"> <tr> <td>0x0</td> <td>DMAC</td> <td>Memory to Memory</td> </tr> <tr> <td>0x1</td> <td>DMAC</td> <td>Memory to Peripheral</td> </tr> <tr> <td>0x2</td> <td>DMAC</td> <td>Peripheral to Memory</td> </tr> <tr> <td>0x3</td> <td>DMAC</td> <td>Peripheral to Peripheral</td> </tr> <tr> <td>0x4</td> <td>Source</td> <td>Peripheral to Memory</td> </tr> <tr> <td>0x5</td> <td>Source</td> <td>Peripheral to Peripheral</td> </tr> <tr> <td>0x6</td> <td>Destination</td> <td>Memory to Peripheral</td> </tr> <tr> <td>0x7</td> <td>Destination</td> <td>Peripheral to Peripheral</td> </tr> <tr> <td>0x8</td> <td>No Hardcode</td> <td>No Hardcode</td> </tr> </table> <p><b>Values:</b> 0x0, 0x1, 0x2, 0x3, 0x4, 0x5, 0x6, 0x7, 0x8</p> <p><b>Default Value:</b> 0x8</p> <p><b>Enabled:</b> Always</p> <p><b>Parameter Name:</b> DMAX_CH(x)_TT_FC</p> | 0x0                      | DMAC | Memory to Memory | 0x1 | DMAC | Memory to Peripheral | 0x2 | DMAC | Peripheral to Memory | 0x3 | DMAC | Peripheral to Peripheral | 0x4 | Source | Peripheral to Memory | 0x5 | Source | Peripheral to Peripheral | 0x6 | Destination | Memory to Peripheral | 0x7 | Destination | Peripheral to Peripheral | 0x8 | No Hardcode | No Hardcode |
| 0x0                                                                                                                               | DMAC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Memory to Memory         |      |                  |     |      |                      |     |      |                      |     |      |                          |     |        |                      |     |        |                          |     |             |                      |     |             |                          |     |             |             |
| 0x1                                                                                                                               | DMAC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Memory to Peripheral     |      |                  |     |      |                      |     |      |                      |     |      |                          |     |        |                      |     |        |                          |     |             |                      |     |             |                          |     |             |             |
| 0x2                                                                                                                               | DMAC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Peripheral to Memory     |      |                  |     |      |                      |     |      |                      |     |      |                          |     |        |                      |     |        |                          |     |             |                      |     |             |                          |     |             |             |
| 0x3                                                                                                                               | DMAC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Peripheral to Peripheral |      |                  |     |      |                      |     |      |                      |     |      |                          |     |        |                      |     |        |                          |     |             |                      |     |             |                          |     |             |             |
| 0x4                                                                                                                               | Source                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Peripheral to Memory     |      |                  |     |      |                      |     |      |                      |     |      |                          |     |        |                      |     |        |                          |     |             |                      |     |             |                          |     |             |             |
| 0x5                                                                                                                               | Source                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Peripheral to Peripheral |      |                  |     |      |                      |     |      |                      |     |      |                          |     |        |                      |     |        |                          |     |             |                      |     |             |                          |     |             |             |
| 0x6                                                                                                                               | Destination                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Memory to Peripheral     |      |                  |     |      |                      |     |      |                      |     |      |                          |     |        |                      |     |        |                          |     |             |                      |     |             |                          |     |             |             |
| 0x7                                                                                                                               | Destination                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Peripheral to Peripheral |      |                  |     |      |                      |     |      |                      |     |      |                          |     |        |                      |     |        |                          |     |             |                      |     |             |                          |     |             |             |
| 0x8                                                                                                                               | No Hardcode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | No Hardcode              |      |                  |     |      |                      |     |      |                      |     |      |                          |     |        |                      |     |        |                          |     |             |                      |     |             |                          |     |             |             |

**Table 3-6 Channel x Configuration Parameters (Continued)**

| Label                                                                                                                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Hardcode the Master Interface Attached to the Source of Channel x<br>(for $x = 1; x \leq DMAX\_NUM\_CHANNELS$ )      | <p>Hardcode the AXI master interface attached to the source of channel x. If this is not hardcoded, software can program the source of channel x to be attached to any of the configured layers. Hardcoding this value allows some logic optimization of the implementation.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ Master 1 (0x0)</li> <li>■ Master 2 (0x1)</li> <li>■ No Hardcode (0x2)</li> </ul> <p><b>Default Value:</b> <math>DMAX\_NUM\_MASTER\_IF == 1 ? 0 : 2</math></p> <p><b>Enabled:</b> <math>DMAX\_NUM\_MASTER\_IF &gt; 1</math></p> <p><b>Parameter Name:</b> <math>DMAX\_CH(x)\_SMS</math></p>                             |
| Hardcode the Master Interface Attached to the Destination of Channel x<br>(for $x = 1; x \leq DMAX\_NUM\_CHANNELS$ ) | <p>Hardcode the AXI master interface attached to the channel x destination. If this is not hardcoded, then software can program the destination of channel x to be attached to any of the configured layers. Hardcoding this value allows some logic optimization of the implementation.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ Master 1 (0x0)</li> <li>■ Master 2 (0x1)</li> <li>■ No Hardcode (0x2)</li> </ul> <p><b>Default Value:</b> <math>DMAX\_NUM\_MASTER\_IF == 1 ? 0 : 2</math></p> <p><b>Enabled:</b> <math>DMAX\_NUM\_MASTER\_IF &gt; 1</math></p> <p><b>Parameter Name:</b> <math>DMAX\_CH(x)\_DMS</math></p>                 |
| Hardcode Channel x's Source Transfer Width<br>(for $x = 1; x \leq DMAX\_NUM\_CHANNELS$ )                             | <p>Hardcode the source transfer width for transfers from the source of channel x. If this is not hardcoded, then software can program the source transfer width. Hardcoding the source transfer width allows some logic optimization of the implementation.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ No Hardcode (0)</li> <li>■ Byte (8)</li> <li>■ Half Word (16)</li> <li>■ Word (32)</li> <li>■ Two Word (64)</li> <li>■ Four Word (128)</li> <li>■ Eight Word (256)</li> <li>■ Sixteen Word (512)</li> </ul> <p><b>Default Value:</b> Word</p> <p><b>Enabled:</b> Always</p> <p><b>Parameter Name:</b> <math>DMAX\_CH(x)\_STW</math></p> |

**Table 3-6 Channel x Configuration Parameters (Continued)**

| Label                                                                                                 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Hardcode Channel x's Destination Transfer Width<br>(for x = 1; x <= DMAX_NUM_CHANNELS)                | <p>Hardcode the destination transfer width for transfers to the destination of channel x. If this is not hardcoded, then software can program the destination transfer width. Hardcoding the destination transfer width allows some logic optimization of the implementation.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ No Hardcode (0)</li> <li>■ Byte (8)</li> <li>■ Half Word (16)</li> <li>■ Word (32)</li> <li>■ Two Word (64)</li> <li>■ Four Word (128)</li> <li>■ Eight Word (256)</li> <li>■ Sixteen Word (512)</li> </ul> <p><b>Default Value:</b> Word</p> <p><b>Enabled:</b> Always</p> <p><b>Parameter Name:</b> DMAX_CH(x)_DTW</p> |
| Include Logic to Enable Multiblock DMA Transfers on Channel x?<br>(for x = 1; x <= DMAX_NUM_CHANNELS) | <p>Includes or excludes logic to enable multi-block DMA transfers on channel x. If this option is set to 0, then hardware hardwires channel x to perform only single block transfers. Setting this parameter to 0 allows some logic optimization of the implementation.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ false (0)</li> <li>■ true (1)</li> </ul> <p><b>Default Value:</b> false</p> <p><b>Enabled:</b> Always</p> <p><b>Parameter Name:</b> DMAX_CH(x)_MULTI_BLK_EN</p>                                                                                                                                                                |

**Table 3-6 Channel x Configuration Parameters (Continued)**

| Label                                                                       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                 |             |             |     |            |                |     |            |                 |     |                |            |     |                |                |     |                |                 |     |                 |            |     |                 |                |     |                 |                 |     |            |             |     |                |             |     |             |            |     |             |                |     |             |             |
|-----------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-------------|-------------|-----|------------|----------------|-----|------------|-----------------|-----|----------------|------------|-----|----------------|----------------|-----|----------------|-----------------|-----|-----------------|------------|-----|-----------------|----------------|-----|-----------------|-----------------|-----|------------|-------------|-----|----------------|-------------|-----|-------------|------------|-----|-------------|----------------|-----|-------------|-------------|
| Hardcode Multi-block Transfer Type?<br>(for x = 1; x <= DMAX_NUM_CHANNELS)  | <p>This parameter allows to hardcode the type of multi-block transfers DW_axi_dmac can perform on channel x. This results in some logic optimization of the implementation.</p> <p><b>MULTI_BLK_TYPE Source Multi Block Type Destination Multi Block Type</b></p> <table> <tr><td>0x0</td><td>No Hardcode</td><td>No Hardcode</td></tr> <tr><td>0x1</td><td>Contiguous</td><td>Auto Reloading</td></tr> <tr><td>0x2</td><td>Contiguous</td><td>Shadow Register</td></tr> <tr><td>0x3</td><td>Auto Reloading</td><td>Contiguous</td></tr> <tr><td>0x4</td><td>Auto Reloading</td><td>Auto Reloading</td></tr> <tr><td>0x5</td><td>Auto Reloading</td><td>Shadow Register</td></tr> <tr><td>0x6</td><td>Shadow Register</td><td>Contiguous</td></tr> <tr><td>0x7</td><td>Shadow Register</td><td>Auto Reloading</td></tr> <tr><td>0x8</td><td>Shadow Register</td><td>Shadow Register</td></tr> <tr><td>0x9</td><td>Contiguous</td><td>Linked List</td></tr> <tr><td>0xa</td><td>Auto Reloading</td><td>Linked List</td></tr> <tr><td>0xb</td><td>Linked List</td><td>Contiguous</td></tr> <tr><td>0xc</td><td>Linked List</td><td>Auto Reloading</td></tr> <tr><td>0xd</td><td>Linked List</td><td>Linked List</td></tr> </table> <p><b>Values:</b> 0x0, 0x1, 0x2, 0x3, 0x4, 0x5, 0x6, 0x7, 0x8, 0x9, 0xa, 0xb, 0xc, 0xd<br/> <b>Default Value:</b> 0x0<br/> <b>Enabled:</b> DMAX_CH(x)_MULTI_BLK_EN==1<br/> <b>Parameter Name:</b> DMAX_CH(x)_MULTI_BLK_TYPE</p> | 0x0             | No Hardcode | No Hardcode | 0x1 | Contiguous | Auto Reloading | 0x2 | Contiguous | Shadow Register | 0x3 | Auto Reloading | Contiguous | 0x4 | Auto Reloading | Auto Reloading | 0x5 | Auto Reloading | Shadow Register | 0x6 | Shadow Register | Contiguous | 0x7 | Shadow Register | Auto Reloading | 0x8 | Shadow Register | Shadow Register | 0x9 | Contiguous | Linked List | 0xa | Auto Reloading | Linked List | 0xb | Linked List | Contiguous | 0xc | Linked List | Auto Reloading | 0xd | Linked List | Linked List |
| 0x0                                                                         | No Hardcode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | No Hardcode     |             |             |     |            |                |     |            |                 |     |                |            |     |                |                |     |                |                 |     |                 |            |     |                 |                |     |                 |                 |     |            |             |     |                |             |     |             |            |     |             |                |     |             |             |
| 0x1                                                                         | Contiguous                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Auto Reloading  |             |             |     |            |                |     |            |                 |     |                |            |     |                |                |     |                |                 |     |                 |            |     |                 |                |     |                 |                 |     |            |             |     |                |             |     |             |            |     |             |                |     |             |             |
| 0x2                                                                         | Contiguous                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Shadow Register |             |             |     |            |                |     |            |                 |     |                |            |     |                |                |     |                |                 |     |                 |            |     |                 |                |     |                 |                 |     |            |             |     |                |             |     |             |            |     |             |                |     |             |             |
| 0x3                                                                         | Auto Reloading                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Contiguous      |             |             |     |            |                |     |            |                 |     |                |            |     |                |                |     |                |                 |     |                 |            |     |                 |                |     |                 |                 |     |            |             |     |                |             |     |             |            |     |             |                |     |             |             |
| 0x4                                                                         | Auto Reloading                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Auto Reloading  |             |             |     |            |                |     |            |                 |     |                |            |     |                |                |     |                |                 |     |                 |            |     |                 |                |     |                 |                 |     |            |             |     |                |             |     |             |            |     |             |                |     |             |             |
| 0x5                                                                         | Auto Reloading                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Shadow Register |             |             |     |            |                |     |            |                 |     |                |            |     |                |                |     |                |                 |     |                 |            |     |                 |                |     |                 |                 |     |            |             |     |                |             |     |             |            |     |             |                |     |             |             |
| 0x6                                                                         | Shadow Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Contiguous      |             |             |     |            |                |     |            |                 |     |                |            |     |                |                |     |                |                 |     |                 |            |     |                 |                |     |                 |                 |     |            |             |     |                |             |     |             |            |     |             |                |     |             |             |
| 0x7                                                                         | Shadow Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Auto Reloading  |             |             |     |            |                |     |            |                 |     |                |            |     |                |                |     |                |                 |     |                 |            |     |                 |                |     |                 |                 |     |            |             |     |                |             |     |             |            |     |             |                |     |             |             |
| 0x8                                                                         | Shadow Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Shadow Register |             |             |     |            |                |     |            |                 |     |                |            |     |                |                |     |                |                 |     |                 |            |     |                 |                |     |                 |                 |     |            |             |     |                |             |     |             |            |     |             |                |     |             |             |
| 0x9                                                                         | Contiguous                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Linked List     |             |             |     |            |                |     |            |                 |     |                |            |     |                |                |     |                |                 |     |                 |            |     |                 |                |     |                 |                 |     |            |             |     |                |             |     |             |            |     |             |                |     |             |             |
| 0xa                                                                         | Auto Reloading                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Linked List     |             |             |     |            |                |     |            |                 |     |                |            |     |                |                |     |                |                 |     |                 |            |     |                 |                |     |                 |                 |     |            |             |     |                |             |     |             |            |     |             |                |     |             |             |
| 0xb                                                                         | Linked List                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Contiguous      |             |             |     |            |                |     |            |                 |     |                |            |     |                |                |     |                |                 |     |                 |            |     |                 |                |     |                 |                 |     |            |             |     |                |             |     |             |            |     |             |                |     |             |             |
| 0xc                                                                         | Linked List                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Auto Reloading  |             |             |     |            |                |     |            |                 |     |                |            |     |                |                |     |                |                 |     |                 |            |     |                 |                |     |                 |                 |     |            |             |     |                |             |     |             |            |     |             |                |     |             |             |
| 0xd                                                                         | Linked List                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Linked List     |             |             |     |            |                |     |            |                 |     |                |            |     |                |                |     |                |                 |     |                 |            |     |                 |                |     |                 |                 |     |            |             |     |                |             |     |             |            |     |             |                |     |             |             |
| Enable LLI Prefetching on Channel x?<br>(for x = 1; x <= DMAX_NUM_CHANNELS) | <p>Set this parameter to 1 to enable the LLI prefetching logic on channel x. If this parameter is enabled, DW_axi_dmac tries to fetch one LLI in advance (while the data transfer corresponding to the previous LLI is in progress) and store internally and thus increases bus utilization. Enabling this parameter doesn't guarantee that LLI will be always pre-fetched. This parameter needs to be enabled only if linked-list-based multi-block transfer is used. Setting this parameter to 0 allows some logic optimization of the implementation.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ false (0)</li> <li>■ true (1)</li> </ul> <p><b>Default Value:</b> false<br/> <b>Enabled:</b> Disabled if DMAX_CH(x)_MULTI_BLK_EN = 0 or If DMAX_CH(x)_MULTI_BLK_TYPE is hardcoded to a value that does not use LLI<br/> <b>Parameter Name:</b> DMAX_CH(x)_LLI_PREFETCH_EN</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                 |             |             |     |            |                |     |            |                 |     |                |            |     |                |                |     |                |                 |     |                 |            |     |                 |                |     |                 |                 |     |            |             |     |                |             |     |             |            |     |             |                |     |             |             |

**Table 3-6 Channel x Configuration Parameters (Continued)**

| Label                                                                                                            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Include Shadow Registers on Channel x?<br>(for x = 1; x <= DMAX_NUM_CHANNELS)                                    | <p>Set this parameter to 1 to include shadow registers on channel x. This parameter needs to be enabled only if shadow register based multi-block transfer is used. Setting this parameter to 0 allows some logic optimization of the implementation.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ false (0)</li> <li>■ true (1)</li> </ul> <p><b>Default Value:</b> false</p> <p><b>Enabled:</b> Not enabled if DMAX_CH(x)_MULTI_BLK_EN = 0 and DMAX_CH(x)_MULTI_BLK_TYPE is hardcoded to a value that does not use shadow</p> <p><b>Parameter Name:</b> DMAX_CH(x)_SHADOW_REG_EN</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Hardcode the Master Interface Attached to the LLP peripheral of channel x<br>(for x = 1; x <= DMAX_NUM_CHANNELS) | <p>Hardcode the AXI master interface attached to the peripheral that stores the LLI information (Linked List Item) for channel x. If this is not hardcoded, then software can program the peripheral that stores the LLI information of channel x to be attached to any of the configured layers. Hardcoding this value allows some logic optimization of the implementation.</p> <p>LLI access always uses the burst size (arsize/awsize) that is same as the data bus width. LLI access cannot be changed or programmed to anything other than this value. Burst length (awlen/arlen) is chosen based on the data bus width so that the access does not cross one complete LLI structure of 64 bytes. DW_axi_dmac fetches the entire LLI (40 bytes) in one AXI burst if the burst length is not limited by other settings.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ Master 1 (0x0)</li> <li>■ Master 2 (0x1)</li> <li>■ No Hardcode (0x2)</li> </ul> <p><b>Default Value:</b> DMAX_NUM_MASTER_IF == 1 ? 0 : 2</p> <p><b>Enabled:</b> Enabled only when channel has LLI multi-block transfers enabled</p> <p><b>Parameter Name:</b> DMAX_CH(x)_LMS</p> |
| Fetch Status From Source of Channel x<br>(for x = 1; x <= DMAX_NUM_CHANNELS)                                     | <p>Include or exclude logic to fetch status from source peripheral of channel x pointed to by the content of CH(x)_SSTATAR register and store it in CHx_SSTAT register if CH(x)_CTL.SRC_STAT_EN bit is set to 1. This value is written back to the CH(x)_SSTAT location of linked list at end of each block transfer if DMAX_CH(x)_LLI_WB_EN is set to 1 and if linked-list-based multiblock transfer is used by either source or destination peripheral. Setting this parameter to 0 allows some logic optimization of the implementation.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ false (0)</li> <li>■ true (1)</li> </ul> <p><b>Default Value:</b> false</p> <p><b>Enabled:</b> Always</p> <p><b>Parameter Name:</b> DMAX_CH(x)_SRC_STAT_EN</p>                                                                                                                                                                                                                                                                                                                                                                                                     |

**Table 3-6 Channel x Configuration Parameters (Continued)**

| Label                                                                                                         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Fetch Status From Destination of Channel x<br>(for x = 1; x <= DMAX_NUM_CHANNELS)                             | <p>Include or exclude logic to fetch status from destination peripheral of channel x pointed to by the content of CHx_DSTATAR register and store it in CH(x)_DSTAT register if CH(x)_CTL.DST_STAT_EN bit is set to 1. This value is written back to the CH(x)_DSTAT location of linked list at end of each block transfer if DMAX_CH(x)_LLI_WB_EN is set to 1 and if linked-list-based multiblock transfer is used by either source or destination peripheral. Setting this parameter to 0 allows some logic optimization of the implementation.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ false (0)</li> <li>■ true (1)</li> </ul> <p><b>Default Value:</b> false</p> <p><b>Enabled:</b> Always</p> <p><b>Parameter Name:</b> DMAX_CH(x)_DST_STAT_EN</p> |
| Include Logic to Enable Register Write-back After Each Block Transfer?<br>(for x = 1; x <= DMAX_NUM_CHANNELS) | <p>Includes or excludes logic to enable write-back of the CH(x)_CTL, CH(x)_LLP_STATUS, CH(x)_SSTAT and CHx_DSTAT registers at the end of every block transfer. Write back happens only if linked-list-based multi-block transfer is used by either source or destination peripheral. Setting this parameter to 0 allows some logic optimization of the implementation.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ false (0)</li> <li>■ true (1)</li> </ul> <p><b>Default Value:</b> false</p> <p><b>Enabled:</b> DMAX_CH(x)_MULTI_BLK_TYPE == 0 or DMAX_CH(x)_MULTI_BLK_TYPE &gt;8</p> <p><b>Parameter Name:</b> DMAX_CH(x)_LLI_WB_EN</p>                                                                                                                  |

Synopsys confidential document, provided to Blue Ocean Smart under NDA, do not redistribute

## 4

# Signal Descriptions

This chapter details all possible I/O signals in the core. For configurable IP titles, your actual configuration might not contain all of these signals.

Inputs are on the left of the signal diagrams; outputs are on the right.

**Attention: For configurable IP titles, do not use this document to determine the exact I/O footprint of the core. It is for reference purposes only.**

When you configure the core in coreConsultant, you must access the I/O signals for your actual configuration at workspace/report/IO.html or workspace/report/IO.xml after you have completed the report creation activity. That report comes from the exact same source as this chapter but removes all the I/O signals that are not in your actual configuration. This does not apply to non-configurable IP titles. In addition, all parameter expressions are evaluated to actual values. Therefore, the widths might change depending on your actual configuration.

Some expressions might refer to TCL functions or procedures (sometimes identified as <functionof>) that coreConsultant uses to make calculations. The exact formula used by these TCL functions is not provided in this chapter. However, when you configure the core in coreConsultant, all TCL functions and parameters are evaluated completely; and the resulting values are displayed where appropriate in the coreConsultant GUI reports.

In addition to describing the function of each signal, the signal descriptions in this chapter include the following information:

**Active State:** Indicates whether the signal is active high or active low. When a signal is not intended to be used in a particular application, then this signal needs to be tied or driven to the in-active state (opposite of the active state).

**Registered:** Indicates whether or not the signal is registered directly inside the IP boundary without intervening logic (excluding simple buffers). A value of No does not imply that the signal is not synchronous, only that there is some combinatorial logic between the signal's origin or destination register and the boundary of the controller. A value of N/A indicates that this information is not provided for this IP title.

**Synchronous to:** Indicates which clock(s) in the IP sample this input (drive for an output) when considering all possible configurations. A particular configuration might not have all of the clocks listed. This clock might not be the same as the clock that your application logic should use to clock (sample/drive) this pin. For more details, consult the clock section in the databook.

**Exists:** Name of configuration parameter(s) that populates this signal in your configuration.

**Validated by:** Assertion or de-assertion of signal(s) that validates the signal being described.

The I/O signals are grouped as follows:

- Core Clock and Reset on [page 125](#)
- Test Interface on [page 126](#)
- AHB Signals on [page 127](#)
- Master Interface on [page 130](#)
- Hardware Handshaking Signals on [page 141](#)
- Debug Interface Signals on [page 144](#)
- Interrupt Interface Signals on [page 153](#)
- Low Power Interface Signals on [page 154](#)

Synopsys confidential document, provided to Blue Ocean Smart under NDA, do not redistribute

## 4.1 Core Clock and Reset Signals



**Table 4-1 Core Clock and Reset Signals**

| Port Name        | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| dmac_core_resetn | I   | DW_axi_dmac core reset. Active low input that asynchronously resets the DW_axi_dmac. The reset must be synchronously deasserted after the rising edge of dmac_core_clock. DW_axi_dmac does not contain logic to perform this synchronization, so it must be provided externally.<br><b>Exists:</b> Always<br><b>Synchronous To:</b> None<br><b>Registered:</b> N/A<br><b>Power Domain:</b> SINGLE_DOMAIN<br><b>Active State:</b> Low |
| dmac_core_clock  | I   | DW_axi_dmac core clock.<br><b>Exists:</b> Always<br><b>Synchronous To:</b> None<br><b>Registered:</b> N/A<br><b>Power Domain:</b> SINGLE_DOMAIN<br><b>Active State:</b> N/A                                                                                                                                                                                                                                                          |

## 4.2 Test Interface Signals



Table 4-2 Test Interface Signals

| Port Name | I/O | Description                                                                                                                                                                                                                                                                                                                     |
|-----------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| scan_mode | I   | <p>Scan Mode. This signal should be asserted during scan testing and should be de-asserted (tied to logic 0) at all the other times.</p> <p><b>Exists:</b> (DMAX_CSLP_EN == 1)</p> <p><b>Synchronous To:</b> None</p> <p><b>Registered:</b> N/A</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High.</p> |

## 4.3 AHB Signals



**Table 4-3 AHB Signals**

| Port Name | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| hclk      | I   | <p>AHB slave interface clock.</p> <p><b>Exists:</b> (DMAX_SLVIF_CLOCK_MODE == 1)</p> <p><b>Synchronous To:</b> None</p> <p><b>Registered:</b> N/A</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p>                                                                                                                                                                                                                                     |
| hresetn   | I   | <p>AHB slave interface reset. Asynchronous assertion, synchronous de-assertion. The reset must be synchronously de-asserted after the rising edge of hclk. DW_axi_dmac does not contain logic to perform this synchronization, so it must be provided externally.</p> <p><b>Exists:</b> (DMAX_SLVIF_CLOCK_MODE == 1)</p> <p><b>Synchronous To:</b> None</p> <p><b>Registered:</b> N/A</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> Low</p> |
| hsel      | I   | <p>Slave select. Asserted when the current transfer to the AHB bus is intended for the DW_axi_dmac.</p> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> (DMAX_SLVIF_CLOCK_MODE == 1) ? "hclk" : "dmac_core_clock"</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p>                                                                                                                                |

**Table 4-3 AHB Signals (Continued)**

| <b>Port Name</b> | <b>I/O</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                             |
|------------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| haddr[31:0]      | I          | <p>Address.</p> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> (DMAX_SLVIF_CLOCK_MODE == 1) ? "hclk" : "dmac_core_clock"</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p>                                                                                                                                    |
| hsize[2:0]       | I          | <p>Transfer size.</p> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> (DMAX_SLVIF_CLOCK_MODE == 1) ? "hclk" : "dmac_core_clock"</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p>                                                                                                                              |
| htrans[1:0]      | I          | <p>Transfer type.</p> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> (DMAX_SLVIF_CLOCK_MODE == 1) ? "hclk" : "dmac_core_clock"</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p>                                                                                                                              |
| hready           | I          | <p>Current transfer is complete.</p> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> (DMAX_SLVIF_CLOCK_MODE == 1) ? "hclk" : "dmac_core_clock"</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p>                                                                                                              |
| hwrite           | I          | <p>Transfer direction. When high, this signal indicates a write transfer. When low, this signal indicates a read transfer.</p> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> (DMAX_SLVIF_CLOCK_MODE == 1) ? "hclk" : "dmac_core_clock"</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> 1 for Write, 0 for Read</p> |

**Table 4-3 AHB Signals (Continued)**

| Port Name                      | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------------------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| hwdata[(DMA_S_DATA_WIDTH-1):0] | I   | <p>Write data to slave.</p> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> (DMA_SLVIF_CLOCK_MODE == 1) ? "hclk" : "dmac_core_clock"</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p>                                                                                                                                                                                                                             |
| hrdata[(DMA_S_DATA_WIDTH-1):0] | O   | <p>Read data from slave.</p> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> (DMA_SLVIF_CLOCK_MODE == 1) ? "hclk" : "dmac_core_clock"</p> <p><b>Registered:</b> Yes</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p>                                                                                                                                                                                                                           |
| hresp[1:0]                     | O   | <p>Response type from slave. When the DW_axi_dmac is configured for the AHB Lite mode and instantiated in an AHB Lite system, the hresp[0] signal is connected to the hresp signal in the AHB bus fabric; the hresp[1] signal is left unconnected.</p> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> (DMA_SLVIF_CLOCK_MODE == 1) ? "hclk" : "dmac_core_clock"</p> <p><b>Registered:</b> Yes</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p> |
| hready_resp                    | O   | <p>Transfer complete.</p> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> (DMA_SLVIF_CLOCK_MODE == 1) ? "hclk" : "dmac_core_clock"</p> <p><b>Registered:</b> Yes</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p>                                                                                                                                                                                                                             |

## 4.4 Master Interface (for i = 1; i <= DMAX\_NUM\_MASTER\_IF) Signals

|                             |                 |
|-----------------------------|-----------------|
| aclk_mi                     | - awid_mi       |
| aresetn_mi                  | - awaddr_mi     |
| awready_mi                  | - awlen_mi      |
| arready_mi                  | - awsize_mi     |
| wready_mi                   | - awburst_mi    |
| rid_mi                      | - awlock_mi     |
| rdata_mi                    | - awcache_mi    |
| rresp_mi                    | - awprot_mi     |
| rlast_mi                    | - awqos_mi      |
| rvalid_mi                   | - awvalid_mi    |
| bid_mi                      | - arid_mi       |
| bvalid_mi                   | - araddr_mi     |
| bresp_mi                    | - arlen_mi      |
| dmac_endian_format_mstif_mi | - arsize_mi     |
| dmac_le_select_lli_mstif_mi | - arburst_mi    |
|                             | - arlock_mi     |
|                             | - arcache_mi    |
|                             | - arprot_mi     |
|                             | - arqos_mi      |
|                             | - arvalid_mi    |
|                             | - wid_mi        |
|                             | - wdata_mi      |
|                             | - wstrb_mi      |
|                             | - wlast_mi      |
|                             | - wvalid_mi     |
|                             | - rready_mi     |
|                             | - bready_mi     |
|                             | - last_write_mi |

**Table 4-4 Master Interface (for i = 1; i <= DMAX\_NUM\_MASTER\_IF) Signals**

| Port Name | I/O | Description                                                                                                                                                                                                    |
|-----------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| aclk_mi   | I   | AXI3/AXI4 Master i interface clock.<br><b>Exists:</b> (DMAX_MSTIF1_CLOCK_MODE == 1)<br><b>Synchronous To:</b> None<br><b>Registered:</b> N/A<br><b>Power Domain:</b> SINGLE_DOMAIN<br><b>Active State:</b> N/A |

**Table 4-4 Master Interface (for i = 1; i <= DMAX\_NUM\_MASTER\_IF) Signals (Continued)**

| Port Name                              | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------------------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| aresetn_mi                             | I   | <p>AXI3/AXI4 Master i interface reset. Active low input that asynchronously resets the AXI3/AXI4 Master i interface to its default state. Asynchronous assertion, synchronous de-assertion. The reset must be synchronously de-asserted after the rising edge of aclk_mi/dmac_core_clk. DW_axi_dmac does not contain logic to perform this synchronization, so it must be provided externally.</p> <p><b>Exists:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1)</p> <p><b>Synchronous To:</b> None</p> <p><b>Registered:</b> N/A</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> Low</p>                                          |
| awid_mi[(DMAX_M_ID_WIDTH-1):0]         | O   | <p>AXI3/AXI4 Master i interface write address ID. Identification tag for the write address group of signals. The upper 4 bits of awid_mi is derived from the channel number of the channel that is currently accessing the master interface (channel 1 = 4'b0000, channel 8 = 4'b0111, and so on). The lower bits are the same as the value programmed in the CHx_AXI_IDReg.AXI_Write_ID_Suffix field.</p> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock"</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p> |
| awaddr_mi[(DMAX_M_ADDR_WIDTH-1):0]     | O   | <p>AXI3/AXI4 Master i interface write address. Specifies the address of the AXI write burst transaction.</p> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock"</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p>                                                                                                                                                                                                                                                                                               |
| awlen_mi[(DMAX_M_BURSTLEN_WIDT H-1):0] | O   | <p>AXI3/AXI4 Master i interface write burst length.</p> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock"</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p>                                                                                                                                                                                                                                                                                                                                                    |

**Table 4-4 Master Interface (for i = 1; i <= DMAX\_NUM\_MASTER\_IF) Signals (Continued)**

| Port Name                            | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------------------------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| awsize_mi[2:0]                       | O   | <p>AXI3/AXI4 Master i interface write burst size.</p> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock"</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p>                                                                                                                                                                                                       |
| awburst_mi[1:0]                      | O   | <p>AXI3/AXI4 Master i interface write burst type.</p> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock"</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p>                                                                                                                                                                                                       |
| awlock_mi[(DMAX_AXI_LOCK_WIDTH-1):0] | O   | <p>AXI3/AXI4 Master i interface write lock type.</p> <ul style="list-style-type: none"> <li>■ awlock_mi[0] = 0 as DW_axi_dmac does not initiate exclusive transactions.</li> <li>■ awlock_mi[1] = 0 as DW_axi_dmac does not support AXI bus locking.</li> <li>■ awlock_mi[1] is not available in AXI4 mode.</li> </ul> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> None</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p> |
| awcache_mi[3:0]                      | O   | <p>AXI3/AXI4 Master i interface write cache type. CHx_CTL.AWCACHE field determines the value of this signal.</p> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock"</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p>                                                                                                                                            |
| awprot_mi[2:0]                       | O   | <p>AXI3/AXI4 Master i interface write protection type. CHx_CTL.AWPROT field determines the value of this signal.</p> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock"</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p>                                                                                                                                        |

**Table 4-4 Master Interface (for i = 1; i <= DMAX\_NUM\_MASTER\_IF) Signals (Continued)**

| Port Name     | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| awqos_mi[3:0] | O   | <p>AXI4 Master i interface Quality Of Service signal for write channel. The value of awqos_mi is the same as the value programmed in the CHx_AXI_QoSReg.AXI_AWQOS field of the channel that is currently accessing the master interface.</p> <p><b>Exists:</b> (DMAX_HAS_QOS == 1)</p> <p><b>Synchronous To:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock"</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p> |
| awvalid_mi    | O   | <p>AXI3/AXI4 Master i interface write address valid. Indicates the availability of valid write address and associated control signals.</p> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock"</p> <p><b>Registered:</b> (DMAX_HOLD_IO_EN == 1) ? "No": "Yes"</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p>                                                                             |
| awready_mi    | I   | <p>AXI3/AXI4 Master i interface write address ready. Indicates the AXI slave readiness to accept write address and associated control signals.</p> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock"</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p>                                                                                                       |

**Table 4-4 Master Interface (for i = 1; i <= DMAX\_NUM\_MASTER\_IF) Signals (Continued)**

| Port Name                             | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------------------------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| arid_mi[(DMAX_M_ID_WIDTH-1):0]        | O   | <p>AXI3/AXI4 Master i interface read address ID. Identification tag for the read address group of signals. The upper 4 bits of arid_mi is derived from the channel number of the channel that is currently accessing the master interface. This varies for LLI fetch and source data transfer.</p> <ul style="list-style-type: none"> <li>■ For source data transfer, arid_mi for channel 1 = 4'b0000, arid_mi for channel 8 = 4'b0111, and so on.</li> <li>■ For LLI fetch access, arid_mi for channel 1 = 4'b1000, arid_mi for channel 8 = 4'b1111, and so on. Lower bits are the same as the value programmed in the CHx_AXI_IDReg.AXI_Read_ID_Suffix field.</li> </ul> <p><b>Exists:</b> Always<br/> <b>Synchronous To:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock"<br/> <b>Registered:</b> No<br/> <b>Power Domain:</b> SINGLE_DOMAIN<br/> <b>Active State:</b> N/A</p> |
| araddr_mi[(DMAX_M_ADDR_WIDTH-1):0]    | O   | <p>AXI3/AXI4 Master i interface read address. Specifies the address of the AXI read burst transaction.</p> <p><b>Exists:</b> Always<br/> <b>Synchronous To:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock"<br/> <b>Registered:</b> No<br/> <b>Power Domain:</b> SINGLE_DOMAIN<br/> <b>Active State:</b> N/A</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| arlen_mi[(DMAX_M_BURSTLEN_WIDTH-1):0] | O   | <p>AXI3/AXI4 Master i interface read burst length.</p> <p><b>Exists:</b> Always<br/> <b>Synchronous To:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock"<br/> <b>Registered:</b> No<br/> <b>Power Domain:</b> SINGLE_DOMAIN<br/> <b>Active State:</b> N/A</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| arsize_mi[2:0]                        | O   | <p>AXI3/AXI4 Master i interface read burst size.</p> <p><b>Exists:</b> Always<br/> <b>Synchronous To:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock"<br/> <b>Registered:</b> No<br/> <b>Power Domain:</b> SINGLE_DOMAIN<br/> <b>Active State:</b> N/A</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

**Table 4-4 Master Interface (for i = 1; i <= DMAX\_NUM\_MASTER\_IF) Signals (Continued)**

| Port Name                            | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------------------------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| arburst_mi[1:0]                      | O   | <p>AXI3/AXI4 Master i interface read burst type.</p> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock"</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p>                                                                                                                                                                                             |
| arlock_mi[(DMAX_AXI_LOCK_WIDTH-1):0] | O   | <p>AXI3/AXI4 Master i interface read lock type.</p> <ul style="list-style-type: none"> <li>■ arlock_mi [0] = 0 as DW_axi_dmac does not initiate exclusive transactions.</li> <li>■ arlock_mi [1] = 0 as DW_axi_dmac does not support AXI bus locking.</li> <li>■ arlock_mi [1] = 0 in AXI4 mode.</li> </ul> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> None</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p> |
| arcache_mi[3:0]                      | O   | <p>AXI3/AXI4 Master i interface write cache type. The CHx_CTL.ARCACHE field determines the value of this signal.</p> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock"</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p>                                                                                                                             |
| arprot_mi[2:0]                       | O   | <p>AXI3/AXI4 Master i interface read protection type. The CHx_CTL.ARPROT field determines the value of this signal.</p> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock"</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p>                                                                                                                          |

**Table 4-4 Master Interface (for i = 1; i <= DMAX\_NUM\_MASTER\_IF) Signals (Continued)**

| Port Name                     | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------------------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| arqos_mi[3:0]                 | O   | <p>AXI4 Master i interface Quality of Service signal for read channel. The value of arqos_mi is the same as the value programmed in the CHx_AXI_QoSReg.AXI_ARQOS field of the channel that is currently accessing the master interface.</p> <p><b>Exists:</b> (DMAX_HAS_QOS == 1)</p> <p><b>Synchronous To:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock"</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p>                                                                                                                                                                                                                                                                                                                                 |
| arvalid_mi                    | O   | <p>AXI3/AXI4 Master i interface read address valid. Indicates the availability of a valid read address and associated control signals.</p> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock"</p> <p><b>Registered:</b> (DMAX_HOLD_IO_EN == 1) ? "No": "Yes"</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p>                                                                                                                                                                                                                                                                                                                                                                                                            |
| arready_mi                    | I   | <p>AXI3/AXI4 Master i interface read address ready. Indicates the AXI slave readiness to accept read address and associated control signals.</p> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock"</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p>                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| wid_mi[(DMAX_M_ID_WIDTH-1):0] | O   | <p>AXI3 Master i interface write data ID. Identification tag for the write data group of signals. The upper 4 bits of wid_mi is derived from the channel number of the channel that is currently accessing the master interface (channel 1 = 4'b0000, channel 8 = 4'b0111, and so on). The lower bits are the same as the value programmed in the CHx_AXI_IDReg.AXI_Write_ID_Suffix field. DW_axi_dmac does not support write data interleaving. Therefore, the wid_mi for a particular write transaction is same as the awid_mi of the corresponding write request.</p> <p><b>Exists:</b> (DMAX_MSTIF_MODE == 0)</p> <p><b>Synchronous To:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock"</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p> |

**Table 4-4 Master Interface (for i = 1; i <= DMAX\_NUM\_MASTER\_IF) Signals (Continued)**

| Port Name                             | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                               |
|---------------------------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| wdata_mi[(DMAX_M_DATA_WIDTH-1):0]     | O   | <p>AXI3/AXI4 Master i interface write data.</p> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock"</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p>                                                                                                                         |
| wstrb_mi[((DMAX_M_DATA_WIDTH/8)-1):0] | O   | <p>AXI3/AXI4 Master i interface write data strobe.</p> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock"</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p>                                                                                                                 |
| wlast_mi                              | O   | <p>AXI3/AXI4 Master i interface write last. Indicates the last transfer in a write burst.</p> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock"</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p>                                                                          |
| wvalid_mi                             | O   | <p>AXI3/AXI4 Master i interface write data valid. Indicates the availability of valid write data and associated control signals.</p> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock"</p> <p><b>Registered:</b> (DMAX_HOLD_IO_EN == 1) ? "No": "Yes"</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p> |
| wready_mi                             | I   | <p>AXI3/AXI4 Master i interface write data ready. Indicates the AXI slave readiness to accept write data and associated control signals.</p> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock"</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p>                           |

**Table 4-4 Master Interface (for i = 1; i <= DMAX\_NUM\_MASTER\_IF) Signals (Continued)**

| Port Name                         | I/O | Description                                                                                                                                                                                                                                                                                                                                                           |
|-----------------------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| rid_mi[(DMAX_M_ID_WIDTH-1):0]     | I   | <p>AXI3/AXI4 Master i interface read data ID. Identification tag for the read data group of signals.</p> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock"</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p>                            |
| rdata_mi[(DMAX_M_DATA_WIDTH-1):0] | I   | <p>AXI3/AXI4 Master i interface read data.</p> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock"</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p>                                                                                      |
| rresp_mi[1:0]                     | I   | <p>AXI3/AXI4 Master i Interface read response. AXI slave indicates the status of read transaction.</p> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock"</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p>                              |
| rlast_mi                          | I   | <p>AXI3/AXI4 Master i interface read last. Indicates the last transfer in a read burst.</p> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock"</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p>                                        |
| rvalid_mi                         | I   | <p>AXI3/AXI4 Master i interface read data valid. Indicates the availability of valid read data and associated control signals.</p> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock"</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p> |

**Table 4-4 Master Interface (for i = 1; i <= DMAX\_NUM\_MASTER\_IF) Signals (Continued)**

| Port Name                     | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------------------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| rready_mi                     | O   | <p>AXI3/AXI4 Master i interface read data ready. Indicates the DW_axi_dmac readiness to accept read address and associated control signals.</p> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock"</p> <p><b>Registered:</b> (DMAX_HOLD_IO_EN == 1) ? "No" : "Yes"</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p> |
| bid_mi[(DMAX_M_ID_WIDTH-1):0] | I   | <p>AXI3/AXI4 Master i interface write response ID. Identification tag for the write response group of signals.</p> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock"</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p>                                                                  |
| bvalid_mi                     | I   | <p>AXI3/AXI4 Master i interface write response valid. AXI slave indicates the availability of a valid write response.</p> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock"</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p>                                                          |
| bresp_mi[1:0]                 | I   | <p>AXI3/AXI4 Master i interface write response. AXI slave indicates the status of write transaction.</p> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock"</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p>                                                                           |
| bready_mi                     | O   | <p>AXI3/AXI4 Master i interface write response ready. Indicates the DW_axi_dmac readiness to accept write response.</p> <p><b>Exists:</b> Always</p> <p><b>Synchronous To:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock"</p> <p><b>Registered:</b> (DMAX_HOLD_IO_EN == 1) ? "No" : "Yes"</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p>                         |

**Table 4-4 Master Interface (for i = 1; i <= DMAX\_NUM\_MASTER\_IF) Signals (Continued)**

| Port Name                   | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| last_write_mi               | O   | <p>Last write data of block transfer.</p> <p><b>Exists:</b> (DMAX_ENABLE_LAST_WRITE == 1)</p> <p><b>Synchronous To:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock"</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p>                                                                                                                                                                                                                                                                                                                                                                                                            |
| dmac_endian_format_mstif_mi | I   | <p>Master i interface endian format selection pins. Following are the supported endian formats:</p> <ul style="list-style-type: none"> <li>■ 0: Little Endian</li> <li>■ 1: Big Endian BE-8</li> </ul> <p><b>Exists:</b> (DMAX_STATIC_ENDIAN_SELECT_MSTIF == 0)</p> <p><b>Synchronous To:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock"</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p>                                                                                                                                                                                                                                      |
| dmac_le_select_lll_mstif_mi | I   | <p>Master i interface endian format selection pin for LLI access (LLI fetch and LLI status write-back). The following are the supported endian formats:</p> <ul style="list-style-type: none"> <li>■ 0: Endian scheme used for LLI access is the same as that used for data access Mi interface.</li> <li>■ 1: Little endian method is used for LLI access irrespective of the endian scheme used for data access Mi interface.</li> </ul> <p><b>Exists:</b> (DMAX_LLI_ENDIAN_SELECTION_PIN_EN == 1)</p> <p><b>Synchronous To:</b> (DMAX_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock"</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p> |

## 4.5 Hardware Handshaking Signals



**Table 4-5** Hardware Handshaking Signals

| Port Name                           | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------------------------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| hs_clk[(DMAx_HS_CLKRST_WIDTH-1):0]  | I   | <p>Hardware Handshake Interface Clock.</p> <p><b>Exists:</b> (DMAx_ASYNC_HS_EN == 1)</p> <p><b>Synchronous To:</b> None</p> <p><b>Registered:</b> N/A</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p>                                                                                                                                                                                                                                       |
| hs_rstn[(DMAx_HS_CLKRST_WIDTH-1):0] | I   | <p>Hardware Handshake Interface reset. Asynchronous assertion, synchronous de-assertion. The reset must be synchronously de-asserted after the rising edge of hs_clk. DW_axi_dmac does not contain logic to perform this synchronization, so it must be provided externally.</p> <p><b>Exists:</b> (DMAx_ASYNC_HS_EN == 1)</p> <p><b>Synchronous To:</b> None</p> <p><b>Registered:</b> N/A</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> Low</p> |
| dma_req[(DMAx_NUM_HS_IF-1):0]       | I   | <p>DMA transaction request from peripheral. Where, y = 1...DMAx_NUM_HS_IF and DMAx_HS1_ASYNC_CLK corresponds to dma_req[0], DMAx_HS2_ASYNC_CLK corresponds to dma_req[1], and so on.</p> <p><b>Exists:</b> (DMAx_NUM_HS_IF &gt; 0)</p> <p><b>Synchronous To:</b> ((DMAx_HS(y)_ASYNC_CLK == 1) ? "hs_clk[y-1]" : "dmac_core_clock")</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p>                             |

**Table 4-5 Hardware Handshaking Signals (Continued)**

| Port Name                       | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------------------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| dma_single[(DMA_NUM_HS_IF-1):0] | I   | <p>Single transfer request/status. Where, y = 1...DMA_NUM_HS_IF and DMA_HS1_ASYNC_CLK corresponds to dma_single[0], DMA_HS2_ASYNC_CLK corresponds to dma_single[1], and so on.</p> <p><b>Exists:</b> (DMA_NUM_HS_IF &gt; 0)</p> <p><b>Synchronous To:</b> ((DMA_HS(y)_ASYNC_CLK == 1) ? "hs_clk[y-1]" : "dmac_core_clock")</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p>    |
| dma_last[(DMA_NUM_HS_IF-1):0]   | I   | <p>Last transaction in block indicator. Where, y = 1...DMA_NUM_HS_IF and DMA_HS1_ASYNC_CLK corresponds to dma_last[0], DMA_HS2_ASYNC_CLK corresponds to dma_last[1], and so on.</p> <p><b>Exists:</b> (DMA_NUM_HS_IF &gt; 0)</p> <p><b>Synchronous To:</b> ((DMA_HS(y)_ASYNC_CLK == 1) ? "hs_clk[y-1]" : "dmac_core_clock")</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p>   |
| dma_ack[(DMA_NUM_HS_IF-1):0]    | O   | <p>Transaction complete acknowledge signal. Where, y = 1...DMA_NUM_HS_IF and DMA_HS1_ASYNC_CLK corresponds to dma_ack[0], DMA_HS2_ASYNC_CLK corresponds to dma_ack[1], and so on.</p> <p><b>Exists:</b> (DMA_NUM_HS_IF &gt; 0)</p> <p><b>Synchronous To:</b> ((DMA_HS(y)_ASYNC_CLK == 1) ? "hs_clk[y-1]" : "dmac_core_clock")</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p> |
| dma_finish[(DMA_NUM_HS_IF-1):0] | O   | <p>DMA block complete signal. Where, y = 1...DMA_NUM_HS_IF and DMA_HS1_ASYNC_CLK corresponds to dma_finish[0], DMA_HS2_ASYNC_CLK corresponds to dma_finish[1], and so on.</p> <p><b>Exists:</b> (DMA_NUM_HS_IF &gt; 0)</p> <p><b>Synchronous To:</b> ((DMA_HS(y)_ASYNC_CLK == 1) ? "hs_clk[y-1]" : "dmac_core_clock")</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p>         |

**Table 4-5     Hardware Handshaking Signals (Continued)**

| <b>Port Name</b>                   | <b>I/O</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------------------------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| debug_dma_ack[(DMA_NUM_HS_IF-1):0] | O          | <p>Debug Transaction complete acknowledge signal. This signal is always synchronous to dmac_core_clock, irrespective type Asynchronous Handshake configuration mode chosen.</p> <p><b>Exists:</b> (DMA_NUM_HS_IF &gt; 0) &amp;&amp; (DMA_ASYNC_HS_EN == 1)</p> <p><b>Synchronous To:</b> dmac_core_clock</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p> |

## 4.6 Debug Interface Signals

- dmac\_hold\_req  
 - debug\_ch\_num\_i -  
 - slvif\_busy  
 - dmac\_busy  
 - dmac\_hold\_ack  
 - debug\_grant\_index\_ar\_ch\_m1  
 - debug\_grant\_index\_aw\_ch\_m1  
 - debug\_ch\_wr\_arb\_req\_m1  
 - debug\_ch\_rd\_arb\_req\_m1  
 - debug\_ch\_lli\_rd\_req\_m1  
 - debug\_grant\_index\_ar\_ch\_m2  
 - debug\_grant\_index\_aw\_ch\_m2  
 - debug\_ch\_wr\_arb\_req\_m2  
 - debug\_ch\_rd\_arb\_req\_m2  
 - debug\_ch\_lli\_rd\_req\_m2  
 - debug\_ch\_src\_blk\_tfr\_done  
 - debug\_ch\_dst\_blk\_tfr\_done  
 - debug\_ch\_blk\_tfr\_done  
 - debug\_ch\_src\_trans\_done  
 - debug\_ch\_dst\_trans\_done  
 - debug\_ch\_dma\_tfr\_done  
 - debug\_ch\_src\_trans\_req  
 - debug\_ch\_dst\_trans\_req  
 - debug\_ch\_src\_is\_in\_str  
 - debug\_ch\_dst\_is\_in\_str  
 - debug\_ch\_shadowreg\_or\_lli\_invalid\_err  
 - debug\_ch\_aborted  
 - debug\_ch\_suspended  
 - debug\_ch\_en

**Table 4-6      Debug Interface Signals**

| Port Name     | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| dmac_hold_req | I   | <p>DMAC Core Hold Request. A request to put DW_axi_dmac in hold (freeze) mode. Asserting this request puts the entire DW_axi_dmac in freeze mode without violating the AXI protocol. To exit the hold mode, this signal can be de-asserted after DW_axi_dmac asserts dmac_hold_ack.</p> <p><b>Exists:</b> (DMAX_HOLD_IO_EN == 1)<br/> <b>Synchronous To:</b> dmac_core_clock<br/> <b>Registered:</b> No<br/> <b>Power Domain:</b> SINGLE_DOMAIN<br/> <b>Active State:</b> High</p> |

**Table 4-6 Debug Interface Signals (Continued)**

| Port Name     | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| slvif_busy    | O   | <p>Slave Interface status signal indicating that whether the slave interface is busy or not. This signal is asserted if there is an active transfer on the slave interface.</p> <p><b>Exists:</b> (DMAx_SLVIF_STATUS_OP_EN == 1)<br/> <b>Synchronous To:</b> (DMAx_SLVIF_CLOCK_MODE == 1) ? "hclk" : "dmac_core_clock"<br/> <b>Registered:</b> Yes<br/> <b>Power Domain:</b> SINGLE_DOMAIN<br/> <b>Active State:</b> High</p>                                                                                                                                                                                                                                                                                                                                                       |
| dmac_busy     | O   | <p>DMAC status signal indicates whether DW_axi_dmac core is busy or not. This signal is asserted if any of the channels in DW_axi_dmac are in a non-idle state. A non-idle state of the channel corresponds to the following cases:</p> <ul style="list-style-type: none"> <li>■ There is an active transfer on the Master Interface (including posted requests) corresponding to one or multiple Channels.</li> <li>■ Any of the Channels are about to initiate a transfer, which might correspond to waiting for the grant of the master interface from the arbiter.</li> </ul> <p><b>Exists:</b> (DMAx_CORE_STATUS_OP_EN == 1)<br/> <b>Synchronous To:</b> dmac_core_clock<br/> <b>Registered:</b> No<br/> <b>Power Domain:</b> SINGLE_DOMAIN<br/> <b>Active State:</b> High</p> |
| dmac_hold_ack | O   | <p>DMAC Core Hold request acknowledgement. DW_axi_dmac asserts this signal after entering the hold (freeze) mode. This signal is de-asserted when dmac_hold_req is de-asserted. It is not allowed to de-assert dmac_hold_req before asserting dmac_hold_ack.</p> <p><b>Exists:</b> (DMAx_HOLD_IO_EN == 1)<br/> <b>Synchronous To:</b> dmac_core_clock<br/> <b>Registered:</b> No<br/> <b>Power Domain:</b> SINGLE_DOMAIN<br/> <b>Active State:</b> High</p>                                                                                                                                                                                                                                                                                                                         |

**Table 4-6 Debug Interface Signals (Continued)**

| <b>Port Name</b>                                             | <b>I/O</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------------------------------------------------------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| debug_grant_index_ar_ch_m1[(LOG2_DMAX_ARB_RD_REQ_WIDTH-1):0] | O          | <p>Debug port AXI Master Interface 1 Read Address Channel Arbiter grant index. Where the Read Arbiter request is combination of: When LLI is enabled for at least one channel (DMAX_HAS_LLI_PARAM = 1): {CH(x)_LLI_REQ, CH(x)_DST_REQ, CH(x)_SRC_REQ, ... CH2_LLI_REQ, CH2_DST_REQ, CH2_SRC_REQ, CH1_LLI_REQ, CH1_DST_REQ, CH1_SRC_REQ} When LLI is not enabled for any of the channel (DMAX_HAS_LLI_PARAM = 0): {CH(x)_DST_REQ, CH(x)_SRC_REQ, ... CH2_DST_REQ, CH2_SRC_REQ, CH1_DST_REQ, CH1_SRC_REQ} Where x = DMAX_NUM_CHANNELS.</p> <p><b>Exists:</b> (DMAX_DEBUG_PORTS_EN &gt; 0)<br/> <b>Synchronous To:</b> dmac_core_clock<br/> <b>Registered:</b> Yes<br/> <b>Power Domain:</b> SINGLE_DOMAIN<br/> <b>Active State:</b> N/A</p> |
| debug_grant_index_aw_ch_m1[(LOG2_DMAX_ARB_WR_REQ_WIDTH-1):0] | O          | <p>Debug port AXI Master Interface 1 Write Address Channel Arbiter grant index. Where the Write Arbiter request is combination of: When LLI is enabled for at least one channel (DMAX_HAS_LLI_PARAM = 1): {CH(x)_LLI_REQ, CH(x)_DST_REQ, ... CH2_LLI_REQ, CH2_DST_REQ, CH1_LLI_REQ, CH1_DST_REQ} When LLI is not enabled for any of the channel (DMAX_HAS_LLI_PARAM = 0): {CH(x)_DST_REQ, ... CH2_DST_REQ, CH1_DST_REQ} Where x = DMAX_NUM_CHANNELS.</p> <p><b>Exists:</b> (DMAX_DEBUG_PORTS_EN &gt; 0)<br/> <b>Synchronous To:</b> dmac_core_clock<br/> <b>Registered:</b> Yes<br/> <b>Power Domain:</b> SINGLE_DOMAIN<br/> <b>Active State:</b> N/A</p>                                                                                 |
| debug_ch_wr_arb_req_m1[(DMAX_NUM_CHANNELS-1):0]              | O          | <p>Debug port AXI Master Interface 1 Write Arbiter Request. Each bit of the vector corresponds to respective channels Write Arbiter request. Each request is a combination of Destination Data Write request and LLI Write request (DMAX_HAS_LLI_PARAM==1) of a channel.</p> <p><b>Exists:</b> (DMAX_DEBUG_PORTS_EN &gt; 0)<br/> <b>Synchronous To:</b> dmac_core_clock<br/> <b>Registered:</b> No<br/> <b>Power Domain:</b> SINGLE_DOMAIN<br/> <b>Active State:</b> N/A</p>                                                                                                                                                                                                                                                              |

**Table 4-6 Debug Interface Signals (Continued)**

| Port Name                                                    | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------------------------------------------------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| debug_ch_rd_arb_req_m1[(DMA_NUM_CHANNELS-1):0]               | O   | <p>Debug port AXI Master Interface 1 Read Arbiter Request. Each bit of the vector corresponds to respective Read Arbiter request. Each request is a combination of Source Data Read request (Data Fetch and SSTAT Fetch) and Destination Read request (DSTAT Fetch) of a channel.</p> <p><b>Exists:</b> (DMA_DEBUG_PORTS_EN &gt; 0)</p> <p><b>Synchronous To:</b> dmac_core_clock</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p>                                                                                                                                                                                                                                                                                        |
| debug_ch_lll_rd_req_m1[(DMA_NUM_CHANNELS-1):0]               | O   | <p>Debug port AXI Master Interface 1 LLI Read Arbiter Request. Each bit of the vector corresponds to respective channels LLI Read Arbiter request.</p> <p><b>Exists:</b> (DMA_DEBUG_PORTS_EN &gt; 0) &amp;&amp; (DMA_HAS_LLI_PARAM == 1)</p> <p><b>Synchronous To:</b> dmac_core_clock</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p>                                                                                                                                                                                                                                                                                                                                                                                   |
| debug_grant_index_ar_ch_m2[(LOG2_DMAX_ARB_RD_REQ_WIDTH-1):0] | O   | <p>Debug port AXI Master Interface 2 Read Address Channel Arbiter grant index. Where the Read Arbiter request is combination of: When LLI is enabled for at least one channel (DMA_HAS_LLI_PARAM = 1): {CH(x)_LLI_REQ, CH(x)_DST_REQ, CH(x)_SRC_REQ, ... CH2_LLI_REQ, CH2_DST_REQ, CH2_SRC_REQ, CH1_LLI_REQ, CH1_DST_REQ, CH1_SRC_REQ} When LLI is not enabled for any of the channel (DMA_HAS_LLI_PARAM = 0): {CH(x)_DST_REQ, CH(x)_SRC_REQ, ... CH2_DST_REQ, CH2_SRC_REQ, CH1_DST_REQ, CH1_SRC_REQ} Where x = DMA_NUM_CHANNELS.</p> <p><b>Exists:</b> (DMA_DEBUG_PORTS_EN &gt; 0) &amp;&amp; (DMA_NUM_MASTER_IF &gt; 1)</p> <p><b>Synchronous To:</b> dmac_core_clock</p> <p><b>Registered:</b> Yes</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p> |

**Table 4-6 Debug Interface Signals (Continued)**

| <b>Port Name</b>                                             | <b>I/O</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------------------------------------------------------------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| debug_grant_index_aw_ch_m2[(LOG2_DMAX_ARB_WR_REQ_WIDTH-1):0] | O          | <p>Debug port AXI Master Interface 2 Write Address Channel Arbiter grant index. Where the Write Arbiter request is combination of: When LLI is enabled for at least one channel (DMAX_HAS_LLI_PARAM = 1): {CH(x)_LLI_REQ, CH(x)_DST_REQ, ... CH2_LLI_REQ, CH2_DST_REQ, CH1_LLI_REQ, CH1_DST_REQ} When LLI is not enabled for any of the channel (DMAX_HAS_LLI_PARAM = 0): {CH(x)_DST_REQ, ... CH2_DST_REQ, CH1_DST_REQ} Where x = DMAX_NUM_CHANNELS</p> <p><b>Exists:</b> (DMAX_DEBUG_PORTS_EN &gt; 0) &amp;&amp; (DMAX_NUM_MASTER_IF &gt; 1)</p> <p><b>Synchronous To:</b> dmac_core_clock</p> <p><b>Registered:</b> Yes</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p> |
| debug_ch_wr_arb_req_m2[(DMAX_NUM_CHANNELS-1):0]              | O          | <p>Debug port AXI Master Interface 2 Write Arbiter Request. Each bit of the vector corresponds to Write Arbiter request of the respective channel. Each request is a combination of Destination Data Write request and LLI Write request (DMAX_HAS_LLI_PARAM==1) of a channel.</p> <p><b>Exists:</b> (DMAX_DEBUG_PORTS_EN &gt; 0) &amp;&amp; (DMAX_NUM_MASTER_IF &gt; 1)</p> <p><b>Synchronous To:</b> dmac_core_clock</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p>                                                                                                                                                                       |
| debug_ch_rd_arb_req_m2[(DMAX_NUM_CHANNELS-1):0]              | O          | <p>Debug port AXI Master Interface 2 Read Arbiter Request. Each bit of the vector corresponds to Read Arbiter request of the respective channel. Each request is a combination of Source Data Read request (Data Fetch and SSTAT Fetch) and Destination Data Read request (DSTAT Fetch) of a channel.</p> <p><b>Exists:</b> (DMAX_DEBUG_PORTS_EN &gt; 0) &amp;&amp; (DMAX_NUM_MASTER_IF &gt; 1)</p> <p><b>Synchronous To:</b> dmac_core_clock</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p>                                                                                                                                                |

**Table 4-6 Debug Interface Signals (Continued)**

| Port Name                                      | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------------------------------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| debug_ch_lll_rd_req_m2[(DMA_NUM_CHANNELS-1):0] | O   | <p>Debug port AXI Master Interface 2 LLI Read Arbiter Request. Each bit of the vector corresponds to LLI Read Arbiter request of the respective channel.</p> <p><b>Exists:</b> (DMA_DEBUG_PORTS_EN &gt; 0) &amp;&amp; (DMA_HAS_LLI_PARAM == 1) &amp;&amp; (DMA_NUM_MASTER_IF &gt; 1)</p> <p><b>Synchronous To:</b> dmac_core_clock</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| debug_ch_num_i[(LOG2_DMA_NUM_CHANNELS-1):0]    | I   | <p>Debug Interface Channel number. This channel number is used to multiplex debug signals from all channels to provide one set of debug signals corresponding to a Channel number - debug_ch_num_i. The following Channel specific debug signals are multiplexed based on the debug_ch_num_i:</p> <ul style="list-style-type: none"> <li>■ ch_src_blk_tfr_done</li> <li>■ ch_dst_blk_tfr_done</li> <li>■ ch_blk_tfr_done</li> <li>■ ch_src_trans_done</li> <li>■ ch_dst_trans_done</li> <li>■ ch_dma_tfr_done</li> <li>■ ch_src_trans_req</li> <li>■ ch_dst_trans_req</li> <li>■ ch_src_is_in_str</li> <li>■ ch_dst_is_in_str</li> <li>■ ch_aborted</li> <li>■ ch_suspended</li> <li>■ ch_shadowreg_or_lll_invalid_err</li> </ul> <p><b>Exists:</b> (DMA_DEBUG_PORTS_EN &gt; 0)</p> <p><b>Synchronous To:</b> dmac_core_clock</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p> |
| debug_ch_src_blk_tfr_done                      | O   | <p>Multiplexed - Source Block Transfer Done debug signal corresponding to the channel debug_ch_num_i.</p> <p><b>Exists:</b> (DMA_DEBUG_PORTS_EN &gt; 0)</p> <p><b>Synchronous To:</b> dmac_core_clock</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

**Table 4-6 Debug Interface Signals (Continued)**

| <b>Port Name</b>          | <b>I/O</b> | <b>Description</b>                                                                                                                                                                                                                                                                        |
|---------------------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| debug_ch_dst_blk_tfr_done | O          | Multiplexed - Destination Block Transfer Done debug signal corresponding to the channel debug_ch_num_i.<br><b>Exists:</b> (DMAX_DEBUG_PORTS_EN > 0)<br><b>Synchronous To:</b> dmac_core_clock<br><b>Registered:</b> No<br><b>Power Domain:</b> SINGLE_DOMAIN<br><b>Active State:</b> High |
| debug_ch_blk_tfr_done     | O          | Multiplexed - DMA Block Transfer Done debug signal corresponding to the channel debug_ch_num_i.<br><b>Exists:</b> (DMAX_DEBUG_PORTS_EN > 0)<br><b>Synchronous To:</b> dmac_core_clock<br><b>Registered:</b> No<br><b>Power Domain:</b> SINGLE_DOMAIN<br><b>Active State:</b> High         |
| debug_ch_src_trans_done   | O          | Multiplexed - Source Transaction Done debug signal corresponding to the channel debug_ch_num_i.<br><b>Exists:</b> (DMAX_DEBUG_PORTS_EN > 0)<br><b>Synchronous To:</b> dmac_core_clock<br><b>Registered:</b> No<br><b>Power Domain:</b> SINGLE_DOMAIN<br><b>Active State:</b> High         |
| debug_ch_dst_trans_done   | O          | Multiplexed - Destination Transaction Done debug signal corresponding to the channel debug_ch_num_i.<br><b>Exists:</b> (DMAX_DEBUG_PORTS_EN > 0)<br><b>Synchronous To:</b> dmac_core_clock<br><b>Registered:</b> No<br><b>Power Domain:</b> SINGLE_DOMAIN<br><b>Active State:</b> High    |
| debug_ch_dma_tfr_done     | O          | Multiplexed - DMA Transfer Done debug signal corresponding to the channel debug_ch_num_i.<br><b>Exists:</b> (DMAX_DEBUG_PORTS_EN > 0)<br><b>Synchronous To:</b> dmac_core_clock<br><b>Registered:</b> No<br><b>Power Domain:</b> SINGLE_DOMAIN<br><b>Active State:</b> High               |

**Table 4-6 Debug Interface Signals (Continued)**

| <b>Port Name</b>       | <b>I/O</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                 |
|------------------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| debug_ch_src_trans_req | O          | Multiplexed - internally generated Source Transaction request (generated based on the Source dma_req* and dma_sgl_req*) debug signal corresponding to the channel debug_ch_num_i.<br><b>Exists:</b> (DMAx_DEBUG_PORTS_EN > 0)<br><b>Synchronous To:</b> dmac_core_clock<br><b>Registered:</b> No<br><b>Power Domain:</b> SINGLE_DOMAIN<br><b>Active State:</b> High                                |
| debug_ch_dst_trans_req | O          | Multiplexed - internally generated Destination Transaction request (generated based on the Destination dma_req* and dma_sgl_req*) debug signal corresponding to the channel debug_ch_num_i.<br><b>Exists:</b> (DMAx_DEBUG_PORTS_EN > 0)<br><b>Synchronous To:</b> dmac_core_clock<br><b>Registered:</b> No<br><b>Power Domain:</b> SINGLE_DOMAIN<br><b>Active State:</b> High                      |
| debug_ch_src_is_in_str | O          | Multiplexed - Source State machine is in Single transaction region debug signal corresponding to the channel debug_ch_num_i. For more information, see "Single Transaction Region" section of the databook.<br><b>Exists:</b> (DMAx_DEBUG_PORTS_EN > 0)<br><b>Synchronous To:</b> dmac_core_clock<br><b>Registered:</b> No<br><b>Power Domain:</b> SINGLE_DOMAIN<br><b>Active State:</b> High      |
| debug_ch_dst_is_in_str | O          | Multiplexed - Destination State machine is in Single transaction region debug signal corresponding to the channel debug_ch_num_i. For more information, see "Single Transaction Region" section of the databook.<br><b>Exists:</b> (DMAx_DEBUG_PORTS_EN > 0)<br><b>Synchronous To:</b> dmac_core_clock<br><b>Registered:</b> No<br><b>Power Domain:</b> SINGLE_DOMAIN<br><b>Active State:</b> High |

**Table 4-6 Debug Interface Signals (Continued)**

| <b>Port Name</b>                      | <b>I/O</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------------------------------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| debug_ch_shadowreg_or_lll_invalid_err | O          | <p>Multiplexed - Shadow register or LLI Invalid error debug signal corresponding to the channel debug_ch_num_i. For more information, see "Programming Flow for Shadow-Register-Based Multi-Block Transfer" and "Programming Flow for Linked-List-Based Multi-Block Transfer" sections of the databook.</p> <p><b>Exists:</b> (DMAX_DEBUG_PORTS_EN &gt; 0)</p> <p><b>Synchronous To:</b> dmac_core_clock</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p> |
| debug_ch_aborted                      | O          | <p>Multiplexed - Channel Abort status (generated due to Channel Suspend request, Channel disable, User Channel abort, or due to reception of AXI error response) debug signal corresponding to the channel debug_ch_num_i.</p> <p><b>Exists:</b> (DMAX_DEBUG_PORTS_EN &gt; 0) &amp;&amp; (DMAX_CH_ABORT_EN &gt; 0)</p> <p><b>Synchronous To:</b> dmac_core_clock</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p>                                         |
| debug_ch_suspended                    | O          | <p>Multiplexed - Channel Suspend status debug signal corresponding to the channel debug_ch_num_i.</p> <p><b>Exists:</b> (DMAX_DEBUG_PORTS_EN &gt; 0)</p> <p><b>Synchronous To:</b> dmac_core_clock</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p>                                                                                                                                                                                                       |
| debug_ch_en[(DMAX_NUM_CHANNEL_S-1):0] | O          | <p>DMA Channel enable debug signal.</p> <p><b>Exists:</b> (DMAX_DEBUG_PORTS_EN &gt; 0)</p> <p><b>Synchronous To:</b> dmac_core_clock</p> <p><b>Registered:</b> Yes</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> N/A</p>                                                                                                                                                                                                                                                                     |

## 4.7 Interrupt Interface Signals



**Table 4-7** Interrupt Interface Signals

| Port Name                        | I/O | Description                                                                                                                                                                                                                                                                                                                                                                   |
|----------------------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| intr                             | O   | <p>Logical OR of all individual interrupts.</p> <p><b>Exists:</b> (DMAX_INTR_IO_TYPE != 1)</p> <p><b>Synchronous To:</b> (DMAX_INTR_SYNC2SLVCLK == 1) ? "hclk" : "dmac_core_clock"</p> <p><b>Registered:</b> ((DMAX_INTR_SYNC2SLVCLK == 1) &amp;&amp; (DMAX_INTR_IO_TYPE == 0)) ? "Yes" : "No"</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p> |
| intr_ch[(DMAX_NUM_CHANNELS-1):0] | O   | <p>Logical OR of all individual interrupts of each enabled channels.</p> <p><b>Exists:</b> (DMAX_INTR_IO_TYPE &gt; 0)</p> <p><b>Synchronous To:</b> (DMAX_INTR_SYNC2SLVCLK == 1) ? "hclk" : "dmac_core_clock"</p> <p><b>Registered:</b> (DMAX_INTR_SYNC2SLVCLK == 1) ? "Yes" : "No"</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p>            |
| intr_cmnreg                      | O   | <p>Logical OR of all common register interrupts.</p> <p><b>Exists:</b> (DMAX_INTR_IO_TYPE &gt; 0)</p> <p><b>Synchronous To:</b> (DMAX_INTR_SYNC2SLVCLK == 1) ? "hclk" : "dmac_core_clock"</p> <p><b>Registered:</b> (DMAX_INTR_SYNC2SLVCLK == 1) ? "Yes" : "No"</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p>                                |

## 4.8 Low Power Interface Signals

- dmac\_lp\_req
- ch\_lp\_req
- sbiu\_lp\_req
- mxif\_arch\_lp\_req
- mxif\_arch\_oclk\_lp\_req
- mxif\_awch\_lp\_req
- mxif\_awch\_oclk\_lp\_req
- mxif\_wch\_lp\_req
- mxif\_wch\_oclk\_lp\_req
- mxif\_bch\_lp\_req
- mxif\_bch\_oclk\_lp\_req
- mxif\_rch\_lp\_req
- mxif\_rch\_oclk\_lp\_req
- mxif\_r\_ch\_idle
- mxif\_b\_ch\_idle

**Table 4-8    Low Power Interface Signals**

| Port Name                          | I/O | Description                                                                                                                                                                                                                                                                                                                             |
|------------------------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| dmac_lp_req                        | O   | <p>Global Low Power request, generated based on the Global Context Sensitive Low Power feature.</p> <p><b>Exists:</b> (DMAX_CSLP_EN == 1)</p> <p><b>Synchronous To:</b> dmac_core_clock</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p>                                     |
| ch_lp_req[(DMAX_NUM_CHANNELS-1):0] | O   | <p>DMA Channel Low Power request, generated based on the DMA Channel Context Sensitive Low Power feature.</p> <p><b>Exists:</b> (DMAX_CHNL_CSLP_EN == 1)</p> <p><b>Synchronous To:</b> dmac_core_clock</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p>                      |
| sbiu_lp_req                        | O   | <p>SBIU Low Power request, generated based on the SBIU Context Sensitive Low Power feature.</p> <p><b>Exists:</b> (DMAX_SBIU_CSLP_EN== 1)</p> <p><b>Synchronous To:</b> (DMAX_SLVIF_MODE == 1) ? "hclk" : "dmac_core_clock"</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p> |

**Table 4-8 Low Power Interface Signals (Continued)**

| Port Name                                      | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                               |
|------------------------------------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| mxif_arch_lp_req[(DMA_NUM_MASTER_IF-1):0]      | O   | <p>AXI AR Channel Low Power request, generated based on the AXI Master Interface Context Sensitive Low Power feature.</p> <p><b>Exists:</b> (DMA_MXIF_CSLP_EN== 1)</p> <p><b>Synchronous To:</b> dmac_core_clock</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p>                                                                              |
| mxif_arch_oclk_lp_req[(DMA_NUM_MASTER_IF-1):0] | O   | <p>AXI AR Channel Low Power request (synchronous to other clock - aclk_mi), generated based on the AXI Master Interface Context Sensitive Low Power feature.</p> <p><b>Exists:</b> (DMA_MXIF_CSLP_EN== 1)</p> <p><b>Synchronous To:</b> ((DMA_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "None")</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p> |
| mxif_awch_lp_req[(DMA_NUM_MASTER_IF-1):0]      | O   | <p>AXI AW Channel Low Power request, generated based on the AXI Master Interface Context Sensitive Low Power feature.</p> <p><b>Exists:</b> (DMA_MXIF_CSLP_EN== 1)</p> <p><b>Synchronous To:</b> dmac_core_clock</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p>                                                                              |
| mxif_awch_oclk_lp_req[(DMA_NUM_MASTER_IF-1):0] | O   | <p>AXI AW Channel Low Power request (synchronous to other clock - aclk_mi), generated based on the AXI Master Interface Context Sensitive Low Power feature.</p> <p><b>Exists:</b> (DMA_MXIF_CSLP_EN== 1)</p> <p><b>Synchronous To:</b> ((DMA_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "None")</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p> |
| mxif_wch_lp_req[(DMA_NUM_MASTER_IF-1):0]       | O   | <p>AXI W Channel Low Power request, generated based on the AXI Master Interface Context Sensitive Low Power feature.</p> <p><b>Exists:</b> (DMA_MXIF_CSLP_EN== 1)</p> <p><b>Synchronous To:</b> dmac_core_clock</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p>                                                                               |

**Table 4-8 Low Power Interface Signals (Continued)**

| Port Name                                     | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                              |
|-----------------------------------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| mxif_wch_oclk_lp_req[(DMA_NUM_MASTER_IF-1):0] | O   | <p>AXI W Channel Low Power request (synchronous to other clock - aclk_mi), generated based on the AXI Master Interface Context Sensitive Low Power feature.</p> <p><b>Exists:</b> (DMA_MXIF_CSLP_EN== 1)</p> <p><b>Synchronous To:</b> ((DMA_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "None")</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p> |
| mxif_bch_lp_req[(DMA_NUM_MASTER_IF-1):0]      | O   | <p>AXI B Channel Low Power request, generated based on the AXI Master Interface Context Sensitive Low Power feature.</p> <p><b>Exists:</b> (DMA_MXIF_CSLP_EN== 1)</p> <p><b>Synchronous To:</b> aclk_mi</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p>                                                                                      |
| mxif_bch_oclk_lp_req[(DMA_NUM_MASTER_IF-1):0] | O   | <p>AXI B Channel Low Power request (synchronous to other clock - dmac_core_clock), generated based on the AXI Master Interface Context Sensitive Low Power feature.</p> <p><b>Exists:</b> (DMA_MXIF_CSLP_EN== 1)</p> <p><b>Synchronous To:</b> dmac_core_clock</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p>                               |
| mxif_rch_lp_req[(DMA_NUM_MASTER_IF-1):0]      | O   | <p>AXI R Channel Low Power request, generated based on the AXI Master Interface Context Sensitive Low Power feature.</p> <p><b>Exists:</b> (DMA_MXIF_CSLP_EN== 1)</p> <p><b>Synchronous To:</b> aclk_mi</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p>                                                                                      |
| mxif_rch_oclk_lp_req[(DMA_NUM_MASTER_IF-1):0] | O   | <p>AXI R Channel Low Power request (synchronous to other clock - dmac_core_clock), generated based on the AXI Master Interface Context Sensitive Low Power feature.</p> <p><b>Exists:</b> (DMA_MXIF_CSLP_EN== 1)</p> <p><b>Synchronous To:</b> dmac_core_clock</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p>                               |

**Table 4-8 Low Power Interface Signals (Continued)**

| <b>Port Name</b>                        | <b>I/O</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                |
|-----------------------------------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| mxif_r_ch_idle[(DMA_NUM_MASTER_IF-1):0] | O          | <p>Debug port AXI Master interface Read Data channel Idle status.</p> <p><b>Exists:</b> (DMA_DEBUG_PORTS_EN &gt; 0) &amp;&amp; (DMA_CSLP_EN == 1)</p> <p><b>Synchronous To:</b> ((DMA_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock")</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p>      |
| mxif_b_ch_idle[(DMA_NUM_MASTER_IF-1):0] | O          | <p>Debug port AXI Master interface Write Response channel Idle status.</p> <p><b>Exists:</b> (DMA_DEBUG_PORTS_EN &gt; 0) &amp;&amp; (DMA_CSLP_EN == 1)</p> <p><b>Synchronous To:</b> ((DMA_MSTIF(i)_CLOCK_MODE == 1) ? "aclk_mi" : "dmac_core_clock")</p> <p><b>Registered:</b> No</p> <p><b>Power Domain:</b> SINGLE_DOMAIN</p> <p><b>Active State:</b> High</p> |

Synopsys confidential document, provided to Blue Ocean Smart under NDA, do not redistribute

# 5

## Register Descriptions

This chapter details all possible registers in the core. They are arranged hierarchically into maps and blocks (banks). For configurable IP titles, your actual configuration might not contain all of these registers.

**Attention: For configurable IP titles, do not use this document to determine the exact attributes of your register map. It is for reference purposes only.**

When you configure the core in coreConsultant, you must access the register attributes for your actual configuration at workspace/report/ComponentRegisters.html or workspace/report/ComponentRegisters.xml after you have completed the report creation activity. That report comes from the exact same source as this chapter but removes all the registers that are not in your actual configuration. This does not apply to non-configurable IP titles. In addition, all parameter expressions are evaluated to actual values. Therefore, the Offset and Memory Access values might change depending on your actual configuration.

Some expressions might refer to TCL functions or procedures (sometimes identified as <functionof>) that coreConsultant uses to make calculations. The exact formula used by these TCL functions is not provided in this chapter. However, when you configure the core in coreConsultant, all TCL functions and parameters are evaluated completely; and the resulting values are displayed where appropriate in the coreConsultant GUI reports.

### Exists Expressions

The Exist expressions indicate the combination of configuration parameters required for a register, field, or block to exist in the memory map. The expression is only valid in the local context and does not indicate the conditions for existence of the parent. For example, the Exists expression for a bit field in a register assumes that the register exists and does not include the conditions for existence of the register.

### Offset

The term *Offset* is synonymous with *Address*.

### Memory Access Attributes

The Memory Access attribute is defined as <ReadBehavior>/<WriteBehavior> which are defined in the following table.

**Table 5-1 Possible Read and Write Behaviors**

| Read (or Write) Behavior    | Description                                          |
|-----------------------------|------------------------------------------------------|
| RC                          | A read clears this register field.                   |
| RS                          | A read sets this register field.                     |
| RM                          | A read modifies the contents of this register field. |
| Wo                          | You can only write to this register once field.      |
| W1C                         | A write of 1 clears this register field.             |
| W1S                         | A write of 1 sets this register field.               |
| W1T                         | A write of 1 toggles this register field.            |
| W0C                         | A write of 0 clears this register field.             |
| W0S                         | A write of 0 sets this register field.               |
| W0T                         | A write of 0 toggles this register field.            |
| WC                          | Any write clears this register field.                |
| WS                          | Any write sets this register field.                  |
| WM                          | Any write toggles this register field.               |
| no Read Behavior attribute  | You cannot read this register. It is Write-Only.     |
| no Write Behavior attribute | You cannot write to this register. It is Read-Only.  |

**Table 5-2 Memory Access Examples**

| Memory Access | Description                                                      |
|---------------|------------------------------------------------------------------|
| R             | Read-only register field.                                        |
| W             | Write-only register field.                                       |
| R/W           | Read/write register field.                                       |
| R/W1C         | You can read this register field. Writing 1 clears it.           |
| RC/W1C        | Reading this register field clears it. Writing 1 clears it.      |
| R/Wo          | You can read this register field. You can only write to it once. |

### Special Optional Attributes

Some register fields might use the following optional attributes.

**Table 5-3 Optional Attributes**

| Attribute  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Volatile   | As defined by the IP-XACT specification. If true, indicates in the case of a write followed by read, or in the case of two consecutive reads, there is no guarantee as to what is returned by the read on the second transaction or that this return value is consistent with the write or read of the first transaction. The element implies there is some additional mechanism by which this field can acquire new values other than by reads/writes/resets and other access methods known to IP-XACT. For example, when the core updates the register field contents. |
| Testable   | As defined by the IP-XACT specification. Possible values are unconstrained, untestable, readOnly, writeAsRead, restore. Untestable means that this field is untestable by a simple automated register test. For example, the read-write access of the register is controlled by a pin or another register. readOnly means that you should not write to this register; only read from it. This might apply for a register that modifies the contents of another register.                                                                                                 |
| Reset Mask | As defined by the IP-XACT specification. Indicates that this register field has an unknown reset value. For example, the reset value is set by another register or an input pin; or the register is implemented using RAM.                                                                                                                                                                                                                                                                                                                                               |
| * Varies   | Indicates that the memory access (or reset) attribute (read, write behavior) is not fixed. For example, the read-write access of the register is controlled by a pin or another register. Or when the access depends on some configuration parameter; in this case the post-configuration report in coreConsultant gives the actual access value.                                                                                                                                                                                                                        |

## Component Banks/Blocks

The following table shows the address blocks for each memory map. Follow the link for an address block to see a table of its registers.

**Table 5-4 Address Banks/Blocks for Memory Map: DW\_axi\_dmac\_mem\_map**

| Address Block                                                                                                   | Description                                                                           |
|-----------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|
| Common_Registers_Address_Block on <a href="#">page 162</a>                                                      | DW_axi_dmac common register address block<br><b>Exists:</b> Always                    |
| DW_axi_dmac Channel x register address block<br>(for x = 1; x <= DMAX_NUM_CHANNELS) on <a href="#">page 339</a> | DW_axi_dmac Channel x register address block<br><b>Exists:</b> DMAX_NUM_CHANNELS >= x |
| DUMMY                                                                                                           | <b>Exists:</b> Always                                                                 |

## 5.1 DW\_axi\_dmac\_mem\_map/Common\_Registers\_Address\_Block Registers

DW\_axi\_dmac common register address block Follow the link for the register to see a detailed description of the register.

**Table 5-5 Registers for Address Block: DW\_axi\_dmac\_mem\_map/Common\_Registers\_Address\_Block**

| Register                                                        | Offset | Description                                                                                              |
|-----------------------------------------------------------------|--------|----------------------------------------------------------------------------------------------------------|
| DMAC_IDREG on <a href="#">page 163</a>                          | 0x0    | DMAC ID Register contains a 64-bit value that is hardwired and read back by a read to the DW_axi_dmac... |
| DMAC_COMPVERREG on <a href="#">page 164</a>                     | 0x8    | This register contains a 64-bit value that is hardwired and read back by a read to the DW_axi_dmac...    |
| DMAC_CFGREG on <a href="#">page 165</a>                         | 0x10   | This register is used to enable the DW_axi_dmac, which must be done before any channel activity...       |
| DMAC_CHENREG on <a href="#">page 167</a>                        | 0x18   | This is DW_axi_dmac Channel Enable Register. If software wants to set up a new channel, it can read...   |
| DMAC_CHENREG2 on <a href="#">page 196</a>                       | 0x18   | This is DW_axi_dmac Channel Enable Register. If software wants to set up a new channel, it can read...   |
| DMAC_CHSUSPREG on <a href="#">page 224</a>                      | 0x20   | This is DW_axi_dmac Channel Suspend Register. The channel suspend bit, DMAC_ChSuspReg.CH_SUSP, is...     |
| DMAC_CHABORTREG on <a href="#">page 265</a>                     | 0x28   | This is DW_axi_dmac Channel Abort Register. The channel abort bit, DMAC_ChAbortReg.CH_ABORT, is...       |
| DMAC_INTSTATUSREG on <a href="#">page 308</a>                   | 0x30   | DMAC Interrupt Status Register captures the combined channel interrupt for each channel and Combined...  |
| DMAC_INTSTATUSREG2 on <a href="#">page 311</a>                  | 0x30   | DMAC Interrupt Status Register captures the combined channel interrupt for each channel and Combined...  |
| DMAC_COMMONREG_INTCLEARREG on <a href="#">page 319</a>          | 0x38   | Writing 1 to specific field clears the corresponding field in DMAC Common register Interrupt Status...   |
| DMAC_COMMONREG_INTSTATUS_ENA BLEREG on <a href="#">page 322</a> | 0x40   | Writing 1 to specific field enables the corresponding interrupt status generation in DMAC Common...      |
| DMAC_COMMONREG_INTSIGNAL_ENA BLEREG on <a href="#">page 326</a> | 0x48   | Writing 1 to specific field will propagate the corresponding interrupt status in DMAC Common register... |
| DMAC_COMMONREG_INTSTATUSREG on <a href="#">page 330</a>         | 0x50   | This Register captures Slave interface access errors. - Decode Error. - Write to read only register....  |
| DMAC_RESETREG on <a href="#">page 335</a>                       | 0x58   | This register is used to initiate the Software Reset to DW_axi_dmac.                                     |
| DMAC_LOWPOWER_CFGREG on <a href="#">page 336</a>                | 0x60   | This register contains the fields that configures the Context Sensitive Low Power feature. This...       |

### 5.1.1 DMAC\_IDREG

- **Description:** DMAC ID Register contains a 64-bit value that is hardwired and read back by a read to the DW\_axi\_dmac ID Register.
- **Size:** 64 bits
- **Offset:** 0x0
- **Exists:** Always



**Table 5-6 Fields for Register: DMAC\_IDREG**

| Bits | Name    | Memory Access | Description                                                                       |
|------|---------|---------------|-----------------------------------------------------------------------------------|
| 63:0 | DMAC_ID | R             | DMAC ID Number.<br><b>Value After Reset:</b> DMAX_ID_NUM<br><b>Exists:</b> Always |

### 5.1.2 DMAC\_COMPVERREG

- **Description:** This register contains a 64-bit value that is hardwired and read back by a read to the DW\_axi\_dmac Component Version Register.
- **Size:** 64 bits
- **Offset:** 0x8
- **Exists:** Always



**Table 5-7 Fields for Register: DMAC\_COMPVERREG**

| Bits  | Name                 | Memory Access | Description                                                                                         |
|-------|----------------------|---------------|-----------------------------------------------------------------------------------------------------|
| 63:32 | RSVD_DMAC_COMPVERREG | R             | DMAC_COMPVERREG Reserved bits - Read Only<br><b>Value After Reset:</b> 0x0<br><b>Exists:</b> Always |
| 31:0  | DMAC_COMPVER         | R             | DMAC Component Version Number.<br><b>Value After Reset:</b> DMAX_COMP_VER<br><b>Exists:</b> Always  |

### 5.1.3 DMAC\_CFGREG

- **Description:** This register is used to enable the DW\_axi\_dmac, which must be done before any channel activity can begin. This register also contains global interrupt enable bit.
- **Size:** 64 bits
- **Offset:** 0x10
- **Exists:** Always



**Table 5-8 Fields for Register: DMAC\_CFGREG**

| Bits | Name             | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|------------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:2 | RSVD_DMAC_CFGREG | R             | DMAC_CFGREG Reserved bits - Read Only<br><b>Value After Reset:</b> 0x0<br><b>Exists:</b> Always                                                                                                                                                                                                                                                                                                                                                              |
| 1    | INT_EN           | R/W           | This bit is used to globally enable the interrupt generation.<br><ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Interrupts are disabled</li> <li>■ 1: DW_axi_dmac Interrupt logic is enabled.</li> </ul> <b>Values:</b> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLED): DW_axi_dmac Interrupts are enabled</li> <li>■ 0x0 (DISABLED): DW_axi_dmac Interrupts are disabled</li> </ul> <b>Value After Reset:</b> 0x0<br><b>Exists:</b> Always |

**Table 5-8 Fields for Register: DMAC\_CFGREG (Continued)**

| Bits | Name    | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|---------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | DMAC_EN | R/W           | <p>This bit is used to enable the DW_axi_dmac.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac disabled</li> <li>■ 1: DW_axi_dmac enabled</li> </ul> <p><b>NOTE:</b> If this bit DMAC_EN bit is cleared while any channel is still active, then this bit still returns 1 to indicate that there are channels still active until DW_axi_dmac hardware has terminated all activity on all channels, at which point this bit returns zero (0).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLED): DW_axi_dmac is enabled</li> <li>■ 0x0 (DISABLED): DW_axi_dmac is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> |

## 5.1.4 DMAC CHENREG

- **Description:** This is DW\_axi\_dmac Channel Enable Register. If software wants to set up a new channel, it can read this register to find out which channels are currently inactive and then enable an inactive channel with the required priority.

All bits of this register are cleared to 0 when the DW\_axi\_dmac Global Enable bit (DMAC\_CfgReg.DMAC\_EN) is 0. When DMAC\_CfgReg.DMAC\_EN is 0, a write to the DMAC\_ChEnReg register is ignored and a read always reads back 0.

The channel enable bit, DMAC\_ChEnReg.CH\_EN, is written only if the corresponding channel write enable bit, DMAC\_ChEnReg.CH\_EN\_WE, is asserted on the same slave interface write transfer. For example, writing hex XXXX01X1 writes a 1 into DMAC\_ChEnReg [0], while DMAC\_ChEnReg [7:1] remains unchanged. Writing hex XXXX00XX leaves DMAC\_ChEnReg [7:0] unchanged.

The channel suspend bit, DMAC\_ChEnReg.CH\_SUSP, is written only if the corresponding channel write enable bit, DMAC\_ChEnReg.CH\_SUSP\_WE, is asserted on the same slave interface write transfer. For example, writing hex 01X1XXXX writes a 1 into DMAC\_ChEnReg [16], while DMAC\_ChEnReg [23:17] remains unchanged. Writing hex 00XXXXXX leaves DMAC\_ChEnReg [23:16] unchanged. The channel abort bit, DMAC\_ChEnReg.CH\_ABORT, is written only if the corresponding channel write enable bit, DMAC\_ChEnReg.CH\_ABORT\_WE, is asserted on the same slave interface write transfer.

- **Size:** 64 bits
  - **Offset:** 0x18
  - **Exists:** DMAX NUM CHANNELS <= 8

| RSVDF        | DMMAC_CHENREG | 63,48 |
|--------------|---------------|-------|
| CH8_ABORT_WE | 47            |       |
| CH7_ABORT_WE | 46            |       |
| CH6_ABORT_WE | 45            |       |
| CH5_ABORT_WE | 44            |       |
| CH4_ABORT_WE | 43            |       |
| CH3_ABORT_WE | 42            |       |
| CH2_ABORT_WE | 41            |       |
| CH1_ABORT_WE | 40            |       |
| CH8_ABORT    | 39            |       |
| CH7_ABORT    | 38            |       |
| CH6_ABORT    | 37            |       |
| CH5_ABORT    | 36            |       |
| CH4_ABORT    | 35            |       |
| CH3_ABORT    | 34            |       |
| CH2_ABORT    | 33            |       |
| CH1_ABORT    | 32            |       |
| CH8_SUSP_WE  | 31            |       |
| CH7_SUSP_WE  | 30            |       |
| CH6_SUSP_WE  | 29            |       |
| CH5_SUSP_WE  | 28            |       |
| CH4_SUSP_WE  | 27            |       |
| CH3_SUSP_WE  | 26            |       |
| CH2_SUSP_WE  | 25            |       |
| CH1_SUSP_WE  | 24            |       |
| CH8_SUSP     | 23            |       |
| CH7_SUSP     | 22            |       |
| CH6_SUSP     | 21            |       |
| CH5_SUSP     | 20            |       |
| CH4_SUSP     | 19            |       |
| CH3_SUSP     | 18            |       |
| CH2_SUSP     | 17            |       |
| CH1_SUSP     | 16            |       |
| CH8_EN_WE    | 15            |       |
| CH7_EN_WE    | 14            |       |
| CH6_EN_WE    | 13            |       |
| CH5_EN_WE    | 12            |       |
| CH4_EN_WE    | 11            |       |
| CH3_EN_WE    | 10            |       |
| CH2_EN_WE    | 9             |       |
| CH1_EN_WE    | 8             |       |
| CH8_EN       | 7             |       |
| CH7_EN       | 6             |       |
| CH6_EN       | 5             |       |
| CH5_EN       | 4             |       |
| CH4_EN       | 3             |       |
| CH3_EN       | 2             |       |
| CH2_EN       | 1             |       |
| CH1_EN       | 0             |       |

**Table 5-9 Fields for Register: DMAC\_CHENREG**

| <b>Bits</b> | <b>Name</b>       | <b>Memory Access</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------------|-------------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:48       | RSVD_DMAC_CHENREG | R                    | <p>DMAC_CHENREG Reserved bits - Read Only</p> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p>                                                                                                                                                                                                                                                                                                                                                                                       |
| 47          | CH8_ABORT_WE      | * Varies             | <p>This bit is used to write enable the Channel-8 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH8_ABORT): Enable Write to CH8_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH8_ABORT): Disable Write to CH8_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMA_NUM_CHANNELS &gt; 7</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMA_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p> |
| 46          | CH7_ABORT_WE      | * Varies             | <p>This bit is used to write enable the Channel-7 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH7_ABORT): Enable Write to CH7_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH7_ABORT): Disable Write to CH7_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMA_NUM_CHANNELS &gt; 6</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMA_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p> |

**Table 5-9 Fields for Register: DMAC\_CHENREG (Continued)**

| Bits | Name         | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------|--------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 45   | CH6_ABORT_WE | * Varies      | <p>This bit is used to write enable the Channel-6 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH6_ABORT): Enable Write to CH6_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH6_ABORT): Disable Write to CH6_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 5</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p> |
| 44   | CH5_ABORT_WE | * Varies      | <p>This bit is used to write enable the Channel-5 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH5_ABORT): Enable Write to CH5_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH5_ABORT): Disable Write to CH5_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 4</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p> |
| 43   | CH4_ABORT_WE | * Varies      | <p>This bit is used to write enable the Channel-4 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH4_ABORT): Enable Write to CH4_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH4_ABORT): Disable Write to CH4_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 3</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p> |

**Table 5-9 Fields for Register: DMAC\_CHENREG (Continued)**

| Bits | Name         | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------|--------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 42   | CH3_ABORT_WE | * Varies      | <p>This bit is used to write enable the Channel-3 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH3_ABORT): Enable Write to CH3_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH3_ABORT): Disable Write to CH3_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 2</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p> |
| 41   | CH2_ABORT_WE | * Varies      | <p>This bit is used to write enable the Channel-2 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH2_ABORT): Enable Write to CH2_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH2_ABORT): Disable Write to CH2_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 1</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p> |
| 40   | CH1_ABORT_WE | * Varies      | <p>This bit is used to write enable the Channel-1 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH1_ABORT): Enable Write to CH1_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH1_ABORT): Disable Write to CH1_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 0</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p> |

**Table 5-9 Fields for Register: DMAC\_CHENREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|-----------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 39   | CH8_ABORT | * Varies      | <p>Channel-8 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH8_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH8_ABORT): Request for Channel-8 Abort</li> <li>■ 0x0 (DISABLE_CH8_ABORT): No Request for Channel-8 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 7</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |

**Table 5-9 Fields for Register: DMAC\_CHENREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|-----------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 38   | CH7_ABORT | * Varies      | <p>Channel-7 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH7_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH7_ABORT): Request for Channel-7 Abort</li> <li>■ 0x0 (DISABLE_CH7_ABORT): No Request for Channel-7 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 6</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |

**Table 5-9 Fields for Register: DMAC\_CHENREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|-----------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 37   | CH6_ABORT | * Varies      | <p>Channel-6 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH6_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH6_ABORT): Request for Channel-6 Abort</li> <li>■ 0x0 (DISABLE_CH6_ABORT): No Request for Channel-6 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 5</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |

**Table 5-9 Fields for Register: DMAC\_CHENREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|-----------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 36   | CH5_ABORT | * Varies      | <p>Channel-5 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH5_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH5_ABORT): Request for Channel-5 Abort</li> <li>■ 0x0 (DISABLE_CH5_ABORT): No Request for Channel-5 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 4</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |

**Table 5-9 Fields for Register: DMAC\_CHENREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|-----------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 35   | CH4_ABORT | * Varies      | <p>Channel-4 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH4_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH4_ABORT): Request for Channel-4 Abort</li> <li>■ 0x0 (DISABLE_CH4_ABORT): No Request for Channel-4 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 3</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |

**Table 5-9 Fields for Register: DMAC\_CHENREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|-----------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 34   | CH3_ABORT | * Varies      | <p>Channel-3 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH3_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH3_ABORT): Request for Channel-3 Abort</li> <li>■ 0x0 (DISABLE_CH3_ABORT): No Request for Channel-3 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 2</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |

**Table 5-9 Fields for Register: DMAC\_CHENREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|-----------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 33   | CH2_ABORT | * Varies      | <p>Channel-2 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH2_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH2_ABORT): Request for Channel-2 Abort</li> <li>■ 0x0 (DISABLE_CH2_ABORT): No Request for Channel-2 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 1</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |

**Table 5-9 Fields for Register: DMAC\_CHENREG (Continued)**

| Bits | Name        | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|-------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 32   | CH1_ABORT   | * Varies      | <p>Channel-1 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH1_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH1_ABORT): Request for Channel-1 Abort</li> <li>■ 0x0 (DISABLE_CH1_ABORT): No Request for Channel-1 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 0</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |
| 31   | CH8_SUSP_WE | W             | <p>This bit is used as a write enable to the Channel-8 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH8_SUSP): Enable Write to respective CH8_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH8_SUSP): Disable Write to CH8_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 7</p> <p><b>Volatile:</b> true</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

**Table 5-9 Fields for Register: DMAC\_CHENREG (Continued)**

| Bits | Name        | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|-------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30   | CH7_SUSP_WE | W             | <p>This bit is used as a write enable to the Channel-7 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH7_SUSP): Enable Write to respective CH7_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH7_SUSP): Disable Write to CH7_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 6</p> <p><b>Volatile:</b> true</p> |
| 29   | CH6_SUSP_WE | W             | <p>This bit is used as a write enable to the Channel-6 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH6_SUSP): Enable Write to respective CH6_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH6_SUSP): Disable Write to CH6_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 5</p> <p><b>Volatile:</b> true</p> |
| 28   | CH5_SUSP_WE | W             | <p>This bit is used as a write enable to the Channel-5 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH5_SUSP): Enable Write to respective CH5_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH5_SUSP): Disable Write to CH5_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 4</p> <p><b>Volatile:</b> true</p> |
| 27   | CH4_SUSP_WE | W             | <p>This bit is used as a write enable to the Channel-4 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH4_SUSP): Enable Write to respective CH4_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH4_SUSP): Disable Write to CH4_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 3</p> <p><b>Volatile:</b> true</p> |

**Table 5-9 Fields for Register: DMAC\_CHENREG (Continued)**

| Bits | Name        | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|-------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 26   | CH3_SUSP_WE | W             | <p>This bit is used as a write enable to the Channel-3 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH3_SUSP): Enable Write to respective CH3_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH3_SUSP): Disable Write to CH3_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 2</p> <p><b>Volatile:</b> true</p> |
| 25   | CH2_SUSP_WE | W             | <p>This bit is used as a write enable to the Channel-2 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH2_SUSP): Enable Write to respective CH2_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH2_SUSP): Disable Write to CH2_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 1</p> <p><b>Volatile:</b> true</p> |
| 24   | CH1_SUSP_WE | W             | <p>This bit is used as a write enable to the Channel-1 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH1_SUSP): Enable Write to respective CH1_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH1_SUSP): Disable Write to CH1_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 0</p> <p><b>Volatile:</b> true</p> |

**Table 5-9 Fields for Register: DMAC\_CHENREG (Continued)**

| Bits | Name     | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|----------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23   | CH8_SUSP | R/W           | <p>Channel-8 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH8_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH8_SUSP bit to 1 and polls CH8_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH8_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH8_SUSP bit to 0, after DW_axi_dmac sets CH8_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH8_SUSP): Request to Suspended Channel-8</li> <li>■ 0x0 (DISABLE_CH8_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 7</p> <p><b>Volatile:</b> true</p> |

**Table 5-9 Fields for Register: DMAC\_CHENREG (Continued)**

| Bits | Name     | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|----------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 22   | CH7_SUSP | R/W           | <p>Channel-7 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH7_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH7_SUSP bit to 1 and polls CH7_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH7_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH7_SUSP bit to 0, after DW_axi_dmac sets CH7_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH7_SUSP): Request to Suspended Channel-7</li> <li>■ 0x0 (DISABLE_CH7_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 6</p> <p><b>Volatile:</b> true</p> |

**Table 5-9 Fields for Register: DMAC\_CHENREG (Continued)**

| Bits | Name     | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|----------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 21   | CH6_SUSP | R/W           | <p>Channel-6 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH6_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH6_SUSP bit to 1 and polls CH6_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH6_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH6_SUSP bit to 0, after DW_axi_dmac sets CH6_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH6_SUSP): Request to Suspended Channel-6</li> <li>■ 0x0 (DISABLE_CH6_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 5</p> <p><b>Volatile:</b> true</p> |

**Table 5-9 Fields for Register: DMAC\_CHENREG (Continued)**

| Bits | Name     | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|----------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 20   | CH5_SUSP | R/W           | <p>Channel-5 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH5_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH5_SUSP bit to 1 and polls CH5_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH5_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH5_SUSP bit to 0, after DW_axi_dmac sets CH5_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH5_SUSP): Request to Suspended Channel-5</li> <li>■ 0x0 (DISABLE_CH5_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 4</p> <p><b>Volatile:</b> true</p> |

**Table 5-9 Fields for Register: DMAC\_CHENREG (Continued)**

| Bits | Name     | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|----------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19   | CH4_SUSP | R/W           | <p>Channel-4 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH4_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH4_SUSP bit to 1 and polls CH4_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH4_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH4_SUSP bit to 0, after DW_axi_dmac sets CH4_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH4_SUSP): Request to Suspended Channel-4</li> <li>■ 0x0 (DISABLE_CH4_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 3</p> <p><b>Volatile:</b> true</p> |

**Table 5-9 Fields for Register: DMAC\_CHENREG (Continued)**

| Bits | Name     | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|----------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18   | CH3_SUSP | R/W           | <p>Channel-3 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH3_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH3_SUSP bit to 1 and polls CH3_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH3_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH3_SUSP bit to 0, after DW_axi_dmac sets CH3_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH3_SUSP): Request to Suspended Channel-3</li> <li>■ 0x0 (DISABLE_CH3_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 2</p> <p><b>Volatile:</b> true</p> |

**Table 5-9 Fields for Register: DMAC\_CHENREG (Continued)**

| Bits | Name     | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|----------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17   | CH2_SUSP | R/W           | <p>Channel-2 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH2_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH2_SUSP bit to 1 and polls CH2_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH2_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH2_SUSP bit to 0, after DW_axi_dmac sets CH2_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH2_SUSP): Request to Suspended Channel-2</li> <li>■ 0x0 (DISABLE_CH2_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 1</p> <p><b>Volatile:</b> true</p> |

**Table 5-9 Fields for Register: DMAC\_CHENREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|-----------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16   | CH1_SUSP  | R/W           | <p>Channel-1 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH1_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH1_SUSP bit to 1 and polls CH1_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH1_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH1_SUSP bit to 0, after DW_axi_dmac sets CH1_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH1_SUSP): Request to Suspended Channel-1</li> <li>■ 0x0 (DISABLE_CH1_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 0</p> <p><b>Volatile:</b> true</p> |
| 15   | CH8_EN_WE | W             | <p>DW_axi_dmac Channel-8 Enable Write Enable bit.</p> <p>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH8_EN): Enable Write to CH8_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH8_EN): Disable Write to respective CH8_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 7</p> <p><b>Volatile:</b> true</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

**Table 5-9 Fields for Register: DMAC\_CHENREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------|-----------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14   | CH7_EN_WE | W             | <p>DW_axi_dmac Channel-7 Enable Write Enable bit.<br/>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH7_EN): Enable Write to CH7_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH7_EN): Disable Write to respective CH7_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> DMAX_NUM_CHANNELS &gt; 6<br/> <b>Volatile:</b> true</p> |
| 13   | CH6_EN_WE | W             | <p>DW_axi_dmac Channel-6 Enable Write Enable bit.<br/>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH6_EN): Enable Write to CH6_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH6_EN): Disable Write to respective CH6_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> DMAX_NUM_CHANNELS &gt; 5<br/> <b>Volatile:</b> true</p> |
| 12   | CH5_EN_WE | W             | <p>DW_axi_dmac Channel-5 Enable Write Enable bit.<br/>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH5_EN): Enable Write to CH5_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH5_EN): Disable Write to respective CH5_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> DMAX_NUM_CHANNELS &gt; 4<br/> <b>Volatile:</b> true</p> |

**Table 5-9 Fields for Register: DMAC\_CHENREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------|-----------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11   | CH4_EN_WE | W             | <p>DW_axi_dmac Channel-4 Enable Write Enable bit.<br/>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH4_EN): Enable Write to CH4_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH4_EN): Disable Write to respective CH4_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> DMAX_NUM_CHANNELS &gt; 3<br/> <b>Volatile:</b> true</p> |
| 10   | CH3_EN_WE | W             | <p>DW_axi_dmac Channel-3 Enable Write Enable bit.<br/>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH3_EN): Enable Write to CH3_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH3_EN): Disable Write to respective CH3_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> DMAX_NUM_CHANNELS &gt; 2<br/> <b>Volatile:</b> true</p> |
| 9    | CH2_EN_WE | W             | <p>DW_axi_dmac Channel-2 Enable Write Enable bit.<br/>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH2_EN): Enable Write to CH2_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH2_EN): Disable Write to respective CH2_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> DMAX_NUM_CHANNELS &gt; 1<br/> <b>Volatile:</b> true</p> |

**Table 5-9 Fields for Register: DMAC\_CHENREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|-----------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8    | CH1_EN_WE | W             | <p>DW_axi_dmac Channel-1 Enable Write Enable bit.<br/>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH1_EN): Enable Write to CH1_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH1_EN): Disable Write to respective CH1_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 0</p> <p><b>Volatile:</b> true</p>                                                                                                                                                                                                                                                                                                                                                                        |
| 7    | CH8_EN    | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-8.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-8 is disabled</li> <li>■ 1: DW_axi_dmac Channel-8 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH8_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH8): DW_axi_dmac: Channel-8 is enabled</li> <li>■ 0x0 (DISABLE_CH8): DW_axi_dmac: Channel-8 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= x</p> <p><b>Volatile:</b> true</p> |

**Table 5-9 Fields for Register: DMAC\_CHENREG (Continued)**

| Bits | Name   | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|--------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6    | CH7_EN | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-7.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-7 is disabled</li> <li>■ 1: DW_axi_dmac Channel-7 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH7_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH7): DW_axi_dmac: Channel-7 is enabled</li> <li>■ 0x0 (DISABLE_CH7): DW_axi_dmac: Channel-7 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= x</p> <p><b>Volatile:</b> true</p> |
| 5    | CH6_EN | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-6.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-6 is disabled</li> <li>■ 1: DW_axi_dmac Channel-6 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH6_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH6): DW_axi_dmac: Channel-6 is enabled</li> <li>■ 0x0 (DISABLE_CH6): DW_axi_dmac: Channel-6 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= x</p> <p><b>Volatile:</b> true</p> |

**Table 5-9 Fields for Register: DMAC\_CHENREG (Continued)**

| Bits | Name   | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|--------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4    | CH5_EN | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-5.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-5 is disabled</li> <li>■ 1: DW_axi_dmac Channel-5 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH5_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH5): DW_axi_dmac: Channel-5 is enabled</li> <li>■ 0x0 (DISABLE_CH5): DW_axi_dmac: Channel-5 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= x</p> <p><b>Volatile:</b> true</p> |
| 3    | CH4_EN | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-4.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-4 is disabled</li> <li>■ 1: DW_axi_dmac Channel-4 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH4_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH4): DW_axi_dmac: Channel-4 is enabled</li> <li>■ 0x0 (DISABLE_CH4): DW_axi_dmac: Channel-4 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= x</p> <p><b>Volatile:</b> true</p> |

**Table 5-9 Fields for Register: DMAC\_CHENREG (Continued)**

| Bits | Name   | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|--------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2    | CH3_EN | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-3.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-3 is disabled</li> <li>■ 1: DW_axi_dmac Channel-3 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH3_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH3): DW_axi_dmac: Channel-3 is enabled</li> <li>■ 0x0 (DISABLE_CH3): DW_axi_dmac: Channel-3 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= x</p> <p><b>Volatile:</b> true</p> |
| 1    | CH2_EN | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-2.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-2 is disabled</li> <li>■ 1: DW_axi_dmac Channel-2 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH2_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH2): DW_axi_dmac: Channel-2 is enabled</li> <li>■ 0x0 (DISABLE_CH2): DW_axi_dmac: Channel-2 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= x</p> <p><b>Volatile:</b> true</p> |

**Table 5-9 Fields for Register: DMAC\_CHENREG (Continued)**

| Bits | Name   | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|--------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | CH1_EN | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-1.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-1 is disabled</li> <li>■ 1: DW_axi_dmac Channel-1 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH1_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH1): DW_axi_dmac: Channel-1 is enabled</li> <li>■ 0x0 (DISABLE_CH1): DW_axi_dmac: Channel-1 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= x</p> <p><b>Volatile:</b> true</p> |

### 5.1.5 DMAC\_CHENREG2

- Description:** This is DW\_axi\_dmac Channel Enable Register. If software wants to set up a new channel, it can read this register to find out which channels are currently inactive and then enable an inactive channel with the required priority.

All bits of this register are cleared to 0 when the DW\_axi\_dmac Global Enable bit (DMAC\_CfgReg.DMAC\_EN) is 0. When DMAC\_CfgReg.DMAC\_EN is 0, a write to the DMAC\_ChEnReg register is ignored and a read always reads back 0.

The channel enable bit, DMAC\_ChEnReg.CH\_EN, is written only if the corresponding channel write enable bit, DMAC\_ChEnReg.CH\_EN\_WE, is asserted on the same slave interface write transfer. For example, writing hex 0000\_XXXX\_0001\_XXX1 writes a 1 into DMAC\_ChEnReg [0], while DMAC\_ChEnReg [15:1] and DMAC\_ChEnReg [47:32] remains unchanged. . Writing hex 0000\_XXXX\_0000\_XXXX leaves DMAC\_ChEnReg [15:0] and DMAC\_ChEnReg [47:32] unchanged.

- Size:** 64 bits
- Offset:** 0x18
- Exists:** DMAX\_NUM\_CHANNELS > 8

|            |    |
|------------|----|
| CH32_EN_WE | 63 |
| CH31_EN_WE | 62 |
| CH30_EN_WE | 61 |
| CH29_EN_WE | 60 |
| CH28_EN_WE | 59 |
| CH27_EN_WE | 58 |
| CH26_EN_WE | 57 |
| CH25_EN_WE | 56 |
| CH24_EN_WE | 55 |
| CH23_EN_WE | 54 |
| CH22_EN_WE | 53 |
| CH21_EN_WE | 52 |
| CH20_EN_WE | 51 |
| CH19_EN_WE | 50 |
| CH18_EN_WE | 49 |
| CH17_EN_WE | 48 |
| CH32_EN    | 47 |
| CH31_EN    | 46 |
| CH30_EN    | 45 |
| CH29_EN    | 44 |
| CH28_EN    | 43 |
| CH27_EN    | 42 |
| CH26_EN    | 41 |
| CH25_EN    | 40 |
| CH24_EN    | 39 |
| CH23_EN    | 38 |
| CH22_EN    | 37 |
| CH21_EN    | 36 |
| CH20_EN    | 35 |
| CH19_EN    | 34 |
| CH18_EN    | 33 |
| CH17_EN    | 32 |
| CH16_EN_WE | 31 |
| CH15_EN_WE | 30 |
| CH14_EN_WE | 29 |
| CH13_EN_WE | 28 |
| CH12_EN_WE | 27 |
| CH11_EN_WE | 26 |
| CH10_EN_WE | 25 |
| CH9_EN_WE  | 24 |
| CH8_EN_WE  | 23 |
| CH7_EN_WE  | 22 |
| CH6_EN_WE  | 21 |
| CH5_EN     | 20 |
| CH4_EN     | 19 |
| CH3_EN     | 18 |
| CH2_EN     | 17 |
| CH1_EN     | 16 |
| CH16_EN    | 15 |
| CH15_EN    | 14 |
| CH14_EN    | 13 |
| CH13_EN    | 12 |
| CH12_EN    | 11 |
| CH11_EN    | 10 |
| CH10_EN    | 9  |
| CH9_EN     | 8  |
| CH8_EN     | 7  |
| CH7_EN     | 6  |
| CH6_EN     | 5  |
| CH5_EN     | 4  |
| CH4_EN     | 3  |
| CH3_EN     | 2  |
| CH2_EN     | 1  |

Table 5-10 Fields for Register: DMAC\_CHENREG2

| Bits | Name       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63   | CH32_EN_WE | W             | <p>DW_axi_dmac Channel-32 Enable Write Enable bit.<br/>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH32_EN): Enable Write to CH32_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH32_EN): Disable Write to respective CH32_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> DMAX_NUM_CHANNELS &gt; 31<br/> <b>Volatile:</b> true</p> |

**Table 5-10 Fields for Register: DMAC\_CHENREG2 (Continued)**

| Bits | Name       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 62   | CH31_EN_WE | W             | <p>DW_axi_dmac Channel-31 Enable Write Enable bit.<br/>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH31_EN): Enable Write to CH31_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH31_EN): Disable Write to respective CH31_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> DMAX_NUM_CHANNELS &gt; 30<br/> <b>Volatile:</b> true</p> |
| 61   | CH30_EN_WE | W             | <p>DW_axi_dmac Channel-30 Enable Write Enable bit.<br/>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH30_EN): Enable Write to CH30_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH30_EN): Disable Write to respective CH30_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> DMAX_NUM_CHANNELS &gt; 29<br/> <b>Volatile:</b> true</p> |
| 60   | CH29_EN_WE | W             | <p>DW_axi_dmac Channel-29 Enable Write Enable bit.<br/>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH29_EN): Enable Write to CH29_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH29_EN): Disable Write to respective CH29_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> DMAX_NUM_CHANNELS &gt; 28<br/> <b>Volatile:</b> true</p> |

**Table 5-10 Fields for Register: DMAC\_CHENREG2 (Continued)**

| Bits | Name       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 59   | CH28_EN_WE | W             | <p>DW_axi_dmac Channel-28 Enable Write Enable bit.<br/>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH28_EN): Enable Write to CH28_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH28_EN): Disable Write to respective CH28_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> DMAX_NUM_CHANNELS &gt; 27<br/> <b>Volatile:</b> true</p> |
| 58   | CH27_EN_WE | W             | <p>DW_axi_dmac Channel-27 Enable Write Enable bit.<br/>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH27_EN): Enable Write to CH27_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH27_EN): Disable Write to respective CH27_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> DMAX_NUM_CHANNELS &gt; 26<br/> <b>Volatile:</b> true</p> |
| 57   | CH26_EN_WE | W             | <p>DW_axi_dmac Channel-26 Enable Write Enable bit.<br/>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH26_EN): Enable Write to CH26_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH26_EN): Disable Write to respective CH26_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> DMAX_NUM_CHANNELS &gt; 25<br/> <b>Volatile:</b> true</p> |

**Table 5-10 Fields for Register: DMAC\_CHENREG2 (Continued)**

| Bits | Name       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 56   | CH25_EN_WE | W             | <p>DW_axi_dmac Channel-25 Enable Write Enable bit.<br/>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH25_EN): Enable Write to CH25_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH25_EN): Disable Write to respective CH25_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> DMAX_NUM_CHANNELS &gt; 24<br/> <b>Volatile:</b> true</p> |
| 55   | CH24_EN_WE | W             | <p>DW_axi_dmac Channel-24 Enable Write Enable bit.<br/>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH24_EN): Enable Write to CH24_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH24_EN): Disable Write to respective CH24_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> DMAX_NUM_CHANNELS &gt; 23<br/> <b>Volatile:</b> true</p> |
| 54   | CH23_EN_WE | W             | <p>DW_axi_dmac Channel-23 Enable Write Enable bit.<br/>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH23_EN): Enable Write to CH23_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH23_EN): Disable Write to respective CH23_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> DMAX_NUM_CHANNELS &gt; 22<br/> <b>Volatile:</b> true</p> |

**Table 5-10 Fields for Register: DMAC\_CHENREG2 (Continued)**

| Bits | Name       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 53   | CH22_EN_WE | W             | <p>DW_axi_dmac Channel-22 Enable Write Enable bit.<br/>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH22_EN): Enable Write to CH22_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH22_EN): Disable Write to respective CH22_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> DMAX_NUM_CHANNELS &gt; 21<br/> <b>Volatile:</b> true</p> |
| 52   | CH21_EN_WE | W             | <p>DW_axi_dmac Channel-21 Enable Write Enable bit.<br/>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH21_EN): Enable Write to CH21_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH21_EN): Disable Write to respective CH21_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> DMAX_NUM_CHANNELS &gt; 20<br/> <b>Volatile:</b> true</p> |
| 51   | CH20_EN_WE | W             | <p>DW_axi_dmac Channel-20 Enable Write Enable bit.<br/>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH20_EN): Enable Write to CH20_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH20_EN): Disable Write to respective CH20_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> DMAX_NUM_CHANNELS &gt; 19<br/> <b>Volatile:</b> true</p> |

**Table 5-10 Fields for Register: DMAC\_CHENREG2 (Continued)**

| Bits | Name       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 50   | CH19_EN_WE | W             | <p>DW_axi_dmac Channel-19 Enable Write Enable bit.<br/>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH19_EN): Enable Write to CH19_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH19_EN): Disable Write to respective CH19_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> DMAX_NUM_CHANNELS &gt; 18<br/> <b>Volatile:</b> true</p> |
| 49   | CH18_EN_WE | W             | <p>DW_axi_dmac Channel-18 Enable Write Enable bit.<br/>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH18_EN): Enable Write to CH18_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH18_EN): Disable Write to respective CH18_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> DMAX_NUM_CHANNELS &gt; 17<br/> <b>Volatile:</b> true</p> |
| 48   | CH17_EN_WE | W             | <p>DW_axi_dmac Channel-17 Enable Write Enable bit.<br/>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH17_EN): Enable Write to CH17_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH17_EN): Disable Write to respective CH17_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> DMAX_NUM_CHANNELS &gt; 16<br/> <b>Volatile:</b> true</p> |

**Table 5-10 Fields for Register: DMAC\_CHENREG2 (Continued)**

| Bits | Name    | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|---------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 47   | CH32_EN | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-32.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-32 is disabled</li> <li>■ 1: DW_axi_dmac Channel-32 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH32_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH32): DW_axi_dmac: Channel-32 is enabled</li> <li>■ 0x0 (DISABLE_CH32): DW_axi_dmac: Channel-32 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 31</p> <p><b>Volatile:</b> true</p> |
| 46   | CH31_EN | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-31.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-31 is disabled</li> <li>■ 1: DW_axi_dmac Channel-31 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH31_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH31): DW_axi_dmac: Channel-31 is enabled</li> <li>■ 0x0 (DISABLE_CH31): DW_axi_dmac: Channel-31 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 30</p> <p><b>Volatile:</b> true</p> |

**Table 5-10 Fields for Register: DMAC\_CHENREG2 (Continued)**

| Bits | Name    | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|---------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 45   | CH30_EN | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-30.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-30 is disabled</li> <li>■ 1: DW_axi_dmac Channel-30 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH30_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH30): DW_axi_dmac: Channel-30 is enabled</li> <li>■ 0x0 (DISABLE_CH30): DW_axi_dmac: Channel-30 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 29</p> <p><b>Volatile:</b> true</p> |
| 44   | CH29_EN | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-29.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-29 is disabled</li> <li>■ 1: DW_axi_dmac Channel-29 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH29_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH29): DW_axi_dmac: Channel-29 is enabled</li> <li>■ 0x0 (DISABLE_CH29): DW_axi_dmac: Channel-29 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 28</p> <p><b>Volatile:</b> true</p> |

**Table 5-10 Fields for Register: DMAC\_CHENREG2 (Continued)**

| Bits | Name    | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|---------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 43   | CH28_EN | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-28.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-28 is disabled</li> <li>■ 1: DW_axi_dmac Channel-28 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH28_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH28): DW_axi_dmac: Channel-28 is enabled</li> <li>■ 0x0 (DISABLE_CH28): DW_axi_dmac: Channel-28 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 27</p> <p><b>Volatile:</b> true</p> |
| 42   | CH27_EN | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-27.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-27 is disabled</li> <li>■ 1: DW_axi_dmac Channel-27 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH27_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH27): DW_axi_dmac: Channel-27 is enabled</li> <li>■ 0x0 (DISABLE_CH27): DW_axi_dmac: Channel-27 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 26</p> <p><b>Volatile:</b> true</p> |

**Table 5-10 Fields for Register: DMAC\_CHENREG2 (Continued)**

| Bits | Name    | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|---------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 41   | CH26_EN | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-26.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-26 is disabled</li> <li>■ 1: DW_axi_dmac Channel-26 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH26_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH26): DW_axi_dmac: Channel-26 is enabled</li> <li>■ 0x0 (DISABLE_CH26): DW_axi_dmac: Channel-26 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 25</p> <p><b>Volatile:</b> true</p> |
| 40   | CH25_EN | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-25.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-25 is disabled</li> <li>■ 1: DW_axi_dmac Channel-25 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH25_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH25): DW_axi_dmac: Channel-25 is enabled</li> <li>■ 0x0 (DISABLE_CH25): DW_axi_dmac: Channel-25 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 24</p> <p><b>Volatile:</b> true</p> |

**Table 5-10 Fields for Register: DMAC\_CHENREG2 (Continued)**

| Bits | Name    | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|---------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 39   | CH24_EN | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-24.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-24 is disabled</li> <li>■ 1: DW_axi_dmac Channel-24 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH24_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH24): DW_axi_dmac: Channel-24 is enabled</li> <li>■ 0x0 (DISABLE_CH24): DW_axi_dmac: Channel-24 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 23</p> <p><b>Volatile:</b> true</p> |
| 38   | CH23_EN | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-23.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-23 is disabled</li> <li>■ 1: DW_axi_dmac Channel-23 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH23_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH23): DW_axi_dmac: Channel-23 is enabled</li> <li>■ 0x0 (DISABLE_CH23): DW_axi_dmac: Channel-23 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 22</p> <p><b>Volatile:</b> true</p> |

**Table 5-10 Fields for Register: DMAC\_CHENREG2 (Continued)**

| Bits | Name    | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|---------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 37   | CH22_EN | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-22.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-22 is disabled</li> <li>■ 1: DW_axi_dmac Channel-22 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH22_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH22): DW_axi_dmac: Channel-22 is enabled</li> <li>■ 0x0 (DISABLE_CH22): DW_axi_dmac: Channel-22 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 21</p> <p><b>Volatile:</b> true</p> |
| 36   | CH21_EN | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-21.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-21 is disabled</li> <li>■ 1: DW_axi_dmac Channel-21 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH21_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH21): DW_axi_dmac: Channel-21 is enabled</li> <li>■ 0x0 (DISABLE_CH21): DW_axi_dmac: Channel-21 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 20</p> <p><b>Volatile:</b> true</p> |

**Table 5-10 Fields for Register: DMAC\_CHENREG2 (Continued)**

| Bits | Name    | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|---------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 35   | CH20_EN | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-20.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-20 is disabled</li> <li>■ 1: DW_axi_dmac Channel-20 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH20_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH20): DW_axi_dmac: Channel-20 is enabled</li> <li>■ 0x0 (DISABLE_CH20): DW_axi_dmac: Channel-20 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 19</p> <p><b>Volatile:</b> true</p> |
| 34   | CH19_EN | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-19.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-19 is disabled</li> <li>■ 1: DW_axi_dmac Channel-19 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH19_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH19): DW_axi_dmac: Channel-19 is enabled</li> <li>■ 0x0 (DISABLE_CH19): DW_axi_dmac: Channel-19 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 18</p> <p><b>Volatile:</b> true</p> |

**Table 5-10 Fields for Register: DMAC\_CHENREG2 (Continued)**

| Bits | Name    | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|---------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 33   | CH18_EN | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-18.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-18 is disabled</li> <li>■ 1: DW_axi_dmac Channel-18 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH18_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH18): DW_axi_dmac: Channel-18 is enabled</li> <li>■ 0x0 (DISABLE_CH18): DW_axi_dmac: Channel-18 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 17</p> <p><b>Volatile:</b> true</p> |
| 32   | CH17_EN | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-17.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-17 is disabled</li> <li>■ 1: DW_axi_dmac Channel-17 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH17_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH17): DW_axi_dmac: Channel-17 is enabled</li> <li>■ 0x0 (DISABLE_CH17): DW_axi_dmac: Channel-17 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 16</p> <p><b>Volatile:</b> true</p> |

**Table 5-10 Fields for Register: DMAC\_CHENREG2 (Continued)**

| Bits | Name       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | CH16_EN_WE | W             | <p>DW_axi_dmac Channel-16 Enable Write Enable bit.<br/>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH16_EN): Enable Write to CH16_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH16_EN): Disable Write to respective CH16_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> DMAX_NUM_CHANNELS &gt; 15<br/> <b>Volatile:</b> true</p> |
| 30   | CH15_EN_WE | W             | <p>DW_axi_dmac Channel-15 Enable Write Enable bit.<br/>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH15_EN): Enable Write to CH15_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH15_EN): Disable Write to respective CH15_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> DMAX_NUM_CHANNELS &gt; 14<br/> <b>Volatile:</b> true</p> |
| 29   | CH14_EN_WE | W             | <p>DW_axi_dmac Channel-14 Enable Write Enable bit.<br/>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH14_EN): Enable Write to CH14_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH14_EN): Disable Write to respective CH14_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> DMAX_NUM_CHANNELS &gt; 13<br/> <b>Volatile:</b> true</p> |

**Table 5-10 Fields for Register: DMAC\_CHENREG2 (Continued)**

| Bits | Name       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 28   | CH13_EN_WE | W             | <p>DW_axi_dmac Channel-13 Enable Write Enable bit.<br/>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH13_EN): Enable Write to CH13_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH13_EN): Disable Write to respective CH13_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> DMAX_NUM_CHANNELS &gt; 12<br/> <b>Volatile:</b> true</p> |
| 27   | CH12_EN_WE | W             | <p>DW_axi_dmac Channel-12 Enable Write Enable bit.<br/>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH12_EN): Enable Write to CH12_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH12_EN): Disable Write to respective CH12_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> DMAX_NUM_CHANNELS &gt; 11<br/> <b>Volatile:</b> true</p> |
| 26   | CH11_EN_WE | W             | <p>DW_axi_dmac Channel-11 Enable Write Enable bit.<br/>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH11_EN): Enable Write to CH11_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH11_EN): Disable Write to respective CH11_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> DMAX_NUM_CHANNELS &gt; 10<br/> <b>Volatile:</b> true</p> |

**Table 5-10 Fields for Register: DMAC\_CHENREG2 (Continued)**

| Bits | Name       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------|------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 25   | CH10_EN_WE | W             | <p>DW_axi_dmac Channel-10 Enable Write Enable bit.<br/>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH10_EN): Enable Write to CH10_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH10_EN): Disable Write to respective CH10_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> DMAX_NUM_CHANNELS &gt; 9<br/> <b>Volatile:</b> true</p> |
| 24   | CH9_EN_WE  | W             | <p>DW_axi_dmac Channel-9 Enable Write Enable bit.<br/>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH9_EN): Enable Write to CH9_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH9_EN): Disable Write to respective CH9_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> DMAX_NUM_CHANNELS &gt; 8<br/> <b>Volatile:</b> true</p>      |
| 23   | CH8_EN_WE  | W             | <p>DW_axi_dmac Channel-8 Enable Write Enable bit.<br/>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH8_EN): Enable Write to CH8_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH8_EN): Disable Write to respective CH8_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> DMAX_NUM_CHANNELS &gt; 7<br/> <b>Volatile:</b> true</p>      |

**Table 5-10 Fields for Register: DMAC\_CHENREG2 (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------|-----------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 22   | CH7_EN_WE | W             | <p>DW_axi_dmac Channel-7 Enable Write Enable bit.<br/>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH7_EN): Enable Write to CH7_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH7_EN): Disable Write to respective CH7_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> DMAX_NUM_CHANNELS &gt; 6<br/> <b>Volatile:</b> true</p> |
| 21   | CH6_EN_WE | W             | <p>DW_axi_dmac Channel-6 Enable Write Enable bit.<br/>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH6_EN): Enable Write to CH6_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH6_EN): Disable Write to respective CH6_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> DMAX_NUM_CHANNELS &gt; 5<br/> <b>Volatile:</b> true</p> |
| 20   | CH5_EN_WE | W             | <p>DW_axi_dmac Channel-5 Enable Write Enable bit.<br/>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH5_EN): Enable Write to CH5_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH5_EN): Disable Write to respective CH5_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> DMAX_NUM_CHANNELS &gt; 4<br/> <b>Volatile:</b> true</p> |

**Table 5-10 Fields for Register: DMAC\_CHENREG2 (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|-----------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19   | CH4_EN_WE | W             | <p>DW_axi_dmac Channel-4 Enable Write Enable bit.<br/>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH4_EN): Enable Write to CH4_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH4_EN): Disable Write to respective CH4_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 3</p> <p><b>Volatile:</b> true</p> |
| 18   | CH3_EN_WE | W             | <p>DW_axi_dmac Channel-3 Enable Write Enable bit.<br/>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH3_EN): Enable Write to CH3_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH3_EN): Disable Write to respective CH3_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 2</p> <p><b>Volatile:</b> true</p> |
| 17   | CH2_EN_WE | W             | <p>DW_axi_dmac Channel-2 Enable Write Enable bit.<br/>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH2_EN): Enable Write to CH2_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH2_EN): Disable Write to respective CH2_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 1</p> <p><b>Volatile:</b> true</p> |

**Table 5-10 Fields for Register: DMAC\_CHENREG2 (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|-----------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16   | CH1_EN_WE | W             | <p>DW_axi_dmac Channel-1 Enable Write Enable bit.<br/>Read back value of this register bit is always '0'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH1_EN): Enable Write to CH1_EN bit</li> <li>■ 0x0 (DISABLE_WR_CH1_EN): Disable Write to respective CH1_EN bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 0</p> <p><b>Volatile:</b> true</p>                                                                                                                                                                                                                                                                                                                                                                                |
| 15   | CH16_EN   | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-16.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-16 is disabled</li> <li>■ 1: DW_axi_dmac Channel-16 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH16_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH16): DW_axi_dmac: Channel-16 is enabled</li> <li>■ 0x0 (DISABLE_CH16): DW_axi_dmac: Channel-16 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 15</p> <p><b>Volatile:</b> true</p> |

**Table 5-10 Fields for Register: DMAC\_CHENREG2 (Continued)**

| Bits | Name    | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|---------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14   | CH15_EN | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-15.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-15 is disabled</li> <li>■ 1: DW_axi_dmac Channel-15 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH15_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH15): DW_axi_dmac: Channel-15 is enabled</li> <li>■ 0x0 (DISABLE_CH15): DW_axi_dmac: Channel-15 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 14</p> <p><b>Volatile:</b> true</p> |
| 13   | CH14_EN | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-14.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-14 is disabled</li> <li>■ 1: DW_axi_dmac Channel-14 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH14_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH14): DW_axi_dmac: Channel-14 is enabled</li> <li>■ 0x0 (DISABLE_CH14): DW_axi_dmac: Channel-14 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 13</p> <p><b>Volatile:</b> true</p> |

**Table 5-10 Fields for Register: DMAC\_CHENREG2 (Continued)**

| Bits | Name    | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|---------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12   | CH13_EN | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-13.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-13 is disabled</li> <li>■ 1: DW_axi_dmac Channel-13 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH13_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH13): DW_axi_dmac: Channel-13 is enabled</li> <li>■ 0x0 (DISABLE_CH13): DW_axi_dmac: Channel-13 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 12</p> <p><b>Volatile:</b> true</p> |
| 11   | CH12_EN | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-12.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-12 is disabled</li> <li>■ 1: DW_axi_dmac Channel-12 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH12_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH12): DW_axi_dmac: Channel-12 is enabled</li> <li>■ 0x0 (DISABLE_CH12): DW_axi_dmac: Channel-12 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 11</p> <p><b>Volatile:</b> true</p> |

**Table 5-10 Fields for Register: DMAC\_CHENREG2 (Continued)**

| Bits | Name    | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|---------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10   | CH11_EN | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-11.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-11 is disabled</li> <li>■ 1: DW_axi_dmac Channel-11 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH11_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH11): DW_axi_dmac: Channel-11 is enabled</li> <li>■ 0x0 (DISABLE_CH11): DW_axi_dmac: Channel-11 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 10</p> <p><b>Volatile:</b> true</p> |
| 9    | CH10_EN | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-10.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-10 is disabled</li> <li>■ 1: DW_axi_dmac Channel-10 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH10_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH10): DW_axi_dmac: Channel-10 is enabled</li> <li>■ 0x0 (DISABLE_CH10): DW_axi_dmac: Channel-10 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 9</p> <p><b>Volatile:</b> true</p>  |

**Table 5-10 Fields for Register: DMAC\_CHENREG2 (Continued)**

| Bits | Name   | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|--------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8    | CH9_EN | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-9.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-9 is disabled</li> <li>■ 1: DW_axi_dmac Channel-9 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH9_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH9): DW_axi_dmac: Channel-9 is enabled</li> <li>■ 0x0 (DISABLE_CH9): DW_axi_dmac: Channel-9 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 8</p> <p><b>Volatile:</b> true</p> |
| 7    | CH8_EN | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-8.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-8 is disabled</li> <li>■ 1: DW_axi_dmac Channel-8 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH8_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH8): DW_axi_dmac: Channel-8 is enabled</li> <li>■ 0x0 (DISABLE_CH8): DW_axi_dmac: Channel-8 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 7</p> <p><b>Volatile:</b> true</p> |

**Table 5-10 Fields for Register: DMAC\_CHENREG2 (Continued)**

| Bits | Name   | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|--------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6    | CH7_EN | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-7.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-7 is disabled</li> <li>■ 1: DW_axi_dmac Channel-7 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH7_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH7): DW_axi_dmac: Channel-7 is enabled</li> <li>■ 0x0 (DISABLE_CH7): DW_axi_dmac: Channel-7 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 6</p> <p><b>Volatile:</b> true</p> |
| 5    | CH6_EN | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-6.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-6 is disabled</li> <li>■ 1: DW_axi_dmac Channel-6 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH6_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH6): DW_axi_dmac: Channel-6 is enabled</li> <li>■ 0x0 (DISABLE_CH6): DW_axi_dmac: Channel-6 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 5</p> <p><b>Volatile:</b> true</p> |

**Table 5-10 Fields for Register: DMAC\_CHENREG2 (Continued)**

| Bits | Name   | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|--------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4    | CH5_EN | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-5.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-5 is disabled</li> <li>■ 1: DW_axi_dmac Channel-5 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH5_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH5): DW_axi_dmac: Channel-5 is enabled</li> <li>■ 0x0 (DISABLE_CH5): DW_axi_dmac: Channel-5 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 4</p> <p><b>Volatile:</b> true</p> |
| 3    | CH4_EN | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-4.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-4 is disabled</li> <li>■ 1: DW_axi_dmac Channel-4 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH4_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH4): DW_axi_dmac: Channel-4 is enabled</li> <li>■ 0x0 (DISABLE_CH4): DW_axi_dmac: Channel-4 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 3</p> <p><b>Volatile:</b> true</p> |

**Table 5-10 Fields for Register: DMAC\_CHENREG2 (Continued)**

| Bits | Name   | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|--------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2    | CH3_EN | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-3.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-3 is disabled</li> <li>■ 1: DW_axi_dmac Channel-3 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH3_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH3): DW_axi_dmac: Channel-3 is enabled</li> <li>■ 0x0 (DISABLE_CH3): DW_axi_dmac: Channel-3 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 2</p> <p><b>Volatile:</b> true</p> |
| 1    | CH2_EN | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-2.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-2 is disabled</li> <li>■ 1: DW_axi_dmac Channel-2 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH2_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH2): DW_axi_dmac: Channel-2 is enabled</li> <li>■ 0x0 (DISABLE_CH2): DW_axi_dmac: Channel-2 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 1</p> <p><b>Volatile:</b> true</p> |

**Table 5-10 Fields for Register: DMAC\_CHENREG2 (Continued)**

| Bits | Name   | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|--------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | CH1_EN | R/W           | <p>This bit is used to enable the DW_axi_dmac Channel-1.</p> <ul style="list-style-type: none"> <li>■ 0: DW_axi_dmac Channel-1 is disabled</li> <li>■ 1: DW_axi_dmac Channel-1 is enabled</li> </ul> <p>The bit 'DMAC_ChEnReg.CH1_EN' is automatically cleared by hardware to disable the channel after the last AMBA transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH1): DW_axi_dmac: Channel-1 is enabled</li> <li>■ 0x0 (DISABLE_CH1): DW_axi_dmac: Channel-1 is disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 0</p> <p><b>Volatile:</b> true</p> |

### 5.1.6 DMAC\_CHSUSPREG

- **Description:** This is DW\_axi\_dmac Channel Suspend Register. The channel suspend bit, DMAC\_ChSuspReg.CH\_SUSP, is written only if the corresponding channel write enable bit, DMAC\_ChSuspReg.CH\_SUSP\_WE, is asserted on the same slave interface write transfer. For example, writing hex 0000\_XXXX\_0001\_XXX1 writes a 1 into DMAC\_ChSuspReg [0], while DMAC\_ChSuspReg [15:1] and DMAC\_ChSuspReg [47:32] remains unchanged. Writing hex 0000\_XXXX\_0000\_XXXX leaves DMAC\_ChSuspReg [15:0] and DMAC\_ChSuspReg [47:32] unchanged.
- **Size:** 64 bits
- **Offset:** 0x20
- **Exists:** DMAX\_NUM\_CHANNELS > 8

|              |    |      |    |
|--------------|----|------|----|
| CH32_SUSP_WE | 63 | SUSP | WE |
| CH31_SUSP_WE | 62 | SUSP | WE |
| CH30_SUSP_WE | 61 | SUSP | WE |
| CH29_SUSP_WE | 60 | SUSP | WE |
| CH28_SUSP_WE | 59 | SUSP | WE |
| CH27_SUSP_WE | 58 | SUSP | WE |
| CH26_SUSP_WE | 57 | SUSP | WE |
| CH25_SUSP_WE | 56 | SUSP | WE |
| CH24_SUSP_WE | 55 | SUSP | WE |
| CH23_SUSP_WE | 54 | SUSP | WE |
| CH22_SUSP_WE | 53 | SUSP | WE |
| CH21_SUSP_WE | 52 | SUSP | WE |
| CH20_SUSP_WE | 51 | SUSP | WE |
| CH19_SUSP_WE | 50 | SUSP | WE |
| CH18_SUSP_WE | 49 | SUSP | WE |
| CH17_SUSP_WE | 48 | SUSP | WE |
| CH32_SUSP_WE | 47 | SUSP | WE |
| CH31_SUSP_WE | 46 | SUSP | WE |
| CH30_SUSP_WE | 45 | SUSP | WE |
| CH29_SUSP_WE | 44 | SUSP | WE |
| CH28_SUSP_WE | 43 | SUSP | WE |
| CH27_SUSP_WE | 42 | SUSP | WE |
| CH26_SUSP_WE | 41 | SUSP | WE |
| CH25_SUSP_WE | 40 | SUSP | WE |
| CH24_SUSP_WE | 39 | SUSP | WE |
| CH23_SUSP_WE | 38 | SUSP | WE |
| CH22_SUSP_WE | 37 | SUSP | WE |
| CH21_SUSP_WE | 36 | SUSP | WE |
| CH20_SUSP_WE | 35 | SUSP | WE |
| CH19_SUSP_WE | 34 | SUSP | WE |
| CH18_SUSP_WE | 33 | SUSP | WE |
| CH17_SUSP_WE | 32 | SUSP | WE |
| CH16_SUSP_WE | 31 | SUSP | WE |
| CH15_SUSP_WE | 30 | SUSP | WE |
| CH14_SUSP_WE | 29 | SUSP | WE |
| CH13_SUSP_WE | 28 | SUSP | WE |
| CH12_SUSP_WE | 27 | SUSP | WE |
| CH11_SUSP_WE | 26 | SUSP | WE |
| CH10_SUSP_WE | 25 | SUSP | WE |
| CH9_SUSP_WE  | 24 | SUSP | WE |
| CH8_SUSP_WE  | 23 | SUSP | WE |
| CH7_SUSP_WE  | 22 | SUSP | WE |
| CH6_SUSP_WE  | 21 | SUSP | WE |
| CH5_SUSP_WE  | 20 | SUSP | WE |
| CH4_SUSP_WE  | 19 | SUSP | WE |
| CH3_SUSP_WE  | 18 | SUSP | WE |
| CH2_SUSP_WE  | 17 | SUSP | WE |
| CH1_SUSP_WE  | 16 | SUSP | WE |
| CH16_SUSP    | 15 | SUSP | WE |
| CH15_SUSP    | 14 | SUSP | WE |
| CH14_SUSP    | 13 | SUSP | WE |
| CH13_SUSP    | 12 | SUSP | WE |
| CH12_SUSP    | 11 | SUSP | WE |
| CH11_SUSP    | 10 | SUSP | WE |
| CH10_SUSP    | 9  | SUSP | WE |
| CH9_SUSP     | 8  | SUSP | WE |
| CH8_SUSP     | 7  | SUSP | WE |
| CH7_SUSP     | 6  | SUSP | WE |
| CH6_SUSP     | 5  | SUSP | WE |
| CH5_SUSP     | 4  | SUSP | WE |
| CH4_SUSP     | 3  | SUSP | WE |
| CH3_SUSP     | 2  | SUSP | WE |
| CH2_SUSP     | 1  | SUSP | WE |
| CH1_SUSP     | 0  | SUSP | WE |

Table 5-11 Fields for Register: DMAC\_CHSUSPREG

| Bits | Name         | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|--------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63   | CH32_SUSP_WE | W             | <p>This bit is used as a write enable to the Channel-32 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH32_SUSP): Enable Write to respective CH32_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH32_SUSP): Disable Write to CH\${ch_num}_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 31</p> <p><b>Volatile:</b> true</p> |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| Bits | Name         | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|--------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 62   | CH31_SUSP_WE | W             | <p>This bit is used as a write enable to the Channel-31 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH31_SUSP): Enable Write to respective CH31_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH31_SUSP): Disable Write to CH\${ch_num}_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 30</p> <p><b>Volatile:</b> true</p> |
| 61   | CH30_SUSP_WE | W             | <p>This bit is used as a write enable to the Channel-30 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH30_SUSP): Enable Write to respective CH30_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH30_SUSP): Disable Write to CH\${ch_num}_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 29</p> <p><b>Volatile:</b> true</p> |
| 60   | CH29_SUSP_WE | W             | <p>This bit is used as a write enable to the Channel-29 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH29_SUSP): Enable Write to respective CH29_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH29_SUSP): Disable Write to CH\${ch_num}_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 28</p> <p><b>Volatile:</b> true</p> |
| 59   | CH28_SUSP_WE | W             | <p>This bit is used as a write enable to the Channel-28 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH28_SUSP): Enable Write to respective CH28_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH28_SUSP): Disable Write to CH\${ch_num}_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 27</p> <p><b>Volatile:</b> true</p> |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| Bits | Name         | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|--------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 58   | CH27_SUSP_WE | W             | <p>This bit is used as a write enable to the Channel-27 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH27_SUSP): Enable Write to respective CH27_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH27_SUSP): Disable Write to CH\${ch_num}_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 26</p> <p><b>Volatile:</b> true</p> |
| 57   | CH26_SUSP_WE | W             | <p>This bit is used as a write enable to the Channel-26 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH26_SUSP): Enable Write to respective CH26_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH26_SUSP): Disable Write to CH\${ch_num}_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 25</p> <p><b>Volatile:</b> true</p> |
| 56   | CH25_SUSP_WE | W             | <p>This bit is used as a write enable to the Channel-25 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH25_SUSP): Enable Write to respective CH25_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH25_SUSP): Disable Write to CH\${ch_num}_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 24</p> <p><b>Volatile:</b> true</p> |
| 55   | CH24_SUSP_WE | W             | <p>This bit is used as a write enable to the Channel-24 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH24_SUSP): Enable Write to respective CH24_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH24_SUSP): Disable Write to CH\${ch_num}_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 23</p> <p><b>Volatile:</b> true</p> |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| Bits | Name         | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|--------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 54   | CH23_SUSP_WE | W             | <p>This bit is used as a write enable to the Channel-23 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH23_SUSP): Enable Write to respective CH23_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH23_SUSP): Disable Write to CH\${ch_num}_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 22</p> <p><b>Volatile:</b> true</p> |
| 53   | CH22_SUSP_WE | W             | <p>This bit is used as a write enable to the Channel-22 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH22_SUSP): Enable Write to respective CH22_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH22_SUSP): Disable Write to CH\${ch_num}_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 21</p> <p><b>Volatile:</b> true</p> |
| 52   | CH21_SUSP_WE | W             | <p>This bit is used as a write enable to the Channel-21 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH21_SUSP): Enable Write to respective CH21_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH21_SUSP): Disable Write to CH\${ch_num}_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 20</p> <p><b>Volatile:</b> true</p> |
| 51   | CH20_SUSP_WE | W             | <p>This bit is used as a write enable to the Channel-20 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH20_SUSP): Enable Write to respective CH20_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH20_SUSP): Disable Write to CH\${ch_num}_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 19</p> <p><b>Volatile:</b> true</p> |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| Bits | Name         | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|--------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 50   | CH19_SUSP_WE | W             | <p>This bit is used as a write enable to the Channel-19 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH19_SUSP): Enable Write to respective CH19_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH19_SUSP): Disable Write to CH\${ch_num}_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 18</p> <p><b>Volatile:</b> true</p> |
| 49   | CH18_SUSP_WE | W             | <p>This bit is used as a write enable to the Channel-18 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH18_SUSP): Enable Write to respective CH18_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH18_SUSP): Disable Write to CH\${ch_num}_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 17</p> <p><b>Volatile:</b> true</p> |
| 48   | CH17_SUSP_WE | W             | <p>This bit is used as a write enable to the Channel-17 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH17_SUSP): Enable Write to respective CH17_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH17_SUSP): Disable Write to CH\${ch_num}_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 16</p> <p><b>Volatile:</b> true</p> |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| <b>Bits</b> | <b>Name</b> | <b>Memory Access</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------|-------------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 47          | CH32_SUSP   | R/W                  | <p>Channel-32 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH32_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH32_SUSP bit to 1 and polls CH32_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH32_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH32_SUSP bit to 0, after DW_axi_dmac sets CH32_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH32_SUSP): Request to Suspended Channel-32</li> <li>■ 0x0 (DISABLE_CH32_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 31</p> <p><b>Volatile:</b> true</p> |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|-----------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 46   | CH31_SUSP | R/W           | <p>Channel-31 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH31_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH31_SUSP bit to 1 and polls CH31_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH31_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH31_SUSP bit to 0, after DW_axi_dmac sets CH31_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH31_SUSP): Request to Suspended Channel-31</li> <li>■ 0x0 (DISABLE_CH31_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 30</p> <p><b>Volatile:</b> true</p> |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|-----------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 45   | CH30_SUSP | R/W           | <p>Channel-30 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH30_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH30_SUSP bit to 1 and polls CH30_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH30_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH30_SUSP bit to 0, after DW_axi_dmac sets CH30_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH30_SUSP): Request to Suspended Channel-30</li> <li>■ 0x0 (DISABLE_CH30_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 29</p> <p><b>Volatile:</b> true</p> |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|-----------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 44   | CH29_SUSP | R/W           | <p>Channel-29 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH29_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH29_SUSP bit to 1 and polls CH29_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH29_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH29_SUSP bit to 0, after DW_axi_dmac sets CH29_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH29_SUSP): Request to Suspended Channel-29</li> <li>■ 0x0 (DISABLE_CH29_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 28</p> <p><b>Volatile:</b> true</p> |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|-----------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 43   | CH28_SUSP | R/W           | <p>Channel-28 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH28_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH28_SUSP bit to 1 and polls CH28_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH28_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH28_SUSP bit to 0, after DW_axi_dmac sets CH28_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH28_SUSP): Request to Suspended Channel-28</li> <li>■ 0x0 (DISABLE_CH28_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 27</p> <p><b>Volatile:</b> true</p> |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|-----------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 42   | CH27_SUSP | R/W           | <p>Channel-27 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH27_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH27_SUSP bit to 1 and polls CH27_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH27_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH27_SUSP bit to 0, after DW_axi_dmac sets CH27_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH27_SUSP): Request to Suspended Channel-27</li> <li>■ 0x0 (DISABLE_CH27_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 26</p> <p><b>Volatile:</b> true</p> |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|-----------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 41   | CH26_SUSP | R/W           | <p>Channel-26 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH26_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH26_SUSP bit to 1 and polls CH26_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH26_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH26_SUSP bit to 0, after DW_axi_dmac sets CH26_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH26_SUSP): Request to Suspended Channel-26</li> <li>■ 0x0 (DISABLE_CH26_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 25</p> <p><b>Volatile:</b> true</p> |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|-----------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 40   | CH25_SUSP | R/W           | <p>Channel-25 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH25_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH25_SUSP bit to 1 and polls CH25_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH25_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH25_SUSP bit to 0, after DW_axi_dmac sets CH25_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH25_SUSP): Request to Suspended Channel-25</li> <li>■ 0x0 (DISABLE_CH25_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 24</p> <p><b>Volatile:</b> true</p> |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|-----------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 39   | CH24_SUSP | R/W           | <p>Channel-24 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH24_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH24_SUSP bit to 1 and polls CH24_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH24_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH24_SUSP bit to 0, after DW_axi_dmac sets CH24_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH24_SUSP): Request to Suspended Channel-24</li> <li>■ 0x0 (DISABLE_CH24_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 23</p> <p><b>Volatile:</b> true</p> |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| <b>Bits</b> | <b>Name</b> | <b>Memory Access</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------|-------------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 38          | CH23_SUSP   | R/W                  | <p>Channel-23 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH23_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH23_SUSP bit to 1 and polls CH23_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH23_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH23_SUSP bit to 0, after DW_axi_dmac sets CH23_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH23_SUSP): Request to Suspended Channel-23</li> <li>■ 0x0 (DISABLE_CH23_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 22</p> <p><b>Volatile:</b> true</p> |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|-----------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 37   | CH22_SUSP | R/W           | <p>Channel-22 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH22_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH22_SUSP bit to 1 and polls CH22_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH22_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH22_SUSP bit to 0, after DW_axi_dmac sets CH22_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH22_SUSP): Request to Suspended Channel-22</li> <li>■ 0x0 (DISABLE_CH22_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 21</p> <p><b>Volatile:</b> true</p> |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|-----------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 36   | CH21_SUSP | R/W           | <p>Channel-21 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH21_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH21_SUSP bit to 1 and polls CH21_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH21_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH21_SUSP bit to 0, after DW_axi_dmac sets CH21_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH21_SUSP): Request to Suspended Channel-21</li> <li>■ 0x0 (DISABLE_CH21_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 20</p> <p><b>Volatile:</b> true</p> |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|-----------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 35   | CH20_SUSP | R/W           | <p>Channel-20 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH20_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH20_SUSP bit to 1 and polls CH20_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH20_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH20_SUSP bit to 0, after DW_axi_dmac sets CH20_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH20_SUSP): Request to Suspended Channel-20</li> <li>■ 0x0 (DISABLE_CH20_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 19</p> <p><b>Volatile:</b> true</p> |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|-----------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 34   | CH19_SUSP | R/W           | <p>Channel-19 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH19_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH19_SUSP bit to 1 and polls CH19_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH19_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH19_SUSP bit to 0, after DW_axi_dmac sets CH19_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH19_SUSP): Request to Suspended Channel-19</li> <li>■ 0x0 (DISABLE_CH19_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 18</p> <p><b>Volatile:</b> true</p> |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|-----------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 33   | CH18_SUSP | R/W           | <p>Channel-18 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH18_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH18_SUSP bit to 1 and polls CH18_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH18_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH18_SUSP bit to 0, after DW_axi_dmac sets CH18_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH18_SUSP): Request to Suspended Channel-18</li> <li>■ 0x0 (DISABLE_CH18_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 17</p> <p><b>Volatile:</b> true</p> |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| Bits | Name         | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|--------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 32   | CH17_SUSP    | R/W           | <p>Channel-17 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH17_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH17_SUSP bit to 1 and polls CH17_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH17_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH17_SUSP bit to 0, after DW_axi_dmac sets CH17_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH17_SUSP): Request to Suspended Channel-17</li> <li>■ 0x0 (DISABLE_CH17_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 16</p> <p><b>Volatile:</b> true</p> |
| 31   | CH16_SUSP_WE | W             | <p>This bit is used as a write enable to the Channel-16 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH16_SUSP): Enable Write to respective CH16_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH16_SUSP): Disable Write to CH\${ch_num}_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 15</p> <p><b>Volatile:</b> true</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| Bits | Name         | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|--------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30   | CH15_SUSP_WE | W             | <p>This bit is used as a write enable to the Channel-15 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH15_SUSP): Enable Write to respective CH15_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH15_SUSP): Disable Write to CH\${ch_num}_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 14</p> <p><b>Volatile:</b> true</p> |
| 29   | CH14_SUSP_WE | W             | <p>This bit is used as a write enable to the Channel-14 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH14_SUSP): Enable Write to respective CH14_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH14_SUSP): Disable Write to CH\${ch_num}_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 13</p> <p><b>Volatile:</b> true</p> |
| 28   | CH13_SUSP_WE | W             | <p>This bit is used as a write enable to the Channel-13 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH13_SUSP): Enable Write to respective CH13_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH13_SUSP): Disable Write to CH\${ch_num}_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 12</p> <p><b>Volatile:</b> true</p> |
| 27   | CH12_SUSP_WE | W             | <p>This bit is used as a write enable to the Channel-12 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH12_SUSP): Enable Write to respective CH12_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH12_SUSP): Disable Write to CH\${ch_num}_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 11</p> <p><b>Volatile:</b> true</p> |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| Bits | Name         | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|--------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 26   | CH11_SUSP_WE | W             | <p>This bit is used as a write enable to the Channel-11 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH11_SUSP): Enable Write to respective CH11_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH11_SUSP): Disable Write to CH\${ch_num}_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 10</p> <p><b>Volatile:</b> true</p> |
| 25   | CH10_SUSP_WE | W             | <p>This bit is used as a write enable to the Channel-10 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH10_SUSP): Enable Write to respective CH10_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH10_SUSP): Disable Write to CH\${ch_num}_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 9</p> <p><b>Volatile:</b> true</p>  |
| 24   | CH9_SUSP_WE  | W             | <p>This bit is used as a write enable to the Channel-9 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH9_SUSP): Enable Write to respective CH9_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH9_SUSP): Disable Write to CH\${ch_num}_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 8</p> <p><b>Volatile:</b> true</p>      |
| 23   | CH8_SUSP_WE  | W             | <p>This bit is used as a write enable to the Channel-8 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH8_SUSP): Enable Write to respective CH8_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH8_SUSP): Disable Write to CH\${ch_num}_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 7</p> <p><b>Volatile:</b> true</p>      |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| Bits | Name        | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------|-------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 22   | CH7_SUSP_WE | W             | <p>This bit is used as a write enable to the Channel-7 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH7_SUSP): Enable Write to respective CH7_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH7_SUSP): Disable Write to CH\${ch_num}_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 6</p> <p><b>Volatile:</b> true</p> |
| 21   | CH6_SUSP_WE | W             | <p>This bit is used as a write enable to the Channel-6 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH6_SUSP): Enable Write to respective CH6_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH6_SUSP): Disable Write to CH\${ch_num}_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 5</p> <p><b>Volatile:</b> true</p> |
| 20   | CH5_SUSP_WE | W             | <p>This bit is used as a write enable to the Channel-5 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH5_SUSP): Enable Write to respective CH5_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH5_SUSP): Disable Write to CH\${ch_num}_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 4</p> <p><b>Volatile:</b> true</p> |
| 19   | CH4_SUSP_WE | W             | <p>This bit is used as a write enable to the Channel-4 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH4_SUSP): Enable Write to respective CH4_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH4_SUSP): Disable Write to CH\${ch_num}_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 3</p> <p><b>Volatile:</b> true</p> |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| Bits | Name        | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------|-------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18   | CH3_SUSP_WE | W             | <p>This bit is used as a write enable to the Channel-3 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH3_SUSP): Enable Write to respective CH3_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH3_SUSP): Disable Write to CH\${ch_num}_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 2</p> <p><b>Volatile:</b> true</p> |
| 17   | CH2_SUSP_WE | W             | <p>This bit is used as a write enable to the Channel-2 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH2_SUSP): Enable Write to respective CH2_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH2_SUSP): Disable Write to CH\${ch_num}_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 1</p> <p><b>Volatile:</b> true</p> |
| 16   | CH1_SUSP_WE | W             | <p>This bit is used as a write enable to the Channel-1 Suspend bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH1_SUSP): Enable Write to respective CH1_SUSP bit</li> <li>■ 0x0 (DISABLE_WR_CH1_SUSP): Disable Write to CH\${ch_num}_SUSP bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 0</p> <p><b>Volatile:</b> true</p> |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|-----------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15   | CH16_SUSP | R/W           | <p>Channel-16 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH16_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH16_SUSP bit to 1 and polls CH16_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH16_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH16_SUSP bit to 0, after DW_axi_dmac sets CH16_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH16_SUSP): Request to Suspended Channel-16</li> <li>■ 0x0 (DISABLE_CH16_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 15</p> <p><b>Volatile:</b> true</p> |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|-----------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14   | CH15_SUSP | R/W           | <p>Channel-15 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH15_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH15_SUSP bit to 1 and polls CH15_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH15_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH15_SUSP bit to 0, after DW_axi_dmac sets CH15_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH15_SUSP): Request to Suspended Channel-15</li> <li>■ 0x0 (DISABLE_CH15_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 14</p> <p><b>Volatile:</b> true</p> |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|-----------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13   | CH14_SUSP | R/W           | <p>Channel-14 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH14_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH14_SUSP bit to 1 and polls CH14_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH14_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH14_SUSP bit to 0, after DW_axi_dmac sets CH14_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH14_SUSP): Request to Suspended Channel-14</li> <li>■ 0x0 (DISABLE_CH14_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 13</p> <p><b>Volatile:</b> true</p> |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|-----------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12   | CH13_SUSP | R/W           | <p>Channel-13 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH13_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH13_SUSP bit to 1 and polls CH13_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH13_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH13_SUSP bit to 0, after DW_axi_dmac sets CH13_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH13_SUSP): Request to Suspended Channel-13</li> <li>■ 0x0 (DISABLE_CH13_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 12</p> <p><b>Volatile:</b> true</p> |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|-----------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11   | CH12_SUSP | R/W           | <p>Channel-12 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH12_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH12_SUSP bit to 1 and polls CH12_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH12_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH12_SUSP bit to 0, after DW_axi_dmac sets CH12_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH12_SUSP): Request to Suspended Channel-12</li> <li>■ 0x0 (DISABLE_CH12_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 11</p> <p><b>Volatile:</b> true</p> |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|-----------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10   | CH11_SUSP | R/W           | <p>Channel-11 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH11_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH11_SUSP bit to 1 and polls CH11_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH11_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH11_SUSP bit to 0, after DW_axi_dmac sets CH11_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH11_SUSP): Request to Suspended Channel-11</li> <li>■ 0x0 (DISABLE_CH11_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 10</p> <p><b>Volatile:</b> true</p> |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|-----------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9    | CH10_SUSP | R/W           | <p>Channel-10 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH10_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH10_SUSP bit to 1 and polls CH10_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH10_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH10_SUSP bit to 0, after DW_axi_dmac sets CH10_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH10_SUSP): Request to Suspended Channel-10</li> <li>■ 0x0 (DISABLE_CH10_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 9</p> <p><b>Volatile:</b> true</p> |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| Bits | Name     | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|----------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8    | CH9_SUSP | R/W           | <p>Channel-9 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH9_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH9_SUSP bit to 1 and polls CH9_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH9_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH9_SUSP bit to 0, after DW_axi_dmac sets CH9_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH9_SUSP): Request to Suspended Channel-9</li> <li>■ 0x0 (DISABLE_CH9_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 8</p> <p><b>Volatile:</b> true</p> |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| Bits | Name     | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|----------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7    | CH8_SUSP | R/W           | <p>Channel-8 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH8_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH8_SUSP bit to 1 and polls CH8_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH8_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH8_SUSP bit to 0, after DW_axi_dmac sets CH8_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH8_SUSP): Request to Suspended Channel-8</li> <li>■ 0x0 (DISABLE_CH8_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 7</p> <p><b>Volatile:</b> true</p> |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| <b>Bits</b> | <b>Name</b> | <b>Memory Access</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------------|-------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6           | CH7_SUSP    | R/W                  | <p>Channel-7 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH7_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH7_SUSP bit to 1 and polls CH7_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH7_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH7_SUSP bit to 0, after DW_axi_dmac sets CH7_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH7_SUSP): Request to Suspended Channel-7</li> <li>■ 0x0 (DISABLE_CH7_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 6</p> <p><b>Volatile:</b> true</p> |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| Bits | Name     | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|----------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5    | CH6_SUSP | R/W           | <p>Channel-6 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH6_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH6_SUSP bit to 1 and polls CH6_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH6_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH6_SUSP bit to 0, after DW_axi_dmac sets CH6_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH6_SUSP): Request to Suspended Channel-6</li> <li>■ 0x0 (DISABLE_CH6_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 5</p> <p><b>Volatile:</b> true</p> |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| Bits | Name     | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|----------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4    | CH5_SUSP | R/W           | <p>Channel-5 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH5_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH5_SUSP bit to 1 and polls CH5_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH5_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH5_SUSP bit to 0, after DW_axi_dmac sets CH5_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH5_SUSP): Request to Suspended Channel-5</li> <li>■ 0x0 (DISABLE_CH5_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 4</p> <p><b>Volatile:</b> true</p> |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| Bits | Name     | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|----------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3    | CH4_SUSP | R/W           | <p>Channel-4 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH4_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH4_SUSP bit to 1 and polls CH4_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH4_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH4_SUSP bit to 0, after DW_axi_dmac sets CH4_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH4_SUSP): Request to Suspended Channel-4</li> <li>■ 0x0 (DISABLE_CH4_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 3</p> <p><b>Volatile:</b> true</p> |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| Bits | Name     | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|----------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2    | CH3_SUSP | R/W           | <p>Channel-3 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH3_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH3_SUSP bit to 1 and polls CH3_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH3_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH3_SUSP bit to 0, after DW_axi_dmac sets CH3_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH3_SUSP): Request to Suspended Channel-3</li> <li>■ 0x0 (DISABLE_CH3_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 2</p> <p><b>Volatile:</b> true</p> |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| Bits | Name     | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|----------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1    | CH2_SUSP | R/W           | <p>Channel-2 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH2_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH2_SUSP bit to 1 and polls CH2_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH2_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH2_SUSP bit to 0, after DW_axi_dmac sets CH2_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH2_SUSP): Request to Suspended Channel-2</li> <li>■ 0x0 (DISABLE_CH2_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 1</p> <p><b>Volatile:</b> true</p> |

**Table 5-11 Fields for Register: DMAC\_CHSUSPREG (Continued)**

| <b>Bits</b> | <b>Name</b> | <b>Memory Access</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------------|-------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0           | CH1_SUSP    | R/W                  | <p>Channel-1 Suspend Request.</p> <p>Software sets this bit to 1 to request channel suspend. If this bit is set to 1, DW_axi_dmac suspends all DMA data transfers from the source gracefully until this bit is cleared. There is no guarantee that the current dma transaction will complete. This bit can also be used in conjunction with CH1_Status.CH_SUSPENDED to cleanly disable the channel without losing any data. In this case, software first sets CH1_SUSP bit to 1 and polls CH1_Status.CH_SUSPENDED till it is set to 1. Software can then clear CH1_EN bit to 0 to disable the channel.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Suspend Request.</li> <li>■ 1: Request for Channel Suspend.</li> </ul> <p>Software can clear CH1_SUSP bit to 0, after DW_axi_dmac sets CH1_Status.CH_SUSPENDED bit to 1, to exit the channel suspend mode.</p> <p><b>Note:</b> CH_SUSP is cleared when channel is disabled.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH1_SUSP): Request to Suspended Channel-1</li> <li>■ 0x0 (DISABLE_CH1_SUSP): No Channel Suspend Request</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 0</p> <p><b>Volatile:</b> true</p> |

### 5.1.7 DMAC\_CHABORTREG

- **Description:** This is DW\_axi\_dmac Channel Abort Register. The channel abort bit, DMAC\_ChAbortReg.CH\_ABORT, is written only if the corresponding channel write enable bit, DMAC\_ChAbortReg.CH\_ABORT\_WE, is asserted on the same slave interface write transfer.
- **Size:** 64 bits
- **Offset:** 0x28
- **Exists:** DMAX\_NUM\_CHANNELS > 8

|                |    |
|----------------|----|
| CH32_ABORT_VWE | 63 |
| CH31_ABORT_VWE | 62 |
| CH30_ABORT_VWE | 61 |
| CH29_ABORT_VWE | 60 |
| CH28_ABORT_VWE | 59 |
| CH27_ABORT_VWE | 58 |
| CH26_ABORT_VWE | 57 |
| CH25_ABORT_VWE | 56 |
| CH24_ABORT_VWE | 55 |
| CH23_ABORT_VWE | 54 |
| CH22_ABORT_VWE | 53 |
| CH21_ABORT_VWE | 52 |
| CH20_ABORT_VWE | 51 |
| CH19_ABORT_VWE | 50 |
| CH18_ABORT_VWE | 49 |
| CH17_ABORT_VWE | 48 |
| CH32_ABORT     | 47 |
| CH31_ABORT     | 46 |
| CH30_ABORT     | 45 |
| CH29_ABORT     | 44 |
| CH28_ABORT     | 43 |
| CH27_ABORT     | 42 |
| CH26_ABORT     | 41 |
| CH25_ABORT     | 40 |
| CH24_ABORT     | 39 |
| CH23_ABORT     | 38 |
| CH22_ABORT     | 37 |
| CH21_ABORT     | 36 |
| CH20_ABORT     | 35 |
| CH19_ABORT     | 34 |
| CH18_ABORT     | 33 |
| CH17_ABORT     | 32 |
| CH16_ABORT_VWE | 31 |
| CH15_ABORT_VWE | 30 |
| CH14_ABORT_VWE | 29 |
| CH13_ABORT_VWE | 28 |
| CH12_ABORT_VWE | 27 |
| CH11_ABORT_VWE | 26 |
| CH10_ABORT_VWE | 25 |
| CH9_ABORT_VWE  | 24 |
| CH8_ABORT_VWE  | 23 |
| CH7_ABORT_VWE  | 22 |
| CH6_ABORT_VWE  | 21 |
| CH5_ABORT_VWE  | 20 |
| CH4_ABORT_VWE  | 19 |
| CH15_ABORT     | 15 |
| CH14_ABORT     | 14 |
| CH13_ABORT     | 13 |
| CH12_ABORT     | 12 |
| CH11_ABORT     | 11 |
| CH10_ABORT     | 10 |
| CH9_ABORT      | 9  |
| CH8_ABORT      | 8  |
| CH7_ABORT      | 7  |
| CH6_ABORT      | 6  |
| CH5_ABORT      | 5  |
| CH4_ABORT      | 4  |
| CH3_ABORT      | 3  |
| CH2_ABORT      | 2  |
| CH1_ABORT      | 1  |

Table 5-12 Fields for Register: DMAC\_CHABORTREG

| Bits | Name          | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|---------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63   | CH32_ABORT_WE | * Varies      | <p>This bit is used to write enable the Channel-32 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH32_ABORT): Enable Write to CH32_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH32_ABORT): Disable Write to CH32_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 31</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name          | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|---------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 62   | CH31_ABORT_WE | * Varies      | <p>This bit is used to write enable the Channel-31 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH31_ABORT): Enable Write to CH31_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH31_ABORT): Disable Write to CH31_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 30</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p> |
| 61   | CH30_ABORT_WE | * Varies      | <p>This bit is used to write enable the Channel-30 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH30_ABORT): Enable Write to CH30_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH30_ABORT): Disable Write to CH30_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 29</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p> |
| 60   | CH29_ABORT_WE | * Varies      | <p>This bit is used to write enable the Channel-29 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH29_ABORT): Enable Write to CH29_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH29_ABORT): Disable Write to CH29_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 28</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name          | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|---------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 59   | CH28_ABORT_WE | * Varies      | <p>This bit is used to write enable the Channel-28 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH28_ABORT): Enable Write to CH28_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH28_ABORT): Disable Write to CH28_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 27</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p> |
| 58   | CH27_ABORT_WE | * Varies      | <p>This bit is used to write enable the Channel-27 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH27_ABORT): Enable Write to CH27_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH27_ABORT): Disable Write to CH27_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 26</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p> |
| 57   | CH26_ABORT_WE | * Varies      | <p>This bit is used to write enable the Channel-26 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH26_ABORT): Enable Write to CH26_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH26_ABORT): Disable Write to CH26_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 25</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name          | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|---------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 56   | CH25_ABORT_WE | * Varies      | <p>This bit is used to write enable the Channel-25 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH25_ABORT): Enable Write to CH25_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH25_ABORT): Disable Write to CH25_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 24</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p> |
| 55   | CH24_ABORT_WE | * Varies      | <p>This bit is used to write enable the Channel-24 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH24_ABORT): Enable Write to CH24_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH24_ABORT): Disable Write to CH24_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 23</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p> |
| 54   | CH23_ABORT_WE | * Varies      | <p>This bit is used to write enable the Channel-23 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH23_ABORT): Enable Write to CH23_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH23_ABORT): Disable Write to CH23_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 22</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name          | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|---------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 53   | CH22_ABORT_WE | * Varies      | <p>This bit is used to write enable the Channel-22 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH22_ABORT): Enable Write to CH22_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH22_ABORT): Disable Write to CH22_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 21</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p> |
| 52   | CH21_ABORT_WE | * Varies      | <p>This bit is used to write enable the Channel-21 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH21_ABORT): Enable Write to CH21_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH21_ABORT): Disable Write to CH21_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 20</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p> |
| 51   | CH20_ABORT_WE | * Varies      | <p>This bit is used to write enable the Channel-20 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH20_ABORT): Enable Write to CH20_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH20_ABORT): Disable Write to CH20_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 19</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name          | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|---------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 50   | CH19_ABORT_WE | * Varies      | <p>This bit is used to write enable the Channel-19 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH19_ABORT): Enable Write to CH19_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH19_ABORT): Disable Write to CH19_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 18</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p> |
| 49   | CH18_ABORT_WE | * Varies      | <p>This bit is used to write enable the Channel-18 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH18_ABORT): Enable Write to CH18_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH18_ABORT): Disable Write to CH18_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 17</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p> |
| 48   | CH17_ABORT_WE | * Varies      | <p>This bit is used to write enable the Channel-17 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH17_ABORT): Enable Write to CH17_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH17_ABORT): Disable Write to CH17_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 16</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 47   | CH32_ABORT | * Varies      | <p>Channel-32 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH32_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH32_ABORT): Request for Channel-32 Abort</li> <li>■ 0x0 (DISABLE_CH32_ABORT): No Request for Channel-32 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 31</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 46   | CH31_ABORT | * Varies      | <p>Channel-31 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH31_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH31_ABORT): Request for Channel-31 Abort</li> <li>■ 0x0 (DISABLE_CH31_ABORT): No Request for Channel-31 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 30</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 45   | CH30_ABORT | * Varies      | <p>Channel-30 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH30_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH30_ABORT): Request for Channel-30 Abort</li> <li>■ 0x0 (DISABLE_CH30_ABORT): No Request for Channel-30 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 29</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 44   | CH29_ABORT | * Varies      | <p>Channel-29 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH29_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH29_ABORT): Request for Channel-29 Abort</li> <li>■ 0x0 (DISABLE_CH29_ABORT): No Request for Channel-29 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 28</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 43   | CH28_ABORT | * Varies      | <p>Channel-28 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH28_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH28_ABORT): Request for Channel-28 Abort</li> <li>■ 0x0 (DISABLE_CH28_ABORT): No Request for Channel-28 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 27</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 42   | CH27_ABORT | * Varies      | <p>Channel-27 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH27_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH27_ABORT): Request for Channel-27 Abort</li> <li>■ 0x0 (DISABLE_CH27_ABORT): No Request for Channel-27 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 26</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 41   | CH26_ABORT | * Varies      | <p>Channel-26 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH26_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH26_ABORT): Request for Channel-26 Abort</li> <li>■ 0x0 (DISABLE_CH26_ABORT): No Request for Channel-26 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 25</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 40   | CH25_ABORT | * Varies      | <p>Channel-25 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH25_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH25_ABORT): Request for Channel-25 Abort</li> <li>■ 0x0 (DISABLE_CH25_ABORT): No Request for Channel-25 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 24</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 39   | CH24_ABORT | * Varies      | <p>Channel-24 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH24_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH24_ABORT): Request for Channel-24 Abort</li> <li>■ 0x0 (DISABLE_CH24_ABORT): No Request for Channel-24 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 23</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 38   | CH23_ABORT | * Varies      | <p>Channel-23 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH23_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH23_ABORT): Request for Channel-23 Abort</li> <li>■ 0x0 (DISABLE_CH23_ABORT): No Request for Channel-23 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 22</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 37   | CH22_ABORT | * Varies      | <p>Channel-22 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH22_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH22_ABORT): Request for Channel-22 Abort</li> <li>■ 0x0 (DISABLE_CH22_ABORT): No Request for Channel-22 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 21</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 36   | CH21_ABORT | * Varies      | <p>Channel-21 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH21_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH21_ABORT): Request for Channel-21 Abort</li> <li>■ 0x0 (DISABLE_CH21_ABORT): No Request for Channel-21 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 20</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 35   | CH20_ABORT | * Varies      | <p>Channel-20 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH20_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH20_ABORT): Request for Channel-20 Abort</li> <li>■ 0x0 (DISABLE_CH20_ABORT): No Request for Channel-20 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 19</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 34   | CH19_ABORT | * Varies      | <p>Channel-19 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH19_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH19_ABORT): Request for Channel-19 Abort</li> <li>■ 0x0 (DISABLE_CH19_ABORT): No Request for Channel-19 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 18</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 33   | CH18_ABORT | * Varies      | <p>Channel-18 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH18_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH18_ABORT): Request for Channel-18 Abort</li> <li>■ 0x0 (DISABLE_CH18_ABORT): No Request for Channel-18 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 17</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name          | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|---------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 32   | CH17_ABORT    | * Varies      | <p>Channel-17 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH17_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH17_ABORT): Request for Channel-17 Abort</li> <li>■ 0x0 (DISABLE_CH17_ABORT): No Request for Channel-17 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 16</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |
| 31   | CH16_ABORT_WE | * Varies      | <p>This bit is used to write enable the Channel-16 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH16_ABORT): Enable Write to CH16_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH16_ABORT): Disable Write to CH16_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 15</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name          | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|---------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30   | CH15_ABORT_WE | * Varies      | <p>This bit is used to write enable the Channel-15 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH15_ABORT): Enable Write to CH15_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH15_ABORT): Disable Write to CH15_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 14</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p> |
| 29   | CH14_ABORT_WE | * Varies      | <p>This bit is used to write enable the Channel-14 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH14_ABORT): Enable Write to CH14_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH14_ABORT): Disable Write to CH14_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 13</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p> |
| 28   | CH13_ABORT_WE | * Varies      | <p>This bit is used to write enable the Channel-13 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH13_ABORT): Enable Write to CH13_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH13_ABORT): Disable Write to CH13_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 12</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name          | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|---------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27   | CH12_ABORT_WE | * Varies      | <p>This bit is used to write enable the Channel-12 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH12_ABORT): Enable Write to CH12_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH12_ABORT): Disable Write to CH12_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 11</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p> |
| 26   | CH11_ABORT_WE | * Varies      | <p>This bit is used to write enable the Channel-11 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH11_ABORT): Enable Write to CH11_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH11_ABORT): Disable Write to CH11_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 10</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p> |
| 25   | CH10_ABORT_WE | * Varies      | <p>This bit is used to write enable the Channel-10 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH10_ABORT): Enable Write to CH10_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH10_ABORT): Disable Write to CH10_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 9</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p>  |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name         | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------|--------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24   | CH9_ABORT_WE | * Varies      | <p>This bit is used to write enable the Channel-9 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH9_ABORT): Enable Write to CH9_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH9_ABORT): Disable Write to CH9_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 8</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p> |
| 23   | CH8_ABORT_WE | * Varies      | <p>This bit is used to write enable the Channel-8 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH8_ABORT): Enable Write to CH8_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH8_ABORT): Disable Write to CH8_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 7</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p> |
| 22   | CH7_ABORT_WE | * Varies      | <p>This bit is used to write enable the Channel-7 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH7_ABORT): Enable Write to CH7_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH7_ABORT): Disable Write to CH7_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 6</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name         | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------|--------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 21   | CH6_ABORT_WE | * Varies      | <p>This bit is used to write enable the Channel-6 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH6_ABORT): Enable Write to CH6_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH6_ABORT): Disable Write to CH6_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 5</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p> |
| 20   | CH5_ABORT_WE | * Varies      | <p>This bit is used to write enable the Channel-5 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH5_ABORT): Enable Write to CH5_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH5_ABORT): Disable Write to CH5_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 4</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p> |
| 19   | CH4_ABORT_WE | * Varies      | <p>This bit is used to write enable the Channel-4 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH4_ABORT): Enable Write to CH4_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH4_ABORT): Disable Write to CH4_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 3</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name         | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------|--------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18   | CH3_ABORT_WE | * Varies      | <p>This bit is used to write enable the Channel-3 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH3_ABORT): Enable Write to CH3_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH3_ABORT): Disable Write to CH3_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 2</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p> |
| 17   | CH2_ABORT_WE | * Varies      | <p>This bit is used to write enable the Channel-2 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH2_ABORT): Enable Write to CH2_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH2_ABORT): Disable Write to CH2_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 1</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p> |
| 16   | CH1_ABORT_WE | * Varies      | <p>This bit is used to write enable the Channel-1 Abort bit. The read back value of this register bit is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_WR_CH1_ABORT): Enable Write to CH1_ABORT bit</li> <li>■ 0x0 (DISABLE_WR_CH1_ABORT): Disable Write to CH1_ABORT bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 0</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "write-only" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15   | CH16_ABORT | * Varies      | <p>Channel-16 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH16_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH16_ABORT): Request for Channel-16 Abort</li> <li>■ 0x0 (DISABLE_CH16_ABORT): No Request for Channel-16 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 15</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14   | CH15_ABORT | * Varies      | <p>Channel-15 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH15_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH15_ABORT): Request for Channel-15 Abort</li> <li>■ 0x0 (DISABLE_CH15_ABORT): No Request for Channel-15 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 14</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13   | CH14_ABORT | * Varies      | <p>Channel-14 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH14_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH14_ABORT): Request for Channel-14 Abort</li> <li>■ 0x0 (DISABLE_CH14_ABORT): No Request for Channel-14 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 13</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12   | CH13_ABORT | * Varies      | <p>Channel-13 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH13_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH13_ABORT): Request for Channel-13 Abort</li> <li>■ 0x0 (DISABLE_CH13_ABORT): No Request for Channel-13 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 12</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11   | CH12_ABORT | * Varies      | <p>Channel-12 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH12_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH12_ABORT): Request for Channel-12 Abort</li> <li>■ 0x0 (DISABLE_CH12_ABORT): No Request for Channel-12 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 11</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10   | CH11_ABORT | * Varies      | <p>Channel-11 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH11_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH11_ABORT): Request for Channel-11 Abort</li> <li>■ 0x0 (DISABLE_CH11_ABORT): No Request for Channel-11 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 10</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9    | CH10_ABORT | * Varies      | <p>Channel-10 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH10_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH10_ABORT): Request for Channel-10 Abort</li> <li>■ 0x0 (DISABLE_CH10_ABORT): No Request for Channel-10 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 9</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|-----------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8    | CH9_ABORT | * Varies      | <p>Channel-9 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH9_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH9_ABORT): Request for Channel-9 Abort</li> <li>■ 0x0 (DISABLE_CH9_ABORT): No Request for Channel-9 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 8</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|-----------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7    | CH8_ABORT | * Varies      | <p>Channel-8 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH8_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH8_ABORT): Request for Channel-8 Abort</li> <li>■ 0x0 (DISABLE_CH8_ABORT): No Request for Channel-8 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 7</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|-----------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6    | CH7_ABORT | * Varies      | <p>Channel-7 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH7_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH7_ABORT): Request for Channel-7 Abort</li> <li>■ 0x0 (DISABLE_CH7_ABORT): No Request for Channel-7 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 6</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|-----------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5    | CH6_ABORT | * Varies      | <p>Channel-6 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH6_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH6_ABORT): Request for Channel-6 Abort</li> <li>■ 0x0 (DISABLE_CH6_ABORT): No Request for Channel-6 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 5</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|-----------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4    | CH5_ABORT | * Varies      | <p>Channel-5 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH5_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH5_ABORT): Request for Channel-5 Abort</li> <li>■ 0x0 (DISABLE_CH5_ABORT): No Request for Channel-5 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 4</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|-----------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3    | CH4_ABORT | * Varies      | <p>Channel-4 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH4_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH4_ABORT): Request for Channel-4 Abort</li> <li>■ 0x0 (DISABLE_CH4_ABORT): No Request for Channel-4 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 3</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|-----------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2    | CH3_ABORT | * Varies      | <p>Channel-3 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH3_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH3_ABORT): Request for Channel-3 Abort</li> <li>■ 0x0 (DISABLE_CH3_ABORT): No Request for Channel-3 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 2</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|-----------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1    | CH2_ABORT | * Varies      | <p>Channel-2 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH2_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH2_ABORT): Request for Channel-2 Abort</li> <li>■ 0x0 (DISABLE_CH2_ABORT): No Request for Channel-2 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 1</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |

**Table 5-12 Fields for Register: DMAC\_CHABORTREG (Continued)**

| Bits | Name      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|-----------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | CH1_ABORT | * Varies      | <p>Channel-1 Abort Request.</p> <p>Software sets this bit to 1 to request channel abort. If this bit is set to 1, DW_axi_dmac disables the channel immediately. Aborting the channel might result in AXI Protocol violation as DW_axi_dmac does not make sure that all AXI transfers initiated on the master interface are completed. Aborting the channel is not recommended and should be used only in situations where a particular channel hangs due to no response from the corresponding AXI slave interface and software wants to disable the channel without resetting the entire DW_axi_dmac. It is recommended to try channel disabling first and then only opt for channel aborting.</p> <ul style="list-style-type: none"> <li>■ 0: No Channel Abort Request.</li> <li>■ 1: Request for Channel Abort.</li> </ul> <p>DW_axi_dmac clears this bit to 0 once the channel is aborted (when it sets CH1_Status.CH_ABORTED bit to 1).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH1_ABORT): Request for Channel-1 Abort</li> <li>■ 0x0 (DISABLE_CH1_ABORT): No Request for Channel-1 Abort</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt; 0</p> <p><b>Volatile:</b> true</p> <p><b>Memory Access:</b> {(DMAX_CH_ABORT_EN == 1) ? "read-write" : "read-only"}</p> |

## 5.1.8 DMAC INTSTATUSREG

- **Description:** DMAC Interrupt Status Register captures the combined channel interrupt for each channel and Combined common register block interrupt. This register is present provided number of DMA channels are greater than 8.
  - **Size:** 64 bits
  - **Offset:** 0x30
  - **Exists:** DMAX NUM CHANNELS <= 8

|                               |       |
|-------------------------------|-------|
| RSVD_DMAC_INTSTATUSREG_63to17 | 63:17 |
| CommonReg_IntStat             | 16    |
| RSVD_DMAC_INTSTATUSREG        | 15:8  |
| CH8_IntStat                   | 7     |
| CH7_IntStat                   | 6     |
| CH6_IntStat                   | 5     |
| CH5_IntStat                   | 4     |
| CH4_IntStat                   | 3     |
| CH3_IntStat                   | 2     |
| CH2_IntStat                   | 1     |
| CH1_IntStat                   | 0     |

**Table 5-13 Fields for Register: DMAC\_INTSTATUSREG**

| <b>Bits</b> | <b>Name</b>   | <b>Memory Access</b> | <b>Description</b>                                                                                                                                                           |
|-------------|---------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:17       | RSVD_DM63to17 | R                    | <p>DMAC Interrupt Status Register (bits 63to17) Reserved bits - Read Only</p> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p> |

**Table 5-13 Fields for Register: DMAC\_INTSTATUSREG (Continued)**

| Bits | Name                   | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                 |
|------|------------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16   | CommonReg_IntStat      | R             | <p>Common Register Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Common Register Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Common Register Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p>                    |
| 15:8 | RSVD_DMAC_INTSTATUSREG | R             | <p>DMAC Interrupt Status Register (bits 15to8) Reserved bits - Read Only</p> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p>                                                                                                                                                                                 |
| 7    | CH8_IntStat            | R             | <p>Channel 8 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 7</p> <p><b>Volatile:</b> true</p> |
| 6    | CH7_IntStat            | R             | <p>Channel 7 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 6</p> <p><b>Volatile:</b> true</p> |
| 5    | CH6_IntStat            | R             | <p>Channel 6 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 5</p> <p><b>Volatile:</b> true</p> |

**Table 5-13 Fields for Register: DMAC\_INTSTATUSREG (Continued)**

| Bits | Name        | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                 |
|------|-------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4    | CH5_IntStat | R             | <p>Channel 5 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 4</p> <p><b>Volatile:</b> true</p> |
| 3    | CH4_IntStat | R             | <p>Channel 4 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 3</p> <p><b>Volatile:</b> true</p> |
| 2    | CH3_IntStat | R             | <p>Channel 3 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 2</p> <p><b>Volatile:</b> true</p> |
| 1    | CH2_IntStat | R             | <p>Channel 2 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 1</p> <p><b>Volatile:</b> true</p> |
| 0    | CH1_IntStat | R             | <p>Channel 1 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 0</p> <p><b>Volatile:</b> true</p> |

### 5.1.9 DMAC\_INTSTATUSREG2

- **Description:** DMAC Interrupt Status Register captures the combined channel interrupt for each channel and Combined common register block interrupt. This register is present provided number of DMA channels are less than or equal to 8.
- **Size:** 64 bits
- **Offset:** 0x30
- **Exists:** DMAX\_NUM\_CHANNELS > 8

|                               |       |
|-------------------------------|-------|
| RSVD_DMAC_INTSTATUSREG_63to33 | 63:33 |
| CommonReg_IntStat             | 32    |
| CH32_IntStat                  | 31    |
| CH31_IntStat                  | 30    |
| CH30_IntStat                  | 29    |
| CH29_IntStat                  | 28    |
| CH28_IntStat                  | 27    |
| CH27_IntStat                  | 26    |
| CH26_IntStat                  | 25    |
| CH25_IntStat                  | 24    |
| CH24_IntStat                  | 23    |
| CH23_IntStat                  | 22    |
| CH22_IntStat                  | 21    |
| CH21_IntStat                  | 20    |
| CH20_IntStat                  | 19    |
| CH19_IntStat                  | 18    |
| CH18_IntStat                  | 17    |
| CH17_IntStat                  | 16    |
| CH16_IntStat                  | 15    |
| CH15_IntStat                  | 14    |
| CH14_IntStat                  | 13    |
| CH13_IntStat                  | 12    |
| CH12_IntStat                  | 11    |
| CH11_IntStat                  | 10    |
| CH10_IntStat                  | 9     |
| CH9_IntStat                   | 8     |
| CH8_IntStat                   | 7     |
| CH7_IntStat                   | 6     |
| CH6_IntStat                   | 5     |
| CH5_IntStat                   | 4     |
| CH4_IntStat                   | 3     |
| CH3_IntStat                   | 2     |
| CH2_IntStat                   | 1     |
| CH1_IntStat                   | 0     |

Table 5-14 Fields for Register: DMAC\_INTSTATUSREG2

| Bits  | Name                          | Memory Access | Description                                                                                                                                               |
|-------|-------------------------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:33 | RSVD_DMAC_INTSTATUSREG_63to33 | R             | DMAC Interrupt Status Register (bits 63to33) Reserved bits - Read Only<br><b>Value After Reset:</b> 0x0<br><b>Exists:</b> Always<br><b>Volatile:</b> true |

**Table 5-14 Fields for Register: DMAC\_INTSTATUSREG2 (Continued)**

| Bits | Name              | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                   |
|------|-------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 32   | CommonReg_IntStat | R             | <p>Common Register Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Common Register Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Common Register Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p>                      |
| 31   | CH32_IntStat      | R             | <p>Channel 32 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 31</p> <p><b>Volatile:</b> true</p> |
| 30   | CH31_IntStat      | R             | <p>Channel 31 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 30</p> <p><b>Volatile:</b> true</p> |
| 29   | CH30_IntStat      | R             | <p>Channel 30 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 29</p> <p><b>Volatile:</b> true</p> |
| 28   | CH29_IntStat      | R             | <p>Channel 29 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 28</p> <p><b>Volatile:</b> true</p> |

**Table 5-14 Fields for Register: DMAC\_INTSTATUSREG2 (Continued)**

| Bits | Name         | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                   |
|------|--------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27   | CH28_IntStat | R             | <p>Channel 28 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 27</p> <p><b>Volatile:</b> true</p> |
| 26   | CH27_IntStat | R             | <p>Channel 27 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 26</p> <p><b>Volatile:</b> true</p> |
| 25   | CH26_IntStat | R             | <p>Channel 26 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 25</p> <p><b>Volatile:</b> true</p> |
| 24   | CH25_IntStat | R             | <p>Channel 25 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 24</p> <p><b>Volatile:</b> true</p> |
| 23   | CH24_IntStat | R             | <p>Channel 24 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 23</p> <p><b>Volatile:</b> true</p> |

**Table 5-14 Fields for Register: DMAC\_INTSTATUSREG2 (Continued)**

| <b>Bits</b> | <b>Name</b>  | <b>Memory Access</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                            |
|-------------|--------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 22          | CH23_IntStat | R                    | <p>Channel 23 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 22</p> <p><b>Volatile:</b> true</p> |
| 21          | CH22_IntStat | R                    | <p>Channel 22 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 21</p> <p><b>Volatile:</b> true</p> |
| 20          | CH21_IntStat | R                    | <p>Channel 21 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 20</p> <p><b>Volatile:</b> true</p> |
| 19          | CH20_IntStat | R                    | <p>Channel 20 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 19</p> <p><b>Volatile:</b> true</p> |
| 18          | CH19_IntStat | R                    | <p>Channel 19 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 18</p> <p><b>Volatile:</b> true</p> |

**Table 5-14 Fields for Register: DMAC\_INTSTATUSREG2 (Continued)**

| Bits | Name         | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                   |
|------|--------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17   | CH18_IntStat | R             | <p>Channel 18 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 17</p> <p><b>Volatile:</b> true</p> |
| 16   | CH17_IntStat | R             | <p>Channel 17 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 16</p> <p><b>Volatile:</b> true</p> |
| 15   | CH16_IntStat | R             | <p>Channel 16 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 15</p> <p><b>Volatile:</b> true</p> |
| 14   | CH15_IntStat | R             | <p>Channel 15 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 14</p> <p><b>Volatile:</b> true</p> |
| 13   | CH14_IntStat | R             | <p>Channel 14 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 13</p> <p><b>Volatile:</b> true</p> |

**Table 5-14 Fields for Register: DMAC\_INTSTATUSREG2 (Continued)**

| Bits | Name         | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                   |
|------|--------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12   | CH13_IntStat | R             | <p>Channel 13 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 12</p> <p><b>Volatile:</b> true</p> |
| 11   | CH12_IntStat | R             | <p>Channel 12 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 11</p> <p><b>Volatile:</b> true</p> |
| 10   | CH11_IntStat | R             | <p>Channel 11 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 10</p> <p><b>Volatile:</b> true</p> |
| 9    | CH10_IntStat | R             | <p>Channel 10 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 9</p> <p><b>Volatile:</b> true</p>  |
| 8    | CH9_IntStat  | R             | <p>Channel 9 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 8</p> <p><b>Volatile:</b> true</p>   |

**Table 5-14 Fields for Register: DMAC\_INTSTATUSREG2 (Continued)**

| Bits | Name        | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                 |
|------|-------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7    | CH8_IntStat | R             | <p>Channel 8 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 7</p> <p><b>Volatile:</b> true</p> |
| 6    | CH7_IntStat | R             | <p>Channel 7 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 6</p> <p><b>Volatile:</b> true</p> |
| 5    | CH6_IntStat | R             | <p>Channel 6 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 5</p> <p><b>Volatile:</b> true</p> |
| 4    | CH5_IntStat | R             | <p>Channel 5 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 4</p> <p><b>Volatile:</b> true</p> |
| 3    | CH4_IntStat | R             | <p>Channel 4 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 3</p> <p><b>Volatile:</b> true</p> |

**Table 5-14 Fields for Register: DMAC\_INTSTATUSREG2 (Continued)**

| <b>Bits</b> | <b>Name</b> | <b>Memory Access</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                          |
|-------------|-------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2           | CH3_IntStat | R                    | <p>Channel 3 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 2</p> <p><b>Volatile:</b> true</p> |
| 1           | CH2_IntStat | R                    | <p>Channel 2 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 1</p> <p><b>Volatile:</b> true</p> |
| 0           | CH1_IntStat | R                    | <p>Channel 1 Interrupt Status Bit.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE): Channel \${ch_num} Interrupt is Active</li> <li>■ 0x0 (INACTIVE): Channel \${ch_num} Interrupt is Inactive</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> DMAX_NUM_CHANNELS &gt;= 0</p> <p><b>Volatile:</b> true</p> |

### 5.1.10 DMAC\_COMMONREG\_INTCLEARREG

- **Description:** Writing 1 to specific field clears the corresponding field in DMAC Common register Interrupt Status Register (DMAC\_CommonReg\_IntStatusReg).
- **Size:** 64 bits
- **Offset:** 0x38
- **Exists:** Always

|                                            |      |
|--------------------------------------------|------|
| RSVD_DMAC_COMMONREG_INTCLEARREG_63to9      | 63:9 |
| Clear_SLVIF_UndefinedReg_DEC_ERR_IntStat   | 8    |
| RSVD_DMAC_COMMONREG_INTCLEARREG_7to4       | 7:4  |
| Clear_SLVIF_CommonReg_WrOnHold_ERR_IntStat | 3    |
| Clear_SLVIF_CommonReg_RD2WO_ERR_IntStat    | 2    |
| Clear_SLVIF_CommonReg_WR2RO_ERR_IntStat    | 1    |
| Clear_SLVIF_CommonReg_DEC_ERR_IntStat      | 0    |

Table 5-15 Fields for Register: DMAC\_COMMONREG\_INTCLEARREG

| Bits | Name                                  | Memory Access | Description                                                                                                                                    |
|------|---------------------------------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:9 | RSVD_DMAC_COMMONREG_INTCLEARREG_63to9 | W             | DMAC Common Register Interrupt Clear Register (bits 63to9) Reserved bits - Read Only<br><b>Value After Reset:</b> 0x0<br><b>Exists:</b> Always |

**Table 5-15 Fields for Register: DMAC\_COMMONREG\_INTCLEARREG (Continued)**

| <b>Bits</b> | <b>Name</b>                                | <b>Memory Access</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------------|--------------------------------------------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8           | Clear_SLVIF_UndefinedReg_DEC_ERR_IntStat   | W                    | <p>Slave Interface Undefined register Decode Error Interrupt clear Bit.</p> <p>This bit is used to clear the corresponding channel interrupt status bit(SLVIF_UndefinedReg_DEC_ERR_IntStat in DMAC_CommonReg_IntStatusReg).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (CLEAR_SLVIF_UndefinedReg_DEC_ERR): Clear the SLVIF_UndefinedReg_DEC_ERR interrupt in the interrupt register DMAC_CommonReg_IntStatusReg</li> <li>■ 0x0 (No_ACTION): Inactive signal. No action taken.</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p>           |
| 7:4         | RSVD_DMAC_COMMONREG_INTCLEARREG_7to4       | W                    | <p>DMAC Common Register Interrupt Clear Register (bits 7to4)</p> <p>Reserved bits - Read Only</p> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 3           | Clear_SLVIF_CommonReg_WrOnHold_ERR_IntStat | W                    | <p>Slave Interface Common Register Write On Hold Error Interrupt clear Bit.</p> <p>This bit is used to clear the corresponding channel interrupt status bit(SLVIF_CommonReg_WrOnHold_ERR_IntStat in DMAC_CommonReg_IntStatusReg).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (CLEAR_SLVIF_CommonReg_WrOnHold_ERR): Clear the SLVIF_CommonReg_WrOnHold_ERR interrupt in the interrupt register DMAC_CommonReg_IntStatusReg</li> <li>■ 0x0 (No_ACTION): Inactive signal. No action taken.</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> |
| 2           | Clear_SLVIF_CommonReg_RD2WO_ERR_IntStat    | W                    | <p>Slave Interface Common Register Read to Write only Error Interrupt clear Bit.</p> <p>This bit is used to clear the corresponding channel interrupt status bit(SLVIF_CommonReg_RD2WO_ERR_IntStat in DMAC_CommonReg_IntStatusReg).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (CLEAR_SLVIF_CommonReg_RD2WO_ERR): Clear the SLVIF_CommonReg_RD2WO_ERR interrupt in the interrupt register DMAC_CommonReg_IntStatusReg</li> <li>■ 0x0 (No_ACTION): Inactive signal. No action taken.</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p>     |

**Table 5-15 Fields for Register: DMAC\_COMMONREG\_INTCLEARREG (Continued)**

| <b>Bits</b> | <b>Name</b>                                 | <b>Memory Access</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------------|---------------------------------------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1           | Clear_SLVIF_CommonReg_WR2<br>RO_ERR_IntStat | W                    | <p>Slave Interface Common Register Write to Read only Error Interrupt clear Bit.</p> <p>This bit is used to clear the corresponding channel interrupt status bit(SLVIF_CommonReg_WR2RO_ERR_IntStat in DMAC_CommonReg_IntStatusReg).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (CLEAR_SLVIF_CommonReg_WR2RO_ERR): Clear the SLVIF_CommonReg_WR2RO_ERR interrupt in the interrupt register DMAC_CommonReg_IntStatusReg</li> <li>■ 0x0 (No_ACTION): Inactive signal. No action taken.</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> |
| 0           | Clear_SLVIF_CommonReg_DEC<br>_ERR_IntStat   | W                    | <p>Slave Interface Common Register Decode Error Interrupt clear Bit.</p> <p>This bit is used to clear the corresponding channel interrupt status bit (SLVIF_CommonReg_DEC_ERR_IntStat in DMAC_CommonReg_IntStatusReg).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (CLEAR_SLVIF_CommonReg_DEC_ERR): Clear the SLVIF_CommonReg_DEC_ERR interrupt in the interrupt register DMAC_CommonReg_IntStatusReg</li> <li>■ 0x0 (No_ACTION): Inactive signal. No action taken.</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p>                  |

### 5.1.11 DMAC\_COMMONREG\_INTSTATUS\_ENABLEREG

- **Description:** Writing 1 to specific field enables the corresponding interrupt status generation in DMAC Common register Interrupt Status Register (DMAC\_CommonReg\_IntStatusReg).
- **Size:** 64 bits
- **Offset:** 0x40
- **Exists:** Always

|                                               |             |
|-----------------------------------------------|-------------|
| RSVD_DMAC_COMMONREG_INTSTATUS_ENABLEREG_63to9 | <b>63:9</b> |
| Enable_SLVIF_UndefinedReg_DEC_ERR_IntStat     | 8           |
| RSVD_DMAC_COMMONREG_INTSTATUS_ENABLEREG_7to4  | <b>7:4</b>  |
| Enable_SLVIF_CommonReg_WrOnHold_ERR_IntStat   | 3           |
| Enable_SLVIF_CommonReg_RD2WO_ERR_IntStat      | 2           |
| Enable_SLVIF_CommonReg_WR2RO_ERR_IntStat      | 1           |
| Enable_SLVIF_CommonReg_DEC_ERR_IntStat        | 0           |

**Table 5-16 Fields for Register: DMAC\_COMMONREG\_INTSTATUS\_ENABLEREG**

| Bits | Name                                              | Memory Access | Description                                                                                                                                                         |
|------|---------------------------------------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:9 | RSVD_DMAC_COMMONREG_IN<br>TSTATUS_ENABLEREG_63to9 | R             | DMAC Common Register Interrupt Status Enable Register (bits 63to9) Reserved bits - Read Only<br><b>Value After Reset:</b> 0x7fffffffffffff<br><b>Exists:</b> Always |

**Table 5-16 Fields for Register: DMAC\_COMMONREG\_INTSTATUS\_ENABLEREG (Continued)**

| Bits | Name                                          | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------|-----------------------------------------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8    | Enable_SLVIF_UndefinedReg_DEC_ERR_IntStat     | R/W           | <p>Slave Interface Undefined register Decode Error Interrupt Status enable Bit.</p> <p>This bit is used to enable the corresponding channel interrupt status bit (SLVIF_UndefinedReg_DEC_ERR_IntStat in DMAC_CommonReg_IntStatusReg).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_SLVIF_UndefinedReg_DEC_ERR): SLVIF_UndefinedReg_DEC_ERR_IntStat bit in DMAC_CommonReg_IntStatusReg is Enabled</li> <li>■ 0x0 (DISABLE_SLVIF_UndefinedReg_DEC_ERR): SLVIF_UndefinedReg_DEC_ERR_IntStat bit in DMAC_CommonReg_IntStatusReg is Disabled</li> </ul> <p><b>Value After Reset:</b> 0x1</p> <p><b>Exists:</b> Always</p>               |
| 7:4  | RSVD_DMAC_COMMONREG_IN_TSTATUS_ENABLEREG_7to4 | R             | <p>DMAC Common Register Interrupt Status Enable Register (bits 7to4) Reserved bits - Read Only</p> <p><b>Value After Reset:</b> 0xf</p> <p><b>Exists:</b> Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 3    | Enable_SLVIF_CommonReg_WrOnHold_ERR_IntStat   | R/W           | <p>Slave Interface Common Register Write On Hold Error Interrupt Status Enable Bit.</p> <p>This bit is used to enable the corresponding channel interrupt status bit (SLVIF_CommonReg_WrOnHold_ERR_IntStat in DMAC_CommonReg_IntStatusReg).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_SLVIF_CommonReg_WrOnHold_ERR): SLVIF_CommonReg_WrOnHold_ERR_IntStat bit in DMAC_CommonReg_IntStatusReg is Enabled</li> <li>■ 0x0 (DISABLE_SLVIF_CommonReg_WrOnHold_ERR): SLVIF_CommonReg_WrOnHold_ERR_IntStat bit in DMAC_CommonReg_IntStatusReg is Disabled</li> </ul> <p><b>Value After Reset:</b> 0x1</p> <p><b>Exists:</b> Always</p> |

**Table 5-16 Fields for Register: DMAC\_COMMONREG\_INTSTATUS\_ENABLEREG (Continued)**

| Bits | Name                                     | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|------------------------------------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2    | Enable_SLVIF_CommonReg_RD2WO_ERR_IntStat | R/W           | <p>Slave Interface Common Register Read to Write only Error Interrupt Status Enable Bit.</p> <p>This bit is used to enable the corresponding channel interrupt status bit<br/>(SLVIF_CommonReg_RD2WO_ERR_IntStat in DMAC_CommonReg_IntStatusReg).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_SLVIF_CommonReg_RD2WO_ERR): SLVIF_CommonReg_RD2WO_ERR_IntStat bit in DMAC_CommonReg_IntStatusReg is Enabled</li> <li>■ 0x0 (DISABLE_SLVIF_CommonReg_RD2WO_ERR): SLVIF_CommonReg_RD2WO_ERR_IntStat bit in DMAC_CommonReg_IntStatusReg is Disabled</li> </ul> <p><b>Value After Reset:</b> 0x1</p> <p><b>Exists:</b> Always</p> |
| 1    | Enable_SLVIF_CommonReg_WR2RO_ERR_IntStat | R/W           | <p>Slave Interface Common Register Write to Read only Error Interrupt Status Enable Bit.</p> <p>This bit is used to enable the corresponding channel interrupt status bit<br/>(SLVIF_CommonReg_WR2RO_ERR_IntStat in DMAC_CommonReg_IntStatusReg).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_SLVIF_CommonReg_WR2RO_ERR): SLVIF_CommonReg_WR2RO_ERR_IntStat bit in DMAC_CommonReg_IntStatusReg is Enabled</li> <li>■ 0x0 (DISABLE_SLVIF_CommonReg_WR2RO_ERR): SLVIF_CommonReg_WR2RO_ERR_IntStat bit in DMAC_CommonReg_IntStatusReg is Disabled</li> </ul> <p><b>Value After Reset:</b> 0x1</p> <p><b>Exists:</b> Always</p> |

**Table 5-16 Fields for Register: DMAC\_COMMONREG\_INTSTATUS\_ENABLEREG (Continued)**

| <b>Bits</b> | <b>Name</b>                            | <b>Memory Access</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------------|----------------------------------------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0           | Enable_SLVIF_CommonReg_DEC_ERR_IntStat | R/W                  | <p>Slave Interface Common Register Decode Error Interrupt Status Enable Bit.</p> <p>This bit is used to enable the corresponding channel interrupt status bit (SLVIF_CommonReg_DEC_ERR_IntStat in DMAC_CommonReg_IntStatusReg).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_SLVIF_CommonReg_DEC_ERR): SLVIF_CommonReg_DEC_ERR_IntStat bit in DMAC_CommonReg_IntStatusReg is Enabled</li> <li>■ 0x0 (DISABLE_SLVIF_CommonReg_DEC_ERR): SLVIF_CommonReg_DEC_ERR_IntStat bit in DMAC_CommonReg_IntStatusReg is Disabled</li> </ul> <p><b>Value After Reset:</b> 0x1</p> <p><b>Exists:</b> Always</p> |

### 5.1.12 DMAC\_COMMONREG\_INTSIGNAL\_ENABLEREG

- **Description:** Writing 1 to specific field will propagate the corresponding interrupt status in DMAC Common register Interrupt Status Register (DMAC\_CommonReg\_IntStatusReg) to generate an port level interrupt.
- **Size:** 64 bits
- **Offset:** 0x48
- **Exists:** Always

| RSVD_DMAC_COMMONREG_INTSIGNAL_ENABLEREG_63to9 | 63:9 |
|-----------------------------------------------|------|
| Enable_SLVIF_UndefinedReg_DEC_ERR_IntSignal   | 8    |
| RSVD_DMAC_COMMONREG_INTSIGNAL_ENABLEREG_7to4  | 7:4  |
| Enable_SLVIF_CommonReg_WrOnHold_ERR_IntSignal | 3    |
| Enable_SLVIF_CommonReg_RD2WO_ERR_IntSignal    | 2    |
| Enable_SLVIF_CommonReg_WR2RO_ERR_IntSignal    | 1    |
| Enable_SLVIF_CommonReg_DEC_ERR_IntSignal      | 0    |

Table 5-17 Fields for Register: DMAC\_COMMONREG\_INTSIGNAL\_ENABLEREG

| Bits | Name                                          | Memory Access | Description                                                                                                                                                         |
|------|-----------------------------------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:9 | RSVD_DMAC_COMMONREG_INTSIGNAL_ENABLEREG_63to9 | R             | DMAC Common Register Interrupt Signal Enable Register (bits 63to9) Reserved bits - Read Only<br><b>Value After Reset:</b> 0x7fffffffffffff<br><b>Exists:</b> Always |

**Table 5-17 Fields for Register: DMAC\_COMMONREG\_INTSIGNAL\_ENABLEREG (Continued)**

| Bits | Name                                         | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|----------------------------------------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8    | Enable_SLVIF_UndefinedReg_DEC_ERR_IntSignal  | R/W           | <p>Slave Interface Undefined register Decode Error Interrupt Signal Enable Bit.</p> <p>This bit is used to enable the propagation of corresponding channel interrupt status bit(SLVIF_UndefinedReg_DEC_ERR_IntStat in DMAC_CommonReg_IntStatusReg) to generate a port level interrupt.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1<br/>(ENABLE_SLVIF_UndefinedReg_DEC_ERR_IntSignal): SLVIF_UndefinedReg_DEC_ERR_IntStat signal in DMAC_CommonReg_IntStatusReg is Enabled at port level</li> <li>■ 0x0<br/>(DISABLE_SLVIF_UndefinedReg_DEC_ERR_IntSignal): SLVIF_UndefinedReg_DEC_ERR_IntStat signal in DMAC_CommonReg_IntStatusReg is Disabled at port level</li> </ul> <p><b>Value After Reset:</b> 0x1</p> <p><b>Exists:</b> Always</p> |
| 7:4  | RSVD_DMAC_COMMONREG_INTSIGNAL_ENABLEREG_7to4 | R             | <p>DMAC Common Register Interrupt Signal Enable Register (bits 7to4) Reserved bits - Read Only</p> <p><b>Value After Reset:</b> 0xf</p> <p><b>Exists:</b> Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

**Table 5-17 Fields for Register: DMAC\_COMMONREG\_INTSIGNAL\_ENABLEREG (Continued)**

| Bits | Name                                          | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|-----------------------------------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3    | Enable_SLVIF_CommonReg_WrOnHold_ERR_IntSignal | R/W           | <p>Slave Interface Common Register Write On Hold Error Interrupt Signal Enable Bit.</p> <p>This bit is used to enable the propagation of corresponding channel interrupt status bit(SLVIF_CommonReg_WrOnHold_ERR_IntStat in DMAC_CommonReg_IntStatusReg) to generate a port level interrupt.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1<br/>(ENABLE_SLVIF_CommonReg_WrOnHold_ERR_IntSignal): SLVIF_CommonReg_WrOnHold_ERR_IntStat signal in DMAC_CommonReg_IntStatusReg is Enabled at port level</li> <li>■ 0x0<br/>(DISABLE_SLVIF_CommonReg_WrOnHold_ERR_IntSignal): SLVIF_CommonReg_WrOnHold_ERR_IntStat signal in DMAC_CommonReg_IntStatusReg is Disabled at port level</li> </ul> <p><b>Value After Reset:</b> 0x1</p> <p><b>Exists:</b> Always</p> |
| 2    | Enable_SLVIF_CommonReg_RD2WO_ERR_IntSignal    | R/W           | <p>Slave Interface Common Register Read to Write only Error Interrupt Signal Enable Bit.</p> <p>This bit is used to enable the propagation of corresponding channel interrupt status bit (SLVIF_CommonReg_RD2WO_ERR_IntStat in DMAC_CommonReg_IntStatusReg) to generate a port level interrupt.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1<br/>(ENABLE_SLVIF_CommonReg_RD2WO_ERR_IntSignal): SLVIF_CommonReg_RD2WO_ERR_IntStat signal in DMAC_CommonReg_IntStatusReg is Enabled at port level</li> <li>■ 0x0<br/>(DISABLE_SLVIF_CommonReg_RD2WO_ERR_IntSignal): SLVIF_CommonReg_RD2WO_ERR_IntStat signal in DMAC_CommonReg_IntStatusReg is Disabled at port level</li> </ul> <p><b>Value After Reset:</b> 0x1</p> <p><b>Exists:</b> Always</p>          |

**Table 5-17 Fields for Register: DMAC\_COMMONREG\_INTSIGNAL\_ENABLEREG (Continued)**

| Bits | Name                                       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------|--------------------------------------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1    | Enable_SLVIF_CommonReg_WR2RO_ERR_IntSignal | R/W           | <p>Slave Interface Common Register Write to Read only Error Interrupt Signal Enable Bit.</p> <p>This bit is used to enable the propagation of corresponding channel interrupt status bit (SLVIF_CommonReg_WR2RO_ERR_IntStat in DMAC_CommonReg_IntStatusReg) to generate a port level interrupt.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_SLVIF_CommonReg_WR2RO_ERR_IntSignal): SLVIF_CommonReg_WR2RO_ERR_IntStat signal in DMAC_CommonReg_IntStatusReg is Enabled at port level</li> <li>■ 0x0 (DISABLE_SLVIF_CommonReg_WR2RO_ERR_IntSignal): SLVIF_CommonReg_WR2RO_ERR_IntStat signal in DMAC_CommonReg_IntStatusReg is Disabled at port level</li> </ul> <p><b>Value After Reset:</b> 0x1</p> <p><b>Exists:</b> Always</p> |
| 0    | Enable_SLVIF_CommonReg_DEC_ERR_IntSignal   | R/W           | <p>Slave Interface Common Register Decode Error Interrupt Signal Enable Bit.</p> <p>This bit is used to enable the propagation of corresponding channel interrupt status bit (SLVIF_CommonReg_DEC_ERR_IntStat in DMAC_CommonReg_IntStatusReg) to generate a port level interrupt.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_SLVIF_CommonReg_DEC_ERR_IntSignal): SLVIF_CommonReg_DEC_ERR_IntStat signal in DMAC_CommonReg_IntStatusReg is Enabled at port level</li> <li>■ 0x0 (DISABLE_SLVIF_CommonReg_DEC_ERR_IntSignal): SLVIF_CommonReg_DEC_ERR_IntStat signal in DMAC_CommonReg_IntStatusReg is Disabled at port level</li> </ul> <p><b>Value After Reset:</b> 0x1</p> <p><b>Exists:</b> Always</p>                       |

### 5.1.13 DMAC\_COMMONREG\_INTSTATUSREG

- **Description:** This Register captures Slave interface access errors.
  - Decode Error.
  - Write to read only register.
  - Read to write only register.
  - write on hold.
  - undefined address.
- **Size:** 64 bits
- **Offset:** 0x50
- **Exists:** Always

|                                        |      |
|----------------------------------------|------|
| RSVD_DMAC_COMMONREG_INTSTATUSREG_63to9 | 63:9 |
| SLVIF_UndefinedReg_DEC_ERR_IntStat     | 8    |
| RSVD_DMAC_COMMONREG_INTSTATUSREG_7to4  | 7:4  |
| SLVIF_CommonReg_WrOnHold_ERR_IntStat   | 3    |
| SLVIF_CommonReg_RD2WO_ERR_IntStat      | 2    |
| SLVIF_CommonReg_WR2RO_ERR_IntStat      | 1    |
| SLVIF_CommonReg_DEC_ERR_IntStat        | 0    |

**Table 5-18 Fields for Register: DMAC\_COMMONREG\_INTSTATUSREG**

| <b>Bits</b> | <b>Name</b>                             | <b>Memory Access</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------------|-----------------------------------------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:9        | RSVD_DMAC_COMMONREG_IN_TSTATUSREG_63to9 | R                    | <p>DMAC Common Register Interrupt Signal Enable Register (bits 63to9) Reserved bits - Read Only</p> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 8           | SLVIF_UndefinedReg_DEC_ERR_IntStat      | R                    | <p>Slave Interface Undefined register Decode Error Interrupt Signal Enable Bit.</p> <p>Decode Error generated by DW_axi_dmac during register access. This error occurs if the register access is to undefined address range (&gt;0x8FF if 8 channels are configured, &gt;0x4FF if 4 channels are configured etc.) resulting in error response by DW_axi_dmac slave interface.</p> <ul style="list-style-type: none"> <li>■ 0: No Slave Interface Decode Errors.</li> <li>■ 1: Slave Interface Decode Error detected.</li> </ul> <p>Error Interrupt Status is generated if the corresponding Status Enable bit in DMAC_CommonReg_IntStatus_Enable register bit is set to 1. This bit is cleared to 0 on writing 1 to the corresponding channel interrupt clear bit in DMAC_COMMONREG_INTCLEARREG on enabling the channel (required when the interrupt is not enabled).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (Active_UndefinedReg_DEC_ERR): Slave Interface Decode Error detected</li> <li>■ 0x0 (Inactive_UndefinedReg_DEC_ERR): No Slave Interface Decode Errors</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p> |
| 7:4         | RSVD_DMAC_COMMONREG_IN_TSTATUSREG_7to4  | R                    | <p>DMAC Common Register Interrupt Status Register (bits 7to4) Reserved bits - Read Only</p> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

**Table 5-18 Fields for Register: DMAC\_COMMONREG\_INTSTATUSREG (Continued)**

| Bits | Name                                 | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|--------------------------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3    | SLVIF_CommonReg_WrOnHold_ERR_IntStat | R             | <p>Slave Interface Common Register Write On Hold Error Interrupt Status Bit.</p> <p>This error occurs if an illegal write operation is performed on a common register; this happens if a write operation is performed on a common register except DMAC_RESETREG with DMAC_RST field set to 1 when DW_axi_dmac is in Hold mode.</p> <ul style="list-style-type: none"> <li>■ 0: No Slave Interface Common Register Write On Hold Errors.</li> <li>■ 1: Slave Interface Common Register Write On Hold Error detected.</li> </ul> <p>Error Interrupt Status is generated if the corresponding Status Enable bit in DMAC_CommonReg_IntStatus_Enable register bit is set to 1. This bit is cleared to 0 on writing 1 to the corresponding channel interrupt clear bit in DMAC_COMMONREG_INTCLEARREG on enabling the channel (required when the interrupt is not enabled).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (Active_CommonReg_WrOnHold_ERR): Slave Interface Common Register Write On Hold Error detected</li> <li>■ 0x0 (Inactive_CommonReg_WrOnHold_ERR): No Slave Interface Common Register Write On Hold Errors</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p> |

**Table 5-18 Fields for Register: DMAC\_COMMONREG\_INTSTATUSREG (Continued)**

| Bits | Name                                  | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|---------------------------------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2    | SLVIF_CommonReg_RD2WO_E<br>RR_IntStat | R             | <p>Slave Interface Common Register Read to Write only Error Interrupt Status bit.</p> <p>This error occurs if Read operation is performed to a Write Only register in the common register space (0x000 to 0xFF).</p> <ul style="list-style-type: none"> <li>■ 0: No Slave Interface Read to Write Only Errors.</li> <li>■ 1: Slave Interface Read to Write Only Error detected.</li> </ul> <p>Error Interrupt status is generated if the corresponding Status Enable bit in DMAC_CommonReg_IntStatus_Enable register bit is set to 1. This bit is cleared to 0 on writing 1 to the corresponding channel interrupt clear bit in DMAC_COMMONREG_INTCLEARREG on enabling the channel (required when the interrupt is not enabled).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (Active_CommonReg_RD2WO_ERR): Slave Interface Read to Write Only Error detected</li> <li>■ 0x0 (Inactive_CommonReg_RD2WO_ERR): No Slave Interface Read to Write Only Errors</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p> |
| 1    | SLVIF_CommonReg_WR2RO_E<br>RR_IntStat | R             | <p>Slave Interface Common Register Write to Read Only Error Interrupt Status bit.</p> <p>This error occurs if write operation is performed to a Read Only register in the common register space (0x000 to 0xFF).</p> <ul style="list-style-type: none"> <li>■ 0: No Slave Interface Write to Read Only Errors.</li> <li>■ 1: Slave Interface Write to Read Only Error detected.</li> </ul> <p>Error Interrupt status is generated if the corresponding Status Enable bit in DMAC_CommonReg_IntStatus_Enable register bit is set to 1. This bit is cleared to 0 on writing 1 to the corresponding channel interrupt clear bit in DMAC_COMMONREG_INTCLEARREG on enabling the channel (required when the interrupt is not enabled).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (Active_CommonReg_WR2RO_ERR): No Slave Interface Write to Read Only Errors</li> <li>■ 0x0 (Inactive_CommonReg_WR2RO_ERR): Slave Interface Write to Read Only Error detected</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p> |

**Table 5-18 Fields for Register: DMAC\_COMMONREG\_INTSTATUSREG (Continued)**

| Bits | Name                            | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|---------------------------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | SLVIF_CommonReg_DEC_ERR_IntStat | R             | <p>Slave Interface Common Register Decode Error Interrupt Status Bit.</p> <p>Decode Error generated by DW_axi_dmac during register access. This error occurs if the register access is to an invalid address in the common register space (0x000 to 0x0FF) resulting in error response by DW_axi_dmac slave interface.</p> <ul style="list-style-type: none"> <li>■ 0: No Slave Interface Decode Errors.</li> <li>■ 1: Slave Interface Decode Error detected.</li> </ul> <p>The Error Interrupt status is generated if the corresponding Status Enable bit in DMAC_CommonReg_IntStatus_Enable register bit is set to 1. This bit is cleared to 0 on writing 1 to the corresponding channel interrupt clear bit in DMAC_COMMONREG_INTCLEARREG on enabling the channel (required when the interrupt is not enabled).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (Active_CommonReg_DEC_ERR): Slave Interface Decode Error detected</li> <li>■ 0x0 (Inactive_CommonReg_DEC_ERR): No Slave Interface Decode Errors</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p> |

### 5.1.14 DMAC\_RESETREG

- **Description:** This register is used to initiate the Software Reset to DW\_axi\_dmac.
- **Size:** 64 bits
- **Offset:** 0x58
- **Exists:** Always



**Table 5-19 Fields for Register: DMAC\_RESETREG**

| Bits | Name                     | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                               |
|------|--------------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:1 | RSVD_DMAC_ResetReg_1to63 | R             | DMAC_ResetReg (bits 1to63) Reserved bits - Read Only<br><b>Value After Reset:</b> 0x0<br><b>Exists:</b> Always<br><b>Volatile:</b> true                                                                                                                                                                                                                                   |
| 0    | DMAC_RST                 | R/W           | DMAC Reset Request bit<br>Software writes 1 to this bit to reset the DW_axi_dmac and polls this bit to see it as 0. DW_axi_dmac resets all the modules except the slave bus interface module and clears this bit to 0.<br><b>NOTE:</b> Software is not allowed to write 0 to this bit.<br><b>Value After Reset:</b> 0x0<br><b>Exists:</b> Always<br><b>Volatile:</b> true |

### 5.1.15 DMAC\_LOWPOWER\_CFGREG

- **Description:** This register contains the fields that configures the Context Sensitive Low Power feature. This register should be programmed prior to enabling the channel.
- **Size:** 64 bits
- **Offset:** 0x60
- **Exists:** Always

|                                  |       |
|----------------------------------|-------|
| RSVD_DMAC_LOWPOWER_CFGREG_63to56 | 63:56 |
| MXIF_LPDLY                       | 55:48 |
| SBIU_LPDLY                       | 47:40 |
| GLCH_LPDLY                       | 39:32 |
| RSVD_DMAC_LOWPOWER_CFGREG_31to4  | 31:4  |
| MXIF_CSLP_EN                     | 3     |
| SBIU_CSLP_EN                     | 2     |
| CHNL_CSLP_EN                     | 1     |
| GBL_CSLP_EN                      | 0     |

Table 5-20 Fields for Register: DMAC\_LOWPOWER\_CFGREG

| Bits  | Name                             | Memory Access | Description                                                                                                                                        |
|-------|----------------------------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:56 | RSVD_DMAC_LOWPOWER_CFGREG_63to56 | R             | DMAC_LOWPOWER_CFGREG (bits 56to63) Reserved bits<br>- Read Only<br><b>Value After Reset:</b> 0x0<br><b>Exists:</b> Always<br><b>Volatile:</b> true |

**Table 5-20 Fields for Register: DMAC\_LOWPOWER\_CFGREG (Continued)**

| Bits  | Name                            | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------|---------------------------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 55:48 | MXIF_LPDLY                      | R/W           | <p>Defines the load value to be programmed into the AXI Master Interface low power delay counter. The programmed value must be greater than or equal to 0x4. If value programmed is less than 0x4, then the register value is reset to DMAX_MXIF_LPDLY. The maximum value programmed into this register field is limited to (2**DMAX_MXIF_LPDLY_WIDTH)-1, otherwise the upper bits (8-DMAX_MXIF_LPDLY_WIDTH) of this field is reset to 0x0.</p> <p><b>Value After Reset:</b> "(DMAX_MXIF_CSLP_EN==1) ? DMAX_MXIF_LPDLY : 0x0"</p> <p><b>Exists:</b> Always<br/><b>Volatile:</b> true</p> |
| 47:40 | SBIU_LPDLY                      | R/W           | <p>Defines the load value to be programmed into the SBIU low power delay counter. The programmed value must be greater than or equal to 0x4. If value programmed is less than 0x4, then the register value is reset to DMAX_SBIU_LPDLY. The maximum value programmed into this register field is limited to (2**DMAX_SBIU_LPDLY_WIDTH)-1, otherwise the upper bits (8-DMAX_SBIU_LPDLY_WIDTH) of this field is reset to 0x0.</p> <p><b>Value After Reset:</b> "(DMAX_SBIU_CSLP_EN==1) ? DMAX_SBIU_LPDLY : 0x0"</p> <p><b>Exists:</b> Always<br/><b>Volatile:</b> true</p>                 |
| 39:32 | GLCH_LPDLY                      | R/W           | <p>Defines the load value to be programmed into the Global and DMA Channel low power delay counter. The programmed value must be greater than or equal to 0x4. If value programmed is less than 0x4, then the register value is reset to DMAX_GLCH_LPDLY. The maximum value programmed into this register field is limited to (2**DMAX_GLCH_LPDLY_WIDTH)-1, otherwise the upper bits (8-DMAX_GLCH_LPDLY_WIDTH) of this field is reset to 0x0.</p> <p><b>Value After Reset:</b> "(DMAX_CSLP_EN==1) ? DMAX_GLCH_LPDLY : 0x0"</p> <p><b>Exists:</b> Always<br/><b>Volatile:</b> true</p>    |
| 31:4  | RSVD_DMAC_LOWPOWER_CFGREG_31to4 | R             | <p>DMAC_LOWPOWER_CFGREG (bits 4to31) Reserved bits - Read Only</p> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always<br/><b>Volatile:</b> true</p>                                                                                                                                                                                                                                                                                                                                                                                                                           |

**Table 5-20 Fields for Register: DMAC\_LOWPOWER\_CFGREG (Continued)**

| Bits | Name         | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------|--------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3    | MXIF_CSLP_EN | R/W           | <p>AXI Master Interface Context Sensitive Low Power feature enable.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x0 (MXIF_CSLP_DISABLE): AXI Master Interface Context Sensitive Low Power feature is disabled</li> <li>■ 0x1 (MXIF_CSLP_ENABLE): AXI Master Interface Context Sensitive Low Power feature is enabled</li> </ul> <p><b>Value After Reset:</b> "(DMAX_MXIF_CSLP_EN==1) ? 0x1 : 0x0"</p> <p><b>Exists:</b> Always<br/> <b>Volatile:</b> true</p> |
| 2    | SBIU_CSLP_EN | R/W           | <p>SBIU Context Sensitive Low Power feature enable.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x0 (SBIU_CSLP_DISABLE): SBIU Context Sensitive Low Power feature is disabled</li> <li>■ 0x1 (SBIU_CSLP_ENABLE): SBIU Context Sensitive Low Power feature is enabled</li> </ul> <p><b>Value After Reset:</b> "(DMAX_SBIU_CSLP_EN==1) ? 0x1 : 0x0"</p> <p><b>Exists:</b> Always<br/> <b>Volatile:</b> true</p>                                                 |
| 1    | CHNL_CSLP_EN | R/W           | <p>DMA Channel Context Sensitive Low Power feature enable.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x0 (CHNL_CSLP_DISABLE): DMA Channel Context Sensitive Low Power feature is disabled</li> <li>■ 0x1 (CHNL_CSLP_ENABLE): DMA Channel Context Sensitive Low Power feature is enabled</li> </ul> <p><b>Value After Reset:</b> "(DMAX_CHNL_CSLP_EN==1) ? 0x1 : 0x0"</p> <p><b>Exists:</b> Always<br/> <b>Volatile:</b> true</p>                            |
| 0    | GBL_CSLP_EN  | R/W           | <p>Global Context Sensitive Low Power feature enable.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x0 (GBL_CSLP_DISABLE): Global Context Sensitive Low Power feature is disabled</li> <li>■ 0x1 (GBL_CSLP_ENABLE): Global Context Sensitive Low Power feature is enabled</li> </ul> <p><b>Value After Reset:</b> "(DMAX_CSLP_EN==1) ? 0x1 : 0x0"</p> <p><b>Exists:</b> Always<br/> <b>Volatile:</b> true</p>                                                  |

## 5.2 DW\_axi\_dmac\_mem\_map/Channelx\_Registers\_Address\_Block Registers

DW\_axi\_dmac Channel x register address block Follow the link for the register to see a detailed description of the register.

**Table 5-21 DW\_axi\_dmac\_mem\_map/Channelx\_Registers\_Address\_Block Registers**

| Register                                                                       | Offset                     | Description                                                                                            |
|--------------------------------------------------------------------------------|----------------------------|--------------------------------------------------------------------------------------------------------|
| CHx_SAR<br>(for x = 1; x <= DMAX_NUM_CHANNELS)<br>on page 341                  | 0x100 +<br>(x-<br>1)*0x100 | The starting source address is programmed by software before the DMA channel is enabled, or by an...   |
| CHx_DAR<br>(for x = 1; x <= DMAX_NUM_CHANNELS)<br>on page 342                  | 0x108 +<br>(x-<br>1)*0x100 | The starting destination address is programmed by the software before the DMA channel is enabled,..    |
| CHx_BLOCK_TS<br>(for x = 1; x <= DMAX_NUM_CHANNELS)<br>on page 343             | 0x110 +<br>(x-<br>1)*0x100 | When DW_axi_dmac is the flow controller, the DMAC uses this register before the channel is enabled...  |
| CHx_CTL<br>(for x = 1; x <= DMAX_NUM_CHANNELS)<br>on page 345                  | 0x118 +<br>(x-<br>1)*0x100 | This register contains fields that control the DMA transfer. This register should be programmed...     |
| CHx_CFG<br>(for x = 1; x <= DMAX_NUM_CHANNELS)<br>on page 359                  | 0x120 +<br>(x-<br>1)*0x100 | This register contains fields that configure the DMA transfer. This register should be programmed...   |
| CHx_CFG2<br>(for x = 1; x <= DMAX_NUM_CHANNELS)<br>on page 371                 | 0x120 +<br>(x-<br>1)*0x100 | This register contains fields that configure the DMA transfer. This register should be programmed...   |
| CHx_LL_P<br>(for x = 1; x <= DMAX_NUM_CHANNELS)<br>on page 383                 | 0x128 +<br>(x-<br>1)*0x100 | This is the Linked List Pointer register. This register must be programmed to point to the first...    |
| CHx_STATUSREG<br>(for x = 1; x <= DMAX_NUM_CHANNELS)<br>on page 385            | 0x130 +<br>(x-<br>1)*0x100 | Channelx Status Register contains fields that indicate the status of DMA transfers for...              |
| CHx_SWHSSRCREG<br>(for x = 1; x <= DMAX_NUM_CHANNELS)<br>on page 387           | 0x138 +<br>(x-<br>1)*0x100 | Channelx Software handshake Source Register.                                                           |
| CHx_SWHSDSTREG<br>(for x = 1; x <= DMAX_NUM_CHANNELS)<br>on page 391           | 0x140 +<br>(x-<br>1)*0x100 | Channelx Software handshake Destination Register.                                                      |
| CHx_BLK_TFR_RESUMEREQREG<br>(for x = 1; x <= DMAX_NUM_CHANNELS)<br>on page 396 | 0x148 +<br>(x-<br>1)*0x100 | Channelx Block Transfer Resume Request Register. This register is used during Linked List or Shadow... |

**Table 5-21 DW\_axi\_dmac\_mem\_map/Channelx\_Registers\_Address\_Block Registers**

| <b>Register</b>                                                               | <b>Offset</b>              | <b>Description</b>                                                                                         |
|-------------------------------------------------------------------------------|----------------------------|------------------------------------------------------------------------------------------------------------|
| CHx_AXI_IDREG<br>(for x = 1; x <= DMAX_NUM_CHANNELS)<br>on page 398           | 0x150 +<br>(x-<br>1)*0x100 | Channelx AXI ID Register. This register is allowed to be updated only when the channel is disabled,...     |
| CHx_AXI_QOSREG<br>(for x = 1; x <= DMAX_NUM_CHANNELS)<br>on page 401          | 0x158 +<br>(x-<br>1)*0x100 | Channelx AXI QOS Register. This register is allowed to be updated only when the channel is disabled,...    |
| CHx_SSTAT<br>(for x = 1; x <= DMAX_NUM_CHANNELS)<br>on page 403               | 0x160 +<br>(x-<br>1)*0x100 | Channelx Source Status Register. After each block transfer completes, hardware can retrieve the...         |
| CHx_DSTAT<br>(for x = 1; x <= DMAX_NUM_CHANNELS)<br>on page 405               | 0x168 +<br>(x-<br>1)*0x100 | Channelx Destination Status Register. After each block transfer completes, hardware can retrieve...        |
| CHx_SSTATAR<br>(for x = 1; x <= DMAX_NUM_CHANNELS)<br>on page 407             | 0x170 +<br>(x-<br>1)*0x100 | Channelx Source Status Fetch Register. After completion of each block transfer, hardware can retrieve...   |
| CHx_DSTATAR<br>(for x = 1; x <= DMAX_NUM_CHANNELS)<br>on page 408             | 0x178 +<br>(x-<br>1)*0x100 | Channelx Destination Status Fetch Register. After completion of each block transfer, hardware can...       |
| CHx_INTSTATUS_ENABLEREG<br>(for x = 1; x <= DMAX_NUM_CHANNELS)<br>on page 409 | 0x180 +<br>(x-<br>1)*0x100 | Writing 1 to specific field enables the corresponding interrupt status generation in Channelx Interrupt... |
| CHx_INTSTATUS<br>(for x = 1; x <= DMAX_NUM_CHANNELS)<br>on page 423           | 0x188 +<br>(x-<br>1)*0x100 | Channelx Interrupt Status Register captures the Channelx specific interrupts                               |
| CHx_INTSIGNAL_ENABLEREG<br>(for x = 1; x <= DMAX_NUM_CHANNELS)<br>on page 441 | 0x190 +<br>(x-<br>1)*0x100 | This register contains fields that are used to enable the generation of port level interrupt at...         |
| CHx_INTCLEARREG<br>(for x = 1; x <= DMAX_NUM_CHANNELS)<br>on page 455         | 0x198 +<br>(x-<br>1)*0x100 | Writing 1 to specific field will clear the corresponding field in Channelx Interrupt Status...             |

### 5.2.1 CHx\_SAR (for x = 1; x <= DMAX\_NUM\_CHANNELS)

- **Description:** The starting source address is programmed by software before the DMA channel is enabled, or by an LLI update before the start of the DMA transfer. While the DMA transfer is in progress, this register is updated to reflect the source address of the current AXI transfer.
- **Size:** 64 bits
- **Offset:**  $0x100 + (x-1)*0x100$
- **Exists:**  $DMAX\_NUM\_CHANNELS \geq x$



**Table 5-22 Fields for Register: CHx\_SAR (for x = 1; x <= DMAX\_NUM\_CHANNELS)**

| Bits | Name | Memory Access | Description                                                                                                                                                                                                                                                                                                                                             |
|------|------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:0 | SAR  | R/W           | <p>Current Source Address of DMA transfer.</p> <p>Updated after each source transfer. The SINC fields in the CHx_CTL register determines whether the address increments or is left unchanged on every source transfer throughout the block transfer.</p> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p> |

### 5.2.2 CHx\_DAR (for x = 1; x <= DMAX\_NUM\_CHANNELS)

- **Description:** The starting destination address is programmed by the software before the DMA channel is enabled, or by an LLI update before the start of the DMA transfer. While the DMA transfer is in progress, this register is updated to reflect the destination address of the current AXI transfer.
- **Size:** 64 bits
- **Offset:**  $0x108 + (x-1)*0x100$
- **Exists:**  $DMAX\_NUM\_CHANNELS \geq x$



**Table 5-23 Fields for Register: CHx\_DAR (for x = 1; x <= DMAX\_NUM\_CHANNELS)**

| Bits | Name | Memory Access | Description                                                                                                                                                                                                                                                                                                                     |
|------|------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:0 | DAR  | R/W           | <p>Current Destination Address of DMA transfer.<br/>Updated after each destination transfer. The DINC fields in the CHx_CTL register determines whether the address increments or is left unchanged on every destination transfer.</p> <p><b>Value After Reset:</b> 0x0<br/><b>Exists:</b> Always<br/><b>Volatile:</b> true</p> |

### 5.2.3 CHx\_BLOCK\_TS (for x = 1; x <= DMAX\_NUM\_CHANNELS)

- **Description:** When DW\_axi\_dmac is the flow controller, the DMAC uses this register before the channel is enabled for block-size.
- **Size:** 64 bits
- **Offset:** 0x110 + (x-1)\*0x100
- **Exists:** DMAX\_NUM\_CHANNELS >= x



**Table 5-24 Fields for Register: CHx\_BLOCK\_TS (for x = 1; x <= DMAX\_NUM\_CHANNELS)**

| Bits  | Name                                 | Memory Access | Description                                                                                                                                                              |
|-------|--------------------------------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:22 | RSVD_DMAC_CHx_BLOCK_TS<br>REG_63to22 | R             | DMAC Channelx Block Transfer Size Register (bits 63to22)<br>Reserved bits - Read Only<br><b>Value After Reset:</b> 0x0<br><b>Exists:</b> Always<br><b>Volatile:</b> true |

**Table 5-24 Fields for Register: CHx\_BLOCK\_TS (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name     | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|----------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 21:0 | BLOCK_TS | R/W           | <p>Block Transfer Size.</p> <p>The number programmed into BLOCK_TS field indicates the total number of data of width CHx_CTL.SRC_TR_WIDTH to be transferred in a DMA block transfer.</p> <p>Block Transfer Size = BLOCK_TS+1</p> <p>When the transfer starts, the read-back value is the total number of data items already read from the source peripheral, regardless of who is the flow controller. When the source or destination peripheral is assigned as the flow controller, the value before the transfer starts saturates at DMAX_CHx_MAX_BLK_SIZE, but the actual block size can be greater.</p> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p> |

### 5.2.4 CHx\_CTL (for x = 1; x <= DMAX\_NUM\_CHANNELS)

- **Description:** This register contains fields that control the DMA transfer. This register should be programmed prior to enabling the channel except for LLI-based multi-block transfer. When LLI-based multi-block transfer is enabled, the CHx\_CTL register is loaded from the corresponding location of the LLI and it can be varied on a block-by-block basis within a DMA transfer. The software is not allowed to directly update this register through DW\_axi\_dmac slave interface. Any write to this register during LLI based multi-block transfer is ignored.
- **Size:** 64 bits
- **Offset:**  $0x118 + (x-1)*0x100$
- **Exists:**  $\text{DMAX\_NUM\_CHANNELS} \geq x$

|                          |       |
|--------------------------|-------|
| SHADOWREG_OR_LLI_VALID   | 63    |
| SHADOWREG_OR_LLI_LAST    | 62    |
| RSVD_DMAC_CHx_CTL_59to61 | 61:59 |
| IOC_BlkTfr               | 58    |
| DST_STAT_EN              | 57    |
| SRC_STAT_EN              | 56    |
| AWLEN                    | 55:48 |
| AWLEN_EN                 | 47    |
| ARLEN                    | 46:39 |
| ARLEN_EN                 | 38    |
| AW_PROT                  | 37:35 |
| AR_PROT                  | 34:32 |
| RSVD_DMAC_CHx_CTL_31     | 31    |
| NonPosted_LastWrite_En   | 30    |
| AW_CACHE                 | 29:26 |
| AR_CACHE                 | 25:22 |
| DST_MSIZE                | 21:18 |
| SRC_MSIZE                | 17:14 |
| DST_TR_WIDTH             | 13:11 |
| SRC_TR_WIDTH             | 10:8  |
| RSVD_DMAC_CHx_CTL_7      | 7     |
| DINC                     | 6     |
| RSVD_DMAC_CHx_CTL_5      | 5     |
| SINC                     | 4     |
| RSVD_DMAC_CHx_CTL_3      | 3     |
| DMS                      | 2     |
| RSVD_DMAC_CHx_CTL_1      | 1     |
| SMS                      | 0     |

**Table 5-25 Fields for Register: CHx\_CTL (for x = 1; x <= DMAX\_NUM\_CHANNELS)**

| <b>Bits</b> | <b>Name</b>            | <b>Memory Access</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------------|------------------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63          | SHADOWREG_OR_LLI_VALID | R/W                  | <p>Shadow Register content/Linked List Item valid. Indicates whether the content of shadow register or the linked list item fetched from the memory is valid.</p> <ul style="list-style-type: none"> <li>■ 0: Shadow Register content/LLI is invalid.</li> <li>■ 1: Last Shadow Register/LLI is valid.</li> </ul> <p><b>LLI based multi-block transfer:</b> The CHx_CTL register is loaded from the LLI. Hence, the software is not allowed to directly update this register through the DW_axi_dmac slave interface.</p> <p>This field can be used to dynamically extend the LLI by the software. On noticing this bit as 0, DW_axi_dmac discards the LLI and generates the ShadowReg_Or_LII_Invalid_ERR Interrupt if the corresponding channel error interrupt mask bit is set to 0.</p> <p>In the case of LLI pre-fetching, the ShadowReg_Or_LLI_Invalid_ERR interrupt is not generated even if the ShadowReg_Or_LLI_Valid bit is seen to be 0 for the pre-fetched LLI. In this case, DW_axi_dmac attempts the LLI fetch operation again after completing the current block transfer and generates the ShadowReg_Or_LII_Invalid_ERR interrupt only if ShadowReg_Or_LII_Valid bit is still seen to be 0.</p> |

**Table 5-25 Fields for Register: CHx\_CTL (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |      |               | <p>This error condition causes the DW_axi_dmac to halt the corresponding channel gracefully. DW_axi_dmac waits until software writes (any value) to CHx_BLK_TFR_ResumeReqReg to indicate valid LLI availability before attempting another LLI read operation. This bit is cleared to 0 and written back to the corresponding LLI location after block transfer completion when LLI write-back option is enabled. Hence, for LLI-based multi-block transfers, the software might manipulate/redefine any descriptor with the ShadowReg_Or_LLI_Valid bit set to 0 if LLI write-back option is enabled.</p> <p><b>Shadow Reg based multi-block transfer:</b> On noticing this bit as 0 during shadow register fetch phase, DW_axi_dmac discards the Shadow Register contents and generates ShadowReg_Or_LLI_Invld_ERR Interrupt. In this case, the software has to write (any value) to CHx_BLK_TFR_ResumeReqReg after updating the shadow registers and after setting ShadowReg_Or_LLI_Valid bit to 1 to indicate to DW_axi_dmac that shadow register contents are valid and the next block transfer can be resumed. DW_axi_dmac clears this bit to 0 after copying the shadow register contents. Software can reprogram the shadow registers only if ShadowReg_Or_LLI_Valid bit is 0. Software needs to read this register in block completion interrupt service routine (if interrupt is enabled)/continuously poll this register (if interrupt is not enabled) to make sure that this bit is 0 before updating the shadow registers.</p> <p>If shadow-register-based multi-block transfer is enabled and software attempts to write to the shadow register when ShadowReg_Or_LLI_Valid bit is 1, DW_axi_dmac generates SLVIF_ShadowReg_WrOnValid_ERR interrupt.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (VALID): Indicates shadowreg/LLI content is Valid</li> <li>■ 0x0 (INVALID): Indicates shadowreg/LLI content is Invalid</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p> |

**Table 5-25 Fields for Register: CHx\_CTL (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits  | Name                     | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------|--------------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 62    | SHADOWREG_OR_LLI_LAST    | R/W           | <p>Last Shadow Register/Linked List Item.<br/>Indicates whether shadow register content or the linked list item fetched from the memory is the last one or not.</p> <ul style="list-style-type: none"> <li>■ 0: Not last Shadow Register/LLI</li> <li>■ 1: Last Shadow Register/LLI</li> </ul> <p><b>LLI based multi-block transfer:</b> DW_axi_dmac uses this bit to decide if another LLI fetch is needed in the current DMA transfer.</p> <ul style="list-style-type: none"> <li>■ If this bit is 0, DW_axi_dmac fetches the next LLI from the address pointed out by LLP field in the current LLI.</li> <li>■ If this bit is 1, DW_axi_dmac understands that current block is the final block in the dma transfer and ends the dma transfer once the AMBA transfer corresponding to the current block completes.</li> </ul> <p><b>Shadow Reg based multi-block transfer:</b><br/>DW_axi_dmac uses this bit to decide if another Shadow Register fetch is needed in the current DMA transfer.</p> <ul style="list-style-type: none"> <li>■ If this bit is 0, DW_axi_dmac understands that there are one or more blocks to be transferred in the current block and hence one or more shadow register set contents will be valid and needs to be fetched.</li> <li>■ If this bit is 1, DW_axi_dmac understands that current block is the final block in the dma transfer and ends the dma transfer once the AMBA transfer corresponding to the current block completes.</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (LAST_ITEM): Indicates shadowreg/LLI content is the last one</li> <li>■ 0x0 (NOT_LAST_ITEM): Indicates shadowreg/LLI content is not the last one</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p> |
| 61:59 | RSVD_DMAC_CHx_CTL_59to61 | R             | <p>DMAC Channelx Control Transfer Register (bits 59to61)<br/>Reserved bits - Read Only</p> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

**Table 5-25 Fields for Register: CHx\_CTL (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name        | Memory Access                                                                         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------|-------------|---------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 58   | IOC_BlkTfr  | R/W                                                                                   | <p>Interrupt On completion of Block Transfer<br/> This bit is used to control the block transfer completion interrupt generation on a block by block basis for shadow register or linked list based multi-block transfers. Writing 1 to this register field enables CHx_IntStatusReg.BLOCK_TFR_DONE_IntStat field if this interrupt generation is enabled in CHx_IntStatus_EnableReg register and the external interrupt output is asserted if this interrupt generation is enabled in CHx_IntSignal_EnableReg register.</p> <p><b>Note:</b> If a linked-list or shadow-register-based multi-block transfer is not used for both source and destination (for instance if source and destination use contiguous address or auto-reload-based multi-block transfer), the value of this field cannot be modified per block. Additionally, the value programmed before the channel is enabled is used for all the blocks in the DMA transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (Enable_BLKTFR_INTR): Enables CHx_IntStatusReg.BLOCK_TFR_DONE_IntStat field</li> <li>■ 0x0 (DISABLE_BLKTFR_INTR): Disables CHx_IntStatusReg.BLOCK_TFR_DONE_IntStat field</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> Always</p> |
| 57   | DST_STAT_EN | {(DMAX_CH(x)_D<br>ST_STAT<br>_EN ==<br>1) ?<br>"read-<br>write" :<br>"read-<br>only"} | <p>Destination Status Enable<br/> Enable the logic to fetch status from destination peripheral of channel x pointed to by the content of CHx_DSTATAR register and stores it in CHx_DSTAT register. This value is written back to the CHx_DSTAT location of linked list at end of each block transfer if DMAX_CHx_LLI_WB_EN is set to 1 and if linked list based multi-block transfer is used by either source or destination peripheral.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (Enable_STAT_FETCH): Enables status fetch for Destination and store the value in CH1_DSTAT register</li> <li>■ 0x0 (NO_STAT_FETCH): No status fetch for Destination device</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

**Table 5-25 Fields for Register: CHx\_CTL (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits  | Name        | Memory Access                                                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|-------------|--------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 56    | SRC_STAT_EN | {(DMAX_CH(x)_SRC_STAT_EN == 1) ? "read-write" : "read-only"} | <p>Source Status Enable<br/>Enable the logic to fetch status from source peripheral of channel x pointed to by the content of CHx_SSTAR register and stores it in CHx_SSTAT register. This value is written back to the CHx_SSTAT location of linked list at end of each block transfer if DMAX_CHx_LLI_WB_EN is set to 1 and if linked list based multi-block transfer is used by either source or destination peripheral.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (Enable_STAT_FETCH): Enables status fetch for Source and store the value in CH1_SSTAT register</li> <li>■ 0x0 (NO_STAT_FETCH): No status fetch for Source device</li> </ul> <p><b>Value After Reset:</b> 0x0<br/><b>Exists:</b> Always</p> |
| 55:48 | AWLEN       | R/W                                                          | <p>Destination Burst Length<br/>AXI Burst length used for destination data transfer. The specified burst length is used for destination data transfer till the extent possible; remaining transfers use maximum possible value that is less than or equal to DMAX_CHx_MAX_AMBA_BURST_LENGTH.<br/>The maximum value of AWLEN is limited by DMAX_CHx_MAX_AMBA_BURST_LENGTH.</p> <p><b>Note:</b> The AWLEN setting may not be honored towards end-to-block transfers, the end of a transaction (only applicable to non-memory peripherals), and during 4K boundary crossings.</p> <p><b>Value After Reset:</b> 0x0<br/><b>Exists:</b> Always</p>                                                                                                 |

**Table 5-25 Fields for Register: CHx\_CTL (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits  | Name     | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|----------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 47    | AWLEN_EN | R/W           | <p>Destination Burst Length Enable<br/>If this bit is set to 1, DW_axi_dmac uses the value of CHx_CTL.AWLEN as AXI Burst length for destination data transfer till the extent possible; remaining transfers use maximum possible burst length.<br/>If this bit is set to 0, DW_axi_dmac uses any possible value which is less than or equal to DMAX_CHx_MAX_AMBA_BURST_LENGTH as AXI Burst length for destination data transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (Enable): AXI Burst Length is CH1_CTL.AWLEN (till the extent possible) for Destination data transfers</li> <li>■ 0x0 (Disable): AXI Burst Length is any possible value &lt;= DMAX_CH1_MAX_AMBA_BURST_LENGTH for Destination data transfers</li> </ul> <p><b>Value After Reset:</b> 0x0<br/><b>Exists:</b> Always</p> |
| 46:39 | ARLEN    | R/W           | <p>Source Burst Length<br/>AXI Burst length used for source data transfer. The specified burst length is used for source data transfer till the extent possible; remaining transfers use maximum possible value that is less than or equal to DMAX_CHx_MAX_AMBA_BURST_LENGTH.<br/>The maximum value of ARLEN is limited by DMAX_CHx_MAX_AMBA_BURST_LENGTH</p> <p><b>Value After Reset:</b> 0x0<br/><b>Exists:</b> Always</p>                                                                                                                                                                                                                                                                                                                                                                                                 |

**Table 5-25 Fields for Register: CHx\_CTL (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits  | Name             | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 38    | ARLEN_EN         | R/W           | <p>Source Burst Length Enable<br/>If this bit is set to 1, DW_axi_dmac uses the value of CHx_CTL.ARLEN as AXI Burst length for source data transfer till the extent possible; remaining transfers use maximum possible burst length.</p> <p>If this bit is set to 0, DW_axi_dmac uses any possible value that is less than or equal to DMAX_CHx_MAX_AMBA_BURST_LENGTH as AXI Burst length for source data transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (Enable): AXI Burst Length is CH1_CTL.ARLEN (till the extent possible) for Source data transfers</li> <li>■ 0x0 (Disable): AXI Burst Length is any possible value &lt;= DMAX_CH1_MAX_AMBA_BURST_LENGTH for Source data transfers</li> </ul> <p><b>Value After Reset:</b> 0x0<br/><b>Exists:</b> Always</p> |
| 37:35 | AW_PROT          | R/W           | <p>AXI 'aw_prot' signal<br/><b>Value After Reset:</b> 0x0<br/><b>Exists:</b> Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 34:32 | AR_PROT          | R/W           | <p>AXI 'ar_prot' signal<br/><b>Value After Reset:</b> 0x0<br/><b>Exists:</b> Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 31    | RSVD_DMACHCTL_31 | R             | <p>DMAC Channelx Control Transfer Register bit31 Reserved bits - Read Only<br/><b>Value After Reset:</b> 0x0<br/><b>Exists:</b> Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

**Table 5-25 Fields for Register: CHx\_CTL (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits  | Name                   | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|------------------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30    | NonPosted_LastWrite_En | R/W           | <p>Non Posted Last Write Enable<br/>This bit decides whether posted writes can be used throughout the block transfer.</p> <ul style="list-style-type: none"> <li>■ 0: Posted writes may be used throughout the block transfer.</li> <li>■ 1: Posted writes may be used till the end of the block (inside a block) and the last write in the block must be non-posted. This is to synchronize block completion interrupt generation to the last write data reaching the end memory/peripheral.</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (Enable): Last write in the block must be non-posted</li> <li>■ 0x0 (Disable): Posted writes may be used throughout the block transfer</li> </ul> <p><b>Value After Reset:</b> 0x0<br/><b>Exists:</b> Always</p> |
| 29:26 | AW_CACHE               | R/W           | <p>AXI 'aw_cache' signal<br/><b>Value After Reset:</b> 0x0<br/><b>Exists:</b> Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 25:22 | AR_CACHE               | R/W           | <p>AXI 'ar_cache' signal<br/><b>Value After Reset:</b> 0x0<br/><b>Exists:</b> Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

**Table 5-25 Fields for Register: CHx\_CTL (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits  | Name       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------|------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 21:18 | DST_MSIZEx | R/W           | <p>Destination Burst Transaction Length.<br/>Number of data items, each of width CHx_CTL.DST_TR_WIDTH, to be written to the destination every time a destination burst transaction request is made from the corresponding hardware or software handshaking interface. <b>Note:</b> This Value is not related to the AXI awlen signal.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x0 (DATA_ITEM_1): 1 Data Item read from Destination in the burst transaction</li> <li>■ 0x1 (DATA_ITEMS_4): 4 Data Item read from Destination in the burst transaction</li> <li>■ 0x2 (DATA_ITEMS_8): 8 Data Item read from Destination in the burst transaction</li> <li>■ 0x3 (DATA_ITEMS_16): 16 Data Item read from Destination in the burst transaction</li> <li>■ 0x4 (DATA_ITEMS_32): 32 Data Item read from Destination in the burst transaction</li> <li>■ 0x5 (DATA_ITEMS_64): 64 Data Item read from Destination in the burst transaction</li> <li>■ 0x6 (DATA_ITEMS_128): 128 Data Item read from Destination in the burst transaction</li> <li>■ 0x7 (DATA_ITEMS_256): 256 Data Item read from Destination in the burst transaction</li> <li>■ 0x8 (DATA_ITEMS_512): 512 Data Item read from Destination in the burst transaction</li> <li>■ 0x9 (DATA_ITEMS_1024): 1024 Data Item read from Destination in the burst transaction</li> </ul> <p><b>Value After Reset:</b> 0x0<br/><b>Exists:</b> Always</p> |

**Table 5-25 Fields for Register: CHx\_CTL (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits  | Name       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17:14 | SRC_MSIZEx | R/W           | <p>Source Burst Transaction Length.<br/>Number of data items, each of width CHx_CTL.SRC_TR_WIDTH, to be read from the source every time a source burst transaction request is made from the corresponding hardware or software handshaking interface. The maximum value of DST_MSIZE is limited by DMAX_CHx_MAX_MSIZE.</p> <p><b>Note:</b> This Value is not related to the AXI arlen signal.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x0 (DATA_ITEMS_1): 1 Data Item read from Source in the burst transaction</li> <li>■ 0x1 (DATA_ITEMS_4): 4 Data Item read from Source in the burst transaction</li> <li>■ 0x2 (DATA_ITEMS_8): 8 Data Item read from Source in the burst transaction</li> <li>■ 0x3 (DATA_ITEMS_16): 16 Data Item read from Source in the burst transaction</li> <li>■ 0x4 (DATA_ITEMS_32): 32 Data Item read from Source in the burst transaction</li> <li>■ 0x5 (DATA_ITEMS_64): 64 Data Item read from Source in the burst transaction</li> <li>■ 0x6 (DATA_ITEMS_128): 128 Data Item read from Source in the burst transaction</li> <li>■ 0x7 (DATA_ITEMS_256): 256 Data Item read from Source in the burst transaction</li> <li>■ 0x8 (DATA_ITEMS_512): 512 Data Item read from Source in the burst transaction</li> <li>■ 0x9 (DATA_ITEMS_1024): 1024 Data Item read from Source in the burst transaction</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> |

**Table 5-25 Fields for Register: CHx\_CTL (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits  | Name                | Memory Access                                                     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------|---------------------|-------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:11 | DST_TR_WIDTH        | <code>{(DMAX_CH(x)_DTW == 0) ? "read-write" : "read-only"}</code> | <p>Destination Transfer Width.<br/>Mapped to AXI bus awsize, this value must be less than or equal to DMAX_M_DATA_WIDTH.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x0 (BITS_8): Destination Transfer Width is 8 bits</li> <li>■ 0x1 (BITS_16): Destination Transfer Width is 16 bits</li> <li>■ 0x2 (BITS_32): Destination Transfer Width is 32 bits</li> <li>■ 0x3 (BITS_64): Destination Transfer Width is 64 bits</li> <li>■ 0x4 (BITS_128): Destination Transfer Width is 128 bits</li> <li>■ 0x5 (BITS_256): Destination Transfer Width is 256 bits</li> <li>■ 0x6 (BITS_512): Destination Transfer Width is 512 bits</li> </ul> <p><b>Value After Reset:</b> <code>{(DMAX_CH(x)_DTW_ENC &lt; 7) ? DMAX_CH(x)_DTW_ENC : 2}</code></p> <p><b>Exists:</b> Always</p> |
| 10:8  | SRC_TR_WIDTH        | <code>{(DMAX_CH(x)_STW == 0) ? "read-write" : "read-only"}</code> | <p>Source Transfer Width.<br/>Mapped to AXI bus arsize, this value must be less than or equal to DMAX_M_DATA_WIDTH.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x0 (BITS_8): Source Transfer Width is 8 bits</li> <li>■ 0x1 (BITS_16): Source Transfer Width is 16 bits</li> <li>■ 0x2 (BITS_32): Source Transfer Width is 32 bits</li> <li>■ 0x3 (BITS_64): Source Transfer Width is 64 bits</li> <li>■ 0x4 (BITS_128): Source Transfer Width is 128 bits</li> <li>■ 0x5 (BITS_256): Source Transfer Width is 256 bits</li> <li>■ 0x6 (BITS_512): Source Transfer Width is 512 bits</li> </ul> <p><b>Value After Reset:</b> <code>{(DMAX_CH(x)_STW_ENC &lt; 7) ? DMAX_CH(x)_STW_ENC : 2}</code></p> <p><b>Exists:</b> Always</p>                                         |
| 7     | RSVD_DMAC_CHx_CTL_7 | R                                                                 | <p>DMAC Channelx Control Transfer Register bit7 Reserved bits - Read Only</p> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

**Table 5-25 Fields for Register: CHx\_CTL (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name                | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|---------------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6    | DINC                | R/W           | <p>Destination Address Increment.</p> <p>Indicates whether to increment the destination address on every destination transfer. If the device is writing data from a source peripheral FIFO with a fixed address, then set this field to 'No change'.</p> <ul style="list-style-type: none"> <li>■ 0: Increment</li> <li>■ 1: No Change</li> </ul> <p><b>NOTE:</b> Increment aligns the address to the next CHx_CTL.DST_TR_WIDTH boundary.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x0 (INCREMENTAL): Destination address incremented on every source transfer</li> <li>■ 0x1 (FIXED): Destination address is fixed</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> |
| 5    | RSVD_DMAC_CHx_CTL_5 | R             | <p>DMAC Channelx Control Transfer Register bit5 Reserved bits - Read Only</p> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 4    | SINC                | R/W           | <p>Source Address Increment.</p> <p>Indicates whether to increment the source address on every source transfer. If the device is fetching data from a source peripheral FIFO with a fixed address, then set this field to 'No change'.</p> <ul style="list-style-type: none"> <li>■ 0: Increment</li> <li>■ 1: No Change</li> </ul> <p><b>NOTE:</b> Increment aligns the address to the next CHx_CTL.SRC_TR_WIDTH boundary.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x0 (INCREMENTAL): Source address incremented on every source transfer</li> <li>■ 0x1 (FIXED): Source address is fixed</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p>                         |
| 3    | RSVD_DMAC_CHx_CTL_3 | R             | <p>DMAC Channelx Control Transfer Register bit3 Reserved bits - Read Only</p> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

**Table 5-25 Fields for Register: CHx\_CTL (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name                | Memory Access                                              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|---------------------|------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2    | DMS                 | $\{(DMA_{CH(x)}\_DMS == 2) ? "read-write" : "read-only"\}$ | <p>Destination Master Select.<br/>Identifies the Master Interface layer from which the destination device (peripheral or memory) is accessed.</p> <ul style="list-style-type: none"> <li>■ 0: AXI master 1</li> <li>■ 1: AXI Master 2</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (MASTER2_INTF): Destination device on Master-2 interface layer</li> <li>■ 0x0 (MASTER1_INTF): Destination device on Master-1 interface layer</li> </ul> <p><b>Value After Reset:</b> <math>\{(DMA_{CH(x)}\_DMS &lt; 2) ? DMA_{CH(x)}\_DMS : 0\}</math></p> <p><b>Exists:</b> Always</p> |
| 1    | RSVD_DMAC_CHx_CTL_1 | R                                                          | <p>DMAC Channelx Control Transfer Register bit1 Reserved bits - Read Only</p> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 0    | SMS                 | $\{(DMA_{CH(x)}\_SMS == 2) ? "read-write" : "read-only"\}$ | <p>Source Master Select.<br/>Identifies the Master Interface layer from which the source device (peripheral or memory) is accessed.</p> <ul style="list-style-type: none"> <li>■ 0: AXI master 1</li> <li>■ 1: AXI Master 2</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (MASTER2_INTF): Source device on Master-2 interface layer</li> <li>■ 0x0 (MASTER1_INTF): Source device on Master-1 interface layer</li> </ul> <p><b>Value After Reset:</b> <math>\{(DMA_{CH(x)}\_SMS &lt; 2) ? DMA_{CH(x)}\_SMS : 0\}</math></p> <p><b>Exists:</b> Always</p>                     |

### 5.2.5 CHx\_CFG (for x = 1; x <= DMAX\_NUM\_CHANNELS)

- Description:** This register contains fields that configure the DMA transfer. This register should be programmed prior to enabling the channel.

Bits [63:32] of the channel configuration register remains fixed for all blocks of a multi-block transfer and can be programmed only when channel is disabled.

Bits [3:0] of the channel configuration register can be programmed even when channel is enabled.

Software clears these bits to end the multi-block transfers. For Contiguous-Address and Auto-Reloading-based multi-block transfers (if neither source nor destination peripheral uses Shadow-Register or Linked-List-based multi-block transfers), if the corresponding multi-block type selection bits namely CHx\_CFG.SRC\_MLTBLK\_TYPE and/or CHx\_CFG.DST\_MLTBLK\_TYPE bits are seen to be 2'b00 at the end of a block transfer, the DW\_axi\_dmac understands that the previous block was the final block in the transfer and completes the DMA transfer operation.

- Size:** 64 bits
- Offset:** 0x120 + (x-1)\*0x100
- Exists:** DMAX\_NUM\_CHANNELS >= x && DMAX\_NUM\_CHANNELS <= 8 && DMAX\_NUM\_HS\_IF <= 16

|                         |       |
|-------------------------|-------|
| RSVD_DMAC_CHx_CFG_63    | 63    |
| DST_OSR_LMT             | 62:59 |
| SRC_OSR_LMT             | 58:55 |
| LOCK_CH_L               | 54:53 |
| LOCK_CH                 | 52    |
| CH_PRIOR                | 51:49 |
| RSVD_DMAC_CHx_CFG_48    | 48    |
| RSVD_DMAC_CHx_CFG_47_44 | 47:y  |
| DST_PER                 | x:44  |
| RSVD_DMAC_CHx_CFG_43    | 43    |
| RSVD_DMAC_CHx_CFG_42_39 | 42:y  |
| SRC_PER                 | x:39  |
| DST_HWHS_POL            | 38    |
| SRC_HWHS_POL            | 37    |
| HS_SEL_DST              | 36    |
| HS_SEL_SRC              | 35    |
| TT_FC                   | 34:32 |
| RSVD_DMAC_CHx_CFG_4to31 | 31:4  |
| DST_MULTBLK_TYPE        | 3:2   |
| SRC_MULTBLK_TYPE        | 1:0   |

Table 5-26 Fields for Register: CHx\_CFG (for x = 1; x <= DMAX\_NUM\_CHANNELS)

| Bits | Name                 | Memory Access | Description                                                                                                                                 |
|------|----------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 63   | RSVD_DMAC_CHx_CFG_63 | R             | DMAC Channelx Transfer Configuration Register (63bit)<br>Reserved bit - Read Only<br><b>Value After Reset:</b> 0x0<br><b>Exists:</b> Always |

**Table 5-26 Fields for Register: CHx\_CFG (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits  | Name       | Memory Access                                                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|------------|-----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 62:59 | DST_OSRLMT | R/W                                                             | <p>Destination Outstanding Request Limit</p> <ul style="list-style-type: none"> <li>■ Maximum outstanding request supported is 16.</li> <li>■ Source Outstanding Request Limit = DST_OSRLMT + 1</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 58:55 | SRC_OSRLMT | R/W                                                             | <p>Source Outstanding Request Limit</p> <ul style="list-style-type: none"> <li>■ Maximum outstanding request supported is 16.</li> <li>■ Source Outstanding Request Limit = SRC_OSRLMT + 1</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 54:53 | LOCK_CH_L  | $\{(DMA_{CH(x)}\_LOCK\_EN == 1) ? "read-write" : "read-only"\}$ | <p>Channel Lock Level</p> <p>This bit indicates the duration over which CHx_CFG.LOCK_CH bit applies.</p> <ul style="list-style-type: none"> <li>■ 00: Over complete DMA transfer</li> <li>■ 01: Over DMA block transfer</li> <li>■ 1x: Reserved</li> </ul> <p>This field does not exist if the configuration parameter DMAX_CHx_LOCK_EN is set to False; in that case, the read-back value is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x0 (DMA_transfer_CH_LOCK): Duration of the Channel locking is for the entire DMA transfer</li> <li>■ 0x1 (BLOCK_TRANSFER_CH_LOCK): Duration of the Channel locking is for the current block transfer</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> Always</p> |

**Table 5-26 Fields for Register: CHx\_CFG (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits  | Name               | Memory Access                                                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|--------------------|-----------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 52    | LOCK_CH            | $\{(DMA_{CH(x)}\_LOCK\_EN == 1) ? "read-write" : "read-only"\}$ | <p>Channel Lock bit<br/>When the channel is granted control of the master bus interface and if the CHx_CFG.LOCK_CH bit is asserted, then no other channels are granted control of the master bus interface for the duration specified in CHx_CFG.LOCK_CH_L. Indicates to the master bus interface arbiter that this channel wants exclusive access to the master bus interface for the duration specified in CHx_CFG.LOCK_CH_L.</p> <p>This field does not exist if the configuration parameter DMAX_CHx_LOCK_EN is set to False; in this case, the read-back value is always 0.</p> <p>Locking the channel locks AXI Read Address, Write Address and Write Data channels on the corresponding master interface.</p> <p><b>Note:</b> Channel locking feature is supported only for memory-to-memory transfer at Block Transfer and DMA Transfer levels. Hardware does not check for the validity of channel locking setting, hence the software must take care of enabling the channel locking only for memory-to-memory transfers at Block Transfer or DMA Transfer levels. Illegal programming of channel locking might result in unpredictable behavior.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x0 (NO_CHANNEL_LOCK): Channel is not locked during the transfers</li> <li>■ 0x1 (CHANNEL_LOCK): Channel is locked and granted exclusive access to the Master Bus Interface</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> |
| 51:49 | CH_PRIOR           | R/W                                                             | <p>Channel Priority<br/>A priority of DMAX_NUM_CHANNELS-1 is the highest priority, and 0 is the lowest. This field must be programmed within the following range:<br/>0: DMAX_NUM_CHANNELS-1<br/>A programmed value outside this range will cause erroneous behavior.</p> <p><b>Value After Reset:</b> (DMAX_NUM_CHANNELS -(x))</p> <p><b>Exists:</b> Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 48    | RSVD_DMACHx_CFG_48 | R                                                               | <p>DMAC Channelx Transfer Configuration Register (48bit)<br/>Reserved bit - Read Only</p> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

**Table 5-26 Fields for Register: CHx\_CFG (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name                      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|---------------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 47:y | RSVD_DM_MAC_CHx_CFG_47_44 | R             | DMAC Channelx Transfer Configuration Register (bits (LOG2_DMAX_NUM_HS_IF+44) to 47) Reserved bits - Read Only<br><b>Value After Reset:</b> 0x0<br><b>Exists:</b> Always<br><b>Range Variable[y]:</b> LOG2_DMAX_NUM_HS_IF + 44                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| x:44 | DST_PER                   | * Varies      | Assigns a hardware handshaking interface (0 - DMAX_NUM_HS_IF-1) to the destination of Channelx if the CHx_CFG.HS_SEL_DST field is 0; otherwise, this field is ignored. The channel can then communicate with the destination peripheral connected to that interface. <b>Note:</b> For correct DW_axi_dmac operation, only one peripheral (source or destination) should be assigned to the same handshaking interface.<br>This field does not exist if the configuration parameter DMAX_NUM_HS_IF is set to 0.<br>x = 44 if DMAC_NUM_HS_IF is 1<br>x = ceil(log2(DMAC_NUM_HS_IF)) + 43 if DMAC_NUM_HS_IF is greater than 1<br>Bits 47: (x+1) do not exist and return 0 on a read.<br><b>Value After Reset:</b> 0x0<br><b>Exists:</b> Always<br><b>Range Variable[x]:</b> LOG2_DMAX_NUM_HS_IF + 43<br><b>Memory Access:</b> {(DMAX_NUM_HS_IF == 0) ? "read-only" : "read-write"} |
| 43   | RSVD_DM_MAC_CHx_CFG_43    | R             | DMAC Channelx Transfer Configuration Register (43bit)<br>Reserved bit - Read Only<br><b>Value After Reset:</b> 0x0<br><b>Exists:</b> Always                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 42:y | RSVD_DM_MAC_CHx_CFG_42_39 | R             | DMAC Channelx Transfer Configuration Register (bits (LOG2_DMAX_NUM_HS_IF+39) to 42) Reserved bits - Read Only<br><b>Value After Reset:</b> 0x0<br><b>Exists:</b> Always<br><b>Range Variable[y]:</b> LOG2_DMAX_NUM_HS_IF + 39                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

**Table 5-26 Fields for Register: CHx\_CFG (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name         | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|--------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| x:39 | SRC_PER      | * Varies      | <p>Assigns a hardware handshaking interface (0 - DMAX_NUM_HS_IF-1) to the source of Channelx if the CHx_CFG.HS_SEL_SRC field is 0; otherwise, this field is ignored. The channel can then communicate with the source peripheral connected to that interface through the assigned hardware handshaking interface. <b>Note:</b> For correct DW_axi_dmac operation, only one peripheral (source or destination) should be assigned to the same handshaking interface.</p> <p>This field does not exist if the configuration parameter DMAX_NUM_HS_IF is set to 0.</p> <p>x = 39 if DMAC_NUM_HS_IF is 1</p> <p>x = ceil(log2(DMAC_NUM_HS_IF)) + 38 if DMAC_NUM_HS_IF is greater than 1.</p> <p>Bits 42: (x+1) do not exist and return 0 on a read.</p> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Range Variable[x]:</b> LOG2_DMAX_NUM_HS_IF + 38</p> <p><b>Memory Access:</b> {(DMAX_NUM_HS_IF == 0) ? "read-only" : "read-write"}</p> |
| 38   | DST_HWHS_POL | R             | <p>Destination Hardware Handshaking Interface Polarity.</p> <ul style="list-style-type: none"> <li>■ 0: ACTIVE HIGH</li> <li>■ 1: ACTIVE LOW</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x0 (ACTIVE_HIGH): Polarity of the Handshaking Interface used for the Destination peripheral is Active High</li> <li>■ 0x1 (ACTIVE_LOW): Polarity of the Handshaking Interface used for the Destination peripheral is Active Low</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                              |

**Table 5-26 Fields for Register: CHx\_CFG (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name         | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|--------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 37   | SRC_HWHS_POL | R             | <p>Source Hardware Handshaking Interface Polarity.</p> <ul style="list-style-type: none"> <li>■ 0: ACTIVE HIGH</li> <li>■ 1: ACTIVE LOW</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x0 (ACTIVE_HIGH): Polarity of the Handshaking Interface used for the Source peripheral is Active High</li> <li>■ 0x1 (ACTIVE_LOW): Polarity of the Handshaking Interface used for the Source peripheral is Active Low</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> Always</p>                                                                                                                                                                                                                                                                                                                                              |
| 36   | HS_SEL_DST   | R/W           | <p>Destination Software or Hardware Handshaking Select. This register selects which of the handshaking interfaces (hardware or software) is active for destination requests on this channel.</p> <ul style="list-style-type: none"> <li>■ 0: Hardware handshaking interface. Software-initiated transaction requests are ignored.</li> <li>■ 1: Software handshaking interface. Hardware-initiated transaction requests are ignored.</li> </ul> <p>If the destination peripheral is memory, then this bit is ignored.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x0 (HARDWARE_HS): Hardware Handshaking Interface is used for the Destination peripheral</li> <li>■ 0x1 (SOFTWARE_HS): Software Handshaking Interface is used for the Destination peripheral</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p> |

**Table 5-26 Fields for Register: CHx\_CFG (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------|------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 35   | HS_SEL_SRC | R/W           | <p>Source Software or Hardware Handshaking Select. This register selects which of the handshaking interfaces (hardware or software) is active for source requests on this channel.</p> <ul style="list-style-type: none"> <li>■ 0: Hardware handshaking interface. Software-initiated transaction requests are ignored.</li> <li>■ 1: Software handshaking interface. Hardware-initiated transaction requests are ignored.</li> </ul> <p>If the source peripheral is memory, then this bit is ignored.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x0 (HARDWARE_HS): Hardware Handshaking Interface is used for the Source peripheral</li> <li>■ 0x1 (SOFTWARE_HS): Software Handshaking Interface is used for the Source peripheral</li> </ul> <p><b>Value After Reset:</b> 0x1</p> <p><b>Exists:</b> Always</p> |

**Table 5-26 Fields for Register: CHx\_CFG (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits  | Name                    | Memory Access                                          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|-------------------------|--------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 34:32 | TT_FC                   | {(DMAX_CH(x)_TT_FC == 8) ? "read-write" : "read-only"} | <p>Transfer Type and Flow Control.<br/>The following transfer types are supported.</p> <ul style="list-style-type: none"> <li>■ Memory to Memory</li> <li>■ Memory to Peripheral</li> <li>■ Peripheral to Memory</li> <li>■ Peripheral to Peripheral</li> </ul> <p>Flow Control can be assigned to the DW_axi_dmac, the source peripheral, or the destination peripheral.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x0 (MEM_TO_MEM_DMPC): Transfer Type is memory to memory and Flow Controller is DW_axi_dmac</li> <li>■ 0x1 (MEM_TO_PER_DMPC): Transfer Type is memory to peripheral and Flow Controller is DW_axi_dmac</li> <li>■ 0x2 (PER_TO_MEM_DMPC): Transfer Type is peripheral to memory and Flow Controller is DW_axi_dmac</li> <li>■ 0x3 (PER_TO_PER_DMPC): Transfer Type is peripheral to peripheral and Flow Controller is DW_axi_dmac</li> <li>■ 0x4 (PER_TO_MEM_SRC): Transfer Type is peripheral to Memory and Flow Controller is Source peripheral</li> <li>■ 0x5 (PER_TO_PER_SRC): Transfer Type is peripheral to peripheral and Flow Controller is Source peripheral</li> <li>■ 0x6 (MEM_TO_PER_DST): Transfer Type is memory to peripheral and Flow Controller is Destination peripheral</li> <li>■ 0x7 (PER_TO_PER_DST): Transfer Type is peripheral to peripheral and Flow Controller is Destination peripheral</li> </ul> <p><b>Value After Reset:</b> {(DMAX_CH(x)_TT_FC &lt; 8) ? DMAX_CH(x)_TT_FC : 3}</p> <p><b>Exists:</b> Always</p> |
| 31:4  | RSVD_DMAC_CHx_CFG_4to31 | R                                                      | <p>DMAC Channelx Transfer Configuration Register (bits 4to31)<br/>Reserved bits - Read Only</p> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

**Table 5-26 Fields for Register: CHx\_CFG (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name             | Memory Access                                                                                                                                                                       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:2  | DST_MULTBLK_TYPE | {(DMAX_CH(x)_M_ULTI_BL_K_EN == 1) && ((DMAX_CH(x)_M_ULTI_BL_K_TYPE == 0)    (DMAX_CH(x)_M_ULTI_BL_K_TYPE == 1)    (DMAX_CH(x)_M_ULTI_BL_K_TYPE == 4)) ? "read-write" : "read-only"} | <p>Destination Multi Block Transfer Type.<br/>These bits define the type of multi-block transfer used for destination peripheral.</p> <ul style="list-style-type: none"> <li>■ 00: Contiguous</li> <li>■ 01: Reload</li> <li>■ 10: Shadow Register</li> <li>■ 11: Linked List</li> </ul> <p>If the type selected is Contiguous, the CHx_DAR register is loaded with the value of the end source address of previous block + 1 at the end of every block for multi-block transfers. A new block transfer is then initiated.</p> <p>If the type selected is Reload, the CHx_DAR register is reloaded from the initial value of DAR at the end of every block for multi-block transfers. A new block transfer is then initiated.</p> <p>If the type selected is Shadow Register, the CHx_DAR register is loaded from the content of its shadow register if CHx_CTL.ShadowReg_Or_LLI_Valid bit is set to 1 at the end of every block for multi-block transfers. A new block transfer is then initiated.</p> <p>If the type selected is Linked List, the CHx_DAR register is loaded from the Linked List if CTL.ShadowReg_Or_LLI_Valid bit is set to 1 at the end of every block for multi-block transfers. A new block transfer is then initiated.</p> <p>CHx_CTL and CHx_BLOCK_TS registers are loaded from their initial values or from the contents of their shadow registers (if CHx_CTL.ShadowReg_Or_LLI_Valid bit is set to 1) or from the linked list (if CTL.ShadowReg_Or_LLI_Valid bit is set to 1) at the end of every block for multi-block transfers based on the multi-block transfer type programmed for source and destination peripherals.</p> <p>Contiguous transfer on both source and destination peripheral is not a valid multi-block transfer configuration.</p> |

**Table 5-26 Fields for Register: CHx\_CFG (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |      |               | <p>This field does not exist if the configuration parameter DMAX_CHx_MULTI_BLK_EN is not selected; in that case, the read-back value is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x0 (CONTINUOUS): Contiguous Multiblock Type used for Destination Transfer</li> <li>■ 0x1 (RELOAD): Reload Multiblock Type used for Destination Transfer</li> <li>■ 0x2 (SHADOW_REGISTER): Shadow Register based Multiblock Type used for Destination Transfer</li> <li>■ 0x3 (LINKED_LIST): Linked List based Multiblock Type used for Destination Transfer</li> </ul> <p><b>Value After Reset:</b> {(DMAX_CH(x)_MULTI_BLK_TYPE == 0) ? 0 : DMAX_CH(x)_DST_MULTI_BLK_TYPE}</p> <p><b>Exists:</b> Always</p> |

**Table 5-26 Fields for Register: CHx\_CFG (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name             | Memory Access                                                                                                                                                                       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0  | SRC_MULTBLK_TYPE | {(DMAX_CH(x)_M_ULTI_BL_K_EN == 1) && ((DMAX_CH(x)_M_ULTI_BL_K_TYPE == 0)    (DMAX_CH(x)_M_ULTI_BL_K_TYPE == 3)    (DMAX_CH(x)_M_ULTI_BL_K_TYPE == 4)) ? "read-write" : "read-only"} | <p>Source Multi Block Transfer Type.<br/>These bits define the type of multi-block transfer used for source peripheral.</p> <ul style="list-style-type: none"> <li>■ 00: Contiguous</li> <li>■ 01: Reload</li> <li>■ 10: Shadow Register</li> <li>■ 11: Linked List</li> </ul> <p>If the type selected is Contiguous, the CHx_SAR register is loaded with the value of the end source address of previous block + 1 at the end of every block for multi-block transfers. A new block transfer is then initiated.</p> <p>If the type selected is Reload, the CHx_SAR register is reloaded from the initial value of SAR at the end of every block for multi-block transfers. A new block transfer is then initiated.</p> <p>If the type selected is Shadow Register, the CHx_SAR register is loaded from the content of its shadow register if CHx_CTL.ShadowReg_Or_LLI_Valid bit is set to 1 at the end of every block for multi-block transfers. A new block transfer is then initiated.</p> <p>If the type selected is Linked List, the CHx_SAR register is loaded from the Linked List if CTL.ShadowReg_Or_LLI_Valid bit is set to 1 at the end of every block for multi-block transfers. A new block transfer is then initiated.</p> <p>CHx_CTL and CHx_BLOCK_TS registers are loaded from their initial values or from the contents of their shadow registers (if CHx_CTL.ShadowReg_Or_LLI_Valid bit is set to 1) or from the linked list (if CTL.ShadowReg_Or_LLI_Valid bit is set to 1) at the end of every block for multi-block transfers based on the multi-block transfer type programmed for source and destination peripherals.</p> <p>Contiguous transfer on both source and destination peripheral is not a valid multi-block transfer configuration.</p> |

**Table 5-26 Fields for Register: CHx\_CFG (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |      |               | <p>This field does not exist if the configuration parameter DMAX_CHx_MULTI_BLK_EN is not selected; in that case, the read-back value is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x0 (CONTINUOUS): Contiguous Multiblock Type used for Source Transfer</li> <li>■ 0x1 (RELOAD): Reload Multiblock Type used for Source Transfer</li> <li>■ 0x2 (SHADOW_REGISTER): Shadow Register based Multiblock Type used for Source Transfer</li> <li>■ 0x3 (LINKED_LIST): Linked List based Multiblock Type used for Source Transfer</li> </ul> <p><b>Value After Reset:</b> {(DMAX_CH(x)_MULTI_BLK_TYPE == 0) ? 0 : DMAX_CH(x)_SRC_MULTI_BLK_TYPE}</p> <p><b>Exists:</b> Always</p> |

### 5.2.6 CHx\_CFG2 (for x = 1; x <= DMAX\_NUM\_CHANNELS)

- Description:** This register contains fields that configure the DMA transfer. This register should be programmed prior to enabling the channel.

Bits [63:32] of the channel configuration register remains fixed for all blocks of a multi-block transfer and can be programmed only when channel is disabled.

Bits [3:0] of the channel configuration register can be programmed even when channel is enabled.

Software clears these bits to end the multi-block transfers. For Contiguous-Address and Auto-Reloading-based multi-block transfers (if neither source nor destination peripheral uses Shadow-Register or Linked-List-based multi-block transfers), if the corresponding multi-block type selection bits namely CHx\_CFG.SRC\_MLTBLK\_TYPE and/or CHx\_CFG.DST\_MLTBLK\_TYPE bits are seen to be 2'b00 at the end of a block transfer, the DW\_axi\_dmac understands that the previous block was the final block in the transfer and completes the DMA transfer operation.

- Size:** 64 bits
- Offset:** 0x120 + (x-1)\*0x100
- Exists:** DMAX\_NUM\_CHANNELS >= 1 && (DMAX\_NUM\_CHANNELS > 8 || DMAX\_NUM\_HS\_IF > 16)

|                          |       |
|--------------------------|-------|
| RSVD_DMAC_CHx_CFG_63     | 63    |
| DST_OSR_LMT              | 62:59 |
| SRC_OSR_LMT              | 58:55 |
| LOCK_CH_L                | 54:53 |
| LOCK_CH                  | 52    |
| CH_PRIOR                 | 51:47 |
| RSVD_DMAC_CHx_CFG_39to46 | 46:39 |
| DST_HWHS_POL             | 38    |
| SRC_HWHS_POL             | 37    |
| HS_SEL_DST               | 36    |
| HS_SEL_SRC               | 35    |
| TT_FC                    | 34:32 |
| RSVD_DMAC_CHx_CFG_18to31 | 31:18 |
| RSVD_DMAC_CHx_CFG_17     | 17    |
| RSVD_DMAC_CHx_CFG_16_11  | 16:y  |
| DST_PER                  | x:11  |
| RSVD_DMAC_CHx_CFG_10     | 10    |
| RSVD_DMAC_CHx_CFG_9_4    | 9:y   |
| SRC_PER                  | x:4   |
| DST_MULTBLK_TYPE         | 3:2   |
| SRC_MULTBLK_TYPE         | 1:0   |

Table 5-27 Fields for Register: CHx\_CFG2 (for x = 1; x <= DMAX\_NUM\_CHANNELS)

| Bits | Name                 | Memory Access | Description                                                                                                                                 |
|------|----------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 63   | RSVD_DMAC_CHx_CFG_63 | R             | DMAC Channelx Transfer Configuration Register (63bit)<br>Reserved bit - Read Only<br><b>Value After Reset:</b> 0x0<br><b>Exists:</b> Always |

**Table 5-27 Fields for Register: CHx\_CFG2 (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits  | Name       | Memory Access                                                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|------------|-----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 62:59 | DST_OSRLMT | R/W                                                             | <p>Destination Outstanding Request Limit</p> <ul style="list-style-type: none"> <li>■ Maximum outstanding request supported is 16.</li> <li>■ Source Outstanding Request Limit = DST_OSRLMT + 1</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 58:55 | SRC_OSRLMT | R/W                                                             | <p>Source Outstanding Request Limit</p> <ul style="list-style-type: none"> <li>■ Maximum outstanding request supported is 16.</li> <li>■ Source Outstanding Request Limit = SRC_OSRLMT + 1</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 54:53 | LOCK_CH_L  | $\{(DMA_{CH(x)}\_LOCK\_EN == 1) ? "read-write" : "read-only"\}$ | <p>Channel Lock Level</p> <p>This bit indicates the duration over which CHx_CFG.LOCK_CH bit applies.</p> <ul style="list-style-type: none"> <li>■ 00: Over complete DMA transfer</li> <li>■ 01: Over DMA block transfer</li> <li>■ 1x: Reserved</li> </ul> <p>This field does not exist if the configuration parameter DMAX_CHx_LOCK_EN is set to False; in that case, the read-back value is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x0 (DMA_transfer_CH_LOCK): Duration of the Channel locking is for the entire DMA transfer</li> <li>■ 0x1 (BLOCK_TRANSFER_CH_LOCK): Duration of the Channel locking is for the current block transfer</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> Always</p> |

**Table 5-27 Fields for Register: CHx\_CFG2 (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits  | Name                   | Memory Access                                            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|------------------------|----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 52    | LOCK_CH                | {(DMAX_CH(x)_LOCK_EN == 1) ? "read-write" : "read-only"} | <p>Channel Lock bit<br/>When the channel is granted control of the master bus interface and if the CHx_CFG.LOCK_CH bit is asserted, then no other channels are granted control of the master bus interface for the duration specified in CHx_CFG.LOCK_CH_L. Indicates to the master bus interface arbiter that this channel wants exclusive access to the master bus interface for the duration specified in CHx_CFG.LOCK_CH_L.</p> <p>This field does not exist if the configuration parameter DMAX_CHx_LOCK_EN is set to False; in this case, the read-back value is always 0.</p> <p>Locking the channel locks AXI Read Address, Write Address and Write Data channels on the corresponding master interface.</p> <p><b>Note:</b> Channel locking feature is supported only for memory-to-memory transfer at Block Transfer and DMA Transfer levels. Hardware does not check for the validity of channel locking setting, hence the software must take care of enabling the channel locking only for memory-to-memory transfers at Block Transfer or DMA Transfer levels. Illegal programming of channel locking might result in unpredictable behavior.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x0 (NO_CHANNEL_LOCK): Channel is not locked during the transfers</li> <li>■ 0x0 (CHANNEL_LOCK): Channel is locked and granted exclusive access to the Master Bus Interface</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> |
| 51:47 | CH_PRIOR               | R/W                                                      | <p>Channel Priority<br/>A priority of DMAX_NUM_CHANNELS-1 is the highest priority, and 0 is the lowest. This field must be programmed within the following range:<br/>0: DMAX_NUM_CHANNELS-1<br/>A programmed value outside this range will cause erroneous behavior.</p> <p><b>Value After Reset:</b> (DMAX_NUM_CHANNELS -(x))</p> <p><b>Exists:</b> Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 46:39 | RSVD_DMACHx_CFG_39to46 | R                                                        | <p>DMAC Channelx Transfer Configuration Register (bits 39to46) Reserved bits - Read Only</p> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

**Table 5-27 Fields for Register: CHx\_CFG2 (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name         | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------|--------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 38   | DST_HWHS_POL | R             | <p>Destination Hardware Handshaking Interface Polarity.</p> <ul style="list-style-type: none"> <li>■ 0: ACTIVE HIGH</li> <li>■ 1: ACTIVE LOW</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x0 (ACTIVE_HIGH): Polarity of the Handshaking Interface used for the Destination peripheral is Active High</li> <li>■ 0x1 (ACTIVE_LOW): Polarity of the Handshaking Interface used for the Destination peripheral is Active Low</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> |
| 37   | SRC_HWHS_POL | R             | <p>Source Hardware Handshaking Interface Polarity.</p> <ul style="list-style-type: none"> <li>■ 0: ACTIVE HIGH</li> <li>■ 1: ACTIVE LOW</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x0 (ACTIVE_HIGH): Polarity of the Handshaking Interface used for the Source peripheral is Active High</li> <li>■ 0x1 (ACTIVE_LOW): Polarity of the Handshaking Interface used for the Source peripheral is Active Low</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p>                |

**Table 5-27 Fields for Register: CHx\_CFG2 (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------|------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 36   | HS_SEL_DST | R/W           | <p>Destination Software or Hardware Handshaking Select. This register selects which of the handshaking interfaces (hardware or software) is active for destination requests on this channel.</p> <ul style="list-style-type: none"> <li>■ 0: Hardware handshaking interface. Software-initiated transaction requests are ignored.</li> <li>■ 1: Software handshaking interface. Hardware-initiated transaction requests are ignored.</li> </ul> <p>If the destination peripheral is memory, then this bit is ignored.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x0 (HARDWARE_HS): Hardware Handshaking Interface is used for the Destination peripheral</li> <li>■ 0x1 (SOFTWARE_HS): Software Handshaking Interface is used for the Destination peripheral</li> </ul> <p><b>Value After Reset:</b> 0x1</p> <p><b>Exists:</b> Always</p> |
| 35   | HS_SEL_SRC | R/W           | <p>Source Software or Hardware Handshaking Select. This register selects which of the handshaking interfaces (hardware or software) is active for source requests on this channel.</p> <ul style="list-style-type: none"> <li>■ 0: Hardware handshaking interface. Software-initiated transaction requests are ignored.</li> <li>■ 1: Software handshaking interface. Hardware-initiated transaction requests are ignored.</li> </ul> <p>If the source peripheral is memory, then this bit is ignored.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x0 (HARDWARE_HS): Hardware Handshaking Interface is used for the Source peripheral</li> <li>■ 0x1 (SOFTWARE_HS): Software Handshaking Interface is used for the Source peripheral</li> </ul> <p><b>Value After Reset:</b> 0x1</p> <p><b>Exists:</b> Always</p>                          |

**Table 5-27 Fields for Register: CHx\_CFG2 (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits  | Name                     | Memory Access                                                        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|--------------------------|----------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 34:32 | TT_FC                    | $\{(DMA_{\max\_CH(x)}\_TT\_FC == 8)\}$<br>"read-write" : "read-only" | <p>Transfer Type and Flow Control.<br/>The following transfer types are supported.</p> <ul style="list-style-type: none"> <li>■ Memory to Memory</li> <li>■ Memory to Peripheral</li> <li>■ Peripheral to Memory</li> <li>■ Peripheral to Peripheral</li> </ul> <p>Flow Control can be assigned to the DW_axi_dmac, the source peripheral, or the destination peripheral.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x0 (MEM_TO_MEM_DMPC): Transfer Type is memory to memory and Flow Controller is DW_axi_dmac</li> <li>■ 0x1 (MEM_TO_PER_DMPC): Transfer Type is memory to peripheral and Flow Controller is DW_axi_dmac</li> <li>■ 0x2 (PER_TO_MEM_DMPC): Transfer Type is peripheral to memory and Flow Controller is DW_axi_dmac</li> <li>■ 0x3 (PER_TO_PER_DMPC): Transfer Type is peripheral to peripheral and Flow Controller is DW_axi_dmac</li> <li>■ 0x4 (PER_TO_MEM_SRC): Transfer Type is peripheral to Memory and Flow Controller is Source peripheral</li> <li>■ 0x5 (PER_TO_PER_SRC): Transfer Type is peripheral to peripheral and Flow Controller is Source peripheral</li> <li>■ 0x6 (MEM_TO_PER_DST): Transfer Type is memory to peripheral and Flow Controller is Destination peripheral</li> <li>■ 0x7 (PER_TO_PER_DST): Transfer Type is peripheral to peripheral and Flow Controller is Destination peripheral</li> </ul> <p><b>Value After Reset:</b> <math>\{(DMA_{\max\_CH(x)}\_TT\_FC &lt; 8)\}</math><br/><math>DMA_{\max\_CH(x)}\_TT\_FC : 3\}</math></p> <p><b>Exists:</b> Always</p> |
| 31:18 | RSVD_DMAC_CHx_CFG_18to31 | R                                                                    | <p>DMAC Channelx Transfer Configuration Register (bits 18to31) Reserved bits - Read Only</p> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 17    | RSVD_DMAC_CHx_CFG_17     | R                                                                    | <p>DMAC Channelx Transfer Configuration Register (bit 17) Reserved bit - Read Only</p> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

**Table 5-27 Fields for Register: CHx\_CFG2 (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name                    | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|-------------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16:y | RSVD_DMAC_CHx_CFG_16_11 | R             | DMAC Channelx Transfer Configuration Register (bits (LOG2_DMAX_NUM_HS_IF+11) to 16) Reserved bits - Read Only<br><b>Value After Reset:</b> 0x0<br><b>Exists:</b> Always<br><b>Range Variable[y]:</b> LOG2_DMAX_NUM_HS_IF + 11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| x:11 | DST_PER                 | * Varies      | Assigns a hardware handshaking interface (0 - DMAX_NUM_HS_IF-1) to the destination of Channelx if the CHx_CFG.HS_SEL_DST field is 0; otherwise, this field is ignored. The channel can then communicate with the destination peripheral connected to that interface. <b>Note:</b> For correct DW_axi_dmac operation, only one peripheral (source or destination) should be assigned to the same handshaking interface.<br>This field does not exist if the configuration parameter DMAX_NUM_HS_IF is set to 0.<br>x = 11 if DMAC_NUM_HS_IF is 1<br>x = ceil(log2(DMAC_NUM_HS_IF)) + 10 if DMAC_NUM_HS_IF is greater than 1<br>Bits 16: (x+1) do not exist and return 0 on a read.<br><b>Value After Reset:</b> 0x0<br><b>Exists:</b> Always<br><b>Range Variable[x]:</b> LOG2_DMAX_NUM_HS_IF + 10<br><b>Memory Access:</b> {(DMAX_NUM_HS_IF == 0) ? "read-only" : "read-write"} |
| 10   | RSVD_DMAC_CHx_CFG_10    | R             | DMAC Channelx Transfer Configuration Register (bit 10)<br>Reserved bit - Read Only<br><b>Value After Reset:</b> 0x0<br><b>Exists:</b> Always                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 9:y  | RSVD_DMAC_CHx_CFG_9_4   | R             | DMAC Channelx Transfer Configuration Register (bits (LOG2_DMAX_NUM_HS_IF+4) to 9) Reserved bits - Read Only<br><b>Value After Reset:</b> 0x0<br><b>Exists:</b> Always<br><b>Range Variable[y]:</b> LOG2_DMAX_NUM_HS_IF + 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

**Table 5-27 Fields for Register: CHx\_CFG2 (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name    | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|---------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| x:4  | SRC_PER | * Varies      | <p>Assigns a hardware handshaking interface (0 - DMAX_NUM_HS_IF-1) to the source of Channelx if the CHx_CFG.HS_SEL_SRC field is 0; otherwise, this field is ignored. The channel can then communicate with the source peripheral connected to that interface through the assigned hardware handshaking interface. <b>Note:</b> For correct DW_axi_dmac operation, only one peripheral (source or destination) should be assigned to the same handshaking interface.</p> <p>This field does not exist if the configuration parameter DMAX_NUM_HS_IF is set to 0.</p> <p>x = 4 if DMAC_NUM_HS_IF is 1</p> <p>x = ceil(log2(DMAC_NUM_HS_IF)) + 3 if DMAC_NUM_HS_IF is greater than 1.</p> <p>Bits 9: (x+1) do not exist and return 0 on a read.</p> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Range Variable[x]:</b> LOG2_DMAX_NUM_HS_IF + 3</p> <p><b>Memory Access:</b> {(DMAX_NUM_HS_IF == 0) ? "read-only" : "read-write"}</p> |

**Table 5-27 Fields for Register: CHx\_CFG2 (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name             | Memory Access                                                                                                                                                                       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:2  | DST_MULTBLK_TYPE | {(DMAX_CH(x)_M_ULTI_BL_K_EN == 1) && ((DMAX_CH(x)_M_ULTI_BL_K_TYPE == 0)    (DMAX_CH(x)_M_ULTI_BL_K_TYPE == 1)    (DMAX_CH(x)_M_ULTI_BL_K_TYPE == 4)) ? "read-write" : "read-only"} | <p>Destination Multi Block Transfer Type.<br/>These bits define the type of multi-block transfer used for destination peripheral.</p> <ul style="list-style-type: none"> <li>■ 00: Contiguous</li> <li>■ 01: Reload</li> <li>■ 10: Shadow Register</li> <li>■ 11: Linked List</li> </ul> <p>If the type selected is Contiguous, the CHx_DAR register is loaded with the value of the end source address of previous block + 1 at the end of every block for multi-block transfers. A new block transfer is then initiated.</p> <p>If the type selected is Reload, the CHx_DAR register is reloaded from the initial value of DAR at the end of every block for multi-block transfers. A new block transfer is then initiated.</p> <p>If the type selected is Shadow Register, the CHx_DAR register is loaded from the content of its shadow register if CHx_CTL.ShadowReg_Or_LLI_Valid bit is set to 1 at the end of every block for multi-block transfers. A new block transfer is then initiated.</p> <p>If the type selected is Linked List, the CHx_DAR register is loaded from the Linked List if CTL.ShadowReg_Or_LLI_Valid bit is set to 1 at the end of every block for multi-block transfers. A new block transfer is then initiated.</p> <p>CHx_CTL and CHx_BLOCK_TS registers are loaded from their initial values or from the contents of their shadow registers (if CHx_CTL.ShadowReg_Or_LLI_Valid bit is set to 1) or from the linked list (if CTL.ShadowReg_Or_LLI_Valid bit is set to 1) at the end of every block for multi-block transfers based on the multi-block transfer type programmed for source and destination peripherals.</p> <p>Contiguous transfer on both source and destination peripheral is not a valid multi-block transfer configuration.</p> |

**Table 5-27 Fields for Register: CHx\_CFG2 (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |      |               | <p>This field does not exist if the configuration parameter DMAX_CHx_MULTI_BLK_EN is not selected; in that case, the read-back value is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x0 (CONTINUOUS): Contiguous Multiblock Type used for Destination Transfer</li> <li>■ 0x1 (RELOAD): Reload Multiblock Type used for Destination Transfer</li> <li>■ 0x2 (SHADOW_REGISTER): Shadow Register based Multiblock Type used for Destination Transfer</li> <li>■ 0x3 (LINKED_LIST): Linked List based Multiblock Type used for Destination Transfer</li> </ul> <p><b>Value After Reset:</b> {(DMAX_CH(x)_MULTI_BLK_TYPE == 0) ? 0 : DMAX_CH(x)_DST_MULTI_BLK_TYPE}</p> <p><b>Exists:</b> Always</p> |

**Table 5-27 Fields for Register: CHx\_CFG2 (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name             | Memory Access                                                                                                                                                                                                                                                 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0  | SRC_MULTBLK_TYPE | $\{(DMA_{\_}CH(x)_{\_}M_{\_}ULTI\_BL_{\_}K\_EN == 1) \&\& ((DMA_{\_}CH(x)_{\_}M_{\_}ULTI\_BL_{\_}K\_TYPE == 0)    (DMA_{\_}CH(x)_{\_}M_{\_}ULTI\_BL_{\_}K\_TYPE == 3)    (DMA_{\_}CH(x)_{\_}M_{\_}ULTI\_BL_{\_}K\_TYPE == 4)) ? "read-write" : "read-only"\}$ | <p>Source Multi Block Transfer Type.<br/>These bits define the type of multi-block transfer used for source peripheral.</p> <ul style="list-style-type: none"> <li>■ 00: Contiguous</li> <li>■ 01: Reload</li> <li>■ 10: Shadow Register</li> <li>■ 11: Linked List</li> </ul> <p>If the type selected is Contiguous, the CHx_SAR register is loaded with the value of the end source address of previous block + 1 at the end of every block for multi-block transfers. A new block transfer is then initiated.</p> <p>If the type selected is Reload, the CHx_SAR register is reloaded from the initial value of SAR at the end of every block for multi-block transfers. A new block transfer is then initiated.</p> <p>If the type selected is Shadow Register, the CHx_SAR register is loaded from the content of its shadow register if CHx_CTL.ShadowReg_Or_LLI_Valid bit is set to 1 at the end of every block for multi-block transfers. A new block transfer is then initiated.</p> <p>If the type selected is Linked List, the CHx_SAR register is loaded from the Linked List if CTL.ShadowReg_Or_LLI_Valid bit is set to 1 at the end of every block for multi-block transfers. A new block transfer is then initiated.</p> <p>CHx_CTL and CHx_BLOCK_TS registers are loaded from their initial values or from the contents of their shadow registers (if CHx_CTL.ShadowReg_Or_LLI_Valid bit is set to 1) or from the linked list (if CTL.ShadowReg_Or_LLI_Valid bit is set to 1) at the end of every block for multi-block transfers based on the multi-block transfer type programmed for source and destination peripherals.</p> <p>Contiguous transfer on both source and destination peripheral is not a valid multi-block transfer configuration.</p> |

**Table 5-27 Fields for Register: CHx\_CFG2 (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |      |               | <p>This field does not exist if the configuration parameter DMAX_CHx_MULTI_BLK_EN is not selected; in that case, the read-back value is always 0.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x0 (CONTINUOUS): Contiguous Multiblock Type used for Source Transfer</li> <li>■ 0x1 (RELOAD): Reload Multiblock Type used for Source Transfer</li> <li>■ 0x2 (SHADOW_REGISTER): Shadow Register based Multiblock Type used for Source Transfer</li> <li>■ 0x3 (LINKED_LIST): Linked List based Multiblock Type used for Source Transfer</li> </ul> <p><b>Value After Reset:</b> {(DMAX_CH(x)_MULTI_BLK_TYPE == 0) ? 0 : DMAX_CH(x)_SRC_MULTI_BLK_TYPE}</p> <p><b>Exists:</b> Always</p> |

### 5.2.7 CHx\_LL\_P (for x = 1; x <= DMAX\_NUM\_CHANNELS)

- **Description:** This is the Linked List Pointer register. This register must be programmed to point to the first Linked List Item (LLI) in memory prior to enabling the channel if linked-list-based block chaining is enabled. This register is updated with new value of linked list pointer during the LLI update stage of dma transfer.
- **Size:** 64 bits
- **Offset:**  $0x128 + (x-1)*0x100$
- **Exists:**  $DMAX\_NUM\_CHANNELS \geq x$



**Table 5-28 Fields for Register: CHx\_LL\_P (for x = 1; x <= DMAX\_NUM\_CHANNELS)**

| Bits | Name | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------|------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:6 | LOC  | R/W           | <p>Starting Address Memory of LLI block<br/>Starting Address In Memory of next LLI if block chaining is enabled. The six LSBs of the starting address are not stored because the address is assumed to be aligned to a 64-byte boundary.</p> <p>LLI access always uses the burst size (arsize/awsize) that is same as the data bus width and cannot be changed or programmed to anything other than this. Burst length (awlen/arlen) is chosen based on the data bus width so that the access does not cross one complete LLI structure of 64 bytes. DW_axi_dmac will fetch the entire LLI (40 bytes) in one AXI burst if the burst length is not limited by other settings.</p> <p><b>Value After Reset:</b> 0x0<br/><b>Exists:</b> Always<br/><b>Volatile:</b> true</p> |

**Table 5-28 Fields for Register: CHx\_LL\_P (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name                    | Memory Access                                              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|-------------------------|------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:1  | RSVD_DMAC_CHx_LL_P_1to5 | R                                                          | <p>DMAC Channelx Linked List Pointer Register (bits 1to5)<br/>       Reserved bits - Read Only<br/> <b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> Always<br/> <b>Volatile:</b> true</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 0    | LMS                     | $\{(DMA_{CH(x)}\_LMS == 2) ? "read-write" : "read-only"\}$ | <p>LLI master Select<br/>       This bit identifies the AXI layer/interface where the memory device that stores the next linked list item resides.</p> <ul style="list-style-type: none"> <li>■ 0: AXI Master 1</li> <li>■ 1: AXI Master 2</li> </ul> <p>This field does not exist if the configuration parameter DMAx_CHx_LMS is not set to NO_HARDCODE.<br/>       In this case, the read-back value is always the hardcoded value. The maximum value of this field that can be read back is 'DMAx_NUM_MASTER_IF-1'.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x0 (MASTER1_INTF): next Linked List item resides on AXI Master1 interface</li> <li>■ 0x1 (MASTER2_INTF): next Linked List item resides on AXI Master2 interface</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> Always<br/> <b>Volatile:</b> true</p> |

### 5.2.8 CHx\_STATUSREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)

- **Description:** Channelx Status Register contains fields that indicate the status of DMA transfers for Channelx.
- **Size:** 64 bits
- **Offset:** 0x130 + (x-1)\*0x100
- **Exists:** DMAX\_NUM\_CHANNELS >= x

|                                |       |
|--------------------------------|-------|
| RSVD_DMAC_CHx_STATUSREG_47to63 | 63:47 |
| DATA_LEFT_IN_FIFO              | 46:32 |
| RSVD_DMAC_CHx_STATUSREG_22to31 | 31:22 |
| CMPLTD_BLK_TFR_SIZE            | 21:0  |

Table 5-29 Fields for Register: CHx\_STATUSREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)

| Bits  | Name                           | Memory Access | Description                                                                                                                                                 |
|-------|--------------------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:47 | RSVD_DMAC_CHx_STATUSREG_47to63 | R             | DMAC Channelx Status Register (bits 47to63) Reserved bits<br>- Read Only<br><b>Value After Reset:</b> 0x0<br><b>Exists:</b> Always<br><b>Volatile:</b> true |

**Table 5-29 Fields for Register: CHx\_STATUSREG (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits  | Name                           | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|--------------------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 46:32 | DATA_LEFT_IN_FIFO              | R             | <p>Data Left in FIFO.</p> <p>This bit indicates the total number of data left in DW_axi_dmac channel FIFO after completing the current block transfer.</p> <p>The width of the data in channel FIFO is equal to CHx_CTL.SRC_TR_WIDTH.</p> <p>For normal block transfer completion without errors, Data_Left_In_FIFO = 0.</p> <p>If any error occurs during the dma transfer, the block transfer might be terminated early and in such a case, Data_Left_In_FIFO indicates the data remaining in channel FIFO which could not be transferred to destination peripheral.</p> <p>This field is cleared to zero on enabling the channel.</p> <p><b>Note:</b> If CHx_CTL.DST_TR_WIDTH &gt; CHx_CTL.SRC_TR_WIDTH, there may be residual data left in the FIFO which is not enough to form one CHx_CTL.SRC_TR_WIDTH of data and Data_Left_In_FIFO will return 0 in this case.</p> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p> |
| 31:22 | RSVD_DMAC_CHx_STATUSREG_22to31 | R             | <p>DMAC Channelx Status Register (bits 22to31) Reserved bits</p> <ul style="list-style-type: none"> <li>- Read Only</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 21:0  | CMPLTD_BLK_TFR_SIZE            | R             | <p>Completed Block Transfer Size.</p> <p>This bit indicates the total number of data of width CHx_CTL.SRC_TR_WIDTH transferred for the previous block transfer.</p> <p>For normal block transfer completion without any errors, this value will be equal to the value programmed in BLOCK_TS field of CHx_BLOCK_TS register.</p> <p>If any error occurs during the dma transfer, the block transfer might be terminated early and in such a case, this value indicates the actual data transferred without error in the current block.</p> <p>This field is cleared to zero on enabling the channel.</p> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p>                                                                                                                                                                                                                                                                   |

### 5.2.9 CHx\_SWHSSRCREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)

- **Description:** Channelx Software handshake Source Register.
- **Size:** 64 bits
- **Offset:** 0x138 + (x-1)\*0x100
- **Exists:** DMAX\_NUM\_CHANNELS >= x

| RSVD_DMAC_CHx_SWHSSRCREG_6to63<br>63:6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----------------------------------------|---|---|---|---|---|---|
| SWHS_LST_SRC_WE                        |   |   |   |   |   |   |
| SWHS_LST_SRC                           |   |   |   |   |   |   |
| SWHS_SGLREQ_SRC_WE                     |   |   |   |   |   |   |
| SWHS_SGLREQ_SRC                        |   |   |   |   |   |   |
| SWHS_REQ_SRC_WE                        |   |   |   |   |   |   |
| SWHS_REQ_SRC                           |   |   |   |   |   |   |

Table 5-30 Fields for Register: CHx\_SWHSSRCREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)

| Bits | Name                           | Memory Access | Description                                                                                                                                                                                   |
|------|--------------------------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:6 | RSVD_DMAC_CHx_SWHSSRCREG_6to63 | R             | <p>DMAC Channelx Software Handshake Source Register (bits 6to63) Reserved bits - Read Only</p> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p> |

**Table 5-30 Fields for Register: CHx\_SWHSSRCREG (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name            | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|-----------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5    | SWHS_LST_SRC_WE | W             | <p>Write Enable bit for Software Handshake Last Request for Channel Source.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_SWHS_LAST_SRC): Enables write to the SWHS_LAST_SRC bit</li> <li>■ 0x0 (DISABLE_SWHS_LAST_SRC): Disables write to the SWHS_LAST_SRC bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 4    | SWHS_LST_SRC    | R/W           | <p>Software Handshake Last Request for Channel Source. This bit is used to request LAST dma source data transfer if software handshaking method is selected for the source of the corresponding channel.</p> <p>This bit is ignored if software handshaking is not enabled for the source of the Channelx or if the source of Channelx is not the flow controller.</p> <p>CHx_SWHSSrcReg.SWHS_Req_Src bit must be set to 1 for DW_axi_dmac to treat it as a valid software handshaking request.</p> <p>If CHx_SWHSSrcReg.SWHS_SglReq_Src is set to 1, the LAST request is for SINGLE dma transaction (AXI burst length = 1), else the request is treated as a BURST transaction request.</p> <p>DW_axi_dmac clears this bit to 0 once software reads CHx_SWHSSrcReg.SWHS_Ack_Src bit and sees it as 1. Software can only set this bit to 1; it is not allowed to clear this bit to 0; only DW_axi_dmac can clear this bit.</p> <p><b>Note:</b> SWHS_Lst_Src bit is written only if the corresponding write enable bit, SWHS_Lst_Src_WE is asserted on the same register write operation and if the Channelx is enabled in the DMAC_ChEnReg register. This allows software to set a bit in the CHx_SWHSSrcReg register without performing a read-modified write operation.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE_SWHS_LAST_SRC): Source peripheral indication to dmac that the current transfer is the last transfer</li> <li>■ 0x0 (INACTIVE_SWHS_LAST_SRC): Source peripheral indication that the current transfer is not the last transfer</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p> |

**Table 5-30 Fields for Register: CHx\_SWHSSRCREG (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name               | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|--------------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3    | SWHS_SGLREQ_SRC_WE | W             | <p>Write Enable bit for Software Handshake Single Request for Channel Source.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_SWHS_SGLREQ_SRC): Enables write to the SWHS_SGLREQ_SRC bit</li> <li>■ 0x0 (DISABLE_SWHS_SGLREQ_SRC): Disables write to the SWHS_SGLREQ_SRC bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 2    | SWHS_SGLREQ_SRC    | R/W           | <p>Software Handshake Single Request for Channel Source. This bit is used to request SINGLE (AXI burst length = 1) dma source data transfer if software handshaking method is selected for the source of the corresponding channel. This bit is ignored if software handshaking is not enabled for the source of the Channelx. The functionality of this field depends on whether the peripheral is the flow controller. DW_axi_dmac clears this bit to 0 once software reads CHx_SWHSSrcReg.SWHS_Ack_Src bit and sees it as 1. Software can only set this bit to 1; it is not allowed to clear this bit to 0; only DW_axi_dmac can clear this bit.</p> <p><b>Note:</b> SWHS_SglReq_Src bit is written only if the corresponding write enable bit, SWHS_SglReq_Src_WE is asserted on the same register write operation and if the Channelx is enabled in the DMAC_ChEnReg register. This allows software to set a bit in the CHx_SWHSSrcReg register without performing a read-modified write operation.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE_SWHS_SGLREQ_SRC): Source peripheral request for a single dma transfer</li> <li>■ 0x0 (INACTIVE_SWHS_SGLREQ_SRC): Source peripheral is not requesting for a single transfer</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p> |

**Table 5-30 Fields for Register: CHx\_SWHSSRCREG (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name            | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|-----------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1    | SWHS_REQ_SRC_WE | W             | <p>Write Enable bit for Software Handshake Request for Channel Source.</p> <p><b>Note:</b> This bit always returns 0 on a read back.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_SWHS_REQ_SRC): Enables write to the SWHS_REQ_SRC bit</li> <li>■ 0x0 (DISABLE_SWHS_REQ_SRC): Disables write to the SWHS_REQ_SRC bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 0    | SWHS_REQ_SRC    | R/W           | <p>Software Handshake Request for Channel Source. This bit is used to request dma source data transfer if software handshaking method is selected for the source of the corresponding channel.</p> <p>This bit is ignored if software handshaking is not enabled for the source of the Channelx. The functionality of this field depends on whether the peripheral is the flow controller or not.</p> <p>DW_axi_dmac clears this bit to 0 once software reads CHx_SWHSSrcReg.SWHS_Ack_Src bit and sees it as 1. Software can only set this bit to 1; it is not allowed to clear this bit to 0; only DW_axi_dmac can clear this bit.</p> <p><b>Note:</b> SWHS_Req_Src bit is written only if the corresponding write enable bit, SWHS_Req_Src_WE is asserted on the same register write operation and if the Channelx is enabled in the DMAC_ChEnReg register. This allows software to set a bit in the CHx_SWHSSrcReg register without performing a read-modified write operation.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE_SWHS_REQ_SRC): Source peripheral request for a dma transfer</li> <li>■ 0x0 (INACTIVE_SWHS_REQ_SRC): Source peripheral is not requesting for a burst transfer</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p> |

### 5.2.10 CHx\_SWHSDSTREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)

- **Description:** Channelx Software handshake Destination Register.
- **Size:** 64 bits
- **Offset:** 0x140 + (x-1)\*0x100
- **Exists:** DMAX\_NUM\_CHANNELS >= x



Table 5-31 Fields for Register: CHx\_SWHSDSTREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)

| Bits | Name                           | Memory Access | Description                                                                                                                                                                     |
|------|--------------------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:6 | RSVD_DMAC_CHx_SWHSDSTREG_6to63 | R             | DMAC Channelx Software Handshake Destination Register (bits 6to63) Reserved bits - Read Only<br><b>Value After Reset:</b> 0x0<br><b>Exists:</b> Always<br><b>Volatile:</b> true |

**Table 5-31 Fields for Register: CHx\_SWHSDSTREG (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name            | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|-----------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5    | SWHS_LST_DST_WE | W             | <p>Write Enable bit for Software Handshake Last Request for Channel Destination.</p> <p><b>Note:</b> This bit always returns 0 on a read back.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_SWHS_LAST_DST): Enables write to the SWHS_LAST_DST bit</li> <li>■ 0x0 (DISABLE_SWHS_LAST_DST): Disables write to the SWHS_LAST_DST bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p> |

**Table 5-31 Fields for Register: CHx\_SWHSDSTREG (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name         | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------|--------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4    | SWHS_LST_DST | R/W           | <p>Software Handshake Last Request for Channel Destination. This bit is used to request LAST dma destination data transfer if software handshaking method is selected for the destination of the corresponding channel.</p> <p>This bit is ignored if software handshaking is not enabled for the destination of the Channelx or if the destination of Channelx is not the flow controller.</p> <p>CHx_SWHSDstReg.SWHS_Req_Dst bit must be set to 1 for DW_axi_dmac to treat it as a valid software handshaking request.</p> <p>If CHx_SWHSDstReg.SWHS_SglReq_Dst is set to 1, the LAST request is for SINGLE dma transaction (AXI burst length = 1), else the request is treated as a BURST transaction request.</p> <p>DW_axi_dmac clears this bit to 0 once software reads CHx_SWHSDstReg.SWHS_Ack_Dst bit and sets it as 1. Software can only set this bit to 1; it is not allowed to clear this bit to 0; only DW_axi_dmac can clear this bit.</p> <p><b>Note:</b> SWHS_Lst_Src bit is written only if the corresponding write enable bit, SWHS_Lst_Src_WE is asserted on the same register write operation and if the Channelx is enabled in the DMAC_ChEnReg register. This allows software to set a bit in the CHx_SWHSDstReg register without performing a read-modified write operation.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE_SWHS_LAST_DST): Destination peripheral indication to dmac that the current transfer is the last transfer</li> <li>■ 0x0 (INACTIVE_SWHS_LAST_DST): Destination peripheral indication that the current transfer is not the last transfer</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p> |

**Table 5-31 Fields for Register: CHx\_SWHSDSTREG (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name               | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|--------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3    | SWHS_SGLREQ_DST_WE | W             | <p>Write Enable bit for Software Handshake Single Request for Channel Destination.</p> <p><b>Note:</b> This bit always returns 0 on a read block.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_SWHS_SGLREQ_DST): Enables write to the SWHS_SGLREQ_DST bit</li> <li>■ 0x0 (DISABLE_SWHS_SGLREQ_DST): Disables write to the SWHS_SGLREQ_DST bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 2    | SWHS_SGLREQ_DST    | R/W           | <p>Software Handshake Single Request for Channel Destination.</p> <p>This bit is used to request SINGLE (AXI burst length = 1) dma destination data transfer if software handshaking method is selected for the destination of the corresponding channel.</p> <p>This bit is ignored if software handshaking is not enabled for the destination of the Channelx. The functionality of this field depends on whether the peripheral is the flow controller.</p> <p>DW_axi_dmac clears this bit to 0 once software reads CHx_SWHSDstReg.SWHS_Ack_Dst bit and sees it as 1. Software can only set this bit to 1; it is not allowed to clear this bit to 0; only DW_axi_dmac can clear this bit.</p> <p><b>Note:</b> SWHS_SglReq_Dst bit is written only if the corresponding write enable bit, SWHS_SglReq_Dst_WE is asserted on the same register write operation and if the Channelx is enabled in the DMAC_ChEnReg register. This allows software to set a bit in the CHx_SWHSDstReg register without performing a read-modified write operation.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE_SWHS_SGLREQ_DST): Destination peripheral request for a single dma transfer</li> <li>■ 0x0 (INACTIVE_SWHS_SGLREQ_DST): Destination peripheral is not requesting for a single transfer</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p> |

**Table 5-31 Fields for Register: CHx\_SWHSDSTREG (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name            | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|-----------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1    | SWHS_REQ_DST_WE | W             | <p>Write Enable bit for Software Handshake Request for Channel Destination.</p> <p><b>Note:</b> This bit always returns 0 on a read block.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_SWHS_REQ_DST): Enables write to the SWHS_REQ_DST bit</li> <li>■ 0x0 (DISABLE_SWHS_REQ_DST): Disables write to the SWHS_REQ_DST bit</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0    | SWHS_REQ_DST    | R/W           | <p>Software Handshake Request for Channel Destination. This bit is used to request dma destination data transfer if software handshaking method is selected for the destination of the corresponding channel.</p> <p>This bit is ignored if software handshaking is not enabled for the source of the Channelx. The functionality of this field depends on whether the peripheral is the flow controller. DW_axi_dmac clears this bit to 0 once software reads CHx_SWHSDstReg.SWHS_Ack_Dst bit and sees it as 1. Software can only set this bit to 1; it is not allowed to clear this bit to 0; only DW_axi_dmac can clear this bit.</p> <p><b>Note:</b> SWHS_Req_Dst bit is written only if the corresponding write enable bit, SWHS_Req_Dst_WE is asserted on the same register write operation and if the Channelx is enabled in the DMAC_ChEnReg register. This allows software to set a bit in the CHx_SWHSDstReg register without performing a read-modified write operation.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE_SWHS_REQ_DST): Destination peripheral request for a dma transfer</li> <li>■ 0x0 (INACTIVE_SWHS_REQ_DST): Destination peripheral is not requesting for a burst transfer</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p> |

### 5.2.11 CHx\_BLK\_TFR\_RESUMEREQREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)

- **Description:** Channelx Block Transfer Resume Request Register. This register is used during Linked List or Shadow Register based multi-block transfer.
  - For Linked-List-based multi-block transfer, ShadowReg\_Or\_LLI\_Valid bit in LLI.CHx\_CTL indicates whether the linked list item fetched from the memory is valid (0: LLI is invalid, 1: LLI is valid). On noticing this bit as 0, DW\_axi\_dmac discards the LLI and generates ShadowReg\_Or\_LLI\_Invalid\_ERR Interrupt if the corresponding channel error interrupt mask bit is set to 0. This error condition causes the DW\_axi\_dmac to halt the corresponding channel gracefully. DW\_axi\_dmac waits till software writes (any value) to CHx\_BLK\_TFR\_ResumeReqReg to indicate valid LLI availability, before attempting another LLI read operation.
  - For Shadow-Register-based multi-block transfer, ShadowReg\_Or\_LLI\_Valid bit in CHx\_CTL register indicates whether the shadow register contents are valid (0: Shadow Register contents are invalid, 1: Shadow Register contents are valid). On noticing this bit as 0 during shadow register fetch phase, DW\_axi\_dmac discards the Shadow Register contents and generates ShadowReg\_Or\_LLI\_Invalid\_ERR Interrupt. DW\_axi\_dmac waits till software writes (any value) to CHx\_BLK\_TFR\_ResumeReqReg to indicate valid shadow register availability, before attempting another shadow register fetch operation and continue the next block transfer.
- **Size:** 64 bits
- **Offset:** 0x148 + (x-1)\*0x100
- **Exists:** DMAX\_NUM\_CHANNELS >= x

|                                          |      |   |
|------------------------------------------|------|---|
| RSVD_DMAC_CHx_BLK_TFR_RESUMEREQREG_1to63 | 63:1 | 0 |
| BLK_TFR_RESUMEREQ                        |      |   |

**Table 5-32 Fields for Register: CHx\_BLK\_TFR\_RESUMEREQREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)**

| <b>Bits</b> | <b>Name</b>                               | <b>Memory Access</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                              |
|-------------|-------------------------------------------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:1        | RSVD_DMACHx_BLK_TFR_REG_ESUMEREQREG_1to63 | W                    | <p>DMAC Channelx Block Transfer Resume Request Register<br/>(bits 1to63) Reserved bits - Read Only</p> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p>                                                                                                                                                                                                                                        |
| 0           | BLK_TFR_RESUMEREQ                         | W                    | <p>Block Transfer Resume Request during Linked-List or Shadow-Register-based multi-block transfer.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x0 (INACTIVE_BLK_TFR_RESUMEREQ): No request to resume the block transfer</li> <li>■ 0x1 (ACTIVE_BLK_TFR_RESUMEREQ): Request for resuming the block transfer</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> |

### 5.2.12 CHx\_AXI\_IDREG (for x = 1; x <= DMAC\_NUM\_CHANNELS)

- **Description:** Channelx AXI ID Register. This register is allowed to be updated only when the channel is disabled, which means that it remains fixed for the entire DMA transfer.

**Note:** The presence of this register is determined by the DMAC\_M\_ID\_WIDTH and DMAC\_NUM\_CHANNELS configuration parameters.

- If LLI is enabled for any of the channel, then the register is present only when:

$$\text{DMAX\_M\_ID\_WIDTH} - (\log_2(\text{DMAC\_NUM\_CHANNELS}) + 1) > 0$$

- Otherwise:

$$\text{DMAX\_M\_ID\_WIDTH} - \log_2(\text{DMAC\_NUM\_CHANNELS}) > 0$$

- **Size:** 64 bits
- **Offset:**  $0x150 + (x-1)*0x100$
- **Exists:**  $(\text{DMAX\_NUM\_CHANNELS} \geq x) \&\& (\text{DMAX\_AXI\_ID\_SUFFIX\_WIDTH} \neq 0)$

|                                         |       |
|-----------------------------------------|-------|
| RSVD_DMAC_CHx_AXI_IDREG_32to63          | 63:32 |
| RSVD_DMAC_CHx_AXI_IDREG_IDW_L2NCm32to63 | 31:y  |
| AXI_WRITE_ID_SUFFIX                     | x:16  |
| RSVD_DMAC_CHx_AXI_IDREG_IDW_L2NCm1to31  | 15:y  |
| AXI_READ_ID_SUFFIX                      | x:0   |

**Table 5-33 Fields for Register: CHx\_AXI\_IDREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)**

| <b>Bits</b> | <b>Name</b>                             | <b>Memory Access</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------------|-----------------------------------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:32       | RSVD_DMAC_CHx_AXI_IDREG_32to63          | R                    | DMAC Channelx AXI ID Register (bits 32to63) Reserved bits<br>- Read Only<br><b>Value After Reset:</b> 0x0<br><b>Exists:</b> Always                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 31:y        | RSVD_DMAC_CHx_AXI_IDREG_IDW_L2NCm32to63 | R                    | DMAC Channelx AXI ID Register (bits (IDW-L2NC-1)to32)<br>Reserved bits - Read Only<br><b>Value After Reset:</b> 0x0<br><b>Exists:</b> Always<br><b>Range Variable[y]:</b> DMAX_AXI_ID_SUFFIX_WIDTH + 16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| x:16        | AXI_WRITE_ID_SUFFIX                     | R/W                  | AXI Write ID Suffix.<br>These bits form part of the AWID output of AXI3/AXI4 master interface.<br>IDW = DMAX_M_ID_WIDTH<br>L2NC = log2(DMAX_NUM_CHANNELS)<br>The upper L2NC+1 bits of awidN is derived from the channel number which is currently accessing the master interface.<br>This varies for LLI fetch and source data transfer.<br>For source data transfer, awidN for channel1 4'b0000, awidN for channel8 4'b0111 and so on.<br>For LLI fetch access, awidN for channel1 4'b1000, awidN for channel8 4'b1111 and so on.<br>Lower bits are same as the value programmed in CHx_AXI_IDReg.AXI_Write_ID_Suffix field.<br><b>Value After Reset:</b> 0x0<br><b>Exists:</b> Always<br><b>Range Variable[x]:</b> DMAX_AXI_ID_SUFFIX_WIDTH + 15 |
| 15:y        | RSVD_DMAC_CHx_AXI_IDREG_IDW_L2NCm1to31  | R                    | DMAC Channelx AXI ID Register (bits (IDW-L2NC-1)to31)<br>Reserved bits - Read Only<br><b>Value After Reset:</b> 0x0<br><b>Exists:</b> Always<br><b>Range Variable[y]:</b> DMAX_AXI_ID_SUFFIX_WIDTH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

**Table 5-33 Fields for Register: CHx\_AXI\_IDREG (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name               | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------|--------------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| x:0  | AXI_READ_ID_SUFFIX | R/W           | <p>AXI Read ID Suffix<br/>These bits form part of the ARID output of AXI3/AXI4 master interface.</p> $\text{IDW} = \text{DMAX\_M\_ID\_WIDTH}$ $\text{L2NC} = \log_2(\text{DMAX\_NUM\_CHANNELS})$ <p>The upper L2NC+1 bits of aridN is derived from the channel number which is currently accessing the master interface. This varies for LLI fetch and source data transfer.</p> <p>For source data transfer, aridN for channel1 4'b0000, aridN for channel8 4'b0111 and so on.</p> <p>For LLI fetch access, aridN for channel1 4'b1000, aridN for channel8 4'b1111 and so on. Lower bits are same as the value programmed in CHx_AXI_IDReg.AXI_Read_ID_Suffix field.</p> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Range Variable[x]:</b> DMAX_AXI_ID_SUFFIX_WIDTH - 1</p> |

### 5.2.13 CHx\_AXI\_QOSREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)

- **Description:** Channelx AXI QOS Register. This register is allowed to be updated only when the channel is disabled, which means that it remains fixed for the entire DMA transfer.
- **Size:** 64 bits
- **Offset:** 0x158 + (x-1)\*0x100
- **Exists:** DMAX\_NUM\_CHANNELS >= x



**Table 5-34 Fields for Register: CHx\_AXI\_QOSREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)**

| Bits | Name                           | Memory Access | Description                                                                                                                                                                                                    |
|------|--------------------------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:8 | RSVD_DMAC_CHx_AXI_QOSREG_8to63 | R             | DMAC Channelx AXI QOS Register (bits 8to63) Reserved bits - Read Only<br><b>Value After Reset:</b> 0x0<br><b>Exists:</b> Always                                                                                |
| 7:4  | AXI_ARQOS                      | * Varies      | AXI ARQOS.<br>These bits form the arqos output of AXI4 master interface.<br><b>Value After Reset:</b> 0x0<br><b>Exists:</b> Always<br><b>Memory Access:</b> {(DMAX_HAS_QOS == 1) ? "read-write" : "read-only"} |

**Table 5-34 Fields for Register: CHx\_AXI\_QOSREG (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| <b>Bits</b> | <b>Name</b> | <b>Memory Access</b> | <b>Description</b>                                                                                                                                                                                                                 |
|-------------|-------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0         | AXI_AWQOS   | * Varies             | <p>AXI AWQOS.<br/>These bits form the awqos output of AXI4 master interface.</p> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Memory Access:</b> {(DMAX_HAS_QOS == 1) ? "read-write" : "read-only"}</p> |

### 5.2.14 CHx\_SSTAT (for x = 1; x <= DMAX\_NUM\_CHANNELS)

- Description:** Channelx Source Status Register. After each block transfer completes, hardware can retrieve the source status information from the address pointed to by the contents of the CHx\_SSTATAR register. This status information is then stored in the CHx\_SSTAT register and written out to the CHx\_SSTAT register location of the LLI before the start of the next block.
- Source status write-back to the CHx\_SSTAT register location of the LLI is performed only if DMAX\_CHx\_LLI\_WB\_EN = 1 and linked-list-based multi-block transfer is enabled for either source or destination peripheral of the channel.

This register does not exist if DMAC\_CHx\_SRC\_STAT\_EN is set to False; in this case, the read-back value is always 0.

- Size:** 64 bits
- Offset:** 0x160 + (x-1)\*0x100
- Exists:** (DMAX\_NUM\_CHANNELS >= x) && (DMAX\_CH1\_SRC\_STAT\_EN == 1)



Table 5-35 Fields for Register: CHx\_SSTAT (for x = 1; x <= DMAX\_NUM\_CHANNELS)

| Bits  | Name                       | Memory Access | Description                                                                                                                               |
|-------|----------------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 63:32 | RSVD_DMAC_CHx_SSTAT_32to63 | R             | DMAC Channelx Source Status Register (bits 32to63)<br>Reserved bits - Read Only<br><b>Value After Reset:</b> 0x0<br><b>Exists:</b> Always |

**Table 5-35 Fields for Register: CHx\_SSTAT (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| <b>Bits</b> | <b>Name</b> | <b>Memory Access</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------------|-------------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0        | SSTAT       | R                    | <p>Source Status<br/>Source status information retrieved by hardware from the address pointed to by the contents of the CHx_SSTATAR register.</p> <p>Source peripheral should update the source status information, if any, at the location pointed to by CHx_SSTATAR to utilize this feature. This status is not related to any internal status of DW_axi_dmac.</p> <p>This status is not related to any internal status of DW_axi_dmac.</p> <p><b>Value After Reset:</b> 0x0<br/><b>Exists:</b> Always</p> |

### 5.2.15 CHx\_DSTAT (for x = 1; x <= DMAX\_NUM\_CHANNELS)

- Description:** Channelx Destination Status Register. After each block transfer completes, hardware can retrieve the destination status information from the address pointed to by the contents of the CHx\_DSTATAR register. This status information is then stored in the CHx\_DSTAT register and written out to the CHx\_DSTAT register location of the LLI before the start of the next block. Destination status write-back to the CHx\_DSTAT register location of the LLI is performed only if DMAX\_CHx\_LLI\_WB\_EN = 1 and linked list based multi-block transfer is enabled for either source or destination peripheral of the channel.
- Size:** 64 bits
- Offset:** 0x168 + (x-1)\*0x100
- Exists:** (DMAX\_NUM\_CHANNELS >= x) && (DMAX\_CH1\_DST\_STAT\_EN == 1)



Table 5-36 Fields for Register: CHx\_DSTAT (for x = 1; x <= DMAX\_NUM\_CHANNELS)

| Bits  | Name                       | Memory Access | Description                                                                                                                                    |
|-------|----------------------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:32 | RSVD_DMAC_CHx_DSTAT_32to63 | R             | DMAC Channelx Destination Status Register (bits 32to63)<br>Reserved bits - Read Only<br><b>Value After Reset:</b> 0x0<br><b>Exists:</b> Always |

**Table 5-36 Fields for Register: CHx\_DSTAT (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name  | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|-------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | DSTAT | R             | <p>Destination Status<br/>Destination status information retrieved by hardware from the address pointed to by the contents of the CHx_DSTATAR register.</p> <p>Destination peripheral should update the destination status information, if any, at the location pointed to by CHx_DSTATAR to utilize this feature.</p> <p>This status is not related to any internal status of DW_axi_dmac.</p> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> |

### 5.2.16 CHx\_SSTATAR (for x = 1; x <= DMAX\_NUM\_CHANNELS)

- Description:** Channelx Source Status Fetch Register. After completion of each block transfer, hardware can retrieve the source status information from the user-defined address to which the contents of the CHx\_SSTATAR register point. You can select any location in system memory that provides a 64-bit value to indicate the status of the source transfer.

This register does not exist if DMAC\_CHx\_SRC\_STAT\_EN is set to False; in this case, the read-back value is always 0.

- Size:** 64 bits
- Offset:**  $0x170 + (x-1)*0x100$
- Exists:**  $(DMAX\_NUM\_CHANNELS \geq x) \&& (DMAX\_CH1\_SRC\_STAT\_EN == 1)$



Table 5-37 Fields for Register: CHx\_SSTATAR (for x = 1; x <= DMAX\_NUM\_CHANNELS)

| Bits | Name    | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|---------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:0 | SSTATAR | R/W           | <p>Source Status Fetch Address</p> <p>Pointer from where hardware can fetch the source status information, which is registered in the CHx_SSTAT register and written out to the CHx_SSTAT register location of the LLI before the start of the next block if DMAX_CHx_LLI_WB_EN = 1 and linked list based multi-block transfer is enabled for either source or destination peripheral of the channel.</p> <p>Source peripheral should update the source status information, if any, at the location pointed to by CHx_SSTATAR to utilize this feature.</p> <p>This status is not related to any internal status of DW_axi_dmac.</p> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> |

### 5.2.17 CHx\_DSTATAR (for x = 1; x <= DMAX\_NUM\_CHANNELS)

- Description:** Channelx Destination Status Fetch Register. After completion of each block transfer, hardware can retrieve the destination status information from the user-defined address to which the contents of the CHx\_DSTATAR register points. You can select any location in system memory that would provide a 64-bit value to indicate the status of the destination transfer.

This register does not exist if DMAC\_CHx\_SRC\_STAT\_EN is set to False; in this case, the read-back value is always 0.

- Size:** 64 bits
- Offset:**  $0x178 + (x-1)*0x100$
- Exists:**  $(DMAX\_NUM\_CHANNELS \geq x) \&\& (DMAX\_CH1\_DST\_STAT\_EN == 1)$



Table 5-38 Fields for Register: CHx\_DSTATAR (for x = 1; x <= DMAX\_NUM\_CHANNELS)

| Bits | Name    | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|---------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:0 | DSTATAR | R/W           | <p>Destination Status Fetch Address<br/>Pointer from where hardware can fetch the Destination status information, which is registered in the CHx_DSTAT register and written out to the CHx_DSTAT register location of the LLI before the start of the next block if DMAX_CHx_LLI_WB_EN = 1 and linked list based multi-block transfer is enabled for either source or destination peripheral of the channel.</p> <p>Destination peripheral should update the destination status information, if any, at the location pointed to by CHx_DSTATAR to utilize this feature.</p> <p>This status is not related to any internal status of DW_axi_dmac.</p> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> |

### 5.2.18 CHx\_INTSTATUS\_ENABLEREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)

- **Description:** Writing 1 to specific field enables the corresponding interrupt status generation in Channelx Interrupt Status Register(CH1\_IntStatusReg).
- **Size:** 64 bits
- **Offset:** 0x180 + (x-1)\*0x100
- **Exists:** DMAX\_NUM\_CHANNELS >= 1

|                                               |       |
|-----------------------------------------------|-------|
| RSVD_DMAC_CHx_INTSTATUS_ENABLEREG_32to63      | 63:32 |
| Enable_CH_ABORTED_IntStat                     | 31    |
| Enable_CH_DISABLED_IntStat                    | 30    |
| Enable_CH_SUSPENDED_IntStat                   | 29    |
| Enable_CH_SRC_SUSPENDED_IntStat               | 28    |
| Enable_CH_LOCK_CLEARED_IntStat                | 27    |
| RSVD_DMAC_CHx_INTSTATUS_ENABLEREG_22to26      | 26:22 |
| Enable_SLVIF_WRONHOLD_ERR_IntStat             | 21    |
| Enable_SLVIF_SHADOWREG_WRON_VALID_ERR_IntStat | 20    |
| Enable_SLVIF_WRONCHEN_ERR_IntStat             | 19    |
| Enable_SLVIF_RD2RW0_ERR_IntStat               | 18    |
| Enable_SLVIF_WR2R0_ERR_IntStat                | 17    |
| Enable_SLVIF_DEC_ERR_IntStat                  | 16    |
| RSVD_DMAC_CHx_INTSTATUS_ENABLEREG_15          | 15    |
| Enable_SLVIF_MULTIBLKTYPE_ERR_IntStat         | 14    |
| Enable_SHADOWREG_OR_LLI_INVALID_ERR_IntStat   | 13    |
| Enable_LLI_WR_SLV_ERR_IntStat                 | 12    |
| Enable_LLI_RD_SLV_ERR_IntStat                 | 11    |
| Enable_LLI_WR_DEC_ERR_IntStat                 | 10    |
| Enable_LLI_RD_DEC_ERR_IntStat                 | 9     |
| Enable_DST_SLV_ERR_IntStat                    | 8     |
| Enable_SRC_SLV_ERR_IntStat                    | 7     |
| Enable_DST_DEC_ERR_IntStat                    | 6     |
| Enable_SRC_DEC_ERR_IntStat                    | 5     |
| Enable_DST_TRANSCOMP_IntStat                  | 4     |
| Enable_SRC_TRANSCOMP_IntStat                  | 3     |
| RSVD_DMAC_CHx_INTSTATUS_ENABLEREG_2           | 2     |
| Enable_DMA_TFR_DONE_IntStat                   | 1     |
| Enable_BLOCK_TFR_DONE_IntStat                 | 0     |

Table 5-39 Fields for Register: CHx\_INTSTATUS\_ENABLEREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)

| Bits  | Name                                     | Memory Access | Description                                                                                                                                         |
|-------|------------------------------------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:32 | RSVD_DMAC_CHx_INTSTATUS_ENABLEREG_32to63 | R             | DMAC Channelx Interrupt Status Register (bits 32to63)<br>Reserved bits - Read Only<br><b>Value After Reset:</b> 0xffffffff<br><b>Exists:</b> Always |

**Table 5-39 Fields for Register: CHx\_INTSTATUS\_ENABLEREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)**

| Bits | Name                       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------|----------------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | Enable_CH_ABORTED_IntStat  | R/W           | <p>Channel Aborted Status Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the generation of Channel Aborted Interrupt in CHx_INTSTATUSREG</li> <li>■ 1: Enable the generation of Channel Aborted Interrupt in CHx_INTSTATUSREG</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH_ABORTED): Enable the generation of Channel Aborted Interrupt in CH1_INTSTATUSREG</li> <li>■ 0x0 (DISABLE_CH_ABORTED): Disable the generation of Channel Aborted Interrupt in CH1_INTSTATUSREG</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p>        |
| 30   | Enable_CH_DISABLED_IntStat | R/W           | <p>Channel Disabled Status Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the generation of Channel Disabled Interrupt in CHx_INTSTATUSREG</li> <li>■ 1: Enable the generation of Channel Disabled Interrupt in CHx_INTSTATUSREG</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH_DISABLED): Enable the generation of Channel Disabled Interrupt in CH1_INTSTATUSREG</li> <li>■ 0x0 (DISABLE_CH_DISABLED): Disable the generation of Channel Disabled Interrupt in CH1_INTSTATUSREG</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p> |

**Table 5-39 Fields for Register: CHx\_INTSTATUS\_ENABLEREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)**

| Bits | Name                            | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------|---------------------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29   | Enable_CH_SUSPENDED_IntStat     | R/W           | <p>Channel Suspended Status Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the generation of Channel Suspended Interrupt in CHx_INTSTATUSREG</li> <li>■ 1: Enable the generation of Channel Suspended Interrupt in CHx_INTSTATUSREG</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH_SUSPENDED): Enable the generation of Channel Suspended Interrupt in CH1_INTSTATUSREG</li> <li>■ 0x0 (DISABLE_CH_SUSPENDED): Disable the generation of Channel Suspended Interrupt in CH1_INTSTATUSREG</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p>                                            |
| 28   | Enable_CH_SRC_SUSPENDED_IntStat | R/W           | <p>Channel Source Suspended Status Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the generation of Channel Source Suspended Interrupt in CHx_INTSTATUSREG</li> <li>■ 1: Enable the generation of Channel Source Suspended Interrupt in CHx_INTSTATUSREG</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH_SRC_SUSPENDED): Enable the generation of Channel Source Suspended Interrupt in CH1_INTSTATUSREG</li> <li>■ 0x0 (DISABLE_CH_SRC_SUSPENDED): Disable the generation of Channel Source Suspended Interrupt in CH1_INTSTATUSREG</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p> |

**Table 5-39 Fields for Register: CHx\_INTSTATUS\_ENABLEREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)**

| Bits  | Name                                     | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|------------------------------------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27    | Enable_CH_LOCK_CLEARED_InterruptStat     | R/W           | <p>Channel Lock Cleared Status Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the generation of Channel LOCK CLEARED Interrupt in CHx_INTSTATUSREG</li> <li>■ 1: Enable the generation of Channel LOCK CLEARED Interrupt in CHx_INTSTATUSREG</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH_LOCK_CLEARED): Enable the generation of Channel LOCK CLEARED Interrupt in CH1_INTSTATUSREG</li> <li>■ 0x0 (DISABLE_CH_LOCK_CLEARED): Disable the generation of Channel LOCK CLEARED Interrupt in CH1_INTSTATUSREG</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p>                                                                                  |
| 26:22 | RSVD_DMAC_CHx_INTSTATUS_ENABLEREG_22to26 | R             | <p>DMAC Channelx Interrupt Status Register (bits 22to26)<br/>     Reserved bits - Read Only</p> <p><b>Value After Reset:</b> 0x1f<br/> <b>Exists:</b> Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 21    | Enable_SLVIF_WRONHOLD_ER_R_IntStat       | R/W           | <p>Slave Interface Write On Hold Error Status Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the generation of Slave Interface Write On Hold Error Interrupt in CHx_INTSTATUSREG</li> <li>■ 1: Enable the generation of Slave Interface Write On Hold Error Interrupt in CHx_INTSTATUSREG</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_SLVIF_WRONHOLD_ERR): Enable the generation of Slave Interface Write On Hold Error Interrupt in CH1_INTSTATUSREG</li> <li>■ 0x0 (DISABLE_SLVIF_WRONHOLD_ERR): Disable the generation of Slave Interface Write On Hold Error Interrupt in CH1_INTSTATUSREG</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p> |

**Table 5-39 Fields for Register: CHx\_INTSTATUS\_ENABLEREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)**

| Bits | Name                                          | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|-----------------------------------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 20   | Enable_SLVIF_SHADOWREG_WRON_VALID_ERR_IntStat | R/W           | <p>Shadow Register Write On Valid Error Status Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the generation of Shadow Register Write On Valid Error Interrupt in CHx_INTSTATUSREG</li> <li>■ 1: Enable the generation of Shadow register Write On Valid Error Interrupt in CHx_INTSTATUSREG</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_SLVIF_SHADOWREG_WRON_VALID_ERR): Enable the generation of Shadow register Write On Valid Error Interrupt in CH1_INTSTATUSREG</li> <li>■ 0x0 (DISABLE_SLVIF_SHADOWREG_WRON_VALID_ERR): Disable the generation of Shadow Register Write On Valid Error Interrupt in CH1_INTSTATUSREG</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p>                           |
| 19   | Enable_SLVIF_WRONCHEN_ERR_IntStat             | R/W           | <p>Slave Interface Write On Channel Enabled Error Status Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the generation of Slave Interface Write On Channel enabled Error Interrupt in CHx_INTSTATUSREG</li> <li>■ 1: Enable the generation of Slave Interface Write On Channel enabled Error Interrupt in CHx_INTSTATUSREG</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_SLVIF_WRONCHEN_ERR): Enable the generation of Slave Interface Write On Channel enabled Error Interrupt in CH1_INTSTATUSREG</li> <li>■ 0x0 (DISABLE_SLVIF_WRONCHEN_ERR): Disable the generation of Slave Interface Write On Channel enabled Error Interrupt in CH1_INTSTATUSREG</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p> |

**Table 5-39 Fields for Register: CHx\_INTSTATUS\_ENABLEREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)**

| Bits | Name                            | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------|---------------------------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18   | Enable_SLVIF_RD2RWO_ERR_IntStat | R/W           | <p>Slave Interface Read to write Only Error Status Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the generation of Slave Interface Read to Write only Error Interrupt in CHx_INTSTATUSREG</li> <li>■ 1: Enable the generation of Slave Interface Read to Write Only Error Interrupt in CHx_INTSTATUSREG</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_SLVIF_RD2RWO_ERR): Enable the generation of Slave Interface Read to Write Only Error Interrupt in CH1_INTSTATUSREG</li> <li>■ 0x0 (DISABLE_SLVIF_RD2RWO_ERR): Disable the generation of Slave Interface Read to Write only Error Interrupt in CH1_INTSTATUSREG</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p> |
| 17   | Enable_SLVIF_WR2RO_ERR_Stat     | R/W           | <p>Slave Interface Write to Read Only Error Status Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the generation of Slave Interface Write to Read only Error Interrupt in CHx_INTSTATUSREG</li> <li>■ 1: Enable the generation of Slave Interface Write to Read Only Error Interrupt in CHx_INTSTATUSREG</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_SLVIF_WR2RO_ERR): Enable the generation of Slave Interface Write to Read Only Error Interrupt in CH1_INTSTATUSREG</li> <li>■ 0x0 (DISABLE_SLVIF_WR2RO_ERR): Disable the generation of Slave Interface Write to Read only Error Interrupt in CH1_INTSTATUSREG</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p>   |

**Table 5-39 Fields for Register: CHx\_INTSTATUS\_ENABLEREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)**

| Bits | Name                                  | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|---------------------------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16   | Enable_SLVIF_DEC_ERR_IntStat          | R/W           | <p>Slave Interface Decode Error Status Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the generation of Slave Interface Decode Error Interrupt in CHx_INTSTATUSREG</li> <li>■ 1: Enable the generation of Slave Interface Decode Error Interrupt in CHx_INTSTATUSREG</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_SLVIF_DEC_ERR): Enable the generation of Slave Interface Decode Error Interrupt in CH1_INTSTATUSREG</li> <li>■ 0x0 (DISABLE_SLVIF_DEC_ERR): Disable the generation of Slave Interface Decode Error Interrupt in CH1_INTSTATUSREG</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p>                                                                     |
| 15   | RSVD_DMAC_CHx_INTSTATUS_ENABLEREG_15  | R             | <p>DMAC Channelx Interrupt Status Register (bit 15) Reserved bit - Read Only</p> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 14   | Enable_SLVIF_MULTIBLKTYPE_ERR_IntStat | R/W           | <p>Slave Interface Multi Block type Error Status Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the generation of Slave Interface Multi Block type Error Interrupt in CHx_INTSTATUSREG</li> <li>■ 1: Enable the generation of Slave Interface Multi Block type Error Interrupt in CHx_INTSTATUSREG</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_SLVIF_MULTIBLKTYPE_ERR): Enable the generation of Slave Interface Multi Block type Error Interrupt in CH1_INTSTATUSREG</li> <li>■ 0x0 (DISABLE_SLVIF_MULTIBLKTYPE_ERR): Disable the generation of Slave Interface Multi Block type Error Interrupt in CH1_INTSTATUSREG</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p> |

**Table 5-39 Fields for Register: CHx\_INTSTATUS\_ENABLEREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)**

| Bits | Name                                        | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|---------------------------------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13   | Enable_SHADOWREG_OR_LLI_INVALID_ERR_IntStat | R/W           | <p>Shadow register or LLI Invalid Error Status Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the generation of Shadow Register or LLI Invalid Error Interrupt in CHx_INTSTATUSREG</li> <li>■ 1: Enable the generation of Shadow Register or LLI Invalid Error Interrupt in CHx_INTSTATUSREG</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_SHADOWREG_OR_LLI_INVALID_ERR): Enable the generation of Shadow Register or LLI Invalid Error Interrupt in CH1_INTSTATUSREG</li> <li>■ 0x0 (DISABLE_SHADOWREG_OR_LLI_INVALID_ERR): Disable the generation of Shadow Register or LLI Invalid Error Interrupt in CH1_INTSTATUSREG</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p> |
| 12   | Enable_LLI_WR_SLV_ERR_IntStat               | R/W           | <p>LLI WRITE Slave Error Status Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the generation of LLI WRITE Slave Error Interrupt in CHx_INTSTATUSREG</li> <li>■ 1: Enable the generation of LLI WRITE Slave Error Interrupt in CHx_INTSTATUSREG</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_LLI_WR_SLV_ERR): Enable the generation of LLI WRITE Slave Error Interrupt in CH1_INTSTATUSREG</li> <li>■ 0x0 (DISABLE_LLI_WR_SLV_ERR): Disable the generation of LLI WRITE Slave Error Interrupt in CH1_INTSTATUSREG</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p>                                                                                                        |

**Table 5-39 Fields for Register: CHx\_INTSTATUS\_ENABLEREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)**

| Bits | Name                          | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|-------------------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11   | Enable_LLI_RD_SLV_ERR_IntStat | R/W           | <p>LLI Read Slave Error Status Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the generation of LLI Read Slave Error Interrupt in CHx_INTSTATUSREG</li> <li>■ 1: Enable the generation of LLI Read Slave Error Interrupt in CHx_INTSTATUSREG</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_LLI_RD_SLV_ERR): Enable the generation of LLI Read Slave Error Interrupt in CH1_INTSTATUSREG</li> <li>■ 0x0 (DISABLE_LLI_RD_SLV_ERR): Disable the generation of LLI Read Slave Error Interrupt in CH1_INTSTATUSREG</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p>           |
| 10   | Enable_LLI_WR_DEC_ERR_IntStat | R/W           | <p>LLI WRITE Decode Error Status Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the generation of LLI WRITE Decode Error Interrupt in CHx_INTSTATUSREG</li> <li>■ 1: Enable the generation of LLI WRITE Decode Error Interrupt in CHx_INTSTATUSREG</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_LLI_WR_DEC_ERR): Enable the generation of LLI WRITE Decode Error Interrupt in CH1_INTSTATUSREG</li> <li>■ 0x0 (DISABLE_LLI_WR_DEC_ERR): Disable the generation of LLI WRITE Decode Error Interrupt in CH1_INTSTATUSREG</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p> |

**Table 5-39 Fields for Register: CHx\_INTSTATUS\_ENABLEREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)**

| Bits | Name                          | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|-------------------------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9    | Enable_LLI_RD_DEC_ERR_IntStat | R/W           | <p>LLI Read Decode Error Status Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the generation of LLI Read Decode Error Interrupt in CHx_INTSTATUSREG</li> <li>■ 1: Enable the generation of LLI Read Decode Error Interrupt in CHx_INTSTATUSREG</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_LLI_RD_DEC_ERR): Enable the generation of LLI Read Decode Error Interrupt in CH1_INTSTATUSREG</li> <li>■ 0x0 (DISABLE_LLI_RD_DEC_ERR): Disable the generation of LLI Read Decode Error Interrupt in CH1_INTSTATUSREG</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p>     |
| 8    | Enable_DST_SLV_ERR_IntStat    | R/W           | <p>Destination Slave Error Status Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the generation of Destination Slave Error Interrupt in CHx_INTSTATUSREG</li> <li>■ 1: Enable the generation of Destination Slave Error Interrupt in CHx_INTSTATUSREG</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_DST_SLV_ERR): Enable the generation of Destination Slave Error Interrupt in CH1_INTSTATUSREG</li> <li>■ 0x0 (DISABLE_DST_SLV_ERR): Disable the generation of Destination Slave Error Interrupt in CH1_INTSTATUSREG</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p> |

**Table 5-39 Fields for Register: CHx\_INTSTATUS\_ENABLEREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)**

| Bits | Name                       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|----------------------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7    | Enable_SRC_SLV_ERR_IntStat | R/W           | <p>Source Slave Error Status Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the generation of Source Slave Error Interrupt in CHx_INTSTATUSREG</li> <li>■ 1: Enable the generation of Source Slave Error Interrupt in CHx_INTSTATUSREG</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_SRC_SLV_ERR): Enable the generation of Source Slave Error Interrupt in CH1_INTSTATUSREG</li> <li>■ 0x0 (DISABLE_SRC_SLV_ERR): Disable the generation of Source Slave Error Interrupt in CH1_INTSTATUSREG</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p>                               |
| 6    | Enable_DST_DEC_ERR_IntStat | R/W           | <p>Destination Decode Error Status Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the generation of Destination Decode Error Interrupt in CHx_INTSTATUSREG</li> <li>■ 1: Enable the generation of Destination Decode Error Interrupt in CHx_INTSTATUSREG</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_DST_DEC_ERR): Enable the generation of Destination Decode Error Interrupt in CH1_INTSTATUSREG</li> <li>■ 0x0 (DISABLE_DST_DEC_ERR): Disable the generation of Destination Decode Error Interrupt in CH1_INTSTATUSREG</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p> |

**Table 5-39 Fields for Register: CHx\_INTSTATUS\_ENABLEREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)**

| Bits | Name                         | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|------------------------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5    | Enable_SRC_DEC_ERR_IntStat   | R/W           | <p>Source Decode Error Status Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the generation of Source Decode Error Interrupt in CHx_INTSTATUSREG</li> <li>■ 1: Enable the generation of Source Decode Error Interrupt in CHx_INTSTATUSREG</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_SRC_DEC_ERR): Enable the generation of Source Decode Error Interrupt in CH1_INTSTATUSREG</li> <li>■ 0x0 (DISABLE_SRC_DEC_ERR): Disable the generation of Source Decode Error Interrupt in CH1_INTSTATUSREG</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p>                                                                       |
| 4    | Enable_DST_TRANSCOMP_IntStat | R/W           | <p>Destination Transaction Completed Status Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the generation of Destination Transaction complete Interrupt in CHx_INTSTATUSREG</li> <li>■ 1: Enable the generation of Destination Transaction complete Interrupt in CHx_INTSTATUSREG</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_DST_TRANSCOMP): Enable the generation of Destination Transaction complete Interrupt in CH1_INTSTATUSREG</li> <li>■ 0x0 (DISABLE_DST_TRANSCOMP): Disable the generation of Destination Transaction complete Interrupt in CH1_INTSTATUSREG</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p> |

**Table 5-39 Fields for Register: CHx\_INTSTATUS\_ENABLEREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)**

| Bits | Name                              | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|-----------------------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3    | Enable_SRC_TRANSCOMP_IntStat      | R/W           | <p>Source Transaction Completed Status Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the generation of Source Transaction Complete Interrupt in CHx_INTSTATUSREG</li> <li>■ 1: Enable the generation of Source Transaction Complete Interrupt in CHx_INTSTATUSREG</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_SRC_TRANSCOMP): Enable the generation of Source Transaction Complete Interrupt in CH1_INTSTATUSREG</li> <li>■ 0x0 (DISABLE_SRC_TRANSCOMP): Disable the generation of Source Transaction Complete Interrupt in CH1_INTSTATUSREG</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p> |
| 2    | RSVD_DMACHx_INTSTATUS_ENABLEREG_2 | R             | <p>DMAC Channelx Interrupt Status Register (bit 2) Reserved bit - Read Only</p> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 1    | Enable_DMA_TFR_DONE_IntStat       | R/W           | <p>DMA Transfer Done Interrupt Status Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the generation of DMA Transfer Done Interrupt in CHx_INTSTATUSREG</li> <li>■ 1: Enable the generation of DMA Transfer Done Interrupt in CHx_INTSTATUSREG</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_DMA_TFR_DONE): Enable the generation of DMA Transfer Done Interrupt in CH1_INTSTATUSREG</li> <li>■ 0x0 (DISABLE_DMA_TFR_DONE): Disable the generation of DMA Transfer Done Interrupt in CH1_INTSTATUSREG</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p>                                            |

**Table 5-39 Fields for Register: CHx\_INTSTATUS\_ENABLEREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)**

| Bits | Name                              | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|-----------------------------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | Enable_BLOCK_TFR_DONE_Int<br>Stat | R/W           | <p>Block Transfer Done Interrupt Status Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the generation of Block Transfer Done Interrupt in CHx_INTSTATUSREG</li> <li>■ 1: Enable the generation of Block Transfer Done Interrupt in CHx_INTSTATUSREG</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_BLOCK_TFR_DONE): Enable the generation of Block Transfer Done Interrupt in CH1_INTSTATUSREG</li> <li>■ 0x0 (DISABLE_BLOCK_TFR_DONE): Disable the generation of Block Transfer Done Interrupt in CH1_INTSTATUSREG</li> </ul> <p><b>Value After Reset:</b> 0x1</p> <p><b>Exists:</b> Always</p> |

### 5.2.19 CHx\_INTSTATUS (for x = 1; x <= DMAX\_NUM\_CHANNELS)

- Description:** Channelx Interrupt Status Register captures the Channelx specific interrupts
- Size:** 64 bits
- Offset:** 0x188 + (x-1)\*0x100
- Exists:** DMAX\_NUM\_CHANNELS >= x

|                                        |       |
|----------------------------------------|-------|
| RSVD_DM_MAC_CHx_INTSTATUSREG_32to63    | 63:32 |
| CH_ABORTED_IntStat                     | 31    |
| CH_DISABLED_IntStat                    | 30    |
| CH_SUSPENDED_IntStat                   | 29    |
| CH_SRC_SUSPENDED_IntStat               | 28    |
| CH_LOCK_CLEARED_IntStat                | 27    |
| RSVD_DM_MAC_CHx_INTSTATUSREG_22to26    | 26:22 |
| SLVIF_WRONHOLD_ERR_IntStat             | 21    |
| SLVIF_SHADOWREG_WRON_VALID_ERR_IntStat | 20    |
| SLVIF_WRONCHEN_ERR_IntStat             | 19    |
| SLVIF_RD2RWO_ERR_IntStat               | 18    |
| SLVIF_WR2RO_ERR_IntStat                | 17    |
| SLVIF_DEC_ERR_IntStat                  | 16    |
| RSVD_DM_MAC_CHx_INTSTATUSREG_15        | 15    |
| SLVIF_MULTIBLKTYPE_ERR_IntStat         | 14    |
| SHADOWREG_OR_LLI_INVALID_ERR_IntStat   | 13    |
| LLI_WR_SLV_ERR_IntStat                 | 12    |
| LLI_RD_SLV_ERR_IntStat                 | 11    |
| LLI_WR_DEC_ERR_IntStat                 | 10    |
| LLI_RD_DEC_ERR_IntStat                 | 9     |
| DST_SLV_ERR_IntStat                    | 8     |
| SRC_SLV_ERR_IntStat                    | 7     |
| DST_DEC_ERR_IntStat                    | 6     |
| SRC_DEC_ERR_IntStat                    | 5     |
| DST_TRANSCOMP_IntStat                  | 4     |
| SRC_TRANSCOMP_IntStat                  | 3     |
| RSVD_DM_MAC_CHx_INTSTATUSREG_2         | 2     |
| DMA_TFR_DONE_IntStat                   | 1     |
| BLOCK_TFR_DONE_IntStat                 | 0     |

Table 5-40 Fields for Register: CHx\_INTSTATUS (for x = 1; x <= DMAX\_NUM\_CHANNELS)

| Bits  | Name                                | Memory Access | Description                                                                                                                                                             |
|-------|-------------------------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:32 | RSVD_DM_MAC_CHx_INTSTATUSREG_32to63 | R             | DMAC Channelx Specific Interrupt Register (bits 32to63)<br>Reserved bits - Read Only<br><b>Value After Reset:</b> 0x0<br><b>Exists:</b> Always<br><b>Volatile:</b> true |

**Table 5-40 Fields for Register: CHx\_INTSTATUS (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name                | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------|---------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | CH_ABORTED_IntStat  | R             | <p>Channel Aborted.<br/>This indicates to the software that the corresponding channel in DW_axi_dmac is aborted.</p> <ul style="list-style-type: none"> <li>■ 0: Channel is not aborted</li> <li>■ 1: Channel is aborted</li> </ul> <p>Error Interrupt is generated if the corresponding bit in CHx_INTSTATUS_ENABLEReg is enabled. This bit is cleared to 0 on writing 1 to the corresponding channel interrupt clear bit in CHx_IntClearReg register.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE_CH_ABORTED): Channel is aborted</li> <li>■ 0x0 (INACTIVE_CH_ABORTED): Channel is not aborted</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p>           |
| 30   | CH_DISABLED_IntStat | R             | <p>Channel Disabled.<br/>This indicates to the software that the corresponding channel in DW_axi_dmac is disabled.</p> <ul style="list-style-type: none"> <li>■ 0: Channel is not disabled.</li> <li>■ 1: Channel is disabled. Error Interrupt is generated if the corresponding bit in CHx_INTSTATUS_ENABLEReg is enabled.</li> </ul> <p>This bit is cleared to 0 on writing 1 to the corresponding channel interrupt clear bit in CHx_IntClearReg register.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE_CH_DISABLED): Channel is disabled</li> <li>■ 0x0 (INACTIVE_CH_DISABLED): Channel is not disabled</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p> |

**Table 5-40 Fields for Register: CHx\_INTSTATUS (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name                     | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|--------------------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29   | CH_SUSPENDED_IntStat     | R             | <p>Channel Suspended.<br/>This indicates to the software that the corresponding channel in DW_axi_dmac is suspended.</p> <ul style="list-style-type: none"> <li>■ 0: Channel is not suspended.</li> <li>■ 1: Channel is suspended.</li> </ul> <p>Error Interrupt is generated if the corresponding bit in CHx_INTSTATUS_ENABLEReg is enabled. This bit is cleared to 0 on writing 1 to the corresponding channel interrupt clear bit in CHx_IntClearReg register.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE_CH_SUSPENDED): Channel is suspended</li> <li>■ 0x0 (INACTIVE_CH_SUSPENDED): Channel is not suspended</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p>                                                                |
| 28   | CH_SRC_SUSPENDED_IntStat | R             | <p>Channel Source Suspended.<br/>This indicates to the software that the corresponding channel source data transfer in DW_axi_dmac is suspended.</p> <ul style="list-style-type: none"> <li>■ 0: Channel source is not suspended</li> <li>■ 1: Channel Source is suspended.</li> </ul> <p>Error Interrupt is generated if the corresponding bit in CHx_INTSTATUS_ENABLEReg is enabled. This bit is cleared to 0 on writing 1 to the corresponding channel interrupt clear bit in CHx_IntClearReg register.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE_CH_SRC_SUSPENDED): Channel Source is suspended</li> <li>■ 0x0 (INACTIVE_CH_SRC_SUSPENDED): Channel source is not suspended</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p> |

**Table 5-40 Fields for Register: CHx\_INTSTATUS (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits  | Name                                | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|-------------------------------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27    | CH_LOCK_CLEARED_IntStat             | R             | <p>Channel Lock Cleared.<br/>This indicates to the software that the locking of the corresponding channel in DW_axi_dmac is cleared.</p> <ul style="list-style-type: none"> <li>■ 0: Channel locking is not cleared.</li> <li>■ 1: Channel locking is cleared.</li> </ul> <p>Channel locking is cleared by DW_axi_dmac during the following situations:</p> <ul style="list-style-type: none"> <li>■ Channel locking is cleared and the channel locking settings in CHx_CFG register is reset if DW_axi_dmac disables the channel upon request from software.</li> <li>■ Channel locking is cleared and the channel locking settings in CHx_CFG register is reset if DW_axi_dmac disables the channel upon receiving error response on the master interface.</li> </ul> <p>This bit is cleared to 0 on enabling the channel.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE_CH_LOCK_CLEARED): Channel Locking is cleared</li> <li>■ 0x0 (INACTIVE_CH_LOCK_CLEARED): Channel locking is not cleared, if present.</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p> |
| 26:22 | RSVD_DMACHx_INTSTATUS<br>REG_22to26 | R             | <p>DMAC Channelx Specific Interrupt Register (bits 22to26)<br/>Reserved bits - Read Only</p> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

**Table 5-40 Fields for Register: CHx\_INTSTATUS (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| <b>Bits</b> | <b>Name</b>                | <b>Memory Access</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------------|----------------------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 21          | SLVIF_WRONHOLD_ERR_IntStat | R                    | <p>Slave Interface Write On Hold Error.<br/>This error occurs if an illegal write operation is performed on a register; this happens if a write operation is performed on a channel register when DW_axi_dmac is in Hold mode.</p> <ul style="list-style-type: none"> <li>■ 0: No Slave Interface Write On Hold Errors.</li> <li>■ 1: Slave Interface Write On Hold Error detected.</li> </ul> <p>Error Interrupt is generated if the corresponding bit in CHx_INTSTATUS_ENABLEReg is enabled. This bit is cleared to 0 on writing 1 to the corresponding channel interrupt clear bit in CHx_IntClearReg register.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE_SLVIF_WRONHOLD_ERR): Slave Interface Write On Hold Error detected</li> <li>■ 0x0 (INACTIVE_SLVIF_WRONHOLD_ERR): No Slave Interface Write On Hold Errors</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p> |

**Table 5-40 Fields for Register: CHx\_INTSTATUS (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name                                       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|--------------------------------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 20   | SLVIF_SHADOWREG_WRON_V<br>ALID_ERR_IntStat | R             | <p>Shadow Register Write On Valid Error.<br/>This error occurs if shadow register based multi-block transfer is enabled and software tries to write to the shadow register when CHx_CTL.ShadowReg_Or_LLI_Valid bit is 1.</p> <ul style="list-style-type: none"> <li>■ 0: No Slave Interface Shadow Register Write On Valid Errors.</li> <li>■ 1: Slave Interface Shadow Register Write On Valid Error detected.</li> </ul> <p>Error Interrupt is generated if the corresponding bit in CHx_INTSTATUS_ENABLEReg is enabled. This bit is cleared to 0 on writing 1 to the corresponding channel interrupt clear bit in CHx_IntClearReg register.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE_SLVIF_SHADOWREG_WRON_VALID_ERR): Slave Interface Shadow Register Write On Valid Error detected</li> <li>■ 0x0 (INACTIVE_SLVIF_SHADOWREG_WRON_VALID_ERR): No Slave Interface Shadow Register Write On Valid Errors</li> </ul> <p><b>Value After Reset:</b> 0x0<br/> <b>Exists:</b> Always<br/> <b>Volatile:</b> true</p> |

**Table 5-40 Fields for Register: CHx\_INTSTATUS (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name                       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|----------------------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19   | SLVIF_WRONCHEN_ERR_IntStat | R             | <p>Slave Interface Write On Channel Enabled Error. This error occurs if an illegal write operation is performed on a register; this happens if a write operation is performed on a register when the channel is enabled and if it is not allowed for the corresponding register as per the DW_axi_dmac specification.</p> <ul style="list-style-type: none"> <li>■ 0: No Slave Interface Write On Channel Enabled Errors.</li> <li>■ 1: Slave Interface Write On Channel Enabled Error detected.</li> </ul> <p>Error Interrupt is generated if the corresponding bit in CHx_INTSTATUS_ENABLEReg is enabled. This bit is cleared to 0 on writing 1 to the corresponding channel interrupt clear bit in CHx_IntClearReg register.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE_SLVIF_WRONCHEN_ERR): Slave Interface Write On Channel Enabled Error detected</li> <li>■ 0x0 (INACTIVE_SLVIF_WRONCHEN_ERR): No Slave Interface Write On Channel Enabled Errors</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p> |
| 18   | SLVIF_RD2RWO_ERR_IntStat   | R             | <p>Slave Interface Read to write Only Error. This error occurs if read operation is performed to a Write Only register.</p> <ul style="list-style-type: none"> <li>■ 0: No Slave Interface Read to Write Only Errors.</li> <li>■ 1: Slave Interface Read to Write Only Error detected.</li> </ul> <p>Error Interrupt is generated if the corresponding bit in CHx_INTSTATUS_ENABLEReg is enabled. This bit is cleared to 0 on writing 1 to the corresponding channel interrupt clear bit in CHx_IntClearReg register.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE_SLVIF_RD2RWO_ERR): Slave Interface Read to Write Only Error detected</li> <li>■ 0x0 (INACTIVE_SLVIF_RD2RWO_ERR): No Slave Interface Read to Write Only Errors</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p>                                                                                                                                                                                                                           |

**Table 5-40 Fields for Register: CHx\_INTSTATUS (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name                    | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|-------------------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17   | SLVIF_WR2RO_ERR_IntStat | R             | <p>Slave Interface Write to Read Only Error.<br/>This error occurs if write operation is performed to a Read Only register.</p> <ul style="list-style-type: none"> <li>■ 0: No Slave Interface Write to Read Only Errors.</li> <li>■ 1: Slave Interface Write to Read Only Error detected.</li> </ul> <p>Error Interrupt is generated if the corresponding bit in CHx_INTSTATUS_ENABLEReg is enabled. This bit is cleared to 0 on writing 1 to the corresponding channel interrupt clear bit in CHx_IntClearReg register.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE_SLVIF_WR2RO_ERR): Slave Interface Write to Read Only Error detected</li> <li>■ 0x0 (INACTIVE_SLVIF_WR2RO_ERR): No Slave Interface Write to Read Only Errors</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p>                                                                         |
| 16   | SLVIF_DEC_ERR_IntStat   | R             | <p>Slave Interface Decode Error.<br/>Decode Error generated by DW_axi_dmac during register access. This error occurs if the register access is to invalid address in Channelx register space resulting in error response by DW_axi_dmac slave interface.</p> <ul style="list-style-type: none"> <li>■ 0: No Slave Interface Decode errors.</li> <li>■ 1: Slave Interface Decode Error detected.</li> </ul> <p>Error Interrupt is generated if the corresponding bit in CHxINTSTATUS_ENABLEReg is enabled. This bit is cleared to 0 on writing 1 to the corresponding channel interrupt clear bit in CHx_IntClearReg register.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE_SLVIF_DEC_ERR): Slave Interface Decode Error detected</li> <li>■ 0x0 (INACTIVE_SLVIF_DEC_ERR): No Slave Interface Decode errors</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p> |

**Table 5-40 Fields for Register: CHx\_INTSTATUS (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name                           | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|--------------------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15   | RSVD_DMAC_CHx_INTSTATUS_REG_15 | R             | <p>DMAC Channelx Specific Interrupt Register (bit 15)<br/>Reserved bit - Read Only</p> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 14   | SLVIF_MULTIBLKTYPE_ERR_IntStat | R             | <p>Slave Interface Multi Block type Error.<br/>This error occurs if multi-block transfer type programmed in CHx_CFG register (SRC_MLTBLK_TYPE and DST_MLTBLK_TYPE) is invalid. This error condition causes the DW_axi_dmac to halt the corresponding channel gracefully; Error Interrupt is generated if the corresponding channel error interrupt mask bit is set to 0 and the channel waits till software writes (any value) to CHx_BLK_TFR_ResumeReqReg to indicate valid multi-block transfer type availability.</p> <ul style="list-style-type: none"> <li>■ 0: No Multi-block transfer type Errors.</li> <li>■ 1: Multi-block transfer type Error detected.</li> </ul> <p>Error Interrupt is generated if the corresponding bit in CHx_INTSTATUS_ENABLEReg is enabled. This bit is cleared to 0 on writing 1 to the corresponding channel interrupt clear bit in CHx_IntClearReg register.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE_SLVIF_MULTIBLKTYPE_ERR): Multi-block transfer type Error detected</li> <li>■ 0x0 (INACTIVE_SLVIF_MULTIBLKTYPE_ERR): No Multi-block transfer type Errors</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p> |

**Table 5-40 Fields for Register: CHx\_INTSTATUS (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name                                 | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|--------------------------------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13   | SHADOWREG_OR_LLI_INVALID_ERR_IntStat | R             | <p>Shadow register or LLI Invalid Error. This error occurs if CHx_CTL.ShadowReg_Or_LLI_Valid bit is seen to be 0 during DW_axi_dmac Shadow Register / LLI fetch phase. This error condition causes the DW_axi_dmac to halt the corresponding channel gracefully; Error Interrupt is generated if the corresponding channel error interrupt mask bit is set to 0 and the channel waits till software writes (any value) to CHx_BLK_TFR_ResumeReqReg to indicate valid Shadow Register availability.</p> <p>In the case of LLI pre-fetching, ShadowReg_Or_LLI_Invalid_ERR Interrupt is not generated even if ShadowReg_Or_LLI_Valid bit is seen to be 0 for the pre-fetched LLI. In this case, DW_axi_dmac re-attempts the LLI fetch operation after completing the current block transfer and generates ShadowReg_Or_LLI_Invalid_ERR Interrupt only if ShadowReg_Or_LLI_Valid bit is still seen to be 0.</p> <ul style="list-style-type: none"> <li>■ 0: No Shadow Register / LLI Invalid errors.</li> <li>■ 1: Shadow Register / LLI Invalid error detected.</li> </ul> <p>Error Interrupt is generated if the corresponding bit in CHx_INTSTATUS_ENABLEReg is enabled. This bit is cleared to 0 on writing 1 to the corresponding channel interrupt clear bit in CHx_IntClearReg register.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE_SHADOWREG_OR_LLI_INVALID_ERR): Shadow Register / LLI Invalid error detected</li> <li>■ 0x0 (INACTIVE_SHADOWREG_OR_LLI_INVALID_ERR): No Shadow Register / LLI Invalid errors</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p> |

**Table 5-40 Fields for Register: CHx\_INTSTATUS (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name                   | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|------------------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12   | LLI_WR_SLV_ERR_IntStat | R             | <p>LLI WRITE Slave Error.</p> <p>Slave Error detected by Master Interface during LLI write-back operation. This error occurs if the slave interface on which LLI resides issues a Slave Error. This error condition causes the DW_axi_dmac to disable the corresponding channel gracefully; the DMAC_ChEnReg.CH_EN1 bit which received the error is set to 0.</p> <ul style="list-style-type: none"> <li>■ 0: No LLI write Slave Errors.</li> <li>■ 1: LLI Write SLAVE Error detected.</li> </ul> <p>Error Interrupt is generated if the corresponding bit in CHx_INTSTATUS_ENABLEReg is enabled. This bit is cleared to 0 on writing 1 to the corresponding channel interrupt clear bit in CHx_IntClearReg register.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE_LLI_WR_SLV): LLI Write SLAVE Error detected</li> <li>■ 0x0 (INACTIVE_LLI_WR_SLV): No LLI write Slave Errors</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p> |

**Table 5-40 Fields for Register: CHx\_INTSTATUS (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name                   | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------|------------------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11   | LLI_RD_SLV_ERR_IntStat | R             | <p>LLI Read Slave Error.<br/>Slave Error detected by Master Interface during LLI read operation. This error occurs if the slave interface on which LLI resides issues a Slave Error. This error condition causes the DW_axi_dmac to disable the corresponding channel gracefully; the DMAC_ChEnReg.CH_EN1 bit which received the error is set to 0.</p> <ul style="list-style-type: none"> <li>■ 0: No LLI Read Slave Errors.</li> <li>■ 1: LLI read Slave Error detected.</li> </ul> <p>Error Interrupt is generated if the corresponding bit in CHx_INTSTATUS_ENABLEReg is enabled. This bit is cleared to 0 on writing 1 to the corresponding channel interrupt clear bit in CHx_IntClearReg register.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE_LLI_RD_SLV_ERR): LLI read Slave Error detected</li> <li>■ 0x0 (INACTIVE_LLI_RD_SLV_ERR): No LLI Read Slave Errors</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p> |

**Table 5-40 Fields for Register: CHx\_INTSTATUS (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name                   | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|------------------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10   | LLI_WR_DEC_ERR_IntStat | R             | <p>LLI WRITE Decode Error.<br/>Decode Error detected by Master Interface during LLI write-back operation. This error occurs if the access is to invalid address and a Decode Error is returned from interconnect/slave. This error condition causes the DW_axi_dmac to disable the corresponding channel gracefully; the DMAC_ChEnReg.CH_EN1 bit which received the error is set to 0.</p> <ul style="list-style-type: none"> <li>■ 0: NO LLI Write Decode Errors.</li> <li>■ 1: LLI write Decode Error detected.</li> </ul> <p>Error Interrupt is generated if the corresponding bit in CHx_INTSTATUS_ENABLEReg is enabled. This bit is cleared to 0 on writing 1 to the corresponding channel interrupt clear bit in CHx_IntClearReg register.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE_LLI_WR_DEC_ERR): LLI write Decode Error detected</li> <li>■ 0x0 (INACTIVE_LLI_WR_DEC_ERR): NO LLI Write Decode Errors</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p> |

**Table 5-40 Fields for Register: CHx\_INTSTATUS (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name                   | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------|------------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9    | LLI_RD_DEC_ERR_IntStat | R             | <p>LLI Read Decode Error.<br/>Decode Error detected by Master Interface during LLI read operation. This error occurs if the access is to invalid address and a Decode Error is returned from interconnect/slave. This error condition causes the DW_axi_dmac to disable the corresponding channel gracefully; the DMAC_ChEnReg.CH_EN1 bit which received the error is set to 0.</p> <ul style="list-style-type: none"> <li>■ 0: NO LLI Read Decode Errors.</li> <li>■ 1: LLI Read Decode Error detected</li> </ul> <p>Error Interrupt is generated if the corresponding bit in CHx_INTSTATUS_ENABLEReg is enabled.<br/>This bit is cleared to 0 on writing 1 to the corresponding channel interrupt clear bit in CHx_IntClearReg register.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVELLI_RD_DEC_ERR_): LLI Read Decode Error detected</li> <li>■ 0x0 (INACTIVE_LLI_RD_DEC_ERR): NO LLI Read Decode Errors</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p> |

**Table 5-40 Fields for Register: CHx\_INTSTATUS (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name                | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|---------------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8    | DST_SLV_ERR_IntStat | R             | <p>Destination Slave Error.</p> <p>Slave Error detected by Master Interface during destination data transfer. This error occurs if the slave interface to which the data is written issues a Slave Error. This error condition causes the DW_axi_dmac to disable the corresponding channel gracefully; the DMAC_ChEnReg.CH_EN bit corresponding to the channel which received the error is set to 0.</p> <ul style="list-style-type: none"> <li>■ 0: No Destination Slave Errors</li> <li>■ 1: Destination Slave Errors Detected</li> </ul> <p>This bit is cleared to 0 on writing 1 to the corresponding channel interrupt clear bit in CHx_IntClearReg register.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE_DST_SLV_ERR): Destination Slave Errors Detected</li> <li>■ 0x0 (INACTIVE_DST_SLV_ERR): No Destination Slave Errors</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p> |
| 7    | SRC_SLV_ERR_IntStat | R             | <p>Source Slave Error.</p> <p>Slave Error detected by Master Interface during source data transfer. This error occurs if the slave interface from which the data is read issues a Slave Error. This error condition causes the DW_axi_dmac to disable the corresponding channel gracefully; the DMAC_ChEnReg.CH_EN bit corresponding to the channel which received the error is set to 0.</p> <ul style="list-style-type: none"> <li>■ 0: No Source Slave Errors</li> <li>■ 1: Source Slave Error Detected</li> </ul> <p>This bit is cleared to 0 on writing 1 to the corresponding channel interrupt clear bit in CHx_IntClearReg register.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE_SRC_SLV_ERR): Source Slave Error Detected</li> <li>■ 0x0 (INACTIVE_SRC_SLV_ERR): No Source Slave Errors</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p>                                  |

**Table 5-40 Fields for Register: CHx\_INTSTATUS (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name                | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|---------------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6    | DST_DEC_ERR_IntStat | R             | <p>Destination Decode Error.<br/>Decode Error detected by Master Interface during destination data transfer. This error occurs if the access is to invalid address and a Decode Error is returned from interconnect/slave. This error condition causes the DW_axi_dmac to disable the corresponding channel gracefully; the DMAC_ChEnReg.CH_EN bit corresponding to the channel which received the error is set to 0.</p> <ul style="list-style-type: none"> <li>■ 0: No destination Decode Errors.</li> <li>■ 1: Destination Decode Error Detected</li> </ul> <p>This bit is cleared to 0 on writing 1 to the corresponding channel interrupt clear bit in CHx_IntClearReg register.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE_DST_DEC_ERR): Destination Decode Error Detected</li> <li>■ 0x0 (INACTIVE_DST_DEC_ERR): No destination Decode Errors.</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p> |
| 5    | SRC_DEC_ERR_IntStat | R             | <p>Source Decode Error.<br/>Decode Error detected by Master Interface during source data transfer. This error occurs if the access is to invalid address and a Decode Error is returned from interconnect/slave. This error condition causes the DW_axi_dmac to disable the corresponding channel gracefully; the DMAC_ChEnReg.CH_EN bit corresponding to the channel which received the error is set to 0.</p> <ul style="list-style-type: none"> <li>■ 0: No Source Decode Errors.</li> <li>■ 1: Source Decode Error detected.</li> </ul> <p>This bit is cleared to 0 on writing 1 to the corresponding channel interrupt clear bit in CHx_IntClearReg register.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE_SRC_DEC_ERR): Source Decode Error detected</li> <li>■ 0x0 (INACTIVE_SRC_DEC_ERR): No Source Decode Errors</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p>                               |

**Table 5-40 Fields for Register: CHx\_INTSTATUS (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name                        | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|-----------------------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4    | DST_TRANSCOMP_IntStat       | R             | <p>Destination Transaction Completed.</p> <p>This bit is cleared to 0 on writing 1 to the corresponding channel interrupt clear bit in CHx_IntClearReg register or on enabling the channel (needed when interrupt is not enabled).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE_DST_TRANSCOMP): Destination transaction is complete</li> <li>■ 0x0 (INACTIVE_DST_TRANSCOMP): Destination transaction is not complete</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p> |
| 3    | SRC_TRANSCOMP_IntStat       | R             | <p>Source Transaction Completed.</p> <p>This bit is cleared to 0 on writing 1 to the corresponding channel interrupt clear bit in CHx_IntClearReg register or on enabling the channel (needed when interrupt is not enabled).</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ACTIVE_SRC_TRANSCOMP): Source transaction is complete</li> <li>■ 0x0 (INACTIVE_SRC_TRANSCOMP): Source transaction is not complete</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p>                |
| 2    | RSVD_DMACHx_INTSTATUS_REG_2 | R             | <p>DMAC Channelx Specific Interrupt Register (bit 2) Reserved bit - Read Only</p> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p>                                                                                                                                                                                                                                                                                                                                                                                 |

**Table 5-40 Fields for Register: CHx\_INTSTATUS (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name                   | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------|------------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1    | DMA_TFR_DONE_IntStat   | R             | <p>DMA Transfer Done.</p> <p>This indicates to the software that the DW_axi_dmac has completed the requested DMA transfer.</p> <p>The DW_axi_dmac sets this bit to 1 along with setting CHx_INTSTATUS.BLOCK_TFR_DONE bit to 1 when the last block transfer is completed.</p> <ul style="list-style-type: none"> <li>■ 0: DMA Transfer not completed.</li> <li>■ 1: DMA Transfer Completed</li> </ul> <p>This bit is cleared to 0 on writing 1 to the corresponding channel interrupt clear bit in CHx_IntClearReg register.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (DMA_TFR_COMPLETED): DMA Transfer completed</li> <li>■ 0x0 (DMA_TFR_NOT_COMPLETE): DMA Transfer not complete</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p> |
| 0    | BLOCK_TFR_DONE_IntStat | R             | <p>Block Transfer Done.</p> <p>This indicates to the software that the DW_axi_dmac has completed the requested block transfer.</p> <p>The DW_axi_dmac sets this bit to 1 when the transfer is successfully completed.</p> <ul style="list-style-type: none"> <li>■ 0: Block Transfer not completed.</li> <li>■ 1: Block Transfer completed.</li> </ul> <p>This bit is cleared to 0 on writing 1 to the corresponding channel interrupt clear bit in CHx_IntClearReg register.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (BLOCK_TFR_COMPLETED): Block Transfer completed</li> <li>■ 0x0 (BLOCK_TFR_NOT_COMPLETE): Block Transfer not complete</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> <p><b>Volatile:</b> true</p>                                       |

## 5.2.20 CHx\_INTSTATUS\_ENABLEREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)

- Description:** This register contains fields that are used to enable the generation of port level interrupt at the channel level.
- Size:** 64 bits
- Offset:** 0x190 + (x-1)\*0x100
- Exists:** DMAX\_NUM\_CHANNELS >= x

|                                               |       |
|-----------------------------------------------|-------|
| RSVD_DMAC_CHx_INTSTATUS_ENABLEREG_32to63      | 63:32 |
| Enable_CH_ABORTED_IntSignal                   | 31    |
| Enable_CH_DISABLED_IntSignal                  | 30    |
| Enable_CH_SUSPENDED_IntSignal                 | 29    |
| Enable_CH_SRC_SUSPENDED_IntSignal             | 28    |
| Enable_CH_LOCK_CLEARED_IntSignal              | 27    |
| RSVD_DMAC_CHx_INTSTATUS_ENABLEREG_22to26      | 26:22 |
| Enable_SLVIF_WRONHOLD_ERR_IntSignal           | 21    |
| Enable_SHADOWREG_WRON_VALID_ERR_IntSignal     | 20    |
| Enable_SLVIF_WRONCHEN_ERR_IntSignal           | 19    |
| Enable_SLVIF_WR2RWO_ERR_IntSignal             | 18    |
| Enable_SLVIF_WR2RRO_ERR_IntSignal             | 17    |
| Enable_SLVIF_DEC_ERR_IntSignal                | 16    |
| RSVD_DMAC_CHx_INTSTATUS_ENABLEREG_15          | 15    |
| Enable_SLVIF_MULTIBLKTYPE_ERR_IntSignal       | 14    |
| Enable_SHADOWREG_OR_LLI_INVALID_ERR_IntSignal | 13    |
| Enable_LLI_WR_SLV_ERR_IntSignal               | 12    |
| Enable_LLI_RD_SLV_ERR_IntSignal               | 11    |
| Enable_LLI_WR_DEC_ERR_IntSignal               | 10    |
| Enable_LLI_RD_DEC_ERR_IntSignal               | 9     |
| Enable_DST_SLV_ERR_IntSignal                  | 8     |
| Enable_SRC_SLV_ERR_IntSignal                  | 7     |
| Enable_DST_DEC_ERR_IntSignal                  | 6     |
| Enable_SRC_DEC_ERR_IntSignal                  | 5     |
| Enable_DST_TRANSCOMP_IntSignal                | 4     |
| Enable_SRC_TRANSCOMP_IntSignal                | 3     |
| RSVD_DMAC_CHx_INTSTATUS_ENABLEREG_2           | 2     |
| Enable_DMA_TFR_DONE_IntSignal                 | 1     |
| Enable_BLOCK_TFR_DONE_IntSignal               | 0     |

Table 5-41 Fields for Register: CHx\_INTSTATUS\_ENABLEREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)

| Bits  | Name                                     | Memory Access | Description                                                                                                                                             |
|-------|------------------------------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:32 | RSVD_DMAC_CHx_INTSTATUS_ENABLEREG_32to63 | R             | DMAC Channelx Interrupt Status Enable Register (bits 32to63) Reserved bits - Read Only<br><b>Value After Reset:</b> 0xffffffff<br><b>Exists:</b> Always |

**Table 5-41 Fields for Register: CHx\_INTSIGNAL\_ENABLEREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)**

| Bits | Name                         | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|------------------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | Enable_CH_ABORTED_IntSignal  | R/W           | <p>Channel Aborted Signal Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the propagation of Channel Aborted Interrupt to generate a port level interrupt</li> <li>■ 1: Enable the propagation of Channel Aborted Interrupt to generate a port level interrupt</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH_ABORTED_IntSignal): Enable the propagation of Channel Aborted Interrupt to generate a port level interrupt</li> <li>■ 0x0 (DISABLE_CH_ABORTED_IntSignal): Disable the propagation of Channel Aborted Interrupt to generate a port level interrupt</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p>        |
| 30   | Enable_CH_DISABLED_IntSignal | R/W           | <p>Channel Disabled Signal Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the propagation of Channel Disabled Interrupt to generate a port level interrupt</li> <li>■ 1: Enable the propagation of Channel Disabled Interrupt to generate a port level interrupt</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH_DISABLED_IntSignal): Enable the propagation of Channel Disabled Interrupt to generate a port level interrupt</li> <li>■ 0x0 (DISABLE_CH_DISABLED_IntSignal): Disable the propagation of Channel Disabled Interrupt to generate a port level interrupt</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p> |

**Table 5-41 Fields for Register: CHx\_INTSIGNAL\_ENABLEREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)**

| <b>Bits</b> | <b>Name</b>                       | <b>Memory Access</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------------|-----------------------------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29          | Enable_CH_SUSPENDED_IntSignal     | R/W                  | <p>Channel Suspended Signal Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the propagation of Channel Suspended Interrupt to generate a port level interrupt</li> <li>■ 1: Enable the propagation of Channel Suspended Interrupt to generate a port level interrupt</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH_SUSPENDED_IntSignal): Enable the propagation of Channel Suspended Interrupt to generate a port level interrupt</li> <li>■ 0x0 (DISABLE_CH_SUSPENDED_IntSignal): Disable the propagation of Channel Suspended Interrupt to generate a port level interrupt</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p>                                            |
| 28          | Enable_CH_SRC_SUSPENDED_IntSignal | R/W                  | <p>Channel Source Suspended Signal Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the propagation of Channel Source Suspended Interrupt to generate a port level interrupt</li> <li>■ 1: Enable the propagation of Channel Source Suspended Interrupt to generate a port level interrupt</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH_SRC_SUSPENDED_IntSignal): Enable the propagation of Channel Source Suspended Interrupt to generate a port level interrupt</li> <li>■ 0x0 (DISABLE_CH_SRC_SUSPENDED_IntSignal): Disable the propagation of Channel Source Suspended Interrupt to generate a port level interrupt</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p> |

**Table 5-41 Fields for Register: CHx\_INTSIGNAL\_ENABLEREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)**

| Bits  | Name                                     | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------|------------------------------------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27    | Enable_CH_LOCK_CLEARED_IntSignal         | R/W           | <p>Channel Lock Cleared Signal Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the propagation of Channel Lock Cleared Interrupt to generate a port level interrupt</li> <li>■ 1: Enable the propagation of Channel Lock Cleared Interrupt to generate a port level interrupt</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_CH_LOCK_CLEARED_IntSignal): Enable the propagation of Channel Lock Cleared Interrupt to generate a port level interrupt</li> <li>■ 0x0 (DISABLE_CH_LOCK_CLEARED_IntSignal): Disable the propagation of Channel Lock Cleared Interrupt to generate a port level interrupt</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p>                                                                                  |
| 26:22 | RSVD_DMAC_CHx_INTSTATUS_ENABLEREG_22to26 | R             | <p>DMAC Channelx Interrupt Status Enable Register (bits 22to26) Reserved bits - Read Only</p> <p><b>Value After Reset:</b> 0x1f<br/> <b>Exists:</b> Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 21    | Enable_SLVIF_WRONHOLD_ER_R_IntSignal     | R/W           | <p>Slave Interface Write On Hold Error Signal Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the propagation of Slave Interface Write On Hold Error Interrupt to generate a port level interrupt</li> <li>■ 1: Enable the propagation of Slave Interface Write On Hold Error Interrupt to generate a port level interrupt</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_SLVIF_WRONHOLD_ERR_IntSignal): Enable the propagation of Slave Interface Write On Hold Error Interrupt to generate a port level interrupt</li> <li>■ 0x0 (DISABLE_SLVIF_WRONHOLD_ERR_IntSignal): Disable the propagation of Slave Interface Write On Hold Error Interrupt to generate a port level interrupt</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p> |

**Table 5-41 Fields for Register: CHx\_INTSIGNAL\_ENABLEREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)**

| Bits | Name                                            | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|-------------------------------------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 20   | Enable_SLVIF_SHADOWREG_WRON_VALID_ERR_IntSignal | R/W           | <p>Shadow Register Write On Valid Error Signal Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the propagation of Shadow Register Write On Valid Error Interrupt to generate a port level interrupt</li> <li>■ 1: Enable the propagation of Shadow register Write On Valid Error Interrupt to generate a port level interrupt</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_SLVIF_SHADOWREG_WRON_VALID_ERR_IntSignal): Enable the propagation of Shadow register Write On Valid Error Interrupt to generate a port level interrupt</li> <li>■ 0x0 (DISABLE_SLVIF_SHADOWREG_WRON_VALID_ERR_IntSignal): Disable the propagation of Shadow Register Write On Valid Error Interrupt to generate a port level interrupt</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p>                           |
| 19   | Enable_SLVIF_WRONCHEN_ERR_IntSignal             | R/W           | <p>Slave Interface Write On Channel Enabled Error Signal Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the propagation of Slave Interface Write On Channel enabled Error Interrupt to generate a port level interrupt</li> <li>■ 1: Enable the propagation of Slave Interface Write On Channel enabled Error Interrupt to generate a port level interrupt</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_SLVIF_WRONCHEN_ERR_IntSignal): Enable the propagation of Slave Interface Write On Channel enabled Error Interrupt to generate a port level interrupt</li> <li>■ 0x0 (DISABLE_SLVIF_WRONCHEN_ERR_IntSignal): Disable the propagation of Slave Interface Write On Channel enabled Error Interrupt to generate a port level interrupt</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p> |

**Table 5-41 Fields for Register: CHx\_INTSIGNAL\_ENABLEREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)**

| Bits | Name                              | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|-----------------------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18   | Enable_SLVIF_RD2RWO_ERR_IntSignal | R/W           | <p>Slave Interface Read to write Only Error Signal Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the propagation of Slave Interface Read to Write only Error Interrupt to generate a port level interrupt</li> <li>■ 1: Enable the propagation of Slave Interface Read to Write Only Error Interrupt to generate a port level interrupt</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_SLVIF_RD2RWO_ERR_IntSignal): Enable the propagation of Slave Interface Read to Write Only Error Interrupt to generate a port level interrupt</li> <li>■ 0x0 (DISABLE_SLVIF_RD2RWO_ERR_IntSignal): Disable the propagation of Slave Interface Read to Write only Error Interrupt to generate a port level interrupt</li> </ul> <p><b>Value After Reset:</b> 0x1</p> <p><b>Exists:</b> Always</p> |
| 17   | Enable_SLVIF_WR2RO_ERR_Signal     | R/W           | <p>Slave Interface Write to Read Only Error Signal Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the propagation of Slave Interface Write to Read only Error Interrupt to generate a port level interrupt</li> <li>■ 1: Enable the propagation of Slave Interface Write to Read Only Error Interrupt to generate a port level interrupt</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_SLVIF_WR2RO_ERR_Signal): Enable the propagation of Slave Interface Write to Read Only Error Interrupt to generate a port level interrupt</li> <li>■ 0x0 (DISABLE_SLVIF_WR2RO_ERR_Signal): Disable the propagation of Slave Interface Write to Read only Error Interrupt to generate a port level interrupt</li> </ul> <p><b>Value After Reset:</b> 0x1</p> <p><b>Exists:</b> Always</p>         |

**Table 5-41 Fields for Register: CHx\_INTSTATUS\_ENABLEREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)**

| Bits | Name                                    | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|-----------------------------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16   | Enable_SLVIF_DEC_ERR_IntSignal          | R/W           | <p>Slave Interface Decode Error Signal Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the propagation of Slave Interface Decode Error Interrupt to generate a port level interrupt</li> <li>■ 1: Enable the propagation of Slave Interface Decode Error Interrupt to generate a port level interrupt</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_SLVIF_DEC_ERR_IntSignal): Enable the propagation of Slave Interface Decode Error Interrupt to generate a port level interrupt</li> <li>■ 0x0 (DISABLE_SLVIF_DEC_ERR_IntSignal): Disable the propagation of Slave Interface Decode Error Interrupt to generate a port level interrupt</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p>                                                                     |
| 15   | RSVD_DMAC_CHx_INTSTATUS_ENABLEREG_15    | R             | <p>DMAC Channelx Interrupt Status Enable Register (bit 15)<br/>     Reserved bit - Read Only</p> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 14   | Enable_SLVIF_MULTIBLKTYPE_ERR_IntSignal | R/W           | <p>Slave Interface Multi Block type Error Signal Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the propagation of Slave Interface Multi Block type Error Interrupt to generate a port level interrupt</li> <li>■ 1: Enable the propagation of Slave Interface Multi Block type Error Interrupt to generate a port level interrupt</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_SLVIF_MULTIBLKTYPE_ERR_IntSignal): Enable the propagation of Slave Interface Multi Block type Error Interrupt to generate a port level interrupt</li> <li>■ 0x0 (DISABLE_SLVIF_MULTIBLKTYPE_ERR_IntSignal): Disable the propagation of Slave Interface Multi Block type Error Interrupt to generate a port level interrupt</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p> |

**Table 5-41 Fields for Register: CHx\_INTSIGNAL\_ENABLEREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)**

| Bits | Name                                          | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|-----------------------------------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13   | Enable_SHADOWREG_OR_LLI_INVALID_ERR_IntSignal | R/W           | <p>Shadow register or LLI Invalid Error Signal Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the propagation of Shadow Register or LLI Invalid Error Interrupt to generate a port level interrupt</li> <li>■ 1: Enable the propagation of Shadow Register or LLI Invalid Error Interrupt to generate a port level interrupt</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_SHADOWREG_OR_LLI_INVALID_ERR_IntSignal): Enable the propagation of Shadow Register or LLI Invalid Error Interrupt to generate a port level interrupt</li> <li>■ 0x0 (DISABLE_SHADOWREG_OR_LLI_INVALID_ERR_IntSignal): Disable the propagation of Shadow Register or LLI Invalid Error Interrupt to generate a port level interrupt</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p> |
| 12   | Enable_LLI_WR_SLV_ERR_IntSignal               | R/W           | <p>LLI WRITE Slave Error Signal Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the propagation of LLI WRITE Slave Error Interrupt to generate a port level interrupt</li> <li>■ 1: Enable the propagation of LLI WRITE Slave Error Interrupt to generate a port level interrupt</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_LLI_WR_SLV_ERR_IntSignal): Enable the propagation of LLI WRITE Slave Error Interrupt to generate a port level interrupt</li> <li>■ 0x0 (DISABLE_LLI_WR_SLV_ERR_IntSignal): Disable the propagation of LLI WRITE Slave Error Interrupt to generate a port level interrupt</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p>                                                                                                        |

**Table 5-41 Fields for Register: CHx\_INTSIGNAL\_ENABLEREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)**

| Bits | Name                            | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|---------------------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11   | Enable_LLI_RD_SLV_ERR_IntSignal | R/W           | <p>LLI Read Slave Error Signal Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the propagation of LLI Read Slave Error Interrupt to generate a port level interrupt</li> <li>■ 1: Enable the propagation of LLI Read Slave Error Interrupt to generate a port level interrupt</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_LLI_RD_SLV_ERR_IntSignal): Enable the propagation of LLI Read Slave Error Interrupt to generate a port level interrupt</li> <li>■ 0x0 (DISABLE_LLI_RD_SLV_ERR_IntSignal): Disable the propagation of LLI Read Slave Error Interrupt to generate a port level interrupt</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p>           |
| 10   | Enable_LLI_WR_DEC_ERR_IntSignal | R/W           | <p>LLI WRITE Decode Error Signal Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the propagation of LLI WRITE Decode Error Interrupt to generate a port level interrupt</li> <li>■ 1: Enable the propagation of LLI WRITE Decode Error Interrupt to generate a port level interrupt</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_LLI_WR_DEC_ERR_IntSignal): Enable the propagation of LLI WRITE Decode Error Interrupt to generate a port level interrupt</li> <li>■ 0x0 (DISABLE_LLI_WR_DEC_ERR_IntSignal): Disable the propagation of LLI WRITE Decode Error Interrupt to generate a port level interrupt</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p> |

**Table 5-41 Fields for Register: CHx\_INTSIGNAL\_ENABLEREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)**

| Bits | Name                            | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|---------------------------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9    | Enable_LLI_RD_DEC_ERR_IntSignal | R/W           | <p>LLI Read Decode Error Signal Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the propagation of LLI Read Decode Error Interrupt to generate a port level interrupt</li> <li>■ 1: Enable the propagation of LLI Read Decode Error Interrupt to generate a port level interrupt</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_LLI_RD_DEC_ERR_IntSignal): Enable the propagation of LLI Read Decode Error Interrupt to generate a port level interrupt</li> <li>■ 0x0 (DISABLE_LLI_RD_DEC_ERR_IntSignal): Disable the propagation of LLI Read Decode Error Interrupt to generate a port level interrupt</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p>     |
| 8    | Enable_DST_SLV_ERR_IntSignal    | R/W           | <p>Destination Slave Error Signal Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the propagation of Destination Slave Error Interrupt to generate a port level interrupt</li> <li>■ 1: Enable the propagation of Destination Slave Error Interrupt to generate a port level interrupt</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_DST_SLV_ERR_IntSignal): Enable the propagation of Destination Slave Error Interrupt to generate a port level interrupt</li> <li>■ 0x0 (DISABLE_DST_SLV_ERR_IntSignal): Disable the propagation of Destination Slave Error Interrupt to generate a port level interrupt</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p> |

**Table 5-41 Fields for Register: CHx\_INTSIGNAL\_ENABLEREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)**

| Bits | Name                         | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|------------------------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7    | Enable_SRC_SLV_ERR_IntSignal | R/W           | <p>Source Slave Error Signal Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the propagation of Source Slave Error Interrupt to generate a port level interrupt</li> <li>■ 1: Enable the propagation of Source Slave Error Interrupt to generate a port level interrupt</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_SRC_SLV_ERR_IntSignal): Enable the propagation of Source Slave Error Interrupt to generate a port level interrupt</li> <li>■ 0x0 (DISABLE_SRC_SLV_ERR_IntSignal): Disable the propagation of Source Slave Error Interrupt to generate a port level interrupt</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p>                               |
| 6    | Enable_DST_DEC_ERR_IntSignal | R/W           | <p>Destination Decode Error Signal Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the propagation of Destination Decode Error Interrupt to generate a port level interrupt</li> <li>■ 1: Enable the propagation of Destination Decode Error Interrupt to generate a port level interrupt</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_DST_DEC_ERR_IntSignal): Enable the propagation of Destination Decode Error Interrupt to generate a port level interrupt</li> <li>■ 0x0 (DISABLE_DST_DEC_ERR_IntSignal): Disable the propagation of Destination Decode Error Interrupt to generate a port level interrupt</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p> |

**Table 5-41 Fields for Register: CHx\_INTSIGNAL\_ENABLEREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)**

| Bits | Name                           | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|--------------------------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5    | Enable_SRC_DEC_ERR_IntSignal   | R/W           | <p>Source Decode Error Signal Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the propagation of Source Decode Error Interrupt to generate a port level interrupt</li> <li>■ 1: Enable the propagation of Source Decode Error Interrupt to generate a port level interrupt</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_SRC_DEC_ERR_IntSignal): Enable the propagation of Source Decode Error Interrupt to generate a port level interrupt</li> <li>■ 0x0 (DISABLE_SRC_DEC_ERR_IntSignal): Disable the propagation of Source Decode Error Interrupt to generate a port level interrupt</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p>                                                                       |
| 4    | Enable_DST_TRANSCOMP_IntSignal | R/W           | <p>Destination Transaction Completed Signal Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the propagation of Destination Transaction complete Interrupt to generate a port level interrupt</li> <li>■ 1: Enable the propagation of Destination Transaction complete Interrupt to generate a port level interrupt</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_DST_TRANSCOMP_IntSignal): Enable the propagation of Destination Transaction complete Interrupt to generate a port level interrupt</li> <li>■ 0x0 (DISABLE_DST_TRANSCOMP_IntSignal): Disable the propagation of Destination Transaction complete Interrupt to generate a port level interrupt</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p> |

**Table 5-41 Fields for Register: CHx\_INTSTATUS\_ENABLEREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)**

| Bits | Name                              | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------|-----------------------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3    | Enable_SRC_TRANSCOMP_IntSignal    | R/W           | <p>Source Transaction Completed Signal Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the propagation of Source Transaction Complete Interrupt to generate a port level interrupt</li> <li>■ 1: Enable the propagation of Source Transaction Complete Interrupt to generate a port level interrupt</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_SRC_TRANSCOMP_IntSignal): Enable the propagation of Source Transaction Complete Interrupt to generate a port level interrupt</li> <li>■ 0x0 (DISABLE_SRC_TRANSCOMP_IntSignal): Disable the propagation of Source Transaction Complete Interrupt to generate a port level interrupt</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p> |
| 2    | RSVD_DMACHx_INTSTATUS_ENABLEREG_2 | R             | <p>DMAC Channelx Interrupt Status Enable Register (bit 2)<br/>     Reserved bit - Read Only</p> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 1    | Enable_DMA_TFR_DONE_IntSignal     | R/W           | <p>DMA Transfer Done Interrupt Signal Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the propagation of DMA Transfer Done Interrupt to generate a port level interrupt</li> <li>■ 1: Enable the propagation of DMA Transfer Done Interrupt to generate a port level interrupt</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_DMA_TFR_DONE_IntSignal): Enable the propagation of DMA Transfer Done Interrupt to generate a port level interrupt</li> <li>■ 0x0 (DISABLE_DMA_TFR_DONE_IntSignal): Disable the propagation of DMA Transfer Done Interrupt to generate a port level interrupt</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p>                                            |

**Table 5-41 Fields for Register: CHx\_INTSIGNAL\_ENABLEREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)**

| <b>Bits</b> | <b>Name</b>                     | <b>Memory Access</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------------|---------------------------------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0           | Enable_BLOCK_TFR_DONE_IntSignal | R/W                  | <p>Block Transfer Done Interrupt Signal Enable.</p> <ul style="list-style-type: none"> <li>■ 0: Disable the propagation of Block Transfer Done Interrupt to generate a port level interrupt</li> <li>■ 1: Enable the propagation of Block Transfer Done Interrupt to generate a port level interrupt</li> </ul> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_BLOCK_TFR_DONE_IntSignal): Enable the propagation of Block Transfer Done Interrupt to generate a port level interrupt</li> <li>■ 0x0 (DISABLE_BLOCK_TFR_DONE_IntSignal): Disable the propagation of Block Transfer Done Interrupt to generate a port level interrupt</li> </ul> <p><b>Value After Reset:</b> 0x1<br/> <b>Exists:</b> Always</p> |

### 5.2.21 CHx\_INTCLEARREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)

- **Description:** Writing 1 to specific field will clear the corresponding field in Channelx Interrupt Status Register(CHx\_IntStatusReg).
- **Size:** 64 bits
- **Offset:** 0x198 + (x-1)\*0x100
- **Exists:** DMAX\_NUM\_CHANNELS >= x

|                                              |       |
|----------------------------------------------|-------|
| RSVD_DMAC_CHx_INTCLEARREG_32to63             | 63:32 |
| Clear_CH_ABORTED_IntStat                     | 31    |
| Clear_CH_DISABLED_IntStat                    | 30    |
| Clear_CH_SUSPENDED_IntStat                   | 29    |
| Clear_CH_SRC_SUSPENDED_IntStat               | 28    |
| Clear_CH_LOCK_CLEARD_IntStat                 | 27    |
| RSVD_DMAC_CHx_INTCLEARREG_22to26             | 26:22 |
| Clear_SLVIF_WRONHOLD_ERR_IntStat             | 21    |
| Clear_SLVIF_SHADOWREG_WRON_VALID_ERR_IntStat | 20    |
| Clear_SLVIF_WRONCHEN_ERR_IntStat             | 19    |
| Clear_SLVIF_RD2RW0_ERR_IntStat               | 18    |
| Clear_SLVIF_WR2R0_ERR_IntStat                | 17    |
| Clear_SLVIF_DEC_ERR_IntStat                  | 16    |
| RSVD_DMAC_CHx_INTCLEARREG_15                 | 15    |
| Clear_SLVIF_MULTIBLKTYPE_ERR_IntStat         | 14    |
| Clear_SHADOWREG_OR_LLI_INVALID_ERR_IntStat   | 13    |
| Clear_LLI_WR_SLV_ERR_IntStat                 | 12    |
| Clear_LLI_RD_SLV_ERR_IntStat                 | 11    |
| Clear_LLI_WR_DEC_ERR_IntStat                 | 10    |
| Clear_LLI_RD_DEC_ERR_IntStat                 | 9     |
| Clear_DST_SLV_ERR_IntStat                    | 8     |
| Clear_SRC_SLV_ERR_IntStat                    | 7     |
| Clear_DST_DEC_ERR_IntStat                    | 6     |
| Clear_SRC_DEC_ERR_IntStat                    | 5     |
| Clear_DST_TRANSCOMP_IntStat                  | 4     |
| Clear_SRC_TRANSCOMP_IntStat                  | 3     |
| RSVD_DMAC_CHx_INTCLEARREG_2                  | 2     |
| Clear_DMA_TFR_DONE_IntStat                   | 1     |
| Clear_BLOCK_TFR_DONE_IntStat                 | 0     |

Table 5-42 Fields for Register: CHx\_INTCLEARREG (for x = 1; x <= DMAX\_NUM\_CHANNELS)

| Bits  | Name                             | Memory Access | Description                                                                                                                                |
|-------|----------------------------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 63:32 | RSVD_DMAC_CHx_INTCLEARREG_32to63 | W             | DMAC Channelx Interrupt Clear Register (bits 32to63)<br>Reserved bit - Read Only<br><b>Value After Reset:</b> 0x0<br><b>Exists:</b> Always |

**Table 5-42 Fields for Register: CHx\_INTCLEARREG (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name                           | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------|--------------------------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | Clear_CH_ABORTED_IntStat       | W             | <p>Channel Aborted Interrupt Clear Bit.<br/>This bit is used to clear the corresponding channel interrupt status bit in CHx_INTSTATUSREG.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (CLEAR_CH_ABORTED): Clear the CH_ABORTED interrupt in the Interrupt Status Register(CH1_IntStatusReg).</li> <li>■ 0x0 (NO_ACTION): Inactive signal. No action taken.</li> </ul> <p><b>Value After Reset:</b> 0x0<br/><b>Exists:</b> Always</p>                      |
| 30   | Clear_CH_DISABLED_IntStat      | W             | <p>Channel Disabled Interrupt Clear Bit.<br/>This bit is used to clear the corresponding channel interrupt status bit in CHx_INTSTATUSREG.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (CLEAR_CH_DISABLED): Clear the CH_DISABLED interrupt in the Interrupt Status Register(CH1_IntStatusReg).</li> <li>■ 0x0 (NO_ACTION): Inactive signal. No action taken.</li> </ul> <p><b>Value After Reset:</b> 0x0<br/><b>Exists:</b> Always</p>                   |
| 29   | Clear_CH_SUSPENDED_IntStat     | W             | <p>Channel Suspended Interrupt Clear Bit.<br/>This bit is used to clear the corresponding channel interrupt status bit in CHx_INTSTATUSREG.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (CLEAR_CH_SUSPENDED): Clear the CH_SUSPENDED interrupt in the Interrupt Status Register(CH1_IntStatusReg).</li> <li>■ 0x0 (NO_ACTION): Inactive signal. No action taken.</li> </ul> <p><b>Value After Reset:</b> 0x0<br/><b>Exists:</b> Always</p>                |
| 28   | Clear_CH_SRC_SUSPENDED_IntStat | W             | <p>Channel Source Suspended Interrupt Clear Bit.<br/>This bit is used to clear the corresponding channel interrupt status bit in CHx_INTSTATUSREG.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (CLEAR_CH_SRC_SUSPENDED): Clear the CH_SRC_SUSPENDED interrupt in the Interrupt Status Register(CH1_IntStatusReg).</li> <li>■ 0x0 (NO_ACTION): Inactive signal. No action taken.</li> </ul> <p><b>Value After Reset:</b> 0x0<br/><b>Exists:</b> Always</p> |

**Table 5-42 Fields for Register: CHx\_INTCLEARREG (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits  | Name                                         | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|----------------------------------------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27    | Clear_CH_LOCK_CLEARED_IntStat                | W             | <p>Channel Lock Cleared Interrupt Clear Bit.<br/>This bit is used to clear the corresponding channel interrupt status bit in CHx_INTSTATUSREG.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (CLEAR_CH_LOCK_CLEARED): Clear the CH_LOCK_CLEARED interrupt in the Interrupt Status Register(CH1_IntStatusReg).</li> <li>■ 0x0 (NO_ACTION): Inactive signal. No action taken.</li> </ul> <p><b>Value After Reset:</b> 0x0<br/><b>Exists:</b> Always</p>                                                   |
| 26:22 | RSVD_DMAC_CHx_INTCLEARREG_22to26             | W             | <p>DMAC Channelx Interrupt Clear Register (bits 22to26)<br/>Reserved bit - Read Only</p> <p><b>Value After Reset:</b> 0x0<br/><b>Exists:</b> Always</p>                                                                                                                                                                                                                                                                                                                                                                          |
| 21    | Clear_SLVIF_WRONHOLD_ERR_IntStat             | W             | <p>Slave Interface Write On Hold Error Interrupt Clear Bit.<br/>This bit is used to clear the corresponding channel interrupt status bit in CHx_INTSTATUSREG.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (CLEAR_SLVIF_WRONHOLD_ERR): Clear the SLVIF_WRONHOLD_ERR interrupt in the Interrupt Status Register(CH1_IntStatusReg).</li> <li>■ 0x0 (NO_ACTION): Inactive signal. No action taken.</li> </ul> <p><b>Value After Reset:</b> 0x0<br/><b>Exists:</b> Always</p>                              |
| 20    | Clear_SLVIF_SHADOWREG_WRON_VALID_ERR_IntStat | W             | <p>Shadow Register Write On Valid Error Interrupt Clear Bit.<br/>This bit is used to clear the corresponding channel interrupt status bit in CHx_INTSTATUSREG.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1<br/>(CLEAR_SLVIF_SHADOWREG_WRON_VALID_ERR): Clear the SLVIF_SHADOWREG_WRON_VALID_ERR interrupt in the Interrupt Status Register(CH1_IntStatusReg).</li> <li>■ 0x0 (NO_ACTION): Inactive signal. No action taken.</li> </ul> <p><b>Value After Reset:</b> 0x0<br/><b>Exists:</b> Always</p> |

**Table 5-42 Fields for Register: CHx\_INTCLEARREG (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name                             | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------|----------------------------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19   | Clear_SLVIF_WRONCHEN_ERR_IntStat | W             | <p>Slave Interface Write On Channel Enabled Error Interrupt Clear Bit.</p> <p>This bit is used to clear the corresponding channel interrupt status bit in CHx_INTSTATUSREG.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (CLEAR_SLVIF_WRONCHEN_ERR): Clear the SLVIF_WRONCHEN_ERR interrupt in the Interrupt Status Register(CH1_IntStatusReg).</li> <li>■ 0x0 (NO_ACTION): Inactive signal. No action taken.</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> |
| 18   | Clear_SLVIF_RD2RWO_ERR_Stat      | W             | <p>Slave Interface Read to write Only Error Interrupt Clear Bit.</p> <p>This bit is used to clear the corresponding channel interrupt status bit in CHx_INTSTATUSREG.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (CLEAR_SLVIF_RD2RWO_ERR): Clear the SLVIF_RD2RWO_ERR interrupt in the Interrupt Status Register(CH1_IntStatusReg).</li> <li>■ 0x0 (NO_ACTION): Inactive signal. No action taken.</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p>           |
| 17   | Clear_SLVIF_WR2RO_ERR_IntStat    | W             | <p>Slave Interface Write to Read Only Error Interrupt Clear Bit.</p> <p>This bit is used to clear the corresponding channel interrupt status bit in CHx_INTSTATUSREG.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (CLEAR_SLVIF_WR2RO_ERR): Clear the SLVIF_WR2RO_ERR interrupt in the Interrupt Status Register(CH1_IntStatusReg).</li> <li>■ 0x0 (NO_ACTION): Inactive signal. No action taken.</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p>             |

**Table 5-42 Fields for Register: CHx\_INTCLEARREG (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name                                       | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|--------------------------------------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16   | Clear_SLVIF_DEC_ERR_IntStat                | W             | <p>Slave Interface Decode Error Interrupt Clear Bit.<br/>This bit is used to clear the corresponding channel interrupt status bit in CHx_INTSTATUSREG.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (CLEAR_SLVIF_DEC_ERR): Clear the SLVIF_DEC_ERR interrupt in the Interrupt Status Register(CH1_IntStatusReg).</li> <li>■ 0x0 (NO_ACTION): Inactive signal. No action taken.</li> </ul> <p><b>Value After Reset:</b> 0x0<br/><b>Exists:</b> Always</p>                                       |
| 15   | RSVD_DMAC_CHx_INTCLEARREG_15               | W             | <p>DMAC Channelx Interrupt Clear Register (bit 15) Reserved bit - Read Only</p> <p><b>Value After Reset:</b> 0x0<br/><b>Exists:</b> Always</p>                                                                                                                                                                                                                                                                                                                                                                           |
| 14   | Clear_SLVIF_MULTIBLKTYPE_ERR_IntStat       | W             | <p>Slave Interface Multi Block type Error Interrupt Clear Bit.<br/>This bit is used to clear the corresponding channel interrupt status bit in CHx_INTSTATUSREG.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (CLEAR_SLVIF_MULTIBLKTYPE_ERR): Clear the SLVIF_MULTIBLKTYPE_ERR interrupt in the Interrupt Status Register(CH1_IntStatusReg).</li> <li>■ 0x0 (NO_ACTION): Inactive signal. No action taken.</li> </ul> <p><b>Value After Reset:</b> 0x0<br/><b>Exists:</b> Always</p>           |
| 13   | Clear_SHADOWREG_OR_LLI_INVALID_ERR_IntStat | W             | <p>Shadow register or LLI Invalid Error Interrupt Clear Bit.<br/>This bit is used to clear the corresponding channel interrupt status bit in CHx_INTSTATUSREG.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (CLEAR_SHADOWREG_OR_LLI_INVALID_ERR): Clear the SHADOWREG_OR_LLI_INVALID_ERR interrupt in the Interrupt Status Register(CH1_IntStatusReg).</li> <li>■ 0x0 (NO_ACTION): Inactive signal. No action taken.</li> </ul> <p><b>Value After Reset:</b> 0x0<br/><b>Exists:</b> Always</p> |

**Table 5-42 Fields for Register: CHx\_INTCLEARREG (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name                         | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|------------------------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12   | Clear_LLI_WR_SLV_ERR_IntStat | W             | <p>LLI WRITE Slave Error Interrupt Clear Bit.<br/>This bit is used to clear the corresponding channel interrupt status bit in CHx_INTSTATUSREG.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (CLEAR_LLI_WR_SLV_ERR): Clear the LLI_WR_SLV_ERR interrupt in the Interrupt Status Register(CH1_IntStatusReg).</li> <li>■ 0x0 (NO_ACTION): Inactive signal. No action taken.</li> </ul> <p><b>Value After Reset:</b> 0x0<br/><b>Exists:</b> Always</p>  |
| 11   | Clear_LLI_RD_SLV_ERR_IntStat | W             | <p>LLI Read Slave Error Interrupt Clear Bit.<br/>This bit is used to clear the corresponding channel interrupt status bit in CHx_INTSTATUSREG.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (CLEAR_LLI_RD_SLV_ERR): Clear the LLI_RD_SLV_ERR interrupt in the Interrupt Status Register(CH1_IntStatusReg).</li> <li>■ 0x0 (NO_ACTION): Inactive signal. No action taken.</li> </ul> <p><b>Value After Reset:</b> 0x0<br/><b>Exists:</b> Always</p>   |
| 10   | Clear_LLI_WR_DEC_ERR_IntStat | W             | <p>LLI WRITE Decode Error Interrupt Clear Bit.<br/>This bit is used to clear the corresponding channel interrupt status bit in CHx_INTSTATUSREG.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (CLEAR_LLI_WR_DEC_ERR): Clear the LLI_WR_DEC_ERR interrupt in the Interrupt Status Register(CH1_IntStatusReg).</li> <li>■ 0x0 (NO_ACTION): Inactive signal. No action taken.</li> </ul> <p><b>Value After Reset:</b> 0x0<br/><b>Exists:</b> Always</p> |
| 9    | Clear_LLI_RD_DEC_ERR_IntStat | W             | <p>LLI Read Decode Error Interrupt Clear Bit.<br/>This bit is used to clear the corresponding channel interrupt status bit in CHx_INTSTATUSREG.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (CLEAR_LLI_RD_DEC_ERR): Clear the LLI_RD_DEC_ERR interrupt in the Interrupt Status Register(CH1_IntStatusReg).</li> <li>■ 0x0 (NO_ACTION): Inactive signal. No action taken.</li> </ul> <p><b>Value After Reset:</b> 0x0<br/><b>Exists:</b> Always</p>  |

**Table 5-42 Fields for Register: CHx\_INTCLEARREG (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name                      | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|---------------------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8    | Clear_DST_SLV_ERR_IntStat | W             | <p>Destination Slave Error Interrupt Clear Bit.<br/>This bit is used to clear the corresponding channel interrupt status bit in CHx_INTSTATUSREG.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (CLEAR_DST_SLV_ERR): Clear the DST_SLV_ERR interrupt in the Interrupt Status Register(CH1_IntStatusReg).</li> <li>■ 0x0 (NO_ACTION): Inactive signal. No action taken.</li> </ul> <p><b>Value After Reset:</b> 0x0<br/><b>Exists:</b> Always</p>  |
| 7    | Clear_SRC_SLV_ERR_IntStat | W             | <p>Source Slave Error Interrupt Clear Bit.<br/>This bit is used to clear the corresponding channel interrupt status bit in CHx_INTSTATUSREG.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (CLEAR_SRC_SLV_ERR): Clear the SRC_SLV_ERR interrupt in the Interrupt Status Register(CH1_IntStatusReg).</li> <li>■ 0x0 (NO_ACTION): Inactive signal. No action taken.</li> </ul> <p><b>Value After Reset:</b> 0x0<br/><b>Exists:</b> Always</p>       |
| 6    | Clear_DST_DEC_ERR_IntStat | W             | <p>Destination Decode Error Interrupt Clear Bit.<br/>This bit is used to clear the corresponding channel interrupt status bit in CHx_INTSTATUSREG.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (CLEAR_DST_DEC_ERR): Clear the DST_DEC_ERR interrupt in the Interrupt Status Register(CH1_IntStatusReg).</li> <li>■ 0x0 (NO_ACTION): Inactive signal. No action taken.</li> </ul> <p><b>Value After Reset:</b> 0x0<br/><b>Exists:</b> Always</p> |
| 5    | Clear_SRC_DEC_ERR_IntStat | W             | <p>Source Decode Error Interrupt Clear Bit.<br/>This bit is used to clear the corresponding channel interrupt status bit in CHx_INTSTATUSREG.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (CLEAR_SRC_DEC_ERR): Clear the SRC_DEC_ERR interrupt in the Interrupt Status Register(CH1_IntStatusReg).</li> <li>■ 0x0 (NO_ACTION): Inactive signal. No action taken.</li> </ul> <p><b>Value After Reset:</b> 0x0<br/><b>Exists:</b> Always</p>      |

**Table 5-42 Fields for Register: CHx\_INTCLEARREG (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| Bits | Name                        | Memory Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|-----------------------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4    | Clear_DST_TRANSCOMP_IntStat | W             | <p>Destination Transaction Completed Interrupt Clear Bit. This bit is used to clear the corresponding channel interrupt status bit in CHx_INTSTATUSREG.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (CLEAR_DST_TRANSCOMP): Clear the DST_TRANSCOMP interrupt in the Interrupt Status Register(CH1_IntStatusReg).</li> <li>■ 0x0 (NO_ACTION): Inactive signal. No action taken.</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> |
| 3    | Clear_SRC_TRANSCOMP_IntStat | W             | <p>Source Transaction Completed Interrupt Clear Bit. This bit is used to clear the corresponding channel interrupt status bit in CHx_INTSTATUSREG.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (CLEAR_SRC_TRANSCOMP): Clear the SRC_TRANSCOMP interrupt in the Interrupt Status Register(CH1_IntStatusReg).</li> <li>■ 0x0 (NO_ACTION): Inactive signal. No action taken.</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p>      |
| 2    | RSVD_DMACHx_INTCLEARREG_2   | W             | <p>DMAC Channelx Interrupt Clear Register (bit 2) Reserved bit - Read Only</p> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p>                                                                                                                                                                                                                                                                                                                                       |
| 1    | Clear_DMA_TFR_DONE_IntStat  | W             | <p>DMA Transfer Done Interrupt Clear Bit. This bit is used to clear the corresponding channel interrupt status bit in CHx_INTSTATUSREG.</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (CLEAR_DMA_TFR_DONE): Clear the DMA_TFR_DONE interrupt in the Interrupt Status Register(CH1_IntStatusReg).</li> <li>■ 0x0 (NO_ACTION): Inactive signal. No action taken.</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p>                   |

**Table 5-42 Fields for Register: CHx\_INTCLEARREG (for x = 1; x <= DMAX\_NUM\_CHANNELS) (Continued)**

| <b>Bits</b> | <b>Name</b>                   | <b>Memory Access</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------------|-------------------------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0           | Clear_BLOCK_TFR_DONE_IntSt at | W                    | <p>Block Transfer Done Interrupt Clear Bit.<br/>This bit is used to clear the corresponding channel interrupt status bit in CH1_INTSTATUSREG</p> <p><b>Values:</b></p> <ul style="list-style-type: none"> <li>■ 0x1 (CLEAR_BLOCK_TFR_DONE): Clear the interrupt in the Interrupt Status Register(CHx_IntStatusReg). Writing a 1 to this register field clears the corresponding bit in the CHx_IntStatusReg register.</li> <li>■ 0x0 (NO_ACTION): Inactive signal. No action taken.</li> </ul> <p><b>Value After Reset:</b> 0x0</p> <p><b>Exists:</b> Always</p> |

Synopsys confidential document, provided to Blue Ocean Smart under NDA, do not redistribute

## 6

# Internal Parameter Descriptions

Provides a description of the internal parameters that might be indirectly referenced in expressions in the Signals, Parameters, or Registers chapters. These parameters are not visible in the coreConsultant GUI and most of them are derived automatically from visible parameters. **You must not set any of these parameters directly.**

Some expressions might refer to TCL functions or procedures (sometimes identified as **function\_of**) that coreConsultant uses to make calculations. The exact formula used by these TCL functions is not provided in this chapter. However, when you configure the core in coreConsultant, all TCL functions and parameters are evaluated completely; and the resulting values are displayed where appropriate in the coreConsultant GUI reports.

**Table 6-1 Internal Parameters**

| Parameter Name             | Equals To                                                                                               |
|----------------------------|---------------------------------------------------------------------------------------------------------|
| DMAX_AXI_ID_SUFFIX_WIDTH   | = (DMAX_M_ID_WIDTH - (DMAX_HAS_LLI_PARAM == 1 ? (LOG2_DMAX_NUM_CHANNELS + 1) : LOG2_DMAX_NUM_CHANNELS)) |
| DMAX_AXI_LOCK_WIDTH        | =(DMAX_MSTIF_MODE ==0 ? 2: 1)                                                                           |
| DMAX_COMP_VER              | 64'h0000_0000_3130_322a                                                                                 |
| DMAX_HAS_LLI_PARAM         | {[function_of : DMAX_NUM_CHANNELS, DMAX_CH(x)_MULTI_BLK_EN, DMAX_CH(x)_MULTI_BLK_TYPE]}                 |
| DMAX_HS_CLKRST_WIDTH       | =(DMAX_HS_SAME_ASYNC_CLK ==1 ? 1: DMAX_NUM_HS_IF)                                                       |
| DMAX_NUM_CHANNELS_MUL_3    | DMAX_NUM_CHANNELS*3                                                                                     |
| LOG2_2_DMAX_NUM_CHANNELS   | {1 + [function_of: DMAX_NUM_CHANNELS ]}                                                                 |
| LOG2_3_DMAX_NUM_CHANNELS   | {[function_of: DMAX_NUM_CHANNELS_MUL_3 ]}                                                               |
| LOG2_DMAX_ARB_RD_REQ_WIDTH | = ((DMAX_HAS_LLI_PARAM ==1) ? LOG2_3_DMAX_NUM_CHANNELS : LOG2_2_DMAX_NUM_CHANNELS)                      |

**Table 6-1 Internal Parameters (Continued)**

| Parameter Name             | Equals To                                                                          |
|----------------------------|------------------------------------------------------------------------------------|
| LOG2_DMAX_ARB_WR_REQ_WIDTH | = ((DMAX_HAS_LLI_PARAM ==1) ? LOG2_3_DMAX_NUM_CHANNELS : LOG2_2_DMAX_NUM_CHANNELS) |
| LOG2_DMAX_NUM_CHANNELS     | {[function_of: DMAX_NUM_CHANNELS ]}                                                |
| LOG2_DMAX_NUM_HS_IF        | {[function_of: DMAX_NUM_HS_IF ]}                                                   |
| DMAX_CH(x)_STW_ENC         | {[function_of : DMAX_CH(x)_STW"]}                                                  |
| DMAX_CH(x)_DTW_ENC         | {[function_of : DMAX_CH(x)_DTW"]}                                                  |

# Programming the DW\_axi\_dmac

The DW\_axi\_dmac can be programmed through software registers or the DW\_axi\_dmac low-level software driver; software registers are described in more detail in “[Register Descriptions](#)” on page [159](#).

## 7.1 Programming Flow for Shadow-Register-Based Multi-Block Transfer

1. Software reads the DMAC channel enable register (DMAC\_ChEnReg) to select an available (unused) channel.
2. Software programs the CHx\_CFG register with appropriate values for the DMA transfer.

The SRC\_MLTBLK\_TYPE and/or DST\_MLTBLK\_TYPE bits must be set to 2'b10.



- The CHx\_CFG register must be programmed before programming the CHx\_SAR, CHx\_DAR, CHx\_BLOCK\_TS, or CHx\_CTL registers, as the value of the SRC\_MLTBLK\_TYPE and/or DST\_MLTBLK\_TYPE fields are used for accessing the shadow registers.
- If the slave interface data bus width or transfer size is less than 64 bits, CHx\_CFG[7:0] should be updated in the first write to the CHx\_CFG register.

3. Software programs the CHx\_SAR and/or CHx\_DAR, CHx\_BLOCK\_TS, and CHx\_CTL registers with appropriate values for the first block.

DW\_axi\_dmac loads the corresponding shadow registers with these values.

The CHx\_CTL register must be the last register to be programmed with the ShadowReg\_Or\_LLI\_Valid bit set to 1 to indicate that the shadow register contents are valid. If the slave interface data bus width or transfer size is less than 64 bits, CHx\_CTL[63:56] must be updated last.

4. Software enables the channel by writing 1 to the appropriate bit location in the DMAC\_ChEnReg register.



It is possible to swap the sequence of [step 3](#) and [step 4](#). However, if [step 4](#) is performed before [step 3](#), DW\_axi\_dmac might generate a ShadowReg\_Or\_LLI\_Invalid\_ERR interrupt if the value of the ShadowReg\_Or\_LLI\_Valid bit is 0 during the shadow register fetch phase.

5. DW\_axi\_dmac initiates the DMA block transfer operation based on the settings for the block transfer.
  - a. The block transfer might start immediately or after the hardware or software handshaking request, depending on the value of the TT\_FC field in the CHx\_CFG register.
  - b. DW\_axi\_dmac checks CHx\_CTL\_ShadowReg.ShadowReg\_Or\_LLI\_Valid bit and if it is seen as '0', DW\_axi\_dmac waits till software writes (any value) to CHx\_BLK\_TFR\_ResumeReqReg to indicate valid LLI availability, before attempting another Shadow Register fetch operation. DW\_axi\_dmac might generate 'ShadowReg\_Or\_LLI\_Invalid\_ERR' Interrupt in this case.
  - c. DW\_axi\_dmac checks CHx\_CTL\_ShadowReg.ShadowReg\_Or\_LLI\_Valid bit and if it is seen as '1,' DW\_axi\_dmac copies the shadow register contents to the registers used for executing the DMA block transfer (CHx\_SAR and/or CHx\_DAR, CHx\_BLOCK\_TS and CHx\_CTL registers) and clears the ShadowReg\_Or\_LLI\_Valid bit in CHx\_CTL and CHx\_CTL\_ShadowReg registers to 0.
    - i. If DW\_axi\_dmac sees CHx\_CTL.ShadowReg\_Or\_LLI\_Last bit of the copied Shadow Register as 1, it understands that the current block is the final block in the transfer and completes the DMA transfer operation at the end of current block transfer.
    - ii. If DW\_axi\_dmac sees CHx\_CTL.ShadowReg\_Or\_LLI\_Last bit of the copied Shadow Register as 0, it understands that there are one or more blocks to be transferred and checks CHx\_CTL\_ShadowReg.ShadowReg\_Or\_LLI\_Valid bit again at the end of current block transfer.
6. Software polls the ShadowReg\_Or\_LLI\_Valid bit in the CHx\_CTL register till it is 0.
  - a. DW\_axi\_dmac clears this bit to 0 only after copying the shadow register contents to the registers used for executing the DMA block transfer (that is, the CHx\_SAR and/or CHx\_DAR, CHx\_BLOCK\_TS, and CHx\_CTL registers).
  - b. Software must program the shadow registers with a new set of values only after the ShadowReg\_Or\_LLI\_Valid bit is set to 0.
  - c. If software tries to programs the shadow registers when the ShadowReg\_Or\_LLI\_Valid bit is set to 1, DW\_axi\_dmac ignores this write operation, sets the SLVIF\_ShadowReg\_WrOnValid\_ERR bit of the CHx\_IntStatusReg register to 1, and generates an interrupt (if the corresponding interrupt generation is not masked off).
7. Software programs the CHx\_SAR and/or CHx\_DAR, CHx\_BLOCK\_TS, and CHx\_CTL registers with appropriate values for the next block.
  - a. The CHx\_CTL register must be the last register to be programmed with the ShadowReg\_Or\_LLI\_Valid bit set to 1 to indicate that the shadow register contents are valid.
  - b. If current block is the final block in the transfer, S/W must set CHx\_CTL.ShadowReg\_Or\_LLI\_Last bit to 1.
  - c. The DMA block transfer corresponding to the previous shadow register contents may be in progress during this time.
  - d. DW\_axi\_dmac loads the corresponding shadow registers with these new values.
8. DW\_axi\_dmac initiates the DMA block transfer operation based on the settings for the block transfer.
  - a. Based on the settings of TT\_FC field in CHx\_CFG register, the block transfer might start immediately or after the hardware/software handshaking request.

- b. DW\_axi\_dmac checks CHx\_CTL\_ShadowReg.ShadowReg\_Or\_LLI\_Valid bit and if it is seen as 0, DW\_axi\_dmac waits until software writes (any value) to CHx\_BLK\_TFR\_ResumeReqReg to indicate valid LLI availability, before attempting another Shadow Register fetch operation. DW\_axi\_dmac might generate ShadowReg\_Or\_LLI\_Invalid\_ERR Interrupt in this case.
  - c. DW\_axi\_dmac checks CHx\_CTL\_ShadowReg.ShadowReg\_Or\_LLI\_Valid bit and if it is seen as 1, DW\_axi\_dmac copies the shadow register contents to the registers used for executing the DMA block transfer (CHx\_SAR and/or CHx\_DAR, CHx\_BLOCK\_TS and CHx\_CTL registers) and clears the ShadowReg\_Or\_LLI\_Valid bit in CHx\_CTL and CHx\_CTL\_ShadowReg registers to 0.
  - d. If DW\_axi\_dmac sees CHx\_CTL.ShadowReg\_Or\_LLI\_Last bit of the copied Shadow Register as 1, it understands that the current block is the final block in the transfer and completes the DMA transfer operation at the end of current block transfer.
  - e. If DW\_axi\_dmac sees CHx\_CTL.ShadowReg\_Or\_LLI\_Last bit of the copied Shadow Register as 0, it understands that there are one or more blocks to be transferred and checks CHx\_CTL\_ShadowReg.ShadowReg\_Or\_LLI\_Valid bit again at the end of current block transfer.
9. Software waits for the block transfer completion interrupt or polls the block transfer completion indication bit (BLOCK\_TFR\_DONE) of the CHx\_IntStatusReg register until it is set to 1.
10. On block transfer completion:
- a. DW\_axi\_dmac checks CHx\_CTL\_ShadowReg.ShadowReg\_Or\_LLI\_Valid bit and if it is seen as 0, DW\_axi\_dmac waits until software writes (any value) to CHx\_BLK\_TFR\_ResumeReqReg to indicate valid LLI availability, before attempting another Shadow Register fetch operation. DW\_axi\_dmac might generate a ShadowReg\_Or\_LLI\_Invalid\_ERR Interrupt in this case.
  - b. DW\_axi\_dmac checks CHx\_CTL\_ShadowReg.ShadowReg\_Or\_LLI\_Valid bit and if it is seen as 1, DW\_axi\_dmac copies the shadow register contents to the registers used for executing the DMA block transfer (CHx\_SAR and/or CHx\_DAR, CHx\_BLOCK\_TS and CHx\_CTL registers) and clears ShadowReg\_Or\_LLI\_Valid bit in CHx\_CTL and CHx\_CTL\_ShadowReg registers to 0.
    - If CHx\_CTL.ShadowReg\_Or\_LLI\_Last bit of the copied Shadow Register is 1, it understands that the current block is the final block in the transfer and completes the DMA transfer operation.
    - If CHx\_CTL.ShadowReg\_Or\_LLI\_Last bit of the copied Shadow Register is 0, it understands that there are one or more blocks to be transferred and checks CHx\_CTL\_ShadowReg.ShadowReg\_Or\_LLI\_Valid bit again at the end of current block transfer.
  - c. If there are one or more blocks to be transferred, software polls CHx\_CTL.ShadowReg\_Or\_LLI\_Valid bit until it is seen as 0 and go to step 7.

One read operation is enough as DW\_axi\_dmac should have already copied the shadow register contents and cleared this bit to 0.



**Note** In case when ShadowReg\_Or\_LLI\_Invalid\_ERR is generated the recommended flow to resume transfer is:

- Software programs CHx\_SAR and/or CHx\_DAR, CHx\_BLOCK\_TS and CHx\_CTL registers with appropriate values for the next block.
- Clear the interrupt using interrupt register CHx\_IntClearReg.
- Program block resume request CHx\_BLK\_TFR\_ResumeReqReg.

## 7.2 Programming Flow for Linked-List-Based Multi-Block Transfer

1. Software reads the DMAC channel enable register (DMAC\_ChEnReg) to select an available (unused) channel.
2. Software programs the CHx\_CFG register with appropriate values for the DMA transfer.  
The SRC\_MLTBLK\_TYPE and/or DST\_MLTBLK\_TYPE bits must be set to 2'b11.
3. Software programs the base address of the first linked list item and the master interface on which the linked list item is available in the CHx\_LLlP register.
4. Software creates one or more linked list items in system memory. Software can create the entire linked list item in advance or dynamically extend the linked list using the CHx\_CTL.ShadowReg\_Or\_LLI\_Valid and CHx\_CTL.LLI\_Last fields of the LLI.
5. Software enables the channel by writing 1 to the appropriate bit location in DMAC\_ChEnReg register.



**Note** It is possible to swap the sequence of **step 4** and **step 5**. However, if **step 5** is performed before **step 4**, or if the linked list item for the next block transfer is not available in system memory at any time during the multiblock transfer, as indicated by CHx\_CTL.ShadowReg\_Or\_LLI\_Valid bit of the fetched LLI being set to 0, DW\_axi\_dmac might generate a ShadowReg\_Or\_LLI\_Invalid\_ERR interrupt.

6. DW\_axi\_dmac initiates the DMA block transfer operation based on the settings for the block transfer. The block transfer might start immediately or after the hardware or software handshaking request, depending on the settings of the TT\_FC field in the CHx\_CFG register. DW\_axi\_dmac copies the linked list contents to the registers used for executing the DMA block transfer (that is, the CHx\_SAR and/or CHx\_DAR, CHx\_BLOCK\_TS, and CHx\_CTL registers) and initiates the DMA block transfer.
7. During the linked list fetch phase:
  - a. If DW\_axi\_dmac sees CHx\_CTL.ShadowReg\_Or\_LLI\_Last bit of the fetched LLI as 1, it understands that the current block is the final block in the transfer and completes the DMA transfer operation at the end of current block transfer.
  - b. If DW\_axi\_dmac sees CHx\_CTL.ShadowReg\_Or\_LLI\_Last bit of the fetched LLI as 0, it understands that there are one or more blocks to be transferred and goes to step 6.
  - c. If DW\_axi\_dmac sees CHx\_CTL.ShadowReg\_Or\_LLI\_Valid bit of the fetched LLI as 0, DW\_axi\_dmac might generate ShadowReg\_Or\_LLI\_Invalid\_ERR Interrupt. DW\_axi\_dmac waits till software writes (any value) to CHx\_BLK\_TFR\_ResumeReqReg to indicate valid LLI availability, before attempting another LLI read operation.

## 7.3 Programming Flow for Single Block Transfer

1. Software reads the DMAC Channel Enable Register (DMAC\_ChEnReg) to choose a free (unused) channel.

2. Software programs CHx\_CFG register with multi-block type value of both source and destination peripheral to be 2'b00.
3. Software programs CHx\_SAR and/or CHx\_DAR, CHx\_BLOCK\_TS and CHx\_CTL registers with appropriate values for the block.
4. Software enables the channel by writing 1 to the appropriate bit location in DMAC\_ChEnReg register.
5. Source and destination requests single or burst DMA transactions to transfer the block of data (assuming non-memory peripherals). The DW\_axi\_dmac acknowledges at the completion of every transaction (burst and single) in the block and carries out the block transfer.
6. Software waits for the block transfer completion interrupt/polls the block transfer completion indication bit (BLOCK\_TFR\_DONE) in CHx\_IntStatusReg register till the bit is 1.

Synopsys confidential document, provided to Blue Ocean Smart under NDA, do not redistribute

## 8

# Verification

This chapter provides an overview of the testbench available for DW\_axi\_dmac verification. Once the DW\_axi\_dmac has been configured and the verification environment set up, simulations can be run automatically. For information on running simulations for DW\_axi\_dmac in coreAssembler or coreConsultant, see “[Building and Verifying a Component or Subsystem](#)” on page [25](#).



**Note** The DW\_axi\_dmac verification testbench is built with DesignWare Verification IP (VIP). Ensure that you have the supported version of the VIP components for this release, otherwise, you may experience some tool compatibility problems. For more information about supported tools in this release, see the [DesignWare Synthesizable Components for AMBA 2, AMBA 3 AXI, and AMBA 4 AXI Installation Guide](#).

## 8.1 Overview of SV-UVM Tests

The DW\_axi\_dmac verification testbench (SV-UVM) performs the following tests that have been written to exhaustively verify the functionality:

- A single block transfer
- An LLP block chaining transfer (static and dynamic LLP)
- A reloading transfer
- A shadow transfer

Within each of these transfers, all parameters are randomized. The testbench constantly verifies whether conditions including the following are met:

- Transfers are correct
- Registers are updated correctly
- Registers are written out correctly
- Interrupts are set correctly
- Flow control mode is not violated
- Bus and channel locking is correct
- Channel arbitration is correct

## 8.2 Overview of DW\_axi\_dmac Testbench

As illustrated in Figure 8-1, the DW\_axi\_dmac testbench is an SV-UVM testbench that includes:

- Verilog DUT (DW\_axi\_dmac)
- SV-UVM BFM (Interrupt handler, hardware/software handshake, Transfer Monitors)
- VIPs (AHB Master, bus, monitor and AXI Slaves, interconnect, and monitors)

**Figure 8-1 Verification Testbench Block Diagram**



The file, dmac\_top.sv, shows the instantiation of the top-level design in a testbench and resides in the “<workspace>/sim/testbench” directory. The testbench tests your configuration specified in the **Specify Configuration** task of coreConsultant and is self-checking. When a coreKit has been configured, the verification environment is stored in “<workspace>/sim”. Files in “<workspace>/sim/testbench” form the

actual testbench for DW\_axi\_dmac. The “<workspace>/sim/<test\_name>” directory contains the test\_name.sv file.

Synopsys confidential document, provided to Blue Ocean Smart under NDA, do not redistribute

Synopsys confidential document, provided to Blue Ocean Smart under NDA, do not redistribute

## 9

# Integration Considerations

After you have configured, tested, and synthesized your component with the coreTools flow, you can integrate the component into your own design environment.

## 9.1 Performance

This section discusses the performance and the hardware configuration parameters that affect the performance of the DW\_axi\_dmac.

### 9.1.1 Power Consumption, Frequency, and Area Results

The following section provides information about the synthesis results (power consumption, frequency, and area) of the DW\_axi\_dmac using the industry standard 28nm technology library and how it affects performance.

**Table 9-1** provides synthesis results for the configurations where DMAX\_CHx\_MULTI\_BLK\_TYPE is set to 0.

**Table 9-1 Synthesis Results for DW\_axi\_dmac Where DMAX\_CHx\_MULTI\_BLK\_TYPE = 0**

| Configuration                                                                                                                                                                         | Operating Frequency (in MHz)                                                    | Gate Count   | Leakage Power consumption | Dynamic Power consumption |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|--------------|---------------------------|---------------------------|
| Number of masters = 1<br>Number of channels = 1<br>FIFO depth of each channel = 8<br>Slave clock synchronous to core<br>Master clock synchronous to core<br>(Default configuration)   | Core clock- 400                                                                 | 20084 gates  | 318 nW                    | 2.219 mW                  |
| Number of masters = 1<br>Number of channels = 8<br>Number of Handshakes = 16<br>FIFO depth of each channel = 8<br>Slave clock synchronous to core<br>Master clock synchronous to core | Core clock- 400<br>Master 1 clock- 400<br>Master 2 clock-400<br>Slave clock-300 | 125037 gates | 1.92 uW                   | 12.3 mW                   |

| Configuration                                                                                                                                                                                                                                                      | Operating Frequency (in MHz)                                                       | Gate Count   | Leakage Power consumption | Dynamic Power consumption |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|--------------|---------------------------|---------------------------|
| Number of masters = 1<br>Number of channels = 16<br>Number of Handshakes = 32<br>FIFO depth of each channel = 8<br>Slave clock synchronous to core<br>Master clock synchronous to core                                                                             | Core clock- 400<br>Slave clock-300                                                 | 249952 gates | 3.87 uW                   | 23.7 mW                   |
| Number of masters = 2<br>Number of channels = 16<br>Number of Handshakes = 32<br>FIFO depth of each channel = 64<br>Slave clock asynchronous to core<br>Master clock asynchronous to core                                                                          | Core clock- 400<br>Master 1 clock- 400<br>Master 2 clock- 400<br>Slave clock - 300 | 532841 gates | 8.53 uW                   | 62.4 mW                   |
| Number of masters = 2<br>Number of channels = 16<br>Number of Handshakes = 32<br>FIFO depth of each channel = 64<br>Low Power Enable = 1 (Global CSLP, Channel CSLP, SBIU CSLP, AXI CSLP)<br>Slave clock asynchronous to core<br>Master clock asynchronous to core | Core clock- 400<br>Master 1 clock- 400<br>Master 2 clock- 400<br>Slave clock-300   | 538978 gates | 8.75 uW                   | 23.0 mW                   |

The following table provides synthesis results for configurations where DMAX\_CHx\_MULTI\_BLK\_TYPE is set to 1.

**Table 9-2 Synthesis Results for DW\_axi\_dmac Where DMAX\_CHx\_MULTI\_BLK\_TYPE = 1**

| Configuration                                                                                                                                                                         | Operating Frequency (in MHz)                                                    | Gate Count   | Leakage Power consumption | Dynamic Power consumption |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|--------------|---------------------------|---------------------------|
| Number of masters = 1<br>Number of channels = 1<br>FIFO depth of each channel = 8<br>Slave clock synchronous to core<br>Master clock synchronous to core<br>(Default configuration)   | Core clock- 400                                                                 | 23554 gates  | 370 nW                    | 2.56 mW                   |
| Number of masters = 1<br>Number of channels = 8<br>Number of Handshakes = 16<br>FIFO depth of each channel = 8<br>Slave clock synchronous to core<br>Master clock synchronous to core | Core clock- 400<br>Master 1 clock- 400<br>Master 2 clock-400<br>Slave clock-300 | 153083 gates | 2.36 uW                   | 15.1 mW                   |

| Configuration                                                                                                                                                                                                                                                      | Operating Frequency (in MHz)                                                      | Gate Count   | Leakage Power consumption | Dynamic Power consumption |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|--------------|---------------------------|---------------------------|
| Number of masters = 1<br>Number of channels = 16<br>Number of Handshakes = 32<br>FIFO depth of each channel = 8<br>Slave clock synchronous to core<br>Master clock synchronous to core                                                                             | Core clock- 400<br>Master 1 clock- 400<br>Master 2 clock- 400<br>Slave clock-300  | 306349 gates | 4.74 uW                   | 29.3 mW                   |
| Number of masters = 2<br>Number of channels = 16<br>Number of Handshakes = 32<br>FIFO depth of each channel = 64<br>Slave clock asynchronous to core<br>Master clock asynchronous to core                                                                          | Core clock- 400<br>Master 1 clock- 400<br>Master 2 clock- 400<br>Slave clock- 300 | 593210 gates | 9.55 uW                   | 68 mW                     |
| Number of masters = 2<br>Number of channels = 16<br>Number of Handshakes = 32<br>FIFO depth of each channel = 64<br>Low Power Enable = 1 (Global CSLP, Channel CSLP, SBIU CSLP, AXI CSLP)<br>Slave clock asynchronous to core<br>Master clock asynchronous to core | Core clock- 400<br>Master 1 clock- 400<br>Master 2 clock- 400<br>Slave clock- 300 | 600259 gates | 9.86 uW                   | 32.1 mW                   |

## 9.2 4K Boundary Crossing

The AXI protocol requires that any AXI burst does not cross a 4KB address boundary. DW\_axi\_dmac handles this situation automatically. If a DMA transfer is set up by software such that during the transfer, an AXI transfer crosses a 4KB boundary, DW\_axi\_dmac will automatically set up the AXI transfers such that the end of the 4KB boundary completes one AXI transfer and the beginning of the 4KB boundary starts another AXI transfer.

## 9.3 Read Accesses

For reads, registers less than the full access width return zeros in the unused upper bits. All registers in DW\_axi\_dmac are READ and WRITE in DW\_axi\_dmac core clock domain. Therefore, the time taken for the reads or writes to complete depends on the slave interface clock mode (parameter DMAX\_SLVIF\_CLOCK\_MODE).

### 9.3.1 Slave Interface Clock is Synchronous to the DW\_axi\_dmac Core Clock

When a slave interface clock is synchronous to the core clock, synchronization is not required. In this case, an AHB read takes two hclk cycles. The two cycles can be a control and data cycle, respectively. As shown in [Figure 9-1](#), the address and control is driven from clock 1 (control cycle); the read data for this access is driven by the slave interface onto the bus from clock 2 (data cycle) and is sampled by the master on clock 3.

The operation of the AHB bus is pipelined, so while the read data from the first access is present on the bus for the master to sample, the control for the next access is present on the bus for the slave to sample.

**Figure 9-1 AHB Read When Slave Clock is Synchronous to DW\_axi\_dmac Core Clock**



### 9.3.2 Slave Interface Clock is Asynchronous to DW\_axi\_dmac Core Clock

When a slave interface clock is asynchronous to DW\_axi\_dmac core clock, synchronization occurs in between each read operation. Once the read request is made on the slave interface, it is synchronized in DW\_axi\_dmac core clock domain and then response from register interface is synchronized back in the slave clock domain. Therefore, the data is driven on the slave interface only after the synchronization delay from slave interface clock to DW\_axi\_dmac core clock and the synchronization delay from DW\_axi\_dmac core clock to slave interface clock. Until then, hready\_resp is driven low on AHB interface. As shown in [Figure 9-2](#), the address and control for the first read is driven on clock 1; on clock 2 controls for next read is driven on the bus but hready\_resp is pulled down by DW\_axi\_dmac. After synchronization delay on clock

3, data for first read is driven on the bus by DW\_axi\_dmac and in similar manner reads following that happens.

**Figure 9-2 AHB Read When Slave Clock is Asynchronous to DW\_axi\_dmac Core Clock**



## 9.4 Write Accesses

When writing to a register, bit locations larger than the register width or allocation are ignored. Only pertinent bits are written to the register. Similar to read access, write access time is also dependent on the slave interface clock mode (parameter DMAX\_SLVIF\_CLOCK\_MODE).

### 9.4.1 Slave Interface Clock is Synchronous to DW\_axi\_dmac Core Clock

Similar to read, a write access may be thought of as comprising a control and data cycle. As illustrated [Figure 9-3](#), the address and control are driven from clock1 (control cycle), and the write data is driven by the bus from clock 2 (data cycle) and sampled by the destination register on clock 3.

**Figure 9-3 AHB Write When Slave Clock is Synchronous to DW\_axi\_dmac Core Clock**



### 9.4.2 Slave Interface Clock is Asynchronous to DW\_axi\_dmac Core Clock

Similar to read, in this case also write requests are first synchronized in DW\_axi\_dmac core clock domain and then response is again synchronized to slave clock domain. Therefore, acceptance of next write and response only happens after synchronization delay from slave interface clock to DW\_axi\_dmac core clock and after synchronization delay from DW\_axi\_dmac core clock to slave interface clock. Until then, hready\_resp signal is driven low by DW\_axi\_dmac. As shown in [Figure 9-4](#), control is driven by AHB master on clock 1 and data along with control information for second write is driven on clock 2; at clock 2 DW\_axi\_dmac pulls down hready\_resp to 0 indicating that current data and control has not yet been accepted. After synchronization delay on clock 3, hready\_resp is asserted indicating that current data has been written. At clock 4, AHB master samples hready\_resp and drives data from previous address and next control information.

**Figure 9-4 AHB Write When Slave Clock is Asynchronous to DW\_axi\_dmac Core Clock**

## 9.5 Consecutive Write-Read

This is a specific case for the AHB slave interface (only applicable when slave interface clock is synchronous to DW\_axi\_dmac core clock). The AMBA specification mentions that for a read after a write to the same address, the newly written data must be read back, and not the old data. To comply with this, the slave interface in the DW\_axi\_dmac inserts a "wait state" when it detects a read immediately after a write to the

same address. As shown in [Figure 9-5](#), the control for a write is driven on clock 1, followed by the write data and the control for a read from the same address on clock 2.

**Figure 9-5 AHB Wait State Read/Write**



## 9.6 Accessing Top-Level Constraints

To get SDC constraints from coreConsultant (cC), you need to first complete the synthesis activity and then use the "write\_sdc" command to write out the results:

1. This cC command sets synthesis to write out scripts only, without running DC:

```
set_activity_parameter Synthesize ScriptsOnly 1
```

2. This cC command autocompletes the activity:

```
autocomplete_activity Synthesize
```

3. Finally, this cC command writes out SDC constraints:

```
write_sdc <filename>
```

# A

## Synchronizer Methods

---

This appendix describes the synchronizer methods (blocks of synchronizer functionality) that are used in the DW\_axi\_dmac to cross clock boundaries.

This appendix contains the following sections:

- “Synchronizers used in DW\_axi\_dmac” on page 486
- “Synchronizer 1: Simple Double Register Synchronizer” on page 487
- “Synchronizer 2: Dual Clock Pulse Synchronizer” on page 488
- “Synchronizer 3: Pulse Synchronizer with Acknowledge” on page 489
- “Synchronizer 4: Reset Sequence Synchronizer” on page 490
- “Synchronizer 5: Dual Clock FIFO Controller with Static Flags” on page 491



**Note** The DesignWare Building Blocks (DWBB) contains several synchronizer components with functionality similar to methods documented in this appendix. For more information about the DWBB synchronizer components go to:  
<https://www.synopsys.com/dw/buildingblock.php>

---

## A.1 Synchronizers used in DW\_axi\_dmac

Each of the synchronizers and synchronizer sub-modules are comprised of verified DesignWare Basic Core (BCM) RTL designs. The BCM synchronizer designs are identified by the synchronizer type. The corresponding RTL files comprising the BCM synchronizers used in the DW\_axi\_dmac are listed and cross referenced to the synchronizer type in [Table A-1](#). Note that certain BCM modules are contained in other BCM modules, as they are used in a building block fashion.

**Table A-1 Synchronizer used in DW\_axi\_dmac**

| Synchronizer module file | Sub module file                            | Synchronizer Type and Number                                             |
|--------------------------|--------------------------------------------|--------------------------------------------------------------------------|
| DW_axi_dmac_bcm21.v      |                                            | Synchronizer 1: Simple Multiple register synchronizer                    |
| DW_axi_dmac_bcm22.v      | DW_axi_dmac_bcm21.v                        | Synchronizer 2: Dual Clock Pulse Synchronizer                            |
| DW_axi_dmac_bcm23.v      | DW_axi_dmac_bcm21.v                        | Synchronizer 3: Pulse Synchronizer with Acknowledge                      |
| DW_axi_dmac_bcm37.v      | DW_axi_dmac_bcm22.v<br>DW_axi_dmac_bcm21.v | Synchronizer 3: Reset Sequence Synchronizer                              |
| DW_axi_dmac_bcm07.v      | DW_axi_dmac_bcm05.v<br>DW_axi_dmac_bcm21.v | Synchronizer 4: Synchronous dual clock FIFO controller with Static Flags |



### Caution

Be cautious while choosing the depth (DMAX\_\*\_SYNC\_DEPTH) for different synchronization mechanisms as 1 (where the first stage - negative edge flip-flop is used and for the second stage - positive edge flip-flop is used). At higher frequencies, as the maximum time available for meta-stability resolution is halved with respect to the available clock period, this can lead to meta-stability - when synchronizer depth is selected as 1.

It is recommended to use the synchronizer depths that are greater than or equal to 2. The depth of 1 will be deprecated in the future releases.

## A.2 Synchronizer 1: Simple Double Register Synchronizer

This is a single clock data bus synchronizer for synchronizing data that crosses asynchronous clock boundaries. The synchronization scheme depends on core configuration. If aclk\_m1 or aclk\_m2 and dmac\_core\_clock are asynchronous (DMA\_MSTIF1(/2)\_CLOCK\_MODE = 1) then DW\_axi\_dmac\_bcm21 is instantiated inside the core for synchronization. The number of stages of synchronization is configurable through the parameters DMAX\_M1(/2)\_2\_C\_SYNC\_DEPTH and DMAX\_C\_2\_M1(/2)\_SYNC\_DEPTH. The following example shows the two stage synchronization process (Figure A-1) both using positive edge of clock.

**Figure A-1 Block Diagram of Synchronizer 1 with Two-Stage Synchronization (Both Positive Edges)**



The following example shows the three stage synchronization process (Figure A-2) both using positive edge of clock.

**Figure A-2 Block Diagram of Synchronizer 1 with Three Stage Synchronization (Both Positive Edge)**

### A.3 Synchronizer 2: Dual Clock Pulse Synchronizer

This is a dual clock pulse synchronizer which provides a low-risk method for transmitting single clock cycle pulses between two different clock domains. This synchronizer is used to synchronize the pulse between slave clock (hclk) domain to dmac\_core\_clock domain. The synchronizer will be instantiated when hclk is asynchronous with dmac\_core\_clock (DMAx\_SLVIF\_CLOCK\_MODE = 1). The number of stages of synchronization is configurable through the parameters DMAX\_S\_2\_C\_SYNC\_DEPTH and DMAX\_C\_2\_S\_SYNC\_DEPTH. [Figure A-3](#) shows the block diagram of Dual clock pulse synchronizer which uses DW\_axi\_bcm21 sub-module in design.

**Figure A-3 Dual Clock Pulse Synchronizer Block Diagram**

#### A.4 Synchronizer 3: Pulse Synchronizer with Acknowledge

Dual-clock pulse synchronizer with acknowledge, provides a low-risk method for transmitting single-clock cycle pulses between two different clock domains using acknowledge. The synchronization scheme depends on the core configuration. If `hs_clk[y-1]` and `dmac_core_clock` are asynchronous (`DMAX_HS(y)_ASYNC_CLK = 1`), then `DW_axi_dmac_bcm23` is instantiated inside the core for synchronization of the DMA Handshake signals. The number of stages of synchronization is configurable through the parameters `DMAX_HS_2_C_SYNC_DEPTH` and `DMAX_C_2_HS_SYNC_DEPTH`. [Figure A-4](#) shows the block diagram of Pulse Synchronizer with Acknowledge, which uses `DW_axi_dmac_bcm21` (`DW_sync`) sub-module in design.

**Figure A-4 Block Diagram of Pulse Synchronizer with Acknowledge**

## A.5 Synchronizer 4: Reset Sequence Synchronizer

This module provides a coordinated reset sequence to the source and destination domain logic when a "clear" is initiated by either domain. The synchronization scheme depends on core configuration. If **aclk\_m1/ aclk\_m2** and **dmac\_core\_clock** are asynchronous (**DMAX\_MSTIF1(/2)\_CLOCK\_MODE = 1**) then **DW\_axi\_dmac\_bcm37** is instantiated inside the core for synchronization. The number of stages of synchronization is configurable through the parameters **DMAX\_M1(/2)\_2\_C\_SYNC\_DEPTH** and **DMAX\_C\_2\_M1(/2)\_SYNC\_DEPTH**. [Figure A-5](#) shows the block diagram of Reset sequence synchronizer which uses **DW\_axi\_bcm21** and **DW\_axi\_bcm22** sub-modules in design.

**Figure A-5 Reset Sequence Synchronizer Block Diagram**

## A.6 Synchronizer 5: Dual Clock FIFO Controller with Static Flags

This module implements the functions required to implement a FIFO once connected to a RAM. The push and pop interfaces are in different clock domains. Gray coded pointers are used to pass information between domains. The synchronization scheme depends on core configuration. If `aclk_m1/aclk_m2` and `dmac_core_clock` are asynchronous (`DMAX_MSTIF1(/2)_CLOCK_MODE = 1`) then `DW_axi_dmac_bcm07` is instantiated inside the core for synchronization for data from `dmac_core_clock` domain to `aclk_m1/2` clock domain. The number of stages of synchronization is configurable through the parameters `DMAX_M1(/2)_2_C_SYNC_DEPTH` and `DMAX_C_2_M1(/2)_SYNC_DEPTH`. [Figure A-6](#) shows the block diagram of dual clock FIFO controller which used `DW_axi_bcm21` module to synchronize signals inside the module.

**Figure A-6** Dual Clock FIFO Controller Block Diagram



Synopsys confidential document, provided to Blue Ocean Smart under NDA, do not redistribute

**B****Glossary**

|                        |                                                                                                                                                                                                                                                          |
|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| active command queue   | Command queue from which a model is currently taking commands; see also command queue.                                                                                                                                                                   |
| application design     | Overall chip-level design into which a subsystem or subsystems are integrated.                                                                                                                                                                           |
| BFM                    | Bus-Functional Model — A simulation model used for early hardware debug. A BFM simulates the bus cycles of a device and models device pins, as well as certain on-chip functions. See also Full-Functional Model.                                        |
| big-endian             | Data format in which most significant byte comes first; normal order of bytes in a word.                                                                                                                                                                 |
| blocked command stream | A command stream that is blocked due to a blocking command issued to that stream; see also command stream, blocking command, and non-blocking command.                                                                                                   |
| blocking command       | A command that prevents a testbench from advancing to next testbench statement until this command executes in model. Blocking commands typically return data to the testbench from the model.                                                            |
| command channel        | Manages command streams. Models with multiple command channels execute command streams independently of each other to provide full-duplex mode function.                                                                                                 |
| command stream         | The communication channel between the testbench and the model.                                                                                                                                                                                           |
| component              | A generic term that can refer to any synthesizable IP or verification IP in the DesignWare Library. In the context of synthesizable IP, this is a configurable block that can be instantiated as a single entity (VHDL) or module (Verilog) in a design. |
| configuration          | The act of specifying parameters for a core prior to synthesis; can also be used in the context of VIP.                                                                                                                                                  |
| configuration intent   | Range of values allowed for each parameter associated with a reusable core.                                                                                                                                                                              |
| cycle command          | A command that executes and causes HDL simulation time to advance.                                                                                                                                                                                       |

|                      |                                                                                                                                                                                                                                                              |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| decoder              | Software or hardware subsystem that translates from and “encoded” format back to standard format.                                                                                                                                                            |
| design context       | Aspects of a component or subsystem target environment that affect the synthesis of the component or subsystem.                                                                                                                                              |
| design creation      | The process of capturing a design as parameterized RTL.                                                                                                                                                                                                      |
| DesignWare Library   | A collection of synthesizable IP and verification IP components that is authorized by a single DesignWare license. Products include SmartModels, VMT model suites, DesignWare Memory Models, Building Block IP, and the DesignWare Synthesizable Components. |
| dual role device     | Device having the capabilities of function and host (limited).                                                                                                                                                                                               |
| endian               | Ordering of bytes in a multi-byte word; see also little-endian and big-endian.                                                                                                                                                                               |
| Full-Functional Mode | A simulation model that describes the complete range of device behavior, including code execution. See also BFM.                                                                                                                                             |
| GPIO                 | General Purpose Input Output.                                                                                                                                                                                                                                |
| GTECH                | A generic technology view used for RTL simulation of encrypted source code by non-Synopsys simulators.                                                                                                                                                       |
| hard IP              | Non-synthesizable implementation IP.                                                                                                                                                                                                                         |
| HDL                  | Hardware Description Language – examples include Verilog and VHDL.                                                                                                                                                                                           |
| IIP                  | Implementation Intellectual Property — A generic term for synthesizable HDL and non-synthesizable “hard” IP in all of its forms (coreKit, component, core, MacroCell, and so on).                                                                            |
| implementation view  | The RTL for a core. You can simulate, synthesize, and implement this view of a core in a real chip.                                                                                                                                                          |
| instantiate          | The act of placing a core or model into a design.                                                                                                                                                                                                            |
| interface            | Set of ports and parameters that defines a connection point to a component.                                                                                                                                                                                  |
| IP                   | Intellectual property — A term that encompasses simulation models and synthesizable blocks of HDL code.                                                                                                                                                      |
| little-endian        | Data format in which the least-significant byte comes first.                                                                                                                                                                                                 |
| master               | Device or model that initiates and controls another device or peripheral.                                                                                                                                                                                    |
| model                | A Verification IP component or a Design View of a core.                                                                                                                                                                                                      |
| monitor              | A device or model that gathers performance statistics of a system.                                                                                                                                                                                           |
| non-blocking command | A testbench command that advances to the next testbench statement without waiting for the command to complete.                                                                                                                                               |

|                                        |                                                                                                                                                                           |
|----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| peripheral                             | Generally refers to a small core that has a bus connection, specifically an APB interface.                                                                                |
| RTL                                    | Register Transfer Level. A higher level of abstraction that implies a certain gate-level structure. Synthesis of RTL code yields a gate-level design.                     |
| SDRAM                                  | Synchronous Dynamic Random Access Memory; high-speed DRAM adds a separate clock signal to control signals.                                                                |
| SDRAM controller                       | A memory controller with specific connections for SDRAMs.                                                                                                                 |
| slave                                  | Device or model that is controlled by and responds to a master.                                                                                                           |
| SoC                                    | System on a chip.                                                                                                                                                         |
| soft IP                                | Any implementation IP that is configurable. Generally referred to as synthesizable IP.                                                                                    |
| static controller                      | Memory controller with specific connections for Static memories such as asynchronous SRAMs, Flash memory, and ROMs.                                                       |
| synthesis intent                       | Attributes that a core developer applies to a top-level design, ports, and core.                                                                                          |
| synthesizable IP                       | A type of Implementation IP that can be mapped to a target technology through synthesis. Sometimes referred to as Soft IP.                                                |
| technology-independent                 | Design that allows the technology (that is, the library that implements the gate and via widths for gates) to be specified later during synthesis.                        |
| Testsuite Regression Environment (TRE) | A collection of files for stand-alone verification of the configured component. The files, tests, and functionality vary from component to component.                     |
| VIP                                    | Verification Intellectual Property — A generic term for a simulation model in any form, including a Design View.                                                          |
| wrap, wrapper                          | Code, usually VHDL or Verilog, that surrounds a design or model, allowing easier interfacing. Usually requires an extra, sometimes automated, step to create the wrapper. |
| zero-cycle command                     | A command that executes without HDL simulation time advancing.                                                                                                            |

Synopsys confidential document, provided to Blue Ocean Smart under NDA, do not redistribute

# Index

## A

active command queue  
definition [493](#)

application design  
definition [493](#)

## B

BFM  
definition [493](#)

big-endian  
definition [493](#)

blocked command stream  
definition [493](#)

blocking command  
definition [493](#)

## C

command channel  
definition [493](#)

command stream  
definition [493](#)

component  
definition [493](#)

configuration  
definition [493](#)

configuration intent  
definition [493](#)

Customer Support [10](#)

cycle command  
definition [493](#)

## D

decoder  
definition [494](#)

design context  
definition [494](#)

design creation  
definition [494](#)

**D**  
DesignWare Library

definition [494](#)

## dual role device

definition [494](#)

## DW\_ahb\_dmac

functional description of [25](#)

programming of [467](#)

**E**

## endian

definition [494](#)

Environment, licenses [23](#)**F**

## Full-Functional Mode

definition [494](#)

**G**

## GPIO

definition [494](#)

## GTECH

definition [494](#)

**H**

## hard IP

definition [494](#)

## HDL

definition [494](#)

**I**

## IIP

definition [494](#)

## implementation view

definition [494](#)

## instantiate

definition [494](#)

## interface

definition [494](#)

## IP

definition [494](#)

**L**Licensing [23](#)

## little-endian

definition [494](#)

**M**

## master

definition [494](#)

## model

definition [494](#)

monitor

definition [494](#)

**N**

non-blocking command

definition [494](#)

**P**

peripheral

definition [495](#)

**R**

RTL

definition [495](#)

**S**

SDRAM

definition [495](#)

SDRAM controller

definition [495](#)

slave

definition [495](#)

SoC

definition [495](#)

SoC Platform

AHB contained in [13](#)

APB, contained in [13](#)

defined [13](#)

soft IP

definition [495](#)

static controller

definition [495](#)

synthesis intent

definition [495](#)

synthesizable IP

definition [495](#)

**T**

technology-independent

definition [495](#)

Testsuite Regression Environment (TRE)

definition [495](#)

TRE

definition [495](#)

**V**

VIP

definition [495](#)

**W****wrap**    definition [495](#)**wrapper**    definition [495](#)**Z****zero-cycle command**    definition [495](#)

Synopsys confidential document, provided to Blue Ocean Smart under NDA, do not redistribute