# PrimeCell® Vectored Interrupt Controller (PL190) Cycle Model

Version 9.1.0

**User Guide** 

Non-Confidential



# PrimeCell® Vectored Interrupt Controller (PL190) Cycle Model User Guide

Copyright © 2017 ARM Limited. All rights reserved.

#### **Release Information**

The following changes have been made to this document.

**Change History** 

| Date          | Issue | Confidentiality  | Change          |
|---------------|-------|------------------|-----------------|
| February 2017 | A     | Non-Confidential | Restamp release |

#### **Non-Confidential Proprietary Notice**

This document is protected by copyright and other related rights and the practice or implementation of the information contained in this document may be protected by one or more patents or pending patent applications. No part of this document may be reproduced in any form by any means without the express prior written permission of ARM Limited ("ARM"). No license, express or implied, by estoppel or otherwise to any intellectual property rights is granted by this document unless specifically stated.

Your access to the information in this document is conditional upon your acceptance that you will not use or permit others to use the information for the purposes of determining whether implementations infringe any patents.

THIS DOCUMENT IS PROVIDED "AS IS". ARM PROVIDES NO REPRESENTATIONS AND NO WARRANTIES, EXPRESS, IMPLIED OR STATUTORY, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF MERCHANTABILITY, SATISFACTORY QUALITY, NON-INFRINGEMENT OR FITNESS FOR A PARTICULAR PURPOSE WITH RESPECT TO THE DOCUMENT. For the avoidance of doubt, ARM makes no representation with respect to, and has undertaken no analysis to identify or understand the scope and content of, third party patents, copyrights, trade secrets, or other rights.

This document may include technical inaccuracies or typographical errors.

This document may be translated into other languages for convenience, and you agree that if there is any conflict between the English version of this document and any translation, the terms of the English version shall prevail.

TO THE EXTENT NOT PROHIBITED BY LAW, IN NO EVENT WILL ARM BE LIABLE FOR ANY DAMAGES, INCLUDING WITHOUT LIMITATION ANY DIRECT, INDIRECT, SPECIAL, INCIDENTAL, PUNITIVE, OR CONSEQUENTIAL DAMAGES, HOWEVER CAUSED AND REGARDLESS OF THE THEORY OF LIABILITY, ARISING OUT OF ANY USE OF THIS DOCUMENT, EVEN IF ARM HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.

This document consists solely of commercial items. You shall be responsible for ensuring that any use, duplication or disclosure of this document complies fully with any relevant export laws and regulations to assure that this document or any portion thereof is not exported, directly or indirectly, in violation of such export laws. Use of the word "partner" in reference to ARM's customers is not intended to create or refer to any partnership relationship with any other company. ARM may make changes to this document at any time and without notice.

If any of the provisions contained in these terms conflict with any of the provisions of any signed written agreement specifically covering this document with ARM, then the signed written agreement prevails over and supersedes the conflicting provisions of these terms

Words and logos marked with ® or ™ are registered trademarks or trademarks of ARM Limited or its affiliates in the EU and/or elsewhere. All rights reserved. Other brands and names mentioned in this document may be the trademarks of their respective owners. You must follow the ARM trademark usage guidelines http://www.arm.com/about/trademarks/guidelines/index.php.

Copyright © ARM Limited or its affiliates. All rights reserved. ARM Limited. Company 02557590 registered in England. 110 Fulbourn Road, Cambridge, England CB1 9NJ.

In this document, where the term ARM is used to refer to the company it means "ARM or any of its subsidiaries as appropriate".

#### **Confidentiality Status**

This document is Non-Confidential. The right to use, copy and disclose this document may be subject to license restrictions in accordance with the terms of the agreement entered into by ARM and the party that ARM delivered this document to.

#### **Product Status**

The information in this document is final, that is for a developed product.

#### Web Address

http://www.arm.com

# Contents

## Chapter 1. Using the Cycle Model in SoC Designer

