

# **DesignWare DW\_ahb\_icm Databook**

DW\_ahb\_icm - Product Code

1.17a July 2018

# **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                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Preface                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Product Code                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Chapter 1Product Overview111.1 DesignWare System Overview111.2 General Product Description1.3 I.2.1 DW_ahb_icm Block Diagram1.3 Features1.3 Features1.4 Standards Compliance141.5 Verification Environment Overview141.6 Licenses141.7 Where To Go From Here                                                                                                                                                                                                                     |
| Chapter 2Functional Description2.1 Input Stage2.2 Select Arbitration and Layer Selection2.2 Select Arbitration and Layer Selection2.2.1 Fixed-Priority Arbitration Scheme2.2.2 Dynamic-Priority Arbitration Scheme2.3 Slave to Layer Data and Response Return2.3.1 Data Generation2.3.2 Slave Response Generation2.02.3.4 Slave Return from Split Generation2.5 Non-Standard Master ID Sideband Signals212.6 Timing2.6.1 Layer Arbitration212.6.3 Mask Priority or Arbitration23 |
| Chapter 3 Parameter Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

| Chapter 4Signal Descriptions4.1 Clock and Reset Interface Signals4.2 Arbitration Control Signals4.3 Slave Layer Interface Signals4.4 Master Layer x Interface Signals                                                                                                                                           |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Chapter 5         Verification       49         5.1       Overview of Vera Tests       49         5.1.1       Access       49         5.1.2       Priority Scheme       49         5.1.3       Locked Transfers       50         5.1.4       Responses       50         5.2       DW_ahb_icm Testbench       51 |
| Chapter 6<br>Integration Considerations                                                                                                                                                                                                                                                                         |
| Chapter A<br>Internal Parameter Descriptions                                                                                                                                                                                                                                                                    |
| Appendix B<br>Glossary                                                                                                                                                                                                                                                                                          |
| Index                                                                                                                                                                                                                                                                                                           |

# **Revision History**

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

| Version | Date         | Description                                                                                                                                                                                                         |  |
|---------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 1.17a   | July 2018    | Updated:                                                                                                                                                                                                            |  |
|         |              | <ul> <li>Image version changed for 2018.07a release</li> </ul>                                                                                                                                                      |  |
|         |              | <ul> <li>"Performance" on page 53</li> </ul>                                                                                                                                                                        |  |
|         |              | <ul> <li>"Parameter Descriptions" on page 29, "Signal Descriptions" on page 37, and<br/>"Internal Parameter Descriptions" on page 55 are auto-extracted with change<br/>bars from the RTL</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>                                                                        |  |
| 1.16a   | October 2016 | <ul> <li>Version changed for 2016.10a release</li> </ul>                                                                                                                                                            |  |
|         |              | <ul> <li>"Parameter Descriptions" on page 29 auto-extracted from the RTL</li> </ul>                                                                                                                                 |  |
|         |              | <ul> <li>Moved "Internal Parameter Descriptions" to Appendix.</li> </ul>                                                                                                                                            |  |
|         |              | <ul> <li>Removed "Running Leda on Generated Code with coreConsultant" and<br/>reference to Leda directory in Table 2-1</li> </ul>                                                                                   |  |
|         |              | <ul> <li>Removed "Running Leda on Generated Code with coreAssembler" section,<br/>and reference to Leda directory in Table 2-4</li> </ul>                                                                           |  |
|         |              | <ul> <li>Updated "Features" on page 13</li> </ul>                                                                                                                                                                   |  |
|         |              | <ul> <li>Updated "Parameter Descriptions" and "Signals" chapters</li> </ul>                                                                                                                                         |  |
|         |              | <ul> <li>Added "mid_lx" and "mid" signals in "Signal Descriptions" on page 37</li> </ul>                                                                                                                            |  |
|         |              | <ul> <li>Added "MID_WIDTH" parameter in "Parameter Descriptions" on page 29.</li> </ul>                                                                                                                             |  |
|         |              | <ul> <li>Updated maximum configuration area and power numbers, and added an<br/>entry for "Maximum Configuration (with 16 AHB Layers) for area and power, in<br/>"Integration Considerations" on page 53</li> </ul> |  |
|         |              | <ul> <li>Added a note in "Select Arbitration and Layer Selection" on page 19</li> </ul>                                                                                                                             |  |
|         |              | <ul> <li>Added "Non-Standard Master ID Sideband Signals" on page 21</li> </ul>                                                                                                                                      |  |
|         |              | <ul> <li>Added an entry for the xprop directory in Table 2-1 and Table 2-4.</li> </ul>                                                                                                                              |  |
|         |              | <ul> <li>Added "Running VCS XPROP Analyzer"</li> </ul>                                                                                                                                                              |  |

| Version | Date      | Description                                                                                                                                                                                                                                                                                                                            |  |
|---------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 1.15a   | June 2015 | <ul> <li>Added "Mask Priority or Arbitration" on page 23</li> <li>Added "Running SpyGlass® Lint and SpyGlass® CDC"</li> <li>Added "Running SpyGlass on Generated Code with coreAssembler"</li> <li>"Signal Descriptions" on page 37 auto-extracted from the RTL</li> <li>Added Chapter A, "Internal Parameter Descriptions"</li> </ul> |  |
| 1.14a   | June 2014 | <ul> <li>Version change for 2014.06a release</li> <li>Added "Integration Considerations" chapter</li> <li>Corrected External Input/Output Delays in Signals chapter</li> </ul>                                                                                                                                                         |  |
| 1.13d   | May 2013  | <ul><li>Version change for 2013.05a release</li><li>Updated the template.</li></ul>                                                                                                                                                                                                                                                    |  |
| 1.13c   | Oct 2012  | Added the product code on the cover and in Table 1-1.                                                                                                                                                                                                                                                                                  |  |
| 1.13c   | Mar 2012  | <ul> <li>Updated description of icm_priority signal</li> <li>Added a dynamic-priority arbitration subsection</li> </ul>                                                                                                                                                                                                                |  |
| 1.13b   | Oct 2011  | Version change for 2011.10a release                                                                                                                                                                                                                                                                                                    |  |
| 1.13a   | Jun 2011  | <ul> <li>Updated system diagram in Figure 1-1</li> <li>Enhanced "Related Documents" section in Preface</li> </ul>                                                                                                                                                                                                                      |  |
| 1.13a   | Sep 2010  | Corrected names of include files and vcs command used for simulation.                                                                                                                                                                                                                                                                  |  |
| 1.12a   | Dec 2009  | Updated databook to new template for consistency with other IIP/VIP/PHY databooks                                                                                                                                                                                                                                                      |  |
| 1.12a   | May 2009  | Removed references to QuickStarts, as they are no longer supported                                                                                                                                                                                                                                                                     |  |
| 1.12a   | Apr 2009  | Corrected dependency value of AHB_LITE to 1 in Parameter Descriptions                                                                                                                                                                                                                                                                  |  |
| 1.12a   | Oct 2008  | Version change for 2008.10a release                                                                                                                                                                                                                                                                                                    |  |
| 1.10c   | Jun 2008  | Version change for 2008.06a release                                                                                                                                                                                                                                                                                                    |  |
| 1.10b   | Mar 2008  | Changed from 1-4 layers to 1-8 layers for fixed-priority arbitration scheme                                                                                                                                                                                                                                                            |  |
| 1.10b   | Jun 2007  | Version change for 2007.06a release                                                                                                                                                                                                                                                                                                    |  |

# Preface

This databook provides information about the DesignWare AHB Multi-layer Interconnection Matrix (ICM) peripheral, referred to as the DW\_ahb\_icm throughout the remainder of this databook. The DW\_ahb\_icm conforms to the *AMBA Specification, Revision* 2.0 from Arm®.

