# **SYNOPSYS®**

# DesignWare DW\_ahb\_ictl Databook

DW\_ahb\_ictl - Product Code

#### **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

# **Contents**

| Revision History                           | 7  |
|--------------------------------------------|----|
| Preface                                    | 9  |
| Organization                               |    |
| Related Documentation                      | 10 |
| Web Resources                              | 10 |
| Customer Support                           | 10 |
| Product Code                               | 11 |
| Chapter 1                                  |    |
| Product Overview                           | 13 |
| 1.1 DesignWare System Overview             |    |
| 1.1.1 DesignWare System Block Diagram      |    |
| 1.2 General Product Description            |    |
| 1.2.1 DW_ahb_ictl Block Diagram            |    |
| 1.3 Features                               |    |
| 1.4 Standards Compliance                   |    |
| 1.5 Verification Environment Overview      |    |
| 1.6 Licenses                               |    |
| 1.7 Where to Go From Here                  |    |
| Charter 9                                  |    |
| Chapter 2 Experience Description           | 10 |
| Functional Description                     |    |
|                                            |    |
| 2.2 IRQ Interrupt Processing               |    |
| 2.2.1 IRQ Interrupt Polarity               |    |
|                                            |    |
| 2.2.3 IRQ Enable and Masking               |    |
|                                            |    |
| 2.2.5 IRQ Priority Filter                  |    |
| 2.2.7 IRQ Interrupt Vectors                |    |
| 2.2.8 Vector Port                          |    |
|                                            |    |
| 2.3 FIQ Interrupt Processing               |    |
| 2.3.2 FIQ Software-Programmable Interrupts |    |
| 2.3.3 FIQ Enable and Masking               |    |
| 2.3.4 FIQ Interrupt Status Registers       | 20 |
| 6.0.4 Fig interrupt status tregisters      |    |

| Parameter Descriptions                                      | 32<br>36<br>37<br>38 |
|-------------------------------------------------------------|----------------------|
| 3.6 Individual FIQ Polarity Configuration Parameters        | 40                   |
| Chapter 4                                                   |                      |
| Signal Descriptions                                         | 41                   |
| 4.1 AHB Interface Signals                                   |                      |
| 4.2 Interrupt Signals                                       | 46                   |
| 4.3 Interrupt Source Signals                                |                      |
| 4.4 Vector Interrupt and Handshake Signals                  |                      |
| 4.5 Miscellaneous Signals                                   | 49                   |
| Chapter 5                                                   |                      |
| Register Descriptions                                       | 51                   |
| 5.1 DW_ahb_ictl_mem_map/DW_ahb_ictl_addr_block1 Registers   |                      |
| 5.1.1 irq_inten_l                                           |                      |
| 5.1.2 irq_inten_h                                           |                      |
| 5.1.3 irq_intmask_l                                         |                      |
| 5.1.4 irq_intmask_h                                         |                      |
| 5.1.5 irq_intforce_1                                        |                      |
| 5.1.6 irq_intforce_h                                        |                      |
| 5.1.7 irq_rawstatus_l                                       |                      |
| 5.1.8 irq_rawstatus_h                                       |                      |
| 5.1.9 irq_status_l                                          |                      |
| 5.1.10 irq_status_h                                         | 65                   |
| 5.1.11 irq_maskstatus_l                                     | 66                   |
| 5.1.12 irq_maskstatus_h                                     |                      |
| 5.1.13 irq_finalstatus_l                                    |                      |
| 5.1.14 irq_finalstatus_h                                    |                      |
| 5.1.15 irq_vector                                           |                      |
| 5.1.16 irq_vector_x (for $x = 1$ ; $x \le ICT_IRQ_PLEVEL$ ) |                      |
| 5.1.17 fiq_inten                                            |                      |
| 5.1.18 fiq_intmask                                          |                      |
| 5.1.19 fiq_intforce                                         |                      |
| 5.1.20 fiq_rawstatus                                        |                      |
| 5.1.21 fiq_status                                           |                      |
| 5.1.22 fiq_finalstatus                                      |                      |
| 5.1.23 irq_plevel                                           |                      |
| 5.1.24 irq_internal_plevel                                  |                      |
| 5.1.25 irq_pr_x (for x = 1; x <= ICT_IRQ_NUM)               | 18                   |
| 5.1.26 ICTL_COMP_PARAMS_2<br>5.1.27 ICTL_COMP_PARAMS_1      |                      |
| 5.1.27 ICTL_COMP_PARAMS_I  5.1.28 AHB_ICTL_COMP_VERSION     |                      |
| 5.1.28 AHB_ICTL_COMP_VERSION                                |                      |
| J.1.6J IOIL COMI TIIL                                       | 91                   |

### Chapter 6

| Programming the DW_ahb_ictl                                           | 93  |
|-----------------------------------------------------------------------|-----|
| 6.1 Programming Considerations                                        |     |
| 6.2 Reading/Writing Registers Wider than APB_DATA_WIDTH               |     |
| 6.3 Initialization                                                    |     |
| 6.4 Interrupt Service                                                 |     |
| 6.5 Illegal Accesses                                                  |     |
| 6.6 Register Access                                                   |     |
|                                                                       |     |
| Chapter 7                                                             |     |
| Verification                                                          |     |
| 7.1 Overview of Vera Tests                                            |     |
| 7.1.1 Reset                                                           | 97  |
| 7.1.2 Slave Interface                                                 | 97  |
| 7.1.3 FIQ                                                             | 97  |
| 7.1.4 IRQ                                                             | 98  |
| 7.1.5 Priority Controller                                             | 98  |
| 7.1.6 Dynamic Reconfiguration                                         | 98  |
| 7.2 Overview of DW_ahb_ictl Testbench                                 | 98  |
| 7.3 Running Simulations from the Command Line                         |     |
| 7.4 Command Line Output Files                                         |     |
|                                                                       |     |
| Chapter 8                                                             | 404 |
| Integration Considerations                                            |     |
| 8.1 Read Accesses                                                     |     |
| 8.2 Write Accesses                                                    |     |
| 8.3 Consecutive Write-Read                                            |     |
| 8.4 Accessing Top-level Constraints                                   |     |
| 8.5 Coherency                                                         |     |
| 8.5.1 Writing Coherently                                              |     |
| 8.5.2 Reading Coherently                                              |     |
| 8.6 Performance                                                       |     |
| 8.6.1 Power Consumption, Frequency, and Area Results                  |     |
| Appendix A                                                            |     |
|                                                                       | 115 |
| Synchronizer Methods                                                  |     |
| A.1 Synchronizers Used in DW_ahb_ictl                                 |     |
| A.2 Synchronizer 1: Simple Double Register Synchronizer (DW_ahb_ictl) | 117 |
| Chapter B                                                             |     |
| Internal Parameter Descriptions                                       |     |
|                                                                       |     |
| Appendix C                                                            |     |
| Glossary                                                              |     |
| т. 1                                                                  | 195 |

# **Revision History**

This table shows the revision history for the databook from release to release. This is being tracked from version 2.04b onward.

| Version | Date         | Description                                                                                                                                                                                                     |
|---------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2.14a   | July 2018    | Updated:                                                                                                                                                                                                        |
|         |              | ■ Version number changed for 2018.07a release                                                                                                                                                                   |
|         |              | ■ "Performance" on page 114                                                                                                                                                                                     |
|         |              | ■ "Parameter Descriptions" on page 31, "Register Descriptions" on page 51, "Signal Descriptions" on page 41, and "Internal Parameter Descriptions" on page 119 are auto-extracted with change bars from the RTL |
|         |              | <ul> <li>Added support for configurable synchronization depth through parameter<br/>ICT_ADD_VECTOR_PORT_SYNC_DEPTH</li> </ul>                                                                                   |
|         |              | Removed:                                                                                                                                                                                                        |
|         |              | <ul> <li>Chapter 2, "Building and Verifying a Component or Subsystem" and added the<br/>contents in the newly created user guide.</li> </ul>                                                                    |
| 2.13a   | October 2016 | ■ Version number changed for 2016.10a release                                                                                                                                                                   |
|         |              | ■ "Parameter Descriptions" on page 31 and "Register Descriptions" on page 51 auto-extracted from the RTL                                                                                                        |
|         |              | ■ Removed the "Running Leda on Generated Code with coreConsultant" section, and reference to Leda directory in Table 2-1 on page 20                                                                             |
|         |              | ■ Removed the "Running Leda on Generated Code with coreAssembler" section, and reference to Leda directory in Table 2-4 on page 27                                                                              |
|         |              | ■ Replaced Figure 2-2 and Figure 2-3 to remove references to Leda                                                                                                                                               |
|         |              | ■ Xprop directory in Table 2-1 and Table 2-4                                                                                                                                                                    |
|         |              | ■ Moved "Internal Parameter Descriptions" to Appendix                                                                                                                                                           |
|         |              | ■ Added "Running VCS XPROP Analyzer"                                                                                                                                                                            |
| 2.12a   | June 2015    | ■ Added "Running SpyGlass® Lint and SpyGlass® CDC"                                                                                                                                                              |
|         |              | <ul> <li>Added "Running SpyGlass on Generated Code with coreAssembler"</li> </ul>                                                                                                                               |
|         |              | ■ "Signal Descriptions" on page 41 auto-extracted from the RTL                                                                                                                                                  |
|         |              | ■ Added "Internal Parameter Descriptions" on page 119                                                                                                                                                           |
|         |              | ■ Added Appendix A, "Synchronizer Methods"                                                                                                                                                                      |

### (Continued)

| Version | Date     | Description                                                                                                                                                                                                     |
|---------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2.11a   | Jun 2014 | <ul> <li>Version change for 2014.06a release</li> <li>Added "Performance" section in the "Integration Considerations" chapter</li> <li>Corrected the External Input/Output delays in Signals chapter</li> </ul> |
| 2.10a   | May 2014 | <ul> <li>Version change for 2013.05a release</li> <li>Updated the template</li> </ul>                                                                                                                           |
| 2.09b   | Oct 2012 | Added the product code on the cover and in Table 1-1                                                                                                                                                            |
| 2.09b   | Mar 2012 | Version change for 2012.03a release                                                                                                                                                                             |
| 2.09a   | Nov 2011 | Version change for 2011.11a release                                                                                                                                                                             |
| 2.08b   | Oct 2011 | Version change for 2011.10a release                                                                                                                                                                             |
| 2.08b   | Jun 2011 | <ul> <li>Updated system diagram in Figure 1-1</li> <li>Enhanced "Related Documents" section in Preface</li> </ul>                                                                                               |
| 2.08a   | Apr 2011 | Clarified Note in "Register Memory Map" section                                                                                                                                                                 |
| 2.07a   | Sep 2010 | Corrected names of include files and vcs command used for simulation                                                                                                                                            |
| 2.06a   | Dec 2009 | <ul> <li>Corrected ICT_HAS_VECTOR_PORT to ICT_ADD_VECTOR_PORT parameter name</li> <li>Updated databook to new template for consistency with other IIP/VIP/PHY databooks</li> </ul>                              |
| 2.06a   | May 2009 | Removed references to QuickStarts, as they are no longer supported                                                                                                                                              |
| 2.06a   | Oct 2008 | Version change for 2007.10a release                                                                                                                                                                             |
| 2.05c   | Aug 2008 | Added note about irq_intpfilt signal and changed names of signals in Figures 6 & 10                                                                                                                             |
| 2.05c   | Jun 2008 | Version change for 2008.06a release                                                                                                                                                                             |
| 2.04b   | Jun 2007 | Version change for 2007.06a release                                                                                                                                                                             |

# **Preface**

This databook provides information that you need to interface the DesignWare APB Interrupt Controller (DW\_ahb\_ictl) component to the Advanced Peripheral Bus (APB). This component conforms to the *AMBA Specification, Revision 2.0* from Arm<sup>®</sup>.

The information in this databook includes a functional description, pin 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\_ahb\_ictl.
- Chapter 3, "Parameter Descriptions" identifies the configurable parameters supported by the DW\_ahb\_ictl.
- Chapter 4, "Signal Descriptions" provides a list and description of the DW\_ahb\_ictl signals.
- Chapter 5, "Register Descriptions" describes the programmable registers of the DW\_ahb\_ictl.
- Chapter 6, "Programming the DW\_ahb\_ictl" provides information needed to program the configured DW\_ahb\_ictl.
- Chapter 7, "Verification" provides information on verifying the configured DW\_ahb\_ictl.
- Chapter 8, "Integration Considerations" includes information you need to integrate the configured DW\_ahb\_ictl into your design.
- Appendix A, "Synchronizer Methods" documents the synchronizer methods (blocks of synchronizer functionality) used in DW\_ahb\_ictl to cross clock boundaries.
- Appendix B, "Internal Parameter Descriptions" provides a list of internal parameter descriptions that might be indirectly referenced in expressions in the Signals chapter.
- Appendix C, "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 supplying 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 <a href="http://solvnet.synopsys.com/EnterACall">http://solvnet.synopsys.com/EnterACall</a> and click **Open A Support Case** to enter a call. Provide the requested information, including:

- Product: DesignWare Library IP
- Sub Product: AMBA
- Problem Type:

10