| VIC PL190 Cycle Model Functionality               | 1 |
|---------------------------------------------------|---|
| Fully Functional and Accurate Features            | 2 |
| Unsupported Hardware Features                     | 2 |
| Features Additional to the Hardware               | 2 |
| Adding and Configuring the SoC Designer Component | 3 |
| SoC Designer Component Files                      | 3 |
| Adding the Cycle Model to the Component Library   | 4 |
| Adding the Component to the SoC Designer Canvas   | 4 |
| Available Component ESL Ports                     | 5 |
| Setting Component Parameters                      | 6 |
| Debug Features                                    | 8 |
| Registers Information                             | 8 |
| Available Profiling Data                          |   |

## **Preface**

A Cycle Model component is a library developed from ARM intellectual property (IP) that is generated through Cycle Model Studio<sup>TM</sup>. The Cycle Model then can be used within a virtual platform tool, for example, SoC Designer.

#### **About This Guide**

This guide provides all the information needed to configure and use the Cycle Model in SoC Designer.

#### **Audience**

This guide is intended for experienced hardware and software developers who create components for use with SoC Designer. You should be familiar with the following products and technology:

- SoC Designer
- Hardware design verification
- Verilog or SystemVerilog programming language

#### **Conventions**

This guide uses the following conventions:

| Convention        | Description                                                                                        | Example                                                                                  |
|-------------------|----------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|
| courier           | Commands, functions, variables, routines, and code examples that are set apart from ordinary text. | <pre>sparseMem_t SparseMemCreate- New();</pre>                                           |
| italic            | New or unusual words or phrases appearing for the first time.                                      | Transactors provide the entry and exit points for data                                   |
| bold              | Action that the user performs.                                                                     | Click <b>Close</b> to close the dialog.                                                  |
| <text></text>     | Values that you fill in, or that the system automatically supplies.                                | <pre><place <="" <<="" place="" td=""></place></pre>                                     |
| [ text ]          | Square brackets [ ] indicate optional text.                                                        | <pre>\$CARBON_HOME/bin/modelstudio [ <filename> ]</filename></pre>                       |
| [ text1   text2 ] | The vertical bar   indicates "OR," meaning that you can supply text1 or text 2.                    | <pre>\$CARBON_HOME/bin/modelstudio [<name>.symtab.db   <name>.ccfg ]</name></name></pre> |

Also note the following references:

- References to C code implicitly apply to C++ as well.
- File names ending in .cc, .cpp, or .cxx indicate a C++ source file.

#### **Further reading**

This section lists related publications. The following publications provide information that relate directly to SoC Designer:

- SoC Designer Installation Guide
- SoC Designer User Guide
- SoC Designer Standard Component Library Reference Manual

The following publications provide reference information about ARM® products:

- AMBA 3 AHB-Lite Overview
- AMBA Specification (Rev 2.0)
- AMBA AHB Transaction Level Modeling Specification
- Architecture Reference Manual

See <a href="http://infocenter.arm.com/help/index.jsp">http://infocenter.arm.com/help/index.jsp</a> for access to ARM documentation.

The following publications provide additional information on simulation:

- IEEE 1666<sup>TM</sup> SystemC Language Reference Manual, (IEEE Standards Association)
- SPIRIT User Guide, Revision 1.2, SPIRIT Consortium.

#### Glossary