The information in this databook includes a functional description, signal and parameter descriptions, programming interface, and detailed information about the operation of the DW\_ahb\_icm. Also provided are an overview of the component testbench, a description of the tests that are run to verify the DW\_ahb\_icm, 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\_icm.
- Chapter 3, "Parameter Descriptions" identifies the configurable parameters supported by the DW\_ahb\_icm.
- Chapter 4, "Signal Descriptions" provides a list and description of the DW\_ahb\_icm signals.
- Chapter 5, "Verification" provides information on verifying the configured DW\_ahb\_icm.
- Chapter 6, "Integration Considerations" provides performance hardware configuration parameters that affect the performance of the DW\_ahb\_icm.
- Appendix B, "Glossary" provides a glossary of general terms.
- Appendix A, "Internal Parameter Descriptions" provides a list of internal parameter descriptions that might be indirectly referenced in expressions in the Signals chapter.

## **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 http://solvnet.synopsys.com/EnterACall and click the **Open A Support Case** to enter a call.

Provide the requested information, including:

- Product: DesignWare Library IP
- Sub Product: AMBA
- Tool Version: <product version number>
- Problem Type:
- Priority:
- Title: DW\_ahb\_icm
- **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.

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

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

| Component Name | Description                                                     |
|----------------|-----------------------------------------------------------------|
| DW_axi_x2x     | Flexible bridge between multiple AMBA 3 AXI components or buses |

# **T** Product Overview

The DW\_ahb\_icm is a programmable Multi-layer Interconnection Matrix (ICM) peripheral. This component is part of the family of DesignWare Synthesizable Components.

## 1.1 DesignWare System Overview

The Synopsys DesignWare Synthesizable Components environment is a parameterizable bus system containing AMBA version 2.0-compliant AHB (Advanced High-performance Bus) and APB (Advanced Peripheral Bus) components, and AMBA version 3.0-compliant 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\_icm in a Complete System

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

## **1.2 General Product Description**

The Synopsys DW\_ahb\_icm is a configurable multi-layer interconnection matrix. The DW\_ahb\_icm is neither an AHB slave or an AHB master, but facilitates multiple layers to access a slave; there can be only one slave for each DW\_ahb\_icm.

## 1.2.1 DW\_ahb\_icm Block Diagram

Figure 1-2 shows the DW\_ahb\_icm block diagram.

#### Figure 1-2 DW\_ahb\_icm Block Diagram



## 1.3 Features

DW\_ahb\_icm has the following features:

- Layer arbitration
- Input stage address and control holding registers for each layer; holding registers keep address and control information presented on bus they are removed the following cycle
- Mapping of slave response onto layer that initiated transfer
- Return of split transaction read data onto layer that initiated transfer
- Common clock and reset shared among all layers; common clock implies that all AHB layers use same clock frequency

- Configuration of DesignWare AHB Lite system
- Support for non-standard Master ID sideband signal (in AHB-Lite mode)
- User-defined parameters:
  - □ AMBA Lite
  - AHB address bus width (same width on all layers)
  - AHB data bus width (same width on each layer)
  - AHB master layers (up to 16)
  - Split- or non-split-capable slave
  - Slave with or without multiple select lines
  - Slave with or without protection control
  - Slave with or without burst control
  - Slave with or without lock control
  - □ Layer release scheme
  - Baseline arbitration scheme
  - External arbitration priority control

Some uses of the DW\_ahb\_icm are:

- An add-on interface for AHB slaves to allow them to be used in a multi-layer system
- Support for AHB master to operate in AMBA Lite mode within multi-layer 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\_icm 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\_icm 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 49 section discusses the specific procedures for verifying the DW\_ahb\_icm.

## 1.6 Licenses

Before you begin using the DW\_ahb\_icm, 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\_icm 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\_icm 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\_icm 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 DW\_ahb\_icm and describes the components and functionality of the DW\_ahb\_icm.

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

Figure 2-1 illustrates the block diagram of the DW\_ahb\_icm.

#### Figure 2-1 DW\_ahb\_icm Block Diagram



Figure 2-2 illustrates how the DW\_ahb\_icm might interface between masters and the slave.





## 2.1 Input Stage

A layer is referred to as one or more masters that compete together with one master winning ownership.

When there is more than one layer looking for access to the slave at the same time, this is referred to as a clash of requests. Whenever a clash is detected, only one layer can gain access to the slave. The layers that do not gain access to the slave need to have their address and control signals stored into their input stage. When address and control signals are stored into an input stage, then the stored transfer controls the request and lock generation circuitry. When a lower priority layer is in the middle of a burst transfer and a higher priority layer issues a transfer, the higher priority layer is stored and then held off until the lower priority layer completes the transfer.

When the address and control is presented to a slave with hready = 1, the slave must accept the address. The hready comes from the previously addressed slave on the layer through hready\_l(x), where x is from 1 to 16, and is an indication of whether the last transfer has completed on the corresponding layer.

Layers can hand over accessing the slave to another layer. With different masters capable of accessing the same slave, the slave can indicate that it has completed the transfer with a master on one layer while it is being accessed by a master on another layer or is in the middle of an access. Therefore, the address and control – and associated address decode (the select) – from the layer requesting the slave need to be stored and the layer held off until after the current master has completed its transfer. The stored transfer can then be passed to the slave and the layer released to generate the next address.

Whenever there is address and control stored in the input stage, the address and control passed to the slave is always from the input stage. The slave can have multiple selects lines — up to eight per layer — but only one set of read data and responses come from the slave, which holds off a master with hready\_resp held low. The master then waits with its next address until hready\_resp goes high, at which time it determines if hresp was OK in the previous cycle before continuing with the transfer; if not the master cancels the transfer.

## 2.2 Select Arbitration and Layer Selection

The DW\_ahb\_icm can use either a fixed-priority or a dynamic-priority arbitration scheme between the master layers.

# Attention Priority schemes for arbitration are opposite in DW\_ahb and DW\_ahb\_icm:

- In DW\_ahb, higher the priority value, higher the priority of the Master.
  - In DW\_ahb\_icm, lower the priority value, higher the priority of the layer.

## 2.2.1 Fixed-Priority Arbitration Scheme

In the fixed-priority scheme, each layer is assigned a unique priority. The order of priorities is described by the index of the layer number to which each layer is connected. For example (with ICM\_NUM\_LAYERS = 16):

- Layer 1 is the highest priority
- Layer 16 is the lowest priority

Each layer generates a select for the slave,  $hsel_s(y)_l(x)$ . A slave may have multiple select lines, in which case *y* is from 1 to the number of selects. All the slave selects from a layer are combined to generate a single select from each layer. With a single select for the slave, the arbitration reduces to being between one of eight layers. Once a transfer is stored in the input stage, the input stage select is used instead of the layer select in order to generate the index for which layer wins the arbitration.

The arbitration is carried out at the beginning of every burst transfer with the highest priority layer gaining access when two or more layers want to start a new transfer at the same time. The arbitration is changed only when htrans is IDLE or NON-SEQUENTIAL. If the arbitration is on every beat of a transfer, then slaves that use the burst information are compromised, since it is possible that bursts are broken, which violates the protocol. If a slave does not support burst transfers – by not using the hburst control signal – then the arbitration is carried out on every transfer (as the slave does not use the burst type signal).

Each AHB master has the capability of generating locked transfers by asserting hlock, which is translated into hmastlock by the bus arbiter. The hmastlock signal maintains the current layer as the active layer. This allows a sequence of idle, single, or burst transfers from a master to be generated for the slave without having them separated by another layer gaining access to the slave. Whenever a layer generates locked transfers to a slave and starts accessing the slave, no other layer gains access until hmastlock goes low.

