# VC Verification IP AMBA AXI UVM User Guide

Version O-2018.09, September 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 http://www.synopsys.com/company/legal/trademarks-brands.html.

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

#### Free and Open-Source Software Licensing Notices

If applicable, Free and Open-Source Software (FOSS) licensing notices are available in the product installation.

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

| Preface                                                                                | . 9       |
|----------------------------------------------------------------------------------------|-----------|
| About This Guide                                                                       | .9        |
| Guide Organization                                                                     |           |
| Web Resources                                                                          |           |
| Customer Support                                                                       | <b>10</b> |
| Chapter 1                                                                              |           |
| Introduction                                                                           | 11        |
| 1.1 Introduction                                                                       |           |
| 1.2 Prerequisites                                                                      |           |
| 1.3 References                                                                         |           |
| 1.4 Product Overview                                                                   |           |
| 1.5 Language and Methodology Support                                                   |           |
| 1.6 Features Supported                                                                 |           |
| 1.6.1 Protocol Features                                                                |           |
| 1.6.2 Verification Features                                                            |           |
| 1.6.3 Methodology Features                                                             |           |
| 1.7 Features Not Supported                                                             |           |
|                                                                                        |           |
| Chapter 2                                                                              |           |
| Installation and Setup                                                                 |           |
| 2.1 Verifying the Hardware Requirements                                                |           |
| 2.2 Verifying Software Requirements                                                    |           |
| 2.2.1 Platform/OS and Simulator Software                                               |           |
| 2.2.2 Synopsys Common Licensing (SCL) Software                                         |           |
| 2.2.3 Other Third Party Software                                                       |           |
| 2.3 Preparing for Installation                                                         |           |
| 2.4 Downloading and Installing                                                         |           |
| 2.4.1 Downloading From the Electronic Software Transfer (EST) System (Download Center) |           |
| 2.4.2 Downloading Using FTP with a Web Browser                                         |           |
| 2.5 What's Next?                                                                       |           |
| 2.5.1 Licensing Information                                                            |           |
| 2.5.2 Environment Variable and Path Settings                                           |           |
| 2.5.3 Determining Your Model Version                                                   |           |
| 2.5.4 Integrating the VIP into Your Testbench                                          |           |
| 2.5.5 Include and Import Model Files into Your Testbench                               |           |
| 2.5.6 Compile and Run Time Options                                                     | 31        |
| Chapter 3                                                                              |           |
| · ·                                                                                    | 22        |

|     | Introduction to UVM                                                                      |      |
|-----|------------------------------------------------------------------------------------------|------|
| 3.2 | AXI VIP in an UVM Environment                                                            | 34   |
|     | 3.2.1 Master Agent                                                                       | 34   |
|     | 3.2.2 Slave Agent                                                                        | 34   |
|     | 3.2.3 Stimulus Modeling                                                                  | 35   |
|     | 3.2.4 Slave Memory                                                                       | 46   |
|     | 3.2.5 FIFO Memory                                                                        | 51   |
|     | 3.2.6 Interconnect Env                                                                   | 51   |
|     | 3.2.7 System Environment                                                                 |      |
|     | 3.2.8 System Monitor                                                                     | 54   |
|     | 3.2.9 Active and Passive Mode                                                            |      |
| 3.3 | AXI UVM User Interface                                                                   |      |
|     | 3.3.1 Clock and Reset Connection                                                         |      |
|     | 3.3.2 VIP Interface Connection                                                           |      |
|     | 3.3.3 Configuration Objects                                                              |      |
|     | 3.3.4 Transaction Objects                                                                |      |
|     | 3.3.5 Analysis Ports                                                                     |      |
|     | 3.3.6 Callbacks                                                                          |      |
|     | 3.3.7 Interfaces and Modports                                                            |      |
|     | 3.3.8 Transaction Status Tracking Methods and Events                                     |      |
|     | 3.3.9 Overriding System Constants                                                        |      |
|     | 3.3.10 Support for TLM Generic Payload                                                   |      |
| 3.4 | Functional Coverage                                                                      |      |
|     | 3.4.1 Default Coverage                                                                   |      |
|     | 3.4.2 Coverage Callback Classes                                                          |      |
|     | 3.4.3 Enabling Default Coverage                                                          |      |
|     | 3.4.4 Coverage Shaping and Control                                                       |      |
| 3.5 | Protocol Checks                                                                          |      |
|     | 3.5.1 Comprehensive List of Protocol Checks                                              |      |
|     | 3.5.2 AXI4 Protocol Checks                                                               |      |
| 3.6 | Reset Functionality                                                                      |      |
|     | 3.6.1 Behavior when svt_axi_port_configuration::reset_type = EXCLUDE_UNSTARTED_XACT      | (de- |
|     | fault value)                                                                             |      |
| 0 ~ | 3.6.2 Behavior when svt_axi_port_configuration::reset_type reset_type = RESET_ALL_XACT . | 88   |
| 3.7 | Support for ACE Protocol in AXI Master Agent                                             |      |
|     | 3.7.1 Support for Coherent Transactions                                                  |      |
|     | 3.7.2 Support for Snoop Transactions                                                     |      |
|     | 3.7.3 Back Door Access to the Cache                                                      |      |
|     | 3.7.4 Support for Barrier Transactions                                                   |      |
|     | 3.7.5 Support for DVM Transactions                                                       |      |
|     | 3.7.6 Support for ACE-Lite                                                               |      |
|     | 3.7.7 Support for ACE Domain                                                             |      |
|     | 3.7.8 Support for Speculative Read                                                       |      |
|     | 3.7.9 Support for Snoop Filtering                                                        |      |
|     | 3.7.10 Cache State Transitions to Legal End States                                       |      |
|     | 3.7.11 Support for ACE Exclusive Access                                                  |      |
| 9 0 | 3.7.12 Known Limitations                                                                 |      |
|     | Support for ACE protocol in AXI Slave Agent                                              |      |
| ა.ყ | Support for ACE protocol in AXI Interconnect Env                                         |      |
|     | 3.9.1 Support for Coherent and Snoop Transactions                                        | 90   |

Feedback

| 3.9.2 Support for ACE Domain                                                      |     |
|-----------------------------------------------------------------------------------|-----|
| 3.9.3 Support for DVM                                                             |     |
| 3.9.4 Support for Barrier                                                         |     |
| 3.9.5 Support for Speculative Read                                                |     |
| 3.9.6 Unsupported ACE Features in Interconnect Env                                |     |
| 3.9.7 Known Limitation                                                            |     |
| 3.10 AXI4 Region and Address Range Support in Slave                               |     |
| 3.10.1 Slave Address Range Support                                                |     |
| 3.10.2 Slave Region Support                                                       |     |
| 3.10.3 Slave Response Generation                                                  |     |
| 3.11 Support for Monitoring AXI Low Power Interface                               |     |
| 3.11.1 Module Top                                                                 |     |
| 3.11.2 System Configuration                                                       |     |
| 5.11.5 Alialysis Forts                                                            | 102 |
| Chapter 4                                                                         |     |
| Verification Features                                                             | 105 |
| 4.1 AXI Sequence Collection                                                       | 105 |
| 4.2 Verification Planner                                                          |     |
| 4.3 Protocol Analyzer Support                                                     |     |
| 4.3.1 Support for VC Auto Testbench                                               |     |
| 4.3.2 Support for Native Dumping of FSDB                                          |     |
| 4.4 Performance Analysis                                                          |     |
| 4.4.1 Performance Analyzer                                                        |     |
| 4.4.2 Metrics Description                                                         |     |
| 4.4.3 Accessing the Port Level Performance Metrics From Testbench During Run-time |     |
| 4.4.4 Dynamic Reconfiguration                                                     |     |
| 4.5 Error Injection                                                               |     |
| 4.5.1 Exception Class                                                             |     |
| 4.5.2 Exception Lists                                                             |     |
| 4.5.3 Use Model                                                                   |     |
| 4.6 Phase Jump for AXI VIP                                                        | 116 |
| Chapter 5                                                                         |     |
| Verification Topologies                                                           | 117 |
| 5.1 Testing a Master DUT Using an UVM Slave VIP                                   |     |
| 5.2 Testing a Slave DUT Using an UVM Master VIP                                   |     |
| 5.3 Interconnect DUT and Master/Slave VIP                                         |     |
| 5.4 System DUT with Passive VIP                                                   | 122 |
| 5.5 System DUT with Mix of Active and Passive VIP                                 |     |
| 5.6 System DUT with Active Interconnect VIP                                       |     |
| 5.7 Interconnect DUT with System Monitor                                          |     |
| 5.8 System DUT with System Monitor                                                | 127 |
| Chapter 6                                                                         |     |
| Using AXI Verification IP                                                         | 190 |
| 6.1 SystemVerilog UVM Example Testbenches                                         |     |
| 6.2 Installing and Running the Examples                                           |     |
| 6.2.1 Defines for Increasing Number of Masters and Slaves                         |     |
|                                                                                   | 139 |

| 6.3 How to Provide Data and Response Information to the Slave After a Time Delay           | 132 |
|--------------------------------------------------------------------------------------------|-----|
| 6.4 How to Disable Objection Management by VIP, and Allow Testbench to Manage Objections   | 135 |
| 6.5 How to Control the Forwarding of Barrier and Cache Maintenance Transactions to Downstr |     |
| Slaves by the Interconnect VIP                                                             |     |
| 6.6 How to Configure AXI Slaves with Overlapping Address                                   | 136 |
| 6.7 How to Generate ACE WriteEvict Transactions                                            | 137 |
| 6.8 Why the User Needs to Disable Auto Item Recording                                      |     |
| 6.9 How Does the Interconnect VIP Handle Barrier Transactions?                             |     |
| 6.10 How to Access a Byte Level Data of AXI Slave VIP Memory Using backdoor read/write? .  |     |
| 6.11 Data Integrity Checks                                                                 |     |
| 6.12 Setting up Secure and Non-Secure access mechanism for AXI-ACE Master                  | 140 |
| 6.13 Snoop Filter Support                                                                  |     |
| 6.14 Configuration Requirements to Enable System Level Cover Groups Which Use Master to S  |     |
| Transaction Association                                                                    |     |
| 6.15 Exclusive Access Support                                                              |     |
| 6.15.1 Exclusive Access Related Configurations                                             |     |
| 6.15.2 Exclusive Access Checks                                                             |     |
| 6.15.3 How Exclusive Accesses From Multiple Clusters are Modeled in System Monitor (exc    |     |
| monitor per ID)?                                                                           |     |
| 6.16 Backdoor Cache Access Methods                                                         |     |
| 6.17 AXI4 Stream Protocol                                                                  |     |
| 6.17.1 Concepts                                                                            |     |
| 6.18 Steps to Integrate the uvm_reg With AXI VIP                                           |     |
| 6.19 Design Specific Coherent to Snoop Transaction Association                             |     |
| 6.19.1 Solution Description                                                                | 159 |
| 6.19.2 User Interface                                                                      |     |
|                                                                                            |     |
| 6.20 Single Outstanding Transaction Per AxID                                               |     |
| 6.21 Interleaved Port Support                                                              |     |
| 6.22 Master to Slave Path Access Coverage                                                  |     |
| 6.23 AXI_ACE Path Coverage                                                                 |     |
| 6.24 Wait State Mechanisms                                                                 |     |
| 6.25 Interconnect Routing                                                                  | 160 |
| Chapter 7                                                                                  |     |
| Usage Notes                                                                                |     |
| 7.1 Managing Coverage Through Exclude File                                                 |     |
| 7.1 Managing Coverage Infough Exclude The                                                  | 100 |
| Chapter 8                                                                                  |     |
| Troubleshooting                                                                            |     |
| 8.1 Using Debug Port                                                                       |     |
|                                                                                            |     |
| Appendix A                                                                                 |     |
| Reporting Problems                                                                         |     |
| A.1 Introduction                                                                           |     |
| A.2 Debug Automation                                                                       | 167 |
| A.3 Enabling and Specifying Debug Automation Features                                      |     |
| A.4 Debug Automation Outputs                                                               | 169 |
| A.5 FSDB File Generation                                                                   | 170 |
| A.5.1 VCS                                                                                  | 170 |
| A.5.2 Questa                                                                               | 170 |
|                                                                                            |     |

| A.5.3 Incisive                            |     |
|-------------------------------------------|-----|
| A.6 Initial Customer Information          |     |
| A.7 Sending Debug Information to Synopsys | 170 |
| A.8 Limitations                           |     |

# **Preface**

#### **About This Guide**

This guide contains installation, setup, and usage material for SystemVerilog UVM users of the VC Verification for AMBA AXI, and is for design or verification engineers who want to verify AXI operation using an UVM testbench written in SystemVerilog. Readers are assumed to be familiar with AXI, Object Oriented Programming (OOP), SystemVerilog, and Universal Verification Methodology (UVM) techniques.

## **Guide Organization**

The chapters of this databook are organized as follows:

- Chapter 1, "Introduction", introduces the AXI VIP and its features.
- Chapter 2, "Installation and Setup", describes system requirements and provides instructions on how to install, configure, and begin using the AXI VIP.
- ❖ Chapter 3, "General Concepts", introduces the AXI VIP within the UVM environment and describes the data objects and components that comprise the VIP.
- Chapter 4, "Verification Features", describes the verification features supported by AXI VIP such as, Verification Planner and Protocol Analyzer.
- Chapter 5, "Verification Topologies", describes the topologies to verify master, slave and interconnect DUT.
- ❖ Chapter 6, "Using AXI Verification IP", shows how to install and run a getting started example.
- Chapter 8, "Troubleshooting", describes the debug port.
- Appendix A, "Reporting Problems", outlines the process for working through and reporting AXI VIP issues.

#### **Web Resources**

- Documentation through SolvNet: <a href="https://solvnet.synopsys.com">https://solvnet.synopsys.com</a> (Synopsys password required)
- Synopsys Common Licensing (SCL): <a href="http://www.synopsys.com/keys">http://www.synopsys.com/keys</a>

## **Customer Support**

To obtain support for your product, choose one of the following:

- Open a Case through SolvNet.
  - ◆ Go to https://onlinecase.synopsys.com/Support/OpenCase.aspx and provide the requested information, including:

Product: Verification IP
 Sub Product: AMBA SVT
 Tool Version: O-2018.09

- ♦ Fill in the remaining fields according to your environment and your issue.
- **♦** If applicable, provide the information noted in Appendix A, "Reporting Problems" on page 167.
- Send an e-mail message to support\_center@synopsys.com.
  - ◆ Include the Product name, Sub Product name, and Tool Version (as noted above) in your e-mail so it can be routed correctly.
  - ◆ If applicable, provide the information noted in Appendix A, "Reporting Problems" on page 167.
- 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: http://www.synopsys.com/Support/GlobalSupportCenters

# Introduction

This chapter gives a basic introduction, overview and features of the AXI UVM Verification IP.

This chapter discusses the following topics:

- "Introduction" on page 11
- "Prerequisites" on page 11
- ❖ "References" on page 12
- "Product Overview" on page 12
- "Language and Methodology Support" on page 12
- "Features Supported" on page 12
- "Features Not Supported" on page 13

#### 1.1 Introduction

The AXI VIP supports verification of SoC designs that include interfaces implementing the AXI Specification. This document describes the use of this VIP in testbenches that comply with the SystemVerilog Universal Verification Methodology (UVM). This approach leverages advanced verification technologies and tools that provide,

- Protocol functionality and abstraction
- Constrained random verification
- Functional coverage
- Rapid creation of complex tests
- ❖ Modular testbench architecture that provides maximum reuse, scalability and modularity
- Proven verification approach and methodology
- Transaction-level models
- Self-checking tests
- ❖ Object oriented interface that allows OOP techniques

# 1.2 Prerequisites

❖ Familiarize with AXI, object oriented programming, SystemVerilog, and the current version of UVM.

#### 1.3 References

For more information on AXI Verification IP, see the following documents:

Class Reference for VC Verification IP for AMBA® AXI is available at: \$DESIGNWARE\_HOME/vip/svt/amba\_svt/latest/doc/axi\_svt\_uvm\_class\_reference/html/index.html

#### 1.4 Product Overview

The AXI UVM VIP is a suite of UVM-based verification components that are compatible for use with SystemVerilog-Compliant testbenches. The AXI VIP suite simulates AXI transactions through active agents, as defined by the AXI specification.

The VIP provides an AXI System Env that contains the Master agents, Slave agents, Interconnect Env and System Monitor. The Master and Slave agents support all the functionality normally associated with active and passive UVM components, including the creation of transactions, checking and reporting the protocol correctness, transaction logging and functional coverage. The System Monitor performs system-level checks across the master and slave ports of the interconnect within the system. The Interconnect Env supports transaction routing between masters and slaves. After instantiating the System Env, you can select and combine active and passive agents to create an environment that verifies AXI features in the DUT.

The Master agents, Slave agents and Interconnect Env can also be used in standalone mode, that is, they can be instantiated in the testbench directly, without the system environment.

#### 1.5 Language and Methodology Support

The current version of AXI VIP suite is qualified with the following languages and methodology:

- Languages
  - **♦** SystemVerilog
- Methodology
  - ◆ Qualified with UVM 1.1d and UVM 1.2

# 1.6 Features Supported

#### 1.6.1 Protocol Features

AXI VIP currently supports the following protocol functions:

- **❖** AXI3 Channel handshake (Valid, ready signaling)
- **❖** AXI3 Addressing options (All Burst lengths, burst types, burst sizes)
- AXI3 Response Signaling (support for OKAY, DECERR and SLVERR)
- AXI3 Ordering Model (transaction IDs, read/write ordering, write data interleaving)
- AXI3 exclusive access
- AXI3 Locked access
- **❖** AXI3 Data Buses (Write strobes, narrow transfers)
- AXI3 Unaligned Transfers
- AXI3 Reset functionality
- AXI4 Read/Write

- AXI4 Interface categories (Read only/Write only)
- **❖** AXI4 Quality of Service
- AXI4 Region
- **❖** AXI4 AWCACHE and ARCACHE Attributes
- ❖ AXI4-Lite
- AXI4 Longer bursts
- AXI4 User signals
- **❖** ACE Support
- AXI4 Stream

#### 1.6.2 Verification Features

AXI VIP currently supports the following verification functions:

- Default functional coverage (transaction, state and toggle coverage)
- Protocol checking
- Debug port
- ❖ Programmable value (X, Z, hold previous) on all channel signals, when valid signal is low
- Control on delays and timeouts
- **❖** Built-in slave memory
- Verification Planner
- Protocol Analyzer
- VC Auto Testbench
- **❖** AutoPerformance

#### 1.6.3 Methodology Features

AXI VIP currently supports the following methodology functions:

- VIP organized as AXI System Environment, which includes set of Master agents, Slave agents, Interconnect Env and System Monitor. The Master agents, Slave agents and Interconnect Env can also be used in standalone mode
- Analysis ports for connecting Master/Slave Agents to Scoreboard, or any other component
- Callbacks for Master agents, Slave Agents and Interconnect Env
- Notifications to denote start and end of transactions

# 1.7 Features Not Supported

For more information on features, see *Known Issues and Limitations* section present in *AXI Verification IP Notes* chapter in the AMBA SVT VIP Release Notes.

AMBA SVT VIP Release Notes are present at:

\$DESIGNWARE\_HOME/vip/svt/amba\_svt/latest/doc/amba\_svt\_rel\_notes.pdf

14

2

# **Installation and Setup**

This section leads you through installing and setting up the Synopsys AMBA AXI VIP. When you complete this checklist, the provided example testbench will be operational and the Synopsys AXI VIP will be ready to use.

The checklist consists of the following major steps:

- 1. "Verifying the Hardware Requirements"
- 2. "Verifying Software Requirements"
- 3. "Preparing for Installation"
- 4. "Downloading and Installing"
- 5. "What's Next?"



If you encounter any problems with installing the Synopsys AXI VIP, see "Customer Support" on page 10.

## 2.1 Verifying the Hardware Requirements

The AXI Verification IP requires a Solaris or Linux workstation configured as follows:

- **❖** 1440 MB available disk space for installation
- ❖ 16 GB Virtual Memory recommended
- FTP anonymous access to ftp.synopsys.com (optional)

# 2.2 Verifying Software Requirements

The Synopsys AXI VIP is qualified for use with certain versions of platforms and simulators. This section lists software that the Synopsys AXI VIP requires.

#### 2.2.1 Platform/OS and Simulator Software

Platform/OS and VCS: You need versions of your platform/OS and simulator that have been qualified for use. To see which platform/OS and simulator versions are qualified for use with the AXI VIP, check the support matrix for SVT-based VIP in the following document:

```
amba_svt_release_notes.pdf.
```

#### 2.2.2 Synopsys Common Licensing (SCL) Software

❖ The SCL software provides the licensing function for the Synopsys AXI VIP. Acquiring the SCL software is covered here in the installation instructions in "Licensing Information" on page 18.

#### 2.2.3 Other Third Party Software

- ❖ Adobe Acrobat: Synopsys AXI VIP documents are available in Acrobat PDF files. You can get Adobe Acrobat Reader for free from <a href="http://www.adobe.com">http://www.adobe.com</a>.
- **♦** HTML browser: Synopsys AXI VIP includes class reference documentation in HTML. The following browser/platform combinations are supported:
  - **♦** Microsoft Internet Explorer 6.0 or later (Windows)
  - ◆ Firefox 1.0 or later (Windows and Linux)
  - ♦ Netscape 7.x (Windows and Linux)

### 2.3 Preparing for Installation

1. Set DESIGNWARE\_HOME to the absolute path where Synopsys AXI VIP is to be installed:

```
setenv DESIGNWARE_HOME absolute_path_to_designware_home
```

- 2. Ensure that your environment and PATH variables are set correctly, including:
  - ♦ DESIGNWARE\_HOME/bin The absolute path as described in the previous step.
  - **♦** LM\_LICENSE\_FILE The absolute path to a file that contains the license keys for your third-party tools. Also, include the absolute path to the third party executable in your PATH variable.

```
% setenv LM_LICENSE_FILE <my_license_file|port@host>
```

**♦** SNPSLMD\_LICENSE\_FILE - The absolute path to a file that contains the license keys for Synopsys software or the port@host reference to this file.

```
% setenv SNPSLMD_LICENSE_FILE <my_Synopsys_license_file|port@host>
```

**♦** DW\_LICENSE\_FILE - The absolute path to a file that contains the license keys for VIP product software or the port@host reference to this file.

```
% setenv DW_LICENSE_FILE <my_VIP_license_file|port@host>
```

# 2.4 Downloading and Installing



The Electronic Software Transfer (EST) system only displays products your site is entitled to download. If the product you are looking for is not available, contact est-ext@synopsys.com.

Follow the instructions for downloading the software from Synopsys. You can download from the Download Center using either HTTPS or FTP, or with a command-line FTP session. If your Synopsys SolvNet password is unknown or forgotten, go to <a href="http://solvnet.synopsys.com">http://solvnet.synopsys.com</a>.

Passive mode FTP is required. The passive command toggles between passive and active mode. If your FTP utility does not support passive mode, use http. For additional information, see the following web page:

https://www.synopsys.com/apps/protected/support/EST-FTP\_Accelerator\_Help\_Page.html

#### 2.4.1 Downloading From the Electronic Software Transfer (EST) System (Download Center)

- 1. Point your web browser to http://solvnet.synopsys.com.
- 2. Enter your Synopsys SolvNet Username and Password.
- 3. Click Sign In button.
- 4. Make the following selections on SolvNet to download the .run file of the VIP (See Figure 2-1).
  - a. Downloads tab
  - b. VC VIP Library product releases
  - c. <release\_version>
  - d. Download Here button
  - e. Yes, I Agree to the Above Terms button
  - f. Download . run file for the VIP

Figure 2-1 SolvNet Selections for VIP Download



- g. Set the DESIGNWARE\_HOME environment variable to a path where you want to install the VIP.
  % setenv DESIGNWARE\_HOME VIP\_installation\_path
- h. Execute the <code>.run</code> file by invoking its filename. The VIP is unpacked and all files and directories are installed under the path specified by the <code>DESIGNWARE\_HOME</code> environment variable. The <code>.run</code> file can be executed from any directory. The important step is to set the <code>DESIGNWARE\_HOME</code> environment variable before executing the <code>.run</code> file.



The Synopsys AMBA VIP suite includes VIP models for all AMBA interfaces (AHB, APB, AXI, and ATB). You must download the VC VIP for AMBA suite to access the VIP models for AHB, APB, AXI, and ATB.

#### 2.4.2 Downloading Using FTP with a Web Browser

- 1. Follow the above instructions through the product version selection step.
- 2. Click the *Download via FTP* link instead of the *Download Here* button.
- 3. Click the Click Here To Download button.
- 4. Select the file(s) that you want to download.
- 5. Follow browser prompts to select a destination location.



If you are unable to download the Verification IP using above instructions, see the "Customer Support" section to obtain support for download and installation.

#### 2.5 What's Next?

The remainder of this chapter describes the details of the different steps you performed during installation and setup, and consists of the following sections:

- "Licensing Information" on page 18
- "Environment Variable and Path Settings" on page 21
- "Determining Your Model Version" on page 22
- **❖** "Integrating the VIP into Your Testbench" on page 22
- "Include and Import Model Files into Your Testbench" on page 30
- "Compile and Run Time Options" on page 31

#### 2.5.1 Licensing Information

The AMBA VIP uses the Synopsys Common Licensing (SCL) software to control its usage.

You can find general SCL information in the following location:

http://www.synopsys.com/keys

The Synopsys VIP for AMBA uses a licensing mechanism that is enabled by the following license features:

- VIP-AMBA-ATB-SVT
- VIP-AMBA-APB-SVT
- VIP-AMBA-AHB-SVT
- **❖** VIP-AMBA-STREAM-SVT
- VIP-AMBA-AXI-SVT
- VIP-AMBA-ACE-SVT
- ❖ VIP-AMBA-SVT
- VIP-PROTOCOL-SVT
- VIP-SOC-LIBRARY-SVT

**❖** VIP-LIBRARY-SVT + DesignWare-Regression

These licenses enable the AMBA VIP components as follows:

- **❖** VIP-AMBA-ATB-SVT enables ATB components.
- **❖** VIP-AMBA-APB-SVT enables APB2, APB3, APB4 components.
- ❖ VIP-AMBA-AHB-SVT enables AHB2, AHB3, AHB5, AHB-Lite, AHB Multi-Layer components.
- **❖** VIP-AMBA-STREAM-SVT enables AXI4 Stream components.
- ❖ VIP-AMBA-AXI-SVT enables AXI3, AXI4, AXI4-Lite components.
- ❖ VIP-AMBA-ACE-SVT enables AXI3, AXI4, AXI4-Lite, ACE, ACE-Lite components.
- ♦ VIP-AMBA-SVT enables ATB/APB2/APB3/APB4/AHB2/AHB3/AHB5/AHB-Lite/AHB-Multilayer/AXI4-Stream/AXI3/AXI4/AXI4-Lite/ACE/ACE-Lite components.

The order in which licenses are checked out is as describes below. The table below summarizes the license requirements for different AMBA interfaces.

The sequence in which the licenses are checked out are described in Table 2-1.

Table 2-1 License Requirements for AMBA Interfaces

| VIP Interface                                  | License Checkout Order                                                                                |
|------------------------------------------------|-------------------------------------------------------------------------------------------------------|
| АТВ                                            | VIP-AMBA-ATB-SVT -OR- VIP-AMBA-SVT -OR- VIP-PROTOCOL-SVT -OR- VIP-LIBRARY-SVT + DesignWare-Regression |
| APB2/APB3/APB4                                 | VIP-AMBA-APB-SVT -OR- VIP-AMBA-SVT -OR- VIP-PROTOCOL-SVT -OR- VIP-LIBRARY-SVT + DesignWare-Regression |
| AHB2/ AHB3/ AHB5, AHB-Lite/ AHB<br>Multi-Layer | VIP-AMBA-AHB-SVT -OR- VIP-AMBA-SVT -OR- VIP-PROTOCOL-SVT -OR- VIP-LIBRARY-SVT + DesignWare-Regression |

Table 2-1 License Requirements for AMBA Interfaces

| VIP Interface                                                                                                      | License Checkout Order                                                                                   |
|--------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|
| AXI4 STREAM                                                                                                        | VIP-AMBA-STREAM-SVT -OR- VIP-AMBA-SVT -OR- VIP-PROTOCOL-SVT -OR- VIP-LIBRARY-SVT + DesignWare-Regression |
| AXI3/AXI4/AXI4-Lite                                                                                                | VIP-AMBA-AXI-SVT -OR- VIP-AMBA-SVT -OR- VIP-PROTOCOL-SVT -OR- VIP-LIBRARY-SVT + DesignWare-Regression    |
| AXI3/AXI4/AXI4-Lite/ACE/ACE-Lite                                                                                   | VIP-AMBA-ACE-SVT -OR- VIP-AMBA-SVT -OR- VIP-PROTOCOL-SVT -OR- VIP-LIBRARY-SVT + DesignWare-Regression    |
| ATB/APB2/APB3/APB4/AHB2/AHB3/AH<br>B5/AHB-Lite/AHB-Multilayer/AXI4-<br>Stream/AXI3/AXI4/AXI4-Lite/ACE/ACE-<br>Lite | VIP-AMBA-SVT -OR- VIP-PROTOCOL-SVT -OR- VIP-LIBRARY-SVT + DesignWare-Regression                          |

The following is the description of license consumption for each license type:

- VIP-AMBA-ATB-SVT, VIP-AMBA-APB-SVT, VIP-AMBA-AHB-SVT, VIP-AMBA-STREAM-SVT, VIP-AMBA-AXI-SVT, VIP-AMBA-ACE-SVT: Single license enables multiple instances of any of AHB/APB/AXI/ACE/ATB/AXI4-STREAM VIP in a single simulation session.
- **❖** VIP-AMBA-SVT: Single license enables multiple instances of AMBA VIP in a single simulation session.
- ❖ VIP-PROTOCOL-SVT: Single license enables multiple instances of a single protocol suite of VIP in a single simulation session. Multiple licenses required to enable multiple VIP protocol suites in a single simulation session or multiple simultaneous simulation sessions.
- **❖** VIP-SOC-LIBRARY-SVT
- **❖** VIP-LIBRARY-SVT + DesignWare-Regression: Single license enables multiple instances of any number of protocol suites in a single simulation session.

The licensing key must reside in files that are indicated by specific environment variables. For more information about setting these licensing environment variables, see "Environment Variable and Path Settings" on page 21.

#### 2.5.1.0.1 License Polling

If you request a license and none are available, license polling allows your request to exist until a license becomes available instead of exiting immediately. To control license polling, you use the DW WAIT LICENSE environment variable as follows:

- ❖ To enable license polling, set the DW\_WAIT\_LICENSE environment variable to 1.
- **❖** To disable license polling, unset the DW\_WAIT\_LICENSE environment variable. By default, license polling is disabled.

#### 2.5.1.0.2 Simulation License Suspension

All Synopsys Verification IP products support license suspension. Simulators that support license suspension allow a model to check in its license token while the simulator is suspended, then check the license token back out when the simulation is resumed.



This capability is simulator-specific; not all simulators support license check-in during suspension.

#### 2.5.2 Environment Variable and Path Settings

The following are environment variables and path settings required by the AXI VIP verification models:

- ❖ DESIGNWARE\_HOME: The absolute path to where the VIP is installed.
- **❖** DW\_LICENSE\_FILE The absolute path to file that contains the license keys for the VIP product software or the port@host reference to this file.
- SNPSLMD\_LICENSE\_FILE: The absolute path to file(s) that contains the license keys for Synopsys software (VIP and/or other Synopsys Software tools) or the port@host reference to this file.

#### **Note**

For faster license checkout of Synopsys VIP software please ensure to place the desired license files at the front of the list of arguments to <code>SNPSLMD\_LICENSE\_FILE</code>.

**❖** LM\_LICENSE\_FILE: The absolute path to a file that contains the license keys for both Synopsys software and ∕or your third-party tools.

## Note

The Synopsys VIP License can be set in either of the 3 license variables mentioned above with the order of precedence for checking the variables being:

❖ DW\_LICENSE\_FILE -> SNPSLMD\_LICENSE\_FILE -> LM\_LICENSE\_FILE, but also note If DW\_LICENSE\_FILE environment variable is enabled, VIP will ignore SNPSLMD\_LICENSE\_FILE and LM\_LICENSE\_FILE settings.

Hence to get the most efficient Synopsys VIP license checkout performance, set the DW\_LICENSE\_FILE with only the License servers which contain Synopsys VIP licenses. Also, include the absolute path to the third party executable in your PATH variable.

#### 2.5.2.1 Simulator-Specific Settings

Your simulation environment and PATH variables must be set as required to support your simulator.

#### 2.5.3 Determining Your Model Version

The following steps tell you how to check the version of the models you are using.



Verification IP products are released and versioned by the suite and not by individual model. The version number of a model indicates the suite version.

- ❖ To determine the versions of VIP models installed in your \$DESIGNWARE\_HOME tree, use the setup utility as follows:
  - % \$DESIGNWARE\_HOME/bin/dw\_vip\_setup -i home
- ❖ To determine the versions of VIP models in your design directory, use the setup utility as follows:
  - % \$DESIGNWARE\_HOME/bin/dw\_vip\_setup -p design\_dir\_path -i design

#### 2.5.4 Integrating the VIP into Your Testbench

After installing the VIP, follow these procedures to set up VIP for use in testbenches:

- "Creating a Testbench Design Directory"
- "Setting Up a New VIP"
- "Installing and Setting Up More than One VIP Protocol Suite"
- "Updating an Existing Model"
- "Removing Synopsys VIP Models from a Design Directory"
- "Reporting Information About DESIGNWARE\_HOME or a Design Directory"
- "The dw\_vip\_setup Utility"

#### 2.5.4.1 Creating a Testbench Design Directory

A *design directory* contains a version of VIP that is set up and ready for use in a testbench. You use the dw\_vip\_setup utility to create design directories. For full description of dw\_vip\_setup, see the "The dw\_vip\_setup Utility" on page 27.



If you move a design directory, the references in your testbenches to the include files will need to be revised to point to the new location. Also, any simulation scripts in the examples directory will need to be recreated.

A design directory gives you control over the version of Synopsys VIP in your testbench because it is isolated from the DESIGNWARE\_HOME installation. When you want, you can use dw\_vip\_setup to update the VIP in your design directory. Figure 2-2 shows this process and the contents of a design directory.

Figure 2-2 Design Directory Created by dw\_vip\_setup



A design directory contains:

**examples** Each VIP includes example testbenches. The dw vip setup utility adds them

in this directory, along with a script for simulation. If an example testbench is specified on the command line, this directory contains all files required for

model, suite, and system testbenches.

include Language-specific include files that contain critical information for VIP

models. This directory is specified in simulator command lines.

src VIP-specific include files (not used by all VIPs). This directory may be

specified in simulator command lines.

.dw\_vip.cfg A database of all VIP models being used in the testbench. The dw\_vip\_setup

program reads this file to rebuild or recreate a design setup.



Do not modify this file because dw vip setup depends on the original contents.



When using a design\_dir, you have to make sure that the DESIGNWARE\_HOME that was used to setup the design\_dir is the same one used in the shell when running the simulation.

In other words when using a design\_dir, you have to make sure that the SVT version identified in the design\_dir is available in the DESIGNWARE\_HOME used in the shell when running the simulation.

#### 2.5.4.2 Setting Up a New VIP

After you have installed the VIP, you must set up the VIP for project and testbench use. All VIP suites contain various components such as transceivers, masters, slaves, and monitors depending on the protocol. The setup process gathers together all the required component files you need to incorporate into your testbench required for simulation runs.

You have the choice to set up all of them, or only specific ones. For example, the AXI VIP contains the following components.

- axi\_system\_env\_svt
- axi\_master\_agent\_svt
- axi\_slave\_agent\_svt
- axi\_interconnect\_env\_svt



1. UVM users are expected to set the value of UVM\_PACKER\_MAX\_BYTES macro to 1500000 on command line. If you are a UVM user, add the following to your command line: +define+UVM\_PACKER\_MAX\_BYTES=1500000. Else, AXI VIP will issue a fatal error.

2. UVM users are required to define the UVM macro UVM\_DISABLE\_AUTO\_ITEM\_RECORDING. AXI

2. UVM users are required to define the UVM macro UVM\_DISABLE\_AUTO\_ITEM\_RECORDING. AXI being a pipelined protocol (that is, previous transaction does not necessarily need to complete before starting new transaction), AXI VIP handles triggering the begin/end events and transaction recording. AXI VIP does not use the UVM automatic transaction begin/end event triggering and recording feature. If UVM\_DISABLE\_AUTO\_ITEM\_RECORDING is not defined, VIP issues a FATAL message.

You can set up either an individual component, or the entire set of components within one protocol suite. Use the Synopsys provided tool called dw\_vip\_setup for these tasks. It resides in \$DESIGNWARE\_HOME/bin.

To get help on dw\_vip\_setup, invoke the following:

```
% $DESIGNWARE_HOME/bin/dw_vip_setup --help
```

The following command adds a model to the directory design\_dir.

```
% $DESIGNWARE_HOME/bin/dw_vip_setup -path /tmp/design_dir -add axi_system_env_svt
-svloq
```

This command sets up all the required files in /tmp/design\_dir.

The utility dw\_vip\_setup creates three directories under design\_dir which contain all the necessary model files. Files for every VIP are included in these three directories.

- \* examples: Each VIP includes example testbenches. The dw\_vip\_setup utility adds them in this directory, along with a script for simulation. If an example testbench is specified on the command line, this directory contains all files required for model, suite, and system testbenches.
- include: Language-specific include files that contain critical information for Synopsys models. This directory include/sverilog is specified in simulator commands to locate model files.
- src: Synopsys-specific include files This directory src/sverilog/vcs must be included in the simulator command to locate model files.

Note that some components are top level and will setup the entire suite. You have the choice to set up the entire suite, or just one component such as a monitor.



There *must* be only one design\_dir installation per simulation, regardless of the number of Synopsys Verification and Implementation IPs you have in your project. Do create this directory in \$DESIGNWARE\_HOME.

#### 2.5.4.3 Installing and Setting Up More than One VIP Protocol Suite

All VIPs for a particular project must be set up in a single common directory once you execute the \*.run file. You may have different projects. In this case, the projects can use their own VIP setup directory. However, all the VIPs used by that specific project must reside in a common directory.

The examples in this chapter call that directory as design\_dir, but you can use any name.

In this example, assume you have the AXI suite set up in the design\_dir directory. In addition to the AXI VIP, you require the Ethernet and USB VIP suites.

First, follow the previous instructions on downloading and installing the Ethernet VIP and USB suites.

Once installed, the Ethernet and USB suites must be set up in and located in the same <code>design\_dir</code> location as AMBA. Use the following commands:

```
// First install AXI.
%unix> $DESIGNWARE_HOME/bin/dw_vip_setup -path /tmp/design_dir
-add axi_system_env_svt -svlog

//Add Ethernet to the same design_dir as AXI.
%unix> $DESIGNWARE_HOME/bin/dw_vip_setup -path /tmp/design_dir
-add ethernet_system_env_svt -svlog

// Add USB to the same design_dir as AMBA and Ethernet
%unix> $DESIGNWARE_HOME/bin/dw_vip_setup -path /tmp/design_dir
-add usb system env svt -svlog
```

To specify other model names, consult the VIP documentation.

By default, all of the VIPs use the latest installed version of SVT. Synopsys maintains backward compatibility with previous versions of SVT. As a result, you may mix and match models using previous versions of SVT.

#### 2.5.4.4 Updating an Existing Model

To add and update an existing model, do the following:

- 1. Install the model to the same location at which your other VIPs are present by setting the \$DESIGNWARE\_HOME environment variable.
- 2. Issue the following command using design dir as the location for your project directory.

```
%unix> $DESIGNWARE_HOME/bin/dw_vip_setup -path /tmp/design_dir
-add axi_master_agent_svt -svlog
```

3. You can also update your design dir by specifying the version number of the model.

```
%unix> dw_vip_setup -path design_dir -add axi_master_agent_svt -v 3.50a -svlog
```

#### 2.5.4.5 Removing Synopsys VIP Models from a Design Directory

This example shows how to remove all listed models in the design directory at "/d/test2/daily" using the model list in the file "del\_list" in the scratch directory under your home directory. The dw\_vip\_setup program command line is:

```
% $DESIGNWARE_HOME/bin/dw_vip_setup -p /d/test2/daily -r -m ~/scratch/del_list
```

The models in the *del\_list* file are removed, but object files and include files are not.

#### 2.5.4.6 Reporting Information About DESIGNWARE\_HOME or a Design Directory

In these examples, the setup program sends output to STDOUT.

The following example lists the Synopsys VIP libraries, models, example testbenches, and license version in a DESIGNWARE HOME installation:

```
% $DESIGNWARE_HOME/bin/dw_vip_setup -i home
```

The following example lists the VIP libraries, models, and license version in a testbench design directory:

% \$DESIGNWARE\_HOME/bin/dw\_vip\_setup -p design\_dir -i design

#### 2.5.4.7 Getting Help on Example Run/make Scripts

You can get help on the generated make/run scripts in the following ways:

1. Invoke the run script with no switches, as in:

```
run_axi_svt_uvm_basic_sys --help
```

usage: run\_axi\_svt\_uvm\_basic\_sys [-32] [-verbose] [-debug\_opts] [-waves] [-clean] [-nobuild] [-buildonly] [-norun] [-pa] <scenario> <simulator>

where <scenario> is one of: all axi\_slave\_mem\_diff\_data\_width\_response\_test axi\_unaligned\_backdoor\_write\_read\_test base\_test config\_creator\_test directed\_4kboundary\_test directed\_test directed\_write\_read\_data\_cehck\_wysiwyg\_enable\_test random\_wr\_rd\_test reorder wr rd test

<simulator> is one of: vcsmxvlog mtivlog vcsvlog vcszsimvlog vcsscvlog ncvlog vcszebuvlog vcsmxpcvlog vcsvhdl vcsmxpipvlog ncmvlog vcspcvlog

- -32 forces 32-bit mode on 64-bit machines
- -verbose enable verbose mode during compilation
- -debug\_opts enable debug mode for VIP technologies that support this option
- -waves  $\quad \text{[fsdb | verdi | dve | dump] enables waves dump and optionally opens viewer (VCS only)}$ 
  - -seed run simulation with specified seed value
  - -clean clean simulator generated files
  - -nobuild skip simulator compilation
  - -buildonly exit after simulator build
  - -norun only echo commands (do not execute)
  - -pa invoke Verdi after execution
- 2. Invoke the make file with help switch as in:

#### gmake help

Usage: gmake USE\_SIMULATOR=<simulator> [VERBOSE=1] [DEBUG\_OPTS=1] [SEED=<value>] [FORCE\_32BIT=1] [WAVES=fsdb | verdi | dve | dump] [NOBUILD=1] [BUILDONLY=1] [PA=1] [<scenario> ...]

Valid simulators are: vcsmxvlog mtivlog vcsvlog vcszsimvlog vcsscvlog ncvlog vcszebuvlog vcsmxpcvlog vcsvhdl vcsmxpipvlog ncmvlog vcspcvlog

Valid scenarios are: all axi\_slave\_mem\_diff\_data\_width\_response\_test axi\_unaligned\_backdoor\_write\_read\_test base\_test config\_creator\_test directed\_4kboundary\_test directed\_test directed\_write\_read\_data\_cehck\_wysiwyg\_enable\_test random\_wr\_rd\_test reorder\_wr\_rd\_test

#### **Note**

You must have PA installed if you use the -pa or PA=1 switches.

#### 2.5.4.8 The dw\_vip\_setup Utility

The dw\_vip\_setup utility:

- ❖ Adds, removes, or updates AXI VIP models in a design directory.
- Adds example testbenches to a design directory, the AXI VIP models they use (if necessary), and creates a script for simulating the testbench using any of the supported simulators.
- Restores (cleans) example testbench files to their original state.
- \* Reports information about your installation or design directory, including version information.
- Supports Protocol Analyzer (PA).
- Supports the FSDB wave format.

#### 2.5.4.8.1 Setting Environment Variables

Before running dw\_vip\_setup, the following environment variables must be set:

❖ DESIGNWARE\_HOME - Points to where the Synopsys VIP is installed

#### 2.5.4.8.2 The dw\_vip\_setup Command

You invoke dw\_vip\_setup from the command prompt. The dw\_vip\_setup program checks command line argument syntax and makes sure that the requested input files exist.

The general form of the command is:

Table 2-2 Setup Program Switch Descriptions

| Switch                                   | Description                                                                                                                                                                             |
|------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -a[dd] ( model<br>[-v[ersion] version] ) | Adds the specified model or models to the specified design directory or current working directory. If you do not specify a version, the latest version is assumed. The model names are: |
|                                          | axi_master_agent_svt                                                                                                                                                                    |
|                                          | axi_slave_agent_svt                                                                                                                                                                     |
|                                          | axi_interconnect_env_svt                                                                                                                                                                |
|                                          | axi_system_env_svt                                                                                                                                                                      |
|                                          | The -add switch causes dw_vip_setup to build suite libraries from the same suite as the specified models, and to copy the other necessary files from \$DESIGNWARE_HOME.                 |

Table 2-2 Setup Program Switch Descriptions (Continued)

| Switch                                                      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -r[emove] model                                             | Removes <i>all versions</i> of the specified model or models from the design. The dw_vip_setup program does not attempt to remove any include files used solely by the specified model or models. The model names are:  • axi_master_agent_svt  • axi_slave_agent_svt  • axi_interconnect_env_svt  • axi_system_env_svt                                                                                                                                             |
| -u[pdate] ( model [-v[ersion] version] )                    | Updates to the specified model version for the specified model or models. The dw_vip_setup script updates to the latest models when you do not specify a version. The model names are:  • axi_master_agent_svt  • axi_slave_agent_svt  • axi_interconnect_env_svt  • axi_system_env_svt  The -update switch causes dw_vip_setup to build suite libraries from the same suite as the specified models, and to copy the other necessary files from \$DESIGNWARE_HOME. |
| -e[xample] {scenario   model/scenario} [-v[ersion] version] | The dw_vip_setup script configures a testbench example for a single model or a system testbench for a group of models. The program creates a simulator run program for all supported simulators.  If you specify a <i>scenario</i> (or system) example testbench, the models needed for the testbench are included automatically and do not need to be specified in the command.  Note: Use the -info switch to list all available system examples.                 |
| -ntb                                                        | Not supported.                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| -svtb                                                       | Use this switch to set up models and example testbenches for SystemVerilog UVM. The resulting design directory is streamlined and can only be used in SystemVerilog simulations.                                                                                                                                                                                                                                                                                    |
| -c[lean] {scenario   model/scenario}                        | Cleans the specified scenario/testbench in either the design directory (as specified by the <i>-path</i> switch) or the current working directory. This switch deletes <i>all files in the specified directory</i> , then restores all Synopsys created files to their original contents.                                                                                                                                                                           |

Table 2-2 Setup Program Switch Descriptions (Continued)

| Switch                                                                                          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -i/nfo design   home[: <pre>product&gt;[:<version>[:<meth odology="">]]]</meth></version></pre> | Generate an informational report on a design directory or VIP installation. design: If the '-info design' switch is specified, the tool displays product and version content within the specified design directory to standard output. This output can be captured and used as a modellist file for input to this tool to create another design directory with the same content. home: If the '-info home' switch is specified, the tool displays product, version, and example content within the VIP installation to standard output. Optional filter fields can also be specified such as <pre>product</pre> , <version< p="">, and <methodology< p="">&gt;&gt; delimited by colons (:). An error will be reported if a nonexistent or invalid filter field is specified. Valid methodology names include: OVM, RVM, UVM, VMM and VLOG.</methodology<></version<> |
| -h[elp]                                                                                         | Returns a list of valid dw_vip_setup switches and the correct syntax for each.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| model                                                                                           | Synopsys AXI VIP models are:  • axi_master_agent_svt  • axi_slave_agent_svt  • axi_interconnect_env_svt  • axi_system_env_svt  The model argument defines the model or models that dw_vip_setup acts upon. This argument is not needed with the -info or -help switches. All switches that require the model argument may also use a model list. You may specify a version for each listed model, using the -version option. If omitted, dw_vip_setup uses the latest version. The -update switch ignores model version information.                                                                                                                                                                                                                                                                                                                                 |
| -b/ridge                                                                                        | Updates the specified design directory to reference the current DESIGNWARE_HOME installation. All product versions contained in the design directory must also exist in the current DESIGNWARE_HOME installation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| -ра                                                                                             | Enables the run scripts and Makefiles generated by dw_vip_setup to support PA. If this switch is enabled, and the testbench example produces XML files, PA will be launched and the XML files will be read at the end of the example execution.  For run scripts, specify -pa.  For Makefiles, specify -pa = 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| -waves                                                                                          | Enables the run scripts and Makefiles generated by dw_vip_setup to support the fsdb waves option . To support this capability, the testbench example must generate an FSDB file when compiled with the WAVES Verilog macro set to fsdb, that is, +define+WAVES=\"fsdb\". If a .fsdb file is generated by the example, the Verdi nWave viewer will be launched.  For run scripts, specify -waves fsdb.  For Makefiles, specify WAVES=fsdb.                                                                                                                                                                                                                                                                                                                                                                                                                            |

Table 2-2 Setup Program Switch Descriptions (Continued)