**AMBA** Advanced Microcontroller Bus Architecture. The ARM open standard on-chip bus specification that describes a strategy for the interconnection and management of functional blocks that make up a System-on-Chip (SoC). **AHB** Advanced High-performance Bus. A bus protocol with a fixed pipeline between address/control and data phases. It only supports a subset of the functionality provided by the AMBA AXI protocol. **APB** Advanced Peripheral Bus. A simpler bus protocol than AXI and AHB. It is designed for use with ancillary or general-purpose peripherals such as timers, interrupt controllers, UARTs, and I/O ports. **AXI** Advanced eXtensible Interface. A bus protocol that is targeted at high performance, high clock frequency system designs and includes a number of features that make it very suitable for high speed sub-micron interconnect. A software object created by the Cycle Model Studio (or Cycle Model Com-Cycle Model piler) from an RTL design. The Cycle Model contains a cycle- and registeraccurate model of the hardware design. Cycle Model Graphical tool for generating, validating, and executing hardware-accurate Studio software models. It creates a Cycle Model, and it also takes a Cycle Model as input and generates a component that can be used in SoC Designer, Platform Architect, or Accellera SystemC for simulation. **CASI** ESL API Simulation Interface, is based on the SystemC communication library and manages the interconnection of components and communication between components. **CADI** ESL API Debug Interface, enables reading and writing memory and register values and also provides the interface to external debuggers. **CAPI** ESL API Profiling Interface, enables collecting historical data from a component and displaying the results in various formats. Component Building blocks used to create simulated systems. Components are connected together with unidirectional transaction-level or signal-level connections. **ESL** Electronic System Level. A type of design and verification methodology that models the behavior of an entire system using a high-level language such as C or C++. **HDL** Hardware Description Language. A language for formal description of electronic circuits, for example, Verilog. RTL Register Transfer Level. A high-level hardware description language (HDL) for defining digital circuits. SoC Designer High-performance, cycle accurate simulation framework which is targeted at System-on-a-Chip hardware and software debug as well as architectural exploration. SystemC SystemC is a single, unified design and verification language that enables verification at the system level, independent of any detailed hardware and software implementation, as well as enabling co-verification with RTL design. Transactor

form.

*Transaction adaptors.* You add transactors to your component to connect your component directly to transaction level interface ports for your particular plat-

# Chapter 1

1

# Using the Cycle Model in SoC Designer

This chapter describes the functionality of the Cycle Model component, and how to use it in SoC Designer. It contains the following sections:

- VIC PL190 Cycle Model Functionality
- Adding and Configuring the SoC Designer Component
- Available Component ESL Ports
- Setting Component Parameters
- Debug Features
- Available Profiling Data

## 1.1 VIC PL190 Cycle Model Functionality

This section provides a summary of the functionality of the Cycle Model compared to that of the hardware, and the performance and accuracy of the Cycle Model. For details of the functionality of the hardware that the Cycle Model simulates, refer to the *ARM PrimeCell® Vectored Interrupt Controller (PL190) Technical Reference Manual*.

- Fully Functional and Accurate Features
- Unsupported Hardware Features
- Features Additional to the Hardware

## 1.1.1 Fully Functional and Accurate Features

The following features of the VIC PL190 hardware implementation are fully implemented in the VIC PL190 Cycle Model.

- Compliance to AMBA AHB specification
- Support for 32 standard interrupts
- Support 16 vectored IRQ interrupts
- Hardware interrupts priority levels
- IRQ and FIQ generation
- Software interrupts generation
- Debug Register
- Raw interrupt status
- · Interrupt request status
- · Interrupt masking
- Privileged mode support
- Interrupt controller Daisy chaining

## 1.1.2 Unsupported Hardware Features

The PL190 Cycle Model does not support scan or other testing features.

#### 1.1.3 Features Additional to the Hardware

The following features that are implemented in the VIC PL190 Cycle Model do not exist in the VIC PL190 hardware. These features have been added to the Cycle Model for enhanced usability.

• The component supports positive and negative level *irq* and *fiq* signal. This is configurable using the *negLogic* parameter (see Table 1-3 on page 1-6).

## 1.2 Adding and Configuring the SoC Designer Component

The following topics briefly describe how to use the Cycle Model component. See the *SoC Designer User Guide* for more information.

- SoC Designer Component Files
- Adding the Cycle Model to the Component Library
- Adding the Component to the SoC Designer Canvas

## 1.2.1 SoC Designer Component Files

The component files are the final output from the Cycle Model Studio compile and are the input to SoC Designer. There are two versions of the component; an optimized *release* version for normal operation, and a *debug* version.

On Linux the *debug* version of the component is compiled without optimizations and includes debug symbols for use with gdb. The *release* version is compiled without debug information and is optimized for performance.