A slave access is always reduced to a single request, regardless of the number of select lines that it may have.

A two-tiered arbiter is used to generate the layer arbitration for requests and locks. The two-tiered arbiter is configured with fixed priorities for each layer, and none of the layers are masked. The result of the arbitration is an index of the layer that has won access to the slave. The index selects the correct address and control signals to pass to the slave. The address and control may come directly from the layer or from an input stage.

A master is stopped from generating any more transfers until the slave accepts the stored transfer from the input stage. Only one set of address and control signals from a layer is accepted into the input stage.

## 2.2.2 Dynamic-Priority Arbitration Scheme

The DW\_ahb\_icm supports dynamically changing the arbitration priority using the icm\_priority signals.

For example, you could create an external round-robin-type arbiter, and connect it to the icm\_priority bus to dynamically change the priority. The width of the icm\_priority bus is detemined by the number of layers; for more details, see the Signal Descriptions description on page 37.

- 1. Select "true" for External Priority Control? in coreConsultant. This sets the parameter ICM\_HAS\_XPRIORITY = 1.
- 2. Create the circuit for an external round-robin arbitration function.
- 3. Connect the output signal of the round-robin arbiter to the icm\_priority signals of the DW\_ahb\_icm.v file.

```
Priority can be changed at any time. The arbiter considers the priority for the respective layer when the transfer type HTRANS=NSEQ. Except dynamic priority selection on NSEQ, all other aspects are same as described for fixed priority scheme in "Fixed-Priority Arbitration Scheme" on page 19.
```

## 2.3 Slave to Layer Data and Response Return

The following sections discuss how data and slave response generation relates to layers.

### 2.3.1 Data Generation

For write data, the layer index that supplied the address and control signals is stored each time the slave is accessed. This is done so that the data to the slave can be generated from selecting the layer that initiated the transfer in order to supply the write data. The matrix does not store the write data.

For read data, the same data is passed back to all layers. When multiple layers try to read the same slave, only one layer has an active hready\_resp\_l(x). The master ignores the hrdata\_lx signal, unless the associated hready\_resp\_lx for the same layer is active.

## 2.3.2 Slave Response Generation

The slave response is passed back to a master on hready\_resp\_lx in order to indicate that the current transfer has completed. Only when a layer accesses a slave is its response passed back to that layer. The stored index of the layer that generated the address and control signals is used to indicate to which layer the response is returned.

A layer may be ready to start a transfer to the slave after it has completed a transfer to another slave. However, the slave that must be accessed through the DW\_ahb\_icm may not be ready because it is or was accessed by another layer. In this case, the transfer is accepted into the input-stage, and holding hready\_resp\_lx low holds off the layer until the slave is ready. At all other times the slave response comes directly from the slave.

If the layer is held off because of its priority or because another layer accesses the slave, then the DW\_ahb\_icm can return a RETRY response to the layer. The RETRY is returned if the matrix calculates that the layer has been held off for more than the configured limit of cycles (ICM\_RLIMIT\_Lx) for that layer. Generating a RETRY because a layer is held for too long is a user-configurable option, (ICM\_RELEASE\_Lx),

which requires the hready\_resp\_lx signal for the layer to be brought high. The layer that is retried can then give a higher priority master access to its layer before retrying the access to the shared slave. The stored address and control in the input stage is cancelled. At all other times, the DW\_ahb\_icm sends back an OKAY response to the layer.

## 2.4 Slave Return from Split Generation

In a multi-master, single-layer AHB bus configuration, a slave capable of split transaction read data (split) uses hmaster to calculate which master was driving the address and control signals when the transfer was split. The slave pulses a 1 on the hmaster bit of its hsplit bus to allow the split master back into the arbitration scheme.

With multiple layers, there may be many masters on many layers with the same master number. Therefore, when a slave returns an hsplit, it needs to be passed back to the layer that initiated the transfer. This ensures that masters on other layers are not returned from splits because they have the same master number as other masters.

When a slave is split, it sets a bit on its hsplit bus that returns the master from a split. The DW\_ahb\_icm keeps track of which masters on which layers are split by the common slave, which allows only the correct master on the layer that initiated the transfer to be returned from a split. The slave has no concept of a layer, but of a master number. When the slave indicates that a master should be returned, it can be on any layer. The DW\_ahb\_icm keeps track of which master on which layer receives a split from the common slave. This allows the master on a layer that receives a split from a slave other than the common slave to not be unmasked from the return-from-split generated by the common slave. If the same master number is split on multiple layers at the same time, then the common slave returns all split layers from the split at the same time.

# 2.5 Non-Standard Master ID Sideband Signals

The Non-Standard Master ID Sideband signals are available only in the AHB-Lite mode when the MID\_WIDTH parameter set to a non zero value. These signals enable the propagation of the ID through DW\_ahb\_icm. The timing of these signals is similar to other AHB control signals, such as hsize and hprot.

## 2.6 Timing

The following sections discuss DW\_ahb\_icm timing.

## 2.6.1 Layer Arbitration

Figure 2-3 shows the result of two layers trying to access the same slave. Layer 1 wants to complete a burst of transfers, and Layer 2 wants to complete a single transfer.

#### Figure 2-3 Layer Arbitration



The slave inserts a wait state for each transfer. In the first cycle, there is no clash of requests, and Layer 1 gains control. The arbitration is locked until a new transfer starts or until there is no activity on the bus. Layer 2 inserts its transfer, which is accepted into the input stage by the DW\_ahb\_icm and is then prevented from generating any other traffic because its hready\_l2 is brought low. The transfer is placed into the input stage for Layer 2. As long as there is data in the input stage, the master on Layer 2 is prevented from generating any subsequent transfers.

When the burst transfer from Layer 1 is completed, the ownership of the DW\_ahb\_icm is swapped to Layer 2. The arbiter sees an idle transfer from Layer 1 (clock cycle 9) so that it can transfer ownership. The address and control for Layer 2 are then taken from the input stage. Only when the transfer is accepted is the input stage cleared. If there are subsequent transfers from Layer 2, they come directly from the layer and not from the input stage.

The resulting address bus that is passed to the slave is a sequence of back-to-back transfers. Bursts are allowed to complete from one layer before another layer gains access.

## 2.6.2 **RETRY Generation**

In Figure 2-4, a write transfer is generated on Layer 1 for a slave that is being accessed by another layer.





The DW\_ahb\_icm is configured to release a layer (ICM\_RELEASE\_L1 = 1). There is a clash of requests for access to the slave. The address and control, and the select, are all moved to an input stage where one waits for the clash of requests to clear. After an ICM\_RLIMIT\_L1 of cycles, there is still a clash of requests and then a RETRY response is sent back to the master on Layer 1. The address and control in the input stage is released. This RETRY would then free up Layer 1 for a higher priority master to do some other transfers or to retry the write transfer to the common slave. The slave is deemed free when there is no activity on the bus for the slave, or when the current granted layer is driving a NON-SEQUENTIAL transfer.

## 2.6.3 Mask Priority or Arbitration

Figure 2-5 shows the result of multiple layers attempting to access the common slave during the wait cycle of the previous transfer data phase with AHB\_MASK\_PRIORITY set to false.

# Figure 2-5 Multiple Layers Attempting to Access the Common Slave during Wait Cycle of Previous Transfer Data Phase (AHB\_MASK\_PRIORITY=false)



In Figure 2-5, the assumption is that AHB Layer 1 - AHB Layer 3 => Lowest Priority - Highest Priority

The AHB Layer 1 requests the DW\_ahb\_icm to the access the common slave and gets the grant because AHB Layer 1 is the highest priority layer requesting the common slave. The common slave inserts a wait cycle during the data phase of the AHB Layer 1 transfer.