| Switch                             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -doc                               | Creates a doc directory in the specified design directory which is populated with symbolic links to the DESIGNWARE_HOME installation for documents related to the given model or example being added or updated.                                                                                                                                                                                                                                                                      |
| -methodology <name></name>         | When specified with -doc, only documents associated with the specified methodology name are added to the design directory. Valid methodology names include: OVM, RVM, UVM, VMM, and VLOG.                                                                                                                                                                                                                                                                                             |
| -сору                              | When specified with -doc, documents are copied into the design directory, not linked.                                                                                                                                                                                                                                                                                                                                                                                                 |
| -s/uite_list <filename></filename> | Specifies a file name which contains a list of suite names to be added, updated or removed in the design directory. This switch is valid only when following an operation switch, such as, -add, -update, or -remove. Only one suite name per line and each suite may include a version selector. The default version is 'latest'. This switch is optional, but if given the filename argument is required. The lines in the file starting with the pound symbol (#) will be ignored. |
| -m/odel_list <filename></filename> | Specifies a file name which contains a list of model names to be added, updated or removed in the design directory. This switch is valid only when following an operation switch, such as, -add, -update, or -remove. Only one model name per line and each model may include a version selector. The default version is 'latest'. This switch is optional, but if given the filename argument is required. The lines in the file starting with the pound symbol (#) will be ignored. |
| -simulator <vendor></vendor>       | When used with the <code>-example</code> switch, only simulator flows associated with the specified vendor are supported with the generated run script and Makefile. <b>Note</b> : Currently the vendors VCS, MTI, and NCV are supported.                                                                                                                                                                                                                                             |



The dw\_vip\_setup program treats all lines beginning with "#" as comments.

For more information on installing and running SystemVerilog UVM example testbenches, see the "SystemVerilog UVM Example Testbenches" and "Installing and Running the Examples" sections.

#### 2.5.5 Include and Import Model Files into Your Testbench

After you set up the models, you must include and import various files into your top testbench files to use the VIP.

Following is a code list of the includes and imports for components within amba\_system\_env\_svt:

```
/* include uvm package before VIP includes, If not included elsewhere*/
`include "uvm_pkg.sv"

/* include AXI , AHB and APB VIP interface */
`include "svt_ahb_if.svi"

`include "svt_axi_if.svi"
```

```
`include "svt_apb_if.svi"

/** Include the AMBA SVT UVM package */
  include "svt_amba.uvm.pkg"

/** Import UVM Package */
  import uvm_pkg::*;

/** Import the SVT UVM Package */
  import svt_uvm_pkg::*;

/** Import the AMBA VIP */
  import svt_amba_uvm_pkg::*;
```

You must also include various VIP directories on the simulator command line. Add the following switches and directories to all the compile scripts:

- +incdir+<design\_dir>/include/verilog
- +incdir+<design\_dir>/include/sverilog
- +incdir+<design\_dir>/src/verilog/<vendor>
- +incdir+<design\_dir>/src/sverilog/<vendor>

Supported vendors are VCS, MTI and NCV. For example:

```
+incdir+<design dir>/src/sverilog/vcs
```

Using the previous examples, the directory <design\_dir> would be /tmp/design\_dir.

#### 2.5.6 Compile and Run Time Options

Every Synopsys provided example has ASCII files containing compile and run time options. The examples for the model are located in:

\$DESIGNWARE\_HOME/vip/svt/<model>/latest/examples/sverilog/<example\_name>

The files containing the options are:

- sim\_build\_options (contain compile time options common for all simulators)
- sim\_run\_options (contain run time options common for all simulators)
- vcs\_build\_options (contain compile time options for VCS)
- vcs run options (contain run time options for VCS)
- mti\_build\_options (contain compile time options for MTI)
- mti\_run\_options (contain run time options for MTI)
- ncv\_build\_options (contain compile time options for IUS)
- ncv run options (contain run time options for IUS)

These files contain both optional and required switches. For AXI VIP, following are the contents of each file, listing optional and required switches:

```
vcs_build_options:
```

```
Required: +define+UVM_PACKER_MAX_BYTES=1500000

Required: +define+UVM_DISABLE_AUTO_ITEM_RECORDING
Optional: -timescale=1ns/1ps
Required: +define+SVT <model> INCLUDE USER DEFINES
```

Installation and Setup

VC VIP AMBA AXI

UVM User Guide



UVM\_PACKER\_MAX\_BYTES define needs to be set to maximum value as required by each VIP title in your testbench. For example, if VIP title 1 needs UVM\_PACKER\_MAX\_BYTES to be set to 8192, and VIP title 2 needs UVM\_PACKER\_MAX\_BYTES to be set to 500000, you need to set UVM\_PACKER\_MAX\_BYTES to 500000.

vcs\_run\_options:

Required: +UVM\_TESTNAME=\$scenario



The "scenario" is the UVM test name you pass to VCS.

3

# **General Concepts**

This chapter describes the usage of AXI VIP in an UVM environment, and it's user interface. This chapter discusses the following topics:

- **❖** "Introduction to UVM" on page 33
- "AXI VIP in an UVM Environment" on page 34
- "AXI UVM User Interface" on page 56
- "Functional Coverage" on page 79
- "Protocol Checks" on page 82
- "Reset Functionality" on page 87
- "Support for ACE Protocol in AXI Master Agent" on page 88
- "Support for ACE-Lite Protocol in AXI Slave Agent" on page 98
- "Support for ACE protocol in AXI Interconnect Env" on page 98
- "AXI4 Region and Address Range Support in Slave" on page 99

#### 3.1 Introduction to UVM

UVM is an object-oriented approach. It provides a blueprint for building testbenches using constrained random verification. The resulting structure also supports directed testing.

This chapter describes the usage of AXI VIP in UVM environment, and its user interface. See the Class Reference HTML for a description of attributes and properties of the objects mentioned in this chapter.

This chapter assumes that you are familiar with SystemVerilog and UVM. For more information:

- ❖ For the IEEE SystemVerilog standard, see:
  - ◆ IEEE Standard for SystemVerilog—Unified Hardware Design, Specification, and Verification Language
- For essential guides describing UVM as it is represented in SystemVerilog, along with a class reference, see:
  - ◆ Universal Verification Methodology (UVM) 1.0 User's Manual at: http://www.accellera.org/.

#### 3.2 AXI VIP in an UVM Environment

The following sections describe these components.

#### 3.2.1 Master Agent

The Master Agent encapsulates Master Sequencer, Master Driver, and Port Monitor. The Master Agent can be configured to operate in active mode and passive mode. You can provide AXI sequences to the Master Sequencer.

The Master Agent is configured using a port configuration, which is available in the system configuration. The port configuration should be provided to the Master Agent in the build phase of the test.

Within the Master Agent, the Master Driver gets sequences from the Master Sequencer. The Master Driver then drives the AXI transactions on the AXI port. The Master Driver and port Monitor components within Master Agent call callback methods at various phases of execution of the AXI transaction. Details of callbacks are covered in later sections. After the AXI transaction on the bus is complete, the completed sequence item is provided to the analysis port of Port Monitor for use by the testbench.

Figure 3-1 Usage With Standalone Master Agent



#### 3.2.2 Slave Agent

The Slave Agent encapsulates Slave Sequencer, Slave Driver, and Port Monitor. The Slave Agent can be configured to operate in active mode and passive mode. You can provide AXI response sequences to the Slave Sequencer.

The Slave Agent is configured using port configuration, which is available in the system configuration. The port configuration should be provided to the Slave Agent in the build phase of the test or the testbench environment.

In the Slave Agent, the Port Monitor samples the AXI port signals. When a new transaction is detected, the Port Monitor provides a response request sequence item to the Slave Sequencer through port response\_request\_port. The slave response sequence within the sequencer programs the appropriate slave response. The updated response sequence item is then provided by the Slave Sequencer to the Slave Driver. The Slave Driver in turn drives the response on the AXI bus.



The slave driver expects the slave response sequence to,

- Return same handle of the slave response object as provided to the sequencer by the port monitor
- Return the slave response object in zero time, that is, without any delay after sequencer receives object from the port monitor

If any of the above conditions is violated, the slave agent issues a FATAL message.

The Slave Driver and Monitor call callback methods at various phases of execution of the AXI transaction. Details of callbacks are covered in later sections. After the AXI transaction on the bus is complete, the completed sequence item is provided to the analysis port for use by the testbench.

Figure 3-2 Usage With Standalone Slave Agent



#### 3.2.3 Stimulus Modeling

#### 3.2.3.1 Stimulus Modeling at Master

The svt\_axi\_master\_transaction is the basic master transaction description class, which depicts a transaction that has to be generated on the master interface. The class provides rich set of attributes such as address, burst type etc. The class contains transaction level attributes which can be directly mapped to

interface signals (for example, addr, burst\_type burst\_lenth), transaction configuration attributes (for example, data\_before\_addr) and delay configurations on the master side (for example, addr\_valid\_delay, and bready\_delay). The Master transaction constraint take into account the configuration set for the master agent while randomizing the class instances in order to ensure that attributes are within its configured bounds. Some of the commonly used master transaction class attributes are listed below.

- xact\_type: Specifies the transaction types as READ or WRITE
- addr: Specifies the address for the transaction
- burst\_type: Specifies burst type as INCR/FIXED/WRAP
- burst\_size: Specifies maximum number of bytes to be transfered in each data transfer.
- addr\_valid\_delay: Specifies the number of cycles AWVALID/ARVALID signal is delayed.
- burst\_length: Specifies the number of beats in the burst
- \* data before addr: Indicates that data will start before address for write transactions
- \* reference\_event\_for\_addr\_valid\_delay: Specifies the reference event from which addr\_valid\_delay should begin.

For complete list of master transaction class attributes, see the class reference HTML document.

#### 3.2.3.2 Master VIP Sequence Examples

Sample master sequence using some of the common attributes are given as follows. You can use 'svt\_axi\_master\_base\_sequence' base class to create their sequences.

#### **Example 1: Master Directed Sequence**

This sequence allows you to write directed test cases for specific scenarios. You have to explicitly specify all relevant master transaction attributes here as the transaction object is not randomized in this sequence.

```
class axi_master_directed_sequence extends svt_axi_master_base_sequence;

/** Parameter that controls the number of transactions that will be generated */
rand int unsigned sequence_length = 10;

/** Constrain the sequence length to a reasonable value */
constraint reasonable_sequence_length {
    sequence_length <= 100;
}

/** UVM Object Utility macro */
    `uvm_object_utils(axi_master_directed_sequence)

/** Class Constructor */
function new(string name="axi_master_directed_sequence");
    super.new(name);
endfunction</pre>
```

```
virtual task body();
    svt_axi_master_transaction write_tran, read_tran;
    svt_configuration get_cfg;
    bit status;
    `uvm_info("body", "Entered ...", UVM_LOW)

    super.body();

    status = uvm_config_db #(int unsigned)::get(null, get_full_name(),
    "sequence_length", sequence_length);
    `uvm_info("body", $sformatf("sequence_length is %0d as a result of %0s.",
    sequence_length, status ? "config DB" : "randomization"), UVM_LOW);

/** Obtain a handle to the port configuration */
    /*
```

In case of directed sequence, port configuration handle need to obtain explicitly, whereas in case of random sequence this is done implicitly while randomizing the transaction class with uvm\_do macro.

```
* /
   p_sequencer.get_cfg(get_cfg);
    if (!$cast(cfg, get_cfg)) begin
      `uvm_fatal("body", "Unable to $cast the configuration to a
svt_axi_port_configuration class");
    end
    for(int i = 0; i < sequence_length; i++) begin</pre>
      /** Set up the write transaction */
      `uvm_create(write_tran)
      write_tran.port_cfg
                             = cfq;
      write_tran.xact_type
                              = svt_axi_transaction::WRITE;
                              = 32'h0000_0100 | ('h100 << i);
      write_tran.addr
      write_tran.burst_type
                              = svt_axi_transaction::INCR;
                              = svt_axi_transaction::BURST_SIZE_32BIT;
      write_tran.burst_size
      write_tran.atomic_type = svt_axi_transaction::NORMAL;
      write_tran.burst_length = 4;
      write tran.data
                              = new[write_tran.burst_length];
      write_tran.wstrb
                              = new[write_tran.burst_length];
     write tran.data user
                              = new[write_tran.burst_length];
      foreach (write tran.data[i]) begin
        write_tran.data[i] = i;
      end
```

```
foreach(write_tran.wstrb[i]) begin
   write_tran.wstrb[i] = 4'hf;
  end
  write tran.wvalid delay = new[write tran.burst length];
  foreach (write tran.wvalid delay[i]) begin
   write tran.wvalid delay[i]=i;
  end
  /** Send the write transaction */
  `uvm_send(write_tran)
  /** Wait for the write transaction to complete */
  get_response(rsp);
  /** Set up the read transaction */
  `uvm create(read tran)
  read tran.port cfg
                        = cfq;
  read_tran.xact_type
                        = svt_axi_transaction::READ;
  read_tran.addr
                         = 32'h0000_0100 | ('h100 << i);
  read_tran.burst_type
                         = svt_axi_transaction::INCR;
  read_tran.burst_size
                         = svt_axi_transaction::BURST_SIZE_32BIT;
  read_tran.atomic_type = svt_axi_transaction::NORMAL;
  read tran.burst length = 4;
 read_tran.rresp
                         = new[read_tran.burst_length];
 read tran.data
                         = new[read tran.burst length];
 read_tran.rready_delay = new[read_tran.burst_length];
  read_tran.data_user
                      = new[read_tran.burst_length];
  foreach (read_tran.rready_delay[i]) begin
   read_tran.rready_delay[i]=i;
  end
  /** Send the read transaction */
  `uvm_send(read_tran)
  /** Wait for the read transaction to complete */
 get_response(rsp);
end
`uvm_info("body", "Exiting...", UVM_LOW)
```

```
endtask: body
endclass: axi_master_directed_sequence
```

Master agent has is\_valid check, which checks the transaction programming against protocol specification. So, if transaction attributes are programmed incorrectly, then is\_valid check will issue a UVM\_WARNING indicating the issue and the test will fail with UVM\_FATAL due to 'is\_valid' check failure.

#### Example 1:

The following UVM\_WARNING and UVM\_FATAL are reported when the interface type is configured as AXI3 and the burst\_length is 17 for an INCR burst as this is not allowed as per AXI3 protocol.

UVM\_WARNING @ 1025000: reporter [is\_valid] Invalid burst\_length of 17 provided, must be inside { 1:16 } based on interface type(AXI3), xact\_type(WRITE) and `SVT\_AXI3\_MAX\_BURST\_LENGTH(16)

UVM\_FATAL @ 1025000: uvm\_test\_top.env.axi\_system\_env.master[0] [add\_to\_master\_active] {OBJECT\_NUM(100000) PORT\_ID(0) TYPE(WRITE) ID(0) ADDR(100)} Master Transaction is\_valid check failed.

## **Example 2: Master Random Sequence**

This sequence randomizes the transaction class attributes as per the master transaction class constrains. You can specify inline constraints in the sequence if required. Remaining attributes will be assigned with applicable values as per the protocol constraints.

```
class axi_master_wr_rd_sequence extends svt_axi_master_base_sequence;
  /** Parameter that controls the number of transactions that will be generated */
  rand int unsigned sequence_length = 10;
  /** Constrain the sequence length to a reasonable value */
  constraint reasonable_sequence_length {
    sequence length <= 100;
  }
  /** UVM Object Utility macro */
  `uvm_object_utils(axi_master_wr_rd_sequence)
  /** Class Constructor */
  function new(string name="axi_master_wr_rd_sequence");
    super.new(name);
  endfunction
  virtual task body();
   bit status:
    `uvm info("body", "Entered ...", UVM LOW)
    super.body();
```

```
status = uvm_config_db #(int unsigned)::get(null, get_full_name(),
"sequence length", sequence length);
    `uvm_info("body", $sformatf("sequence_length is %0d as a result of %0s.",
sequence_length, status ? "config DB" : "randomization"), UVM_LOW);
    repeat (sequence length) begin
      `uvm_do_with(req,
        {
          xact type == svt axi transaction::WRITE;
          data before addr == 0;
        })
      `uvm\_do\_with(req,
        {
          xact_type == svt_axi_transaction::READ;
          data_before_addr == 0;
        })
    end
    `uvm info("body", "Exiting...", UVM LOW)
  endtask: body
endclass: axi master wr rd sequence
```

You can use object\_id field of transaction for transaction tracking. This field is set by VIP for each transaction. Read transaction object\_id start with 0 whereas as write transaction object\_id start with 100000. object\_id will be seen as OBJECT\_NUM in VIP log messages as shown in the example. You can track status related information of a specific transaction using the object\_id/OBJECT\_NUM.

#### **Example:**

UVM\_INFO @ 1025000: uvm\_test\_top.env.axi\_system\_env.master[0] [send\_write\_addr] {OBJECT\_NUM(100000) PORT\_ID(0) TYPE(WRITE) ID(0) ADDR(100)} Driving write address channel signals

UVM\_INFO @ 15125000: uvm\_test\_top.env.axi\_system\_env.master[0] [send\_read\_addr] {OBJECT\_NUM(0) PORT\_ID(0) TYPE(READ) ID(0) ADDR(100)} Driving read address channel signals

UVM\_INFO @ 15175000: uvm\_test\_top.env.axi\_system\_env.slave[0] [sample\_read\_addr\_chan\_signals] {OBJECT\_NUM(0) PORT\_ID(0) TYPE(READ) ID(0) ADDR(100)} Received read address

#### 3.2.3.3 Stimulus Modeling at Slave

The class that describes slave transactions is 'svt\_axi\_slave\_transaction'. Slave generates an object of svt\_axi\_slave\_transaction when a command is received for which response has to be generated. The object defines complete transaction, that is, the command received along with the default response that Slave is configured to generate. Slave transaction class provides attributes to configure the slave response (for

example, rresp[], bresp and data[]) and the delay applicable for the slave response (for example, bvalid\_delay and addr\_ready\_delay). Example for slave transaction class attributes are

- rresp[]: This is a dynamic array which configures slave read response for each beat
- bresp: Configures slave write response
- bvalid\_delay: Configures slave write response delay
- addr\_ready\_delay: Configures the delay on arready assertion.
- enable\_interleave: Enables / Disables interleave
- Interleave\_pattern: Defines the pattern for interleaving

VIP allows you to specify distribution weights for delays with attributes. Attributes <code>ZERO\_DELAY\_wt</code>, <code>SHORT\_DELAY\_wt</code> and <code>LONG\_DELAY\_wt</code> defines the weight used to control distribution of zero delay, short delay and long delay respectively. Example for associated delay is ready signal assertion delay.

For usage details, see axi\_slave\_random\_response\_sequence sequence.

For complete list attributes and details, see the svt\_axi\_slave\_transaction in class reference HTML.

The slave monitor of the AXI Slave agent contains a blocking peek port named response\_request\_imp which gets updated with any requests that target that slave. The slave agent connects this peek port to the slave sequencer which has a blocking peek port named response\_request\_port. Slave sequences must obtain a handle to the request through this port in the sequence, fill in the response information, and then submit this response to the driver through the normal means of sequencer/driver communication.

# 3.2.3.4 Slave VIP Example Sequences

This section demonstrates response generation with slave sequences. These slave sequences are extended from svt\_axi\_slave\_base\_sequence.

#### **Example1: Random Response Sequence**

This sequence generates random response from the slave. For write transactions, data is not written to the slave memory and for read, the response and data are random.

```
class axi_slave_random_response_sequence extends svt_axi_slave_base_sequence;
    svt_axi_slave_transaction resp_req;

/** UVM Object Utility macro */
    `uvm_object_utils(axi_slave_random_response_sequence)

/** Class Constructor */
    function new(string name="axi_slave_random_response_sequence");
        super.new(name);
    endfunction

virtual task body();
    `uvm_info("body", "Entered ...", UVM_LOW)
```

```
forever begin
/**
       * Get the response request from the slave sequencer. The response request is
       * provided to the slave sequencer by the slave port monitor, through
       * TLM port.
       * /
      p_sequencer.response_request_port.peek(resp_req);
      $cast(req,resp_req);
      req.ZERO_DELAY_wt = 10;
       req.SHORT_DELAY_wt = 20;
       req.LONG_DELAY_wt = 100;
       * Demonstration of response randomization with constraints.
       * /
      `uvm_rand_send_with(req,
           foreach(rresp[i]) {
            rresp[i] inside { svt_axi_transaction::SLVERR, svt_axi_transaction::OKAY };
           bresp inside { svt_axi_transaction::SLVERR,svt_axi_transaction::OKAY };
         })
   end
    `uvm_info("body", "Exiting...", UVM_LOW)
 endtask: body
endclass: axi_slave_random_response_sequence
```

#### **Example2: Memory Sequence**

This sequence makes use of slave VIP memory. Data is written to and read back from the actual slave memory using the methods put\_write\_transaction\_data\_to\_mem and get\_read\_data\_from\_mem\_to\_zltransaction respectively. These methods are defined in the parent sequence - svt\_axi\_slave\_base\_sequence.

```
class axi_slave_mem_response_sequence extends svt_axi_slave_base_sequence;
  svt_axi_slave_transaction req_resp;
  /** UVM Object Utility macro */
  `uvm_object_utils(axi_slave_mem_response_sequence)
  /** Class Constructor */
  function new(string name="axi_slave_mem_response_sequence");
    super.new(name);
  endfunction
  virtual task body();
    integer status;
    svt_configuration get_cfg;
    `uvm_info("body", "Entered ...", UVM_LOW)
   p_sequencer.get_cfg(get_cfg);
    if (!$cast(cfg, get_cfg)) begin
      `uvm_fatal("body", "Unable to $cast the configuration to a
svt_axi_port_configuration class");
    end
    forever begin
      /**
       * Get the response request from the slave sequencer. The response request is
       * provided to the slave sequencer by the slave port monitor, through
       * TLM port.
       * /
     p_sequencer.response_request_port.peek(req_resp);
      /**
       * Randomize the response and delays
       * /
      status=req_resp.randomize with {
       bresp == svt_axi_slave_transaction::OKAY;
        foreach (rresp[index]) {
          rresp[index] == svt_axi_slave_transaction::OKAY;
          }
       };
```

```
if(!status)
        `uvm_fatal("body","Unable to randomize a response")
       * If write transaction, write data into slave built-in memory, else get
       * data from slave built-in memory
       * /
      if(req_resp.xact_type == svt_axi_slave_transaction::WRITE) begin
        put_write_transaction_data_to_mem(req_resp);
      end
      else begin
        get_read_data_from_mem_to_transaction(req_resp);
      6nd
      $cast(req,req_resp);
      /**
       * send to driver
       * /
      `uvm_send(req)
    end
    `uvm_info("body", "Exiting...", UVM_LOW)
  endtask: body
endclass: axi_slave_mem_response_sequence
```

The object id and OBJECT NUM can be used for slave transaction tracking also.

#### 3.2.3.5 Interconnect VIP Transaction classes

Master and slave ports of interconnect VIP also uses transaction classes. The transaction class used by interconnect VIP slave ports is 'svt\_axi\_ic\_slave\_transaction' whereas master ports uses svt\_axi\_master\_transaction class itself.

# 3.2.3.6 Overriding Master and Slave Transaction Classes

You can override master and slave transaction base classes from test or env class in the build\_phase with custom classes with additional user constraints. Overriding can be done globally and locally using uvm methods 'set\_type\_override\_by\_type' and by 'set\_inst\_override\_by\_type' respectively. The following are the examples:

## **Example:**

```
virtual function void build phase (uvm phase phase);
```

# 7 Note

Master transaction and Slave response will not start until a reset is observed by Master and Slave respectively.

## 3.2.3.7 Setting Valid-Ready Delay Values for Master, Slave, and Interconnect

Three types of delays ZERO (0), SHORT (1:max-1) and LONG (max) are used by VIP for valid-ready delay, and they are applied as weighted constraints in VIP transactions using their respective ZERO\_DELAY/SHORT\_DELAY/LONG\_DELAY\_wt attributes. All such constraints can be found in HTML document with reasonable.\*delay reg\_exp search.

For example, the following are the two-step process on how you can set all delays to '0' value, leveraging VIP transaction provided attribute <code>ZERO\_DELAY\_wt</code>.

#### Step 1:

Create custom factory transactions for applicable VIP components in your testbench with ZERO\_DELAY\_wt=100

```
//Custom factory master transaction , applicable for master agent
cust_svt_axi_master_transaction extends svt_axi_master_transaction;
  `uvm_object_utils(cust_svt_axi_master_transaction)

function new (string name = "cust_svt_axi_master_transaction");
  super.new(name);
  this.ZERO_DELAY_wt = 100;
  this.SHORT_DELAY_wt = 0;
  this.LONG_DELAY_wt = 0;
  endfunction: new
endclass: cust_svt_axi_master_transaction

//Custom factory slave transaction , applicable for slave agent
class cust_svt_axi_slave_transaction;
  `uvm_object_utils(cust_svt_axi_slave_transaction)

function new (string name = "cust_svt_axi_slave_transaction");
```

```
super.new(name);
   this.ZERO_DELAY_wt = 100;
   this.SHORT DELAY wt = 0;
   this.LONG DELAY wt = 0;
 endfunction: new
    endclass: cust_svt_axi_slave_transaction
//Custom factory Interconnect transaction , applicable for interconnect agent
class cust svt axi ic slave transaction extends svt axi ic slave transaction;
  `uvm_object_utils(cust_svt_axi_ic_slave_transaction)
 function new (string name = "cust_svt_axi_ic_slave_transaction");
   super.new(name);
   this.ZERO DELAY wt = 100;
   this.SHORT DELAY wt = 0;
   this.LONG_DELAY_wt = 0;
 endfunction: new
endclass: cust_svt_axi_ic_slave_transaction
```

## Step 2:

Do three factory type-wide replacements in your env/test (or you can apply this to specific instances as applicable)

```
set_type_override_by_type(svt_axi_master_transaction::get_type(),
cust_svt_axi_master_transaction::get_type());
    set_type_override_by_type(svt_axi_slave_transaction::get_type(),
cust_svt_axi_slave_transaction::get_type());
    set_type_override_by_type(svt_axi_ic_slave_transaction::get_type(),
cust_svt_axi_ic_slave_transaction::get_type());
```

# 3.2.4 Slave Memory

AXI VIP provides slave memory represented by class svt\_mem. Slave memory is instantiated in slave agent. In passive mode, the slave agent keeps the memory updated based on the observed data on the bus. This enables the system-level checks in the passive mode. In active mode, the slave memory is updated by the slave sequence.

```
See the slave sequence svt_axi_slave_base_sequence in file 
$DESIGNWARE_HOME/vip/svt/amba_svt/latest/axi_slave_agent_svt/sverilog/src/vcs/svt_axi_s
lave_ sequence_collection.svp. A reference to the slave memory instantiated in the slave agent is
provided in the slave sequence. Using the API of this slave memory, you can read or write into the slave
memory through this base sequence, or sequence extended from this base sequence.
```

For details on svt\_mem and svt\_axi\_slave\_base\_sequence, see the AXI SVT class reference HTML documentation.

## 3.2.4.1 Slave Memory Modeling

#### 3.2.4.2 AXI Slave Memory Modeling

The memory in AXI slave VIP is modeled using the class "svt\_mem". Slave memory is instantiated in slave agent.

In passive mode, the slave agent keeps the memory updated based on the observed data on the bus. For write transactions, the memory is updated based on the observed write data. For read transactions, the

## memory is updated based on the read data. The configuration

svt\_axi\_port\_configuration::memory\_update\_for\_read\_xact\_enable controls the vip behavior. The default value for this configuration is 1, so the memory will be updated for the read transactions it observes. This doesn't enable system check. At any RTL-to-RTL interface, if passive slave VIP is connected, then memory update from the observed traffic facilitate system level data integrity checks across such port.

#### 3.2.4.3 Front Door Access

In active mode, the slave memory is updated by the slave sequence whenever it observes a transaction on the interface. In passive mode, the slave memory is updated by the monitor based on the observed write/read transactions on the interface. This is referred as front door access of slave memory. See the slave sequence svt\_axi\_slave\_base\_sequence in the file:

\$DESIGNWARE\_HOME/vip/svt/amba\_svt/latest/axi\_slave\_agent\_svt/sverilog/src/vcs/svt\_axi\_s lave\_ sequence\_collection.svp. A reference to the slave memory instantiated in the slave agent is provided in the slave sequence. Using the API of this slave memory, you can read or write into the slave memory through this base sequence, or sequence extended from this base sequence.

For more details on svt\_mem and svt\_axi\_slave\_base\_sequencet, see AXI SVT class reference HTML documentation. The usage of these APIs is shown in the axi\_slave\_mem\_response\_sequence that is part of the vip example.

#### **Example:**

The body() of a typical slave sequence looks like below:

```
virtual task body();
    integer status;
    svt_configuration get_cfg;
    `uvm_info("body", "Entered ...", UVM_LOW)
   p_sequencer.get_cfg(get_cfg);
    if (!$cast(cfg, get_cfg)) begin
      `uvm fatal("body", "Unable to $cast the configuration to a
svt axi port configuration class");
    end
    // consumes responses sent by driver
    sink responses();
    forever begin
       * Get the response request from the slave sequencer. The response request is
       * provided to the slave sequencer by the slave port monitor, through
       * TLM port.
       * /
      p_sequencer.response_request_port.peek(req_resp);
```

```
/**
       * Randomize the response and delays
       * /
      status=reg resp.randomize with {
        bresp == svt_axi_slave_transaction::OKAY;
        foreach (rresp[index]) {
          rresp[index] == svt_axi_slave_transaction::OKAY;
       };
       if(!status)
        `uvm_fatal("body","Unable to randomize a response")
      /**
       * If write transaction, write data into slave built-in memory, else get
       * data from slave built-in memory
       * /
      if(req_resp.xact_type == svt_axi_slave_transaction::WRITE) begin
        put_write_transaction_data_to_mem(req_resp);
      end
      else begin
        get_read_data_from_mem_to_transaction(req_resp);
      end
      $cast(req,req_resp);
      /**
       * send to driver
      `uvm_send(req)
    end
    `uvm_info("body", "Exiting...", UVM_LOW)
  endtask: body
The memory is updated from the sequence in the following way:
      if(req_resp.xact_type == svt_axi_slave_transaction::WRITE) begin
       put_write_transaction_data_to_mem(req_resp);
      end
```

```
else begin
  get_read_data_from_mem_to_transaction(req_resp);
end
```

These APIs are part of the slave agent and can be copied over and modified as per the custom requirement. The code related to these APIs is not protected.

axi\_slave\_random\_response\_sequence shown in the vip example does not access the slave memory. The response and data is completely random.

#### 3.2.4.4 Backdoor Access

The slave memory can also be accessed using the back door APIs (not through axi interface) from the testbench. The important APIs are:

```
* read()
* write()
* set_meminit()
* load_mem()
* save_mem()
* clear()
```

See the HTML doc for details. The following are some articles related to back door memory access:

https://solvnet.synopsys.com/retrieve/2290799.html

https://solvnet.synopsys.com/retrieve/2214179.html

https://solvnet.synopsys.com/retrieve/2042786.html

https://solvnet.synopsys.com/retrieve/034476.html

While doing the backdoor access of memory using read() and write() methods, the number of bytes accesses will be equal to the data\_width configured on the slave agent. For example, if the data\_width is 32 bit (i.e., 4 bytes), then the address provided to these methods should be aligned to 4 bytes i.e., 0, 4, 8, 12 etc... If an unaligned (intermediate) address is provided, these methods internally align the address and then access the bytes in the memory.

```
The slave VIP has methods svt_axi_slave_agent::write_byte() and svt_axi_slave_agent::read_byte() that can be used to access a single byte of data in slave memory.
```

You can configure the memory to return some predefined values on the addresses that were not previously written. This can be achieve using the members:

```
meminit
set_meminit()
```

These take the enum values of type meminit\_enum as inputs. It has the following values. Please see the html class reference doc for details:

- UNKNOWNS
- ZEROES
- ONES
- ADDRESS
- VALUE

- ❖ INCR
- DECR
- **❖** USER PATTERN

## 3.2.4.5 Configuring Slave Memory Address Map

To configure the address ranges of slave memory, you need to use the method svt\_axi\_system\_configuration::set\_addr\_range().

```
Example: set_addr_range(0, 32'h0000_0000, 32'h0000_fffff); //this will set the address range of slave[0].
```

It is possible to have discontinuous address ranges within a single slave vip. This can be done by calling the set\_addr\_range() multiple times, like:

```
set_addr_range(0, 32'h0000_0000, 32'h0000_ffff);
set_addr_range(0, 32'h0004_0000, 32'h0004_ffff);
set_addr_range(0, 32'h0006_0000, 32'h0006_ffff);
```

It is possible to have a shared memory across multiple slave vips. This can be achieved by creating an object of  $svt\_mem$  in the testbench and setting this as slave memory for all the slave vips. This is demonstrated in the VIP example tb\_amba\_svt\_uvm\_basic\_sys. Check the description of the member

```
svt_axi_system_configuration::allow_slaves_with_overlapping_addr which has the details.
```

You can also specify rules for masters accessing shared memory through specific slave interfaces. Please check the article:

https://solvnet.synopsys.com/retrieve/2216520.html

#### **3.2.4.6** FIFO Memory

The slave agent has a FIFO memory that can be used for transactions of FIXED burst type. The FIFO memory is represented by class svt\_axi\_fifo\_mem. FIFO memory is instantiated in the slave agent as follows:

```
svt_axi_fifo_mem fifo_mem[];
```

This FIFO is configured based on the port configuration parameters svt\_axi\_port\_configuration::num\_fifo\_mem and svt\_axi\_port\_configuration::fifo\_mem\_addresses[]. By default, svt\_mem will be used for FIXED burst\_type also.

Example configuration to create a single FIFO element is as follows:

```
this.slave_cfg[0].num_fifo_mem = 1;
this.slave_cfg[0].fifo_mem_addresses = new[1];
this.slave_cfg[0].fifo_mem_addresses[0] = 64'h100;
```

The depth of the FIFO is infinite. The width of the FIFO is same as the data\_width of the slave vip. These are not configurable.

The FIFO will be accessed by the slave memory sequence (svt\_axi\_slave\_memory\_sequence) only for the FIXED type bursts. You need to use the svt\_axi\_slave\_memory\_sequence to access the FIFO.

For more information on svt axi fifo mem, see the AXI SVT class reference HTML documentation.

The below article shows how to customize the slave vip behavior for accessing the FIFO memory. It also has an example for accessing FIFO memory for INCR transactions of burst\_length=1.

https://solvnet.synopsys.com/retrieve/1512706.html

#### 3.2.4.7 AXI System Monitor Considerations

The axi system monitor <code>data\_integrity\_checks</code> are based on the slave memory updates. So you need to use the <code>slave\_mem\_response\_sequence</code> on the active slave vips. A passive slave vip needs to be connected to the interfaces where there is a DUT. The memory in the passive slave vip will be updated based on the activity observed on the interface.

# 3.2.5 FIFO Memory

AXI VIP provides FIFO memory represented by class svt\_axi\_fifo\_mem. FIFO memory is instantiated in the slave agent as follows:

```
svt_axi_fifo_mem fifo_mem[];
```

This FIFO is configured based on the port configuration parameters num\_fifo\_mem and fifo\_mem\_addresses.

Example configuration to create a single FIFO element is as follows:

```
this.slave_cfg[0].num_fifo_mem = 1;
this.slave_cfg[0].fifo_mem_addresses = new[1];
this.slave_cfg[0].fifo_mem_addresses[0] = 64'h100;
```

The depth of the FIFO is infinite. The width of the FIFO is same as the data width of the interface. These are not configurable.

The FIFO will be accessed by the slave memory sequence (svt\_axi\_slave\_memory\_sequence) only for the FIXED type bursts. You need to use the svt\_axi\_slave\_memory\_sequence to access the FIFO.

For more information on svt\_axi\_fifo\_mem, see the AXI SVT class reference HTML documentation.

#### 3.2.6 Interconnect Env

The Interconnect Env routes the AXI transactions between multiple masters and slaves. The Interconnect Env contains configurable number of master and slave ports. The number of master and slave ports of the Interconnect Env can be controlled through interconnect configuration. The Interconnect Env routes the transactions from masters to slaves based on address map. Multiple address ranges can be specified for a single slave. The Interconnect Env can be configured to operate in active mode and passive mode.

In the Interconnect Env component, the ports which are connected to master components are referred to as Interconnect Slave ports and ports which are connected to slave components are referred to as Interconnect Master ports. More details on Interconnect master and slave ports are provided in the following sections.

The Interconnect VIP waits for the entire write data (from the master) to arrive before it initiates a transaction on the slave. The Interconnect VIP is a functionally ideal interconnect which comprises of several AXI masters and slaves. It is not designed to be the most efficient in terms of bandwidth utilization, performance and hence forth (which obviously an RTL is designed for). So for a write transaction, the Interconnect waits for the wlast to arrive before it starts sending the corresponding awvalid to the slave.



For more information on Interconnect features related to ACE protocol, see "Support for ACE protocol in AXI Interconnect Env".

#### 3.2.6.1 Interconnect Env Master Ports

The master ports of the Interconnect Env drive the slave components in the system. The master ports within the interconnect Env are represented by Interconnect Master Agent class svt\_axi\_ic\_master\_agent. The

Interconnect Master Agent is configured using a port configuration, which is available in the interconnect configuration.

The Driver within the Interconnect Master Agent drives the AXI transactions towards the slave component connected to the interconnect master port. The Driver and port Monitor components within Interconnect Master Agent call callback methods at various phases of execution of the AXI transaction. Details of callbacks are covered in later sections. At the end of each transaction on the Interconnect Master port, the port monitor within the Interconnect Master Agent provides the completed transaction object from its analysis port, in active and passive mode.

#### 3.2.6.2 Interconnect Env Slave Ports

The slave ports of the interconnect Env are driven by the master components in the system. The slave ports within the interconnect Env are represented by Interconnect Slave Agent class <code>svt\_axi\_ic\_slave\_agent</code>. The Interconnect Slave Agent is configured using a port configuration, which is available in the interconnect configuration.

The Driver within the Interconnect Slave Agent responds to the AXI transactions driven by the master component connected to the interconnect slave port. The Driver and port Monitor components within Interconnect Slave Agent call callback methods at various phases of execution of the AXI transaction. Details of callbacks are covered in later sections. At the end of each transaction on the Interconnect Slave port, the port monitor within the Interconnect Slave Agent provides the completed transaction object from its analysis port, in active and passive mode.

## 3.2.6.3 Connecting Interconnect Env to the DUT

The number of master and slave ports of the Interconnect Env is configured using configuration members svt\_axi\_interconnect\_configuration::num\_ic\_master\_ports and svt\_axi\_interconnect\_configuration::num\_ic\_slave\_ports respectively. If the System Env also contains master and slave VIP components in addition to the Interconnect Env, these master and slave VIP components get automatically connected to the lowest port indices of the Interconnect Env. The number of master and slave VIP components in system Env is configured using configuration members svt\_axi\_system\_configuration::num\_masters and svt\_axi\_system\_configuration::num\_slaves respectively.

For example, if svt\_axi\_interconnect\_configuration::num\_ic\_slave\_ports = 3, and svt\_axi\_system\_configuration::num\_masters = 2, then master VIP components would automatically connect to slave port 0 and 1 of the Interconnect Env component. Slave port 2 of Interconnect Env can be connected to Master DUT. In such a case, the port monitor in Slave port 2 of the Interconnect Env will continue to carry out the passive functionality like protocol checking.

It is recommended to configure the number of master or slave VIP components in the System Env to match the number of slave or master ports of Interconnect Env. Then, for the Interconnect Env ports which are expected to be connected to the DUT, configure the corresponding Master or Slave VIP components in passive mode. That way, even if you replace Interconnect Env with Interconnect RTL, the passive monitors would continue to function.

For example, if Interconnect Env has 3 slave ports (port 0,1,2), and you need Master VIP components to drive port 0 and 1, and Master DUT to drive port 2.

In this case, configure the number of masters in System Env to 3 (svt\_axi\_system\_configuration::num\_masters = 3). Configure Master VIP 0 and Master VIP 1 as active, and Master VIP 2 as passive (as Master DUT would drive this port).

# 3.2.6.4 Configuration Consistency Checks

When the VIP is configured to use the interconnect model by setting the configuration parameter svt\_axi\_system\_configuration::use\_interconnect, the configuration of master or slave VIP components must match configuration of interconnect ports to which they connect. The VIP does a consistency check between the port configuration of master or slave VIP components and corresponding interconnect port configuration. The consistency checks ensure that:

```
sys_cfg.master_cfg[<master_num>].<port_config_param> matches
sys_cfg.ic_cfg.slave_cfg[<master_num>].<port_config_param>
sys_cfg.slave_cfg[<slave_num>].<port_config_param> matches
sys_cfg.ic_cfg.master_cfg[<slave_num>].<port_config_param>
```

VIP checks the consistency of below port configuration parameters between master or slave VIP components and corresponding Interconnect port configurations:

```
addr_width
addr user width
data_width
data_user_width
resp_user_width
snoop_data_width
wysiwyg_enable
use_separate_rd_wr_chan_id_width
id width
read_chan_id_width
write chan id width
num outstanding xact
num_read_outstanding_xact
num_write_outstanding_xact
num_outstanding_snoop_xact
exclusive_access_enable
barrier_enable
dvm_enable
max_num_exclusive_access
write_data_interleave_depth
serial_read_write_access
```

#### If consistency check fails, VIP issues the following message:

UVM\_FATAL /.../svt\_axi\_system\_env.svp(189) @ Ons: uvm\_test\_top.env.axi\_env [build\_phase] Invalid configuration passed. Please pass a valid svt\_axi\_system\_configuration object or derived object.

## 3.2.7 System Environment

The AXI System Env encapsulates the Master agents, Slave Agents, System Sequencer, Interconnect Env and the system configuration. The number of configured Master and Slave Agents is based on the system

configuration provided by you. In the build phase, the System Env builds the Master agents, Slave agents and Interconnect Env. After the Master and Slave Agents are built, they are configured by System Env by using the port configuration information available in the system configuration.

Figure 3-3 Usage With System Environment



#### 3.2.7.1 System Sequencer

AXI System sequencer is a virtual sequencer with references to each Master and Slave Sequencers in the system. The System Sequencer is created in the build phase of the System Env. The system configuration is provided to the System Sequencer. The System Sequencer can be used to synchronize between the sequencers in Master and Slave Agents.

## 3.2.8 System Monitor

The System Monitor component is instantiated within the AXI System Env component. The System Monitor performs system-level checks across the master and slave ports within the system. The system monitor is enabled by setting the system configuration class member

svt\_axi\_system\_configuration::system\_monitor\_enable.

# 3.2.8.1 System Checks

The System checks supported by System Monitor fall under the following categories:

- Checks for mapping between ACE coherent transaction and snoop transactions
- Checks for sequencing between ACE coherent and snoop transactions
- Checks for response to coherent transactions based on response to snoop transactions
- Data integrity between ACE coherent transaction data and snoop transaction data

- ❖ Data integrity checks for transactions that span across multiple cachelines such as READONCE and WRITEUNIQUE transactions
- **❖** Data integrity between cache of all masters
- **❖** Data integrity between cache of all masters and slave memory
- **❖** Data Integrity across Interconnect master and slave ports
- **❖** Transaction routing

There are certain checks which might be design specific. System Monitor provides hooks in the form of callbacks, which can be used by you to perform such design specific checks.

For the list of system checks and callbacks, see the AXI VIP Class reference HTML documentation.

## 3.2.9 Active and Passive Mode

Table 3-1 lists the behavior of Master and Slave Agents in active and passive modes.

Table 3-1 Agents in Active and Passive Mode

| Component behavior in active mode                                                                                                                                                                                                                                                                                                                                                                     | Component behavior in passive mode                                                                                                                                                                                                     |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| In active mode, Master and Slave components generate transactions on the signal interface.                                                                                                                                                                                                                                                                                                            | In passive mode, master and slave components do not generate transactions on the signal interface. These components only sample the signal interface.                                                                                  |
| Master and Slave components continue to perform passive functionality of coverage and protocol checking. You can enable/disable this functionality through configuration.                                                                                                                                                                                                                             | Master and Slave components monitor the input and output signals, and perform passive functionality such as coverage and protocol checking. You can enable/disable this functionality through configuration options.                   |
| The Port Monitor within the component performs protocol checks only on sampled signals. That is, it does not perform checks on the signals that are driven by the agent. This is because when the agent is driving an exception (exceptions are not supported in this release) the Monitor should not flag an error, since it knows that it is driving an exception. Exception means error injection. | The port monitor within the component performs protocol checks on all signals. In passive mode, signals are considered as input signals.                                                                                               |
| The delay values reported in the AXI transaction provided by the Master and Slave component, are the values provided by you, and not the sampled delay values.                                                                                                                                                                                                                                        | The delay values reported in the AXI transaction provided by the Master and Slave Agent, are the sampled delay values on the bus.                                                                                                      |
| Interconnect component routes transactions from masters to slaves.                                                                                                                                                                                                                                                                                                                                    | Interconnect component does not route the transactions from masters to slaves.                                                                                                                                                         |
| Interconnect component continues to perform passive functionality of coverage and protocol checking on all the master and slave ports. You can enable/disable this functionality through configuration.                                                                                                                                                                                               | Interconnect component monitors the input and output signals on all the master and slave ports, and performs passive functionality of coverage and protocol checking. You can enable/disable this functionality through configuration. |

## 3.3 AXI UVM User Interface

The following sections give an overview of the user interface into the AXI VIP.

#### 3.3.1 Clock and Reset Connection

There is a small change in the bind use model starting from from the 1.96a release of AXI VIP. Following are the details of the change:

1. For active agent connection:

Pass '1' as the parameter value and svt\_axi\_master\_async\_modport as the first argument to the connector.

```
bind test_top svt_axi_master_connector #(1)
master_bind_connector0(axi_if.master_if[0].svt_axi_master_async_modport,
slave_dut.master_bind_if);
```

2. For passive agent connection:

Pass '0' as the parameter value and svt\_axi\_monitor\_modport as the first argument to the connector.

```
bind test_top svt_axi_master_connector #(0)
master_bind_connector0(axi_if.master_if[0].svt_axi_monitor_modport,
slave_dut.master_bind_if);
```

#### 3.3.2 VIP Interface Connection

AXI VIP provides the SystemVerilog interface which can be used to connect the VIP to the DUT. A top level interface svt\_axi\_if is provided which contains an array of master & slave interfaces.

For example,

```
/* instantiate top level interface*/
svt axi if axi if();
```

There are two ways on how you can set clock signal "aclk" for each/all of master and slave sub interfaces under this top level svt\_axi\_if interface instance.

1. If you want to use a common clock for all the master and slave port interfaces, there is 'common\_aclk' signal at svt\_axi\_if level , which can be used. This common clock will then be used by all the port interfaces.

For example,

```
svt_axi_if axi_if();
assign axi_if.common_aclk = SystemClock;
```



You must leave svt\_axi\_system\_configuration::common\_clock\_mode set to default value '1' for system configuration object.

2. If any/all master/slave port interface under svt\_axi\_if instance need to use a separate clock, then the 'aclk' signal in the port interface should be connected to respective individual clocks and system configuration object field "svt\_axi\_system\_configuration::common\_clock\_mode" should be set to '0' to disable common clock mode.

# 3.3.3 Configuration Objects

Configuration data objects convey the system level and port level testbench configuration. The configuration of agents is done in the build() phase of environment or the testcase. If the configuration

needs to be changed later, it can be done through reconfigure() method of the Master, Slave Agent or System Env.

The configuration can be of the following two types:

Static configuration properties

Static configuration parameters specify a configuration value which cannot be changed when the system is running. Examples of static configuration parameters are number of masters and slaves, data bus width, and address width.

Dynamic configuration properties

Dynamic configuration parameters specify configuration value which can be changed at any time, regardless of whether the system is running or not. An example of a dynamic configuration parameter is a timeout value.

The configuration data objects contain built-in constraints, which come into effect when the configuration objects are randomized.

The AXI VIP defines following configuration classes:

❖ System configuration (svt axi system configuration)

The System configuration class contains configuration information which is applicable across the entire system. You can specify the system level configuration parameters through this class. You need to provide the system configuration to the system env from the environment or the testcase. The system configuration mainly specifies:

- ♦ Number of master and slave agents in the system env
- Port configurations for master and slave agents
- Virtual top level AXI interface
- ♦ Address map
- **♦** Timeout values
- ❖ Port configuration (svt\_axi\_port\_configuration)

The Port configuration class contains configuration information which is applicable to individual AXI master or slave agents in the system env. Some of the important information provided by port configuration class is:

- ◆ Active or Passive mode of the master or slave port agent
- Enable or disable protocol checks
- Enable or disable port-level coverage
- ◆ Interface type (AXI3/AXI4/AXI4-Lite)
- ◆ Port configuration contains the virtual interface for the port

The port configuration objects within the system configuration object are created in the constructor of the system configuration.

❖ Interconnect configuration (svt\_axi\_interconnect\_configuration)

Interconnect configuration class contains configuration information for the interconnect component. It has a handle to the system configuration. In addition, this class contains configuration for number of master and slave ports of the interconnect component, and the respective configuration for these master and slave ports.

For details on individual members of configuration classes, see the AXI VIP Class reference HTML documentation.

# 3.3.4 Transaction Objects

Transaction objects, which are extended from the <code>uvm\_sequence\_item</code> base class, define a unit of AXI protocol information that is passed across the bus. The attributes of transaction objects are public and are accessed directly for setting and getting values. Most transaction attributes can be randomized. The transaction object can represent the desired activity to be simulated on the bus, or the actual bus activity that was monitored.

AXI transaction data objects store data content and protocol execution information for AXI transactions in terms of timing details of the transactions.

These data objects extend from the uvm\_sequence\_item base class and implement all methods specified by UVM for that class.

AXI transaction data objects are used to:

- Generate random stimulus
- Report observed transactions
- Generate random responses to transaction requests
- Collect functional coverage statistics

Class properties are public and accessed directly to set and read values. Transaction data objects support randomization and provide built-in constraints. Two set of constraints are provided: valid\_ranges and reasonable constraints.

- valid\_ranges constraints limit generated values to those acceptable to the drivers. These constraints ensure basic VIP operation and should never be disabled.
- reasonable\_\* constraints, which can be disabled individually or as a block, limit the simulation by the following:
  - **♦** Enforcing the protocol. These constraints are typically enabled unless errors are being injected into the simulation.
  - **♦** Setting simulation boundaries. Disabling these constraints may slow the simulation and introduce system memory issues.

The VIP supports extending transaction data classes for customizing randomization constraints. This allows you to disable some reasonable\_\* constraints and replace them with constraints appropriate to your system.

Individual reasonable\_\* constraints map to independent fields, each of which can be disabled. The class provides the reasonable\_constraint\_mode() method to enable or disable blocks of reasonable\_\* constraints.

AXI VIP defines following transaction classes:

- AXI Base transaction (svt\_axi\_transaction)
  - This is the base transaction type which contains all the physical attributes of the transaction like address, data, burst type, burst length, etc. It also provides the timing information the transaction, to the master and slave drivers, that is, delays for valid and .ready signals with respect to some reference events.
- AXI Master transaction (svt\_axi\_master\_transaction)

The master transaction class extends from the AXI transaction base class <code>svt\_axi\_transaction</code>. The master transaction class contains the constraints for master specific members in the base transaction class. At the end of each transaction, the master agent provides object of type <code>svt\_axi\_master\_transaction</code> from its analysis ports, in active and passive mode.

AXI Slave transaction (svt\_axi\_slave\_transaction)

The slave transaction class extends from the AXI transaction base class svt\_axi\_transaction. The slave transaction class contains the constraints for slave specific members in the base transaction class. At the end of each transaction, the slave agent provides object of type svt\_axi\_slave\_transaction from its analysis ports, in active and passive mode.

The master and slave transactions contain a handle to configuration object of type svt\_axi\_port\_configuration, which provides the configuration of the port on which this transaction would be applied. The port configuration is used during randomizing the transaction. The port configuration is available in the sequencer of the master or slave agent.

You should initialize the port configuration handle in the transaction using the port configuration available in the sequencer of the master or slave agent. If the port configuration handle in the transaction is null at the time of randomization, the transaction will issue a fatal message.

❖ AXI ACE Snoop Base transaction (svt\_axi\_snoop\_transaction)

This is the base class for snoop transaction type which contains all the physical attributes of the transaction like address, data, transaction type, etc. It also provides the timing information of the transaction to the master component, that is, delays for valid and ready signals with respect to some reference events. The <code>svt\_axi\_snoop\_transaction</code> also contains a handle to configuration object of type <code>svt\_axi\_port\_configuration</code>, which provides the configuration of the port on which this transaction would be applied. The port configuration is used during randomizing the transaction.

**❖** AXI ACE Master Snoop transaction (svt\_axi\_master\_snoop\_transaction)

The master snoop transaction class extends from the snoop transaction base class svt\_axi\_snoop\_transaction. The master snoop transaction class contains the constraints for master specific members in the base transaction class. At the end of each transaction, the port monitor within the master VIP component provides object of type svt\_axi\_master\_snoop\_transaction from its analysis ports, in active and passive mode.

AXI transaction on Interconnect Slave port (svt\_axi\_ic\_slave\_transaction)

svt\_axi\_ic\_slave\_transaction class is used by the slave ports of the Interconnect component, to represent the transaction received on the Interconnect slave port from a master component. At the end of each transaction on the Interconnect Slave port, the port monitor within the Interconnect slave port provides object of type svt\_axi\_ic\_slave\_transaction from its analysis port, in active and passive mode.

AXI transaction on Interconnect Master port (svt\_axi\_ic\_master\_transaction)

svt\_axi\_ic\_master\_transaction class is used by the master ports of the Interconnect component, to represent the transaction transmitted on the interconnect master port to a connected slave component. At the end of each transaction on the Interconnect Master port, the port monitor within the Interconnect Master port provides object of type svt\_axi\_ic\_master\_transaction from its analysis port, in active and passive mode.

This transaction class is not supported in this release. Currently, the port monitor within the Interconnect Master port provides object of type svt\_axi\_master\_transaction from its analysis port.

❖ AXI ACE Snoop transaction on Interconnect Slave port (svt\_axi\_ic\_snoop\_transaction)

svt\_axi\_ic\_snoop\_transaction class extends from the snoop transaction base class svt\_axi\_snoop\_transaction. This class represents the snoop transaction at the interconnect slave ports, which are connected to the external master components. At the end of each snoop transaction on the Interconnect Slave port, the port monitor within the Interconnect Slave port provides object of type svt\_axi\_ic\_snoop\_transaction from its analysis port, in active and passive mode.

For more information on individual members of transaction classes, see the AXI VIP Class reference HTML documentation.

# 3.3.5 Analysis Ports

The Port Monitor in the Master and Slave Agent provides item\_started\_port and item\_observed\_port analysis ports.

The Master and Slave Agents respectively write the svt\_axi\_master\_transaction and svt\_axi\_slave\_transaction object to the item\_started\_port analysis port which provides AXI transactions available just when the transaction starts.

At the end of the transaction, the Master and Slave Agents respectively write the completed

svt\_axi\_master\_transaction and svt\_axi\_slave\_transaction object to the item\_observed\_port analysis port. This holds true in active as well as passive mode of operation of the master or slave agent. You can use this analysis port for connecting to scoreboard, or any other purpose, where a transaction object for the completed transaction is required.

The Port Monitor in the Interconnect Master Agent and Interconnect Slave agent also provides an analysis port item\_observed\_port. At the end of the transaction on the interconnect ports, the port monitor within the Interconnect Master Agent and Interconnect Slave agent provides the completed

svt\_axi\_ic\_master\_transaction and svt\_axi\_ic\_slave\_transaction object respectively, from its analysis port.

Also you can create user-defined analysis ports for their scoreboarding purpose.

#### **Usage:**

Steps to use item\_observed\_port analysis port in an UVM verification environment.

1. Create an axi scoreboard class extending from uvm\_scoreboard class and declare the export for the analysis port.

```
//The uvm_analysis_imp_decl allows for a scoreboard (or other analysis component) to
support input from many places
/** Macro that define two analysis ports with unique suffixes */
`uvm_analysis_imp_decl(_initiated)
```

```
`uvm_analysis_imp_decl(_response)

class axi_uvm_scoreboard extends uvm_scoreboard;

   /** Analysis port connected to the AXI Master Agent */
   uvm_analysis_imp_initiated#(svt_axi_transaction, axi_uvm_scoreboard)
item_observed_initiated_export;

   /** Analysis port connected to the AXI Slave Agent */
   uvm_analysis_imp_response#(svt_axi_transaction, axi_uvm_scoreboard)
item_observed_response_export;

   /** UVM Component Utility macro */
   `uvm_component_utils(axi_uvm_scoreboard)

function new (string name = "axi_uvm_scoreboard", uvm_component parent=null);
        super.new(name, parent);
   endfunction : new
endclass
```

2. In the Scoreboard::build() phase, build export of analysis ports and create write\_\*\*\*() method to get the object from the analysis ports.

```
class axi_uvm_scoreboard extends uvm_scoreboard;
...
...
function void build_phase(uvm_phase phase);
    super.build();
    /** Construct the analysis ports */
    item_observed_initiated_export = new("item_observed_initiated_export", this);
    item_observed_response_export = new("item_observed_response_export", this);
    endfunction
endclass
```

3. Create write\_\*\*\*() method to get the object from the item\_observed\_port analysis port class axi\_uvm\_scoreboard extends uvm\_scoreboard;

```
..
..
/** This method is called by item_observed_initiated_export */
virtual function void write_initiated(input svt_axi_transaction xact);
    svt_axi_transaction init_xact;

    if (!$cast(init_xact, xact.clone())) begin
        `uvm_fatal("write_initiated", "Unable to $cast the received transaction to
svt_axi_transaction");
    end
    `uvm_info("write_initiated", $sformatf("xact:\n%s", init_xact.sprint()), UVM_FULL)
endfunction

/** This method is called by item_observed_response_export */
virtual function void write_response(input svt_axi_transaction xact);
```

4. In the ENV create an instance of the axi\_uvm\_scoreboard and build the object class axi\_env extends uvm env;

```
/** AXI System ENV */
 svt_axi_system_env axi_system_env;
 /** Master/Slave Scoreboard */
 axi uvm scoreboard axi scoreboard;
  /** UVM Component Utility macro */
  'uvm component utils(axi env)
  /** Class Constructor */
 function new (string name="axi env", uvm component parent=null);
    super.new (name, parent);
 endfunction
 /** Build the AXI System ENV */
 virtual function void build_phase(uvm_phase phase);
    `uvm info("build phase", "Entered...", UVM LOW)
    super.build phase(phase);
    /* Create the scoreboard */
    axi scoreboard = axi uvm scoreboard::type id::create("axi scoreboard", this);
    . .
    `uvm_info("build_phase", "Exiting...", UVM_LOW)
 endfunction
endclass
```

5. In the connect phase Connect master & slave agent analysis ports to scoreboard

```
class axi_env extends uvm_env;
...
...
function void connect_phase(uvm_phase phase);
   `uvm_info("connect_phase", "Entered...",UVM_LOW)

/**
   * Connect the master and slave agent's analysis ports with
   * item_observed_before_export and item_observed_after_export ports of the
   * scoreboard.
```

\*/

```
axi_system_env.master[0].monitor.item_observed_port.connect(axi_scoreboard.item_observed
_initiated_export);
axi_system_env.slave[0].monitor.item_observed_port.connect(axi_scoreboard.item_observed_response_export);
    endfunction
endclass
```

For complete example, see the tb\_axi\_svt\_uvm\_intermediate\_sys example testbench.

**Example**: How do I add user-defined TLM analysis ports into Port Monitor callbacks in an UVM environment?

https://solvnet.synopsys.com/retrieve/037331.html

#### 3.3.6 Callbacks

Callbacks are an access mechanism that enable the insertion of user-defined code and allow access to objects for scoreboarding and functional coverage. Each Master and Slave Agent is associated with a callback class that contains a set of callback methods. These methods are called as part of the normal flow of procedural code. There are a few differences between callback methods and other methods that set them apart.

- Callbacks are virtual methods with no code initially, so they do not provide any functionality unless they are extended. The exception to this rule is that some of the callback methods for functional coverage already contain a default implementation of a coverage model.
- The callback class is accessible to you so the class can be extended and your code inserted, potentially including testbench specific extensions of the default callback methods, and testbench specific variables and/or methods used to control whatever behavior the testbench is using the callbacks to support.
- Callbacks are called within the sequential flow at places where external access would be useful. In addition, the arguments to the methods include references to relevant data objects. For example, just before a monitor puts a transaction object into an analysis port is a good place to sample for functional coverage since the object reflects the activity that just happened on the pins. A callback at this point with an argument referencing the transaction object allows this exact scenario.
- There is no need to invoke callback methods for callbacks that are not extended. To avoid a loss of performance, callbacks are not executed by default. To execute callback methods, callback class must be registered with the component using uvm\_register\_cb macro.

AXI VIP uses callbacks in three main applications:

- Access for functional coverage
- Access for scoreboarding
- ❖ Insertion of user-defined code

#### 3.3.6.1 Master Agent Callbacks

In the Master Agent, the callback methods are called by Master Driver and Port Monitor components.

The following callback classes which contain the callback methods are invoked by the Master Agent:

- svt\_axi\_master\_callback
- svt\_axi\_port\_monitor\_callback

For more information on these classes, see the class reference HTML documentation.

The following is the list of callback methods available from svt\_axi\_master\_callback class:

- virtual function void associate\_xact\_to\_barrier\_pair (svt\_axi\_master axi\_master,
  svt\_axi\_master\_transaction xact, svt\_axi\_barrier\_pair\_transaction barrier\_pair\_xact
  [\$])
  - Callback issued by master transactor when barrier transactions are enabled and when 'associate\_barrier\_xact' bit is set to 1 in the svt\_axi\_master\_transaction class
- virtual function void input\_port\_cov (svt\_axi\_master axi\_master , svt\_axi\_transaction xact )
  - Callback issued to allow the testbench to collect functional coverage information from a transaction received at the input channel which is connected to the generator.
- virtual function void post\_input\_port\_get (svt\_axi\_master axi\_master, svt\_axi\_transaction xact, ref bit drop)
  - Called after the master transactor gets a transaction from the input TLM port.
- virtual function void post\_snoop\_input\_port\_get (svt\_axi\_master axi\_master, svt\_axi\_master\_snoop\_transaction xact, ref bit drop)
  - Callback issued by master transactor after pulling the snoop response from the snoop response generator
- virtual function void pre\_address\_phase\_started (svt\_axi\_master axi\_master, svt\_axi\_transaction xact)
  - Called just before driving the address phase of a transaction.
- virtual function void pre\_cache\_update (svt\_axi\_master axi\_master, svt\_axi\_master\_transaction xact)
  - Callback issued by master transactor just before updating the data into the cache.
- virtual function void pre\_snoop\_data\_phase\_started (svt\_axi\_master axi\_master, svt\_axi\_master\_snoop\_transaction xact)
  - Callback issued just before driving the data phase of a snoop transaction.
- virtual function void pre\_snoop\_resp\_phase\_started (svt\_axi\_master axi\_master, svt\_axi\_master\_snoop\_transaction xact)
  - Callback issued just before driving response to a snoop transaction.
- virtual function void pre\_write\_data\_phase\_started (svt\_axi\_master axi\_master, svt axi transaction xact)
  - Called just before driving a data beat of a write transaction
- virtual function void snoop\_input\_port\_cov (svt\_axi\_master axi\_master , svt\_axi\_master\_snoop\_transaction xact)
  - Callback issued to allow the testbench to collect functional coverage information from a snoop transaction received at the input port of the master transactor, which is connected to the snoop response generator.
- svt\_axi\_master\_callback methods arguments description:
  - → axi\_master A reference to the svt\_axi\_master component that is issuing this callback. The
    user's callback implementation can use this to access the public data and/or methods of the
    component.
  - **♦** xact A reference to the transaction descriptor object of interest.

♦ drop - A ref argument, which if set by the user's callback implementation causes the transactor to discard the transaction descriptor without further action.

#### 3.3.6.2 Slave Agent Callbacks

In the Slave Agent, the callback methods are called by Slave Driver and port monitor components.

The following callback classes which contain the callback methods are invoked by the Slave Agent:

- svt\_axi\_slave\_callback
- svt\_axi\_port\_monitor\_callback

For more information of these classes, see the class reference HTML documentation.

The following is the list of callback methods available from svt\_axi\_slave\_callback class:

- virtual function void input\_port\_cov (svt\_axi\_slave axi\_slave, svt\_axi\_transaction xact)
  Callback issued to allow the testbench to collect functional coverage information from a transaction received the input channel which is connected to the generator.
- virtual function void post\_input\_port\_get (svt\_axi\_slave axi\_slave, svt\_axi\_transaction xact, ref bit drop)

Called after the slave transactor gets a slave response transaction from the slave response generator.

- - Called just before driving the read data phase of a read transaction.
- virtual function void pre\_write\_resp\_phase\_started (svt\_axi\_slave axi\_slave, svt axi transaction xact)

Called just before driving a write response phase of a write transaction.

- svt\_axi\_slave\_callback method arguments description:
  - → axi\_slave A reference to the svt\_axi\_slave component that is issuing this callback. The
    user's callback implementation can use this to access the public data and/or methods of the
    component.
  - ◆ xact A reference to the transaction descriptor object of interest.
  - ♦ drop A ref argument, which if set by the user's callback implementation causes the transactor to discard the transaction descriptor without further action.

The following is the list of callback methods available from svt\_axi\_port\_monitor\_callback class:

- virtual function void new\_snoop\_transaction\_started (svt\_axi\_port\_monitor axi\_monitor, svt\_axi\_snoop\_transaction item)
  - Called when a new snoop transaction is observed on the port.
- virtual function void new\_transaction\_started ( svt\_axi\_port\_monitor axi\_monitor , svt\_axi\_transaction item )
  - Called when a new transaction is observed on the port.
- virtual function void pre\_output\_port\_put (svt\_axi\_port\_monitor axi\_monitor, svt\_axi\_transaction item)
  - Called before putting a transaction to the analysis port. Extension of this method in the default coverage callback class is used for triggering transaction coverage.

- virtual function void pre\_response\_request\_port\_put ( svt\_axi\_port\_monitor axi\_monitor , svt\_axi\_transaction item )
  - Called just before the response request transaction is provided by slave port monitor to slave response generator.
- virtual function void pre\_snoop\_output\_port\_put (svt\_axi\_port\_monitor axi\_monitor, svt\_axi\_snoop\_transaction item)
  - Called before putting a snoop transaction to the analysis port.
- virtual function void pre\_tlm\_generic\_payload\_port\_put ( svt\_axi\_port\_monitor axi\_monitor , uvm\_tlm\_generic\_payload xact )
  - Called when a transaction completes and when use\_tlm\_gp\_sequencer is set in the port configuration. The completed AXI transaction is converted to a PV-annotated TLM GP and is made available through this callback.
- virtual function void pre\_tlm\_generic\_payload\_snoop\_port\_put (svt\_axi\_port\_monitor axi\_monitor , uvm\_tlm\_generic\_payload xact)
  - Called when a snoop transaction completes and when use\_tlm\_gp\_sequencer is set in the port configuration. The completed AXI snoop response is converted to a PV-annotated TLM GP and is made available through this callback.
- virtual function void read\_address\_phase\_ended ( svt\_axi\_port\_monitor axi\_monitor , svt\_axi\_transaction item )
  - Called when read address handshake is complete, that is, when ARVALID and ARREADY are asserted. Extension of this method in the default coverage callback class is used for signal coverage of read address channel signals.
- virtual function void read\_address\_phase\_started (svt\_axi\_port\_monitor axi\_monitor, svt\_axi\_transaction item)
  - Called when ARVALID is asserted.
- virtual function void read\_data\_phase\_ended ( svt\_axi\_port\_monitor axi\_monitor , svt axi transaction item )
  - Called when read data handshake is complete, that is, when RVALID and RREADY are asserted. Extension of this method in the default coverage callback class is used for signal coverage of read data channel signals.
- virtual function void read\_data\_phase\_started ( svt\_axi\_port\_monitor axi\_monitor , svt\_axi\_transaction item )
  - Called when RVALID is asserted.
- virtual function void snoop\_address\_phase\_ended (svt\_axi\_port\_monitor axi\_monitor, svt\_axi\_snoop\_transaction item)
  - Called when snoop address handshake is complete, that is, when ACVALID and ACREADY are asserted.
- virtual function void snoop\_address\_phase\_started (svt\_axi\_port\_monitor axi\_monitor, svt\_axi\_snoop\_transaction item)
  - Called when ACVALID is asserted.
- virtual function void snoop\_data\_phase\_ended ( svt\_axi\_port\_monitor axi\_monitor , svt axi snoop transaction item )

Called when snoop data handshake is complete, that is, when CDVALID and CDREADY are asserted.

virtual function void snoop\_data\_phase\_started (svt\_axi\_port\_monitor axi\_monitor, svt\_axi\_snoop\_transaction item)

Called when CDVALID is asserted.

virtual function void snoop\_resp\_phase\_ended ( svt\_axi\_port\_monitor axi\_monitor , svt axi snoop transaction item )

Called when snoop response handshake is complete, that is, when CRVALID and CRREADY are asserted.

virtual function void snoop\_resp\_phase\_started (svt\_axi\_port\_monitor axi\_monitor, svt\_axi\_snoop\_transaction item)

Called when CRVALID is asserted.

virtual function void stream\_transfer\_ended ( svt\_axi\_port\_monitor axi\_monitor , svt axi transaction item )

Called when stream handshake is complete, that is, when TVALID and TREADY are asserted.

virtual function void stream\_transfer\_started ( svt\_axi\_port\_monitor axi\_monitor , svt\_axi\_transaction item )

Called when TVALID is asserted.

virtual function void transaction\_ended ( svt\_axi\_port\_monitor axi\_monitor , svt\_axi\_transaction item )

Called when a transaction ends.

virtual function void write\_address\_phase\_ended ( svt\_axi\_port\_monitor axi\_monitor , svt\_axi\_transaction item )

Called when write address handshake is complete, that is, when AWVALID and AWREADY are asserted. Extension of this method in the default coverage callback class is used for signal coverage of write address channel signals.

virtual function void write\_address\_phase\_started (svt\_axi\_port\_monitor axi\_monitor, svt\_axi\_transaction item)

Called when AWVALID is asserted.

virtual function void write\_data\_phase\_ended ( svt\_axi\_port\_monitor axi\_monitor , svt\_axi\_transaction item )

Called when write data handshake is complete, that is, when WVALID and WREADY are asserted. Extension of this method in the default coverage callback class is used for signal coverage of write data channel signals.

virtual function void write\_data\_phase\_started (svt\_axi\_port\_monitor axi\_monitor, svt\_axi\_transaction item)

Called when WVALID is asserted.

virtual function void write\_resp\_phase\_ended (svt\_axi\_port\_monitor axi\_monitor, svt\_axi\_transaction item)

Called when write response handshake is complete, that is, when BVALID and BREADY are asserted. Extension of this method in the default coverage callback class is used for signal coverage of write response channel signals.

virtual function void write\_resp\_phase\_started (svt\_axi\_port\_monitor axi\_monitor, svt\_axi\_transaction item)

Called when BVALID is asserted.

- svt\_axi\_port\_monitor\_callback method arguments description:
  - → axi\_monitor A reference to the svt\_axi\_port\_monitor component that is issuing this callback.

    The user's callback implementation can use this to access the public data and/or methods of the component.
  - → item A reference to the transaction descriptor object of interest.

#### 3.3.6.3 Interconnect Env Callbacks

In the Interconnect Env, callback methods are called by the master and slave ports.

The following callback class contains the Interconnect Env callback method:

svt\_axi\_interconnect\_callback

For more information of these classes, see the class reference HTML documentation.

The following is the list of callback methods available from svt\_axi\_interconnect\_callback class:

- virtual function void post\_input\_port\_get(svt\_axi\_interconnect axi\_interconnect, svt\_axi\_ic\_slave\_transaction xact)
  - Callback issued just after receiving a coherent transaction.
- virtual function void post\_slave\_xact\_gen(svt\_axi\_interconnect axi\_interconnect, svt axi master transaction xact)
  - Callback issued after the interconnect randomizes a transaction to be routed to a slave.
- virtual function void pre\_output\_port\_put (svt\_axi\_interconnect axi\_interconnect, svt\_axi\_ic\_slave\_transaction xact)
  - Callback issued after the interconnect receives all responses from snooped ports and before driving coherent response to corresponding port.
- svt axi interconnect callback method arguments description:
  - → axi\_interconnect A reference to the svt\_axi\_interconnect component that is issuing this callback.

    The user's callback implementation can use this to access the public data and/or methods of the component.
  - xact A reference to the transaction descriptor object of interest.

## 3.3.6.4 System Monitor Callbacks

System Monitor provides hooks in the form of callbacks, which can be used to perform such design specific checks. The following callback class contains the System Monitor callback method:

```
svt_axi_system_monitor_callback
```

virtual function void interconnect\_generated\_dirty\_data\_write\_detected ( svt\_axi\_system\_monitor system\_monitor , svt\_axi\_system\_transaction sys\_xact , svt\_axi\_transaction slave\_xact )

- Called after the system monitor detects that a write transaction initiated by the interconnect corresponds to a write of dirty data returned by a snoop transaction.
- virtual function void master\_xact\_fully\_associated\_to\_slave\_xacts (svt\_axi\_system\_monitor system\_monitor, svt\_axi\_system\_transaction sys\_xact)
  - Called after the system monitor correlates all the bytes of a master transaction to corresponding slave transactions.
- virtual function void new\_master\_transaction\_received (svt\_axi\_system\_monitor system\_monitor, svt\_axi\_transaction xact)
  - Called when a new transaction initiated by a master is observed on the port.
- virtual function void new\_slave\_transaction\_received ( svt\_axi\_system\_monitor system\_monitor , svt\_axi\_transaction xact )
  - Called when a new transaction initiated by an interconnect to a slave is observed on the port.
- virtual function void new\_snoop\_transaction\_received ( svt\_axi\_system\_monitor system\_monitor , svt\_axi\_snoop\_transaction xact )
  - Called when a new snoop transaction initiated by an interconnect is observed on the port.
- virtual function void new\_system\_transaction\_started ( svt\_axi\_system\_monitor system\_monitor , svt\_axi\_system\_transaction sys\_xact , svt\_axi\_transaction xact )
  - Called when a new overlapped transaction initiated by a master is observed on the port.
- virtual function void post\_coherent\_and\_snoop\_transaction\_association (svt\_axi\_system\_monitor system\_monitor, svt\_axi\_transaction coherent\_xact, svt\_axi\_snoop\_transaction snoop\_xacts [\$])
   Called after the system monitor associates snoop transactions to a coherent transaction.
- virtual function void pre\_check\_execute (svt\_axi\_system\_monitor system\_monitor, svt\_err\_check\_stats check, svt\_axi\_transaction xact, ref bit execute\_check)
  - Called before a check is executed by the system monitor. Currently supported only for data\_integrity\_check.
- svt\_axi\_system\_monitor\_callback method arguments description:
  - ♦ system\_monitor A reference to the svt\_axi\_system\_monitor component that is issuing this callback. The user's callback implementation can use this to access the public data and/or methods of the component.
  - ♦ sys\_xact A reference to the system transaction descriptor object of interest.
  - slave\_xact A reference to the slave transaction descriptor object which was detected as a dirty data write.
  - ◆ xact A reference to the data descriptor object of interest.
  - ◆ coherent\_xact A reference to the coherent data descriptor object of interest.
  - ◆ snoop xacts A queue of all associated snoop transactions.
  - check A reference to the check that will be executed
  - execute\_check A bit that indicates if the check must be performed.

#### **Usage:**

Steps to implement callbacks feature in an UVM verification environment.

1. Create a user-defined callback class that extends from the AXI VIP callback class.

class axiPortMonitorCallbacks extends svt\_axi\_port\_monitor\_callback;

2. Implement the required callback method in this extended class.

```
virtual function void new_transaction_started (svt_axi_port_monitor axi_monitor,
svt_axi_transaction item);
    $display("Inside new_transaction_started Port Monitor Callback");
    item.print();
endfunction
```

3. Declare an instance of the user defined callback class (Example: In your env).

```
class axiEnv extends uvm_env;
  axiPortMonitorCallbacks monitor_cb;
  ..
  ..
endclass
```

4. Register the callback with the appropriate component in either connect\_phase or start\_of\_simulation\_phase.

```
class axiEnv extends uvm_env;
...
...
function void start_of_simulation();
   super.start_of_simulation_phase(phase);
   monitor_cb = new( "monitor_cb" ); //create object of callback class
   uvm_callback#(svt_axi_port_monitor,svt_axi_port_monitor_callback)::add(
   axi_system_env.master[0].monitor, monitor_cb);
        //Registering the callback with AXI Master VIP's monitor.
        //The master monitor type and the master monitor callback type are provided as parameters to uvm_callbacks class.
        //The add method takes the actual instance of the AXI master monitor and the callback object.
   endfunction
endclass
```

# Example: Usage of AXI port monitor callback to get count of outstanding transactions with AXI SVT VIP slave component

(solvnet: https://solvnet.synopsys.com/retrieve/040575.html)

# 3.3.7 Interfaces and Modports

SystemVerilog models signal connections using interfaces and modports. Interfaces define the set of signals which make up a port connection. Modports define collection of signals for a given port, the direction of the signals, and the clock with respect to which these signals are driven and sampled.

AXI VIP provides the SystemVerilog interface which can be used to connect the VIP to the DUT. A top-level interface svt\_axi\_if is defined. The top-level interface contains an array of Master port sub-interfaces of type svt\_axi\_master\_if, and Slave port sub-interfaces of type svt\_axi\_slave\_if.

The top-level interface is contained in the system configuration class. The top-level interface is specified to the system configuration class using method svt\_axi\_system\_configuration::set\_if.

Alternatively, the interface can also be specified to the AXI System Env component directly through UVM Configuration database. For more details on usage, see AXI Basic example tb\_axi\_svt\_uvm\_basic\_sys.

If the AXI System Env is used, then it first retrieves the configuration using the config db. It then attempts to retrieve the virtual interface using the config db. If a virtual interface is supplied through the config db, then

the AXI System Env will update the configuration with it (a warning will be generated if the configuration object already has a virtual interface reference). The AXI System Env then passes the configuration object down to the master and slave agents. If the virtual interface is not supplied through the config db, then a fatal error is generated if the virtual interface is not valid in the configuration.

Otherwise the virtual interface in configuration is used without modification. When the System Env has a configuration object with a valid virtual interface, then all the sub-objects receive the interface from the configuration object.

If the Master or Slave Agent is used as standalone, then the process is the same. These classes will continue to receive the configuration object using the config db. In addition, they will retrieve the virtual interface from the config db and perform the same checks done in the AXI System Env to ensure that a valid configuration object is created that contains a virtual interface reference.

For more information on AXI Interface, see the

\$DESIGNWARE\_HOME/vip/svt/amba\_svt/latest/doc/axi\_svt\_uvm\_class\_reference/html/interface
s.html

# **3.3.7.1** Modports

The port interface svt\_axi\_master\_if contains following modports which you should use to connect VIP to the DUT:

svt\_axi\_slave\_modport

This modport is used to connect master VIP component to slave DUT port.

svt\_axi\_debug\_modport

This modport can be used by you to access the debug port signals. For information on debug port, see the "Using Debug Port".

The port interface svt\_axi\_slave\_if contains the following modports which you should use to connect VIP to the DUT:

svt\_axi\_master\_modport

This modport is used to connect slave VIP component to master DUT port.

svt\_axi\_debug\_modport

This modport can be used by you to access the debug port signals. See "Using Debug Port" for details on debug port.

# 3.3.7.2 Clocking Modes

The interface works in the following two clocking modes:

- Common clock mode
- Multiple clock mode

The clock mode can be selected using configuration parameter,

svt\_axi\_system\_configuration::common\_clock\_mode. When set to one, the signal common\_aclk in the top interface will be used to drive clock of all port sub-interfaces. In this case, the system clock in the environment will need to be connected to common\_aclk signal in the top interface.

When this configuration parameter is set to 0, the aclk signal of each port sub-interface would need to be connected to appropriate clock in the environment.

#### 3.3.7.2.1 Common Clock Mode

In this mode.

- ❖ All port sub-interfaces will operate on a single common clock.
- ❖ You need to connect system clock to the common\_aclk signal in the top interface.
- Top-level interface will pass the common clock signal down to all port sub-interfaces.

## 3.3.7.2.2 Multiple Clock Mode

In this mode, each port interface would operate on a separate port interface clock. In this case, aclk signal in the port interface needs to be connected to the appropriate clock in the environment.

#### 3.3.7.3 Bind Interfaces

AXI VIP also supports bind interfaces for master & slave. Bind interface is an interface which contains directional signals for AXI. You can connect DUT signals to these directional signals. Bind interfaces provided with VIP are <code>svt\_axi\_master\_bind\_if</code> and <code>svt\_axi\_slave\_bind\_if</code>. To use bind interface, you must instantiate the non-bind interface, and then connect the bind interface to the non-bind interface. VIP provides master and slave connector modules to connect the VIP bind interface to the VIP non-bind interface. You must instantiate a connector module corresponding to each instance of VIP master and slave, and pass the bind interface and non-bind interface instance to this connector module.

For more information on the usage of bind interface, see the AXI intermediate example.

#### 3.3.7.4 Parameterized Interfaces

AXI VIP supports parameterized interfaces <code>svt\_axi\_master\_param\_if</code> and <code>svt\_axi\_slave\_param\_if</code>. These interfaces are parameterized for signal widths. The default value of all the parameters are same as the system constants defined in <code>svt\_axi\_port\_defines.svi</code> (see Section 3.3.9). These interface parameters can be changed to match the DUT signal widths. The parameter value should be less than or equal to the <code>system constant defined in svt\_axi\_port\_defines.svi</code> or <code>svt\_axi\_user\_defines.svi</code>.

To use parameterized interface, the user still needs to instantiate the top-level interface <code>svt\_axi\_if</code>. The <code>svt\_axi\_master\_param\_if</code> interface should be used for connecting AXI Master VIP component to the DUT and <code>svt\_axi\_slave\_param\_if</code> interface should be used to connect AXI Slave VIP component to the DUT.

For usage of parameterized interface, see the tb\_axi\_svt\_uvm\_basic\_param\_if\_sys example. The README file in the example describes the usage.

# 3.3.8 Transaction Status Tracking Methods and Events

Transaction status tracking methods provides information on the status of the data transfer at the interface. Different methods and events that you can make use of are as follows:

- Transaction Class Status Attributes
- Transaction Class Methods
- \* Events

#### 3.3.8.1 Transaction Class Status Attributes

Transaction class status attributes indicate status of transactions based on valid and ready signals of the axi interface. The status attributes are addr\_status, data\_status, and write\_resp\_status for address phase, data phase, and write response phase respectively. The status indicator strings are INITIAL, ACTIVE, ACCEPT, PARTIAL \_ACCEPT and ABORTED. HTML Class reference document provides detailed description on status strings and transaction status flow.

You can track the transaction flow through transaction object by referring these status indicator strings. This is helpful for transaction tracking in the log file.

#### **INITIAL**

Status is considered as INITIAL when valid and ready are both LOW on the channel

Example: Read addr\_status at INITIAL state is shown as follows:



The status indicates that master has not driven an address at the interface

#### **ACTIVE**

The Status is considered as ACTIVE when valid signal is HIGH with ready signal at LOW. If the VIP agent is driving a transaction, (that is, Active VIP Agents) the status will be set to ACTIVE when it asserts valid signal whereas if the VIP Agent is monitoring the transfer, (for example, Passive VIP Agents) the status will be set to ACTIVE at the event of sampling valid signal.

Example: Read addr\_status status changing to ACTIVE is illustrated as follows:



The status indicates that master has driven an address and is not yet accepted by the slave

#### ACCEPT

Status is considered as ACCEPT when the channel handshake is complete, that is when both ready and valid are both HIGH.

Example: Read addr\_status changing to ACCEPT is shown as follows:



The status indicates that the slave has accepted the address with awvalid-awready handshake

#### PARTIAL\_ACCEPT

PARTIAL\_ACCEPT status is applicable on read/write data channels incase of multi-beat or burst transfer. In case of multi-beat transfer, the transfer is complete only when the last beat data is transferred. Status is

considered as PARTIAL\_ACCEPT when a beat is completed with hand shake but the last beat data is not transferred. For example, In case of an INCR4 write, for beat 1-3, when wvalid and wready are both HIGH then the status is PARTIAL\_ACCEPT. The figure shows write data\_status as PARTIAL\_ACCEPT.



wlast at LOW indicate that the write data beats are not complete.

#### **ABORTED**

The status is considered as ABORTED when a transfer is canceled. This happens in case of a mid-simulation reset.

#### 3.3.8.2 Transaction Class Methods

- get\_begin\_time(): This method gives starting time of a transaction.
- ❖ get\_end\_time(): This method gives end time of a transaction.
- wait\_for\_transaction\_end(): This method waits for the transaction to end. In case of read transfer, the transaction ends when read response is complete with read response handshake.

Similarly, for write, the transaction ends when the write response handshake is complete.

#### 3.3.8.3 Events

VIP components issue transaction begin\_event and end\_event. These events are provided by the uvm library and they denote the start of transaction and end of transaction. These events are issued by the Master and Slave components as described below, in both active and passive mode.

- begin\_event: For WRITE transactions, begin\_event is issued on the rising clock edge when awvalid (for address before data) or wvalid (for data before address) is high. For READ transactions, begin\_event is issued on the rising clock edge when arvalid is high.
- end\_event: For WRITE transactions, the end\_event is issued on the rising clock edge when bvalid and bready both are high. For READ transactions, the end\_event is issued on the rising clock edge when rvalid, rlast and rready are high.

# 3.3.9 Overriding System Constants

The VIP uses include files to define system constants that, in some cases, you may override so the VIP matches your expectations. For example, you can override the maximum delay values. You can also adjust the default simulation footprint, like maximum address width.

The system constants for the VIP are specified (or referenced) in the following files (the first three files reside at \$DESIGNWARE\_HOME/vip/svt/amba\_svt/latest/sverilog/include):

svt\_axi\_defines.svi

Top-level include file. It allows for the inclusion of the common define symbols and the port define symbols in a single file. Also, it contains a `include to read user overrides if the `SVT\_AXI\_INCLUDE\_USER\_DEFINES symbol is defined.

#### \* svt axi common defines.svi

This file defines common constants used by the AXI VIP components. You can override only the User Definable constants, which are declared in ifndef statements, such as the following:

```
`ifndef SVT_AXI_MAX_ADDR_VALID_DELAY
  `define SVT_AXI_MAX_ADDR_VALID_DELAY 16
`endif
```

svt\_axi\_port\_defines.svi

This file contains the constants that set the default maximum footprint of the environment. These values determine the wire bit widths in the 'wire frame'-- they do not (necessarily) define the actual bit widths used by the components, which is determined by the configuration classes.

svt\_axi\_user\_defines.svi

This file contains override values that you define. This file can reside anywhere-- specify its location on the simulator command line.

To override the SVT\_AXI\_MAX\_ID\_WIDTH constant from the svt\_axi\_port\_defines.svi file,

\* Redefine the corresponding symbol in the svt\_axi\_user\_defines.svi file. For example:

```
`define SVT_AXI_MAX_ID_WIDTH 12
```

- In the simulator compile command,
  - ◆ Ensure that the directory containing svt\_axi\_user\_defines.svi is provided to the simulator
  - ◆ Provide SVT AXI INCLUDE USER DEFINES on the simulator command line as follows:

```
+define+SVT AXI INCLUDE USER DEFINES
```

Note the following restrictions when overriding the default maximum footprint:

- **❖** Do not use a value of 0 for a MAX ★ WDTH value. The value must be >= 1
- ❖ The maximum footprint set at compile time must work for the full design. If you are using multiple instances of AXI VIP, only one maximum footprint can be set and must therefore satisfy the largest requirement.
- \* The value of less than 32 is not supported for SVT\_AXI\_MAX\_ADDR\_WIDTH.

  SVT\_AXI\_MAX\_ADDR\_WIDTH only defines the footprint of address port. The actual used address with is defined by svt\_axi\_port\_configuration::addr\_width, which can still be configured to less than 32.

### 3.3.10 Support for TLM Generic Payload

The AXI VIP supports TLM Generic Payload feature where the user can develop sequences based on the uvm\_tlm\_generic\_payload transaction type. The AXI VIP then maps these Generic Payload sequences into AXI specific sequences.



This feature is supported for UVM flow only, for interface types AXI3 and AXI4. Also, TLM Generic Payload feature does not yet map TLM Generic Payload transactions to AXI transactions with burst length greater than 16.

## 3.3.10.1 Generating TLM Generic Payload Stimulus

By default, AXI stimulus is generated using svt\_axi\_master\_transaction sequence items in the AXI master agent sequencer. The bus-agnostic stimulus can be generated using uvm\_tlm\_generic\_payload sequence items.

You can enable this functionality by setting the svt\_axi\_port\_configuration::use\_tlm\_generic\_payload to '1' for the corresponding AXI master before that master's build\_phase is executed.

Enabling this functionality causes the instantiation of svt\_axi\_tlm\_generic\_payload\_sequencer in the svt\_axi\_master\_agent::tlm\_generic\_payload\_sequencer property and the execution of a layering sequence on the AXI transaction sequencer. The layering sequence pulls generated TLM generic payload sequence items from the generic payload sequencer, maps them to one or more AXI master transactions, and executes them on the driver. The layering sequence executes with a normal priority. It is still possible to execute normal AXI transaction sequences on the AXI transaction sequencer, in parallel with the TLM generic payload layering sequence.

The response from the execution of the generic payload item is annotated in the generic payload sequence item itelf. It is valid only when the completed generic payload sequence item is returned by the uvm\_sequence::get\_response() method.

The TLM generic payload sequence items are mapped into one or more AXI transactions that implement the semantics of the Generic Payload transaction, as defined by the TLM 2.0 standard. It is not possible to generate all possible AXI master transactions from generic payload stimulus.

# 7 Note

For demonstration of the usage, see the ts.tlm\_generic\_payload\_test.sv test present in the tb\_axi\_svt\_uvm\_intermediate\_sys example.

By default, generic payload WRITE and READ commands are mapped to WRITENOSNP and READNOSNP AXI transactions respectively, with a maximum 16-beat INCR burst and individual transfer size matching the configured port size. In case different AXI transactions are required, the generic payload sequence item must be annotated with an instance of the svt\_amba\_pv\_extension generic payload AMBA PV (Programmer's View) extension.

The various attributes of the AMBA PV extension can be set to specify the characteristics of the AXI transaction(s) used to implement the annotated generic payload transaction. Should the annotation be present, it will be further annotated with the relevant response from the execution of the AXI transactions. The relevant response will be annotated within the member svt\_amba\_pv\_extension::m\_response of svt\_amba\_pv\_response type.



For details of svt\_amba\_pv\_extension, see AXI UVM Class Reference HTML. See ts.amba\_pv\_test.sv test present in tb\_axi\_svt\_uvm\_intermediate\_sys example for demonstration of the usage.

#### 3.3.10.2 Connecting a TLM 2.0 Master

By default, TLM generic payload stimulus is generated using SystemVerilog sequences in the AXI master agent generic payload sequencer. If the TLM generic payload transactions are created by an ARM FastModel or a TLM Master model written in SystemC/SystemVerilog, it is possible to connect the AXI master agent to a TLM master. AXI Master agent component in the AMBA VIP provides required sockets for connecting to the TLM master.

Should the TLM Master be implemented in SystemC, you will need to connect the socket on the Master to the socket on the VIP using UVMConnect or VCS/TLI and convert the AMBA PV SystemC transactions to equivalent AMBA PV SystemVerilog transactions.

You can enable this functionality by setting the svt\_axi\_port\_configuration::use\_pv\_socket to '1' for the corresponding AXI master before that master's build\_phase is executed.

```
axi_env = axi_system_env::type_id::create("axi_env", this);
endfunction
```

Enabling this functionality implies the enabling of TLM generic payload stimulus (see Section 3.3.10.1).

Enabling this functionality causes the instantiation of an uvm\_tlm\_b\_target\_socket interface in the svt\_axi\_master\_agent::b\_fwd property and an uvm\_tlm\_b\_initiator\_socket interface in the svt\_axi\_master\_agent::b\_snoop property. Furthermore, the default run\_phase sequence for the ACE snoop response sequencer is replaced with a reactive sequence which forwards all ACE snoop transaction requests (translated to equivalent uvm\_tlm\_generic\_payload transactions annotated with a svt\_amba\_pv\_extension) to the backward svt\_axi\_master\_agent::b\_snoop interface to be fulfilled by the coherent TLM master. The coherent TLM master must provide the snoop response by providing the relevant cache line content in the data member of the uvm\_tlm\_generic\_payload and status information in the relevant fields of the attached svt\_amba\_pv\_extension.

In case the TLM master is not coherent, the AXI master agent can be re-configured to handle ACE snoop requests natively using its local cache model. The following is an example code snippet that can be used for this purpose:

```
uvm_config_db#(uvm_object_wrapper)::set("axi_env.master[2]",
    "snoop_sequencer.run_phase", "default_sequence",
    svt_axi_ace_master_snoop_response_sequence::type_id::get());
```

For demonstration of the usage for AXI3/4, see the ts.amba\_pv\_test.sv test within the tb\_axi\_svt\_uvm\_intermediate\_sys example. For demonstration of the usage for ACE, see tb\_axi\_svt\_uvm\_ace\_sys example.

# 3.3.10.3 Connecting a TLM 2.0 Slave

As Reactive agent, the sequence <code>svt\_axi\_slave\_tlm\_response\_sequence</code> in AXI Slave agent sequencer translates slave transactions into corresponding AMBA-PV extended TLM Generic Payload Transactions. This is applicable for TLM generic payload transactions created by an ARM.

FastModel or a TLM Slave model written in SystemC or SystemVerilog, connects the AXI Slave agent to a TLM Slave. The AMBA VIP provides the sockets required for connecting to the TLM slave in the AXI Slave agent component.

When the TLM Slave is implemented in SystemC, you will need to connect the socket on the Slave to the socket on the VIP using UVM Connect or VCS/TLI and convert AMBA PV SystemVerilog transactions to AMBA PV SystemC transactions.

# Note Note

Support for TLM GP in the AXI slave is through sockets. Therefore, the configuration attribute svt\_axi\_port\_configuration::use\_pv\_socket must be set to '1' to enable TLM GP at the slave for the corresponding AXI Slave before that slave's build phase is executed.

Enabling this functionality causes the instantiation of an uvm\_tlm\_b\_initiator\_socket interface in the svt\_axi\_slave\_agent::resp\_socket property.

For demonstration of the usage of AXI3 or AXI4, see ts.amba\_pv\_test.sv test within the tb\_axi\_svt\_uvm\_intermediate\_sys example.

# 3.4 Functional Coverage

The AXI VIP provides various levels of coverage support. This section describes those levels of support.

# 3.4.1 Default Coverage

The following sections describe the default coverage provided with AXI VIP. For more details on actual cover groups, see the AXI VIP Class Reference HTML document.

### 3.4.1.1 Toggle Coverage

Toggle coverage is a signal level coverage. Toggle coverage provides baseline information that a system is connected properly, and that higher level coverage or compliance failures are not simply the result of connectivity issues.

Toggle coverage answers the question: Did a bit change from a value of 0 to 1 and back from 1 to 0? This type of coverage does not indicate that every value of a multi-bit vector was seen but measures that all the individual bits of a multi-bit vector did toggle.

## 3.4.1.2 State Coverage

State coverage is a signal level coverage. State coverage applies to signals that are a minimum of two bits wide. In most cases, the states (also commonly referred to as coverage bins) can be easily identified as all possible combinations of the signal. For example, for the RRESP[1:0] signal, the states would be 00 (OKAY), 01 (EXOKAY), 10 (SLVERR) and 11 (DECERR). If the state space is too large, an intelligent classification of the states must be made.

In the case of the AWADDR signal, for example, coverage bins would be one bin to cover the lower address range, one bin to cover the upper address range and one bin to cover all other intermediary addresses.

### 3.4.1.3 Delay Coverage

Delay coverage is coverage on various delays between valid and ready signals. The following valid to ready delays are covered:

- Write Address handshake delay
- Read Address handshake delay
- Write Data handshake delay
- Read Data handshake delay
- **❖** Write Response handshake delay

# 3.4.1.4 Transaction Cross Coverage

Cross coverage specifies interesting cross coverage across AXI signals. Table 3-2 shows the cross coverage points.

Table 3-2 AXI3/4 Transaction Cross Coverage Matrix

| awburst/awburst | awlen/arlen | awaddr/araddr | awid/arid | awsize/arsize | wstrb | awlock/arlock | awcache/awcache | awprot/arprot | bresp/rresp | awqos/arqos | Cross Description                                                                                                                                                                                                 |
|-----------------|-------------|---------------|-----------|---------------|-------|---------------|-----------------|---------------|-------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| X               | Х           |               |           |               |       |               |                 |               |             |             | Cross all transaction types with certain ranges of lengths like SINGLE and BURSTS Covergroup names: trans_cross_axi_arburst_arlen trans_cross_axi_awburst_awlen                                                   |
| X               | X           | X             |           |               |       |               |                 |               |             |             | Cross all transaction types with all targets Covergroup names: trans_cross_axi_arburst_arlen_araddr trans_cross_axi_awburst_awlen_awaddr                                                                          |
| X               | Х           |               |           |               |       |               |                 |               | Х           |             | Cross all transaction types with all transaction responses Covergroup names: trans_cross_axi_arburst_arlen_rresp trans_cross_axi_awburst_awlen_bresp                                                              |
| X               | Х           |               |           | Х             |       |               |                 |               |             |             | Cross all transaction types with all transaction sizes Covergroup names: trans_cross_axi_arburst_arlen_arsize trans_cross_axi_awburst_awlen_awsize                                                                |
| Х               | Х           |               |           |               |       | Х             |                 |               |             |             | Cross all transaction types with all transaction access types Covergroup names: trans_cross_axi_arburst_arlen_arlock trans_cross_axi_awburst_awlen_awlock                                                         |
| Х               | Х           | Х             |           | Х             |       |               |                 |               |             |             | Cross all transaction types with all targets with all sizes to cover aligned and unaligned transactions Covergroup names: trans_cross_axi_arburst_arlen_araddr_arsize trans_cross_axi_awburst_awlen_awaddr_awsize |

Table 3-2 AXI3/4 Transaction Cross Coverage Matrix (Continued)

| awburst/awburst | awlen/arlen | awaddr/araddr | awid/arid | awsize/arsize | wstrb | awlock/arlock | awcache/awcache | awprot/arprot | bresp/rresp | awqos/arqos | Cross Description                                                                                                                                 |
|-----------------|-------------|---------------|-----------|---------------|-------|---------------|-----------------|---------------|-------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| X               | X           |               |           |               |       |               | X               |               |             |             | Cross all transaction types with all cache types Covergroup names: trans_cross_axi_arburst_arlen_arcache trans_cross_axi_awburst_awlen_awcache    |
| X               | X           |               |           |               |       |               |                 | X             |             |             | Cross all transaction types with all protection types Covergroup names: trans_cross_axi_arburst_arlen_arprot trans_cross_axi_awburst_awlen_awprot |
| X               |             |               |           |               |       |               |                 |               |             | Х           | Cross all transaction types with all QOS values Covergroup names: trans_cross_axi_arburst_arqos trans_cross_axi_awburst_awqos                     |

# 3.4.2 Coverage Callback Classes

### 3.4.2.1 Coverage Data Callback

This callback class defines default data and event information that are used to implement the coverage groups. The naming convention uses "def\_cov\_data" in the class names for easy identification of these classes. This class also includes implementations of the coverage methods that respond to the coverage requests by setting the coverage data and triggering the coverage events. This implementation does not include any coverage groups. The def\_cov\_data callbacks classes are extended from agent callback class.

Based on above, the coverage data callback class name is svt\_axi\_def\_cov\_data\_callbacks.

The following callback methods are implemented for triggering coverage events:

- pre\_output\_port\_put
- write\_address\_phase\_ended
- read\_address\_phase\_ended
- write\_data\_phase\_ended
- read\_data\_phase\_ended
- write\_resp\_phase\_ended

### 3.4.2.2 Coverage Callback

This class is extended from the coverage data callback class. The naming convention uses "def\_cov" in the class names for easy identification of these classes. It includes default cover groups based on the data and events defined in the data class.

The coverage callback class implementing default cover groups is called svt\_axi\_port\_monitor\_def\_cov\_callback.

# 3.4.3 Enabling Default Coverage

The default functional coverage can be enabled by setting the following attributes in the port configuration class svt\_axi\_port\_configuration to '1'. To disable coverage, set the attributes to '0'. The attributes are:

- toggle\_coverage\_enable
- state\_coverage\_enable
- transaction\_coverage\_enable

By default, the coverage is disabled.

# 3.4.4 Coverage Shaping and Control

The handle to the port configuration class svt\_axi\_port\_configuration is provided to the class svt\_axi\_port\_monitor\_def\_cov\_callback, which implements the default cover groups. Based on the port configuration, the coverage bins are shaped. The unwanted bins are ignored. For example, all the burst size bins greater than svt\_axi\_port\_configuration::data\_width are ignored.

In addition, you also have the ability to disable coverage at cover group level. Class svt\_axi\_port\_configuration provides members svt\_axi\_port\_configuration::<cover\_group\_name>\_enable, to enable/disable cover groups. By default, the value to these members is 1. For example, to disable cover group trans\_cross\_axi\_awburst\_awlen, member svt\_axi\_port\_configuration:: trans\_cross\_axi\_awburst\_awlen\_enable should be set to 0.

### 3.5 Protocol Checks

The protocol checks can be enabled by setting the configuration attribute protocol\_checks\_enable in class svt\_axi\_port\_configuration to '1'. To disable the checks, set the attribute to '0'. By default, the protocol checks are enabled.

# 3.5.1 Comprehensive List of Protocol Checks

Important AXI3/4 protocol checks are described in the following sections. For a comprehensive list of all protocol checks for AXI3/4 protocol, see the class svt\_axi\_checker in AXI VIP Class Reference HTML documentation.

Table 3-3 Write Address Channel Checks

| Protocol check                               | Check condition                            |
|----------------------------------------------|--------------------------------------------|
| signal_valid_awid_when_awvalid_high_check    | AWID is not X or Z when AWVALID is high    |
| signal_valid_awaddr_when_awvalid_high_check  | AWADDR is not X or Z when AWVALID is high  |
| signal_valid_awlen_when_awvalid_high_check   | AWLEN is not X or Z when AWVALID is high   |
| signal_valid_awsize_when_awvalid_high_check  | AWSIZE is not X or Z when AWVALID is high  |
| signal_valid_awburst_when_awvalid_high_check | AWBURST is not X or Z when AWVALID is high |
| signal_valid_awlock_when_awvalid_high_check  | AWLOCK is not X or Z when AWVALID is high  |

Table 3-3 Write Address Channel Checks (Continued)

| Protocol check                                | Check condition                                                                 |
|-----------------------------------------------|---------------------------------------------------------------------------------|
| signal_valid_awcache_when_awvalid_high_check  | AWCACHE is not X or Z when AWVALID is high                                      |
| signal_valid_awprot_when_awvalid_high_check   | AWPROT is not X or Z when AWVALID is high                                       |
| signal_valid_awready_when_awvalid_high_check  | AWREADY is not X or Z when AWVALID is high                                      |
|                                               |                                                                                 |
| signal_stable_awid_when_awvalid_high_check    | AWID is stable when AWVALID is high                                             |
| signal_stable_awaddr_when_awvalid_high_check  | AWADDR is stable when AWVALID is high                                           |
| signal_stable_awlen_when_awvalid_high_check   | AWLEN is stable when AWVALID is high                                            |
| signal_stable_awsize_when_awvalid_high_check  | AWSIZE is stable when AWVALID is high                                           |
| signal_stable_awburst_when_awvalid_high_check | AWBURST is stable when AWVALID is high                                          |
| signal_stable_awlock_when_awvalid_high_check  | AWLOCK is stable when AWVALID is high                                           |
| signal_stable_awcache_when_awvalid_high_check | AWCACHE is stable when AWVALID is high                                          |
| signal_stable_awprot_when_awvalid_high_check  | AWPROT is stable when AWVALID is high                                           |
|                                               |                                                                                 |
| signal_valid_awvalid_check                    | AWVALID is not X or Z                                                           |
| awvalid_interrupted_check                     | AWVALID was interrupted before awready got asserted                             |
| awburst_reserved_val_check                    | The value of awburst=2'b11 when awvalid is high                                 |
| awvalid_awcache_active_check                  | The value of awcache[3:2]=2'b00 when awvalid is high and awcache[1] is also low |
| awsize_data_width_active_check                | size of write transfer exceeds the width of the data bus                        |
| awaddr_wrap_aligned_active_check              | write burst of WRAP type has an aligned address                                 |
| awlen_wrap_active_check                       | write burst of WRAP type has a valid length                                     |
| awaddr_4k_boundary_cross_active_check         | write burst cross a 4KB boundary                                                |

Table 3-4 Write Data Channel Checks

| Protocol check                             | Check condition                          |
|--------------------------------------------|------------------------------------------|
| signal_valid_wid_when_wvalid_high_check    | WID is not X or Z when WVALID is high    |
| signal_valid_wdata_when_wvalid_high_check  | WDATA is not X or Z when WVALID is high  |
| signal_valid_wstrb_when_wvalid_high_check  | WSTRB is not X or Z when WVALID is high  |
| signal_valid_wlast_when_wvalid_high_check  | WLAST is not X or Z when WVALID is high  |
| signal_valid_wready_when_wvalid_high_check | WREADY is not X or Z when WVALID is high |

Table 3-4 Write Data Channel Checks (Continued)

| Protocol check                                   | Check condition                                                            |
|--------------------------------------------------|----------------------------------------------------------------------------|
|                                                  |                                                                            |
| signal_stable_wid_when_wvalid_high_check         | WID is stable when WVALID is high                                          |
| signal_stable_wdata_when_wvalid_high_check       | WDATA is stable when WVALID is high                                        |
| signal_stable_wstrb_when_wvalid_high_check       | WSTRB is stable when WVALID is high                                        |
| signal_stable_wlast_when_wvalid_high_check       | WLAST is stable when WVALID is high                                        |
|                                                  |                                                                            |
| signal_valid_wvalid_check                        | WVALID is not X or Z                                                       |
| wvalid_interrupted_check                         | WVALID was interrupted before WREADY got asserted                          |
| wdata_awlen_match_for_corresponding_awaddr_check | The number of write data items matches AWLEN for the corresponding address |

Table 3-5 Write Response Channel Checks

| Protocol check                             | Check condition                                                                                    |
|--------------------------------------------|----------------------------------------------------------------------------------------------------|
| signal_valid_bid_when_bvalid_high_check    | BID is not X or Z when BVALID is high                                                              |
| signal_valid_bresp_when_bvalid_high_check  | BRESP is not X or Z when BVALID is high                                                            |
| signal_valid_bready_when_bvalid_high_check | BREADY is not X or Z when BVALID is high                                                           |
|                                            |                                                                                                    |
| signal_stable_bid_when_bvalid_high_check   | BID is stable when BVALID is high                                                                  |
| signal_stable_bresp_when_bvalid_high_check | BRESP is stable when BVALID is high                                                                |
|                                            |                                                                                                    |
| signal_valid_bvalid_check                  | BVALID is not X or Z                                                                               |
| write_resp_follows_last_write_xfer_check   | A transaction with corresponding ID whose data phase is complete, when a write response is sampled |
| wlast_asserted_for_last_write_data_beat    | WLAST is asserted for the last beat of write data                                                  |
| bvalid_interrupted_check                   | bvalid was interrupted before bready got asserted                                                  |
| write_resp_after_last_wdata_check          | The slave must only give a write response after the last write data item is transferred            |
| write_resp_after_write_addr_check          | A slave must not give a write response before the write address                                    |

Table 3-6 Read Address Channel Checks

| Protocol check                                | Check condition                                                                 |
|-----------------------------------------------|---------------------------------------------------------------------------------|
| signal_valid_arid_when_arvalid_high_check     | ARID is not X or Z when ARVALID is high                                         |
| signal_valid_araddr_when_arvalid_high_check   | ARADDR is not X or Z when ARVALID is high                                       |
| signal_valid_arlen_when_arvalid_high_check    | ARLEN is not X or Z when ARVALID is high                                        |
| signal_valid_arsize_when_arvalid_high_check   | ARSIZE is not X or Z when ARVALID is high                                       |
| signal_valid_arburst_when_arvalid_high_check  | ARBURST is not X or Z when ARVALID is high                                      |
| signal_valid_arlock_when_arvalid_high_check   | ARLOCK is not X or Z when ARVALID is high                                       |
| signal_valid_arcache_when_arvalid_high_check  | ARCACHE is not X or Z when ARVALID is high                                      |
| signal_valid_arprot_when_arvalid_high_check   | ARPROT is not X or Z when ARVALID is high                                       |
| signal_valid_arready_when_arvalid_high_check  | ARREADY is not X or Z when ARVALID is high                                      |
|                                               |                                                                                 |
| signal_stable_arid_when_arvalid_high_check    | ARID is stable when ARVALID is high                                             |
| signal_stable_araddr_when_arvalid_high_check  | ARADDR is stable when ARVALID is high                                           |
| signal_stable_arlen_when_arvalid_high_check   | ARLEN is stable when ARVALID is high                                            |
| signal_stable_arsize_when_arvalid_high_check  | ARSIZE is stable when ARVALID is high                                           |
| signal_stable_arburst_when_arvalid_high_check | ARBURST is stable when ARVALID is high                                          |
| signal_stable_arlock_when_arvalid_high_check  | ARLOCK is stable when ARVALID is high                                           |
| signal_stable_arcache_when_arvalid_high_check | ARCACHE is stable when ARVALID is high                                          |
| signal_stable_arprot_when_arvalid_high_check  | ARPROT is stable when ARVALID is high                                           |
|                                               |                                                                                 |
| signal_valid_arvalid_check                    | ARVALID is not X or Z                                                           |
| arvalid_interrupted_check                     | ARVALID was interrupted before arready got asserted                             |
| arburst_reserved_val_check                    | The value of ARBURST=2'b11 when arvalid is high                                 |
| arvalid_arcache_active_check                  | The value of ARCACHE[3:2]=2'b00 when arvalid is high and ARCACHE[1] is also low |
| arsize_data_width_active_check                | Size of read transfer exceeds the width of the data bus                         |
| araddr_wrap_aligned_active_check              | Read burst of WRAP type has an aligned address                                  |
| arlen_wrap_active_check                       | Read burst of WRAP type has a valid length                                      |
| araddr_4k_boundary_cross_active_check         | Read burst cross a 4KB boundary                                                 |

Table 3-7 Read Data Channel Checks

| Protocol check                                   | Check condition                                                           |
|--------------------------------------------------|---------------------------------------------------------------------------|
| signal_valid_rid_when_rvalid_high_check          | RID is not X or Z when RVALID is high                                     |
| signal_valid_rdata_when_rvalid_high_check        | RDATA is not X or Z when RVALID is high                                   |
| signal_valid_rresp_when_rvalid_high_check        | RRESP is not X or Z when RVALID is high                                   |
| signal_valid_rlast_when_rvalid_high_check        | RLAST is not X or Z when RVALID is high                                   |
| signal_valid_rready_when_rvalid_high_check       | RREADY is not X or Z when RVALID is high                                  |
|                                                  |                                                                           |
| signal_stable_rid_when_rvalid_high_check         | RID is stable when RVALID is high                                         |
| signal_stable_rdata_when_rvalid_high_check       | RDATA is stable when RVALID is high                                       |
| signal_stable_rresp_when_rvalid_high_check       | RRESP is stable when RVALID is high                                       |
| signal_stable_rlast_when_rvalid_high_check       | RLAST is stable when RVALID is high                                       |
|                                                  |                                                                           |
| read_data_follows_addr_check                     | Sample read data has associated address                                   |
| signal_valid_rvalid_check                        | RVALID is not X or Z                                                      |
| rvalid_interrupted_check                         | RVALID was interrupted before rready got asserted                         |
| rdata_arlen_match_for_corresponding_araddr_check | The number of read data items matches ARLEN for the corresponding address |

# 3.5.2 AXI4 Protocol Checks

Table 3-8 Write Address Channel Checks

| Protocol check                                 | Check condition                             |
|------------------------------------------------|---------------------------------------------|
| signal_valid_awqos_when_awvalid_high_check     | AWQOS is not X or Z when AWVALID is high    |
| signal_valid_awregion_when_awvalid_high_check  | AWREGION is not X or Z when AWVALID is high |
| signal_valid_awuser_when_awvalid_high_check    | AWUSER is not X or Z when AWVALID is high   |
|                                                |                                             |
| signal_stable_awqos_when_awvalid_high_check    | AWQOS is stable when AWVALID is high        |
| signal_stable_awregion_when_awvalid_high_check | AWREGION is stable when AWVALID is high     |
| signal_stable_awuser_when_awvalid_high_check   | AWUSER is stable when AWVALID is high       |

#### Table 3-9 Write Data Channel Checks

| Protocol check                             | Check condition                         |
|--------------------------------------------|-----------------------------------------|
| signal_valid_wuser_when_wvalid_high_check  | WUSER is not X or Z when WVALID is high |
| signal_stable_wuser_when_wvalid_high_check | WUSER is stable when WVALID is high     |

#### Table 3-10 Write Response Channel Checks

| Protocol check                             | Check condition                         |
|--------------------------------------------|-----------------------------------------|
| signal_valid_buser_when_bvalid_high_check  | BUSER is not X or Z when BVALID is high |
| signal_stable_buser_when_bvalid_high_check | BUSER is stable when BVALID is high     |

#### Table 3-11 Read Address Channel Checks

| Protocol check                                 | Check condition                             |  |  |
|------------------------------------------------|---------------------------------------------|--|--|
| signal_valid_arqos_when_arvalid_high_check     | ARQOS is not X or Z when ARVALID is high    |  |  |
| signal_valid_arregion_when_arvalid_high_check  | ARREGION is not X or Z when ARVALID is high |  |  |
| signal_valid_aruser_when_arvalid_high_check    | ARUSER is not X or Z when ARVALID is high   |  |  |
|                                                |                                             |  |  |
| signal_stable_arqos_when_arvalid_high_check    | ARQOS is stable when ARVALID is high        |  |  |
| signal_stable_arregion_when_arvalid_high_check | ARREGION is stable when ARVALID is high     |  |  |
| signal_stable_aruser_when_arvalid_high_check   | ARUSER is stable when ARVALID is high       |  |  |

#### Table 3-12 Read Data Channel Checks

| Protocol check                             | Check condition                         |  |
|--------------------------------------------|-----------------------------------------|--|
| signal_valid_ruser_when_rvalid_high_check  | RUSER is not X or Z when RVALID is high |  |
| signal_stable_ruser_when_rvalid_high_check | RUSER is stable when RVALID is high     |  |

# 3.6 Reset Functionality

The AXI VIP samples the assertion of reset signal asynchronously, and de-assertion of reset signal asynchronously. When reset is de-asserted, VIP detects it with or without clock being present. However, it starts driving or sampling signals from the first clock edge received after the reset is de-asserted.

The AXI port configuration attribute svt\_axi\_port\_configuration::reset\_type controls the behavior of AXI VIP during the reset.

# 3.6.1 Behavior when svt\_axi\_port\_configuration::reset\_type = EXCLUDE\_UNSTARTED\_XACT (default value)

When reset signal is asserted, all the transactions in the master and slave agents whose address, data, response phases that are in progress are ABORTED. All the aborted transactions are provided from the analysis port <code>item\_observed\_port</code> of the master and slave agents. The <code>addr\_status</code>, <code>data\_status</code>, and

write\_resp\_status fields of these transactions reflect the value as ABORTED. The transactions which are not yet started by the master agent are resumed after the reset signal of master agent is de-asserted. For READ or WRITE transactions whose address phase is complete, and the data or response phase is in progress, the transaction ENDED notification is issued on the rising edge of the clock during reset signal assertion.

# 3.6.2 Behavior when svt\_axi\_port\_configuration::reset\_type reset\_type = RESET\_ALL\_XACT

When reset signal is asserted, all the transactions in master and slave agents are ABORTED. For the master agent, this includes the transactions whose address, data, response phases are in progress, and also the transactions that are not yet started by the master agent (present in the active queue). All the aborted transactions are provided from the analysis port <code>item\_observed\_port</code> of the master and slave agents. The <code>addr\_status</code>, <code>data\_status</code>, and <code>write\_resp\_status</code> fields of these transactions reflect the value as <code>ABORTED</code>. For <code>READ</code> or <code>WRITE</code> transactions whose address phase is complete, and the data or response phase is in progress, transaction ENDED notification is issued on the rising edge of the clock during reset signal assertion.

# 3.7 Support for ACE Protocol in AXI Master Agent

The AXI VIP supports the ARM ACE protocol specification. This support is provided in the axi\_master\_agent\_svt component. The axi\_master\_agent\_svt component contains a snoop response generator, which responds back to the snoop transactions. It also contains a cache model.

The axi\_master\_agent\_svt component supports the following:

- Generating coherent transactions.
- Responding to snoop transactions.
- Allocating data and updating state of the cache model, based on generated coherent transactions and received snoop transactions.
- **❖** Back door access to the cache in the master.

# 3.7.1 Support for Coherent Transactions

When the svt\_axi\_port\_configuration::axi\_interface\_type is AXI\_ACE, all transactions are of type COHERENT, that is, svt\_axi\_transaction::xact\_type is COHERENT. You will set the different types of coherent transactions in svt\_axi\_transaction::coherent\_xact\_type.

The following section describes the behavior of the AXI master VIP for each of the coherent transaction types. See ACE protocol specification for a list of start states and expected end states for each of the transaction types. State transitions of the cache model conform to those specified in the ACE protocol specification.

### 3.7.1.1 ReadNoSnoop

#### **Before transmission:**

A ReadNoSnoop transaction is always sent out on the bus.

After read response completion and before RACK transmission:

No allocation is made.

#### 3.7.1.2 ReadOnce

**Before Transmission:** 

A ReadOnce transaction is always sent out on the bus.

# After read response completion and before RACK transmission:

No Allocation is made.

### 3.7.1.3 ReadClean/ReadShared/ReadNotSharedDirty

#### **Before Transmission:**

If cache line state is anything other than Invalid, the transaction is not sent out on the bus. Instead, the data in cache is returned in member svt\_axi\_transaction::data[]. Otherwise, the transaction is transmitted on the bus.

### After read response completion and before RACK transmission:

Cache allocation is made based on the data available in svt\_axi\_transaction::data[].

# 3.7.1.4 ReadUnique

Such a transaction is normally used when a master wants to do a partial write and it does not have a copy of the line. So it gets a unique copy and then stores into the line.

#### **Before transmission:**

If cache line state is anything other than Invalid, the transaction is not sent out on the bus. Instead, the data in cache is returned in member svt\_axi\_transaction::data[]. Otherwise, the transaction is sent out on the bus.

### After read response completion and before RACK transmission:

If svt\_axi\_transaction::allocate\_in\_cache is set, cache is allocated. The data to be allocated must be set in member svt\_axi\_transaction::cache\_write\_data. The value of member svt\_axi\_transaction::cache\_write\_data[] can be programmed upfront, or can also be updated in the pre\_cache\_update callback. If the svt\_axi\_transaction::allocate\_in\_cache bit is not set, the data available in the svt\_axi\_transaction::data[] field is stored in the cache.

### 3.7.1.5 CleanUnique

This transaction is normally used when a master wants to do a partial write and has a copy of the line. So it invalidates the line in all other masters and causes dirty data to be written to memory.

#### **Before transmission:**

Transaction is transmitted only if the state of cache line is NOT Unique.

### After read response completion and before RACK transmission:

If svt\_axi\_transaction::allocate\_in\_cache is set, cache is allocated. The data to be allocated must be set in member svt\_axi\_transaction::cache\_write\_data. The value of member svt\_axi\_transaction::cache\_write\_data[] can be programmed upfront, or can also be updated in the pre\_cache\_update callback.

#### 3.7.1.6 CleanShared

#### **Before transmission:**

If the line was in a UniqueClean state, the transaction is not transmitted. If the line is in a dirty state, the VIP automatically generates a WRITEBACK or WRITECLEAN transaction to first write data to memory. The property svt\_axi\_transaction::is\_auto\_generated is set for the WRITEBACK/WRITECLEAN transaction which is auto generated by the VIP. After the WRITEBACK/WRITECLEAN transaction is sent, the CLEANSHARED transaction is sent.

# After read response completion and before RACK transmission:

There is no change in the data in cache. Only the state of the cache line changes.

#### 3.7.1.7 CleanInvalid

#### **Before transmission:**

If the line is in a dirty state, the VIP automatically generates a writeback or writeclean transaction to first write data to memory. The property svt\_axi\_transaction::is\_auto\_generated is set for the writeback/writeclean transaction which is auto generated by the VIP. After the writeback/writeclean transaction is sent, the Cleaninvalid transaction is sent.

# After read response completion and before RACK transmission:

No allocation in cache is made.

# 3.7.1.8 MakeUnique

#### **Before Transmission:**

If line is already in unique state, transaction is not transmitted on the bus. Else, transaction is transmitted.

# After read response completion and before RACK transmission:

Model automatically allocates the cache line, and stores the data in member svt\_axi\_transaction::cache\_write\_data[] into the cache line. The value of member svt\_axi\_transaction::cache\_write\_data[] can be programmed upfront, or can also be updated in the pre\_cache\_update callback.

#### 3.7.1.9 MakeInvalid

#### **Before Transmission:**

If the line is in Valid state, the line is first invalidated.

#### After read response completion and before RACK transmission:

Line should be in Invalid state. No data is stored in cache.

#### 3.7.1.10 WriteNoSnoop

#### **Before Transmission:**

WriteNoSnoop transaction is transmitted if cache line is in UniqueClean or UniqueDirty state.

#### After write response completion and before WACK transmission:

The cache line state becomes UniqueClean.

### 3.7.1.11 WriteUnique/WriteLineUnique

#### **Before transmission:**

Transaction is dropped if cache line is not in required state.

# After write response completion and before WACK transmission:

There is no change in the state or the contents of the cache.

#### 3.7.1.12 WriteBack

#### **Before transmission:**

If line is not in dirty state, the transaction is dropped.

# After write response completion and before WACK transmission:

Line is invalidated in the cache.

#### 3.7.1.13 WriteClean

#### **Before transmission:**

If line is not in dirty state, the transaction is dropped.

# After write response completion and before WACK transmission:

Line remains allocated in the cache.

#### 3.7.1.14 Evict

#### Before transmission:

If the line is not in Clean state, transaction is dropped.

### After write response completion and before WACK transmission:

Line is invalidated in the cache.

# 3.7.2 Support for Snoop Transactions

For received snoop transaction types, the snoop response confirms to ACE protocol specification. The snoop response is provided by the snoop response sequencer within the Master Agent. You need to create a snoop response sequence and register it with the snoop response sequencer within the Master Agent. The snoop response sequence may provide a random snoop response, or a snoop response based on the state of the cache within the Master Agent.

#### 3.7.3 Back Door Access to the Cache

The user can directly access the cache instantiated in the master to read and write information, and to set and get cache line state. The method svt\_axi\_master\_agent::get\_cache() returns a handle to the cache instantiated in the master. The returned handle is of type svt\_axi\_cache.

Data can be written into the cache using method svt\_axi\_cache::write(). The cache state can also be optionally updated using this method. Data and cache line state can be read from the cache using methods svt\_axi\_cache::read\_by\_addr() or svt\_axi\_cache::read\_by\_index().

The method svt\_axi\_cache::get\_any\_index() can be used to obtain index of a cache line within the cache. Methods svt\_axi\_cache::invalidate\_addr(), svt\_axi\_cache::invalidate\_index() and svt\_axi\_cache::invalidate\_all() can be used to invalidate cache line entries within the cache.

For more details on accessing the cache, see the Class Reference HTML documentation of svt\_axi\_cache class.

### 3.7.4 Support for Barrier Transactions

The AXI VIP supports Barrier protocol as defined in the ACE protocol specification. This support is provided in the axi\_master\_agent\_svt component.

#### 3.7.4.1 Barrier Transaction Generation

The AXI VIP master can be enabled to generate barrier transactions by programming the port configuration member svt axi port configuration::barrier enable to '1'. You can program barrier transactions using

member svt\_axi\_transaction::barrier\_type. You should generate the barrier transaction pair on read address and write address channels.

If the delay between barrier transactions belonging to a barrier pair exceeds the value specified by svt\_axi\_port\_configuration::barrier\_watchdog\_timeout, the VIP master would issue a fatal message.

# 3.7.4.2 Associating a Normal Transaction with Barrier Transaction

A normal transaction be specified as a post-barrier transaction, and can be associated with a barrier transaction pair. When a normal transaction is associated with a barrier transaction pair, this transaction will be blocked till both read and write transactions belonging to barrier pair complete.

You can specify whether a normal transaction needs to be associated to a barrier transaction pair by setting member svt\_axi\_transaction::associate\_barrier to '1'. If this member is set to '1', the VIP can either automatically associate this transaction with one of the outstanding barrier transaction pairs, or the association can be defined by the user. This can be controlled using member svt\_axi\_port\_configuration::barrier\_association\_type.

When barrier\_association\_type is defined as RANDOM\_ASSOCIATION, the VIP master automatically associates the normal transaction with one of the outstanding barrier transaction pairs. When barrier\_association\_type is defined as USER\_DEFINED\_ASSOCIATION, you need to implement the callback method svt\_axi\_master\_callback::associate\_xact\_to\_barrier\_pair (svt\_axi\_master\_transaction xact, svt\_axi\_barrier\_pair\_transaction barrier\_xact[\$]).

# **J** Note

The barrier\_association\_type RANDOM\_ASSOCIATION is currently not supported.

The arguments of this callback method are,

- Handle to the normal transaction with which Barrier pair needs to be associated
- List of outstanding barrier transaction pairs, to which the normal transaction can be associated

You can associate the normal transaction to any of the outstanding barrier transaction pairs. This association can be done using member svt\_axi\_transaction::associated\_barrier\_xact, which is of class type svt\_axi\_barrier\_pair\_transaction. After implementing the callback, you should append the callback class to the master driver. The above callback method is called under following conditions:

- 1. svt\_axi\_port\_configuration::barrier\_enable is set to '1'
- 2. svt axi transaction::associate barrier is set to '1'
- 3. svt\_axi\_transaction::associated\_barrier\_xact is null. If svt\_axi\_transaction::associated\_barrier\_xact is not null, it implies that user has already associated this transaction with a barrier pair

The barrier pair is represented by an object of type svt\_axi\_barrier\_pair\_transaction. This object contains handles to read barrier and write barrier transactions, which are of type svt\_axi\_master\_transaction.



When a normal transaction is associated to the barrier pair as a post barrier transaction, all the other transactions specified after the post barrier transaction would also get blocked, till the post barrier transaction is transmitted.

#### 3.7.4.3 IDs for Barrier Transactions

The specification requires that Barrier transactions use different ID values than are in use for non-barrier transactions. To support this, the VIP allows you to specify a range of ID values which can be used for Barrier transactions. The VIP will then validate that the ID specified for Barrier transactions is within this range, and ID specified for normal transactions is outside this range. An error message is issued if this

condition is not met. This ensures that Barrier transactions and normal transactions use a mutually exclusive set of IDs.

The range of ID values which can be used for Barrier transactions are specified using members svt\_axi\_port\_configuration::barrier\_id\_min and svt\_axi\_port\_configuration::barrier\_id\_max. The non-barrier transactions should use the ID values outside this range.

# 3.7.4.4 Outstanding Barrier Transactions

Member svt\_axi\_port\_configuration::num\_outstanding\_xact specifies the total number of outstanding transactions. Barrier transactions are considered as part of this total number of outstanding transactions. That is, total of normal outstanding transactions and barrier outstanding transactions will not exceed svt\_axi\_port\_configuration::num\_outstanding\_xact.

# 3.7.5 Support for DVM Transactions

The AXI VIP supports DVM protocol as defined in the ACE protocol specification. This support is provided in the <code>axi\_master\_agent\_svt</code> component. The AXI VIP supports DVM Operations, DVM Sync and DVM Complete transactions.



As per Specification section C12.2 A, a component must have only one outstanding DVM Sync transaction. A component must receive a DVM Complete transaction before it issues another DVM Sync transaction, but VIP currently blocks all transaction driving (and not just next DVMSYNC), till DVMCOMPLETE comes back for recently completed DVMSYNC.

#### 3.7.5.1 DVM Transaction Generation

The AXI VIP master can be enabled to generate DVM transactions by programming the port configuration member svt\_axi\_port\_configuration::dvm\_enable to '1'. You can program DVM transactions by programming member svt\_axi\_transaction::coherent\_xact\_type to DVMMESSAGE or DVMCOMPLETE. You might need to program the values of field svt\_axi\_transaction::addr to specify the message type. The values specified in this field would get driven on the ARADDR signals. The svt\_axi\_master\_transaction has pre-defined constraints to constrain the values of other fields, when transaction is of type DVM, as required by the ACE protocol specification.

#### 3.7.5.2 Generation of DVM Sync

Behavior of DVM Sync generation is as described below based on ACE protocol specification:

- 1. When you generate a DVM Sync using master VIP, the master VIP would transmit it only if there are preceding DVM Operations. If a DVM Sync is generated right after another DVM Sync, then the second DVM Sync would be dropped.
- 2. If you attempt to transmit a new DVM Sync, without having received DVM Complete for previous DVM Sync, the new DVM Sync will be stalled till DVM Complete for previous DVM Sync is received.

### 3.7.5.3 Generation of DVM Complete

The Automatic generation of DVM Complete in response to the DVM Sync is not currently supported. However, this feature will be supported in future releases.

# 3.7.5.4 IDs for DVM Transactions

The specification requires that DVM transactions use different ID values than are in use for non-DVM transactions. To support this, the VIP allows you to specify a range of ID values which can be used for DVM

transactions. The VIP will then validate that the ID specified for DVM transactions is within this range, and ID specified for normal transactions is outside this range. An error message is issued if this condition is not met. This ensures that DVM transactions and normal transactions use a mutually exclusive set of IDs.

The range of ID values which can be used for DVM transactions are specified using members svt\_axi\_port\_configuration::dvm\_id\_min and svt\_axi\_port\_configuration::dvm\_id\_max. The non-DVM transactions should use the ID values outside this range.

#### 3.7.5.5 Multi-Part DVM

VIP supports multi-part DVM operation both in active and passive mode. In passive mode, it detects multipart DVM operation and performs checking associated protocol rules. In active mode, once VIP receives transactions generated from sequence, it first tries to identify multi-part DVM operation and checks all associated rules. If it detects another transaction between the two parts of the multi-part DVM message, then the master VIP drops the transaction and issues an ERROR message. Dropped transaction is not driven on the bus. The transaction which is dropped in such a manner is still written to the analysis port, with the bit svt\_axi\_transaction::is\_coherent\_xact\_dropped set to 1. This signifies that the transaction was dropped by the master VIP and was not actually driven on the bus.



Built-in sequence svt\_axi\_ace\_master\_multipart\_dvm\_virtual\_sequence is provided as part of the VIP to generate Multi-Part DVM scenario from master VIP.

### **Programming Multi-part DVM with VIP**

Set addr[0] to 1, you need to switch off the following constraint before randomizing:

```
tr1.reasonable_no_multi_part_dvm.constraint_mode(0);
```

You should continue to switch off constraint block and as well call following transaction task before randomization:

```
tr2.set_multipart_dvm_flag();
tr2.reasonable_no_multi_part_dvm.constraint_mode(0);
```

## 3.7.6 Support for ACE-Lite

ACE-Lite mode is enabled when svt\_axi\_port\_configuration::axi\_interface\_type is set to ACE\_LITE. In ACE-Lite mode, the Master VIP transmits only following type of coherent transactions, as per the ACE protocol specification:

- ReadNoSnoop
- ReadOnce
- CleanShared
- CleanInvalid
- ❖ MakeInvalid
- WriteNoSnoop
- WriteUnique
- WriteLineUnique
- Barrier

If you try to send any other coherent transaction type which is not valid in ACE-Lite mode, the Master VIP will issue a fatal message. The svt\_axi\_master\_transaction class contains constraints such that when the

master transaction is randomized, only valid coherent transaction types will be generated in ACE-Lite mode.

In ACE-Lite mode, the un-used signals are driven to Z.

# 3.7.7 Support for ACE Domain

You can program the domain using field svt\_axi\_transaction::domain\_type. If you program a domain type which violates the combination with AxCACHE, AxSNOOP and AxBAR signals, the master VIP would issue a fatal message. The svt\_axi\_master\_transaction class contains constraints such that when the master transaction is randomized, only valid combinations of AxDOMAIN, AxCACHE, AxSNOOP and AxBAR signals are generated.

# 3.7.8 Support for Speculative Read

Support for speculative read feature can be enabled by programming the port configuration member svt\_axi\_port\_configuration::speculative\_read\_enable to 1.

A speculative read is defined as a read of a cache line that a master may already be holding in its cache. Consider a case when user generates a coherent transaction for read of a cache line that a master already holds in its cache.

When speculative read is enabled, the master will transmit this coherent transaction. Also, the master will support cache state transitions as defined in second set of tables in chapter C4 of ACE protocol specification.

When speculative read is disabled, the master will not transmit this coherent transaction. In this case, the master will only support cache state transitions as defined in first set of tables in chapter C4 of ACE protocol specification.

Whether a transaction is a speculative read is indicated by read-only transaction class member svt\_axi\_transaction::is\_speculative\_read.

# 3.7.9 Support for Snoop Filtering

Support for snoop filtering can be enabled by programming the port configuration member svt\_axi\_port\_configuration::snoop\_filter\_enable to 1. When snoop filtering is enabled in the master VIP, cache state transitions to "Legal End State (with snoop filter)" as specified in tables in chapter C4 of ACE protocol specification, are allowed. These cache state transitions can be done using transaction class member svt\_axi\_transaction::force\_to\_shared\_state, and by setting

svt\_axi\_port\_configuration::cache\_line\_state\_change\_type to LEGAL WITH SNOOP FILTER CACHE LINE STATE CHANGE.

When snoop filtering is enabled, Master VIP would automatically generate evict transactions, when Master VIP removes a cache line to make space to allocate a new cache line.

# 3.7.10 Cache State Transitions to Legal End States

Tables in chapter C4 of ACE protocol specification specify a set of legal end states (with snoop filter and without snoop filter), in addition to the expected end states. The Master VIP can support cache state transitions to these legal end states using the following members:

- svt\_axi\_port\_configuration::cache\_line\_state\_change\_type
- svt\_axi\_transaction::force\_to\_shared\_state
- \* svt axi transaction::force to invalid state

For details of the members, see the AXI VIP Class Reference HTML documentation.

# 3.7.11 Support for ACE Exclusive Access

The ACE Master model supports the ACE Exclusive access. The master VIP implements a master exclusive monitor. This exclusive monitor is used to monitor the address location used by an Exclusive sequence. This master exclusive monitor is used to determine if another master could have performed a store to the address location during the Exclusive sequence, by monitoring the snoop transaction it receives.

When the master performs an Exclusive Load, the master exclusive monitor is set. The master exclusive monitor is reset when a snoop transaction is observed that indicates another master could perform a store to the location.

Only one outstanding exclusive transaction is allowed, that is, while an exclusive transaction is in progress, any new exclusive transaction will be blocked for execution by master until the completion of the outstanding exclusive transaction.

#### 3.7.11.1 Exclusive Load

This section explains the behavior of the ACE Master VIP with respect to the exclusive load.

If a cache line is either in unique or shared state, then master will not initiate the exclusive load transaction on to the interface. This is based on the below description provided in Chapter "Exclusive Accesses" of the ACE protocol specification.

- ❖ If the master holds a copy of the line in a Unique state, then issuing a transaction for the Exclusive Load is permitted, but not recommended.
- If the master holds a copy of the line in a Shared state then issuing a transaction for the Exclusive Load is permitted, but not required

#### 3.7.11.2 Exclusive Store

This section explains the behavior of the ACE Master VIP with respect to the exclusive store.

- 1. Exclusive store transaction will not be allowed without a prior exclusive load transaction, hence it will be dropped. All dropped exclusive store transactions will be tagged with svt\_axi\_transaction::is\_coherent\_xact\_dropped set to '1'.
- 2. If the master receives OKAY response to an exclusive store transaction, based on the status of the master exclusive monitor, the following actions will be taken:
  - ★ If the master exclusive monitor is reset, then the store will fail, that is, cache will not be updated. You need to restart the whole exclusive sequence again.
  - ◆ If the master exclusive monitor is set, then the exclusive store will fail, that is, cache will not be updated. You can re-initiate the exclusive store transaction alone, or restart the complete exclusive sequence.

The status of the master exclusive monitor is represented by member svt\_axi\_transaction::excl\_mon\_status. The status of exclusive access is represented by member svt\_axi\_transaction::excl\_access\_status.

The following table shows how to interpret the various combinations of svt\_axi\_transaction::excl\_mon\_status and svt\_axi\_transaction::excl\_access\_status, to derive the meaning of failure of an exclusive store associated with the corresponding exclusive store transaction.

**Table 3-13** 

| excl_access_status | excl_mon_status  | Reason for exclusive store failure                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Action needed                                                                                                  |
|--------------------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|
| EXCL_ACCESS_FAIL   | EXCL_MON_INVALID | Exclusive store transaction generated prior to an exclusive load transaction and hence the exclusive store transaction will be dropped.                                                                                                                                                                                                                                                                                                                                                      | You need to start<br>the exclusive<br>sequence with<br>Exclusive load.                                         |
| EXCL_ACCESS_FAIL   | EXCL_MON_RESET   | While initiating the exclusive store transaction, if the exclusive monitor is reset, the master will drop the exclusive store transaction. This will be indicated by setting svt_axi_transaction::is_coherent_xact_dropped to '1'. In this case, exclusive store fails.                                                                                                                                                                                                                      | You need to restart the complete exclusive sequence.                                                           |
|                    |                  | While initiating the exclusive store transaction, if the exclusive monitor is set, the master will initiate the exclusive store transaction on the bus. This will be indicated by setting svt_axi_transaction::is_coherent_xact_dropped to '0'. Between the point that the Exclusive Store transaction was issued and the point that it completed, a non-Exclusive Store can reset the exclusive monitor. In such a case, irrespective of the response (EXOKAY/OKAY), exclusive store fails. | You need to restart the complete exclusive sequence.                                                           |
| EXCL_ACCESS_FAIL   | EXCL_MON_SET     | The exclusive store transaction is initiated on to the bus, the response received is OKAY, and master exclusive monitor is set. In this case, exclusive store fails, as response indicates exclusive access fail.                                                                                                                                                                                                                                                                            | Exclusive store transaction alone can be re-initiated, or complete exclusive sequence can be initiated by you. |

#### 3.7.12 Known Limitations

- ❖ Requirement for WriteUnique and WriteLineUnique transactions specified in ACE protocol specification are not supported. Note that these transactions are typically used by non-cached components, and the restrictions given apply to cacheable components using it (which is a typical case).
- The specification allows a cache line state to transition to the UniqueClean state after it completes. In other words an allocation is made for the transaction. This is currently not supported for READNOSNOOP because a READNOSNOOP need not necessarily be of cache line size, and the allocation may span multiple cache lines.

# 3.8 Support for ACE-Lite Protocol in AXI Slave Agent

The Slave Agent can be configured to work in ACE-Lite mode. This enables the slave to receive and respond to barrier and cache maintenance transactions which may get forwarded to it by the interconnect.

ACE-Lite mode is enabled when svt\_axi\_port\_configuration::axi\_interface\_type is set to ACE\_LITE.

# 3.9 Support for ACE protocol in AXI Interconnect Env

When the svt\_axi\_port\_configuration::axi\_interface\_type of the Interconnect slave ports is specified as AXI\_ACE, the ACE functionality in the corresponding Interconnect Slave ports is enabled.

# 3.9.1 Support for Coherent and Snoop Transactions

When the Interconnect Slave port receives a coherent transaction from a Master, the Interconnect initiates appropriate snoop transactions towards other masters. The interconnect uses the recommended snoop transactions, as specified in chapter C6 of the ACE protocol specification.

In case of coherent read transactions (ReadOnce, ReadClean, ReadNotSharedDirty, ReadShared, ReadUnique), the interconnect initiates snoop transactions, and also initiates read transaction to the main memory in parallel to the snoop transactions. If data is available from snoop transaction, that data is returned to the initiating master. If data is not available from snoop transaction, then data from main memory is returned to the initiating master.

If dirty data is returned from the responding master and the initiating master cannot accept dirty data (for example, initiating master generated a ReadClean coherent transaction), then the Interconnect writes back data to main memory before sending clean data to the initiating master.

When the interconnect receives a READONCE transaction that spans across multiple cachelines, a snoop transaction corresponding to each cacheline is sent to each AXI\_ACE port.

For each cacheline, if any snoop returns data, the interconnect uses it, else, it uses data from memory. It merges data received for each cacheline and returns it to the initiating master. If any snoop passes dirty data, it is written back to memory.

If the interconnect receives a WRITEUNIQUE transaction, it sends a CLEANINVALID snoop transaction corresponding to each cacheline access to all AXI\_ACE ports. The interconnect merges data in the WRITEUNIQUE transaction and any dirty data received from the snoop transaction. If the strobe for a byte is asserted, the data from the WRITEUNIQUE transaction is always used. If the strobe for a byte is not asserted, but the snoop transaction returned dirty data for the corresponding byte, then the data from snoop transaction is used. The merged data based on the above description is written into memory.

# 3.9.2 Support for ACE Domain

The mapping of masters to inner and outer domains can be specified to the Interconnect component through configuration method svt\_axi\_system\_configuration::create\_new\_domain. Based on this domain mapping information and the domain specified in the coherent transaction from initiating master, the Interconnect generates snoop transactions to the corresponding masters in the domain.

## 3.9.3 Support for DVM

Interconnect supports DVM feature as specified in the ACE specification.

# 3.9.4 Support for Barrier

Interconnect orders the post barrier transactions based on barrier transactions. Interconnect also has the ability to forward barrier transactions to downstream slaves. For more information, see the svt\_axi\_interconnect\_configuration::forward\_barriers configuration member.

# 3.9.5 Support for Speculative Read

Interconnect always performs speculative read to memory to optimize system performance.

# 3.9.6 Unsupported ACE Features in Interconnect Env

The following features are not supported in Interconnect Env:

Exclusive access

#### 3.9.7 Known Limitation

Interconnect does not support ReadOnce and WriteUnique transactions if the total number of bytes to be transferred is larger than cache line size.

# 3.10 AXI4 Region and Address Range Support in Slave

# 3.10.1 Slave Address Range Support

System level address map can be specified using system configuration method svt\_axi\_system\_configuration::set\_addr\_range. The start address and end address can be specified for each slave in the system. Multiple address ranges can also be specified for a single slave. These address ranges can be specified as a continuous or a discontinuous.

# 3.10.2 Slave Region Support

The specified address ranges can be divided into maximum of 16 regions as guided by the AxREGION[3:0] signal of the AXI4 interface. These regions can be specified as continuous or discontinuous. The regions can be specified using method svt\_axi\_slave\_addr\_range::set\_region\_range. Every region is marked by a region-id ranging from 0-15.

The region can be associated to a region type, which defines the characteristics of the specified region. The region type can be specified as one of the arguments of the method svt\_axi\_slave\_addr\_range::set\_region\_range.

The following region types are currently supported:

- R- Read Only
- ❖ W Write Only
- RW Read/Write
- \* RSVD Reserved

Table 3-14 depicts the slave response generated for a read transaction, based on the region attribute:

### Table 3-14 Slave Response for a Read Transaction

| Type Attribute | Resultant<br>Response |
|----------------|-----------------------|
| R- Read Only   | OKAY                  |

Table 3-14 Slave Response for a Read Transaction (Continued)

| Type Attribute  | Resultant<br>Response |
|-----------------|-----------------------|
| W - Write Only  | SLV_ERR               |
| RW - Read/Write | OKAY                  |
| RSVD - Reserved | SLV_ERR               |

Table 3-15 depicts the slave response generated for a write transaction, based on the region attribute:

Table 3-15 Slave Response for a Write Transaction

| Type Attribute  | Resultant<br>Response |
|-----------------|-----------------------|
| R- Read Only    | SLV_ERR               |
| W - Write Only  | OKAY                  |
| RW - Read/Write | OKAY                  |
| RSVD - Reserved | SLV_ERR               |

Figure 3-4 pictorially shows the range and regions described above.

Figure 3-4 Slave Response generated for Write transaction



# 3.10.3 Slave Response Generation

For each received transaction, the port monitor within the slave agent generates the appropriate response based on address range and region type. This response is populated in the svt\_axi\_transaction::rresp[] (for read transactions) or svt\_axi\_transaction::bresp (for write transactions) fields of the slave transaction object. This slave transaction is then provided to the slave agent sequencer. If the slave sequence running in the slave agent sequencer modifies the pre-populated response in slave transaction, the response might no longer be correct.

Figure 3-5 Flow Diagram for Slave Response Generation



# 3.11 Support for Monitoring AXI Low Power Interface

The AXI protocol supports a low power interface through the signals ACLK, CACTIVE, CSYSREQ, and CSYSACK signals. These signals allows an AXI component to enter into low power state, and also exit from low power state.

The AXI low power monitor supports monitoring of these signals. It verifies whether the entry to low power state, and exit from the low power state is happening as per the protocol. It also provides the transaction object through the analysis port after a low power handshake is complete.

# **3.11.1** Module Top

1. svt\_axi\_if should be present in the module top.

### For example,

```
svt_axi_if axi_if();
```

The svt\_axi\_if interface now also contains an array of low power interfaces, lp\_if[] in addition to master if[] and slave if[].

2. Connect clock, reset and low power signals to lp\_if. Signals of low power interface are aclk, aresetn, cactive, csysreq and csysack.

### For example,

```
assign axi_if.lp_if[0].aclk = clk;
assign axi_if.lp_if[0].aresetn = rstn;
assign axi_if.lp_if[0].cactive = cactive;
assign axi_if.lp_if[0].csysreq = csysreq;
assign axi_if.lp_if[0].csysack = csysack;
```

# 3.11.2 System Configuration

Low power configuration is required in the system configuration file. This involves

1. Configuring the number of low power masters using the attribute 'num\_lp\_masters'

```
For example, this.num_lp_masters = 1; //This needs to be configured before
create_sub_cfgs()
```

2. Enable/disable low power protocol checks using protocol\_checks\_enable. This is enabled by default.

### 3.11.3 Analysis Ports

Low power master monitors have item\_observed\_port which collects and write low power transactions whenever low power activity is observed on the bus.

#### For example,

```
axi_system_env.lp_master[0].monitor.item_observed_port.connect(lp_listener.analysis_exp
ort);
```

The sample print of transaction object obtained from the analysis port:

UVM\_INFO ./env/axi\_basic\_env.sv(45) @ 490000: uvm\_test\_top.env.lp\_listener [lp\_listener] inside write method.

Name Type Size Value

lp\_entry\_obj svt\_axi\_service - @1749
causal\_xact object - <null>
implementation da(object) 0 -

| original_xact                 | object                 | -  | <null></null> |
|-------------------------------|------------------------|----|---------------|
| trace                         | da(object)             | 0  | _             |
| lp_entry_active_req_delay     | real                   | 64 | 185.000000    |
| lp_entry_req_ack_delay        | real                   | 64 | 115.000000    |
| lp_exit_prp_active_req_delay  | real                   | 64 | 0.000000      |
| lp_exit_prp_req_ack_delay     | real                   | 64 | 0.000000      |
| lp_exit_ctrl_req_active_delay | real                   | 64 | 0.000000      |
| lp_exit_ctrl_req_ack_delay    | real                   | 64 | 0.000000      |
| lp_exit_ctrl_active_ack_delay | real                   | 64 | 0.000000      |
| lp_handshake_type             | lp_handshake_type_enum | 32 | POWER_DOWN    |
| lp_initiator                  | lp_initiator_type_enum | 32 | PERIPHERAL    |
| lp_active_assertion_time      | real                   | 64 | 190.000000    |
| lp_req_assertion_time         | real                   | 64 | 375.000000    |
| lp_ack_assertion_time         | real                   | 64 | 490.000000    |
| begin_time                    | time                   | 64 | 190000        |
| end_time                      | time                   | 64 | 490000        |

The following is the example snippet. The Master and slave configurations are not included class cust\_svt\_axi\_system\_configuration extends svt\_axi\_system\_configuration;

```
/** UVM Object Utility macro */
`uvm_object_utils (cust_svt_axi_system_configuration)

/** Class Constructor */
function new (string name = "cust_svt_axi_system_configuration");

super.new(name);

/** Assign the necessary configuration parameters. This example uses single
   * master and single slave configuration.
   */
this.num_masters = 1;
this.num_slaves = 1;
this.num_lp_masters = 1;

/** Create port configurations */
this.create_sub_cfgs(1,1);

this.lp_master_cfg[0].protocol_checks_enable = 1'b1;
```

endfunction
endclass

104

4

# **Verification Features**

This chapter describes the various verification features available along with AXI VIP. This chapter discusses the following topics:

- **❖** "AXI Sequence Collection" on page 105
- "Verification Planner" on page 105
- "Protocol Analyzer Support" on page 106
- "Performance Analysis" on page 108
- "Error Injection" on page 114
- "Phase Jump for AXI VIP" on page 116

# 4.1 AXI Sequence Collection

The AXI VIP provides a collection of AXI master and slave sequences. These sequences can be registered with the master and slave sequencers within the master and slave agents respectively, to generate different types of AXI scenarios.

All the AXI Master sequences are extended from base sequence svt\_axi\_master\_base\_sequence. All the AXI Slave sequences are extended from base sequence svt\_axi\_slave\_base\_sequence.

For a list of all the master and slave sequences, see AXI VIP class reference HTML documentation.

AXI VIP provides a pre-defined AXI Master sequence library svt\_axi\_master\_transaction\_sequence\_library, which can hold the AXI Master sequences. The library by default has no registered sequences. You are expected to call svt\_axi\_master\_transaction\_sequence\_library::populate\_library() method to populate the sequence library with master sequences provided with the VIP. The port configuration is provided to the populate\_library() method. Based on the port configuration, appropriate sequences are added to the sequence library. You can then load the sequence library in the sequencer within the master agent. The AXI master and slave sequences are not encrypted, however, provided as source code.

# 4.2 Verification Planner

AXI VIP provides verification plans which can be used for tracking verification progress of AXI3/4 and ACE protocols. A set of top-level plans and sub-plans are provided. The verification plans are available at:

\$DESIGNWARE\_HOME/vip/svt/amba\_svt/latest/doc/VerificationPlans

For more information, see the README file, which is available at:

\$DESIGNWARE\_HOME/vip/svt/amba\_svt/latest/doc/VerificationPlans/README.

# 4.3 Protocol Analyzer Support

AXI VIP supports Synopsys® Protocol Analyzer. Protocol Analyzer is an interactive graphical application which provides protocol-oriented analysis and debugging capabilities.

For the AXI SVT VIP, protocol file generation is enabled or disabled through the variable "enable\_xml\_gen" that is defined in the class "svt\_axi\_port\_configuration". The default value of this variable is "0", which means that protocol file generation is disabled by default.

To enable protocol file generation, set the value of the variable "enable\_xml\_gen" to '1' in the port configuration of each master or slave for which protocol file generation is desired.

The next time that the environment is simulated, protocol files will be generated according to the port configurations. The protocol files will be in .xml format. Import these files into the Protocol Analyzer to view the protocol transactions.

For Verdi documentation, see \$VERDI\_HOME/doc/Verdi\_Transaction\_and\_Protocol\_Debug.pdf.



Protocol Analyzer has been enhanced to read FSDB transactions and Verdi can load the FSDB transactions into Browser.

# 4.3.1 Support for VC Auto Testbench

AXI VIP supports VC AutoTestbench which generates SV UVM testbench for Block level or Sub-System or System Level Design.

For VC ATB documentation, see Verdi\_Transaction\_and\_Protocol\_Debug.pdf.

# 4.3.2 Support for Native Dumping of FSDB

Native FSDB supported in AXI VIP.

- **FSBD Generation**: Protocol Analyzer uses transaction-level dump database. You can use the following settings to dump the transaction database:
  - **♦** Compile Time Options:
    - → +define+SVT\_AXI\_ACE\_SNPS\_INTERNAL\_SYSTEM\_MONITOR\_USE\_MASTER\_SLAVE\_AGENT\_CONN ECTION. Required for master-slave latency metrics.
    - -lca -kdb // dumps the work.lib++ data for source coding view
    - +define+SVT\_FSDB\_ENABLE // enables FSDB dumping

For more information on how to set the FSDB dumping libraries, see Appendix B section in *Linking Novas Files with Simulators and Enabling FSDB Dumping* guide available at: \$VERDI\_HOME/doc/linking\_dumping.pdf.

♦ New configuration parameter added for XML/FSDB generation in svt\_axi\_port\_configuration.sv. It is a port configuration variable. Add the following setting in system configuration to enable the generation of XML/FSDB:

```
/** Enable protocol file generation for Protocol Analyzer */
    this.master_cfg[0].enable_xml_gen = 1;
    this.slave_cfg[0].enable_xml_gen = 1;
    this.master_cfg[0].pa_format_type = svt_xml_writer:: ::<XML/FSDB/BOTH>;
    this.slave_cfg[0].pa_format_type= svt_xml_writer:: ::<XML/FSDB/BOTH>;
// 0 is XML, 1 FSDB and 2 both XML and FSDB, default it will be zero
```

♦ New configuration parameter added for XML/FSDB generation in svt\_axi\_system\_configuration class. These are system configuration variables. Add the following setting in system configuration to enable the generation of XML/FSDB from system monitor. These are required for master-slave latency metrics:

```
/** Enable protocol file generation for Protocol Analyzer */
this.enable_xml_gen = 1;
this.pa_format_type = svt_xml_writer:: ::<XML/FSDB/BOTH>; // 0 is XML, 1 FSDB
and 2 both XML and FSDB, default it will be zero
```

- **❖ Invoking Protocol Analyzer:** Perform the following steps to invoke Protocol Analyzer in interactive or post-processing mode:
  - ♦ Post-processing Mode
    - Load the transaction dump data and issue the following command to invoke the GUI: verdi -ssf <dump.fsdb> -lib work.lib++
    - ♦ In Verdi, navigate to Tools > Transaction Debug > Transaction and Protocol Analyzer.

#### **♦** Interactive Mode

Sissue the following command to invoke Protocol Analyzer in an interactive mode:

```
<simv> -gui=verdi
```

#### Runtime Switch:

```
+svt enable pa=fsdb
```

Enables FSDB output of transaction and memory information for display in Verdi.

You can invoke the Protocol Analyzer as described above using Verdi. The Protocol Analyzer transaction view gets updated during the simulation.

# 4.4 Performance Analysis

AXI VIP provides the capability to monitor the performance of a system, based on configuration parameters.

To view the properties related to Performance Analysis, see the group *Performance Analysis configuration parameters* in svt\_axi\_port\_configuration class present in AXI Class Reference.

By default, no performance monitoring is done. The user needs to configure the VIP to monitor the performance. The VIP monitors each port to check if the performance constraints are met based on the configured values and reports an error if a violation is observed.

Following is an example for performance constraint violation:

```
UVM_ERROR
```

```
/remote/vgvips14/rayrv/rayrv_axi_svt_us01_perf_analysis_demo/vip/svt/src/svt_err_check_stats.sv(637) @ 100000: uvm_test_top.env_2m_2s.system_env.master[0].monitor [register_fail] CHECK [effect=ERROR]: Executed and FAILED - ENABLED AMBA CHECK: perf_avg_max_write_xact_latency_check (AXI3/ver 2.0), Description: Monitor Check that the average latency of write transactions in a given interval is less than or equal to the configured max value - Configured average max latency constraint = 500.000000.

Observed average latency = 1883.3333333.

Interval start time = 0.0000000.

Interval end time = 10000.0000000
```

Reporting and measurement of performance parameters is done for each interval specified by the user. The interval is a configuration specified by the user in svt\_axi\_port\_configuration::perf\_recording\_interval.

The entire simulation time is divided into intervals specified in this configuration and performance metrics are reported for each of these intervals at the end of simulation.

To get a performance report, set the configuration parameter

svt\_axi\_system\_configuration::display\_perf\_summary\_report to 1. The performance report is present in the log under the header "PERFORMANCE REPORT".

The following additional members are added for performance analysis feature:

- ❖ svt\_axi\_system\_configurtaion::display\_perf\_summary\_report
- svt\_axi\_port\_configuration::perf\_exclude\_inactive\_periods\_for\_throughput

See the HTML Class Reference for description of these members.

### 4.4.1 Performance Analyzer

The performance analyzer tool is used to calculate the performance of sub-systems. For more information on FSDB Dumping, see "Support for Native Dumping of FSDB" on page 106.

## 4.4.1.1 Invoking Verdi GUI After Running the Simulation

1. Invoking Verdi GUI after running the simulation:

verdi -lca -ssf test\_top.fsdb

Figure 4-1 Final View Of Performance Metric With Graph and Data Details



## **Note**

For more information, see Verdi Performance Analyzer.pdf.

## 4.4.2 Metrics Description

Performance metrics are used to measure the performance of sub-systems. Each AMBA VIP has three types of performance metrics as follows:

- Transaction metrics
- Cross transaction metrics
- Cross instance metrics

#### 4.4.2.1 Transaction Type Metrics

These metrics are used to measure the performance of any given transaction. The following metrics comes under this type of metrics:

- \* \*\_trans\_read\_latency
- \* \*\_trans\_write\_latency
- \* \*\_trans\_read\_byte\_count
- \* \*\_trans\_write\_byte\_count

#### 4.4.2.2 Cross Transaction Type

These metrics are used to measure the performance across transactions at a given port. The following metrics comes under this type of metrics:

- \*\_ctrans\_min\_read\_latency
- \* \*\_ctrans\_min\_write\_latency
- \* \* ctrans max read latency
- \* \* ctrans max write latency
- \* \*\_ctrans\_avg\_read\_latency
- \* \* ctrans avg write latency
- \* \*\_ctrans\_read\_request\_count
- \* \*\_ctrans\_write\_request\_count
- \*\_ctrans\_read\_outstanding\_count
- \* \*\_ctrans\_write\_outstanding\_count
- \* \*\_ctrans\_read\_byte\_count
- \* \*\_ctrans\_write\_byte\_count

#### 4.4.2.3 Cross Instance Type

These metrics are used to measure the performance of the transactions across all ports. The following metrics comes under this type of metrics:

- \* \* cinst read request count
- \* \*\_cinst\_write\_request\_count
- \* cinst read request percentage
- \* \*\_cinst\_write\_request\_percentage
- \* \*\_cinst\_read\_bus\_bandwidth
- \* \*\_cinst\_read\_bus\_bandwidth
- \* \*\_cinst\_read\_byte\_count
- \* \*\_cinst\_write\_byte\_count

### 7 Note

\* indicates the protocol name.(for example, for AXI \*\_trans\_read\_latency will be axi\_trans\_read\_latency)

For more information, see \$DESIGNWARE\_HOME/vip/svt/amba\_svt/latest/doc/axi\_performance\_metrics.pdf.

#### 4.4.3 Accessing the Port Level Performance Metrics From Testbench During Run-time

The performance metrics monitored by the VIP port monitor can be accessed using the APIs that are available in the VIP. The svt\_axi\_master\_agent and svt\_axi\_slave\_agent has a member perf\_status of type svt\_axi\_port\_perf\_status class.

This class has the following APIs:

- get\_unit\_for\_latency\_metrics()
- get\_unit\_for\_throughput\_metrics()
- start\_performance\_monitoring()
- stop\_performance\_monitoring()

- is\_performance\_monitoring\_in\_progress()
- ♦ get num performance monitoring intervals()
- get\_num\_completed\_performance\_monitoring\_intervals()
- is\_performance\_monitoring\_interval\_complete()

Please check the documentation of svt\_axi\_port\_perf\_status class in the html class reference doc for detailed description of the above APIs.

The APIs can be accessed as follows:

#### For example,

```
<hierarchy to the axi system env>.<axi_agent_instance>.perf_status.<API>
```

The API <code>get\_perf\_metric()</code> can be used to retrieve the value of one of the following metrics that are monitored by the VIP. It can also return the transaction handles corresponding to min/max read/write latencies and the transaction handles that violated the constraints on min/max read/write latencies:

- ❖ AVG\_READ\_LATENCY: Average latency of the read type transactions.
- **❖** MIN\_READ\_LATENCY: **Minimum latency of the read type transactions.**
- **❖** MAX\_READ\_LATENCY: **Maximum latency of the read type transactions.**
- ❖ READ\_THROUGHPUT: Throughput of the read data bus.
- ❖ AVG\_WRITE\_LATENCY: Average latency of the write type transactions.
- **❖** MIN\_WRITE\_LATENCY: **Minimum latency of the write type transactions.**
- ❖ MAX\_WRITE\_LATENCY: Maximum latency of the write type transactions.
- ❖ WRITE\_THROUGHPUT: Throughput of the write data bus.

```
The get_perf_metric() can be used only if svt_axi_port_configuration::perf_recording_interval is set to 0 or -1.
```

When svt\_axi\_port\_configuration::perf\_recording\_interval is set to 0:

The <code>get\_perf\_metric()</code> returns the value of the metric computed from the start of simulation till the time the method is called.

```
When svt axi port configuration::perf recording interval is set to -1:
```

Call the methods start\_performance\_monitoring() and stop\_performance\_monitoring() to start and stop the performance monitoring respectively. These methods can be called multiple times in a single simulation, which will establish multiple user defined time windows for performance monitoring. The perf\_rec\_interval argument of get\_perf\_metric() determines the performance window for which the metric value needs to be retrieved.

#### **Example usage:**

```
//variables to hold the retrieved metric values
   real avg_read_latency, max_read_latency, min_read_latency, avg_write_latency,
max_write_latency, min_write_latency, read_throughput, write_throughput;

//queues to retrieve the transaction handles
   svt_axi_transaction max_read_xact[$], max_read_xact_queue[$], min_read_xact[$],
min_read_xact_queue[$], max_write_xact[$], max_write_xact_queue[$], min_write_xact[$],
min_write_xact_queue[$], xact_queue[$];
   bit status;
```

```
//send the initial register configuration transactions, then start the perf monitoring
      status = agent.perf_status.start_performance_monitoring();
//send the perf stimulus. Once done, stop the perf monitoring
      status = agent.perf status.stop performance monitoring();
//any time after stopping perf monitoring, access the metrics, transaction handles by
calling get_perf_metric()
    avg_read_latency =
agent.perf_status.get_perf_metric(svt_axi_port_perf_status::AVG_READ_LATENCY,
xact_queue);
    `uvm_info("body", $sformatf("At the end of sequence, AVG_READ_LATENCY:
%f",avg_read_latency), UVM_LOW);
    avg_write_latency =
agent.perf_status.get_perf_metric(svt_axi_port_perf_status::AVG_WRITE_LATENCY,
xact_queue);
    `uvm_info("body", $sformatf("At the end of sequence, AVG_WRITE_LATENCY:
%f",avg_write_latency), UVM_LOW);
    min read latency =
agent.perf_status.get_perf_metric(svt_axi_port_perf_status::MIN_READ_LATENCY,
min read xact, 1);
    `uvm_info("body", $sformatf("At the end of sequence, MIN_READ_LATENCY:
%f", min_read_latency), UVM_LOW);
    `uvm_info("body", $sformatf("At the end of sequence, MIN_READ_LATENCY xact: %s",
`SVT_AXI_PRINT_PREFIX1(min_read_xact[0])), UVM_LOW);
    min_read_latency =
agent.perf_status.get_perf_metric(svt_axi_port_perf_status::MIN_READ_LATENCY,
min_read_xact_queue, -1);
    `uvm_info("body", $sformatf("At the end of sequence, MIN_READ_LATENCY: %f,
violations:",min_read_latency), UVM_LOW);
    foreach(min_read_xact_queue[idx])
      `uvm_info("body", $sformatf("%d: %s", idx,
`SVT_AXI_PRINT_PREFIX1(min_read_xact_queue[idx])),                           UVM_LOW);
    max_read_latency =
agent.perf_status.get_perf_metric(svt_axi_port_perf_status::MAX_READ_LATENCY,
max read xact, 1);
    `uvm_info("body", $sformatf("At the end of sequence, MAX_READ_LATENCY:
%f", max_read_latency), UVM_LOW);
    `uvm_info("body", $sformatf("At the end of sequence, MAX_READ_LATENCY xact: %s",
`SVT_AXI_PRINT_PREFIX1(max_read_xact[0])), UVM_LOW);
    max read latency =
agent.perf_status.get_perf_metric(svt_axi_port_perf_status::MAX_READ_LATENCY,
max_read_xact_queue, -1);
    `uvm_info("body", $sformatf("At the end of sequence, MAX_READ_LATENCY: %f,
violations:",max_read_latency), UVM_LOW);
    foreach(max_read_xact_queue[idx])
      `uvm info("body", $sformatf("%d: %s", idx,
`SVT_AXI_PRINT_PREFIX1(max_read_xact_queue[idx])),                           UVM_LOW);
```

```
min write latency =
agent.perf_status.get_perf_metric(svt_axi_port_perf_status::MIN_WRITE_LATENCY,
min_write_xact, 1);
    `uvm_info("body", $sformatf("At the end of sequence, MIN_WRITE_LATENCY:
%f", min_write_latency), UVM_LOW);
    `uvm_info("body", $sformatf("At the end of sequence, MIN_WRITE_LATENCY xact: %s",
`SVT_AXI_PRINT_PREFIX1(min_write_xact[0])), UVM_LOW);
    min write latency =
agent.perf status.get perf metric(svt axi port perf status::MIN WRITE LATENCY,
min_write_xact_queue, -1);
    `uvm info("body", $sformatf("At the end of sequence, MIN WRITE LATENCY: %f,
violations:",min_write_latency), UVM_LOW);
    foreach(min_write_xact_queue[idx])
      `uvm info("body", $sformatf("%d: %s", idx,
`SVT_AXI_PRINT_PREFIX1(min_write_xact_queue[idx])),                           UVM_LOW);
    max write latency =
agent.perf status.get perf metric(svt axi port perf status::MAX WRITE LATENCY,
max_write_xact, 1);
    `uvm_info("body", $sformatf("At the end of sequence, MAX_WRITE_LATENCY:
%f", max_write_latency), UVM_LOW);
    `uvm_info("body", $sformatf("At the end of sequence, MAX_WRITE_LATENCY xact: %s",
`SVT_AXI_PRINT_PREFIX1(max_write_xact[0])), UVM_LOW);
    max_write_latency =
agent.perf_status.get_perf_metric(svt_axi_port_perf_status::MAX_WRITE_LATENCY,
max write xact queue, -1);
    `uvm_info("body", $sformatf("At the end of sequence, MAX_WRITE_LATENCY: %f,
violations:",max_write_latency), UVM_LOW);
    foreach(max_write_xact_queue[idx])
      `uvm info("body", $sformatf("%d: %s", idx,
`SVT AXI PRINT PREFIX1(max write xact queue[idx])), UVM LOW);
    read_throughput =
agent.perf_status.get_perf_metric(svt_axi_port_perf_status::READ_THROUGHPUT,
xact_queue);
    `uvm_info("body", $sformatf("At the end of sequence, READ_THROUGHPUT:
%f",read_throughput), UVM_LOW);
    write throughput =
agent.perf_status.get_perf_metric(svt_axi_port_perf_status::WRITE_THROUGHPUT,
xact queue);
    `uvm_info("body", $sformatf("At the end of sequence, WRITE_THROUGHPUT:
%f", write_throughput), UVM_LOW);
```

## 4.4.4 Dynamic Reconfiguration

All the properties related to performance analysis can be configured dynamically at run time. This is done by passing a new configuration with updated values to the top level component using the reconfigure() method.

The performance monitoring of a metric can be enabled or disabled at any time during the simulation. But, the new values will take effect only after the current interval has elapsed, as shown in Figure 4-2.

Figure 4-2 Dynamic Reconfiguration



## 4.5 Error Injection

AXI SVT VIP supports implementation of predefined errors that can be injected during the execution of a transaction. This is achieved through AXI SVT exception class svt\_axi\_transaction\_exception and exception list class svt\_axi\_transaction\_exception\_list. The following sections describe these classes in detail.

## 4.5.1 Exception Class

The Exception class for the AXI transaction class is svt\_axi\_transaction\_exception. It extends from the svt\_exception class. A randomizable error\_kind property of type error\_kind\_enum exists in this class. This property defines the type of error to be injected.

```
/** Selects the type of error that will be injected. */
rand error_kind_enum error_kind = COHERENT_XACT_BYTES_LESS_THAN_CACHE_LINE_SIZE_ERROR;
```

For a list of supported error kinds, refer to the svt\_axi\_transaction\_exception::error\_kind member in the AXI Class Reference HTML.

## 4.5.2 Exception Lists

The Exception list for the AXI transaction is svt\_axi\_transaction\_exception\_list. It basically contains a queue of svt\_axi\_transaction\_exception objects. An instance of the exception list class describes all of the exceptions applicable to an individual transaction. Therefore, a transaction descriptor should have a reference to an exception list.

For more details on the svt\_axi\_transaction\_exception\_list class, see the AXI Class Reference HTML.

#### 4.5.3 Use Model

VIP provides the <code>svt\_axi\_master\_callback</code> class. It contains all the callback methods called by the master component. You can implement an error injection callback class by extending from <code>svt\_axi\_master\_callback</code> class. It is recommended that the exceptions are added in the <code>post\_input\_port\_get</code> callback to ensure that all exceptions are added before the transaction is processed and driven on the interface.

The following is an example of error injection callback class that extends from the svt\_axi\_master\_callback class.

The following is the code snippet for the UVM flow:

```
* This class extends from svt_axi_master_callback class.
   * It shows how user can inject pre-defined errors during the execution of a
transaction
  * through various callback methods. In this class post_input_port_get() callback is
  * overridden and specific errors are injected.
class cust_svt_axi_master_error_injection_callback extends svt_axi_master_callback;
   // Instance of svt axi transaction exception class
  svt_axi_transaction_exception my_exception;
  // Instance of svt_axi_transaction_exception_list class
  svt_axi_transaction_exception_list my_exception_list;
// Flag for checking randomization success or failure
 int result = 0;
  /**
   * Constructor of the class.
  function new ( string name =
"cust svt axi system interconnect error injection callback");
    super.new(name);
  endfunction
 * Overrides post_input_port_callback() method to inject errors through the
* use of SVT AXI exception classes.
 virtual function void post_input_port_get(svt_axi_master axi_master,
svt_axi_transaction xact, ref bit drop);
   super.post_input_port_get(axi_master, xact, drop);
 // Construct svt_axi_transaction_exception and svt_axi_transaction_exception_list
 my_exception = svt_axi_transaction_exception::type_id::create("master_exception");
 my exception list =
svt_axi_transaction_exception_list::type_id::create("master_exception_list");
  // Assign xact and cfg handle of svt_axi_transaction_exception class before
randomization
 my_exception.xact = xact;
 my_exception.cfg = xact.port_cfg;
```

```
// Randomize exception class based on error_kind to be injected
 result = my_exception.randomize() with {error_kind ==
svt_axi_transaction_exception::INVALID_BURST_TYPE_FOR_COHERENT_XACT_ERROR;};
if (!result) begin
   svt_axi_transaction_exception class for error_kind =
%0s",my exception.error kind.name()));
end
   ^{\star} Add a new exception with the specified content to the exception list.
my_exception_list.add_exception(my_exception);
// Initialize svt_axi_transaction_exception_list handle
(svt_axi_transaction::exception_list) with the user-defined
// exception list. This way the error_kind of type
   svt_axi_transaction_exception::INVALID_BURST_TYPE_FOR_COHERENT_XACT_ERROR
// gets injected in this particular transaction.
xact.exception_list = my_exception_list;
endfunction //end of function post_input_port_get()
endclass //end of class cust_svt_axi_master_error_injection_callback
```

## 4.6 Phase Jump for AXI VIP

AXI VIP supports UVM Phase jump from main\_phase() to reset\_phase().

## **Verification Topologies**

This chapter shows you from a high-level, how the AXI VIP can be used to test Master, Slave, or Interconnect DUT. This chapter discusses the following topics:

- ◆ "Testing a Master DUT Using an UVM Slave VIP" on page 117
- "Testing a Slave DUT Using an UVM Master VIP" on page 120
- **❖** "Interconnect DUT and Master/Slave VIP" on page 121
- **❖** "System DUT with Passive VIP" on page 122
- "System DUT with Mix of Active and Passive VIP" on page 124
- "System DUT with Active Interconnect VIP" on page 125
- "Interconnect DUT with System Monitor" on page 126
- "System DUT with System Monitor" on page 127

## 5.1 Testing a Master DUT Using an UVM Slave VIP

In this scenario, you are testing an AXI Master DUT using an UVM AXI Slave.

- \* Testbench setup: Configure the AXI System Env to have one Slave Agent, in active mode. The active Slave Agent will respond to the transactions generated by master DUT. The Slave Agent will also perform passive functions such as protocol checking, coverage generation and transaction logging.
- ❖ Implementation of this topology requires the setting of the following properties: (Assuming instance name of system configuration is "sys\_cfg").
  - **♦** System configuration settings:
    - $\Rightarrow$  sys cfg.num masters = 0;
  - **♦** Port configuration settings:
    - \$ sys\_cfg.slave\_cfg[0].is\_active = 1;

When DUT has a single AXI master port to be verified, testbench can either use a Slave Agent in standalone mode, or use a System Env configured for a single slave agent. The advantages and disadvantages of the two approaches are listed below.

Advantages of using standalone agent versus System Env:

\* Testbench becomes light weight as System Env and related infrastructure is not required

### Disadvantages:

- The testbench does not remain scalable. If the number of AXI master ports to be verified increases, the standalone Slave Agent should to be replaced with System Env, or, multiple Slave Agents would need to be instantiated by you.
- **❖** The AXI system monitor cannot be used, which is part of the System Env.

Figure 5-1 Master DUT and Slave VIP - Usage With Standalone Slave Agent



Figure 5-2 Master DUT and Slave VIP - Usage With System Environment



## 5.2 Testing a Slave DUT Using an UVM Master VIP

In this scenario, you are testing an AXI Slave DUT using an UVM AXI Master.Configure the AXI System Env to have one Master Agent, in active mode. The active master agent will generate AXI transactions for the Slave DUT. The Master Agent will also perform passive functions such as protocol checking, coverage generation and transaction logging.

When DUT has a single AXI slave port to be verified, testbench can either use a Master Agent in standalone mode, or use a System Env configured for a single Master Agent.

The advantages and disadvantages of the two approaches are listed below.

Advantages of using standalone agent versus System Env:

Testbench becomes light weight as System Env and related infrastructure is not required

#### Disadvantages:

- The testbench does not remain scalable. If the number of AXI master ports to be verified increases, standalone Slave Agent should be replaced with System Env, or, multiple Slave Agents would need to be instantiated by you.
- The AXI system monitor cannot be used, which is part of the System Env.

Implementation of this topology requires the setting of the following properties: (Assuming instance name of system configuration is "sys\_cfg")

- System configuration settings:
  - sys\_cfg.num\_masters = 1;
  - sys\_cfg.num\_slaves = 0;
- Port configuration settings:
  - sys\_cfg.master\_cfg[0].is\_active = 1;

Figure 5-3 Slave DUT and Master VIP - Usage With Standalone Master Agent



System Env DUT

Master Agent (Active mode)

AXI Slave RTL

Figure 5-4 Slave DUT and Master VIP - Usage With System Environment

## 5.3 Interconnect DUT and Master/Slave VIP

In this scenario, DUT is an AXI Interconnect tested by a Master and Slave VIP: Assuming that the AXI Interconnect has M master ports and S slave ports, configure the AXI System Env to have S master agents and M slave agents, in active mode. The active master agents will generate AXI transactions towards the interconnect slave ports, and active slave agents connected would respond to the transactions generated by interconnect master ports. The master and slave agents would also perform passive functions such as protocol checking, coverage generation and transaction logging.

Implementation of this topology requires the setting of the following properties:

- Assuming instance name of system configuration is "sys\_cfg"
- Assuming number of master ports on interconnect = 2
- **❖** Assuming number of slave ports on interconnect = 2

#### **System configuration settings:**

- sys\_cfg.num\_masters = 2;
- sys\_cfg.num\_slaves = 2;

#### Port configuration settings:

- sys\_cfg.master\_cfg[0].is\_active = 1;
- sys\_cfg.master\_cfg[1].is\_active = 1;
- sys\_cfg.slave\_cfg[0].is\_active = 1;
- sys\_cfg.slave\_cfg[1].is\_active = 1;

Figure 5-5 shows the testbench setup.



Figure 5-5 Interconnect DUT with Master and Slave VIP (Active Mode)

## 5.4 System DUT with Passive VIP

In this setup, DUT is a AXI system with multiple AXI masters, slaves and interconnect. VIP is required to monitor DUT.

Assuming that the AXI System has M masters and S slaves, configure the AXI System Env to have M master agents and S slave agents, in passive mode. The passive master and slave agents would perform passive functions such as protocol checking, coverage generation and transaction logging.

Implementation of this topology requires the setting of the following properties:

- Assuming instance name of system configuration is "sys\_cfg"
- Assuming number of master ports on interconnect = 2
- **❖** Assuming number of slave ports on interconnect = 2

## **System configuration settings:**

- sys\_cfg.num\_masters = 2;
- sys\_cfg.num\_slaves = 2;

## Port configuration settings:

- sys\_cfg.master\_cfg[0].is\_active = 0;
- sys\_cfg.master\_cfg[1].is\_active = 0;
- sys\_cfg.slave\_cfg[0].is\_active = 0;
- sys\_cfg.slave\_cfg[1].is\_active = 0;

Figure 5-6 shows this setup.

Figure 5-6 System DUT with Passive VIP



## 5.5 System DUT with Mix of Active and Passive VIP

In this scenario, DUT is a system with multiple AXI masters, slaves and interconnect. The VIP is required to provide background traffic on some ports, and to monitor on ports.

Assuming that the AXI System DUT has two master ports and two slave ports. VIP is required to provide background traffic to ports S0 and M0. All the ports need to be monitored. Configure the AXI System Env to have two master agents and two slave agents. Configure the master agent connected to port S0, and slave agent connected to port M0 as active. Configure the master agent connected to port M1 and slave agent connected to port M1 as passive. All the agents would continue to perform passive functions such as protocol checking and coverage.

Figure 5-7 System DUT with Mix of Active and Passive VIP



Implementation of this topology requires the setting of the following properties:

Assuming instance name of system configuration is "sys\_cfg".

### **System configuration settings:**

- sys\_cfg.num\_masters = 2;
- $\star$  sys cfg.num slaves = 2;

#### Port configuration settings:

- sys\_cfg.master\_cfg[0].is\_active = 1;
- $\diamond$  sys cfg.master cfg[1].is active = 0;
- sys\_cfg.slave\_cfg[0].is\_active = 1;
- sys\_cfg.slave\_cfg[1].is\_active = 0;

## 5.6 System DUT with Active Interconnect VIP

In this scenario, DUT is a system with multiple AXI masters and slaves. VIP is required to provide the background traffic on some ports, and to route the transactions between master and slave ports.

Assuming that the AXI System DUT has two master ports and two slave ports. VIP is required to provide the background traffic to ports S0 and M0. All the ports need to be monitored. Configure the AXI System Env to have one master agent and, slave agent and Interconnect Env. Configure the master agent, slave agent and Interconnect Env as active. The ports of Interconnect Env would continue to perform passive functions such as protocol checking and coverage. The passive functionality in master and slave agents connected to the Interconnect Env ports may be optionally disabled.

Figure 5-8 System DUT with Active Interconnect VIP



Implementation of this topology requires the setting of the following properties:

Assuming instance name of system configuration is "sys\_cfg".

### **System configuration settings:**

- sys\_cfg.num\_masters = 1;
- sys\_cfg.num\_slaves = 1;
- sys\_cfg.use\_interconnect = 1;

## Port configuration settings:

- sys\_cfg.master\_cfg[0].is\_active = 1;
- sys\_cfg.slave\_cfg[0].is\_active = 1;

## 5.7 Interconnect DUT with System Monitor

Figure 5-9 Interconnect DUT with System Monitor VIP



## 5.8 System DUT with System Monitor

Figure 5-10 System DUT with System Monitor VIP



128

6

# **Using AXI Verification IP**

This chapter describes how to install and run a getting started example and provides usage notes for AXI Verification IP.

This chapter discusses the following topics:

- "SystemVerilog UVM Example Testbenches" on page 130
- "Installing and Running the Examples" on page 131
- "How to Provide Data and Response Information to the Slave After a Time Delay" on page 132
- "How to Disable Objection Management by VIP, and Allow Testbench to Manage Objections" on page 135
- "How to Control the Forwarding of Barrier and Cache Maintenance Transactions to Downstream Slaves by the Interconnect VIP" on page 136
- "How to Configure AXI Slaves with Overlapping Address" on page 136
- "How to Generate ACE WriteEvict Transactions" on page 137
- "Why the User Needs to Disable Auto Item Recording" on page 137
- ♦ "How Does the Interconnect VIP Handle Barrier Transactions?" on page 138
- "How to Access a Byte Level Data of AXI Slave VIP Memory Using backdoor read/write?" on page 139
- \* "Data Integrity Checks" on page 139
- "Setting up Secure and Non-Secure access mechanism for AXI-ACE Master" on page 140
- "Snoop Filter Support" on page 141
- "Configuration Requirements to Enable System Level Cover Groups Which Use Master to Slave Transaction Association" on page 142
- "Exclusive Access Support" on page 142
- "Backdoor Cache Access Methods" on page 147
- "AXI4 Stream Protocol" on page 148
- "Steps to Integrate the uvm\_reg With AXI VIP" on page 151
- "Design Specific Coherent to Snoop Transaction Association" on page 152
- "Single Outstanding Transaction Per AxID" on page 153

- **❖** "Interleaved Port Support" on page 153
- **❖** "Master to Slave Path Access Coverage" on page 155

## 6.1 SystemVerilog UVM Example Testbenches

This section describes SystemVerilog UVM example testbenches that show general usage for various applications. A summary of the examples is listed in Table 6-1

Table 6-1 SystemVerilog Example Summary

| Example Name                      | Level | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------------------------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| tb_axi_svt_uvm_basic_sys          | Basic | <ul> <li>The example consists of the following:         <ul> <li>A top-level module, which includes tests, instantiates interfaces, HDL interconnect wrapper, generates system clock, and runs the tests</li> <li>A base test, which is extended to create a directed and a random test</li> </ul> </li> <li>The tests create a testbench environment, which in turn creates AXI System Env</li> <li>AXI System Env is configured with one master and one slave agent         <ul> <li>Note</li> <li>AXI UVM Basic example Quickstart is located at: \$DESIGNWARE_HOME/vip/svt/amba_svt/latest/examples/sverilog/tb_axi_svt_uvm_basic_sys/doc/tb_axi_svt_uvm_basic_sys/index_basic.html</li> </ul> </li> </ul> |
| tb_axi_svt_uvm_basic_program_s ys | Basic | The example demonstrates the usage of program block.  It consists of the following:  • A top-level module, which includes the user program, instantiates interfaces, HDL interconnect wrapper, generates system clock, and runs the tests  • The axi_basic_tb.sv file that contains the user program in the example  • A base test, which is extended to create a directed and a random test  The tests create a testbench environment, which in turn creates AXI System Env.  AXI System Env is configured with one master and one slave agent.                                                                                                                                                               |

Table 6-1 SystemVerilog Example Summary (Continued)

| Example Name                    | Level        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|---------------------------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| tb_axi_svt_uvm_intermediate_sys | Intermediate | <ul> <li>The example consists of the following:</li> <li>A top-level module, which includes tests, instantiates interfaces, HDL interconnect wrapper, generates system clock, and runs the tests</li> <li>A base test, which is extended to create a directed and a random test</li> <li>The tests create a testbench environment, which in turn creates AXI System Env</li> <li>AXI System Env is configured with one master and one slave agent</li> <li>AXI UVM Scoreboard</li> <li>Demonstrates how to override system constants</li> <li>Coverage generation</li> </ul> |
| tb_axi_svt_uvm_advanced_sys     | Advanced     | Not yet supported                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

The examples are located at:

\$DESIGNWARE\_HOME/vip/svt/amba\_svt/latest/examples/sverilog/

## 6.2 Installing and Running the Examples

Below are the steps for installing and running example tb\_axi\_svt\_uvm\_basic\_sys. The similar steps are also applicable for other examples:

- 1. Install the example using the following command line:
  - % cd < location where example is to be installed>
  - % mkdir design\_dir of your choice>
  - $\% \ SDESIGNWARE\_HOME/bin/dw\_vip\_setup \ -path \ ./design\_dir \ -e \\ amba\_svt/tb\_axi\_svt\_uvm\_basic\_sys \ -svtb$

The example would get installed under:

<design\_dir>/examples/sverilog/amba\_svt/tb\_axi\_svt\_uvm\_basic\_sys

- 2. Use either one of the following to run the testbench:
  - a. Use the Makefile:

Three tests are provided in the "tests" directory.

The tests are:

- i. ts.base test.sv
- ii. ts.directed\_test.sv
- iii. ts.random\_wr\_rd\_test.sv

For example, to run test ts.directed\_test.sv, do following:

gmake USE\_SIMULATOR=vcsvlog directed\_test WAVES=1

Invoke "gmake help" to show more options.

b. Use the sim script:

For example, to run test ts.random\_wr\_rd\_test.sv, do following:
./run\_axi\_svt\_uvm\_basic\_sys -w random\_wr\_rd\_test vcsvlog

Invoke "./run\_axi\_svt\_uvm\_basic\_sys -help" to show more options.

For more details of installing and running the example, see the README file in the example, located at:

\$DESIGNWARE\_HOME/vip/svt/amba\_svt/latest/examples/sverilog/tb\_axi\_svt\_uvm\_basic\_sys/REA
DME

OR

<design\_dir>/examples/sverilog/amba\_svt/tb\_axi\_svt\_uvm\_basic\_sys/README

## 6.2.1 Defines for Increasing Number of Masters and Slaves

The default max number of masters and slaves that can be used in an axi\_system\_env is 16. This can be increased up to a maximum value of 450. To use more than 16 masters and slaves in an AXI system, you need to define the macros +define+SVT\_AXI\_MAX\_NUM\_MASTERS\_<value>, +define+SVT\_AXI\_MAX\_NUM\_SLAVES\_<value>.

## For example:

1. To use 380 AXI masters and 380 AXI slaves in a single AXI system env:

```
Add compile time options "+define+SVT_AXI_MAX_NUM_MASTERS_380 +define+SVT_AXI_MAX_NUM_SLAVES_380"
```

2. In the VIP configuration, do:

```
svt_axi_system_configuration::num_masters=380;
svt_axi_system_configuration::num_slaves=380;
```

### 6.2.2 Support for UVM version 1.2

While using UVM 1.2, note the below requirements:

- **♦ When using VCS version H-2013.06-SP1 and lower versions, you must define the**USE\_UVM\_RESOURCE\_CONVERTER macro. This macro is not required to be defined with VCS version I-2014.03-SP1 and higher versions.
- It is not required to define the uvm\_disable\_auto\_item\_recording macro.

# 6.3 How to Provide Data and Response Information to the Slave After a Time Delay

As a default behavior, the slave driver expects the slave response sequence to return the slave response object in zero time, that is, without any delay after the sequencer receives object from the port monitor. This poses a problem where data and response information may not be available immediately and therefore cannot be given in zero time.

There are two alternatives to address this issue:

- Using svt\_axi\_transaction::suspend\_response:
  - The users can use the member svt\_axi\_transaction::suspend\_response to achieve this. This requires the user to fork off the threads which wait for data to become available. This option is recommended when user can provide data & response information for all the beats in one shot to the slave driver, after a certain time delay, after receiving the slave response object from the port monitor.
- Using svt\_axi\_port\_configuration::enable\_delayed\_response\_port:

This option is recommended when user cannot provide data and response information for all the beats in one shot to the slave driver, after a certain time delay, after receiving slave response object from the port monitor.

The following is the usage model for this feature.

- This feature will be enabled using a port level configuration parameter (svt\_axi\_port\_configuration::enable\_delayed\_response\_port). By default, this feature will be disabled.
- 2. The slave monitor provides a handle to a transaction to the sequencer for the following events:
  - a. Address phase of read/write transaction
  - b. First beat of write data if the data arrives before address

There is no change to this behavior.

- 3. The model will still require that the handle to the transaction is returned to the driver in zero time. This is to ensure that the driver has enough information to drive signals such as arready and awready. However, read data and read/write response related information need not be populated at this time. The mechanism detailed in (4) below may be used for the same.
- 4. A TLM port (uvm\_blocking\_get\_port) is added to the slave driver, which enables the user to supply information related to read data and read/write response at a later point in time. This port is connected to a corresponding 'put' port (delayed\_response\_request\_port) in the sequencer by the VIP.

When the data and response information is available, the slave sequence can provide the slave response object using this 'put' port in the sequencer. The transaction supplied through this TLM port should NOT be the same transaction handle given by the monitor to the sequencer, but it should be its copy. The information related to data and response, refers to the following properties in svt\_axi\_transaction:

- a. data[]
- b. rresp[]
- c. coh\_rresp[]
- d. rvalid\_delay[]
- e. bresp
- f. bvalid\_delay

For READ transaction, a user will have the flexibility to input any number of beats at any point of time. The model detects an availability of data by checking the array size of rresp[] field. For example, if the size of array rresp[] is 1, it indicates that the first beat is available. If the size is two, it indicates that the first two beats are available and so on. The array sizes of all the above properties should be consistent and the responsibility to ensure this lies on the user. The model would allow the transaction to be submitted back to the p\_sequencer multiple times, if partial beat information was received. It is user's responsibility to make sure that eventually all the read data required for read transaction to complete, is provided to the model.

For WRITE transactions, a user has the ability to return the response (bresp) at any point of time.

- 5. When the above feature is enabled, the constraints will not enforce array sizes of the above mentioned parameters to be consistent with burst length, since the array sizes will be used to recognize availability of data.
- 6. When this feature is enabled, responses sent through the seq\_item\_port must have data.size() and rresp.size() as 0. That is, these arrays must be empty. In other words, all the response and data information must be sent through the delayed\_response\_request\_port of the sequencer.
- 7. If a transaction is randomized before it is sent through the delayed\_response\_request\_port, the property svt\_axi\_transaction::is\_delayed\_response\_xact must be set for the transaction (this transaction will be the copy of the transaction received from the monitor since only a copy is allowed on this port as mentioned below).
- 8. The transaction provided through the delayed\_response\_request\_port must be a copy of the original transaction and not a reference. The following fields of the original transaction received from the monitor and the delayed response should match:

```
svt_axi_transaction::object_id
svt_axi_transaction::id
svt_axi_transaction::addr
```

#### Sample code:

```
virtual task body();
      svt axi slave transaction reg resp;
      forever
      begin
         p_sequencer.response_request_port.peek(req_resp);
         // Randomize the initial response. The response will be completed
         // after some time has elapsed, when the block that is external to the
         // slave returns data.
         status = req_resp.randomize (...);
         fork
           svt axi slave transaction delayed resp;
          delayed_resp = svt_axi_slave_transaction::type_id::create("delayed slave
          response", p sequencer);
          delayed_resp.copy(req_resp);
           begin
               if((delayed resp.xact type == svt axi slave transaction::WRITE) &&
                   (delayed resp.addr status != svt axi transaction::INITIAL))
              //Provide the data to an external entity which will supply back the write
                response
              put_write_transaction_data_to_external_block(delayed_resp);
              //After write response is available, provide it to
                delayed response request port port
              p_sequencer.delayed_response_request_port.put(delayed_resp);
              // Provide delayed write response
               else
               begin
               //Get the read data from an external entity
               get read data from external block to transaction(delayed resp);
               //After read data and response is available, provide it to
                 delayed_response_request_port port
```

# 6.4 How to Disable Objection Management by VIP, and Allow Testbench to Manage Objections

The objection management in AXI VIP components is controlled through a system configuration property svt\_axi\_system\_configuration::manage\_objections\_enable. This parameter decides whether the objections will be raised and dropped by the drivers of VIP components. If set, the VIP will raise an objection when it receives a transaction in the input port of the driver and will drop the objection when the transaction completes. If not set, the driver will not raise any objection and complete control of objections is with the user. By default, the configuration parameter will be set, that is, VIP will raise and drop objections.

# The following example code shows how a user could potentially control objections from the testbench through callbacks:

```
class cust_svt_axi_system_interconnect_objection_control_callback extends
svt_axi_interconnect_callback;
  // Counter to keep track of number of transactions
  int counter = 0;
  // Handle to the environment class where the callback is instantiated
  axi_env sys_env;
  // Set by env in the run_ph. Need this handle to raise objections on this based on
     transactions
  uvm_phase env_run_ph;
  function new
      ( string name = "cust_svt_axi_system_interconnect_objection_control_callback"
                       axi_env sys_env);
    super.new(name);
    this.sys_env = sys_env;
  endfunction
  virtual function void post_input_port_get(svt_axi_interconnect axi_interconnect,
                                            svt_axi_ic_slave_transaction xact);
      counter++;
     // Raise objections only for 1000 transactions.
      if (counter < 1000) begin
        env_run_ph.raise_objection(axi_env);
        fork
```

```
wait(`SVT_AXI_XACT_STATUS_ENDED(xact));
    env_run_ph.drop_objection(axi_env);
    join_none
    end
endfunction
endclass
```

## 6.5 How to Control the Forwarding of Barrier and Cache Maintenance Transactions to Downstream Slaves by the Interconnect VIP

Forwarding of barrier and cache maintenance transactions to downstream ACE-LITE slaves by the interconnect are determined by the following two configuration parameters:

```
svt_axi_interconnect_configuration::forward_barriers
svt_axi_interconnect_configuration::forward_cache_maintenance_transactions
```

For a detailed description of the two parameters, see the Class Reference HTML documentation.

## 6.6 How to Configure AXI Slaves with Overlapping Address

If the address map of slaves overlap with each other such as in the case of a dual port memory, the parameter svt\_axi\_system\_configuration::allow\_slaves\_with\_overlapping\_addr must be set. The address map of each slave is then set using the svt\_axi\_system\_configuration::set\_addr\_range method as is usually done.

For details on usage of this parameter, see the documentation of

```
svt_axi_system_configuration::allow_slaves_with_overlapping_addr in AXI Class Reference.
```

The following are some additional notes for configuring AXI Slaves with overlapping address:

- Any number of AXI slaves can have overlapping addresses.
- ❖ These slaves must lie within the same svt\_axi\_system\_env instance if the AXI system monitor is used (by setting svt\_axi\_system\_configuration::system\_monitor\_enable).
- ❖ The start address and end address of an address range that overlaps between multiple AXI slaves must match.

In other words, the entire address range for a given range must match across multiple slaves. Partial overlap of an address range is not allowed. For details, see the documentation of

```
svt_axi_system_configuration::allow_slaves_with_overlapping_addr parameter.
```

The user needs to pass a shared memory across slaves that share a common address space. This can be done by creating an instance of svt\_mem in the testbench and passing the same svt\_mem instance through uvm\_config\_db to the slave agents that have a shared address space, as shown in the following code snippet:

- The attributes of the slaves which have overlapping addresses, such as data width, can be different.
- If the slaves that share memory have different data widths, the data width of the shared memory must be equal to or greater than the largest data width of the slaves that share an address space.
  For example, if there are three slaves of data width 32, 64 and 128 bits which share an address range,

the data width of the memory created in the testbench can be 128, 256, 512 or 1024.

- ❖ If the slaves that share memory have different address widths, the minimum and maximum address of the memory created in the testbench should accommodate the largest addressable region.
- There is no arbitration of accesses between the two shared interfaces to memory. If there are accesses to the same location at the same time, the actual value written to memory is not deterministic.

## 6.7 How to Generate ACE WriteEvict Transactions

The AXI Verification IP supports the ACE WriteEvict transactions.

The following port configuration class members have been added to support this feature:

- ❖ svt\_axi\_port\_configuration::writeevict\_enable
- svt\_axi\_port\_configuration::awunique\_enable

The following port transaction class members have been added to support this feature:

- svt\_axi\_transaction::coherent\_xact\_type
- svt\_axi\_transaction::is\_unique

For more details, see the AXI Class Reference.

## 6.8 Why the User Needs to Disable Auto Item Recording

If you are using AHB UVM or AXI UVM Verification IP, you need to define a macro named UVM\_DISABLE\_AUTO\_ITEM\_RECORDING. This section describes why this macro needs to be defined, and what are its implications if a user defined driver and sequencer also exist in the same environment.

AXI and AHB protocols are pipelined protocols. In pipelined protocols, driver needs to initiate the next transaction before the previous transaction completes. Thus, the VIP driver indicates seq\_item\_port.item\_done() much before the transaction is completed on the bus, so that the sequencer can provide next sequence item to the driver. Driver does not wait for a transaction to complete before calling seq\_item\_port.item\_done().

For AXI, seq\_item\_port.item\_done() is called as soon as the driver accepts a transaction from the sequencer. For AHB, seq\_item\_port.item\_done() is called when penultimate beat address of the current transaction is accepted by the slave. The VIP explicitly marks end of transaction when the transaction actually completes on the interface, instead of letting UVM do it. Hence, VIP needs to define UVM DISABLE AUTO ITEM RECORDING macro.

If the environment contains a user defined driver/sequencer, and the macro UVM\_DISABLE\_AUTO\_ITEM\_RECORDING is defined, user needs to make sure that the driver explicitly marks end of transaction when transaction actually completes on the interface. For example, for a non-pipelined protocol, user can call req.end\_tr() in the driver code after calling seq\_item\_port.item\_done(), assuming that seq\_item\_port.item\_done() is called only after the transaction is complete. Alternatively, user can call req.end\_tr() in the corresponding sequence, after the sequence unblocks based on seq\_item\_port.item\_done().

For pipelined protocol, user needs to wait till the transaction is complete on the bus, before calling req.end\_tr().

Code snippet of the driver (assuming non-pipelined protocol):

```
seq_item_port.item_done();
req.end_tr();
```

Code snippet of the sequence (assuming non-pipelined protocol):

```
`uvm_do(req);
req.end_tr();
```



VIPs for pipelined and non-pipelined protocols are designed to work correctly when UVM\_DISABLE\_AUTO\_ITEM\_RECORDING macro is defined.

## 6.9 How Does the Interconnect VIP Handle Barrier Transactions?

When a barrier transaction is received, the VIP blocks further progress of all transactions received after it until the transactions received prior to the barrier are complete. The response to a READBARRIER is sent only when prior READ type transactions are complete. The same applies to WRITEBARRIER. A barrier transaction does not result in a snoop to other masters.

Steps to debug the barrier transactions are as follows:

- 1. Check the number of transactions began, but did not end. Lookup for the Transaction started and Transaction ended message to figure this out.
- 2. From the transactions being performed, check how many are before the barrier and how many are after the barrier.
- 3. If there are any transactions before the barrier which is not complete, then the response to the barrier will not be sent. Subsequent transactions will also be blocked. So check why transactions before the barrier did not complete.
- 4. If there are transactions after the barrier which are blocked, check if the barrier itself completed.
- 5. Note that barriers in ACE are sent as pairs. So the core should be sending a READBARRIER and a WRITEBARRIER to the interconnect corresponding to a synchronization barrier.



The Interconnect VIP is not a behavioural model of the CCI-400. It is only one of the many implementations of the interconnect which is compliant to the ACE specification. In particular, we may not be bothered about ensuring optimal performance (not from a simulation perspective, but from bus utilization perspective etc.). The timings of the transactions (snoop for example) initiated by the interconnect VIP will be very different from CCI-400.

The easiest way to debug the Interconnect VIP is to enable the system monitor and see the transaction summary (the requirement is that there is an AXI VIP connected to every port). The system monitor can be enabled and simulation run in <code>UVM\_HIGH</code> and you can grep for <code>TRANSACTION SUMMARY</code> at the end of the log. If you do not want to run simulation in <code>UVM\_HIGH</code>, but would like to see the summary report the <code>svt\_axi\_system\_configuration::display\_summary\_report should be set.</code>

# 6.10 How to Access a Byte Level Data of AXI Slave VIP Memory Using backdoor read/write?

The AXI slave VIP memory is modeled using the class svt\_mem. The svt\_mem's backdoor methods update the memory based on the data\_width. There is no easy way to read/write a single byte of data at a given address location.

The AXI slave VIP has the following APIs that makes it easy to access byte level data:

```
task write_byte(input bit[`SVT_AXI_MAX_ADDR_WIDTH-1:0] addr, bit[7:0] data);
task read_byte(input bit[`SVT_AXI_MAX_ADDR_WIDTH-1:0] addr, output bit[7:0] data);
For example,
```

1. To write a single byte of data ('h0f) at address 'h100 from the test, you can use:

```
env.axi_system_env.slave[0].write_byte(32'h100, 8'h0f);
```

2. To read a single byte of data at the address 'h200 from the test, you can use:

```
bit[7:0] read_data;
env.axi_system_env.slave[0].read_byte(32'h200, read_byte);
$display("data at address 'h200: %h", read_byte);
```

## 6.11 Data Integrity Checks

The following data integrity checks are performed by the system monitor. For specific information on the checks, see the class reference documentation of the checks:

```
svt_axi_system_checker::data_integrity_check
svt_axi_system_checker::data_integrity_with_outstanding_coherent_write_check
svt axi system checker::master slave xact data integrity check
```

The data\_integrity\_check performs a check on data integrity by comparing data in a write or read transaction the contents of the memory for the same location. This check is performed only when svt\_axi\_system\_configuration::posted\_write\_xacts\_enable is not set. Please read the documentation of svt\_axi\_port\_configuration::memory\_update\_for\_read\_xacts\_enable also as its configuration is critical for data integrity checks. This variable must be 1 if a slave DUT is used and if it can return non-default data for locations not written into via frontdoor access (ie, through previous WRITE transactions). The check is bypassed in the following situations:

- ❖ A WRITE transaction to an overlapping address is detected during the liftetime of the transaction.
- svt\_axi\_port\_configuration::memory\_update\_for\_read\_xacts\_enable is set and a READ transaction to an overlapping address is detected during the lifetime of the transaction
- There is a WRITENOSNOOP or READNOSNOOP transaction to an address which is in a shareable domain or the shareability domains of the address received in the WRITENOSNOOP/READNOSNOOP transactions is not configured. Shareability domains are configured using svt\_axi\_system\_configuration::create\_new\_domain() and svt\_axi\_system\_configuration::set\_addr\_for\_domain()

The master\_slave\_xact\_data\_integrity\_check is performed to ensure data integrity between master transactions and the corresponding slave transactions across an interconnect. These checks are performed only if either of the following parameters are set: svt\_axi\_system\_configuration::posted\_write\_xacts\_enable or svt\_axi\_system\_configuration:: master\_slave\_xact\_data\_integrity\_check\_enable. This check is performed by correlating slave transactions to master transactions and comparing data. The system monitor requires additional information so that it can properly correlate master transactions and slave transactions. The following fields must be set in the configuration:

```
svt_axi_system_configuration::id_based_correlation_enable
svt_axi_system_configuration::source_master_info_id_width
svt_axi_system_configuration::source_master_info_position
svt_axi_system_configuration::source_interconnect_id_xmit_to_slaves
svt_axi_system_configuration::source_master_id_wu_wlu_xmit_to_slaves
svt_axi_port_configuration::source_master_id_xmit_to_slaves
```

You can retrieve a system transaction that has the correlated information through the following callback in svt\_axi\_system\_monitor\_callback:

```
virtual function void
master_xact_fully_associated_to_slave_xacts(svt_axi_system_monitor
system_monitor,svt_axi_system_transaction sys_xact);
endfunction
```

The following properties in the system transaction can be used to retrieve the master and slave transaction information from the callback. A user could perform custom checks in the callback based on this.

```
svt_axi_system_transaction::master_xact
svt_axi_system_transaction::assoc_slave_xacts[$]
```

The master\_slave\_xact\_data\_integrity\_check is not intended to replace the data\_integrity\_check, it is meant to supplement it by addressing the situations where memory based checking has limitations and need to be bypassed. It is also provides a powerful mechanism for users to do custom functional as well as performance checks based on the callback provided.

The system monitor supports correlation of master transactions to slave transactions when Interconnect converts FIXED bursts to INCR bursts as below:

- ❖ Master sends a FIXED burst of a given burst size and burst length
- ❖ Interconnect converts this into 'burst length' number of INCR transactions, each of which has a burst size of 8-bit and burst length based on the burst size of the master transaction. For example, let us say master sends a FIXED burst with burst\_size of 32 bits and length of 8. This will be converted into 8 INCR transactions of burst\_size 8-bit and burst\_length 4 (corresponding to burst\_size of 4 bytes of the original transaction).

In above case, the system monitor can associate the INCR slave transactions to FIXED burst master transactions. The protocol check master\_slave\_xact\_data\_integrity\_check performs this check.

# 6.12 Setting up Secure and Non-Secure access mechanism for AXI-ACE Master

By default when cacheline is written or read by VIP master agent or backdoor APIs, they are agnostic to any secure/non-secure protection specialization. ACE protocol indicate the Secure/Non-Secure access using AxPROT[1].

Here is how VIP can be configured to manage this protection mechanism

 $1. \ \ \, The following port configuration attributes enable this mechanism for corresponding VIP agent$ 

```
svt_axi_port_configuration::tagged_address_space_attributes_enable = 1;
```

// This Enables support of independent secure and non-secure address space, including cacheline for snoop response 2. The following this configuration setting the AxProt[1] bit will be used as ADDRESS - MSB by VIP to write/read the cacheline, so address width must be set accordingly.

For example, if you had set SVT\_AXI\_MAX\_ADDR\_WIDTH macro to maximum address width possible across any agent in given system (for example, 44), then you need to set it '1+' to accommodate the tagged address bit (MSB appended to address coming from AxPROT[1]).

#### Example:

```
`define SVT AXI MAX ADDR WIDTH 45
```

3. You also need to set the address tag attribute width, which is used to indicate on how many bits of AxPROT will be used (currently there is support for only AxPROT[1], hence setting it to '1' is good enough)

#### **Example**

```
`define SVT_AXI_ADDR_TAG_ATTRIBUTES_WIDTH 1
```

4. Set the VIP master agent addr\_width <= SVT\_AXI\_MAX\_ADDR\_WIDTH - `SVT AXI ADDR TAG ATTRIBUTES WIDTH

Here is how VIP manages secure and non-secure address ranges :-

Whenever VIP master will see the cacheline store (For example, addr 2000000000), then the address information in cache will be stored based on actual address, appended with MSB value from AxPROT[1] (that address MSB value stored in cache will be!(AxPROT[1]))

For example, address stored in cache for the case , where AxPROT[1] was "1" (i.e non secure) will be 02000000000.

#### **User Backdoor WRITE and READ to Master Cache**

These operations should access respective cacheline using these tagged address (MSB appended to actual cacheline address as 1/0 for secure and non-secure respectively)

Each write backdoor should be followed by set\_prot\_type call for that cacheline. VIP also does it under the hood when it writes to cache.

```
svt_axi_cache::set_prot_type(addr_t addr, int is_privelged = -1, int is_secure = -1 ,
int is_instruction = -1)
```



VIP supports only AxPROT[1] value currently that is, is\_secure argument, hence passing any/no value to other arguments (is\_privileged and is\_instruction) will not make any difference.

## 6.13 Snoop Filter Support

Some interconnects have a snoop filter which keeps track of allocations and de-allocations of cachelines in masters connected to it. The interconnect uses this information to decide which masters to snoop when a coherent transaction is received. Snoops are not broadcasted, but sent only to masters that have an entry in the cache. From a system monitor's point of view, the main difference when it is connected to an interconnect with/without a snoop filter is in the correlations it makes between coherent and snoop transactions and the corresponding checks on the ports on which it expects snoop transactions. If snoop filter is not enabled, all ACE masters will be expected to receive a snoop corresponding to a coherent transaction. If snoop filter is enabled, the system monitor keeps track of allocations and deallocations of cachelines in ACE masters and it expects only those ports which have an allocation to be snooped. Snoop filter configuration is a port level configuration. If the

interconnect supports snoop filter, all masters connected to the interconnect must have the following parameter set:

svt\_axi\_port\_configuration::snoop\_filter\_enable

# 6.14 Configuration Requirements to Enable System Level Cover Groups Which Use Master to Slave Transaction Association

To enable system level cover groups which use master to slave transaction association, user needs to enable following configuration parameter:

svt\_axi\_system\_configuration::id\_based\_xact\_correlation\_enable

## 6.15 Exclusive Access Support

## 6.15.1 Exclusive Access Related Configurations

AMBA VIP uses individual exclusive access monitor for each port and therein tracking each exclusive sequences independently through combination of transaction ID (representing master id) and transaction address. Exclusive monitor sets and resets itself depending on the sequence of exclusive or normal type transactions. While it tracks each exclusive sequence it prepares expected response for both read and write transactions based on whether the exclusive sequence was successful or not. If any mismatch found between expected and actual response, then it reports error and possible underlying cause i.e. whether there was no exclusive read performed or if the monitor is already reset or exclusive read address was reset before receiving exclusive write.

 $//\ \mbox{enables}$  or disables exclusive access completely. VIP neither generates EXOK response nor expects it.

exclusive access enable

// exclusive monitors for each port can be disabled even if exclusive access is enabled. If disabled then VIP doesn't track exclusive accesses and allows all type of responses to exclusive transactions and doesn't report any error related to exclusive access checks.

exclusive\_monitor\_enable

// indicates the maximum number of open exclusive sequence supported. Once an exclusive sequence is started inside exclusive monitor it is checked against existing number of open exclusive sequences. When exclusive write completes the sequence then that sequence is removed from the exclusive sequence tracking. Attempts to exceed this max number results in a failed exclusive access read response of OKAY instead of EXOKAY.

## **J** Note

Currently, it can not be disabled by setting 0. This will be added in later version.

max num exclusive access

- \* Number of ADDRESS bits that need to be monitored by the exclusive monitors for current port in order to support one or more independent exclusive access thread. This is currently applicable only for ACE Exclusive transactions.
  - \* NOTE: configuring with value 0 means, no address is being monitored by the

- \* corresponding exclusive monitor and hence exclusive access to different address
- \* may also affect current thread.

num addr bits used in exclusive monitor

- \* similar as above
- \* This is currently applicable only for ACE Exclusive transactions.

num\_id\_bits\_used\_in\_exclusive\_monitor

- \* If set to '1' then VIP will not assert error if Master sends Exclusive Store without sending Exlusive Load.
- \* However, if Exclusive Store is sent from the Invalid cacheline state then VIP will still assert error since,
- \* that is not a valid state to start Exclusive Store.

rand bit allow\_exclusive\_store\_without\_exclusive\_load = 0;

- \* If set to '1' then VIP will respond to very first Exclusive Store with EXOKAY response. This means that if
- \* no master has performed any excluisve transaction after reset is de-asserted then then if one master issues
- \* exclusive store then VIP will respond with EXOKAY or will expect EXOKAY response from the coherent interconnect.
  - \* Note: reference point of first exclusive store is reset.

rand bit allow\_first\_exclusive\_store\_to\_succeed = 0;

- \* If set to '1' then Exclusive Monitor will get reset once Exclusive Store is successful.
- \* If set to '0' then Exclusive Monitor will remain set even if Exclusive Store is successful.
- \* Please Note that, VIP will still reset Exclusive Monitor for failed Exclusive Store attempt
- \* regardless of the value set for this parameter.

rand bit reset\_exclusive\_monitor\_on\_successful\_exclusive\_store = 1;

#### 6.15.2 Exclusive Access Checks

```
/** Checks that ARLEN and ARSIZE are valid for exclusive read transaction */
signal_valid_exclusive_arlen_arsize_check;

/** Checks that ARCACHE is valid for exclusive read transaction */
signal_valid_exclusive_arcache_check;

/** Checks that address is aligned for exclusive read transaction */
signal_valid_exclusive_read_addr_aligned_check;
```

```
/** Checks that AWLEN and AWSIZE are valid for exclusive read transaction */
   signal_valid_exclusive_awlen_awsize_check;
  /** Checks that AWCACHE is valid for exclusive read transaction */
   signal_valid_exclusive_awcache_check;
  /** Checks that address is aligned for exclusive read transaction */
   signal_valid_exclusive_write_addr_aligned_check;
  /** Checks that address is generated same for exclusive read and write
   * transactions */
   exclusive_read_write_addr_check;
  /** Checks that id is generated same for exclusive read and write
   * transactions */
   exclusive read write id check;
 /** Checks that response generated for exclusive load accesss is correct */
   exclusive_load_response_check;
  /** Checks that response generated for exclusive store accesss is correct */
   exclusive store response check;
  /** Checks that master does not permit an Exclusive Store transaction to be
    * in progress at the same time as any transaction that registers that it
    * is performing an Exclusive sequence
    * /
   exclusive_store_overlap_with_another_exclusive_sequence_check;
  /** Checks that, once a master receives successful exclusive store response EXOKAY
    * from interconnect, then no other master should be provided with EXOKAY response,
    * until current master acknowledges completing successful exclusive store by
asserting RACK
    * /
    exokay_not_sent_until_successful_exclusive_store_rack_observed_check;
     /** Checks that READ_ONLY_INTERFACE does not support exclusive access
     * Applicable only for AXI4 VIP
     * Passive Master, Passive Slave and Active slave will perform this
```

```
* check
     * /
      excl_access_on_read_only_interface_check;
     /** Checks that WRITE ONLY INTERFACE does not support exclusive access
      * Applicable only for AXI4 VIP
      * Passive Master, Passive Slave and Active slave will perform this check
      * /
       excl_access_on_write_only_interface_check;
     /** Checks that burst length is generated same for exclusive read and write
   * transactions */
   exclusive_read_write_burst_length_check;
  /** Checks that burst size is generated same for exclusive read and write
   * transactions */
   exclusive_read_write_burst_size_check;
  /** Checks that burst type is generated same for exclusive read and write
   * transactions */
  exclusive_read_write_burst_type_check;
  /** Checks that cache type is generated same for exclusive read and write
   * transactions */
   exclusive_read_write_cache_type_check;
  /** Checks that protection type is generated same for exclusive read and write
   * transactions */
   exclusive_read_write_prot_type_check;
  /** Checks that exclusive transaction sent on AXI_ACE interface are
   * only of WRITENOSNOOP, READNOSNOOP, READCLEAN, READSHARED and CLEANUNIQUE type */
   exclusive_ace_transaction_type_check;
  /**Checks the valid response of EXOKAY response is only for readnosnoop Transactions
   exokay_resp_observed_only_for_exclusive_transactions_check;
  /**Checks that if cacheline is in invalid state then exclusive load transaction is
issued only as READCLEAN or READSHARED */
  exclusive_load_from_valid_state_check;
```

```
/**Checks that if cacheline is in invalid state then exclusive store transaction is
not issued */
   exclusive_store_from_valid_state_check;
  /**Checks that if cacheline is in shared state then exclusive transaction is issued
only as CLEANUNIQUE, READCLEAN or READSHARED*/
   exclusive_transaction_from_shared_state_check;
  /** Checks that an exclusive sequence is reset after a cacheline is
    * invalidated by a snoop. This checks that after a snoop invalidates
    * a cacheline, an exclusive load is always sent prior to sending the
    * exclusive store.
  restart_exclusive_seq_post_cache_line_invalidation_check;
  /** Checks that if cacheline is in invalid state then exclusive load transaction is
issued
    * only as READCLEAN or READSHARED
  exclusive_load_from_valid_state_sys_check;
  /** Checks that if cacheline is in invalid state then exclusive store transaction is
not issued
  exclusive_store_from_valid_state_sys_check;
signal_valid_exclusive_arlen_arsize_check
signal_valid_exclusive_arcache_check
signal_valid_exclusive_read_addr_aligned_check
signal_valid_exclusive_awlen_awsize_check
signal_valid_exclusive_awcache_check
signal_valid_exclusive_write_addr_aligned_check
exclusive_read_write_addr_check
exclusive_read_write_id_check
exclusive_load_response_check
exclusive_store_response_check
exclusive_store_overlap_with_another_exclusive_sequence_check
exokay_not_sent_until_successful_exclusive_store_rack_observed_check
exclusive_read_write_burst_length_check
exclusive read write burst size check
exclusive_read_write_burst_type_check
exclusive_read_write_cache_type_check
exclusive_read_write_prot_type_check
```

```
exclusive_ace_transaction_type_check
exokay_resp_observed_only_for_exclusive_transactions_check
exclusive_load_from_valid_state_check
exclusive_store_from_valid_state_check
exclusive_transaction_from_shared_state_check
restart_exclusive_seq_post_cache_line_invalidation_check
exclusive_load_from_valid_state_sys_check
exclusive_store_from_valid_state_sys_check
```

# 6.15.3 How Exclusive Accesses From Multiple Clusters are Modeled in System Monitor (exclusive monitor per ID)?

System Monitor uses Exclusive Monitor for each AXI\_ACE port irrespective of exclusive monitor inside port monitor. System Monitor currently doesn't track exclusive accesses for AXI3/AXI4/ACE\_LITE ports as those are tracked at port monitor level. Additionally, each of these Exclusive monitors independently tracks supported number of exclusive sequence based on transaction ID and address. Number of bits considered for transaction ID can be used to model multiple processors within a single cluster. For ACE Exclusive accesses, each of these PoS Exclusive Monitors observes all master transactions in the system i.e. both coherent and snoop transactions. This means, for each coherent transaction all PoS Exclusive Monitors take appropriate actions based on its internal state and the observed transaction. If multiple exclusive sequence is open in more than one PoS Excl Monitor then one may make it successful and others will get reset. It is also possible that based on the observed coherent or snoop transaction monitor will get reset. Invalidating snoop transactions will always reset corresponding PoS Exclusive Monitor.

#### 6.16 Backdoor Cache Access Methods

Cache is modeled using the class ' $svt_axi_cache$ '. This has the following methods for backdoor access. See the HTML class reference doc for descriptions:

```
$DESIGNWARE_HOME/vip/svt/amba_svt/latest/doc/axi_svt_uvm_class_reference/html/class_svt
_axi_cache.html
```

```
function bit
                    backdoor_write ( int index , addr_t addr = 0, bit [7:0] data
[], bit byteen [], int is_unique = -1, int is_clean = -1, longint age = -1)
                     get_cache_type ( addr_t addr , output bit [3:0] cache_type )
function bit
function bit
                     get_prot_type ( addr_t addr , output bit is_privileged ,
output bit is_secure , output bit is_instruction )
function bit
                    get_status ( addr_t addr , output bit is_unique , output bit
is clean )
function bit
                     invalidate_addr ( addr_t addr )
function void
                   invalidate_all ( )
function bit
                    read_by_addr ( input addr_t addr , output int index , output
bit [7:0] data [], output bit is_unique, output bit is_clean, output longint age
function bit
                     set_cache_type ( addr_t addr , bit [3:0] cache_type )
function bit
                     set_prot_type ( addr_t addr , int is_privileged = -1, int
is secure = -1, int is instruction = -1)
```

function bit update\_status ( addr\_t addr , int is\_unique , int is\_clean )

#### 6.17 AXI4 Stream Protocol

#### 6.17.1 Concepts

The AXI4-stream protocol is used as a standard interface to connect components that share data. The interface can be used to connect a single master, that generates data, to a single slave, that receives data. The protocol can also be used when connecting larger numbers of master and slave components. The data is shared in the form of data streams. A data stream can be a series of individual byte transfers or a series of byte transfers grouped together in packets.

The following section describes the below components:

#### 6.17.1.1 Master Agent

The Master Agent encapsulates Master Sequencer, Master Driver, and Port Monitor. The Master Agent can be configured to operate in active mode and passive mode. You can provide AXI4\_STREAM sequences to the Master Sequencer.

The Master Agent is configured using a port configuration, which is available in the system configuration. The port configuration should be provided to the Master Agent in the build phase of the test.

Within the Master Agent, the Master Driver gets sequences from the Master Sequencer. The Master Driver then drives the AXI4\_STREAM transactions on the AXI4\_STREAM port. The Master Driver and port Monitor components within Master Agent call callback methods at various phases of execution of the AXI4\_STREAM transaction.

After the AXI4\_STREAM transaction on the bus is complete, the completed sequence item is provided to the analysis port of Port Monitor for use by the testbench.

Figure 6-1 Usage With Standalone Master Agent



#### **6.17.1.2** Slave Agent

The Slave Agent encapsulates Slave Sequencer, Slave Driver, and Port Monitor. The Slave Agent can be configured to operate in active mode and passive mode. You can provide ATB response sequences to the Slave Sequencer.

The Slave Agent is configured using port configuration, which is available in the system configuration. The port configuration should be provided to the Slave Agent in the build phase of the test or the testbench environment.

In the Slave Agent, the Port Monitor samples the AXI4\_STREAM port signals. When a new transaction is detected, the Port Monitor provides a response request sequence item to the Slave Sequencer through port response\_request\_port. The slave response sequence within the sequencer programs the appropriate slave response. The updated response sequence item is then provided by the Slave Sequencer to the Slave Driver. The Slave Driver in turn drives the response on the AXI4\_STREAM bus.

The slave driver expects the slave response sequence to,

- Return same handle of the slave response object as provided to the sequencer by the port monitor
- **❖** Return the slave response object in zero time, that is, without any delay after sequencer receives object from the port monitor

If any of the above conditions are violated, the slave agent issues a FATAL message.

The Slave Driver and Monitor call callback methods at various phases of execution of the AXI4\_STREAM transaction. After the AXI4\_STREAM transaction on the bus is complete, the completed sequence item is provided to the analysis port for use by the testbench.

Figure 6-2 Usage with Standalone Slave Agent



#### 6.17.1.3 Agents in Active and Passive Mode

#### Component behavior in active mode

In active mode, Master and Slave components generate transactions on the signal interface.

Master and Slave components continue to perform passive functionality of coverage and protocol checking. You can enable/disable this functionality through configuration.

The Port Monitor within the component performs protocol checks only on sampled signals. That is, it does not perform checks on the signals that are driven by the agent. This is because when the agent is driving an exception (exceptions are not supported in this release) the Monitor should not flag an error, since it knows that it is driving an exception. Exception means error injection.

#### Component behavior in passive mode

In passive mode, master and slave components do not generate transactions on the signal interface. These components only sample the signal interface.

Master and Slave components monitor the input and output signals, and perform passive functionality such as coverage and protocol checking. You can enable/disable this functionality through configuration options.

The port monitor within the component performs protocol checks on all signals. In passive mode, signals are considered as input signals.

#### 6.17.1.4 AXI4 STREAM UVM User Interface

The following sections give an overview of the user interface into the AXI4\_STREAM VIP.

AXI4\_STREAM VIP uses the svt\_axi\_port\_configuration class for assigning port configuration values.

The following parameters can be set to use AXI4\_STREAM VIP:

```
svt_axi_port_configuration: axi_interface_type
```

axi\_interface\_type must be set to AXI4\_STREAM to configure the interface of the port to AXI4\_STREAM.

The following is the description of some of the port configuration attributes for AXI4\_STREAM. The width of the tdata signal can be set using svt\_axi\_port\_configuration::tdata\_width

The width of tid\_signal can be set using svt\_axi\_port\_configuration::tid\_width

The width of tdest\_signal can be set using svt\_axi\_port\_configuration::tdest\_width

An elaborate description of port configuration attributes can be found in svdoc.

AXI4\_STREAM VIP uses svt\_axi\_transaction class as its base transaction class.

```
Xact_type = svt_axi_transaction::DATA_STREAM must be set for AXI4_STREAM transactions.
```

The detailed description of transaction class attributes can be found in svdoc.

## 6.18 Steps to Integrate the uvm\_reg With AXI VIP

The following are the steps to integrate the uvm\_reg flow with AXI Master Agent:

- 1. Generate the System Verilog file for the register definition, using the ralgen utility.
  - ralgen -uvm -t axi\_regmodel <>.ralf, this will generate a System Verilog file with register
    definition
- 2. Instantiate and create the RAL/uvm\_reg model in the uvm\_env and pass that handle to the AXI Master agent.

```
// Declare RAL model.
    ral_sys_axi_intermediate_slave regmodel;
virtual function void build_phase(uvm_phase phase);
    super.build_phase(phase);
    ...
/** Check if regmodel is passed to env if not then create and lock it. */
    If (regmodel == null) begin
    regmodel = ral_sys_axi_intermediate_slave::type_id::create("regmodel");
    regmodel.build();
    regmodel.build();
    regmodel.set_hdl_path_root(hdl_path);
    `uvm_info("build_phase", "Reg Model created", UVM_LOW)
    regmodel.lock_model();
    end
    uvm_config_db#(uvm_reg_block)::set(this, "axi_system_env.master[0]", "axi_regmodel",
    regmodel);
    ...
endfunction : build_phase
```

3. Call the reset() function of the regmodel from the reset\_phase of uvm\_env.

```
// Reset the register model
task reset_phase(uvm_phase phase);
   phase.raise_objection(this, "Resetting regmodel");
   regmodel.reset();
   phase.drop_objection(this);
endtask
```

4. To enable the uvm\_reg adapter of the AXI Master agent, user need to do the following

```
Set the uvm_reg_enable, svt_axi_port_configuration attribute to 1 for the desired AXI agent. this.master_cfg[i].uvm_reg_enable= 1;
```

5. Modify the uvm\_reg tests, if required and execute them

You can find the complete example in the VIP installation (tb\_axi\_svt\_uvm\_intermediate\_ral\_sys)

You can download the example using the dw\_vip\_setup\_utility (see "Installing and Running the Examples" on page 131.

## 6.19 Design Specific Coherent to Snoop Transaction Association

The AXI system monitor associates coherent transactions to snoop transactions. Since there is no implication of the snoops for the corresponding coherent transactions on the interface, hence the information is derived from the activities performed on the interface. There are many DUT specific scheduling behaviours that impact the behaviour in which the system monitor associates coherent transactions to snoop transactions. The snoop transactions can be determined by providing the schedule information of the NOC, if the signals within the NOC are tapped and corresponding transactions provided to the system monitor.

#### 6.19.1 Solution Description

The solution description for design specific coherent to snoop transaction is described in the following example. For example, when the VIP cannot associate snoops to coherent transactions appropriately. Consider the following steps:

## **J** Note

A topology where master[0] is a full ACE port and master[1] is an ACE-LITE port.

- 1. The DUT is configured to generate a CLEANINVALID snoop for READONCE and CLEANINVALID/MAKEINVALID for WRITEUNIQUE transactions.
- 2. Master[1] issues a READONCE transaction. While this is outstanding a WRITEUNIQUE is also issued from master[1] to the same address.
- 3. The snoops (CLEANINVALID snoop) corresponding to the READONCE are sent first to master[0], followed by those (MAKEINVALID snoop) corresponding to WRITEUNIQUE.
- 4. The WRITEUNIQUE completes first, after which, the system monitor tries to associate the snoops.
- 5. The system monitor associates the CLEANINVALID snoop to WRITEUNIQUE transaction.
- 6. After the READONCE completes, it tries to associate the MAKEINVALID, but it cannot because MAKEINVALID is not configured as a valid snoop for READONCE transactions.

The system monitor tries to associate snoops in the order in which the responses complete. However, this is not the scheduling sequence maintained by the NOC. If there is visibility into the scheduling of the NOC, then the system monitor can use that information. The signals can be connected from the output of the scheduler to a VIP and provided to the corresponding transactions of the system monitor using a TLM port. The system monitor uses this information to correlate transactions. In the example, the output of the scheduler delivers the READONCE transaction followed by the WRITEUNIQUE transaction. This

information is used by the system monitor to determine the READONCE transaction previously associated before the WRITEUNIQUE transaction, thereby verifying the snoops ahead in the queue are associated to the transactions which are ahead as per the scheduler's output to maintain the sequence.

#### 6.19.2 User Interface

The svt\_axi\_port\_monitor class has the following API added to push transactions from the scheduler to the port monitors. This is similar to the existing API

```
(svt_axi_port_monitor::push_coherent_xact_to_port_monitor)
```

/\*\* Task that can be used to drive an exernal coherent transaction to the port monitor. This transaction must be sampled from the output received from the scheduler within the interconnect, since the transaction sequence are used as input for this API and is used by the system monitor to associate snoops to coherent transactions \*/

```
extern virtual function void
push_coherent_xact_from_ic_scheduler_to_port_monitor(svt_axi_transaction xact);
```

## 6.20 Single Outstanding Transaction Per AxID

The Master VIP component supports a feature where there can only be a single outstanding transaction for a given AxID value for Non-Device and Non-DVM transactions.

You must configure the following members to enable this feature:

- svt\_axi\_port\_configuration::single\_outstanding\_per\_id\_enable
- ❖ svt axi port configuration::single outstanding per id kind

For more details on each member, see AXI Class Reference HTML documentation.

Added the following protocol check for this feature:

```
axi_checker::perform_non_dvm_non_device_with_overlap_id_check
```

## 6.21 Interleaved Port Support

AXI VIP master or slave VIP components support interleaved set of addresses. The master components and slave components can be grouped together in interleaved group. Master or slave components within an interleaved group will support a unique non-overlapping set of address ranges. For example, assume that there are two masters within an interleaved group. Master 0 supports address range 0 to 63, Master 1 supports address range 64 to 127, Master 0 supports address range 128 to 191, Master 1 supports address range 192 to 255, and so on. It means that the Master 0 generates transactions with addresses 0 to 63, 128 to 191 and so on. The interconnect snoops Master 0 for addresses 0 to 63, 128 to 191 and so on.

- ❖ AXI System monitor issues error if it observes snoop transaction for an address that is issued to a master which does not support the address range.
- ❖ AXI System monitor issues error if it observes snoop transaction issued within the same interleaved group.
- AXI System Monitor checks whether the coherent address observed on master port falls within the interleaving address range. If not, System Monitor generates error.
- AXI System Monitor checks whether the address that is received on slave port falls in the interleaving address range. If the address does not lie in the interleaving address range for this Slave port, then the AXI System Monitor generates error.

In active mode, Master VIP checks if the coherent address generated by it falls in the interleaving address range. If the address does not lie in the interleaving address range for this master port, then the Master VIP generates error through is\_valid() check. The Master VIP continues to transmit the transaction.

In active mode, Master VIP checks if the snoop address received by it falls in the interleaving address range. If the address does not lie in the interleaving address range for this master port, then the Master VIP generates error through is\_valid() check.

In passive mode, Master VIP checks whether the coherent or snoop address observed on this port falls within the interleaving address range. If not, then the Master VIP generates error.

In active and passive mode, Slave VIP checks if the address that is received by it falls in the interleaving address range. If the address does not lie in the interleaving address range for this Slave port, then the Slave VIP generates error.

The following configuration members must be programmed to enable this feature. For more details on each member, see AXI Class Reference HTML documentation:

```
    svt_axi_port_configuration::port_interleaving_enable
    svt_axi_port_configuration::port_interleaving_size
    svt_axi_port_configuration::port_interleaving_group_id
    svt_axi_port_configuration::dvm_sent_from_interleaved_port
    svt_axi_port_configuration::device_xact_sent_from_interleaved_port
    svt_axi_port_configuration::port_interleaving_index
    svt_axi_port_configuration::port_interleaving_for_device_xact_enable
```

#### Example 6-1 Use Case

#### ❖ Scenario 1

Two interleaved ACE master (64 bytes Interleaving Size).

You must configure the *cust\_svt\_axi\_system\_configuration* file as shown below:

```
master_cfg[0].port_interleaving_enable = 1;
master_cfg[0].port_interleaving_group_id = 2;
master_cfg[0].dvm_sent_from_interleaved_port = 0;
master_cfg[0].port_interleaving_size =64;
master_cfg[0].port_id = 0;
master_cfg[0].port_interleaving_index = 0;
master_cfg[1].port_interleaving_enable = 1;
master_cfg[1].port_interleaving_group_id = 2;
master_cfg[1].dvm_sent_from_interleaved_port = 0;
master_cfg[1].port_interleaving_size =64;
master_cfg[1].port_id = 1;
master_cfg[1].port_interleaving_index = 1;
```

The VIP will take care of the interleaving based on the above configuration inputs In the above use case, VIP will generate error if address[6] == 0 address comes on port 1 and also if address[6] == 1 comes on port 0.

#### ❖ Scenario 2

Two slaves are interleaved with interleaving size 512 bytes.

You must configure the VIP as shown below:

```
slave_cfg[0].port_interleaving_enable = 1;
slave_cfg[0].port_interleaving_group_id = 2;
```

```
slave_cfg[0].dvm_sent_from_interleaved_port = 0;
slave_cfg[0].port_interleaving_size =512;
slave_cfg[0].port_interleaving_index = 0;
slave_cfg[0].port_id = 0;
slave_cfg[1].port_interleaving_enable = 1;
slave_cfg[1].port_interleaving_group_id = 2;
slave_cfg[1].dvm_sent_from_interleaved_port = 0;
slave_cfg[1].port_interleaving_size =512;
slave_cfg[1].port_id = 1;
slave_cfg[1].port_interleaving_index = 1;
```

In the above scenario, slave VIP will generate an error if address[9] == 1 is observed on port 0. This is because slave[0] is configured with port\_interleaving\_index = 0. Therefore, port 0 is first in the interleaving scheme and expected to receive addresses only with address[9]== 0.

AXI VIP ensures that WriteUnique/WriteLineUnique transactions from one interleaved port do not overlap in time with WriteBack/WriteClean/WriteEvict transactions from the same or another interleaved port. This requirement arises from the fact that the interleaved ports within the same group are considered as a single master component by the interconnect. This behavior is applicable to all the interleaved ports within the interleaved group, irrespective of the address.

## 6.22 Master to Slave Path Access Coverage

This feature allows you to identify the master to slave paths covered during the simulation. The cover group name defined for this purpose is trans\_cross\_master\_to\_slave\_path\_access. Note that this coverage works in conjunction with the AXI Complex Memory Map feature. For more details on covergroup, see AXI Class Reference HTML documentation.

Perform the following steps to enable this feature:

- 1. Enable the covergroup by setting port configuration
   svt\_axi\_port\_configuration::trans\_cross\_master\_to\_slave\_path\_access\_cov\_enable to
   1
- 2. Enable the AXI Complex Memory Map feature by setting the system configuration svt\_axi\_system\_configuration::enable\_complex\_memory\_map to 1.
- 3. Define the macro SVT\_AMBA\_PATH\_COV\_DEST\_NAMES with the names of the slaves in the system. These are user-defined names, which identify the slave ports within the system. These names will be used in the bin names of the covergroup.

For example,

```
`define SVT_AMBA_PATH_COV_DEST_NAMES slave_0, slave_1, slave_2, slave_3, slave_4, slave_5
```

4. In Master configuration, assign the master name to

svt\_axi\_port\_configuration::source\_requester\_name. This is a user-defined name, which identifies the master port. This name will be used in the bin names of the covergroup.

For example,

```
axi_sys_cfg.master_cfg[0].source_requester_name = $sformatf("master_%0d",0);
```

5. In Master configuration, push back the slave names in to

svt\_axi\_port\_configuration::path\_cov\_slave\_names. Note that these names should match the names specified in the macro SVT\_AMBA\_PATH\_COV\_DEST\_NAMES. These names signify the slave ports to which the master port can communicate.

For example,

```
axi_sys_cfg.master_cfg[0].path_cov_slave_names.push_back(svt_amba_addr_mapper::slave_0);
axi_sys_cfg.master_cfg[0].path_cov_slave_names.push_back(svt_amba_addr_mapper::slave_1);
axi_sys_cfg.master_cfg[0].path_cov_slave_names.push_back(svt_amba_addr_mapper::slave_2);
axi_sys_cfg.master_cfg[0].path_cov_slave_names.push_back(svt_amba_addr_mapper::slave_3);
axi_sys_cfg.master_cfg[0].path_cov_slave_names.push_back(svt_amba_addr_mapper::slave_4);
axi_sys_cfg.master_cfg[0].path_cov_slave_names.push_back(svt_amba_addr_mapper::slave_5);
```

- 6. Slave configuration svt\_axi\_port\_configuration::svt\_amba\_addr\_mapper dest\_addr\_mappers[] is the address mapper, which specifies the slave memory map as part of the AXI Complex Memory Map feature.
- 7. In the Slave configuration, instantiate the address mapper.

#### For example,

```
axi_sys_cfg.slave_cfg[0].dest_addr_mappers = new;
axi_sys_cfg.slave_cfg[0].dest_addr_mappers[0] =
svt_amba_addr_mapper::type_id::create("axi_slave_addr_mapper");
```

8. In the Slave configuration, specify the name for the slave port. Note that this name should match the name specified in the macro SVT\_AMBA\_PATH\_COV\_DEST\_NAMES. This name helps to identify the slave port. This name will be used in the bin names of the cover group.

#### For example,

```
axi_sys_cfg.slave_cfg[0].dest_addr_mappers[0].path_cov_slave_component_name =
svt_amba_addr_mapper::slave_0;
```

9. This step is optional and must be done only if, for a given address, the destination is different based on originating master. Note that these names should match the names specified in

```
svt axi port configuration::source requester name.
```

#### For example,

```
axi_sys_cfg.slave_cfg[0].dest_addr_mappers[0].source_masters.push_back("master_0");
axi_sys_cfg.slave_cfg[0].dest_addr_mappers[0].source_masters.push_back("master_1");
axi_sys_cfg.slave_cfg[0].dest_addr_mappers[0].source_masters.push_back("master_2");
axi_sys_cfg.slave_cfg[0].dest_addr_mappers[0].source_masters.push_back("master_3");
axi_sys_cfg.slave_cfg[0].dest_addr_mappers[0].source_masters.push_back("master_4");
axi_sys_cfg.slave_cfg[0].dest_addr_mappers[0].source_masters.push_back("master_5");
```

After configuring the above settings, run the simulation and review the covergroup trans\_cross\_master\_to\_slave\_path\_access in coverage report.

## 6.23 AXI\_ACE Path Coverage

The path coverage enhancement provides the cross coverage of transaction properties with Master to Slave access paths. This cross coverage can separate cross coverage group within VIP coverage.

The proposed VIP covergroup trans\_cross\_master\_to\_slave\_path\_access\_ace cross coverage is added in port level.

#### **Use Model:**

- 1. Enable the svt\_axi\_system\_configuration::enable\_complex\_memory\_map.
- 2. svt\_axi\_port\_configuration::trans\_cross\_master\_to\_slave\_path\_access\_cov\_enable enables path coverage for a given master.
- 3. Define SVT\_AMBA\_PATH\_COV\_DEST\_NAMES based on the names of the slaves in the system For example,

```
`ifndef SVT_AMBA_PATH_COV_DEST_NAMES
  `define SVT_AMBA_PATH_COV_DEST_NAMES
ace_lite_slave_0,ace_lite_slave_1,ace_lite_slave_2
`endif
```

For slaves: svt\_axi\_port\_configuration: svt\_amba\_addr\_mapper dest\_addr\_mappers[]; // This is where slave memory map is specified.

4. The general equation to determine if a given master address will be routed to a particular slave, is as that a master\_addr and the slave's address mapper must fulfill this condition. Here global\_addr actually refers to global base address of the slave.

```
master_addr and~slave_mapper.mask = slave mapper.global_addr.
```

Here are some examples on setting address map at the slave:

◆ Let us say there is a total slave address space of 2 GB and it is equally divided between two slaves. The definition will be as follows:

```
Slave 1 address range is: 0000_0000 to 3FFF_FFFF (0 to 1GB)
global_addr = 0;local_addr = 0;mask = 0x3fff_ffff; (fullfill the above condition)
Slave 2: 4000_0000 to 7FFF_FFFF (1GB to 2GB)
global_addr = 0x4000_0000; local_addr = 0x4000_0000 mask = 0x3fff_ffff (fullfill the above condition)
```

♦ Now let us say that the below address space is interleaved between the two slaves.

```
Slave 1 address range is: 0000_0000 to FFFF_FFFF

Slave 2 address range is: 0000_0000 to FFFF_FFFF

Slave_0, mapper 0 and Slave 1, mapper 0:

global_addr = 0;local_addr = 0;mask = ffff_ffff; (fullfill the above condition)
```

Now let us say that slaves are interleaved at 400 address boundary. So the mapping of slave 1 and slave 2 has to be divided into multiple mappings. The general rule of thumb is that the mask value cannot exceed the global\_addr (except when global\_addr is 0 or memory is interleaved).

```
Slave_0, mapper 1: 0000\_0000 to 0000\_03FF -> global_addr = 32'h0000\_0000; mask = 32'hFFFF\_FBFF;
```

```
Slave_1, mapper 1: 0000_0400 to 0000_07FF -> global_addr = 32'h0400_0000; mask =32'hFFFF FBFF;
```

In this case, address 10th bit decides the Slave \_0 and Slave\_1, If 10th bit of address signal is 0 than Slave1 is being accessed and if its 1 than Slave2 is being accessed. Here, mask is configured based on the above condition to satisfy and address 10th bit should match to route to the particular slaves.

```
svt_amba_addr_mapper ::local addr should be equal to the svt_amba_addr_mapper ::global_addr and svt_amba_addr_mapper ::mask should be configured based on the svt_amba_addr_mapper ::global_address.
svt_amba_addr_mapper::is_register_addr_space set as 0.
```

#### 5. Snippet of Master Configuration with respect to Path Coverage:

set\_amba\_sys\_config()

foreach (this.axi\_sys\_cfg[i]) begin
 set\_axi\_system\_configuration(this.axi\_sys\_cfg[i],num\_axi\_masters,num\_axi\_slaves);
 void'(set\_axi\_test\_suite\_system\_config(this.axi\_sys\_cfg[i]));
 //Required for test\_suite or interconnect VIP, not typically required for users
 this.axi\_sys\_cfg[i].set\_addr\_range(0,64'h0,(64'hFFF\_FFFF\_FFFF\_FFFF));
 this.axi\_sys\_cfg[i].set\_addr\_range(1,64'h1000\_0000\_0000,(64'h1FFF\_FFFF\_FFFFFFFF));
 this.axi\_sys\_cfg[i].set\_addr\_range(2,64'h2000\_0000\_0000,(64'h2FFF\_FFFF\_FFFFFFF));
 end

set\_axi\_system\_configuration()
 foreach(axi\_sys\_cfg.master\_cfg[i]) begin

```
foreach(axi_sys_cfg.master_cfg[i]) begin
    axi_sys_cfg.master_cfg[i].source_requester_name = $sformatf("ace_master_%0d",i);
axi_sys_cfg.master_cfg[i].path_cov_slave_names.push_back(svt_amba_addr_mapper::ace_lite_slave_0);
axi_sys_cfg.master_cfg[i].path_cov_slave_names.push_back(svt_amba_addr_mapper::ace_lite_slave_1);
axi_sys_cfg.master_cfg[i].path_cov_slave_names.push_back(svt_amba_addr_mapper::ace_lite_slave_2);
end
```

#### 6. Snippet of Slave Configuration with respect to Path Coverage:

```
foreach(axi_sys_cfg.slave_cfg[i]) begin
      axi_sys_cfg.slave_cfg[i].axi_interface_type =
svt axi port configuration::ACE LITE;
      // configure the dest_addr_mappers
      if (i == 0) begin
        axi_sys_cfg.slave_cfg[i].dest_addr_mappers = new[1];
        axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0] =
svt_amba_addr_mapper::type_id::create("axi_slave_addr_mapper");
        axi sys cfq.slave cfg[i].dest addr mappers[0].path cov slave component name =
svt_amba_addr_mapper::ace_lite_slave_0;
        axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].global_addr = 64'h0;
        axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].local_addr = 64'h0;
        axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].mask = 64'hfff_ffff_ffff_ffff;
        axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].is_register_addr_space = 0;
axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].source_masters.push_back("ace_master_0");
axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].source_masters.push_back("ace_master_1");
axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].source_masters.push_back("ace_master_2");
axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].source_masters.push_back("ace_master_3");
axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].source_masters.push_back("ace_master_4");
axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].source_masters.push_back("ace_master_5");
      else if (i == 1) begin
        axi_sys_cfg.slave_cfg[i].dest_addr_mappers = new[1];
        axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0] =
svt_amba_addr_mapper::type_id::create("axi_slave_addr_mapper");
        axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].path_cov_slave_component_name =
svt amba addr mapper::ace lite slave 1;
```

```
axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].global_addr =
64'h1000_0000_0000_0000;
       axi sys cfg.slave cfg[i].dest addr mappers[0].local addr =
64'h1000 0000 0000 0000;
        axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].mask = 64'hFFF_FFFF_FFFF_FFFF;
       axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].is_register_addr_space = 0;
axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].source_masters.push_back("ace_master_0");
axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].source_masters.push_back("ace_master_1");
axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].source_masters.push_back("ace_master_2");
axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].source_masters.push_back("ace_master_3");
axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].source_masters.push_back("ace_master_4");
axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].source_masters.push_back("ace_master_5");
      else if (i == 2) begin
        axi_sys_cfg.slave_cfg[i].dest_addr_mappers = new[1];
        axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0] =
svt_amba_addr_mapper::type_id::create("axi_slave_addr_mapper");
       axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].path_cov_slave_component_name =
svt_amba_addr_mapper::ace_lite_slave_2;
       axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].global_addr =
64'h2000 0000 0000 0000;
        axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].local_addr =
64'h2000_0000_0000_0000;
        axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].mask = 64'hfff_ffff_ffff_ffff;
       axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].is_register_addr_space = 0;
axi sys cfq.slave cfq[i].dest addr mappers[0].source masters.push back("ace master 0");
axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].source_masters.push_back("ace_master_1");
axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].source_masters.push_back("ace_master_2");
axi sys cfq.slave cfq[i].dest addr mappers[0].source masters.push back("ace master 3");
axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].source_masters.push_back("ace_master_4");
axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].source_masters.push_back("ace_master_5");
      else if (i == 3) begin
        axi_sys_cfg.slave_cfg[i].dest_addr_mappers = new[1];
        axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0] =
svt_amba_addr_mapper::type_id::create("axi_slave_addr_mapper");
       axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].path_cov_slave_component_name =
svt_amba_addr_mapper::ace_lite_slave_3;
       axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].global_addr =
64'h3000 0000 0000 0000;
        axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].local_addr =
64'h3000_0000_0000_0000;
        axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].mask = 64'hFFF_FFFF_FFFF_FFFF;
        axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].is_register_addr_space = 0;
axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].source_masters.push_back("ace_master_0");
```

```
axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].source_masters.push_back("ace_master_1");
axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].source_masters.push_back("ace_master_2");
axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].source_masters.push_back("ace_master_3");
axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].source_masters.push_back("ace_master_4");
axi_sys_cfg.slave_cfg[i].dest_addr_mappers[0].source_masters.push_back("ace_master_5");
end
end
```

#### 6.24 Wait State Mechanisms

There are two ways to insert wait states in awready signal.

- ❖ Program the value of svt\_axi\_transaction::addr\_ready\_delay to apply delays in awready signal assertion from the slave. See class reference HTML for further reference.
- Set svt\_axi\_transaction::suspend\_awready to 1. This can be set to 1 from the svt\_axi\_slave\_memory\_reponse\_sequence in the testbench.
  Once svt\_axi\_transaction::suspend\_awready is set to 1, active slave VIP will drive awready signal to 0 and will wait for svt\_axi\_transaction::suspend\_awready to become 0 before driving awready signal high.



This is applicable only when svt\_axi\_port\_configuration::default\_awready is set to 0. See class reference HTML for further reference.

## 6.25 Interconnect Routing

Interconnect Routing you to redefine the master to slave routing behavior in the interconnect VIP. Interconnect VIP will call this method and use the first slave port returned by this function to route the incoming master transaction.

By default, this method is undefined and returns FALSE.

It is expected to define this method with the routing behavior of your choice and it must return TRUE. Interconnect VIP will then use the first slave port returned by this function for routing master transaction. Else, it will use its default mode of routing master transactions to slave ports based on the address ranges.



This method is applicable for Interconnect VIP and System Monitor component.

The following system configuration function needs to be programmed to enable this feature.

```
extern virtual function bit
get_interconnect_slave_route_port(bit[`SVT_AXI_MAX_ADDR_WIDTH-1:0]
tagged_master_addr, bit is_register_addr_space, int master_port_id, output int
slave_port_ids[$]);
```

For more details, see AXI Class Reference HTML.

**Usage Examples:** 

# **7** Usage Notes

This chapter provides usage notes for AXI Verification IP.

This chapter discusses the following topics:

**❖** "Managing Coverage Through Exclude File" on page 163

## 7.1 Managing Coverage Through Exclude File

As per the requirement, coverbins or covergroups can be excluded, by using the exclude file. The exclude file can be generated using Verdi and the exclusions can be incorporated in the urgReport.



For more information, see Verdi documentation.

# **Troubleshooting**

This chapter provides some useful information that can help you troubleshoot common issues that you may encounter while using the AXI VIP. This chapter discusses the following topics:

"Using Debug Port" on page 165

## 8.1 Using Debug Port

Port interfaces svt\_axi\_master\_if and svt\_axi\_slave\_if of AXI VIP provide a modport svt\_axi\_debug\_modport for debugging purpose. The signals in the debug modport represent the transaction number and beat number which are currently executing on all channels of the AXI port.

The debug port signals starting with mon are driven by the port monitor within the Master and Slave Agent. The signals, read\_addr\_xact\_num, write\_addr\_xact\_num, write\_data\_xact\_num and write\_data\_beat\_num are driven by master driver in Master Agent. The signals, read\_data\_xact\_num, read\_data\_beat\_num and write\_resp\_xact\_num are driven by slave driver in Slave Agent.



## **Reporting Problems**

#### A.1 Introduction

This chapter outlines the process for working through and reporting VIP transactor issues encountered in the field. It describes the data you must submit when a problem is initially reported to Synopsys. After a review of the initial information, Synopsys may decide to request adjustments to the information being requested, which is the focus of the next section. This section outlines the process for working through and reporting problems. It shows how to use Debug Automation to enable all the debug capabilities of any VIP. In addition, the VIP provides a case submittal tool to help you pack and send all pertinent debug information to Synopsys Support.

## A.2 Debug Automation

Every Synopsys model contains a feature called "debug automation". It is enabled through *svt\_debug\_opts* plusarg. The Debug Automation feature allows you to enable all relevant debug information. The following are critical features of debug automation:

- ❖ Enabled by the use of a command line run-time plusarg.
- Can be enabled on individual VIP instances or multiple instances using regular expressions.
- Enables debug or verbose message verbosity:
  - ◆ The timing window for message verbosity modification can be controlled by supplying start\_time and end\_time.
- Enables at one time any, or all, standard debug features of the VIP:
  - **♦** Transaction Trace File generation
  - **♦** Transaction Reporting enabled in the transcript
  - ◆ PA database generation enabled
  - **♦** Debug Port enabled
  - ◆ Optionally, generates a file name *svt\_model\_out.fsdb* when Verdi libraries are available

When the Debug feature is enabled, then all VIP instances that are enabled for debug will have their messages routed to a file named *svt\_debug.transcript*.

## A.3 Enabling and Specifying Debug Automation Features

Debug Automation is enabled through the use of a run-time plusarg named +svt\_debug\_opts. This plusarg accepts an optional string-based specification to control various aspects Debug Automation. If this

command control specification is not supplied, then the feature will default to being enabled on all VIP instances with the default options listed as follows:

Note the following about the plusarg:

- ❖ The command control string is a comma separated string that is split into the multiple fields.
- All fields are optional and can be supplied in any order.

The command control string uses the following format (white space is disallowed):

inst:<inst>, type:<string>, feature:<string>, start\_time:<longint>, end\_time:<longint>, verb
osity:<string>

The following table explains each control string:

Table A-1 Control Strings for Debug Automation plusarg

| Field      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| inst       | Identifies the VIP instance to apply the debug automation features. Regular expressions can be used to identify multiple VIP instances. If this value is not supplied, and if a type value is not supplied, then the debug automation feature will be enabled on all VIP instances.                                                                                                                                                                                                                                   |
| type       | Identifies a class type to apply the debug automation features. When this value is supplied then debug automation will be enabled for all instances of this class type.                                                                                                                                                                                                                                                                                                                                               |
| feature    | Identifies a sub-feature that can be defined by VIP designers to identify smaller grouping of functionality that is specific to that title. The definition and implementation of this field is left to VIP designers, and by default it has no effect on the debug automation feature. (Specific to VIP titles)                                                                                                                                                                                                       |
| start_time | Identifies when the debug verbosity settings will be applied. The time must be supplied in terms of the timescale that the VIP is compiled. If this value is not supplied, then the verbosity settings will be applied at time zero.                                                                                                                                                                                                                                                                                  |
| end_time   | Identifies when the debug verbosity settings will be removed. The time must be supplied in terms of the timescale that the VIP is compiled. If this value is not supplied, then the debug verbosity remains in effect until the end of the simulation.                                                                                                                                                                                                                                                                |
| verbosity  | Message verbosity setting that is applied at the start_time. Two values are accepted in all methodologies: DEBUG and VERBOSE. UVM and OVM users can also supply the verbosity that is native to their respective methodologies (UVM_HIGH/UVM_FULL and OVM_HIGH/OVM_FULL). If this value is not supplied then the verbosity defaults to DEBUG/UVM_HIGH/OVM_HIGH. When this feature is enabled, then all VIP instances that are enabled for debug will have their messages routed to a file named svt_debug.transcript. |

#### **Examples:**

Enable on all VIP instances with default options:

+svt\_debug\_opts

**Enable on all instances:** 

- containing the string "endpoint" with a verbosity of UVM\_HIGH
- starting at time zero (default) until the end of the simulation (default):

+svt\_debug\_opts=inst:/.\*endpoint.\*/,verbosity:UVM\_HIGH

**Enable on all instances:** 

starting at time 1000 until time 1500:

+svt\_debug\_opts=start\_time:1000,end\_time:1500,verbosity:VERBOSE

Enable debug feature on all instances using default options:

❖ By setting the macro SVT\_DEBUG\_OPTS to 1 in the command line, the debug feature is enabled on all instances using default options. The macro will enable the XMLs and Trace files.

gmake <testname> SVT\_DEBUG\_OPTS=1 PA=FSDB



The SVT\_DEBUG\_OPTS option is available through the installed VIP examples, but if required, in customer environments, then a similar feature should be added to their environment.

The PA=FSDB option is the default option available in public examples and is required to enable Verdi libraries, and that when this option is used, then the Debug Opts file will record VIP activity to a file named svt\_model\_log.fsdb.

In addition, the SVT Automated Debug feature will enable waveform generation to an FSDB file, if the Verdi libraries are available. When enabled this feature, it should cause the simulator to dump waveform information only for the VIP interfaces.

When this feature is enabled then all VIP instances that have been enabled for debug will have their messages routed to a file named svt\_debug.transcript.

## A.4 Debug Automation Outputs

The Automated Debug feature generates a *svt\_debug.out* file. It records important information about the debug feature itself, and data about the environment that the VIPs are operating in. This file records the following information:

- **❖** The compiled timeunit for the SVT package
- **❖** The compiled timeunit for each SVT VIP package
- Version information for the SVT library
- Version information for each SVT VIP
- Every SVT VIP instance, and whether the VIP instance has been enabled for debug
- ❖ For every SVT VIP enabled for debug, a list of configuration properties that have been modified to enable debug will be listed
- A list of all methodology phases will be recorded, along with the start time for each phase

The following are the output files generated:

- svt\_debug.out: It records important information about the debug feature itself, and data about the environment that the VIPs are operating. One file is optionally created when this feature is enabled, depending on if the Verdi libraries are available.
- svt\_debug.transcript: Log files generated by the simulation run.
- \* transaction trace: Log files that records all the different transaction activities generated by VIPs.
- \* svt\_model\_log.fsdb: Contains PA FSDB information (if the VIP supports this), and which contains other recorded activity. The additional information records signal activity associated with the VIP interface, TLM input (through SIPP ports), other TLM output activity, configurations applied to the VIP, and all callback activity (recorded by before and after callback execution).

#### A.5 FSDB File Generation

To enable FSDB writing capabilities, the simulator compile-time options and environment must be updated to enable this. The steps to enable this are specific to the simulator being used (the {LINUX/LINUX64} label needs to be replaced based on the platform being used). The ability to write to an FSDB file requires that the user supplies the Verdi dumper libraries when they compile their testbench. If these are not supplied then the VIP will not be enabled to generate the <code>svt\_model\_log.fsdb</code> file.

#### A.5.1 VCS

The following must be added to the compile-time command:

```
-debug access
```

For more information on how to set the FSDB dumping libraries, see Appendix B section in *Linking Novas Files with Simulators and Enabling FSDB Dumping* guide available at: \$VERDI HOME/doc/linking dumping.pdf.

#### A.5.2 Questa

The following must be added to the compile-time command:

```
+define+SVT_FSDB_ENABLE -pli novas_fli.so
```

#### A.5.3 Incisive

The following must be added to the compile-time command:

```
+define+SVT_FSDB_ENABLE -access +r
```

#### A.6 Initial Customer Information

Follow these steps when you call the Synopsys Support Center:

- 1. Before you contact technical support, be prepared to provide the following:
  - **♦** A description of the issue under investigation.
  - **♦** A description of your verification environment.

Enable the Debug Opts feature. For more information, see the "Debug Automation" on page 167.

## A.7 Sending Debug Information to Synopsys

To help you debug testing issues, follow the given instructions to pack all pertinent debug information into one file which you can send to Synopsys (or to other users in your company):

- 1. Create a description of the issue under investigation. Include the simulation time and bus cycle of the failure, as well as any error or warning messages that are part of the failure.
- 2. Create a description of your verification environment. Assemble information about your simulation environment, making sure to include:
  - **♦** OS type and version
  - ◆ Testbench language (SystemVerilog or Verilog)
  - Simulator and version
  - ◆ DUT languages (Verilog)

3. Use the VIP case submittal tool to pack a file with the appropriate debug information. It has the following usage syntax:

\$DESIGNWARE HOME/bin/snps vip debug [-directory <path>]

The tool will generate a <username>.<uniqid>.svd file in the current directory. The following files are packed into a single file:

- ♦ HISTL
- ♦ MISC
- ♦ SLID
- ♦ SVTO
- ♦ SVTX
- ♦ TRACE
- ♦ VCD
- ♦ VPD
- ♦ XML

If any one of the above files are present, then the files will be saved in the <username>.<uniqid>.svd in the current directory. The simulation transcript file will not be part of this and it will be saved separately.

The -directory switch can be specified to select an alternate source directory.

- 4. You will be prompted by the case submittal tool with the option to include additional files within the SVD file. The simulation transcript files cannot be automatically identified and it must be provided during this step.
- 5. The case submittal tool will display options on how to send the file to Synopsys.

#### A.8 Limitations

Enabling DEBUG or VERBOSE verbosity is an expensive operation, both in terms of runtime and disk space utilization. The following steps can be used to minimize this cost:

- ♦ Only enable the VIP instance necessary for debug. By default, the +svt\_debug\_opts command enables Debug Opts on all instances, but the 'inst' argument can be used to select a specific instance.
- Use the start\_time and end\_time arguments to limit the verbosity changes to the specific time window that needs to be debugged.