- **■** Priority:
- **Title:** DW ahb ictl
- 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 (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

#### **Product Code**

Table 1-1 lists all the components associated with the product code for DesignWare AMBA Fabric.

Table 1-1 DesignWare AMBA Fabric – Product Code: 3768-0

| Component Name | Description                                                                                                       |
|----------------|-------------------------------------------------------------------------------------------------------------------|
| DW_ahb         | High performance, low latency interconnect fabric for AMBA 2 AHB                                                  |
| DW_ahb_eh2h    | High performance, high bandwidth AMBA 2 AHB to AHB bridge                                                         |
| DW_ahb_h2h     | Area efficient, low bandwidth AMBA 2 AHB to AHB Bridge                                                            |
| DW_ahb_icm     | Configurable multi-layer interconnection matrix                                                                   |
| DW_ahb_ictl    | Configurable vectored interrupt controllers for AHB bus systems                                                   |
| DW_apb         | High performance, low latency interconnect fabric & bridge for AMBA 2 APB for direct connect to AMBA 2 AHB fabric |
| DW_apb_ictl    | Configurable vectored interrupt controllers for APB bus systems                                                   |
| DW_axi         | High performance, low latency interconnect fabric for AMBA 3 AXI                                                  |
| DW_axi_a2x     | Configurable bridge between AXI and AHB components or AXI and AXI components.                                     |
| DW_axi_gm      | Simplify the connection of third party/custom master controllers to any AMBA 3 AXI fabric                         |
| DW_axi_gs      | Simplify the connection of third party/custom slave controllers to any AMBA 3 AXI fabric                          |
| DW_axi_hmx     | Configurable high performance interface from and AHB master to an AXI slave                                       |

| Component Name | Description                                                                                                             |
|----------------|-------------------------------------------------------------------------------------------------------------------------|
| DW_axi_rs      | Configurable standalone pipelining stage for AMBA 3 AXI subsystems                                                      |
| DW_axi_x2h     | Bridge from AMBA 3 AXI to AMBA 2.0 AHB, enabling easy integration of legacy AHB designs with newer AXI systems          |
| DW_axi_x2p     | High performance, low latency interconnect fabric and bridge for AMBA 2 & 3 APB for direct connect to AMBA 3 AXI fabric |
| DW_axi_x2x     | Flexible bridge between multiple AMBA 3 AXI components or buses                                                         |

# **Product Overview**

This chapter describes the DesignWare AHB Interrupt Controller, referred to as the DW\_ahb\_ictl.

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

#### 1.1.1 DesignWare System Block Diagram

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

Figure 1-1 Example of DW\_ahb\_ictl in a Complete System



You can connect, configure, synthesize, and verify the DW\_ahb\_ictl 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\_ahb\_ictl component, you might prefer to use coreConsultant, documentation for which is available in the *coreConsultant User Guide*.

#### 1.2 General Product Description

The DW\_ahb\_ictl is a configurable, vectored interrupt controller for AMBA-based systems. It is an AMBA 2.0-compliant Advanced High-speed Bus (AHB) slave device and is part of the DesignWare Synthesizable Components for AMBA 2.

The DW\_ahb\_ictl supports two to sixty-four normal interrupt (IRQ) sources that are processed to produce a single IRQ interrupt to the processor. It supports one to eight fast interrupt (FIQ) sources that are processed to produce a single FIQ interrupt to the processor. All interrupt processing is combinational so that interrupts are propagated if the bus interface of the DW\_ahb\_ictl is powered down. This means that interrupts are registered only when the system accesses the interrupt registers (raw, status, or final\_status). Ensure sure that the interrupts stay asserted until they are serviced.

IRQ interrupts support software interrupts, priority filtering, and vector generation. They have configurable input and output polarity. FIQ interrupts are similar to IRQ interrupts, with the exception that priority filtering and vector generation are not included.

#### 1.2.1 DW\_ahb\_ictl Block Diagram

Figure 1-2 shows a block diagram of the DW\_ahb\_ictl.

Figure 1-2 Block Diagram DW\_ahb\_ictl



#### 1.3 Features

The DW\_ahb\_ictl supports the following features:

- 2 to 64 IRQ normal interrupt sources
- 1 to 8 FIQ fast interrupt sources (optional)
- Vectored interrupts (optional)
- Software interrupts
- Priority filtering (optional)
- Masking
- Scan mode (optional)
- Programmable interrupt priorities (after configuration)
- Configuration ID registers
- Encoded parameters
- Vector port interface that allows a processor to sample the vector address associated with the current highest priority irq without a bus access
- Configuration of DesignWare AHB Lite system

Source code for this component is available on a per-project basis as a DesignWare Core. Contact your local sales office for the details.

#### 1.4 Standards Compliance

The DW\_ahb\_ictl component conforms to the *AMBA Specification, Revision 2.0* from Arm®. Readers are assumed to be familiar with this specification.

#### 1.5 Verification Environment Overview

The DW\_ahb\_ictl includes an extensive verification environment, which sets up and invokes your selected simulation tool to execute tests that verify the functionality of the configured component. You can then analyze the results of the simulation.

The "Verification" on page 97 chapter discusses the specific procedures for verifying the DW\_ahb\_ictl.

#### 1.6 Licenses

Before you begin using the DW\_ahb\_ictl, you must have a valid license. For more information, see "Licenses" in the *DesignWare Synthesizable Components for AMBA 2/AMBA 3 AXI Installation Guide.* 

#### 1.7 Where to Go From Here

At this point, you may want to get started working with the DW\_ahb\_ictl 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\_ahb\_ictl component, see "Overview of the coreConsultant Configuration and Integration Process" in DesignWare Synthesizable Components for AMBA 2 User Guide.

For more information about implementing your DW\_ahb\_ictl component within a DesignWare subsystem using coreAssembler, see "Overview of the coreAssembler Configuration and Integration Process" in DesignWare Synthesizable Components for AMBA 2 User Guide.

# **Functional Description**

This chapter describes the functional operation of the DesignWare AHB Interrupt Controller, referred to as DW\_ahb\_ictl.

There is an option to configure AHB Lite, which is the DesignWare implementation of AMBA 2.0 AHB-Lite. The DesignWare AHB Lite configuration does not include the following:

- Requesting/granting protocols to the arbiter and split/retry responses from the slaves; all slaves are made non-split capable
- No arbiter as the signals associated with the component are not used: hbusreq and hgrant
- No write data, address, or control multiplexers
- Pause mode not enabled
- Default master number changed to 1
- Number of masters is changed to 1

For more information about AHB Lite, see the *DesignWare DW\_ahb Databook*.

#### 2.1 Overview

The DW\_ahb\_ictl component is a configurable, vectored interrupt controller for DesignWare Synthesizable Components. It supports from two to sixty-four normal interrupt (IRQ) sources that are processed to produce a single IRQ interrupt to the processor. It supports from one to eight fast interrupt (FIQ) sources that are processed to produce a single FIQ interrupt to the processor. All interrupt processing is combinational so that interrupts are propagated if the bus interface of the DW\_ahb\_ictl is powered down. This means that reading any of the interrupt status registers (raw, status, or final\_status) is simply returning the status of the combinational logic, since there are no flip-flops associated with these registers. Ensure that the interrupts stay asserted until they are serviced.

IRQ interrupts support software interrupts, priority filtering, and vector generation. They have configurable input and output polarity. FIQ interrupts are similar to IRQ interrupts, with the exception that priority filtering and vector generation are not included.

Figure 2-1 shows a block diagram of the DW\_ahb\_ictl.

Figure 2-1 DW\_ahb\_ictl Block Diagram



### 2.2 IRQ Interrupt Processing

The DW\_ahb\_ictl can be configured to support from 2 to 64 IRQ interrupt sources (irq\_intsrcN) using the ICT\_IRQ\_NUM configuration parameter. The DW\_ahb\_ictl processes these interrupt sources to produce a single IRQ interrupt to the processor; irq or irq\_n.



The irq\_intpfilt signal is an internally-generated priority mask signal. Its purpose is to mask any IRQ sources with a priority level below the irq\_plevel register.

The processing of the interrupt sources is shown in Figure 2-2 and described in the following sections.

Figure 2-2 Normal Interrupt Generation - Interrupt 1 Example



#### 2.2.1 IRQ Interrupt Polarity

The input polarity of each IRQ interrupt source is individually configurable. To configure the input polarity, use the ICT\_IRQSRC\_POL\_n parameter. This parameter exists for n = 0 to ICT\_IRQ\_NUM-1 (a polarity parameter for each irq\_intsrc bit). Setting one of these parameters to 1 makes the corresponding interrupt source active high; setting it to 0 makes the corresponding interrupt source active low. This parameter also determines the polarity of the software-programmable interrupt force bits in the irq\_intforce registers (irq\_intforce\_l or irq\_intforce\_h).

The output polarity of the interrupt signal is also configurable. The output polarity is set using the ICT\_INT\_POL parameter. Setting this parameter to 1 configures both the normal and fast interrupt outputs to active-high; setting it to 0, configures them to be active low. When configured to active high, the signal names for the interrupt outputs are irq and fiq; when configured to active low, the signal names are irq\_n and fiq\_n.

All interrupt status registers are always active high, regardless of the polarity configured for the interrupt sources and outputs.

#### 2.2.2 IRQ Software-Programmable Interrupts

The DW\_ahb\_ictl supports forcing interrupts from software. To force an interrupt to be active, write to the corresponding bit in the irq\_intforce registers (irq\_intforce\_l or irq\_intforce\_h). The polarity of each bit in these registers is the same as the polarity of the corresponding interrupt source signal.

To configure the polarity of both the irq\_intsrc signal and the irq\_intforce register bits, set the corresponding bits of the ICT\_IRQSRC\_POL\_n parameter (n = ICT\_IRQ\_NUM-1). Setting one of these parameters to 1 configures the corresponding bit of irq\_intsrc and irq\_intforce to be active high; setting one of these parameters to 0 configures them to be active low.

Regardless of the polarity you configure, the reset state of each bit in the irq\_intforce registers is always inactive.

#### 2.2.3 IRQ Enable and Masking

To enable each interrupt source independently, write a 1 to the corresponding bit of the irq\_inten registers (irq\_inten\_l or irq\_inten\_h). To configure the reset state of these registers, set the ICT\_IRQ\_DFLT\_EN parameter. If you set a bit of the ICT\_IRQ\_DFLT\_EN parameter to 1, the corresponding bit of the irq\_inten registers is 1 on reset, which enables the corresponding interrupt source.

To mask each interrupt source independently, write a 1 to the corresponding bit of the interrupt mask register (irq\_maskstatus\_l/irq\_maskstatus\_h). The reset value for each mask bit is 0 (unmasked).

#### 2.2.4 IRQ Software-Programmable Priority Levels

The DW\_ahb\_ictl supports optional software programmable priority levels. To change the priority level of an interrupt, you write the priority value to the corresponding priority level register in the memory map. There is a priority register for each of the interrupt sources, which can be programmed to one of 16 values from 0x0 to 0xf. Priority registers only exist for available interrupt sources.

The priority registers take on the reset state of the configuration parameter ICT\_IRQSRC\_PLEVEL\_n.

- To enable reading the priorities, set the ICT\_READ\_PRIORITY parameter to 1 (True). It is possible to read the priority registers when they (priorities) are not programmable.
- To enable programmable priorities, set the ICT\_HC\_PRIORITIES parameter to 0 (False). This can be done only if priorities can be read; that is, if ICT\_READ\_PRIORITIES is 1.

#### 2.2.5 IRQ Priority Filter

The DW\_ahb\_ictl supports optional priority filtering. To enable the priority filtering logic, set the ICT\_HAS\_PFLT parameter to 1. If ICT\_HAS\_PFLT is set to 0, none of the associated logic is instantiated and vectored interrupts are not supported.

The function of the priority filtering logic is described as follows:

- Each interrupt source is configured to one of 16 priority levels. To configure an interrupt source to a priority level, set the ICT\_IRQSRC\_PLEVEL\_n to a value from 0 to 15, where 0 is the lowest priority, assuming that programmable priorities is not enabled. If programmable priorities are enabled (ICT\_HC\_PRIORITIES = 1), then the priority registers can be changed dynamically after configuration.
- A system priority level can be programmed into the irq\_plevel register, which holds values from 0 to 15. The reset value of this register is set by programming the ICT\_IRQ\_PLEVEL parameter to a value from 0 to 15.
- The DW\_ahb\_ictl filters out any interrupt source with a configured priority level less than the priority currently programmed in the irq\_plevel register.

#### 2.2.6 IRQ Interrupt Status Registers

The DW\_ahb\_ictl includes up to four status registers used for querying the current status of any interrupt at various stages of the processing. see Figure 2-2 for an illustration of the register values. All of the following status registers have the same polarity; a 1 indicates that an interrupt is active, a 0 indicates it is inactive:

#### irq\_rawstatus

The irq\_rawstatus register (irq\_rawstatus\_l/irq\_rawstatus\_h) contains the state of the interrupt sources after being adjusted for input polarity. Each bit of this register is set to 1 if the corresponding interrupt source bit is active and is set to 0 if it is inactive.

#### ■ irq\_status

The irq\_status register (irq\_status\_l/irq\_status\_l) contains the state of all interrupts after the enabling stage, meaning that an active-high bit indicates that particular interrupt source is active and enabled.

#### irq\_maskstatus

The irq\_maskstatus register (irq\_maskstatus\_l/irq\_maskstatus\_h) contains the state of all interrupts after the masking stage, meaning that an active-high bit indicates that particular interrupt source is active, enabled, and not masked.

#### irq\_finalstatus

This register (irq\_finalstatus\_l/irq\_finalstatus\_h) contains the state of all interrupts after the priority filtering stage, meaning an active-high bit indicates that particular interrupt source is active, enabled, not masked, and its configured priority level is greater or equal to the value programmed in the irq\_plevel register. If priority filtering has not been selected, this register contains the same value as the irq\_maskstatus register (the final stage of processing).

#### 2.2.7 IRQ Interrupt Vectors

The DW\_ahb\_ictl can be configured to support interrupt vectors. To enable vectored interrupt support, you must include priority filtering logic by setting the ICT\_HAS\_PFLT parameter to 1. To include vector generation logic, set the ICT\_HAS\_VECTOR parameter to 1. If ICT\_HAS\_VECTOR is set to 0, none of the interrupt vector logic is instantiated and vectored interrupts are not supported.

The DW\_ahb\_ictl has one vector register associated with each of the 16 interrupt priority levels: irq\_vector\_x through irq\_vector\_15. These registers are 32 bits wide.

The value of each interrupt vector register can be hardcoded or programmed. If the parameter ICT\_HC\_VECTOR\_n is set to 1, irq\_vector\_n has a hardcoded value and is a read-only register. If the parameter ICT\_HC\_VECTOR\_n is set to 0, irq\_vector\_n is programmable and is a read/write value.

To configure the vector register value for hardcoded vector registers and the reset value for programmable vector registers, set the ICT\_VECTOR\_n parameter to the desired value.

Vector processing proceeds as follows:

- Active interrupts are conditioned by their enable and mask control bits.
- All active interrupts with a configured priority level (ICT\_IRQSRC\_PLEVEL\_*n*) less than the current value programmed into the irq\_plevel register are filtered out.

- The highest priority level from among the remaining active interrupts is used to select one of the 16 interrupt vectors that have been programmed or configured into the irq\_vector registers.
- By reading the irq\_vector register, retrieve the vector associated with the highest priority level that has an active interrupt source.

The irq\_vector register may be accessed only with hsize = 32. By imposing this restriction, the user is guaranteed to read a valid value for the irq\_vector register. Accesses with hsize less that 32 would require shadow registers to guarantee a coherent value for the irq\_vector register.

#### 2.2.8 Vector Port

You can configure the DW\_ahb\_ictl to include vector port functionality through the ICT\_ADD\_VECTOR\_PORT parameter. If you enable this parameter, signals are added to the top level of the DW\_ahb\_ictl that allow a processor to quickly sample the vector address associated with a currently pending IRQ. Using the vector port potentially decreases IRQ service latency, as the processor does not need to initiate an AHB bus transaction in order to discover the vector address associated with the current highest-priority interrupt.

The DW\_ahb\_ictl vector port meets the requirements of the ARM11 and ARM1026EJ processor VIC ports. Vector port functionality applies to only IRQ processing; FIQ processing is unaffected.

Figure 2-3 shows the operation of the vector port where the processor clock and bus clock are running at the same frequency.



Figure 2-3 Vector Port Handshaking (Synchronous Processor Clock)

#### 2.2.8.1 Handshaking Operation

The irq\_addr output becomes valid in the same cycle that irq\_n asserts. At some point after this, the processor asserts irq\_ack to acknowledge receipt of the IRQ, which then causes the DW\_ahb\_ictl to assert irq\_addr\_v in order to inform the processor that it may sample irq\_addr. Until the DW\_ahb\_ictl asserts irq\_addr\_v, irq\_addr changes combinatorially to reflect the vector associated with the currently highest-priority active interrupt source. The DW\_ahb\_ictl holds irq\_addr static while irq\_addr\_v is asserted.

In the same cycle that the DW\_ahb\_ictl de-asserts irq\_addr\_v, irq\_n also de-asserts. At this point in the handshaking, the DW\_ahb\_ictl has reset its internal priority filter to mask out all interrupt sources of a priority level less than or equal to the priority of the interrupt source just sampled by the processor; this prevents the processor from re-sampling the same interrupt and also prevents lower-priority interrupt sources from causing an assertion of irq\_n during the interrupt service routine (ISR) of the sampled

24

interrupt. If the interrupt source currently being processed has the highest possible priority level (4'hF), then all IRQs are masked until software resets the priority filter.

The processor can reset the level of the priority filter to its previous setting by writing a new priority level to the irq\_internal\_plevel register. Ideally this should be one of the last steps in the ISR code.

If a higher-priority interrupt occurs during the handshaking process, irq\_n stays asserted when irq\_addr\_v de-asserts, and the DW\_ahb\_ictl waits for the processor to assert irq\_ack in order to start the handshaking process for the new interrupt.

Figure 2-3 shows the vector port handshaking when the bus clock and processor clock are identical (synchronous). In this case, there is a one-cycle delay from the assertion of irq\_ack by the processor to the assertion of irq\_addr\_v by the DW\_ahb\_ictl. Also there is a one-cycle delay from the de-assertion of irq\_ack by the processor to the de-assertion of irq\_addr\_v by the DW\_ahb\_ictl.

#### 2.2.8.2 Priority-Level Registers

If the ICT\_ADD\_VECTOR\_PORT parameter is equal to 1, you can use a priority-level memory-mapped register—irq\_internal\_plevel—to sample the priority level currently being applied by the DW\_ahb\_ictl; if ICT\_ADD\_VECTOR\_PORT is equal to 0, irq\_internal\_plevel does not exist.

Unless an IRQ is currently being handled, the irq\_internal\_plevel register reflects the value of the system priority level register, irq\_plevel. While an IRQ is being handled, irq\_internal\_plevel is set to one priority level greater than the priority of the IRQ being processed. In contrast to the irq\_plevel register that is 4 bits wide, the irq\_internal\_plevel register is 5 bits wide in order to accommodate stacking an IRQ source with a priority level of 15; in this case, irq\_internal\_plevel is set to 16.

At the end of the ISR, the processor writes to the irq\_internal\_plevel register in order to reset it to the value stored in the irq\_plevel register. Writing to the irq\_internal\_plevel register at any other time may break the operation of the DW\_ahb\_ictl.



For writes to the irq\_internal\_plevel register, the write data on the bus is ignored. The only effect of a write to the irq\_internal\_plevel register is to reset its value to that of the irq\_plevel register.

Splitting up the system priority level into two separate locations enables you to have read/write access to the current system priority level independent of the temporary priority level used during the ISR. If a higher priority IRQ occurs while a stacked priority is being used, irq\_internal\_plevel is reset to the value of irq\_plevel from the next hclk cycle. This new IRQ is stacked after the handshaking procedure, described in "Handshaking Operation" on page 24.

If the ICT\_ADD\_VECTOR\_PORT parameter is set to false, the irq\_internal\_plevel register does not exist, and only the irq\_plevel register is used to set the current priority level of the DW\_ahb\_ictl.

Figure 2-4 shows how the priority filter value is changed by the DW\_ahb\_ictl for the duration of the ISR.

Figure 2-4 Priority Masking During ISR



In this example, a lower-priority interrupt occurs after the handshaking but before the irq\_internal\_plevel register is reset by the processor. Sometime later the processor writes to the irq\_internal\_plevel register in order to reset the priority filter level, and the lower-priority interrupt is allowed to propagate to the processor; the bus data is ignored in the write to the irq\_internal\_plevel register.

#### 2.2.8.3 Synchronization

You can configure the DW\_ahb\_ictl using the ICT\_ADD\_VECTOR\_PORT\_SYNC parameter to add synchronization to vector port signals in order to support processors running at a different asynchronous frequency to the bus clock. If this parameter is enabled, the DW\_ahb\_ictl adds N-stages of hclk register synchronization to all signals coming from the processor, where N=

ICT\_ADD\_VECTOR\_PORT\_SYNC\_DEPTH. By default, DW\_ahb\_ictl adds 2-stages of hclk register synchronization to all signals coming from the processor.

Figure 2-5 shows vector port handshaking with synchronization enabled. Processor signals coming into the DW\_ahb\_ictl go through two levels of metastability registers that give protection from one hclk cycle of

metastability. In this situation, signals from the DW\_ahb\_ictl to the processor should be synchronized external to the DW\_ahb\_ictl.

Figure 2-5 Vector Port Handshaking with Synchronization



**Joseph Note** 

N cycles of synchronization time are additional to the one cycle latency described for the synchronous processor and AHB bus clocks, which yields a total of N+1 cycles of latency between irq\_ack and irq\_addr\_v.

Synchronization is not required for integer multiple or quasi-synchronous processor and bus clocks.

#### 2.2.8.4 Interrupt Timing

The following describes basic interrupt handling steps using the vector port feature of the DW\_ahb\_ictl:

- 1. Sample vector associated with IRQ using DW\_ahb\_ictl vector port.
- 2. If priority level is shared among IRQ sources, read irq\_final\_status to determine which interrupt source caused the interrupt.
- 3. Execute interrupt service routine.
- 4. Optionally read irq\_status to see if other interrupts are pending and service as required.
- 5. Clear interrupt at source (hardware peripheral or interrupt controller for s/w interrupt).
- 6. Write to irq\_internal\_plevel to reset the priority filter.

### 2.3 FIQ Interrupt Processing

FIQ interrupts are an optional feature of the DW\_ahb\_ictl interrupt controller. To include FIQ interrupt logic in the DW\_ahb\_ictl, set the value of the ICT\_HAS\_FIQ parameter to 1. If ICT\_HAS\_FIQ is set to 0, the FIQ logic is not included and the associated signals are not present.

You can configure the DW\_ahb\_ictl to support from 1 to 8 FIQ interrupt sources (fiq\_intsrcN) using the ICT\_FIQ\_NUM parameter. The DW\_ahb\_ictl processes these interrupt sources to produce a single FIQ interrupt to the processor; fiq or fiq\_n.

FIQ interrupt processing is similar to IRQ interrupt processing, except that priority filtering and interrupt vectors are not supported for the FIQ interrupts. This section describes how the DW\_ahb\_ictl handles the FIQ interrupt processing.

Figure 2-6 shows the processing of the interrupt sources, which is described in the following sections.

Figure 2-6 Fast Interrupt Generation - Interrupt 1 Example



#### 2.3.1 FIQ Interrupt Polarity

The input polarity of each FIQ interrupt source can be configured individually. To configure the input polarity, use the ICT\_FIQSRC\_POL parameter. This parameter exists for n=0 to ICT\_FIQ\_NUM-1 (a polarity parameter for each fiq\_intsrc bit). Setting one of these parameters to 1 makes the corresponding interrupt source active high; setting it to 0 makes the corresponding interrupt source active low. This parameter also determines the polarity of the software programmable interrupt force bits in the fiq\_intforce register.

The output polarity of the interrupt signal can also be configured. You configure the output polarity using the ICT\_INT\_POL parameter. Setting this parameter to 1 configures both the IRQ and FIQ interrupt outputs to be active high; setting the parameter to 0 configures them to be active low. When configured as active high, the signal names for the interrupt outputs are irq and fiq; when configured active low, the signal names are irq\_n and fiq\_n.

All interrupt status registers are always active high, regardless of the polarity configured for the interrupt sources and outputs.

#### 2.3.2 FIQ Software-Programmable Interrupts

The DW\_ahb\_ictl supports forcing interrupts from software. You force an interrupt to be active by writing to the corresponding bit in the fiq\_intforce register. The polarity of each bit in this register is the same as the polarity of the corresponding interrupt source signal.

To configure the polarity of both the fiq\_intsrc signal and the fiq\_intforce register bits, set the corresponding bits of the ICT\_FIQSRC\_POL\_n parameter ( $n = ICT_FIQ_NUM_{-1}$ ). Setting one of these parameters to 1 configures the corresponding bit of fiq\_intsrc and fiq\_intforce to be active high; setting one of these parameters to 0 configures them to be active low.

Regardless of the polarity you configure, the reset state of each bit in the fiq\_intforce register is always inactive.

#### 2.3.3 FIQ Enable and Masking

You can enable each interrupt source independently by writing a 1 to the corresponding bit of the fiq\_inten register. You can configure the reset state of this register by setting the ICT\_FIQ\_DFLT\_EN parameter. If you set a bit of the ICT\_FIQ\_DFLT\_EN parameter to 1, the corresponding bit of the fiq\_inten register is 1 on reset, which enables the corresponding interrupt source.

You can mask each interrupt source independently by writing a 1 to the corresponding bit of the fiq\_intmask register. The reset value for each mask bit is 0; that is, unmasked.

#### 2.3.4 FIQ Interrupt Status Registers

The DW\_ahb\_ictl includes three status registers that you can use to query the current status of any FIQ interrupt at various stages of the processing. For an illustration of the register values, see Figure 2-6 on page 28. All of the following status registers have the same polarity; a 1 indicates that in interrupt is active, a 0 indicates inactive:

#### fiq\_rawstatus

The fiq\_rawstatus register contains the state of the interrupt sources after being adjusted for input polarity. Each bit of this register is set to 1 if the corresponding interrupt source bit is active and is set to 0 if it is inactive.

#### ■ fiq\_status

The fiq\_status register contains the state of all interrupts after the enabling stage, meaning that an active-high bit indicates that particular interrupt source is active and enabled.

#### ■ fiq\_finalstatus

The fiq\_finalstatus register contains the state of all interrupts after the masking, meaning that an active-high bit indicates that particular interrupt source is active, enabled, and unmasked.

# **Parameter Descriptions**

This chapter details all the configuration parameters. You can use the coreConsultant GUI configuration reports to determine the actual configured state of the controller. 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 controller in coreConsultant, all TCL functions and parameters are evaluated completely; and the resulting values are displayed where appropriate in the coreConsultant GUI reports.

The parameter descriptions in this chapter include the **Enabled**: attribute which indicates the values required to be set on other parameters before you can change the value of this parameter.

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

- Top Level Parameters on page 32
- Vector Port Interface on page 36
- Priority Controller Configuration on page 37
- Configuration of Vector Generation Module on page 38
- Individual IRQ Polarity Configuration on page 39
- Individual FIQ Polarity Configuration on page 40

# 3.1 Top Level Parameters

Table 3-1 Top Level Parameters

| Label                                          | Description                                                                                                                                                                                                                                                                                                                                                                          |
|------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                | ICTL Source Code Configuration                                                                                                                                                                                                                                                                                                                                                       |
| Use DesignWare Foundation<br>Synthesis Library | Specifies the availability of a DesignWare license. The component code utilizes DesignWare Foundation parts for optimal Synthesis QoR. Customers with only a DesignWare license must use Foundation parts. Customers with only a Source license, CANNOT use Foundation parts. Customers with both Source and DesignWare licenses have the option of using Foundation parts.  Values: |
|                                                | ■ false (0)                                                                                                                                                                                                                                                                                                                                                                          |
|                                                | ■ true (1)                                                                                                                                                                                                                                                                                                                                                                           |
|                                                | Default Value: True if DesignWare License is available; False if DesignWare License is not available  Enabled: When both Source and DesignWare licenses are available  Parameter Name: USE_FOUNDATION                                                                                                                                                                                |
|                                                | System Configuration                                                                                                                                                                                                                                                                                                                                                                 |
| AHB Data Bus Width                             | Specifies the width of the AHB data bus.  Values: 32, 64, 128, 256  Default Value: 32  Enabled: Always  Parameter Name: AHB_DATA_WIDTH                                                                                                                                                                                                                                               |
| AHB System Address Width                       | Specifies the system address width of the AHB bus.  Values:  32 (32)  64 (64)  Default Value: 32  Enabled: Always  Parameter Name: HADDR_WIDTH                                                                                                                                                                                                                                       |
| Big Endian AHB Data Bus ?                      | Selects the endianness (big-endian or little-endian) of the AHB system.  Values:  false (0)  true (1)  Default Value: false Enabled: Always Parameter Name: BIG_ENDIAN                                                                                                                                                                                                               |

Table 3-1 Top Level Parameters (Continued)

| Label                                           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
|-------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                                                 | Internal Configuration                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| Add Encoded Parameters                          | Provides firmware an easy and quick way of identifying the DesignWare component within an I/O memory map. Some critical design-time options determine how a driver must interact with the peripheral. There is a minimal area overhead by including these parameters. When set, this parameter allows a single driver to be developed for each component that is self-configurable.  Values:  false (0x0)  true (0x1)  Default Value: true  Enabled: Always  Parameter Name: ICT_ADD_ENCODED_PARAMS |  |
| Active-high Level for IRQ/FIQ outputs?          | Drives the polarity of the FIQ and IRQ interrupt output signals to active high. Both the fast and normal interrupts are the same polarity.  Values:  false (0)  true (1)  Default Value: true  Enabled: Always  Parameter Name: ICT_INT_POL                                                                                                                                                                                                                                                         |  |
| Make irq_intforce and fiq_intforce active high? | Drives the irq_intforce and fiq_intforce registers to active high. By writing a 1 to the corresponding interrupt source bit, forces an interrupt for that source, regardless of the interrupt sources' configured polarity.  Values:  If alse (0)  It rue (1)  Default Value: false  Enabled: Always  Parameter Name: ICT_FORCEREG_ACTIVE_HIGH                                                                                                                                                      |  |
| IRQ Configuration                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
| Install Priority Controller?                    | Allows interrupts that are assigned a priority level to be compared against a system-level priority level. If the interrupt source has a priority level that is greater than or equal to the system level, then it is not masked.  Values:  false (0)  true (1)  Default Value: false  Enabled: Always  Parameter Name: ICT_HAS_PFLT                                                                                                                                                                |  |

Table 3-1 Top Level Parameters (Continued)

| Label                            | Description                                                                                                                                                                                                                                                                                                          |
|----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Be able to read back priorities? | Determines whether the priority levels can be read or not.  Values:  false (0)  true (1)  Default Value: false  Enabled: ICT_HAS_PFLT==1  Parameter Name: ICT_READ_PRIORITY                                                                                                                                          |
| Hard-Coded Priorities?           | Determines whether the priority levels can be programmed or not.  Values:  false (0)  true (1)  Default Value: true  Enabled: ICT_READ_PRIORITY==1 && ICT_HAS_PFLT==1  Parameter Name: ICT_HC_PRIORITIES                                                                                                             |
| Install Vector Generation?       | Instantiates the interrupt vector generation circuitry and registers in the DW_ahb_ictl. This parameter can only be set if the ICT_HAS_PFLT parameter is set to True (1).  Values:  false (0)  true (1)  Default Value: false Enabled: ICT_HAS_PFLT==1  Parameter Name: ICT_HAS_VECTOR_USER                          |
| Number of irq sources (2 -> 64)  | Defines the number of interrupt sources to generate.  Values: 2,, 64  Default Value: 32  Enabled: Always  Parameter Name: ICT_IRQ_NUM                                                                                                                                                                                |
| IRQ Source Polarity Type         | Specifies the IRQ Source Polarity Type. You must either use the individual interrupt polarities or override these to be either all active high or all active low.  Values:  Individual (0)  All-Active-Low (1)  All-Active-High (2)  Default Value: Individual  Enabled: Always  Parameter Name: ICT_IRQSRC_POL_TYPE |

Table 3-1 Top Level Parameters (Continued)

| Label                                 | Description                                                                                                                                                                                                                                                                                                                                                                          |
|---------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Individual irq enables on reset       | Specifies the reset value of the IRQ interrupt source enable register (irq_inten). A logic '1' in any bit position indicates that the interrupt source corresponding to that bit is enabled on reset; a logic '0' indicates that it is not enabled on reset.  Values: 0x0,, 0xffffffff  Default Value: {multi} {ICT_IRQ_NUM} {0b0}  Enabled: Always  Parameter Name: ICT_IRQ_DFLT_EN |
|                                       | FIQ Configuration                                                                                                                                                                                                                                                                                                                                                                    |
| Install Fast Interrupt<br>Generation? | Instantiates the generation logic for fast interrupts.  Values:  false (0)  true (1)  Default Value: true  Enabled: Always  Parameter Name: ICT_HAS_FIQ                                                                                                                                                                                                                              |
| Number of fiq sources (1 -> 8)        | Defines the number of fast interrupt sources to generate. This parameter can be set only if the ICT_HAS_FIQ parameter is set to True(1).  Values: 1, 2, 3, 4, 5, 6, 7, 8  Default Value: 4  Enabled: ICT_HAS_FIQ==1  Parameter Name: ICT_FIQ_NUM                                                                                                                                     |
| FIQ Source Polarities                 | Specifies the FIQ Source Polarity Type. You must either use the individual interrupt polarities or override these to be either all active high or all active low.  Values:  Individual (0)  All-Active-Low (1)  All-Active-High (2)  Default Value: Individual  Enabled: ICT_HAS_FIQ==1  Parameter Name: ICT_FIQSRC_POL_TYPE                                                         |
| Individual fiq enables on reset       | Specifies the reset state of the FIQ interrupt source enable register. A logic '1' in any bit position indicates that the fast interrupt source corresponding to that bit is enabled on reset; a logic '0' indicates that it is not enabled on reset.  Values: 0x0,, 0xf  Default Value: {multi} {ICT_FIQ_NUM} {0b0}  Enabled: ICT_HAS_FIQ==1  Parameter Name: ICT_FIQ_DFLT_EN       |

### 3.2 Vector Port Interface Parameters

Table 3-2 Vector Port Interface Parameters

| Label                                                                         | Description                                                                                                                                                                                                                                                                                                          |  |
|-------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                                                                               | Vector Port Configuration                                                                                                                                                                                                                                                                                            |  |
| Add Vector Port Interface ?                                                   | Selects whether or not to include vector port signals and functionality in the interrupt controller. The vector port allows a processor with similar functionality to sample the IRQ vector address directly without performing an AHB bus access, thereby potentially improving interrupt service latency.  Values: |  |
|                                                                               | ■ false (0)                                                                                                                                                                                                                                                                                                          |  |
|                                                                               | ■ true (1)  Default Value: false                                                                                                                                                                                                                                                                                     |  |
|                                                                               | Enabled: ((ICT_HAS_PFLT==1)?ICT_HAS_VECTOR_USER:0)==1 Parameter Name: ICT_ADD_VECTOR_PORT                                                                                                                                                                                                                            |  |
| Add Vector Port Interface Synchronisation ?                                   | Adds an N-stage (where N = ICT_ADD_VECTOR_PORT_SYNC_DEPTH) hclk synchronization on vector port signals coming from the processor (irq_ack). This parameter is used when the processor clock and hclk are asynchronous.  Values:                                                                                      |  |
|                                                                               | ■ false (0)                                                                                                                                                                                                                                                                                                          |  |
|                                                                               | ■ true (1)                                                                                                                                                                                                                                                                                                           |  |
|                                                                               | Default Value: false Enabled: ICT_ADD_VECTOR_PORT==1 Parameter Name: ICT_ADD_VECTOR_PORT_SYNC                                                                                                                                                                                                                        |  |
| Number of synchronization stages on vector port signal coming from processor? | Selects the number of hclk synchronization stages on vector port signal.  Values: 2, 3, 4  Default Value: 2  Enabled: ICT_ADD_VECTOR_PORT_SYNC==1  Parameter Name: ICT_ADD_VECTOR_PORT_SYNC_DEPTH                                                                                                                    |  |

## 3.3 Priority Controller Configuration Parameters

**Table 3-3** Priority Controller Configuration Parameters

| Label                                                        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
|--------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Priority Controller Configuration                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |
| System priority controller filter level                      | Defines the default system priority controller filter level. This is the reset value of the interrupt priority level filter register. The interrupts must have a priority greater than or equal to this value to be propagated to the CPU. This parameter value may always be overwritten by software and is required only when the priority filter is installed.  Values: 0x0, 0x1, 0x2, 0x3, 0x4, 0x5, 0x6, 0x7, 0x8, 0x9, 0xa, 0xb, 0xc, 0xd, 0xe, 0xf  Default Value: 0x0  Enabled: ICT_HAS_PFLT==1  Parameter Name: ICT_IRQ_PLEVEL |  |  |  |  |
| Priority level of IRQ Source x (for x = 1; x <= ICT_IRQ_NUM) | Sets the default priority level for interrupt source 0. It can be set only if the ICT_HAS_PFLT parameter is set to True (1).  Values: 0x0, 0x1, 0x2, 0x3, 0x4, 0x5, 0x6, 0x7, 0x8, 0x9, 0xa, 0xb, 0xc, 0xd, 0xe, 0xf  Default Value: 0x0  Enabled: ICT_HAS_PFLT==1  Parameter Name: ICT_ISRC_PLEVEL_x                                                                                                                                                                                                                                   |  |  |  |  |

## 3.4 Configuration of Vector Generation Module Parameters

**Table 3-4** Configuration of Vector Generation Module Parameters

| Label                                              | Description                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                    | Configuration of Vector 0                                                                                                                                                                                                                                                                                                                                                                                                          |
| Priority x vector (for x = 1; x <= ICT_IRQ_PLEVEL) | Vector for interrupts with a priority setting of 0. Value must be less than HADDR_WIDTH bits wide.  Values: 0x0,, 0xffffffff  Default Value: 0x0  Enabled: ICT_HAS_VECTOR_USER==1 && ICT_HAS_PFLT==1  Parameter Name: ICT_VECTOR_x                                                                                                                                                                                                 |
| Hardcode Vector x (for x = 1; x <= ICT_IRQ_PLEVEL) | Hardcodes the corresponding priority vector and the irq_vector_x register is read only. If this parameter is set to False (0), the corresponding priority vector is programmable and the corresponding irq_vector_x register is read/write. This is configurable only if ICT_HAS_VECTOR=1 and ICT_HAS_PFLT=1.  Values: 0, 1  Default Value: 0  Enabled: ICT_HAS_VECTOR_USER==1 && ICT_HAS_PFLT==1  Parameter Name: ICT_HC_VECTOR_x |

## 3.5 Individual IRQ Polarity Configuration Parameters

Table 3-5 Individual IRQ Polarity Configuration Parameters

| Label                                                       | Description                                                                                                                                                                                                                                                                                               |  |  |  |  |
|-------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|                                                             | Individual IRQ Polarity Configuration                                                                                                                                                                                                                                                                     |  |  |  |  |
| Interrupt irq x Active High ? (for x = 1; x <= ICT_IRQ_NUM) | Sets the interrupt level of interrupt 0 to either active high (1) or active low (0). This is configurable only if ICT_IRQSRC_POL_TYPE = Individual (0).  Values: 0x0, 0x1  Default Value: ICT_IRQSRC_POL_TYPE != 1  Enabled: ICT_IRQSRC_POL_TYPE == 0 && ICT_IRQ_NUM > 0  Parameter Name: CT_IRQSRC_POL_x |  |  |  |  |

## 3.6 Individual FIQ Polarity Configuration Parameters

Table 3-6 Individual FIQ Polarity Configuration Parameters

| Label                                                   | Description                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
|---------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|                                                         | Individual FIQ Polarity Configuration                                                                                                                                                                                                                                                                                        |  |  |  |  |
| Interrupt x Active High ? (for x = 1; x <= ICT_FIQ_NUM) | Sets the interrupt level of interrupt 0 to either active high (1) or active low (0). This is configurable only if ICT_FIQSRC_POL_TYPE = Individual (0).  Values: 0x0, 0x1  Default Value: ICT_FIQSRC_POL_TYPE != 1  Enabled: ICT_HAS_FIQ==1 && ICT_FIQSRC_POL_TYPE == 0 && ICT_FIQ_NUM > 0  Parameter Name: ICT_FIQSRC_POL_x |  |  |  |  |

# **Signal Descriptions**

This chapter details all possible I/O signals in the controller. 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 controller. It is for reference purposes only.

When you configure the controller 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 controller 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 inactive 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.

#### **Attributes used with Synchronous To**

- Clock name The name of the clock that samples an input or drive and output.
- None This attribute may be used for clock inputs, hard-coded outputs, feed-through (direct or combinatorial), dangling inputs, unused inputs and asynchronous outputs.
- Asynchronous This attribute is used for asynchronous inputs and asynchronous resets.

#### The I/O signals are grouped as follows:

- AHB Interface on page 43
- Interrupt on page 46
- Interrupt Source on page 47
- Vector Interrupt and Handshake Signals on page 48
- Miscellaneous on page 49

### 4.1 AHB Interface Signals



Table 4-1 AHB Interface Signals

| Port Name | I/O | Description                                                                                                                                             |
|-----------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| hclk      | 1   | Bus clock.  Exists: Always  Synchronous To: None  Registered: N/A  Power Domain: SINGLE_DOMAIN  Active State: N/A                                       |
| hresetn   | I   | Bus reset. Removed synchronously to hclk  Exists: Always  Synchronous To: Asynchronous  Registered: N/A  Power Domain: SINGLE_DOMAIN  Active State: Low |
| hsel      | I   | Slave select line.  Exists: Always  Synchronous To: hclk  Registered: No  Power Domain: SINGLE_DOMAIN  Active State: High                               |
| hwrite    | I   | Write control.  Exists: Always Synchronous To: hclk Registered: No Power Domain: SINGLE_DOMAIN Active State: High                                       |

Table 4-1 AHB Interface Signals (Continued)

| Port Name                    | I/O | Description                                                                                                                                 |
|------------------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------|
| htrans[1:0]                  | I   | Transfer control.  Exists: Always Synchronous To: hclk Registered: No Power Domain: SINGLE_DOMAIN Active State: N/A                         |
| hsize[2:0]                   |     | Transfer size.  Exists: Always  Synchronous To: hclk  Registered: No  Power Domain: SINGLE_DOMAIN  Active State: N/A                        |
| hready                       | I   | Current transfer is complete.  Exists: Always Synchronous To: hclk Registered: No Power Domain: SINGLE_DOMAIN Active State: High            |
| haddr[(HADDR_WIDTH-1):0]     | I   | Address.  Exists: Always Synchronous To: hclk Registered: No Power Domain: SINGLE_DOMAIN Active State: N/A                                  |
| hwdata[(AHB_DATA_WIDTH-1):0] | Ι   | Write data.  Exists: Always  Synchronous To: hclk  Registered: No  Power Domain: SINGLE_DOMAIN  Active State: N/A                           |
| hresp[1:0]                   | 0   | Response type from slave.  Exists: Always  Synchronous To: hclk  Registered: 0:0=Yes;1:1=No  Power Domain: SINGLE_DOMAIN  Active State: N/A |

Table 4-1 AHB Interface Signals (Continued)

| Port Name                    | I/O | Description                                                                                                                                                                 |
|------------------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| hready_resp                  | 0   | Response from slave. When asserted, current transfer has completed.  Exists: Always  Synchronous To: hclk  Registered: Yes  Power Domain: SINGLE_DOMAIN  Active State: High |
| hrdata[(AHB_DATA_WIDTH-1):0] | 0   | Data from slave.  Exists: Always  Synchronous To: hclk  Registered: Yes  Power Domain: SINGLE_DOMAIN  Active State: N/A                                                     |

## 4.2 Interrupt Signals



Table 4-2 Interrupt Signals

| Port Name | I/O | Description                                                                                                                                                               |
|-----------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| irq       | 0   | Optional. Active-high normal interrupt.  Exists: ICT_INT_POL==1 Synchronous To: hclk Registered: No Power Domain: SINGLE_DOMAIN Active State: High                        |
| irq_n     | 0   | Optional. Active-low normal interrupt.  Exists: ICT_INT_POL==0 Synchronous To: hclk Registered: No Power Domain: SINGLE_DOMAIN Active State: Low                          |
| fiq       | 0   | Optional. Active-high fast interrupt.  Exists: (ICT_INT_POL==1) && (ICT_HAS_FIQ==1)  Synchronous To: hclk  Registered: No Power Domain: SINGLE_DOMAIN  Active State: High |
| fiq_n     | 0   | Optional. Active-low fast interrupt.  Exists: (ICT_INT_POL==0) && (ICT_HAS_FIQ==1)  Synchronous To: hclk  Registered: No Power Domain: SINGLE_DOMAIN  Active State: Low   |

## 4.3 Interrupt Source Signals



Table 4-3 Interrupt Source Signals

| Port Name                     | I/O | Description                                                                                                                                                   |
|-------------------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| fiq_intsrc[(ICT_FIQ_NUM-1):0] | I   | Bused interrupts for fast interrupt generation.  Exists: ICT_HAS_FIQ==1  Synchronous To: hclk  Registered: No  Power Domain: SINGLE_DOMAIN  Active State: N/A |
| irq_intsrc[(ICT_IRQ_NUM-1):0] | I   | Bused interrupts for normal interrupt generation.  Exists: Always  Synchronous To: hclk  Registered: No  Power Domain: SINGLE_DOMAIN  Active State: N/A       |

### 4.4 Vector Interrupt and Handshake Signals



Table 4-4 Vector Interrupt and Handshake Signals

| Port Name                   | I/O | Description                                                                                                                                                                                                                                                                |
|-----------------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| irq_addr[(HADDR_WIDTH-1):0] | 0   | Optional. Address vector sampled by the processor during vector port handshaking.  Exists: ICT_ADD_VECTOR_PORT==1  Synchronous To: hclk  Registered: No Power Domain: SINGLE_DOMAIN  Active State: N/A                                                                     |
| irq_ack                     | I   | Optional. Asserted by processor to acknowledge receipt of the IRQ.  Exists: ICT_ADD_VECTOR_PORT==1  Synchronous To: ICT_ADD_VECTOR_PORT_SYNC==1?  "Asynchronous": "hclk"  Registered: ICT_ADD_VECTOR_PORT_SYNC==1? Yes: No Power Domain: SINGLE_DOMAIN  Active State: High |
| irq_addr_v                  | O   | Optional. Asserted by DW_ahb_ictl to inform processor that it may sample irq_addr.  Exists: ICT_ADD_VECTOR_PORT==1 Synchronous To: hclk Registered: Yes Power Domain: SINGLE_DOMAIN Active State: High                                                                     |

## 4.5 Miscellaneous Signals

scan\_mode -

Table 4-5 Miscellaneous Signals

| Port Name | I/O | Description                                                                                                                                                                                                                                                                                                                                             |
|-----------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| scan_mode | I   | Optional scan mode. This signal helps increase fault coverage in the design. During scan testing, scan_mode must be asserted- that is, tied to logic 1. At all other times, this signal must be de-asserted- tied to logic 0.  Exists: (ICT_HAS_PFLT==1)  Synchronous To: Asynchronous  Registered: No  Power Domain: SINGLE_DOMAIN  Active State: High |

# **Register Descriptions**

This chapter details all possible registers in the controller. 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 controller 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 controller 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**

These 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 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.            |  |  |  |  |
| WOC                         | A write of 0 clears this register field.             |  |  |  |  |
| W0S                         | A write of 0 sets this register field.               |  |  |  |  |
| WOT                         | 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\_ahb\_ictl\_mem\_map

| Address Block                      | Description                              |
|------------------------------------|------------------------------------------|
| DW_ahb_ictl_addr_block1 on page 54 | DW_ahb_ictl address block Exists: Always |

### 5.1 DW\_ahb\_ictl\_mem\_map/DW\_ahb\_ictl\_addr\_block1 Registers

DW\_ahb\_ictl address block. Follow the link for the register to see a detailed description of the register.

Table 5-5 Registers for Address Block: DW\_ahb\_ictl\_mem\_map/DW\_ahb\_ictl\_addr\_block1

| Register                                                       | Offset | Description                                                                                  |
|----------------------------------------------------------------|--------|----------------------------------------------------------------------------------------------|
| irq_inten_I on page 56                                         | 0x0    | This register specifies the interrupt enable bits for the lower 32 interrupt sources.        |
| irq_inten_h on page 57                                         | 0x4    | This register specifies interrupt enable bit for upper 32 interrupt sources.                 |
| irq_intmask_I on page 58                                       | 0x8    | This register masks interrupt bits for the lower 32 interrupt sources.                       |
| irq_intmask_h on page 59                                       | 0xc    | This register masks interrupt bits for the upper 32 interrupt sources.                       |
| irq_intforce_I on page 60                                      | 0x10   | This register specifies interrupt force bits for the lower 32 interrupt sources.             |
| irq_intforce_h on page 61                                      | 0x14   | This register specifies the interrupt force bits for the upper 32 interrupt sources.         |
| irq_rawstatus_I on page 62                                     | 0x18   | This register specifies the lower 32 actual interrupt sources.                               |
| irq_rawstatus_h on page 63                                     | 0x1c   | This register specifies the upper 32 actual interrupt sources.                               |
| irq_status_I on page 64                                        | 0x20   | This register specifies the interrupt status signal for the lower 32 interrupt sources.      |
| irq_status_h on page 65                                        | 0x24   | This register specifies the interrupt status signals for the upper 32 interrupt sources.     |
| irq_maskstatus_I on page 66                                    | 0x28   | This register specifies the interrupt status signals for the lower 32 interrupt sources.     |
| irq_maskstatus_h on page 67                                    | 0x2c   | irq_maskstatus_h register specifies the interrupt status signals for the upper 32 interrupt  |
| irq_finalstatus_I on page 68                                   | 0x30   | This register specifies the interrupt status signals for the lower 32 interrupt sources.     |
| irq_finalstatus_h on page 69                                   | 0x34   | irq_finalstatus_h register specifies the interrupt status signals for the upper 32 interrupt |
| irq_vector on page 70                                          | 0x38   | This register denotes the vector with the highest priority level interrupt.                  |
| irq_vector_x<br>(for x = 1; x <= ICT_IRQ_PLEVEL) on<br>page 71 | 0x40   | Interrupt Vector (Priority Level 0) Register                                                 |
| fiq_inten on page 72                                           | 0xc0   | This register indicates the bits to enable the Fast Interrupt.                               |

SolvNet

Registers for Address Block: DW\_ahb\_ictl\_mem\_map/DW\_ahb\_ictl\_addr\_block1 (Continued) Table 5-5

| Register                                                | Offset | Description                                                                                    |
|---------------------------------------------------------|--------|------------------------------------------------------------------------------------------------|
| fiq_intmask on page 73                                  | 0xc4   | This register indicates the bits to mask a Fast Interrupt.                                     |
| fiq_intforce on page 74                                 | 0xc8   | This register indicate the Fast Interrupt Force bits.                                          |
| fiq_rawstatus on page 75                                | 0xcc   | This register indicates the Fast Interrupt Source Raw Status bits.                             |
| fiq_status on page 76                                   | 0xd0   | This register indicates the Fast Interrupt Status Register bits.                               |
| fiq_finalstatus on page 77                              | 0xd4   | This register indicates the Fast Interrupt Final Status bits.                                  |
| irq_plevel on page 78                                   | 0xd8   | This register specifies the normal interrupt (IRQ) System Priority Level bits.                 |
| irq_internal_plevel on page 79                          | 0xdc   | This register specifies the internal IRQ system priority level.                                |
| irq_pr_x<br>(for x = 1; x <= ICT_IRQ_NUM) on<br>page 81 | 0xe8   | This register specifies the normal interrupt (IRQ) Individual Interrupt x Priority Level bits. |
| ICTL_COMP_PARAMS_2 on page 82                           | 0x3f0  | This register denotes the Component Parameter Register 2 bits.                                 |
| ICTL_COMP_PARAMS_1 on page 86                           | 0x3f4  | This register denotes the Component Parameter Register 1 bits.                                 |
| AHB_ICTL_COMP_VERSION on page 90                        | 0x3f8  | This register specifies the version of the Component.                                          |
| ICTL_COMP_TYPE on page 91                               | 0x3fc  | This register specifies the Component Type.                                                    |

### 5.1.1 irq\_inten\_I

■ Name: Interrupt Source Enable (Low) Register

■ **Description:** This register specifies the interrupt enable bits for the lower 32 interrupt sources.

Size: 32 bitsOffset: 0x0Exists: Always



Table 5-6 Fields for Register: irq\_inten\_I

| Bits | Name             | Memory<br>Access | Description                                                                                                                                                                                                                                                                                                                                                                                            |
|------|------------------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:y | RSVD_irq_inten_I | R                | RSVD_irq_inten_I Reserved bits - Read Only Value After Reset: 0x0 Exists: Always Range Variable[y]: ICT_IRQ_NUM                                                                                                                                                                                                                                                                                        |
| x:0  | irq_inten_I      | R/W              | These bits specify the interrupt enable bits for lower 32 interrupt sources. A 1 in any bit position enables the corresponding interrupt.  Values:  Ox0 (DISABLED): Interrupt is disabled  Ox1 (ENABLED): Interrupt is enabled  Value After Reset: The corresponding bits of the ICT_IRQ_DFLT_EN configuration parameter.  Exists: Always  Range Variable[x]: "(ICT_IRQ_NUM<32) ? ICT_IRQ_NUM: 32" - 1 |

#### 5.1.2 irq\_inten\_h

■ Name: Interrupt Source Enable (High) Register

■ **Description:** This register specifies interrupt enable bit for upper 32 interrupt sources.

Size: 32 bitsOffset: 0x4



Table 5-7 Fields for Register: irq\_inten\_h

| Bits | Name             | Memory<br>Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| х:у  | RSVD_irq_inten_h | R                | RSVD_irq_inten_h Reserved bits - Read Only Value After Reset: 0x0 Exists: Always Range Variable[x]: "32-(ICT_IRQ_NUM-32)" + "(ICT_IRQ_NUM - 32)" - 1 Range Variable[y]: "(ICT_IRQ_NUM - 32)"                                                                                                                                                                                                                                                                        |
| x:0  | irq_inten_h      | R/W              | These bits specify the interrupt enable bit for upper 32 interrupt sources. A 1 in any bit position enables the corresponding interrupt. If there are less than 32 interrupt sources, this address location and register do not exist for a write or a read. By default, all bits enabled.  Value After Reset: The corresponding bits of the ICT_IRQ_DFLT_EN configuration parameter.  Exists: (ICT_IRQ_NUM>32) ? 1: 0  Range Variable[x]: "(ICT_IRQ_NUM - 32)" - 1 |

### 5.1.3 irq\_intmask\_l

■ Name: Interrupt Source Mask (Low) Register

■ **Description:** This register masks interrupt bits for the lower 32 interrupt sources.

Size: 32 bitsOffset: 0x8Exists: Always



Table 5-8 Fields for Register: irq\_intmask\_I

| Bits | Name               | Memory<br>Access | Description                                                                                                                                                                                                                                                                                                                                                                   |
|------|--------------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:y | RSVD_irq_intmask_I | R                | RSVD_irq_intmask_I Reserved bits - Read Only Value After Reset: 0x0 Exists: Always Range Variable[y]: ICT_IRQ_NUM                                                                                                                                                                                                                                                             |
| x:0  | irq_intmask_I      | R/W              | These bits indicate the interrupt mask bits for the lower 32 interrupt sources. A 1 in any bit position masks (disables) the corresponding interrupt. By default, all bits are unmasked.  Values:  Ox0 (UNMASK): Unmasks the interrupts  Ox1 (MASK): Masks the interrupt  Value After Reset: 0x0  Exists: Always  Range Variable[x]: "(ICT_IRQ_NUM<32) ? ICT_IRQ_NUM: 32" - 1 |

#### 5.1.4 irq\_intmask\_h

■ Name: Interrupt Source Mask (High) Register

■ **Description:** This register masks interrupt bits for the upper 32 interrupt sources.

Size: 32 bitsOffset: 0xc



Table 5-9 Fields for Register: irq\_intmask\_h

| Bits | Name               | Memory<br>Access | Description                                                                                                                                                                                                                                                                                                                       |
|------|--------------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| х:у  | RSVD_irq_intmask_h | R                | RSVD_irq_intmask_h Reserved bits - Read Only Value After Reset: 0x0 Exists: Always Range Variable[x]: "32-(ICT_IRQ_NUM-32)" + "(ICT_IRQ_NUM - 32)" - 1 Range Variable[y]: "(ICT_IRQ_NUM - 32)"                                                                                                                                    |
| x:0  | irq_intmask_h      | R/W              | These bits indicate the interrupt mask bits for the upper 32 interrupt sources. If there are less than 32 interrupt sources, this address location does not exist for a write or a read. By default, all bits are unmasked.  Value After Reset: 0x0  Exists: (ICT_IRQ_NUM>32) ? 1: 0  Range Variable[x]: "(ICT_IRQ_NUM - 32)" - 1 |

### 5.1.5 irq\_intforce\_I

■ Name: Interrupt Force (Low) Register

■ **Description:** This register specifies interrupt force bits for the lower 32 interrupt sources.

Size: 32 bitsOffset: 0x10Exists: Always



Table 5-10 Fields for Register: irq\_intforce\_I

| Bits | Name                | Memory<br>Access | Description                                                                                                                                                                                                                                                                                                                                                                                   |
|------|---------------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:y | RSVD_irq_intforce_I | R                | RSVD_irq_intforce_I Reserved bits - Read Only Value After Reset: 0x0 Exists: Always Range Variable[y]: ICT_IRQ_NUM                                                                                                                                                                                                                                                                            |
| x:0  | irq_intforce_I      | R/W              | These bits indicate the interrupt force bits for the lower 32 interrupt sources. Each bit in this register corresponds to one bit of the irq_intsrc input. The polarity of the bits in the register correspond to the polarity of the associated irq_intsrc input. If the interrupt input is configured to be active high, the corresponding bit in the register is also active high. Values: |
|      |                     |                  | ■ 0x0 (ACTIVE_LOW): Active low polarity                                                                                                                                                                                                                                                                                                                                                       |
|      |                     |                  | ■ 0x1 (ACTIVE_HIGH): Active high polarity                                                                                                                                                                                                                                                                                                                                                     |
|      |                     |                  | Value After Reset: The reset state of the force bits is always inactive. It is derived by the configuration parameter ICT_IRQSRC_POL or ICT_FORCEREG_ACTIVE_HIGH.  Exists: Always                                                                                                                                                                                                             |
|      |                     |                  | Range Variable[x]: "(ICT_IRQ_NUM<32) ? ICT_IRQ_NUM : 32" - 1                                                                                                                                                                                                                                                                                                                                  |

### 5.1.6 irq\_intforce\_h

■ Name: Interrupt Force (High) Register

■ **Description:** This register specifies the interrupt force bits for the upper 32 interrupt sources.

Size: 32 bitsOffset: 0x14



Table 5-11 Fields for Register: irq\_intforce\_h

| Bits | Name                | Memory<br>Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|---------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| х:у  | RSVD_irq_intforce_h | R                | RSVD_irq_intforce_h Reserved bits - Read Only  Value After Reset: 0x0  Exists: Always  Range Variable[x]: "32-(ICT_IRQ_NUM-32)" +  "(ICT_IRQ_NUM - 32)" - 1  Range Variable[y]: "(ICT_IRQ_NUM - 32)"                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| x:0  | irq_intforce_h      | R/W              | These bits specify the interrupt force bits for the upper 32 interrupt sources. Each bit in this register corresponds to one bit of the irq_intsrc input. The polarity of the bits in the register correspond to the polarity of the associated irq_intsrc input. If the interrupt input is configured to be active high, the corresponding bit in the register is also active high. The reset state of the force bits is always inactive.  Value After Reset: The reset state of the force bits is always inactive. It is derived by the configuration parameter ICT_IRQSRC_POL or ICT_FORCEREG_ACTIVE_HIGH.  Exists: (ICT_IRQ_NUM>32) ? 1: 0  Range Variable[x]: "(ICT_IRQ_NUM - 32)" - 1 |

#### 5.1.7 irq\_rawstatus\_l

■ Name: Interrupt Raw Status (Low) Register

■ **Description:** This register specifies the lower 32 actual interrupt sources.

Size: 32 bitsOffset: 0x18Exists: Always



Table 5-12 Fields for Register: irq\_rawstatus\_I

| Bits | Name                  | Memory<br>Access | Description                                                                                                                                                                                                                                             |
|------|-----------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:y | RSVD_irq_raw_status_I | R                | RSVD_irq_raw_status_I Reserved bits - Read Only Value After Reset: 0x0 Exists: Always Volatile: true Range Variable[y]: ICT_IRQ_NUM                                                                                                                     |
| x:0  | irq_rawstatus_I       | R                | These bits specify the actual interrupt source. These are the lower 32 interrupt sources.  Values:  0x0 (INACTIVE): Inactive Raw Interrupt Status  0x1 (ACTIVE): Active Raw Interrupt Status  Value After Reset: irq_rawstatus_I - Dependent on setting |
|      |                       |                  | of corresponding interrupt source bit.  Exists: Always  Volatile: true  Range Variable[x]: "(ICT_IRQ_NUM<32) ? ICT_IRQ_NUM : 32" - 1                                                                                                                    |

#### 5.1.8 irq\_rawstatus\_h

■ Name: Interrupt Raw Status (High) Register

■ **Description:** This register specifies the upper 32 actual interrupt sources.

Size: 32 bitsOffset: 0x1c



Table 5-13 Fields for Register: irq\_rawstatus\_h

| Bits | Name                 | Memory<br>Access | Description                                                                                                                                                                                                                                                                                                                                                                              |
|------|----------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| х:у  | RSVD_irq_rawstatus_h | R                | RSVD_irq_rawstatus_h Reserved bits - Read Only Value After Reset: 0x0 Exists: Always Volatile: true Range Variable[x]: "32-(ICT_IRQ_NUM-32)" + "(ICT_IRQ_NUM - 32)" - 1 Range Variable[y]: "(ICT_IRQ_NUM - 32)"                                                                                                                                                                          |
| x:0  | irq_rawstatus_h      | R                | These bits specify the actual interrupt source. These are the upper 32 interrupt sources. If there are less than 32 interrupt sources, this address location does not exist for a read.  Value After Reset: irq_rawstatus_h - Dependent on setting of corresponding interrupt source bit.  Exists: (ICT_IRQ_NUM>32) ? 1 : 0  Volatile: true  Range Variable[x]: "(ICT_IRQ_NUM - 32)" - 1 |

#### 5.1.9 irq\_status\_l

■ Name: Interrupt Status Low Register

■ **Description:** This register specifies the interrupt status signal for the lower 32 interrupt sources.

Size: 32 bitsOffset: 0x20Exists: Always



Table 5-14 Fields for Register: irq\_status\_I

| Bits | Name                  | Memory<br>Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|-----------------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:y | RSVD_irq_raw_status_I | R                | RSVD_irq_raw_status_I Reserved bits - Read Only Value After Reset: 0x0 Exists: Always Volatile: true Range Variable[y]: ICT_IRQ_NUM                                                                                                                                                                                                                                                                                                                             |
| x:0  | irq_status_I          | R                | These bits specify the interrupt status after the forcing and interrupt enabling stage. These are the interrupt status signals for the lower 32 interrupt sources.  Values:  Ox0 (INACTIVE): Interrupt status is inactive  Ox1 (ACTIVE): Interrupt status is active  Value After Reset: irq_status_I - Dependent on setting of corresponding interrupt source bit.  Exists: Always  Volatile: true  Range Variable[x]: "(ICT_IRQ_NUM<32) ? ICT_IRQ_NUM: 32" - 1 |

#### 5.1.10 irq\_status\_h

■ Name: Interrupt Status (High) Register

■ **Description:** This register specifies the interrupt status signals for the upper 32 interrupt sources.

Size: 32 bitsOffset: 0x24



Table 5-15 Fields for Register: irq\_status\_h

| Bits | Name              | Memory<br>Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------|-------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| х:у  | RSVD_irq_status_h | R                | RSVD_irq_status_h Reserved bits - Read Only  Value After Reset: 0x0  Exists: Always  Volatile: true  Range Variable[x]: "32-(ICT_IRQ_NUM-32)" +  "(ICT_IRQ_NUM - 32)" - 1  Range Variable[y]: "(ICT_IRQ_NUM - 32)"                                                                                                                                                                                                                                                        |
| x:0  | irq_status_h      | R                | These bits specify the interrupt status after the forcing and interrupt enabling stage. These are the interrupt status signals for the upper 32 interrupt sources. If there are less than 32 interrupt sources, this address location does not exist for a write or a read.  Value After Reset: irq_status_h - Dependent on setting of corresponding interrupt source bit.  Exists: (ICT_IRQ_NUM>32) ? 1 : 0  Volatile: true  Range Variable[x]: "(ICT_IRQ_NUM - 32)" - 1 |

#### 5.1.11 irq\_maskstatus\_l

■ Name: Interrupt Mask Status (Low) Register

■ **Description:** This register specifies the interrupt status signals for the lower 32 interrupt sources.

Size: 32 bitsOffset: 0x28Exists: Always



Table 5-16 Fields for Register: irq\_maskstatus\_I

| Bits | Name                  | Memory<br>Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|-----------------------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:y | RSVD_irq_maskstatus_I | R                | RSVD_irq_maskstatus_I Reserved bits - Read Only Value After Reset: 0x0 Exists: Always Volatile: true Range Variable[y]: ICT_IRQ_NUM                                                                                                                                                                                                                                                                                                              |
| x:0  | irq_maskstatus_I      | R                | These bits specify the interrupt status after the masking stage. These are the interrupt status signals for the lower 32 interrupt sources.  Values:  Ox0 (INACTIVE): Inactive interrupt mask status  Ox1 (ACTIVE): Active interrupt mask status  Value After Reset: irq_maskstatus_I - Dependent on setting of corresponding interrupt source bit.  Exists: Always  Volatile: true  Range Variable[x]: "(ICT_IRQ_NUM<32) ? ICT_IRQ_NUM: 32" - 1 |

#### 5.1.12 irq\_maskstatus\_h

■ Name: Interrupt Mask Status (High) Register

■ **Description:** irq\_maskstatus\_h register specifies the interrupt status signals for the upper 32 interrupt sources.

Size: 32 bitsOffset: 0x2c



Table 5-17 Fields for Register: irq\_maskstatus\_h

| Bits | Name                  | Memory<br>Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|-----------------------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| х:у  | RSVD_irq_maskstatus_h | R                | RSVD_irq_maskstatus_h Reserved bits - Read Only Value After Reset: 0x0 Exists: Always Volatile: true Range Variable[x]: "32-(ICT_IRQ_NUM-32)" + "(ICT_IRQ_NUM - 32)" - 1 Range Variable[y]: "(ICT_IRQ_NUM - 32)"                                                                                                                                                                                                                                       |
| x:0  | irq_maskstatus_h      | R                | These bits specify the interrupt status after the masking stage. These are the interrupt status signals for the upper 32 interrupt sources. If there are less than 32 interrupt sources, this address location does not exist for a write or a read.  Value After Reset: irq_maskstatus_h - Dependent on setting of corresponding interrupt source bit.  Exists: (ICT_IRQ_NUM>32) ? 1 : 0  Volatile: true  Range Variable[x]: "(ICT_IRQ_NUM - 32)" - 1 |

#### 5.1.13 irq\_finalstatus\_l

■ Name: Interrupt Final Status (Low) Register

■ **Description:** This register specifies the interrupt status signals for the lower 32 interrupt sources.

Size: 32 bitsOffset: 0x30Exists: Always



Table 5-18 Fields for Register: irq\_finalstatus\_I

| Bits | Name                   | Memory<br>Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------|------------------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:y | RSVD_irq_finalstatus_I | R                | RSVD_irq_finalstatus_I Reserved bits - Read Only Value After Reset: 0x0 Exists: Always Volatile: true Range Variable[y]: ICT_IRQ_NUM                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| x:0  | irq_finalstatus_I      | R                | These bits specify the interrupt status after the priority level filtering stage. These are the interrupt status signals for the lower 32 interrupt sources. If there is no priority interrupt scheme configured, then this location contains the same value as irq_maskstatus_I.  Values:  Ox0 (INACTIVE): Inactive interrupt final status  Ox1 (ACTIVE): Active interrupt final status  Value After Reset: irq_finalstatus_I - Dependent on setting of corresponding interrupt source bit.  Exists: Always  Volatile: true  Range Variable[x]: "(ICT_IRQ_NUM<32) ? ICT_IRQ_NUM: 32" - 1 |

### 5.1.14 irq\_finalstatus\_h

■ Name: Interrupt Final Status (High) Register

■ **Description:** irq\_finalstatus\_h register specifies the interrupt status signals for the upper 32 interrupt sources.

Size: 32 bitsOffset: 0x34



Table 5-19 Fields for Register: irq\_finalstatus\_h

| Bits | Name                   | Memory<br>Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|------------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| х:у  | RSVD_irq_finalstatus_h | R                | RSVD_irq_finalstatus_h Reserved bits - Read Only Value After Reset: 0x0 Exists: Always Volatile: true Range Variable[x]: "32-(ICT_IRQ_NUM-32)" + "(ICT_IRQ_NUM - 32)" - 1 Range Variable[y]: "(ICT_IRQ_NUM - 32)"                                                                                                                                                                                                                                                                                                                              |
| x:0  | irq_finalstatus_h      | R                | These bits specify the interrupt status after the priority level filtering stage. These are the interrupt status signals for the upper 32 interrupt sources. If there are less than 32 interrupt sources, this location does not exist. If there is no priority interrupt scheme, this location contains the same value as irq_maskstatus_h.  Value After Reset: irq_finalstatus_h - Dependent on setting of corresponding interrupt source bit.  Exists: (ICT_IRQ_NUM>32) ? 1: 0  Volatile: true  Range Variable[x]: "(ICT_IRQ_NUM - 32)" - 1 |

#### 5.1.15 irq\_vector

■ Name: IRQ Vector Register

■ **Description:** This register denotes the vector with the highest priority level interrupt.

Size: 32 bitsOffset: 0x38Exists: Always



Table 5-20 Fields for Register: irq\_vector

| Bits | Name       | Memory<br>Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | irq_vector | R                | These bits indicate the vector with the highest priority level interrupt. When an interrupt occurs and the provided vectored interrupts are supported, this location can be read and it returns one of the 16 vectors. The returned vector corresponds to the highest priority level interrupt.  This register returns 0 when ICT_HAS_VECTOR = 0. To ensure valid data, this location may be accessed only with an hsize of 32. Otherwise, the slave interface issues an error response.  Value After Reset: System priority vector ICT_VECTOR_n value when there are no pending interrupts. Else, 0x0 when vectored interrupts not supported (ICT_HAS_VECTOR = 0).  Exists: Always  Volatile: true |

### 5.1.16 irq\_vector\_x (for x = 1; $x \le ICT_IRQ_PLEVEL$ )

■ Name: Interrupt Vector (Priority Level 0) Register

■ **Description:** Interrupt Vector (Priority Level 0) Register

Size: 32 bitsOffset: 0x40

■ Exists: (((ICT\_HAS\_PFLT==1)?ICT\_HAS\_VECTOR\_USER:0)==0) ? 0 : 1



Table 5-21 Fields for Register:  $irq_vector_x$  (for x = 1;  $x \le ICT_IRQ_PLEVEL$ )

| Bits | Name         | Memory<br>Access | Description                                                                                                                                                         |
|------|--------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | irq_vector_x | * Varies         | Interrupt vector for priority level x. This register does not exist when ICT_HAS_VECTOR = 0.                                                                        |
|      |              |                  | <ul> <li>If ICT_HC_VECTOR_x is set to 1, this is a read-only<br/>register and the interrupt vector is set by<br/>ICT_VECTOR_x.</li> </ul>                           |
|      |              |                  | If ICT_HC_VECTOR_x is set to 0, this is a read/write<br>register used to program the interrupt vector and the<br>reset value is determined by ICT_VECTOR_x.         |
|      |              |                  | <b>Value After Reset:</b> System priority vector value when there are no pending interrupts. Else, 0x0 when vectored interrupts not supported (ICT_HAS_VECTOR = 0). |
|      |              |                  | Exists: Always                                                                                                                                                      |
|      |              |                  | <b>Memory Access:</b> "(ICT_HC_VECTOR_0==0) ? \"readwrite\" : \"read-only\""                                                                                        |

### 5.1.17 fiq\_inten

■ Name: Fast Interrupt Enable Register

■ **Description:** This register indicates the bits to enable the Fast Interrupt.

Size: 32 bitsOffset: 0xc0

■ **Exists:** (ICT\_HAS\_FIQ==0) ? 0 : 1



Table 5-22 Fields for Register: fiq\_inten

| Bits | Name           | Memory<br>Access | Description                                                                                                                                                                                                                                                                                                                            |
|------|----------------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:y | RSVD_fiq_inten | R                | RSVD_fiq_inten Reserved bits - Read Only Value After Reset: 0x0 Exists: Always Range Variable[y]: ICT_FIQ_NUM                                                                                                                                                                                                                          |
| x:0  | fiq_inten      | R/W              | These bits enable the Fast interrupt. A 1 in any bit position enables the corresponding interrupt. This register does not exist when ICT_HAS_FIQ = 0.  Values:  Ox0 (DISABLED): Fast interrupt disabled  Ox1 (ENABLED): Fast interrupt enabled  Value After Reset: ICT_FIQ_DFLT_EN  Exists: Always  Range Variable[x]: ICT_FIQ_NUM - 1 |

## 5.1.18 fiq\_intmask

■ Name: Fast Interrupt Mask Register

■ **Description:** This register indicates the bits to mask a Fast Interrupt.

Size: 32 bitsOffset: 0xc4



Table 5-23 Fields for Register: fiq\_intmask

| Bits | Name             | Memory<br>Access | Description                                                                                                                                                                                                |
|------|------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:y | RSVD_fiq_intmask | R                | RSVD_fiq_intmask Reserved bits - Read Only Value After Reset: 0x0 Exists: Always Range Variable[y]: ICT_FIQ_NUM                                                                                            |
| x:0  | fiq_intmask      | R/W              | These bits mask the Fast interrupt mask. A 1 in any bit position masks the corresponding interrupt. This register does not exist when ICT_HAS_FIQ = 0.  Values:  0x0 (UNMASK): Unmasks the Fast interrupts |
|      |                  |                  | 0x1 (MASK): Masks the Fast interrupts  Value After Reset: 0x0  Exists: Always  Range Variable[x]: ICT_FIQ_NUM - 1                                                                                          |

## 5.1.19 fiq\_intforce

■ Name: Fast Interrupt Force Register

■ **Description:** This register indicate the Fast Interrupt Force bits.

Size: 32 bitsOffset: 0xc8



Table 5-24 Fields for Register: fiq\_intforce

| Bits | Name              | Memory<br>Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|-------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:y | RSVD_fiq_intforce | R                | RSVD_fiq_intforce Reserved bits - Read Only Value After Reset: 0x0 Exists: Always Range Variable[y]: ICT_FIQ_NUM                                                                                                                                                                                                                                                                                                                      |
| x:0  | fiq_intforce      | R/W              | These bits indicate the Fast interrupt force bits. Each bit in this register corresponds to one ICT_READ_PRIORITY bit of the irq_intsrc input. The polarity of the bits in the register correspond to the polarity of the associated fiq_intsrc input. If the interrupt input is configured to be active high, the corresponding bit in the register is also active high. This register does not exist when ICT_HAS_FIQ = 0.  Values: |
|      |                   |                  | Ox0 (ACTIVE_LOW): Active low interrupts  Ox4 (ACTIVE_LUCID): Active birth interrupts                                                                                                                                                                                                                                                                                                                                                  |
|      |                   |                  | ■ 0x1 (ACTIVE_HIGH): Active high interrupts  Value After Reset: The reset state of the force bits is always inactive. It is derived by the configuration parameter ICT_FIQSRC_POL_x (where x ranges from 0 to ICT_FIQ_NUM) or ICT_FORCEREG_ACTIVE_HIGH.  Exists: Always  Range Variable[x]: ICT_FIQ_NUM - 1                                                                                                                           |

## 5.1.20 fiq\_rawstatus

■ Name: Fast Interrupt Source Raw Status Register

■ **Description:** This register indicates the Fast Interrupt Source Raw Status bits.

Size: 32 bitsOffset: 0xcc



Table 5-25 Fields for Register: fiq\_rawstatus

| Bits | Name                | Memory<br>Access | Description                                                                                                                                                                                                                                                                                                                                                                       |
|------|---------------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:y | RSVD_fiq_raw_status | R                | RSVD_fiq_raw_status Reserved bits - Read Only Value After Reset: 0x0 Exists: Always Range Variable[y]: ICT_FIQ_NUM                                                                                                                                                                                                                                                                |
| x:0  | fiq_rawstatus       | R                | These bits indicate the Fast interrupt source raw input status. This register does not exist when ICT_HAS_FIQ = 0.  Values:  Ox0 (INACTIVE): Fast interrupt status is inactive  Ox1 (ACTIVE): Fast interrupt status is active  Value After Reset: fiq_rawstatus - Dependent on setting of corresponding interrupt source bit.  Exists: Always  Range Variable[x]: ICT_FIQ_NUM - 1 |

## 5.1.21 fiq\_status

■ Name: Fast Interrupt Status Register

■ **Description:** This register indicates the Fast Interrupt Status Register bits.

Size: 32 bitsOffset: 0xd0



Table 5-26 Fields for Register: fiq\_status

| Bits | Name            | Memory<br>Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|-----------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:y | RSVD_fiq_status | R                | RSVD_fiq_status Reserved bits - Read Only Value After Reset: 0x0 Exists: Always Volatile: true Range Variable[y]: ICT_FIQ_NUM                                                                                                                                                                                                                                                                                                |
| x:0  | fiq_status      | R                | These bits indicate the Fast interrupt status after the forcing and interrupt enabling stage. This register does not exist when ICT_HAS_FIQ = 0.  Values:  Ox0 (INACTIVE): Fast interrupt status is inactive  Ox1 (ACTIVE): Fast interrupt status is active  Value After Reset: fiq_status - Dependent on setting of corresponding interrupt source bit.  Exists: Always  Volatile: true  Range Variable[x]: ICT_FIQ_NUM - 1 |

## 5.1.22 fiq\_finalstatus

■ Name: Fast Interrupt Final Status Register

■ **Description:** This register indicates the Fast Interrupt Final Status bits.

Size: 32 bitsOffset: 0xd4



Table 5-27 Fields for Register: fiq\_finalstatus

| Bits | Name                  | Memory<br>Access | Description                                                                                                                                                                                                                                                                                                                                    |
|------|-----------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:y | RSVD_fiq_final_status | R                | RSVD_fiq_final_status Reserved bits - Read Only Value After Reset: 0x0 Exists: Always Volatile: true Range Variable[y]: ICT_FIQ_NUM                                                                                                                                                                                                            |
| x:0  | fiq_finalstatus       | R                | These bits indicate the Fast interrupt status after the masking stage. This register does not exist when ICT_HAS_FIQ = 0.  Values:                                                                                                                                                                                                             |
|      |                       |                  | <ul> <li>0x0 (INACTIVE): Fast interrupt final status is inactive</li> <li>0x1 (ACTIVE): Fast interrupt final status is active</li> <li>Value After Reset: fiq_finalstatus - Dependent on setting of corresponding interrupt source bit.</li> <li>Exists: Always</li> <li>Volatile: true</li> <li>Range Variable[x]: ICT_FIQ_NUM - 1</li> </ul> |

## 5.1.23 irq\_plevel

■ Name: IRQ System Priority Level Register

■ **Description:** This register specifies the normal interrupt (IRQ) System Priority Level bits.

Size: 32 bitsOffset: 0xd8Exists: Always



Table 5-28 Fields for Register: irq\_plevel

| Bits | Name            | Memory<br>Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|-----------------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | RSVD_irq_plevel | R                | RSVD_irq_plevel Reserved bits - Read Only Value After Reset: 0x0 Exists: Always                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 3:0  | irq_plevel      | R/W              | These bits specify the Interrupt controller system priority level for normal interrupt sources. The default state can be configured so that after reset the interrupt controller will accept only interrupts that are enabled and have a priority the same or greater than the system level priority setting.  If ICT_ADD_VECTOR_PORT is set to true, this register does not reflect the priority level being applied by the DW_ahb_ictl in the period between the completion of vector port handshaking and a write to irq_internal_plevel or arrival of a higher priority IRQ. During this time, irq_internal_plevel reflects the priority level currently being applied.  Value After Reset: ICT_IRQ_PLEVEL  Exists: Always |

## 5.1.24 irq\_internal\_plevel

■ Name: Internal IRQ System Priority Level Register

■ **Description:** This register specifies the internal IRQ system priority level.

Size: 32 bitsOffset: 0xdc

■ Exists: ICT\_ADD\_VECTOR\_PORT==1



Table 5-29 Fields for Register: irq\_internal\_plevel

| Bits | Name                     | Memory<br>Access | Description                                                                                                  |
|------|--------------------------|------------------|--------------------------------------------------------------------------------------------------------------|
| 31:5 | RSVD_irq_internal_plevel | R                | irq_internal_plevel 31to5 Reserved bits - Read Only.  Value After Reset: 0x0  Exists: Always  Volatile: true |

Table 5-29 Fields for Register: irq\_internal\_plevel (Continued)

| Bits | Name                | Memory<br>Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|---------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4:0  | irq_internal_plevel | R/W              | Internal interrupt system priority level register.  If ICT_ADD_VECTOR_PORT is set to true, this register reflects the priority level currently being applied by the DW_ahb_ictl. In the period between the completion of vector port handshaking and a write to irq_internal_plevel or arrival of a higher priority IRQ, it is set to one priority level greater than the priority level currently being handled by the processor. At all other times, it reflects the value of irq_plevel. This register should only be written to at the end of an interrupt service routine in order to reset the priority level to that of irq_plevel.  Reads to this register return the current priority level.  Writes to this register reset its value to irq_plevel; bus write data is ignored.  Value After Reset: ICT_IRQ_PLEVEL  Exists: (ICT_ADD_VECTOR_PORT==1) ? 1 : 0  Volatile: true |

## 5.1.25 irq\_pr\_x (for x = 1; $x \le ICT_IRQ_NUM$ )

■ Name: IRQ Individual Interrupt 0 Priority Level Register

■ **Description:** This register specifies the normal interrupt (IRQ) Individual Interrupt x Priority Level bits.

Size: 32 bitsOffset: 0xe8

■ Exists: (ICT\_READ\_PRIORITY==1 && ICT\_IRQ\_NUM-1 >= 0)?1:0



Table 5-30 Fields for Register:  $irq_pr_x$  (for x = 1;  $x \le ICT_IRQ_NUM$ )

| Bits | Name          | Memory<br>Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|---------------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | RSVD_irq_pr_x | R                | RSVD_irq_pr_x Reserved bits - Read Only Value After Reset: 0x0 Exists: Always                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 3:0  | irq_pr_x      | * Varies         | These bits specify the Individual interrupt x priority level. The number of Individual Interrupt Priority Level registers is from 0 to ICT_IRQ_NUM-1. A register's value must be an integer from 0x0 to 0xf.  Read/Write Values:  DNE: If ICT_READ_PRIORITY=0, then all irq_pN_priority registers do not exist.  R: If ICT_READ_PRIORITY=1 and ICT_HC_PRIORITIES=1, then interrupt 0 priority register is read-only  R/W: If ICT_READ_PRIORITY=1 and ICT_HC_PRIORITIES=0, then interrupt 0 priority register is read/write |
|      |               |                  | Value After Reset: ICT_IRQ_PLEVEL_x Exists: Always Memory Access: "(ICT_HC_PRIORITIES==0) ? \"readwrite\" : \"read-only\""                                                                                                                                                                                                                                                                                                                                                                                                 |

## 5.1.26 ICTL\_COMP\_PARAMS\_2

■ Name: Component Parameter Register 2

■ **Description:** This register denotes the Component Parameter Register 2 bits.

Size: 32 bitsOffset: 0x3f0Exists: Always

| RSVD_ICTL_COMP_PARAMS_2 | 31:16 |
|-------------------------|-------|
| ICT_HC_VECTOR_15        | 15    |
| ICT_HC_VECTOR_14        | 14    |
| ICT_HC_VECTOR_13        | 13    |
| ICT_HC_VECTOR_12        | 12    |
| ICT_HC_VECTOR_11        | 11    |
| ICT_HC_VECTOR_10        | 10    |
| ICT_HC_VECTOR_9         | 6     |
| ICT_HC_VECTOR_8         | 8     |
| ICT_HC_VECTOR_7         | 7     |
| ICT_HC_VECTOR_6         | 9     |
| ICT_HC_VECTOR_5         | 5     |
| ICT_HC_VECTOR_4         | 4     |
| ICT_HC_VECTOR_3         | 3     |
| ICT_HC_VECTOR_2         | 2     |
| ICT_HC_VECTOR_1         | 1     |
| ICT_HC_VECTOR_0         | 0     |

Table 5-31 Fields for Register: ICTL\_COMP\_PARAMS\_2

| Bits  | Name                    | Memory<br>Access | Description                                                                                                                                                                                                                     |
|-------|-------------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RSVD_ICTL_COMP_PARAMS_2 | R                | RSVD_ICTL_COMP_PARAMS_2 Reserved bits - Read Only Value After Reset: 0x0 Exists: Always                                                                                                                                         |
| 15    | ICT_HC_VECTOR_15        | R                | The value of this register is derived from the ICT_HC_VECTOR_15 parameter.  Values:  Ox0 (FALSE): Programmable interrupt vector.  Ox1 (TRUE): Hard coded interrupt vector.  Value After Reset: ICT_HC_VECTOR_15  Exists: Always |

Table 5-31 Fields for Register: ICTL\_COMP\_PARAMS\_2 (Continued)

| Bits | Name             | Memory<br>Access | Description                                                                                                                                                                                                                     |
|------|------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14   | ICT_HC_VECTOR_14 | R                | The value of this register is derived from the ICT_HC_VECTOR_14 parameter.  Values:  0x0 (FALSE): Programmable interrupt vector.  0x1 (TRUE): Hard coded interrupt vector.  Value After Reset: ICT_HC_VECTOR_14  Exists: Always |
| 13   | ICT_HC_VECTOR_13 | R                | The value of this register is derived from the ICT_HC_VECTOR_13 parameter.  Values:  Ox0 (FALSE): Programmable interrupt vector.  Ox1 (TRUE): Hard coded interrupt vector.  Value After Reset: ICT_HC_VECTOR_13  Exists: Always |
| 12   | ICT_HC_VECTOR_12 | R                | The value of this register is derived from the ICT_HC_VECTOR_12 parameter.  Values:  Ox0 (FALSE): Programmable interrupt vector.  Ox1 (TRUE): Hard coded interrupt vector.  Value After Reset: ICT_HC_VECTOR_12  Exists: Always |
| 11   | ICT_HC_VECTOR_11 | R                | The value of this register is derived from the ICT_HC_VECTOR_11 parameter.  Values:  0x0 (FALSE): Programmable interrupt vector.  0x1 (TRUE): Hard coded interrupt vector.  Value After Reset: ICT_HC_VECTOR_11  Exists: Always |
| 10   | ICT_HC_VECTOR_10 | R                | The value of this register is derived from the ICT_HC_VECTOR_10 parameter.  Values:  Ox0 (FALSE): Programmable interrupt vector.  Ox1 (TRUE): Hard coded interrupt vector.  Value After Reset: ICT_HC_VECTOR_10  Exists: Always |

Table 5-31 Fields for Register: ICTL\_COMP\_PARAMS\_2 (Continued)

| Bits | Name            | Memory<br>Access | Description                                                                                                                                                                                                                   |
|------|-----------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9    | ICT_HC_VECTOR_9 | R                | The value of this register is derived from the ICT_HC_VECTOR_9 parameter.  Values:  0x0 (FALSE): Programmable interrupt vector.  0x1 (TRUE): Hard coded interrupt vector.  Value After Reset: ICT_HC_VECTOR_9  Exists: Always |
| 8    | ICT_HC_VECTOR_8 | R                | The value of this register is derived from the ICT_HC_VECTOR_8 parameter.  Values:  0x0 (FALSE): Programmable interrupt vector.  0x1 (TRUE): Hard coded interrupt vector.  Value After Reset: ICT_HC_VECTOR_8  Exists: Always |
| 7    | ICT_HC_VECTOR_7 | R                | The value of this register is derived from the ICT_HC_VECTOR_7 parameter.  Values:  0x0 (FALSE): Programmable interrupt vector.  0x1 (TRUE): Hard coded interrupt vector.  Value After Reset: ICT_HC_VECTOR_7  Exists: Always |
| 6    | ICT_HC_VECTOR_6 | R                | The value of this register is derived from the ICT_HC_VECTOR_6 parameter.  Values:  0x0 (FALSE): Programmable interrupt vector.  0x1 (TRUE): Hard coded interrupt vector.  Value After Reset: ICT_HC_VECTOR_6  Exists: Always |
| 5    | ICT_HC_VECTOR_5 | R                | The value of this register is derived from the ICT_HC_VECTOR_5 parameter.  Values:  0x0 (FALSE): Programmable interrupt vector.  0x1 (TRUE): Hard coded interrupt vector.  Value After Reset: ICT_HC_VECTOR_5  Exists: Always |

Table 5-31 Fields for Register: ICTL\_COMP\_PARAMS\_2 (Continued)

| Bits | Name            | Memory<br>Access | Description                                                                                                                                                                                                                   |
|------|-----------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4    | ICT_HC_VECTOR_4 | R                | The value of this register is derived from the ICT_HC_VECTOR_4 parameter.  Values:  0x0 (FALSE): Programmable interrupt vector.  0x1 (TRUE): Hard coded interrupt vector.  Value After Reset: ICT_HC_VECTOR_4  Exists: Always |
| 3    | ICT_HC_VECTOR_3 | R                | The value of this register is derived from the ICT_HC_VECTOR_3 parameter.  Values:  0x0 (FALSE): Programmable interrupt vector.  0x1 (TRUE): Hard coded interrupt vector.  Value After Reset: ICT_HC_VECTOR_3  Exists: Always |
| 2    | ICT_HC_VECTOR_2 | R                | The value of this register is derived from the ICT_HC_VECTOR_2 parameter.  Values:  0x0 (FALSE): Programmable interrupt vector.  0x1 (TRUE): Hard coded interrupt vector.  Value After Reset: ICT_HC_VECTOR_2  Exists: Always |
| 1    | ICT_HC_VECTOR_1 | R                | The value of this register is derived from the ICT_HC_VECTOR_1 parameter.  Values:  0x0 (FALSE): Programmable interrupt vector.  0x1 (TRUE): Hard coded interrupt vector.  Value After Reset: ICT_HC_VECTOR_1  Exists: Always |
| 0    | ICT_HC_VECTOR_0 | R                | The value of this register is derived from the ICT_HC_VECTOR_0 parameter.  Values:  0x0 (FALSE): Programmable interrupt vector.  0x1 (TRUE): Hard coded interrupt vector.  Value After Reset: ICT_HC_VECTOR_0  Exists: Always |

## 5.1.27 ICTL\_COMP\_PARAMS\_1

■ Name: Component Parameter Register 1

■ **Description:** This register denotes the Component Parameter Register 1 bits.

Size: 32 bitsOffset: 0x3f4Exists: Always

| RSVD_ICTL_COMP_PARAMS_1  | 31:29 |
|--------------------------|-------|
| ICT_HC_PRIORITIES        | 28    |
| ICT_READ_PRIORITY        | 27    |
| ENCODED_ICT_FIQ_NUM      | 26:24 |
| RSVD_ICT_FIQ_DFLT_EN     | 23:y  |
| ICT_FIQ_DFLT_EN          | x:16  |
| ICT_HAS_VECTOR           | 15    |
| ICT_HAS_PFLT             | 14    |
| ENCODED_ICT_IRQ_NUM      | 13:8  |
| ICT_IRQ_PLEVEL           | 7:4   |
| ICT_HAS_FIQ              | 3     |
| ICT_FORCEREG_ACTIVE_HIGH | 2     |
| ENCODED_AHB_DATA_WIDTH   | 1:0   |

Table 5-32 Fields for Register: ICTL\_COMP\_PARAMS\_1

| Bits  | Name                    | Memory<br>Access                                                                                                                 | Description                                                                                 |  |
|-------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|--|
| 31:29 | RSVD_ICTL_COMP_PARAMS_1 | R                                                                                                                                | RSVD_ICTL_COMP_PARAMS_1 Reserved bits - Read Or Value After Reset: 0x0 Exists: Always       |  |
| 28    | ICT_HC_PRIORITIES       | R The value of this register is derived from the ICT_HC_PRIORITIES parameter.  Values:  0x0 (FALSE): Not able to read Priorities |                                                                                             |  |
|       |                         |                                                                                                                                  | ■ 0x1 (TRUE): Able to read Priorities  Value After Reset: ICT_HC_PRIORITIES  Exists: Always |  |

Table 5-32 Fields for Register: ICTL\_COMP\_PARAMS\_1 (Continued)

| Bits  | Name                 | Memory<br>Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
|-------|----------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 27    | ICT_READ_PRIORITY    | R                | The value of this register is derived from the ICT_READ_PRIORITY parameter.  Values:  Ox0 (FALSE): Priorities are not hardcoded  Ox1 (TRUE): Priorities are hardcoded  Value After Reset: ICT_READ_PRIORITY  Exists: Always                                                                                                                                                                                                                                                                                                                                                                                      |  |
| 26:24 | ENCODED_ICT_FIQ_NUM  | R                | This value is an encoded representation of the ICT_FIQ_NUM parameter.  Values:  ■ 0x0 (FIQ_NUM_1): Number of FIQ sources is equals to 1.  ■ 0x1 (FIQ_NUM_2): Number of FIQ sources is equals to 2.  ■ 0x2 (FIQ_NUM_3): Number of FIQ sources is equals to 3.  ■ 0x3 (FIQ_NUM_4): Number of FIQ sources is equals to 4.  ■ 0x4 (FIQ_NUM_5): Number of FIQ sources is equals to 5.  ■ 0x5 (FIQ_NUM_6): Number of FIQ sources is equals to 6.  ■ 0x6 (FIQ_NUM_7): Number of FIQ sources is equals to 7.  ■ 0x7 (FIQ_NUM_8): Number of FIQ sources is equals to 8.  Value After Reset: ICT_FIQ_NUM-1  Exists: Always |  |
| 23:y  | RSVD_ICT_FIQ_DFLT_EN | R                | RSVD_ICT_FIQ_DFLT_EN Reserved bits - Read Only Value After Reset: 0x0 Exists: (ICT_FIQ_NUM<8) ? 1 : 0 Range Variable[y]: ICT_FIQ_NUM + 16                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |
| x:16  | ICT_FIQ_DFLT_EN      | R                | The value of this register is derived from the ICT_FIQ_DFLT_EN coreConsultant parameter.  Values:  ■ 0x0 (ENABLES): Individual fiq enables on reset  Value After Reset: (`ICT_FIQ_NUM == 8) ?  `ICT_FIQ_DFLT_EN : {{(8-`ICT_FIQ_NUM){1'b0}},  `ICT_FIQ_DFLT_EN})  Exists: Always  Range Variable[x]: ICT_FIQ_NUM + 15                                                                                                                                                                                                                                                                                            |  |

Table 5-32 Fields for Register: ICTL\_COMP\_PARAMS\_1 (Continued)

| Bits | Name                | Memory<br>Access | Description                                                                                                                                                                                                                                                                                                                         |
|------|---------------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15   | ICT_HAS_VECTOR      | R                | The value of this register is derived from the ICT_HAS_VECTOR parameter.  Values:  Ox0 (FALSE): Interrupt vector generation circuitry is not instantiated.  Ox1 (TRUE): Interrupt vector generation circuitry is instantiated.  Value After Reset: ICT_HAS_VECTOR Exists: Always                                                    |
| 14   | ICT_HAS_PFLT        | R                | The value of this register is derived from the ICT_HAS_PFLT parameter.  Values:  Ox0 (FALSE): Does not allow interrupts that are assigned a priority level.  Ox1 (TRUE): Allows interrupts that are assigned a priority level to be compared against a system-level priority level.  Value After Reset: ICT_HAS_PFLT Exists: Always |
| 13:8 | ENCODED_ICT_IRQ_NUM | R                | This value is an encoded representation of the ICT_IRQ_NUM parameter.  0x00 = 2 to 0x3D = 64  0x3E to 0x3F = reserved  Value After Reset: ICT_IRQ_NUM-2  Exists: Always                                                                                                                                                             |
| 7:4  | ICT_IRQ_PLEVEL      | R                | The value of this register is derived from the ICT_IRQ_PLEVEL parameter.  Value After Reset: ICT_IRQ_PLEVEL  Exists: Always                                                                                                                                                                                                         |
| 3    | ICT_HAS_FIQ         | R                | The value of this register is derived from the ICT_HAS_FIQ parameter.  Values:  Ox0 (FALSE): Default system priority controller filter level is not defined.  Ox1 (TRUE): Defines the default system priority controller filter level.  Value After Reset: ICT_HAS_FIQ Exists: Always                                               |

Table 5-32 Fields for Register: ICTL\_COMP\_PARAMS\_1 (Continued)

| Bits | Name                     | Memory<br>Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
|------|--------------------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 2    | ICT_FORCEREG_ACTIVE_HIGH | R                | The value of this register is derived from the ICT_FORCEREG_ACTIVE_HIGH parameter.  Values:  Ox0 (FALSE): The irq_intforce and fiq_intforce register become active low.  Ox1 (TRUE): The irq_intforce and fiq_intforce register become active high.  Value After Reset: ICT_FORCEREG_ACTIVE_HIGH Exists: Always                                                                                                                                                                                           |  |
| 1:0  | ENCODED_AHB_DATA_WIDTH   | R                | This value is an encoded representation of the AHB_DATA_WIDTH parameter.  Values:  Ox0 (AHB_DATA_WIDTH_32): AHB data width is 32 bit  Ox1 (AHB_DATA_WIDTH_64): AHB data width is 64 bit  Ox2 (AHB_DATA_WIDTH_128): AHB data width 128 bit  Ox3 (AHB_DATA_WIDTH_256): AHB data width 256 bit  Value After Reset: Encoded Value of AHB_DATA_WIDTH; AHB_DATA_WIDTH=32, Reset Value=0; AHB_DATA_WIDTH=64, Reset Value=1; AHB_DATA_WIDTH=128, Reset Value=2; AHB_DATA_WIDTH=256, Reset Value=3  Exists: Always |  |

## 5.1.28 AHB\_ICTL\_COMP\_VERSION

■ Name: Component Version Register

■ **Description:** This register specifies the version of the Component.

Size: 32 bitsOffset: 0x3f8Exists: Always

IC\_COMP\_VERSION 31:0

Table 5-33 Fields for Register: AHB\_ICTL\_COMP\_VERSION

| Bits | Name            | Memory<br>Access | Description                                                                   |  |
|------|-----------------|------------------|-------------------------------------------------------------------------------|--|
| 31:0 | IC_COMP_VERSION | R                | These bits specify the component version.  Value After Reset: ICTL_VERSION_ID |  |
|      |                 |                  | Exists: Always                                                                |  |

90

## 5.1.29 ICTL\_COMP\_TYPE

■ Name: Component Type Register

■ **Description:** This register specifies the Component Type.

Size: 32 bitsOffset: 0x3fcExists: Always

ICTL\_COMP\_TYPE 31:0

Table 5-34 Fields for Register: ICTL\_COMP\_TYPE

| Bits | Name           | Memory<br>Access | Description                                                                                                                                                                                                                                                     |
|------|----------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | ICTL_COMP_TYPE | R                | These bits specify the DesignWare Component Type number (0x44_57_11_20). This assigned unique hexadecimal value is constant and is derived from the two ASCII letters 'DW' followed by a 16-bit unsigned number.  Value After Reset: 0x44571120  Exists: Always |

## Programming the DW\_ahb\_ictl

This section describes the some of the programmable features of the DW\_ahb\_ictl.

## 6.1 Programming Considerations

The APB data bus width is independently configurable from the width of registers internal to the DW\_ahb\_ictl. If the APB data bus width is narrower than the width of an internal register, multiple reads and writes are necessary to access the complete register.

## 6.2 Reading/Writing Registers Wider than APB\_DATA\_WIDTH



Because interrupt processing is combinational, care must be taken when reading and writing registers that are wider than APB\_DATA\_WIDTH.

Values of status registers can change if new interrupts arrive between reading slices of the register. Configuration registers should not be programmed while interrupts are enabled. Therefore, all IRQ interrupts should be disabled using the irq\_inten register prior to programming the vector registers.

#### 6.3 Initialization

A normal initialization sequence is as follows:

- 1. Disable all interrupts by writing to the irq\_inten and fiq\_inten. You can also configure the DW\_ahb\_ictl so that this is the reset state using the ICT\_IRQ\_DFLT\_EN and ICT\_FIQ\_DFLT\_EN parameters.
- 2. Initialize peripheral devices that could generate interrupts.
- 3. Program the irq\_vector, irq\_plevel, irq\_intmask, and fiq\_intmask registers as appropriate.
- 4. Enable interrupts.

#### 6.4 **Interrupt Service**

Without vectored interrupts, a normal interrupt servicing sequence is as follows:

- Poll the interrupt status register (irq\_finalstatus, irq\_maskstatus, or fiq\_finalstatus, as appropriate) to determine which interrupt source caused the interrupt.
- 2. Service the interrupt.
- 3. Optionally read the irq\_status or fiq\_status register to see if other currently masked interrupts are pending; service these as required.

With vectored interrupt support, a normal interrupt servicing sequence is as follows:

- Read the irq\_vector register to get the address of the service routine.
- 2. Service routine reads irq\_finalstatus to see which interrupt sources caused the interrupt.
- 3. Service the interrupt.
- 4. Optionally read the irq\_status to see if other interrupts are pending; service these as required.

#### 6.5 Illegal Accesses

The following are the cases where the slave interface of the DW\_ahb\_ictl issues an ERROR response.

- Accessing the slave with an address that does not decode to a register in the design. (The DW\_ahb\_ictl slave interface decodes for a 1 KB address space [bits 0 to 9 of haddr]. If an address inside this boundary does not refer to a register in the design, an ERROR is given.)
- Attempting to write to a read only register location.
- Accesses to a 64-bit register location with hsize greater than 64.
- Accesses to a 32-bit register location with hsize greater than 32.
- Accesses to the irq\_vector register with hsize < 32. This restriction is imposed to remove the need for shadow registers to guarantee coherency of irq\_vector for reads with a hsize of less than 32 bits.

The following figure shows an error response. The control for the errant access is driven from clock 1. In this case, you are attempting to write to the irq\_finalstatus register, which is read only. From clock 2, hready resp is driven low, and hresp is driven to ERROR. From clock 3, hready resp is driven to high and hresp remains at ERROR. From clock 4, hresp is driven to OKAY again and the ERROR response is complete.

Synopsys, Inc. 2.14a July 2018

Figure 6-1 AHB Error Response



## 6.6 Register Access

There is mixture of 32- and 64-bit registers in the AHB slave interface. All the registers are 64 bits wide, except the fiq registers, which are 32 bits wide. A register may not be accessed with a hsize greater than its width. Notwithstanding this hsize restriction, all other types of hsize accesses are supported as per the AMBA specification.

When performing a transfer on the AHB bus, the address must be aligned with the value of hsize. For example, if hsize = 32, then the address must be aligned to 32 bits, such as the two least significant bits equal 'b0. This condition is not checked in the slave interface but is a requirement of the AMBA specification. Also, hsize must not specify a transfer width greater than the slave's AHB data width; this is also a protocol violation.

# **7** Verification

This chapter provides an overview of the testbench available for DW\_ahb\_ictl verification. Once you have configured the DW\_ahb\_ictl in coreConsultant and have set up the verification environment, you can run simulations automatically.



The DW\_ahb\_ictl verification testbench is built with DesignWare Verification IP (VIP). Make sure 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 Installation Guide*.

#### 7.1 Overview of Vera Tests

The DW\_ahb\_ictl verification testbench performs the following set of tests, which exhaustively verify the functionality of the component and provide maximum RTL code coverage.

#### 7.1.1 Reset

The objective of this test is to ensure that all configurable registers are reset to the correct values defined for the DW\_ahb\_ictl under test.

#### 7.1.2 Slave Interface

Accesses to registers that do not contain configured interrupt or fast interrupt information return zeros. Registers are valid for only the number of active bits contained. For example, bytes 0 and 1 are valid for an access to irq\_register name when ICT\_IRQ\_NUM is 9 or greater. If ICT\_IRQ\_NUM is 8 or less, then only byte 0 is valid.

#### 7.1.3 FIQ

This sequence of tests verifies the operation of the FIQ generation circuitry and is repeated for active low and active high input FIQ source levels (fiq\_intrsrc). These tests are independent of the active level of the fast interrupt source inputs and are executed on each fiq\_intrsrc bit to verify all paths in the FIQ generation circuitry. The active level of fiq\_intsrcN and fiq\_forceN is determined by the ICT\_FIQ\_INTSRC\_POL\_n configuration parameter.

#### 7.1.4 IRQ

This sequence of tests verifies the operation of the IRQ generation circuitry and is repeated for active low and active high input IRQ source levels (irq\_intrsrc). These tests are independent of the active level of the interrupt source inputs and are executed on each irq\_intrsrc bit to verify all paths in the IRQ generation circuitry. The active level of irq\_intsrcN and irq\_forceN is determined by the ICT\_IRQ\_INTSRC\_POL\_n configuration parameter.

## 7.1.5 Priority Controller

This sequence of tests verifies the operation of the priority controller and vector generation. It verifies the generation of irq\_intpmask bus. This test is run when the DW\_ahb\_ictl is configured to have a priority controller. The vector generation sections of this test can be run only when the ICT\_HAS\_VECTOR configuration parameter is set to 1. These tests are independent of the active level of the interrupt source inputs.

### 7.1.6 Dynamic Reconfiguration

The tests associated with Priority Controller and IRQ tests, verify the operation of the priority controller and of the enable, mask and status registers. You must also be able to dynamically change the priority and vector register values without affecting the operation of the DW\_ahb\_ictl. This test is run only when the DW\_ahb\_ictl is configured to have a priority controller with vector generation. These tests are independent of the active level of the interrupt source inputs.

## 7.2 Overview of DW\_ahb\_ictl Testbench

As illustrated in Figure 7-1, the Verilog DW\_ahb\_ictl testbench includes an instantiation of the design under test (DUT), AHB bus model, and a Vera shell. The Vera shell consists of an AHB master bus functional model (BFM), one AHB slave BFM, an AHB monitor, test stimuli, BFM configuration, and test results. The AHB monitor tracks activity from the AHB master and slave BFMs.

The testbench covers all possible configurations that you specified in the Specify Configuration task of coreConsultant. The testbench also tests that the component is AMBA-compliant and includes a self-checking mechanism.

98

Figure 7-1 DW\_ahb\_ictl Testbench



1 By default, the testbench includes an AHB Monitor to test bus activity.

## 7.3 Running Simulations from the Command Line

To run simulations from a UNIX command line, a simulation model must be generated through the coreConsultant GUI. In addition, all tests and test options must be configured in the Verification tab of the GUI. Then, simulations can be run as follows:

■ To run all tests selected in the GUI, change your working directory to DW\_ahb\_ictl/sim and then execute the following command:

```
runtest.sh
```

■ To run single tests, change the working directory to DW\_ahb\_ictl/sim and run the following:

```
runtest --simulator selected simulator --test test name
```

The *selected\_simulator* is the one chosen in the GUI (does not work if not configured in the GUI). The *test\_name* is the name of the selected test and the sub directory where the test is located. For example, to run the simple register write/read test using vcs, run the following:

```
runtest --simulator vcs --test test_reg_wr_rd
```

The results of running tests through the command line are available only in each test directory, in the test.log file.

## 7.4 Command Line Output Files

The runtest.log file is generated in <code>workspace/sim/</code> only as a result of running simulations from coreConsultant or coreAssembler. The runtest.log file provides a pass/fail result for the particular simulation, as well as some detailed information. The test.log file located in <code>workspace/sim/test\_name</code> is generated when tests are run from the GUI or command line, and provides more detail on each specific test simulation, in addition to the pass/fail status. The waveforms are also written to this directory, when enabled. To enable waveform generation from the command line, the switch DumpEnabled must be set as follows:

```
runtest --simulator vcs --DumpEnabled 1 --test test reg wr rd
```

If the simulation results match expected results, the simulation completes successfully and the simulation status in the test.log file is PASSED. If the simulation results do not match expected results, the simulation terminates and the simulation status in the test.log file is FAILED.

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

## 8.1 Read Accesses

For reads, registers less than the full access width return zeros in the unused upper bits. An AHB read takes two hclk cycles. The two cycles can be thought of as a control and data cycle, respectively. As shown in the following figure, 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 8-1 AHB Read



## 8.2 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 the read case, a write access may be thought of as comprising a control and data cycle. As illustrated in the following figure, the address and control is 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 8-2 AHB Write



The operation of the AHB bus is pipelined, so while the write data for the first write is present on the bus for the slave to sample, the control for the next write is present on the bus for the slave to sample.

#### 8.3 Consecutive Write-Read

This is a specific case for the AHB slave interface. The AMBA specification says that for a read after a write to the same address, the newly written data must be read back, not the old data. To comply with this, the slave interface in the DW\_ahb\_ictl inserts a "wait state" when it detects a read immediately after a write to the same address. As shown in the following figure, 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 8-3 AHB Wait State Read/Write



Sensing the read after a write to the same address, the slave interface drives hready\_resp low from clock 3; hready\_resp is driven high on clock 4 when the new write data can be read; and the bus samples hready\_resp high on clock 5 and reads the newly written data. The following figure shows a normal consecutive write-read access.

Figure 8-4 AHB Consecutive Read/Write



## 8.4 Accessing Top-level Constraints

To get SDC constraints out of coreConsultant, 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>
```

## 8.5 Coherency

Coherency is where bits within a register are logically connected. For instance, part of a register is read at time 1 and another part is read at time 2. Being coherent means that the part read at time 2 is at the same value it was when the register was read at time 1. The unread part is stored into a shadow register and this is read at time 2. When there is no coherency, no shadow registers are involved.

A bus master may need to be able to read the contents of a register, regardless of the data bus width, and be guaranteed of the coherency of the value read. A bus master may need to be able to write a register coherently regardless of the data bus width and use that register only when it has been fully programmed. This may need to be the case regardless of the relationship between the clocks.

Coherency enables a value to be read that is an accurate reflection of the state of the counter, independent of the data bus width, the counter width, and even the relationship between the clocks. Additionally, a value written in one domain is transferred to another domain in a seamless and coherent fashion.

Throughout this appendix the following terms are used:

- Writing. A bus master programs a configuration register. An example is programming the load value of a counter into a register.
- **Transferring**. The programmed register is in a different clock domain to where it is used, therefore, it needs to be transferred to the other clock domain.
- **Loading**. Once the programmed register is transferred into the correct clock domain, it needs to be loaded or used to perform its function. For example, once the load value is transferred into the counter domain, it gets loaded into the counter.

## 8.5.1 Writing Coherently

Writing coherently means that all the bits of a register can be written at the same time. A peripheral may have programmable registers that are wider than the width of the connected APB data bus, which prevents all the bits being programmed at the same time unless additional coherency circuitry is provided.

The programmable register could be the load value for a counter that may exist in a different clock domain. Not only does the value to be programmed need to be coherent, it also needs to be transferred to a different clock domain and then loaded into the counter. Depending on the function of the programmable register, a qualifier may need to be generated with the data so that it knows when the new value is currently transferred and when it should be loaded into the counter.

Depending on the system and on the register being programmed, there may be no need for any special coherency circuitry. One example that requires coherency circuitry is a 32-bit timer within an 8-bit APB system. The value is entirely programmed only after four 8-bit wide write transfers. It is safe to transfer or use the register when the last byte is currently written. An example where no coherency is required is a 16-bit wide timer within a 16-bit APB system. The value is entirely programmed after a single 16-bit wide write transfer.

Coherency circuitry enables the value to be loaded into the counter only when fully programmed and crossed over clock domains if the peripheral clock is not synchronous to the processor clock. While the load register is being programmed, the counter has access to the previous load value in case it needs to reload the counter.

Coherency circuitry is only added in cores where it is needed. The coherency circuitry incorporates an upper byte method that requires users to program the load register in LSB to MSB order when the peripheral width is smaller than the register width. When the upper byte is programmed, the value can be transferred and loaded into the load register. When the lower bytes are being programmed, they need to be stored in shadow registers so that the previous load register is available to the counter if it needs to reload. When the upper byte is programmed, the contents of the shadow registers and the upper byte are loaded into the load register.

104 SolvNet Synopsys, Inc.
DesignWare.com

The upper byte is the top byte of a register. A register can be transferred and loaded into the counter only when it has been fully programmed. A new value is available to the counter once this upper byte is written into the register. The following table shows the relationship between the register width and the peripheral bus width for the generation of the correct upper byte. The numbers in the table represent bytes, Byte 0 is the LSB and Byte 3 is the MSB. NCR means that no coherency circuitry is required, as the entire register is written with one access.

Table 8-1 Upper Byte Generation

|                     | Upper Byte<br>Bus Width |          |     |  |  |
|---------------------|-------------------------|----------|-----|--|--|
| Load Register Width | 8                       | 16       | 32  |  |  |
| 1 - 8               | NCR                     | NCR      | NCR |  |  |
| 9 - 16              | 1                       | NCR      | NCR |  |  |
| 17 - 24             | 2                       | 2        | NCR |  |  |
| 25 - 32             | 3                       | 2 (or 3) | NCR |  |  |

There are three relationship cases to be considered for the processor and peripheral clocks:

- Identical
- Synchronous (phase coherent but of an integer fraction)
- Asynchronous

#### 8.5.1.1 Identical Clocks

The following figure illustrates an RTL diagram for the circuitry required to implement the coherent write transaction when the APB bus clock and peripheral clocks are identical.

Figure 8-5 Coherent Loading – Identical Synchronous Clocks



The following figure shows a 32-bit register that is written over an 8-bit data bus, as well as the shadow registers being loaded and then loaded into the counter when fully programmed. The LoadCnt signal lasts for one cycle and is used to load the counter with CntLoadValue.

Figure 8-6 Coherent Loading – Identical Synchronous Clocks



Each of the bytes that make up the load register are stored into shadow registers until the final byte is written. The shadow register is up to three bytes wide. The contents of the shadow registers and the final byte are transferred into the CntLoadValue register when the final byte is written. The counter uses this register to load/initialize itself. If the counter is operating in a periodic mode, it reloads from this register each time the count expires.

By using the shadow registers, the CntLoadValue is kept stable until it can be changed in one cycle. This allows the counter to be loaded in one access and the state of the counter is not affected by the latency in programming it. When there is a new value to be loaded into the counter initially, this is signaled by LoadCnt = 1. After the upper byte is written, the LoadCnt goes to zero.

#### 8.5.1.2 Synchronous Clocks

When the clocks are synchronous but do not have identical periods, the circuitry needs to be extended so that the LoadCnt signal is kept high until a rising edge of the counter clock occurs. This extension is necessary so that the value can be loaded, using LoadCnt, into the counter on the first counter clock edge. At the rising edge of the counter clock if LoadCnt is high, then a register clocked with the counter clock toggles, otherwise it keeps its current value. A circuit detecting the toggling is used to clear the original LoadCnt by looking for edge changes. The value is loaded into the counter when a toggle has been detected. Once it is loaded, the counter should be free to increment or decrement by normal rules.

The following figure shows an RTL diagram for the circuitry required to implement the coherent write when the bus and peripheral clocks are synchronous.

Figure 8-7 Coherent Loading – Synchronous Clocks



The following figure shows a 32-bit register being written over an 8-bit data bus, as well as the shadow registers being loaded and then loaded into the counter when fully programmed. The LoadCnt signal is extended until a change in the toggle is detected and is used to load the counter.

Figure 8-8 Coherent Loading – Synchronous Clocks



#### 8.5.1.3 Asynchronous Clocks

When the clocks are asynchronous, the processor clock needs to be three-times the speed of the peripheral clock for the re-timing to operate correctly. The high pulse time of the peripheral clock needs to be greater than the period of the processor clock. The following figure shows an RTL diagram for the circuitry required to implement the coherent write when the bus and peripheral clocks are asynchronous.

Figure 8-9 Coherent Loading – Asynchronous Clocks



When the clocks are asynchronous, you need to transfer the contents of the register from one clock domain to another. It is not desirable to transfer the entire register through meta-stability registers, as coherency is not guaranteed with this method. The circuitry needed requires the processor clock to be used to re-time the peripheral clock. Upon a rising edge of the re-timed clock, the new value signal, NewValue, is transferred into a safe new value signal, SafeNewValue, which happens after the edge of the peripheral clock has occurred.

Every time there is a rising edge of the peripheral clock detected, the CntLoadValue is transferred into a SafeCntLoadValue. This value is used to transfer the load value across the clock domains. The SafeCntLoadValue only changes a number of bus clock cycles after the peripheral clock edge changes. A

counter running on the peripheral clock is able to use this value safely. It could be up to two peripheral clock periods before the value is loaded into the counter. Along with this loaded value, there also is a single bit transferred that is used to qualify the loading of the value into the counter.

The timing diagram depicted in the following figure does not show the shadow registers being loaded. This is identical to the loading for the other clock modes.

Figure 8-10 Coherent Loading - Asynchronous Clocks



The NewValue signal is extended until a change in the toggle is detected and is used to update the safe value. The SafeNewValue is used to load the counter at the rising edge of the peripheral clock. Each time a new value is written the toggle bit is flipped and the edge detection of the toggle is used to remove both the NewValue and the SafeNewValue.

### 8.5.2 Reading Coherently

For writing to registers, an upper-byte concept is proposed for solving coherency issues. For read transactions, a lower-byte concept is required. The following table provides the relationship between the register width and the bus width for the generation of the correct lower byte.

Table 8-2 Lower Byte Generation

|                        | Lower Byte<br>Bus Width |     |     |
|------------------------|-------------------------|-----|-----|
| Counter Register Width | 8                       | 16  | 32  |
| 1 - 8                  | NCR                     | NCR | NCR |
| 9 - 16                 | 0                       | NCR | NCR |

Table 8-2 Lower Byte Generation

|         | Lower Byte<br>Bus Width |   |     |
|---------|-------------------------|---|-----|
| 17 - 24 | 0                       | 0 | NCR |
| 25 - 32 | 0                       | 0 | NCR |

Depending on the bus width and the register width, there may be no need to save the upper bits because the entire register is read in one access, in which case there is no problem with coherency. When the lower byte is read, the remaining upper bytes within the counter register are transferred into a holding register. The holding register is the source for the remaining upper bytes. Users must read LSB to MSB for this solution to operate correctly. NCR means that no coherency circuitry is required, as the entire register is read with one access.

There are two cases regarding the relationship between the processor and peripheral clocks to be considered as follows:

- Identical and/or synchronous
- Asynchronous

#### 8.5.2.1 Synchronous Clocks

When the clocks are identical and/or synchronous, the remaining unread bits (if any) need to be saved into a holding register once a read is started. The first read byte must be the lower byte provided in the previous table, which causes the other bits to be moved into the holding register, SafeCntVal, provided that the register cannot be read in one access. The upper bytes of the register are read from the holding register rather than the actual register so that the value read is coherent. This is illustrated in the following figure and in the timing diagram after it.

Figure 8-11 Coherent Registering – Synchronous Clocks





Figure 8-12 Coherent Registering – Synchronous Clocks

#### 8.5.2.2 Asynchronous Clocks

When the clocks are asynchronous, the processor clock needs to be three times the speed of the peripheral clock for the re-timing to operate correctly. The high pulse time of the peripheral clock needs to be greater than the period of the processor clock.

To safely transfer a counter value from the counter clock domain to the bus clock domain, the counter clock signal should be transferred to the bus clock domain. When the rising edge detect of this re-timed counter clock signal is detected, it is safe to use the counter value to update a shadow register that holds the current value of the counter.

While reading the counter contents it may take multiple APB transfers to read the value.



You must read LSB to MSB when the bus width is narrower than the counter width.

Once a read transaction has started, the value of the upper register bits need to be stored into a shadow register so that they can be read with subsequent read accesses. Storing these upper bits preserves the coherency of the value that is being read. When the processor reads the current value it actually reads the contents of the shadow register instead of the actual counter value. The holding register is read when the bus width is narrower than the counter width. When the LSB is read, the value comes from the shadow register; when the remaining bytes are read they come from the holding register. If the data bus width is wide enough to read the counter in one access, then the holding registers do not exist.

The counter clock is registered and successively pipelined to sense a rising edge on the counter clock. Having detected the rising edge, the value from the counter is known to be stable and can be transferred into the shadow register. The coherency of the counter value is maintained before it is transferred, because the value is stable.

The following figure illustrates the synchronization of the counter clock and the update of the shadow register.

Figure 8-13 Coherency and Shadow Registering – Asynchronous Clocks



### 8.6 Performance

This section discusses performance and the hardware configuration parameters that affect the performance of the DW\_ahb\_ictl.

### 8.6.1 Power Consumption, Frequency, and Area Results

Table 8-3 provides information about the synthesis results (power consumption, frequency, and area) of the DW\_ahb\_ictl using the industry standard 28nm technology library and how it affects performance.

Table 8-3 Power Consumption, Frequency, and Area Results for DW\_ahb\_ictl Using 28nm Technology Library

| Configuration                                                                                                                                           | Operating<br>Frequency | Gate Count  | Static Power<br>Consumption | Dynamic Power Consumption |
|---------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|-------------|-----------------------------|---------------------------|
| Default Configuration                                                                                                                                   | hclk: 300 MHz          | 1869 gates  | 31 nW                       | 5.816 uW                  |
| Minimum Configuration: AHB_DATA_WIDTH 32 BIG_ENDIAN 0 ICT_IRQ_NUM 2 ICT_HAS_FIQ 0 ICT_HAS_PFLT 0                                                        | hclk: 300 MHz          | 546 gates   | 8.66 nW                     | 1.899 uW                  |
| Maximum Configuration: AHB_DATA_WIDTH 256 BIG_ENDIAN 0 ICT_IRQ_NUM 64 ICT_HAS_FIQ 1 ICT_FIQ_NUM 8 ICT_HAS_PFLT 1 ICT_HAS_VECTOR_USER 1 ICT_IRQ_PLEVEL 5 | hclk: 300 MHz          | 11805 gates | 198 nW                      | 34.29 uW                  |



# **Synchronizer Methods**

This appendix describes the synchronizer methods (blocks of synchronizer functionality) that are used in the DW\_ahb\_ictl to cross clock boundaries.

This appendix contains the following sections:

- "Synchronizers Used in DW\_ahb\_ictl" on page 116
- "Synchronizer 1: Simple Double Register Synchronizer (DW\_ahb\_ictl)" on page 117



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\_ahb\_ictl

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\_ahb\_ictl 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\_ahb\_ictl

| Synchronizer Module File | Synchronizer Type and Number                          |
|--------------------------|-------------------------------------------------------|
| DW_ahb_ictl_bcm21.v      | Synchronizer 1: Simple Multiple Register Synchronizer |



The BCM21 is a basic multiple register based synchronizer module used in the design. It can be replaced with equivalent technology specific synchronizer cell.

### A.2 Synchronizer 1: Simple Double Register Synchronizer (DW\_ahb\_ictl)

This is a single clock data bus synchronizer for synchronizing control signals that crosses asynchronous clock boundaries. The synchronization scheme uses 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 Edge)





В

### **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 B-1 Internal Parameters

| Parameter Name         | Equals To                                          |
|------------------------|----------------------------------------------------|
| ENCODED_AHB_DATA_WIDTH | {[function_of: AHB_DATA_WIDTH ]}                   |
| ENCODED_ICT_FIQ_NUM    | {[function_of: ICT_FIQ_NUM ]}                      |
| ENCODED_ICT_IRQ_NUM    | {[function_of: ICT_IRQ_NUM ]}                      |
| FALSE                  | 1'b0                                               |
| ICT_HAS_VECTOR         | ((((ICT_HAS_PFLT == 1)) ? ICT_HAS_VECTOR_USER : 0) |
| ICTL_VERSION_ID        | 32'h3231342a                                       |
| TRUE                   | 1'b1                                               |

# **C** Glossary

command queue.

activity A set of functions in coreConsultant that step you through configuration,

verification, and synthesis of a selected core.

AHB Advanced High-performance Bus — high-performance system backbone bus.

AHB supports the efficient connection of processors, on-chip memories and off-

chip external memory interfaces (Arm® Limited specification).

AMBA Advanced Microcontroller Bus Architecture — a trademarked name by Arm®

Limited that defines an on-chip communication standard for high speed

microcontrollers.

APB Advanced Peripheral Bus — optimized for minimal power consumption and

reduced interface complexity to support peripheral functions (Arm® Limited

specification).

APB bridge DW\_apb submodule that converts protocol between the AHB bus and APB bus.

application design Overall chip-level design into which a subsystem or subsystems are integrated.

arbiter AMBA bus submodule that arbitrates bus activity between masters and slaves.

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.

bus bridge Logic that handles the interface and transactions between two bus standards,

such as AHB and APB. See APB bridge.

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.

core Any configurable block of synthesizable IP that can be instantiated as a single

entity (VHDL) or module (Verilog) in a design. Core is the preferred term for a big piece of IIP. Anything that requires coreConsultant for configuration, as well as

anything in the DesignWare Cores library, is a core.

core developer Person or company who creates or packages a reusable core. All the cores in the

DesignWare Library are developed by Synopsys.

core integrator Person who uses coreConsultant or coreAssembler to incorporate reusable cores

into a system-level design.

coreAssembler Synopsys product that enables automatic connection of a group of cores into a

subsystem. Generates RTL and gate-level views of the entire subsystem.

coreConsultant A Synopsys product that lets you configure a core and generate the design views

and synthesis views you need to integrate the core into your design. Can also synthesize the core and run the unit-level testbench supplied with the core.

coreKit An unconfigured core and associated files, including the core itself, a specified

synthesis methodology, interfaces definitions, and optional items such as

verification environment files and core-specific documentation.

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.

Design View A simulation model for a core generated by coreConsultant.

DesignWare Synthesizable

Components

The Synopsys name for the collection of AMBA-compliant coreKits and

verification models delivered with DesignWare and used with coreConsultant or coreAssembler to quickly build DesignWare Synthesizable Component designs.

SolvNet DesignWare.com

DesignWare cores A specific collection of synthesizable cores that are licensed individually. For

more information, refer to www.synopsys.com/designware.

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.

MacroCell Bigger IP blocks (6811, 8051, memory controller) available in the DesignWare

Library and delivered with coreConsultant.

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.

subsystem In relation to coreAssembler, highest level of RTL that is automatically generated.

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** A collection of files for stand-alone verification of the configured component. The Environment (TRE)

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.

workspace A network location that contains a personal copy of a component or subsystem.

> After you configure the component or subsystem (using coreConsultant or coreAssembler), the workspace contains the configured component/subsystem and generated views needed for integration of the component/subsystem at the

top level.

Code, usually VHDL or Verilog, that surrounds a design or model, allowing easier wrap, wrapper

interfacing. Usually requires an extra, sometimes automated, step to create the

wrapper.

A command that executes without HDL simulation time advancing. zero-cycle command

## Index

| A                      | definition 122                      |
|------------------------|-------------------------------------|
| active command queue   | component                           |
| definition 121         | definition 122                      |
| activity               | configuration                       |
| definition 121         | definition 122                      |
| AHB                    | configuration intent                |
| definition 121         | definition 122                      |
| AMBA                   | core                                |
| definition 121         | definition 122                      |
| APB                    | core developer                      |
| definition 121         | definition 122                      |
| APB bridge             | core integrator                     |
| definition 121         | definition 122                      |
| application design     | coreAssembler                       |
| definition 121         | definition 122                      |
| arbiter                | coreConsultant                      |
| definition 121         | definition 122                      |
| В                      | coreKit                             |
| BFM                    | definition 122                      |
| definition 121         | Customer Support 10                 |
| big-endian             | cycle command                       |
| definition 121         | definition 122                      |
| blocked command stream | D                                   |
| definition 121         | decoder                             |
| blocking command       | definition 122                      |
| definition 121         | design context                      |
| bus bridge             | definition 122                      |
| definition 122         | design creation                     |
|                        | definition 122                      |
| C                      | Design View                         |
| Coherency              | definition 122                      |
| about 103<br>read 110  | DesignWare cores                    |
| write 104              | definition 123                      |
| command channel        | DesignWare Library                  |
| definition 122         | definition 123                      |
| command stream         | DesignWare Synthesizable Components |
|                        |                                     |

| definition 122               | definition 123                               |
|------------------------------|----------------------------------------------|
| dual role device             | implementation view                          |
| definition 123               | definition 123                               |
| DW_ahb_ictl 100              | instantiate                                  |
| features of 16               | definition 123                               |
| FIQ interrupt processing 27  | interface                                    |
| functional description 19    | definition 123                               |
| IRQ interrupt processing 20  | IP                                           |
| polarity of IRQ interrupt 21 | definition 123                               |
| programming 93 testbench     | IRQ interrupts                               |
| about 98                     | enabling of 22                               |
| overview of tests 97         | masking of 22                                |
|                              | polarity of 21                               |
| <b>E</b>                     | priority filter 22                           |
| Enabling                     | processing of 20                             |
| FIQ interrupts 29            | programming of 21<br>status registers for 23 |
| IRQ interrupts 22            | vectors 23                                   |
| endian                       | irq_finalstatus 23                           |
| definition 123               | •                                            |
| Environment, licenses 16     | irq_maskstatus 23                            |
| F                            | irq_rawstatus 23                             |
| FIQ interrupts               | irq_status 23                                |
| enabling 29                  | L                                            |
| masking of 29                | Licenses 16                                  |
| polarity of 28               | little-endian                                |
| processing of 27             | definition 123                               |
| programming of 28            | М                                            |
| status registers for 29      | MacroCell                                    |
| fiq_finalstatus 29           | definition 123                               |
| fiq_rawstatus 29             | Masking                                      |
| fiq_status 29                | FIQ interrupts 29                            |
| Full-Functional Mode         | IRQ interrupts 22                            |
| definition 123               | master 22                                    |
| G                            | definition 123                               |
| GPIO                         | model                                        |
| definition 123               | definition 123                               |
| GTECH                        | monitor                                      |
| definition 123               | definition 123                               |
| н                            | N                                            |
| hard IP                      |                                              |
| definition 123               | non-blocking command<br>definition 123       |
| HDL                          |                                              |
| definition 123               | Р                                            |
|                              | peripheral                                   |
| <u> </u>                     | definition 123                               |
| IIP                          | Programming DW_ahb_ictl                      |

| memory map 93 notes for 93                             | synthesis intent<br>definition 124     |
|--------------------------------------------------------|----------------------------------------|
|                                                        | synthesizable IP                       |
| R                                                      | definition 124                         |
| Read coherency                                         |                                        |
| about 110                                              | Т                                      |
| and asynchronous clocks 112 and synchronous clocks 111 | technology-independent definition 124  |
| Registers                                              | test.log 100                           |
| and APB_DATA_WIDTH 93                                  | testbench                              |
| fiq_finalstatus 29                                     | output files 100                       |
| fiq_rawstatus 29                                       | Testsuite Regression Environment (TRE) |
| fiq_status 29                                          | definition 124                         |
| irq_finalstatus 23                                     | TRE                                    |
| irq_maskstatus 23                                      | definition 124                         |
| irq_rawstatus 23                                       |                                        |
| irq_status 23                                          | V                                      |
| RTL                                                    | Vera, overview of tests 97             |
| definition 124                                         | Verification                           |
| runtest.log 100                                        | and Vera tests 97                      |
| S                                                      | of DW_ahb_ictl 98                      |
| SDRAM                                                  | output file 100                        |
| definition 124                                         | results 100                            |
| SDRAM controller                                       | VIP                                    |
| definition 124                                         | definition 124                         |
|                                                        | W                                      |
| Simple double register synchronizer 117                | workspace                              |
| Simulation                                             | definition 124                         |
| command line output files 100 from command line 99     |                                        |
| of DW_ahb_ictl 98                                      | wrap<br>definition 124                 |
| results 100                                            |                                        |
|                                                        | wrapper<br>definition 124              |
| slave definition 124                                   |                                        |
|                                                        | Write coherency                        |
| SoC definition 124                                     | about 104 and asynchronous clocks 109  |
| definition 124                                         | and identical clocks 106               |
| SoC Platform                                           | and synchronous clocks 107             |
| AHB contained in 13                                    |                                        |
| APB, contained in 13                                   | Z                                      |
| defined 13                                             | zero-cycle command                     |
| soft IP                                                | definition 124                         |
| definition 124                                         |                                        |
| static controller                                      |                                        |
| definition 124                                         |                                        |
| subsystem                                              |                                        |
| definition 124                                         |                                        |
| Synchronizer                                           |                                        |
| simple double register 117                             |                                        |