During the wait cycle, AHB Layer 2 requests the common slave and it gets the grant temporarily because the arbitration is not locked to a particular AHB layer until hready is set to high, when AHB\_MASK\_PRIORITY is false. But, the actual grant or access to the common slave is given to the AHB Layer 3, as the AHB Layer 3 has the highest priority AHB layer requesting the common slave and hready is high at the same time.

Figure 2-6 shows the result of multiple layers trying to access the common slave during the wait cycle of the previous transfer data phase with AHB\_MASK\_PRIORITY set to true.

# Figure 2-6 Multiple Layers Attempting to Access the Common Slave during Wait Cycle of Previous Transfer Data Phase (AHB\_MASK\_PRIORITY=true)



This scenario is same as discussed in Figure 2-5 except that AHB\_MASK\_PRIORITY is set to true. During the first wait cycle, AHB Layer 2 requests the common slave and it gets the grant. But, the difference is that the grant is locked to the AHB Layer 2 until it is accepted by the common slave, that is, until hready is high. The grant is not provided to any high priority AHB Layer thereafter until the granted AHB layer request is accepted by the common slave.

# **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 30
- Top Level Parameters / DW\_ahb\_icm Source Code Configuration on page 35

# 3.1 Top Level Parameters

### Table 3-1Top Level Parameters

| Label                                                                 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
|-----------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                                                                       | System Configuration                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| AMBA Lite ?                                                           | <ul> <li>When this is set to Yes, no master in the system is capable of accepting a RETRY or a SPLIT response from a slave. Therefore, it is not possible to have a split-capable slave within the system, nor is it possible for the DW_ahb_icm to generate the RETRY. On a layer, this setting implies only a single master with no dummy master, and some parameters are disabled and overwritten with their default values.</li> <li>Values:</li> <li>false (0)</li> <li>true (1)</li> </ul> |  |  |
|                                                                       | Default Value: false                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
|                                                                       | Enabled: Always                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
|                                                                       | Parameter Name: AHB_LITE                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
| Mask the Priority during the<br>progress of previous<br>transaction ? | If this parameter is set to True, the DW_ahb_icm masks the bus arbitration to all<br>AHB layers, except for AHB Layer for which transaction is in progress under<br>following conditions: A NONSEQ transfer is issued from one AHB Layer, if Slave<br>issues a wait state through pulling hready low (data phase of previous transaction).<br><b>Values:</b><br><ul> <li>false (0)</li> <li>true (1)</li> </ul> <li>Default Value: false<br/>Enabled: Always</li>                                |  |  |
|                                                                       | Parameter Name: AHB_MASK_PRIORITY                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| AHB System Address Width                                              | Specifies the width of the connected address bus.<br>Values:<br>32 (32)<br>64 (64)<br>Default Value: 32<br>Enabled: Always<br>Parameter Name: HADDR_WIDTH                                                                                                                                                                                                                                                                                                                                        |  |  |
| AHB Data Bus Width                                                    | Specifies the width of the AHB data bus.<br>Values: 32, 64, 128, 256<br>Default Value: 32<br>Enabled: Always<br>Parameter Name: AHB_DATA_WIDTH                                                                                                                                                                                                                                                                                                                                                   |  |  |

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

| Label                                           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Non Standard Master ID<br>Sideband Signal Width | Specifies the width of a non standard Master ID sideband signals. When set to 0, the Master ID sideband signals are removed.<br><b>Values:</b> 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12<br><b>Default Value:</b> 0<br><b>Enabled:</b> AHB_LITE == 1<br><b>Parameter Name:</b> MID_WIDTH                                                                                                                                                                                                                       |
|                                                 | Layer Control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Number of layers?                               | The number of AHB layers that the DW_ahb_icm must support.<br>Values: 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16<br>Default Value: 2<br>Enabled: Always<br>Parameter Name: ICM_NUM_LAYERS                                                                                                                                                                                                                                                                                                             |
|                                                 | Slave Select Control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Slave Has Multiple Selects?                     | This parameter controls the connected slave select lines. The connected slave can<br>have multiple slave-select lines and share a common AHB interface layer, or it may<br>have only one.<br>Values:<br><ul> <li>false (0)</li> <li>true (1)</li> </ul> <li>Default Value: [<functionof> equal \$::shell_activity_mode<br/>"assembler"]?ICM_NUM_HSEL&gt;1:0</functionof></li> <li>Enabled: ![<functionof> equal \$::shell_activity_mode "assembler"]</functionof></li> <li>Parameter Name: ICM_HAS_MHSEL</li> |
| Number of Select Line?                          | Number of select lines attached to a slave.<br>Values: 1, 2, 3, 4, 5, 6, 7, 8<br>Default Value: 1<br>Enabled: ICM_HAS_MHSEL==1 II [ <functionof> equal \$::shell_activity_mode<br/>"assembler"]<br/>Parameter Name: ICM_NUM_HSEL</functionof>                                                                                                                                                                                                                                                                 |
|                                                 | Interface Control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Slave uses burst control?                       | The connected slave uses and requires the burst control from each of the masters.<br>Values:<br>false (0)<br>true (1)<br>Default Value: true<br>Enabled: Always<br>Parameter Name: ICM_HAS_BURST                                                                                                                                                                                                                                                                                                              |

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

| Label                          | Description                                                                                                                                                                                                                                           |
|--------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Slave uses lock control?       | The connected slave uses and requires the lock control from each of the masters.<br>Values:<br>false (0)<br>true (1)<br>Default Value: true<br>Enabled: Always<br>Parameter Name: ICM_HAS_LOCK                                                        |
| Slave uses protection control? | The connected slave uses and requires the protection control from each of the masters.<br><b>Values:</b> <ul> <li>false (0)</li> <li>true (1)</li> </ul> <li>Default Value: false</li> <li>Enabled: Always</li> <li>Parameter Name: ICM_HAS_PROT</li> |

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

| Label                      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| External Priority Control? | <ul> <li>This setting, when True (1), enables you to control the arbitration priority from external signals. This is the only way for you to dynamically change the priorities. When priorities are internal, they are fixed with Layer 1 the highest priority down to Layer 8 with the lowest priority.</li> <li>The external priorities are controlled by driving the icm_priority bus input. When there are:</li> </ul>                                                                              |  |
|                            | 2 layers - bus is 2-bits wide; each layer has 1 bit for priority.                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
|                            | <ul> <li>3 layers - bus is 6-bits wide; each layer has 2 bits for priority.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
|                            | 4 layers - bus is 8-bits wide; each layer has 2 bits for priority.                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
|                            | <ul> <li>5 layers - bus is 15-bits wide; each layer has 3 bits for priority.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
|                            | <ul> <li>6 layers - bus is 18-bits wide; each layer has 3 bits for priority.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
|                            | <ul> <li>7 layers - bus is 21-bits wide; each layer has 3 bits for priority.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
|                            | 8 layers - bus is 24-bits wide; each layer has 3 bits for priority.                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
|                            | <ul> <li>9 layers - bus is 36-bits wide, each layer has 4 bit for priority.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
|                            | <ul> <li>10 layers - bus is 40-bits wide; each layer has 4 bits for priority.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                |  |
|                            | 11 layers - bus is 44-bits wide; each layer has 4 bits for priority.                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
|                            | 12 layers - bus is 48-bits wide; each layer has 4 bits for priority.                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
|                            | 13 layers - bus is 52-bits wide; each layer has 4 bits for priority.                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
|                            | 14 layers - bus is 56-bits wide; each layer has 4 bits for priority.                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
|                            | 15 layers - bus is 60-bits wide; each layer has 4 bits for priority.                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
|                            | 16 layers - bus is 64-bits wide; each layer has 4 bits for priority.                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
|                            | The bit order of the icm_priority is always:                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
|                            | <pre>[layer16]_[layer15]_[layer14]_[layer13]_[layer12]_[layer11]_[layer10]_[layer9]<br/>[layer8]_[layer7]_[layer6]_[layer5]_[layer4]_[layer3]_[layer2]_[layer1]<br/>For a four-layer system, the following is an example of driving icm_priority:<br/>icm_priority[1:0] =&gt; layer 1 (2'b00) Highest Priority<br/>icm_priority[3:2] =&gt; layer 2 (2'b11) Fourth Priority<br/>icm_priority[5:4] =&gt; layer 3 (2'b01) Second Priority<br/>icm_priority[7:6] =&gt; layer 4 (2'b10) Third Priority</pre> |  |
|                            | If the priorities are the same, then the layer index is used to calculate the highest priority. If layer 1 and layer 2 have the same priority then layer 1 is deemed as the higher priority.<br>Values:                                                                                                                                                                                                                                                                                                 |  |
|                            | <ul> <li>false (0)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
|                            | <ul> <li>true (1)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
|                            | Default Value: false                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
|                            | Enabled: Always                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
|                            | Parameter Name: ICM_HAS_XPRIORITY                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |

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