On Windows the *debug* version of the component is compiled referencing the debug runtime libraries, so it can be linked with the debug version of SoC Designer. The *release* version is compiled referencing the release runtime library. Both release and debug versions generate debug symbols for use with the Visual C++ debugger on Windows.

The provided component files are listed below:

Table 1-1 SoC Designer Component Files

| Platform | File                                              | Description                         |
|----------|---------------------------------------------------|-------------------------------------|
| Linux    | maxlib.lib <model_name>.conf</model_name>         | SoC Designer configuration file     |
|          | lib <component_name>.mx.so</component_name>       | SoC Designer component runtime file |
|          | lib <component_name>.mx_DBG.so</component_name>   | SoC Designer component debug file   |
| Windows  | maxlib.lib <model_name>.windows.conf</model_name> | SoC Designer configuration file     |
|          | lib <component_name>.mx.dll</component_name>      | SoC Designer component runtime file |
|          | lib <component_name>.mx_DBG.dll</component_name>  | SoC Designer component debug file   |

Additionally, this User Guide PDF file is provided with the component.

## 1.2.2 Adding the Cycle Model to the Component Library

The compiled Cycle Model component is provided as a configuration file (.conf). To make the component available in the Component Window in SoC Designer Canvas, perform the following steps:

- 1. Launch SoC Designer Canvas.
- 2. From the *File* menu, select Preferences.
- 3. Click on Component Library in the list on the left.
- 4. Under the Additional Component Configuration Files window, click Add.
- 5. Browse to the location where the Cycle Model is located and select the component configuration file:
  - maxlib.lib<model name>.conf (for Linux)
  - maxlib.lib<model\_name>.windows.conf (for Windows)
- 6. Click OK.
- 7. To save the preferences permanently, click the **OK & Save** button.

The component is now available from the SoC Designer Component Window.

### 1.2.3 Adding the Component to the SoC Designer Canvas

Locate the component in the Component Window and drag it out to the Canvas.

# 1.3 Available Component ESL Ports

Table 1-2 describes the ESL ports that are exposed in SoC Designer. See the *ARM PrimeCell*® *VIC (PL190) Technical Reference Manual* for more information.

Table 1-2 ESL Component Ports

| ESL Port   | Description                                                                                           | Direction | Туре                                |
|------------|-------------------------------------------------------------------------------------------------------|-----------|-------------------------------------|
| clk-in     | Input clock. This component must be connected to the clock.                                           | Input     | Clock slave                         |
| reset      | Input reset. Reset port for receiving reset signal.                                                   | Input     | Signal slave                        |
| ahb        | AHB slave port.                                                                                       | Input     | AHB_Slave_FT2S<br>Transaction slave |
| isrc       | Interrupt source.                                                                                     | Input     | Interrupt slave                     |
| fiq_in     | External interrupt controller FIQ interrupt. Active high/low is controlled by the negLogic parameter. | Input     | Signal slave                        |
| irq_in     | External interrupt controller IRQ interrupt. Active high/low is controlled by the negLogic parameter. | Input     | Signal slave                        |
| VecAddrIn  | Daisy-chained vector address input.                                                                   | Input     | Signal slave                        |
| fiq        | FIQ interrupt. Active high/low is controlled by the negLogic parameter.                               | Output    | Signal master                       |
| irq        | IRQ interrupt. Active high/low is controlled by the negLogic parameter.                               | Output    | Signal master                       |
| VecAddrOut | Daisy-chained vector address output.                                                                  | Output    | Signal master                       |

All pins that are not listed in this table have been either tied or disconnected for performance reasons.

*Note:* It is necessary to disable the ports if they are not used.

## 1.4 Setting Component Parameters

You can change the settings of all the component parameters in SoC Designer Canvas, and of some of the parameters in SoC Designer Simulator. To modify the Cycle Model parameters:

- 1. In the Canvas, right-click on the Cycle Model and select Edit Parameters.... You can also double-click the component.
- 2. In the *Parameters* window, double-click the Value field of the parameter that you want to modify.
- 3. If it is a text field, type a new value in the *Value* field. If a menu choice is offered, select the desired option. The parameters are described in Table 1-3.

Table 1-3 Component Parameters

| Name                             | Description                                                                                                                                                                                                | Allowed<br>Values  | Default<br>Value | Runtime <sup>1</sup> |
|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|------------------|----------------------|
| ahb Align Data                   | Whether halfword and byte transactions will align data to the transaction size. By default, data is not aligned.                                                                                           | true, false        | false            | No                   |
| ahb Big Endian                   | Whether AHB data is treated as big endian.<br>By default, data is not sent as big endian.                                                                                                                  | true, false        | false            | No                   |
| ahb Enable Debug<br>Messages     | Enable or disable the capture of ahb debug messages.                                                                                                                                                       | true, false        | false            | Yes                  |
| ahb Filter<br>HREADYIN           | The HREADYIN signal indicates the state of other AHB devices on the bus. By default, this signal is not filtered - it is received by this component.                                                       | true, false        | false            | No                   |
| ahb region size 0                | Address range size.                                                                                                                                                                                        | 0 -<br>0xFFFFFFF   | 0x100            | No                   |
| ahb region size [1-5]            | Unused                                                                                                                                                                                                     | 0 -<br>0xFFFFFFF   | 0x0              | No                   |
| ahb region start 0               | Address range base.                                                                                                                                                                                        | 0x0 -<br>0xfffffff | 0x1000000        | No                   |
| ahb region start [1-5]           | Unused                                                                                                                                                                                                     | 0x0 -<br>0xfffffff | 0x0              | No                   |
| ahb Subtract Base<br>Address     | Whether the Base Address parameter is subtracted from the actual transaction address before being passed to the component. By default, the actual transaction address is passed directly to the component. | true, false        | false            | No                   |
| ahb Subtract Base<br>Address Dbg | Same description as for <i>ahb Subtract Base Address</i> , except this is for debug transactions.                                                                                                          | true, false        | true             | No                   |

Table 1-3 Component Parameters (continued)

| Name                       | Description                                                                                                                                                                       | Allowed<br>Values        | Default<br>Value     | Runtime <sup>1</sup> |
|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|----------------------|----------------------|
| Align Waveforms            | When set to <i>true</i> , waveforms dumped from the component are aligned with the SoC Designer simulation time. The reset sequence, however, is not included in the dumped data. | true, false              | true                 | No                   |
|                            | When set to <i>false</i> , the reset sequence is dumped to the waveform data, however, the component time is not aligned with the SoC Designer time.                              |                          |                      |                      |
| Carbon DB Path             | Sets the directory path to the database file.                                                                                                                                     | Not Used                 | empty                | No                   |
| Dump Waveforms             | Whether SoC Designer dumps waveforms for this component.                                                                                                                          | true, false              | false                | Yes                  |
| Enable Debug<br>Messages   | Enable or disable the capture of debug messages.                                                                                                                                  | true, false              | false                | Yes                  |
| negLogic                   | Sets IRQ/FIQ assertion to use negative logic. Default of <i>false</i> means 0=off and 1=on. <i>True</i> means 0=on and 1=off.                                                     | true, false              | false                | No                   |
| Waveform File <sup>2</sup> | Name of the waveform file.                                                                                                                                                        | string                   | arm_cm_pl1<br>90.vcd | No                   |
| Waveform Timescale         | Sets the timescale to be used in the waveform.                                                                                                                                    | Many values in drop-down | 1 ns                 | No                   |

<sup>1.</sup> Yes means the parameter can be dynamically changed during simulation, No means it can be changed only when building the system, Reset means it can be changed during simulation, but its new value will be taken into account only at the next reset.

<sup>2.</sup> When enabled, SoC Designer writes accumulated waveforms to the waveform file in the following situations: when the waveform buffer fills, when validation is paused and when validation finishes, and at the end of each validation run.