| Label                                               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
|-----------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                                                     | Split Control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| Slave is split capable?                             | The connected slave is split-capable and needs to know which master is driving the address and control. Values:  false (0)  true (1) Default Value: false Enabled: AHB_LITE == 0 Parameter Name: ICM_HAS_SPLIT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
|                                                     | Holding Control Layer x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
| Matrix can release layer x?<br>(for x = 1; x <= 16) | <ul> <li>Enables a layer to give the option for a higher priority layer to be granted access to the slave.</li> <li>A layer may be prevented from getting access to the slave if other layers have higher priority or are taking a long time. Meanwhile, masters on the layer can do nothing with that slave and may need to access other slaves. When the slave becomes available, the DW_ahb_icm allows the layer to RETRY, whereby a master on that layer can continue with the original transfer or enable another master to have access.</li> <li>If there is no other master requesting access, then the master that was being held off can RETRY the transfer.</li> <li>Values: <ul> <li>false (0)</li> <li>true (1)</li> </ul> </li> <li>Default Value: false</li> <li>Enabled: This option is not available when the component is configured as an AMBA Lite system (AHB_LITE = 1).</li> <li>Parameter Name: ICM_RELEASE_Lx</li> </ul> |  |  |
| Wait Limit layer x<br>(for x = 1; x <= 16)          | The number of cycles that a layer can be held off before the matrix generates a RETRY response. Once a RETRY is generated, any stored address and control is cancelled and the master with the highest priority on Layer 1 gains access.<br><b>Values:</b> 0x4, 0x5, 0x6, 0x7, 0x8, 0x9, 0xa, 0xb, 0xc, 0xd, 0xe, 0xf<br><b>Default Value:</b> 0x4<br><b>Enabled:</b> This option is not available when the component is configured as an AMBA Lite system (AHB_LITE = 1).<br><b>Parameter Name:</b> ICM_RLIMIT_Lx                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |

## 3.2 Top Level Parameters / DW\_ahb\_icm Source Code Configuration Parameters

| Table 3-2 | Top Level Parameters / DW | _ahb_icm Source Code | <b>Configuration Parameters</b> |
|-----------|---------------------------|----------------------|---------------------------------|
|           |                           |                      |                                 |

| Label                                          | Description                                                                                                                                                                                                                                                                                                                                                     |  |  |
|------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| DW_ahb_icm Source Code Configuration           |                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| Use DesignWare Foundation<br>Synthesis Library | The component code utilizes DesignWare Foundation parts for optimal Synthesis<br>QoR. Customers with only a DesignWare license must use Foundation parts.<br>Customers with only a Source license cannot use Foundation parts. Customers with<br>both Source and DesignWare licenses have the option of using DesignWare<br>Foundation parts.<br><b>Values:</b> |  |  |
|                                                | <ul> <li>false (0)</li> <li>true (1)</li> </ul>                                                                                                                                                                                                                                                                                                                 |  |  |
|                                                | <b>Default Value:</b> True if DesignWare License is available; False if no DesignWare License is available                                                                                                                                                                                                                                                      |  |  |
|                                                | <b>Enabled:</b> Parameter is enabled if customer has both Source and DesignWare licenses                                                                                                                                                                                                                                                                        |  |  |
|                                                | Parameter Name: USE_FOUNDATION                                                                                                                                                                                                                                                                                                                                  |  |  |

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

- Clock and Reset Interface on page 39
- Arbitration Control on page 40
- Slave Layer Interface on page 41
- Master Layer x Interface on page 45

### 4.1 Clock and Reset Interface Signals



### Table 4-1 Clock and Reset Interface Signals

| Port Name | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                      |  |
|-----------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| hclk      | 1   | Bus clock. Active on rising edge. Common clock for all layers.<br>Exists: Always<br>Synchronous To: None<br>Registered: N/A<br>Power Domain: SINGLE_DOMAIN<br>Active State: N/A                                                                                                                                                                                                                                  |  |
| hresetn   | I   | Bus reset. Common reset for all layers. Asynchronous assertion,<br>synchronous de-assertion. The reset must be synchronously de-<br>asserted after the rising edge of hclk. DW_ahb_icm does not contain<br>logic to perform this synchronization, so it must be provided<br>externally.<br>Exists: Always<br>Synchronous To: Asynchronous<br>Registered: N/A<br>Power Domain: SINGLE_DOMAIN<br>Active State: Low |  |

### 4.2 Arbitration Control Signals



### Table 4-2Arbitration Control Signals

| Port Name                                              | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------------------------------------------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| icm_priority[((ICM_NUM_LAYERS*ICM_<br>DP_PWIDTH)-1):0] | 1   | Optional. This bus allows you to control the arbitration priority<br>externally. In cases where the number of layers is not a power of 2<br>(that is, 2, 4, 8 or 16), the priority of a layer should be programmed<br>with only a value from 0 to ICM_NUM_LAYERS-1. The following<br>range of values will cause an illegal operation, if used:<br>ICM_NUM_LAYERS to 2 ^ (ceil(log2ICM_NUM_LAYERS)).<br>Exists: (ICM_HAS_XPRIORITY == 1)<br>Synchronous To: hclk<br>Registered: No<br>Power Domain: SINGLE_DOMAIN<br>Active State: High |

### 4.3 Slave Layer Interface Signals



### Table 4-3 Slave Layer Interface Signals

| Port Name                    | I/O | Description                                                                                                                                                                                          |
|------------------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| hresp[1:0]                   | 1   | Response type from slave.<br>Exists: Always<br>Synchronous To: (AHB_MASK_PRIORITY==1   <br>ICM_HAS_SPLIT==1) ? "hclk" : "None"<br>Registered: No<br>Power Domain: SINGLE_DOMAIN<br>Active State: N/A |
| hready_resp                  | I   | Transfer complete.<br>Exists: Always<br>Synchronous To: hclk<br>Registered: No<br>Power Domain: SINGLE_DOMAIN<br>Active State: High                                                                  |
| hrdata[(AHB_DATA_WIDTH-1):0] | I   | Read data from slave.<br>Exists: Always<br>Synchronous To: hclk<br>Registered: No<br>Power Domain: SINGLE_DOMAIN<br>Active State: N/A                                                                |

### Table 4-3 Slave Layer Interface Signals (Continued)

| Port Name                                 | I/O | Description                                                                                                                                                                                                                                                                                                                                                                      |  |
|-------------------------------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| hsplit[15:0]                              | 1   | Optional. Split response from slave. Used to clear the internal<br>arbitration to allow the master to re-arbitrate. One bit for each master<br>on a layer. The response is passed to the layer that was split and that<br>initiated the transfer.<br>Exists: (ICM_HAS_SPLIT == 1)<br>Synchronous To: hclk<br>Registered: No<br>Power Domain: SINGLE_DOMAIN<br>Active State: High |  |
| hsel_sj<br>(for j = 1; j <= ICM_NUM_HSEL) | 0   | Slave select line. jth slave signal.<br>Exists: ((ICM_HAS_MHSEL==1) && (ICM_NUM_HSEL>=j))<br>Synchronous To: hclk<br>Registered: No<br>Power Domain: SINGLE_DOMAIN<br>Active State: High                                                                                                                                                                                         |  |
| haddr[(HADDR_WIDTH-1):0]                  | 0   | Slave address.<br>Exists: Always<br>Synchronous To: hclk<br>Registered: No<br>Power Domain: SINGLE_DOMAIN<br>Active State: N/A                                                                                                                                                                                                                                                   |  |
| htrans[1:0]                               | 0   | Slave transfer control.<br>htrans = 0> IDLE<br>htrans = 01> BUSY<br>htrans = 10> NONSEQ<br>htrans = 11> SEQ<br>Exists: Always<br>Synchronous To: hclk<br>Registered: No<br>Power Domain: SINGLE_DOMAIN<br>Active State: N/A                                                                                                                                                      |  |
| hsize[2:0]                                | 0   | Slave transfer size.<br>Exists: Always<br>Synchronous To: hclk<br>Registered: No<br>Power Domain: SINGLE_DOMAIN<br>Active State: N/A                                                                                                                                                                                                                                             |  |

### Table 4-3 Slave Layer Interface Signals (Continued)

| Port Name                    | I/O | Description                                                                                                                                                                                                                                                                    |  |
|------------------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| hburst[(HBURST_WIDTH-1):0]   | 0   | Optional. Slave transfer type.<br>Exists: (ICM_HAS_BURST == 1)<br>Synchronous To: hclk<br>Registered: No<br>Power Domain: SINGLE_DOMAIN<br>Active State: N/A                                                                                                                   |  |
| hwdata[(AHB_DATA_WIDTH-1):0] | 0   | Slave write data.<br>Exists: Always<br>Synchronous To: hclk<br>Registered: No<br>Power Domain: SINGLE_DOMAIN<br>Active State: N/A                                                                                                                                              |  |
| hwrite                       | 0   | Slave write control.<br>Exists: Always<br>Synchronous To: hclk<br>Registered: No<br>Power Domain: SINGLE_DOMAIN<br>Active State: High                                                                                                                                          |  |
| hmastlock                    | 0   | Optional. Slave locked transfer control.<br>Exists: (ICM_HAS_LOCK == 1)<br>Synchronous To: hclk<br>Registered: No<br>Power Domain: SINGLE_DOMAIN<br>Active State: High                                                                                                         |  |
| hprot[3:0]                   | 0   | Optional. Slave protection control.<br>Exists: (ICM_HAS_PROT == 1)<br>Synchronous To: hclk<br>Registered: No<br>Power Domain: SINGLE_DOMAIN<br>Active State: N/A                                                                                                               |  |
| hmaster[3:0]                 | 0   | Optional. The master that is currently accessing the slave, Each layer<br>keeps track of which master is driving and presents this to the slave.<br>Exists: (ICM_HAS_SPLIT == 1)<br>Synchronous To: hclk<br>Registered: No<br>Power Domain: SINGLE_DOMAIN<br>Active State: N/A |  |

### Table 4-3 Slave Layer Interface Signals (Continued)

| Port Name                  | I/O | Description                                                                                                                                                                                             |  |
|----------------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| mid[(MID_LAYNO_WIDTH-1):0] | 0   | Optional. Non standard Master ID sideband signal output (in AHB-<br>Lite mode).<br>Exists: (MID_WIDTH!=0)<br>Synchronous To: hclk<br>Registered: No<br>Power Domain: SINGLE_DOMAIN<br>Active State: N/A |  |
| hready                     | 0   | Current transfer is complete.<br>Exists: Always<br>Synchronous To: hclk<br>Registered: No<br>Power Domain: SINGLE_DOMAIN<br>Active State: High                                                          |  |

### 4.4 Master Layer x Interface Signals



- hresp\_lx (for x = 1; x <= ICM\_NUM\_LAYERS)
- hready\_resp\_lx (for x = 1; x <= ICM\_NUM\_LAYERS)
- hrdata\_lx (for x = 1; x <= ICM\_NUM\_LAYERS)
   hsplit\_lx (for x = 1; x <= ICM\_NUM\_LAYERS)</pre>

| Port Name                                                            | I/O | Description                                                                                                                                                                                                                                                         |
|----------------------------------------------------------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| hsel_s1_lx<br>(for x = 1; x <= ICM_NUM_LAYERS)                       | I   | Slave select from the layer decoder. 1st slave select signal on layer x.<br>Exists: (ICM_NUM_LAYERS>=x)<br>Synchronous To: hclk<br>Registered: No<br>Power Domain: SINGLE_DOMAIN<br>Active State: High                                                              |
| hsel_sj_lx<br>(for j,x = 2,1; j,x <=<br>ICM_NUM_HSEL,ICM_NUM_LAYERS) | I   | Optional. Slave select from the layer decoder. jth slave select signal<br>on layer x.<br>Exists: ((ICM_HAS_MHSEL==1) && (ICM_NUM_HSEL>=j) &&<br>(ICM_NUM_LAYERS>=x))<br>Synchronous To: hclk<br>Registered: No<br>Power Domain: SINGLE_DOMAIN<br>Active State: High |
| haddr_lx[(HADDR_WIDTH-1):0]<br>(for x = 1; x <= ICM_NUM_LAYERS)      | I   | Address.<br>Exists: Always<br>Synchronous To: hclk<br>Registered: No<br>Power Domain: SINGLE_DOMAIN<br>Active State: N/A                                                                                                                                            |

### Table 4-4 Master Layer x Interface Signals (Continued)

| Port Name                                                           | I/O | Description                                                                                                                                                                                                                        |
|---------------------------------------------------------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| htrans_lx[1:0]<br>(for x = 1; x <= ICM_NUM_LAYERS)                  | I   | Transfer control.<br>htrans_lx = 00> IDLE<br>htrans_lx = 01> BUSY<br>htrans_lx = 10> NONSEQ<br>htrans_lx = 11> SEQ<br>Exists: Always<br>Synchronous To: hclk<br>Registered: No<br>Power Domain: SINGLE_DOMAIN<br>Active State: N/A |
| hsize_lx[2:0]<br>(for x = 1; x <= ICM_NUM_LAYERS)                   | I   | Transfer size.<br>Exists: Always<br>Synchronous To: hclk<br>Registered: No<br>Power Domain: SINGLE_DOMAIN<br>Active State: N/A                                                                                                     |
| hburst_lx[(HBURST_WIDTH-1):0]<br>(for x = 1; x <= ICM_NUM_LAYERS)   | 1   | Transfer type. Optional signal.<br>Exists: (ICM_HAS_BURST == 1)<br>Synchronous To: hclk<br>Registered: No<br>Power Domain: SINGLE_DOMAIN<br>Active State: N/A                                                                      |
| hwdata_lx[(AHB_DATA_WIDTH-1):0]<br>(for x = 1; x <= ICM_NUM_LAYERS) | 1   | Write data.<br>Exists: Always<br>Synchronous To: None<br>Registered: No<br>Power Domain: SINGLE_DOMAIN<br>Active State: N/A                                                                                                        |
| hwrite_lx<br>(for x = 1; x <= ICM_NUM_LAYERS)                       | I   | Write control.<br>Exists: Always<br>Synchronous To: hclk<br>Registered: No<br>Power Domain: SINGLE_DOMAIN<br>Active State: High                                                                                                    |
| hmastlock_lx<br>(for x = 1; x <= ICM_NUM_LAYERS)                    | I   | Optional. Locked transfer control.<br>Exists: (ICM_HAS_LOCK == 1)<br>Synchronous To: hclk<br>Registered: No<br>Power Domain: SINGLE_DOMAIN<br>Active State: High                                                                   |