## 1.5 Debug Features

The VIC PL190 Cycle Model has a debug interface (CADI) that allows the user to view, manipulate and control the registers in the SoC Designer Simulator and Model Debugger.

## 1.5.1 Registers Information

This section lists the register views available for the VIC PL190 Cycle Model in the SoC Designer Simulator. The VIC PL190 Cycle Model has three sets of registers that are accessible via the debug interface. Registers are grouped into sets according to functional area.

- General Registers
- Peripheral ID Registers
- PrimeCell ID Registers

See the ARM PrimeCell® VIC (PL190) Technical Reference Manual for detailed descriptions of these registers.

#### 1.5.1.1 General Registers

Table 1-4 shows the General registers.

Table 1-4 General Registers Summary

| Register          | Description                                                                                                                                                                                   | Туре       |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|
| VICIRQStatus      | Provides the status of the interrupts after IRQ masking.                                                                                                                                      | read-only  |
| VICFIQStatus      | Provides the status of the interrupts after FIQ masking.                                                                                                                                      | read-only  |
| VICRawIntr        | Provides the status of the source interrupts, and software interrupts, to the interrupt controller.                                                                                           | read-only  |
| VICIntSelect      | Selects whether the corresponding interrupt source generates an FIQ or an IRQ interrupt.  0 = IRQ interrupt  1 = FIQ interrupt                                                                | read-write |
| VICIntEnable      | Enables the interrupt request lines, by masking the interrupt sources for the IRQ interrupt.                                                                                                  | read-write |
|                   | A write to the debug interface will forcibly set the value. It will not behave as a write to this register through the AHB bus. See section 3.3.5 of the TRM.                                 |            |
| VICIntEnClear     | Set to 0                                                                                                                                                                                      | read-only  |
| VICSoftInt        | Generates software interrupts.  A write to the debug interface will forcibly set the value. It will not behave as a write to this register through the AHB bus. See section 3.3.7 of the TRM. | read-write |
| VICSoftIntClear   | Set to 0                                                                                                                                                                                      | read-only  |
| VICProtection     | Enables or disables protected register access.                                                                                                                                                | read-write |
| VICVectAddr[0-15] | Contains the ISR vector address; from 0 to 15.                                                                                                                                                | read-write |

Table 1-4 General Registers Summary (continued)

| Register           | Description                                                                             | Туре       |
|--------------------|-----------------------------------------------------------------------------------------|------------|
| VICVectCntrl[0-15] | Selects the interrupt source for the vectored interrupt; from 0 to 15.                  | read-write |
| VICVectAddr        | Contains the Interrupt Service Routine (ISR) address of the currently active interrupt. | read-only  |
| VICDefVectAddr     | Contains the address of the default ISR handler.                                        | read-write |

## 1.5.1.2 Peripheral ID Registers

Table 1-5 shows the Peripheral Identification registers.

Table 1-5 Peripheral ID Registers Summary

| Register     | Description                                                | Туре      |
|--------------|------------------------------------------------------------|-----------|
| VICPeriphID0 | Identifies the part number of the peripheral.              | read-only |
| VICPeriphID1 | Identifies the part number and designer of the peripheral. | read-only |
| VICPeriphID2 | Identifies the revision and designer of the peripheral.    | read-only |
| VICPeriphID3 | Identifies the configuration of the peripheral.            | read-only |

#### 1.5.1.3 PrimeCell ID Registers

Table 1-6 shows the PrimeCell Identification registers.

Table 1-6 PrimeCell ID Registers Summary

| Register    | Description                 | Туре      |
|-------------|-----------------------------|-----------|
| VICPCellID0 | Determines the reset value. | read-only |
| VICPCellID1 | Determines the reset value. | read-only |
| VICPCellID2 | Determines the reset value. | read-only |
| VICPCellID3 | Determines the reset value. | read-only |

## 1.6 Available Profiling Data

The VIC PL190 Cycle Model component has no profiling capabilities.