### Table 4-4 Master Layer x Interface Signals (Continued)

| Port Name                                                   | I/O | Description                                                                                                                                                                                                                                                                                                                                                                               |
|-------------------------------------------------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| hprot_lx[3:0]<br>(for x = 1; x <= ICM_NUM_LAYERS)           | 1   | Optional. Protection control.<br>Exists: (ICM_HAS_PROT == 1)<br>Synchronous To: hclk<br>Registered: No<br>Power Domain: SINGLE_DOMAIN<br>Active State: N/A                                                                                                                                                                                                                                |
| hready_lx<br>(for x = 1; x <= ICM_NUM_LAYERS)               | 1   | Previous transfer is complete.<br>Exists: Always<br>Synchronous To: hclk<br>Registered: No<br>Power Domain: SINGLE_DOMAIN<br>Active State: High                                                                                                                                                                                                                                           |
| hmaster_lx[3:0]<br>(for x = 1; x <= ICM_NUM_LAYERS)         | 1   | Optional. Index of the master that is active on the layer. When a slave<br>is split capable, it needs to know which master was driving the<br>address and control signals so that it is able to release the correct<br>master when it returns from a split.<br>Exists: (ICM_HAS_SPLIT == 1)<br>Synchronous To: hclk<br>Registered: No<br>Power Domain: SINGLE_DOMAIN<br>Active State: N/A |
| mid_lx[(MID_WIDTH-1):0]<br>(for x = 1; x <= ICM_NUM_LAYERS) | I   | Optional. Non standard Master ID sideband signal input (in AHB-Lite<br>mode).<br>Exists: (MID_WIDTH!=0)<br>Synchronous To: hclk<br>Registered: No<br>Power Domain: SINGLE_DOMAIN<br>Active State: N/A                                                                                                                                                                                     |
| hresp_lx[1:0]<br>(for x = 1; x <= ICM_NUM_LAYERS)           | 0   | Response type from slave to the Layer x.<br>Exists: Always<br>Synchronous To: hclk<br>Registered: No<br>Power Domain: SINGLE_DOMAIN<br>Active State: N/A                                                                                                                                                                                                                                  |

### Table 4-4 Master Layer x Interface Signals (Continued)

| Port Name                                                           | I/O | Description                                                                                                                                                                                 |
|---------------------------------------------------------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| hready_resp_lx<br>(for x = 1; x <= ICM_NUM_LAYERS)                  | 0   | Transfer complete. When asserted, current transfer has been<br>successful.<br>Exists: Always<br>Synchronous To: hclk<br>Registered: No<br>Power Domain: SINGLE_DOMAIN<br>Active State: High |
| hrdata_lx[(AHB_DATA_WIDTH-1):0]<br>(for x = 1; x <= ICM_NUM_LAYERS) | 0   | Read data from slave to the Layer x.<br>Exists: Always<br>Synchronous To: hclk<br>Registered: No<br>Power Domain: SINGLE_DOMAIN<br>Active State: N/A                                        |
| hsplit_lx[15:0]<br>(for x = 1; x <= ICM_NUM_LAYERS)                 | 0   | Optional. Split data from slave.<br>Exists: (ICM_HAS_SPLIT == 1)<br>Synchronous To: hclk<br>Registered: No<br>Power Domain: SINGLE_DOMAIN<br>Active State: High                             |

# 5 Verification

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

The DW\_ahb\_icm 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 following web page:

### https://www.synopsys.com/dw/doc.php/doc/amba/latest/dw\_amba\_install.pdf

### 5.1 Overview of Vera Tests

The DW\_ahb\_icm verification testbench performs the following set of tests that have been written to exhaustively verify functionality and have also achieved maximum RTL code coverage.

### 5.1.1 Access

This test verifies that it is possible for each layer to access the slave. At no time during this test do the layers compete for access at the same time to the slave. All types of transfers from read and write transfers to single and burst transfers are generated for the slave from each layer. The slave is configured to respond with random wait states for each access. The test writes data from one layer and reads it with another layer. This test verifies that slaves with multiple select lines are capable of getting access for each bit of the select. The test generates transfers to the slave for addresses within all of its regions. This test also verifies that burst, lock, and protection control are channeled through the DW\_ahb\_icm from the layer that initiated the transfer.

### 5.1.2 Priority Scheme

This test verifies the priority scheme between the layers. Multiple layers compete for access to the slave at the same time. As soon as transfers are started from lower priority layers, transfers to the slave from higher priority layers are started. The accesses vary from single transfers to burst transfers. Different scenarios are generated where one layer starts a burst before another layer starts.

### 5.1.3 Locked Transfers

This test verifies that once a transfer that is locked starts, no other layer can gain access to the slave until the lock is removed, regardless of its priority. This test verifies that once burst transfers start, they are allowed to complete without another layer gaining access to the slave.

### 5.1.4 Responses

This test verifies the following:

- Generation of RETRY response by the matrix
- Generation of responses from the common slave
- Channelling of the responses to the layer that initiated the transfer

This test is broken into two parts:

- 1. Slave generates all response types. Split responses are generated only if the slave is configured to be capable of generating a split response. RETRY responses are generated only if the matrix is not connected to AHB Lite master layers.
- 2. Matrix generates RETRY and is only run when the matrix is configured to implement a watchdog on the length of time a layer can be held off before it has to generate a retry response.

The test configures the slave for all responses. Split responses are configured to return from the split after a number of different cycles. The test configures a clash between layers and generates bus traffic where layers are held off for more than their limit, ensuring the DW\_ahb\_icm releases the layer.

For more information on AHB Lite, see "Functional Description" chapter in the *DesignWare DW\_ahb Databook*.

### 5.2 DW\_ahb\_icm Testbench

As illustrated in Figure 5-1, the DW\_ahb\_icm Verilog testbench includes:

- Instantiation of the design under test (DUT)
- Multiple AHB bus models
- Vera shell

### Figure 5-1 DW\_ahb\_icm Testbench



The Vera shell consists of the following:

- AHB Master bus functional models (BFM)
- AHB Slave BFMs
- Transfer Monitor
- Test stimuli
- BFM configuration
- Test results

The Transfer Monitor tracks the transfers from the masters to the slaves, ensuring all are completed and non are lost even during retry/split transfers.

The file, test\_DW\_ahb\_icm.v, shows the instantiation of the top-level MacroCell in a testbench and resides in the *workspace*/src directory. The testbench tests the user configuration specified in the Specify Configuration task of coreConsultant and is self-checking. When a coreKit has been unpacked and configured, the verification environment is stored in *workspace*/sim. Files in *workspace*/sim/test\_icm form the actual testbench for DW\_ahb\_icm.

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

### 6.1 Performance

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

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

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

### Table 6-1 Power Consumption, Frequency, and Area Results for DW\_ahb\_icm Using 28nm Technology Library

| Configuration                                                                                | Operating<br>Frequency | Gate Count | Static Power<br>Consumption | Dynamic Power<br>Consumption |
|----------------------------------------------------------------------------------------------|------------------------|------------|-----------------------------|------------------------------|
| Default Configuration                                                                        | hclk: 300 MHz          | 1076 gates | 0.0186uW                    | 3.26uW                       |
| Minimum Configuration:<br>AHB_LITE=1=<br>ICM_HAS_BURST=0<br>ICM_HAS_PROT=0<br>ICM_HAS_LOCK=0 | hclk: 300 MHz          | 988 gates  | 0.0173uW                    | 2.98uW                       |

| Configuration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Operating<br>Frequency | Gate Count  | Static Power<br>Consumption | Dynamic Power<br>Consumption |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|-------------|-----------------------------|------------------------------|
| Maximum Configuration:ICM_NUM_LAYERS=8ICM_RELEASE_L1=1ICM_RELEASE_L2=1ICM_RELEASE_L3=1ICM_RELEASE_L4=1ICM_RELEASE_L5=1ICM_RELEASE_L6=1ICM_RELEASE_L7=1ICM_RELEASE_L8=1AHB_DATA_WIDTH=256HADDR_WIDTH=64                                                                                                                                                                                                                                                                                                           | hclk: 300 MHz          | 9406 gates  | 0.145uW                     | 23.1uW                       |
| Maximum Configuration (with 16<br>AHB Layers):<br>ICM_NUM_LAYERS=16<br>ICM_RELEASE_L1=1<br>ICM_RELEASE_L2=1<br>ICM_RELEASE_L2=1<br>ICM_RELEASE_L3=1<br>ICM_RELEASE_L4=1<br>ICM_RELEASE_L5=1<br>ICM_RELEASE_L6=1<br>ICM_RELEASE_L6=1<br>ICM_RELEASE_L7=1<br>ICM_RELEASE_L9=1<br>ICM_RELEASE_L10=1<br>ICM_RELEASE_L10=1<br>ICM_RELEASE_L12=1<br>ICM_RELEASE_L12=1<br>ICM_RELEASE_L13=1<br>ICM_RELEASE_L13=1<br>ICM_RELEASE_L15=1<br>ICM_RELEASE_L15=1<br>ICM_RELEASE_L16=1<br>AHB_DATA_WIDTH=256<br>HADDR_WIDTH=64 | hclk: 300 MHz          | 20590 gates | 0.317uW                     | 46.3uW                       |

# A

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

| Parameter Name  | Equals To                                                                                                                                              |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| BUSY            | 2'b01                                                                                                                                                  |
| ICM_DP_PWIDTH   | {[function_of: ]}                                                                                                                                      |
| IDLE            | 2'b00                                                                                                                                                  |
| MID_LAYNO_WIDTH | ((ICM_NUM_LAYERS<=2) ? (1 + MID_WIDTH) :<br>((ICM_NUM_LAYERS<=4) ? (2 + MID_WIDTH) :<br>((ICM_NUM_LAYERS<=8) ? (3 + MID_WIDTH) : (4 +<br>MID_WIDTH)))) |
| NONSEQ          | 2'b10                                                                                                                                                  |
| RETRY           | 2'b10                                                                                                                                                  |
| SEQ             | 2'b11                                                                                                                                                  |
| SPLIT           | 2'b11                                                                                                                                                  |

### Table A-1 Internal Parameters

# **B** Glossary

| active command queue   | Command queue from which a model is currently taking commands; see also 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.<br>AHB supports the efficient connection of processors, on-chip memories and off-<br>chip external memory interfaces (Arm® Limited specification). |
| AMBA                   | Advanced Microcontroller Bus Architecture — a trademarked name by $Arm^{\ensuremath{\mathbb{R}}}$ 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$ <sup>®</sup> 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<br>command streams independently of each other to provide full-duplex mode<br>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<br>entity (VHDL) or module (Verilog) in a design. Core is the preferred term for a big<br>piece of IIP. Anything that requires coreConsultant for configuration, as well as<br>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<br>and synthesis views you need to integrate the core into your design. Can also<br>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<br>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.                                                                                        |

| 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<br>by a single DesignWare license. Products include SmartModels, VMT model<br>suites, DesignWare Memory Models, Building Block IP, and the DesignWare<br>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-<br>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<br>Environment (TRE) | A collection of files for stand-alone verification of the configured component. The files, tests, and functionality vary from component to component.                                                                                                                                                                               |
| VIP                                       | Verification Intellectual Property — A generic term for a simulation model in any form, including a Design View.                                                                                                                                                                                                                    |
| workspace                                 | A network location that contains a personal copy of a component or subsystem.<br>After you configure the component or subsystem (using coreConsultant or<br>coreAssembler), the workspace contains the configured component/subsystem<br>and generated views needed for integration of the component/subsystem at the<br>top level. |
| wrap, wrapper                             | Code, usually VHDL or Verilog, that surrounds a design or model, allowing easier interfacing. Usually requires an extra, sometimes automated, step to create the wrapper.                                                                                                                                                           |
| zero-cycle command                        | A command that executes without HDL simulation time advancing.                                                                                                                                                                                                                                                                      |
|                                           |                                                                                                                                                                                                                                                                                                                                     |

## Index

### Α

active command queue definition 57 activity definition 57 AHB definition 57 AMBA definition 57 APB definition 57 APB bridge definition 57 application design definition 57 arbiter definition 57 Arbitration for layer selection 19 for select lines 19

### В

BFM definition 57 big-endian definition 57 Block diagram, of DW\_ahb\_icm 13, 17, 18 blocked command stream definition 57 blocking command definition 57 bus bridge definition 58

### С

command channel definition 58 command stream

definition 58 component definition 58 configuration definition 58 configuration intent definition 58 core definition 58 core developer definition 58 core integrator definition 58 coreAssembler definition 58 coreConsultant definition 58 coreKit definition 58 Customer Support 8 cycle command definition 58

### D

Data generation, slave to layer 20 decoder definition 58 design context definition 58 design creation definition 58 Design View definition 58 DesignWare cores definition 59 DesignWare Library definition 59 DesignWare Synthesizable Components definition 58 dual role device definition 59 DW\_ahb\_icm block diagram of 13, 17, 18 description 17 functional description of 13 input stage 18 testbench overview of 51 overview of tests 49 timing diagrams 21

### Ε

endian definition 59 Environment, licenses 14

### F

Full-Functional Mode definition 59Functional description 13, 17

### G

Generation of slave responses 20 of slave to layer data 20 GPIO definition 59 GTECH definition 59

### Н

hard IP definition 59 HDL definition 59

### I

IIP definition 59 implementation view definition 59 Input stage, description of 18 instantiate definition 59 interface definition 59 IP definition 59

### L

Layer arbitration description of 19 timing diagram of 21 Layer request 19 Layer selection, description of 19 Licenses 14 little-endian definition 59 Lock generation 19

### Μ

MacroCell definition 59 master definition 59 model definition 59 monitor definition 59

### Ν

non-blocking command definition 59

### Ρ

peripheral definition 59

### R

RETRY generation timing diagram of 22 RTL definition 60

### S

SDRAM definition 60 SDRAM controller definition 60 Select arbitration, description of 19 slave definition 60 Slave response generation 20 SoC definition 60 SoC Platform AHB contained in 11 APB, contained in 11 defined 11 soft IP definition 60 Split-capable slaves, and multiple layers 21 static controller definition 60 subsystem definition 60 synthesis intent definition 60 synthesis intent definition 60

### Т

technology-independent definition 60 Testsuite Regression Environment (TRE) definition 60 TRE definition 60

### V

Vera, overview of tests 49 Verification and Vera tests 49 VIP definition 60

### W

workspace definition 60 wrap definition 60 wrapper definition 60

### Ζ

zero-cycle command definition 60