Verification Continuum™

# VC Verification IP AMBA AHB UVM Getting Started Guide

Version S-2021.06, June 2021



### **Copyright Notice and Proprietary Information**

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

www.synopsys.com

# **Contents**

| Preface                                          | 5   |
|--------------------------------------------------|-----|
| Chapter 1                                        |     |
| Overview of the Getting Started Guide            | 6   |
| Chapter 2                                        |     |
| Integrating the VIP into a User Testbench        | 8   |
| 2.1 VIP Testbench Integration Flow               | . 8 |
| 2.1.1 Connecting the VIP to the DUT              | . 9 |
| 2.1.2 Instantiating and Configuring the VIP      |     |
| 2.1.3 Creating a Test Sequence                   | 11  |
| 2.1.4 Creating a Test                            | 11  |
| 2.2 Compiling and Simulating a Test with the VIP | 12  |
| 2.2.1 Directory Paths for VIP Compilation        | 12  |
| 2.2.2 VIP Compile-time Options                   |     |
| 2.2.3 VIP Runtime Option                         |     |
| Appendix A                                       |     |
| Summary of Commands, Documents, and Examples     | .14 |
| A.1 Useful Commands                              |     |
| A.2 Primary Documentation for VC VIP AHB         |     |
| A.3 Example Home Directory                       |     |

## **Preface**

#### **About This Document**

This Getting Started Guide presents information about integrating the VC VIP for AHB (referred to as VIP) into testbenches that are compliant with the SystemVerilog Universal Verification Methodology (UVM). You are assumed to be familiar with the AMBA AHB protocol and UVM.

#### **Web Resources**

Documentation through SolvNet: https://solvnetplus.synopsys.com (Synopsys password required) Synopsys Common Licensing (SCL): http://www.synopsys.com/keys

#### **Customer Support**

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

- 1. Go to https://solvnetplus.synopsys.com and open a case.

  Enter the information according to your environment and your issue.
- Send an e-mail message to support\_center@synopsys.com.
   Include the Product name, Sub Product name, and Tool Version in your e-mail so it can be routed correctly.
- 3. Telephone your local support center.
  - ♦ North America: Call 1-800-245-8005 from 7 AM to 5:30 PM Pacific time, Monday through Friday.
  - All other countries:
     https://www.synopsys.com/support/global-support-centers.html

#### Synopsys Statement on Inclusivity and Diversity

Synopsys is committed to creating an inclusive environment where every employee, customer, and partner feels welcomed. We are reviewing and removing exclusionary language from our products and supporting customer-facing collateral. Our effort also includes internal initiatives to remove biased language from our engineering and working environment, including terms that are embedded in our software and IPs. At the same time, we are working to ensure that our web content and software applications are usable to people of varying abilities. You may still find examples of non-inclusive language in our software or documentation as our IPs implement industry-standard specifications that are currently under review to remove exclusionary language.

1

# **Overview of the Getting Started Guide**

This Getting Started Guide presents information about integrating the VC VIP for AHB (referred to as VIP) into testbenches that are compliant with the SystemVerilog Universal Verification Methodology (UVM). Figure 1-1 is the VIP integration and test work flow presented in this document. The steps for setting up the VIP are documented in the *VC Verification IP UVM Installation and Setup Guide*. This guide is available on the SolvNet Download Center (click here -> VC VIP Library -> R-2020.12-> Installation Guide) and in the VIP installation at the following location:

\$DESIGNWARE HOME/vip/svt/common/latest/doc/uvm install.pdf

The VIP setup should be completed before executing the steps in this document.

Setting Up the VIP

**VIP Integration and Test Work Flow** 

Figure 1-1



You are assumed to be familiar with the AMBA AHB protocol and UVM. For more information on the VIP, refer to the VC Verification IP AMBA AHB UVM User Manual on SolvNet (click here) or in the VIP installation at the following location:

\$DESIGNWARE\_HOME/vip/svt/amba\_svt/latest/doc/ahb\_svt\_uvm\_user\_guide.pdf

2

# Integrating the VIP into a User Testbench

The VC VIP for AHB provides a suite of advanced SystemVerilog verification components and data objects that are compliant to UVM. Integrating these components and objects into any UVM compliant testbench is straightforward. For a complete list of VIP components and data objects, see the main page of the VC VIP AHB Class Reference Manual (only in HTML format) at the following location:

\$DESIGNWARE\_HOME/vip/svt/amba\_svt/latest/doc/ahb\_svt\_uvm\_class\_reference/html/
index.html

#### 2.1 VIP Testbench Integration Flow

The AHB system environment (svt\_ahb\_system\_env) is the top-level component provided by the VIP. This environment encapsulates all of the VIP components and implicitly constructs the required number of AHB master and AHB slave agents as specified by its system configuration object. You can instantiate and construct the AHB system environment in the top-level environment of your UVM testbench.

Figure 2-1 Top-level Architecture of an AHB VIP Testbench



Figure 2-1 is a top-level architecture of a simple VC VIP for AHB testbench. The steps for integrating the VIP into a UVM testbench are described in the following sections:

- ◆ "Connecting the VIP to the DUT"
- "Instantiating and Configuring the VIP"
- ◆ "Creating a Test Sequence"
- ◆ "Creating a Test"

The code snippets presented in this chapter are generic and can be applied to any UVM compliant testbench. For more information on the code usage, see the following example:

```
$DESIGNWARE_HOME/vip/svt/amba_svt/latest/examples/sverilog/
tb_ahb_svt_uvm_basic_sys
```

#### 2.1.1 Connecting the VIP to the DUT

The following are the steps to establish a connection between the VIP to the DUT in your top-level testbench:

◆ Include the standard UVM and VIP files and packages.

◆ Instantiate and connect the top-level AHB interface to a system clock.

```
svt_ahb_if ahb_if();

assign ahb_if.hclk = <system clock>;"
assign ahb_if.hresetn = <System reset>;
```

◆ Connect the top-level AHB interface to the DUT and the AHB system environment.

```
dut dut_inst(ahb_if);

uvm_config_db#(svt_ahb_vif)::set(uvm_root::get(),
   "uvm_test_top.env.ahb_system_env", "vif", ahb_if);
```

The  $uvm\_config\_db$  command connects the top-level AHB interface to the virtual interface of the AHB system environment. The  $uvm\_test\_top$  represents the top-level module in the UVM environment. The env is an instance of your testbench environment. The  $ahb\_system\_env$  is an instance of the AHB system environment ( $svt\_ahb\_system\_env$ ).

◆ Connect the common reset pin of the AHB interface. The reset connection propagates to each master and slave interface instance in the environment.

```
assign ahb_if.hresetn = <User-select Reset Signal>;
```

#### 2.1.2 Instantiating and Configuring the VIP

The following are steps to instantiate and configure the AHB system environment in your testbench environment.

◆ Instantiate the AHB system environment (svt\_ahb\_system\_env) in the build phase of your testbench environment.

```
svt_ahb_system_env ahb_system_env;
ahb_system_env =
svt_ahb_system_env::type_id::create("ahb_system_env", this);
```

◆ Create a customized AHB system configuration class by extending the AHB system configuration class (svt\_ahb\_system\_configuration) and specifying the required configuration parameters. For example:

```
class cust_svt_ahb_system_configuration extends
svt_ahb_system_configuration;
  function new (string name =
"cust_svt_ahb_system_configuration");
  super.new(name);

// Create a single AHB master agent and a single slave agent
  this.num_masters = 1;
  this.num_slaves = 1;

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

this.master_cfg[0].data_width = 256;
  this.slave_cfg[0].data_width = 256;

// Set interface as AHB_LITE
  this.ahb_lite = 1;

endfunction
endclass
```

For more information on the configuration class, see the svt\_ahb\_configuration, svt\_ahb\_master\_configuration and svt\_ahb\_slave\_configuration Class References at the following locations:

```
$DESIGNWARE_HOME/vip/svt/amba_svt/latest/doc/
ahb_svt_uvm_class_reference/html/class_svt_ahb_configuration.html

$DESIGNWARE_HOME/vip/svt/amba_svt/latest/doc/
ahb_svt_uvm_class_reference/html/
class_svt_ahb_master_configuration.html

$DESIGNWARE_HOME/vip/svt/amba_svt/latest/doc/
ahb_svt_uvm_class_reference/html/
class_svt_ahb_slave_configuration.html
```

◆ Construct the customized AHB system configuration and pass the configuration to the AHB system environment (instance of svt\_ahb\_system\_env) in the build phase of your testbench environment.

```
cfg =
cust_svt_ahb_system_configuration::type_id::create("cfg");

uvm_config_db#(svt_ahb_system_configuration)::set(this,
    "ahb_system_env", "cfg", cfg);
```

The cust\_svt\_ahb\_system\_configuration is the customized AHB system configuration as defined in the previous step. The "cfq" is an instance of this configuration.

#### 2.1.3 Creating a Test Sequence

The VIP provides a base sequence class for the AHB master agent (svt\_ahb\_master\_transaction\_base\_sequence) and the AHB slave agent (svt\_ahb\_slave\_transaction\_base\_sequence). You can extend these base sequences to create test sequences for the AHB master and slave agents.

For more information on the AHB master and slave base sequences, and the VIP sequence collection, see the Sequence Page of the VC VIP AHB Class Reference Manual at the following location:

```
$DESIGNWARE_HOME/vip/svt/amba_svt/latest/doc/
ahb_svt_uvm_class_reference/html/sequencepages.html
```

In addition, a list of random and directed sequences are available in the VIP examples. For more information on the example sequences, refer to the example directories at the following location:

```
$DESIGNWARE HOME/vip/svt/amba svt/latest/examples/sverilog
```

#### 2.1.4 Creating a Test

You can create a VIP test by extending the uvm\_test class. In the build phase of the extended class, you construct the testbench environment and set the respective AHB master and slave sequences.



You must set a slave response sequence for active slaves in the run phase.

#### 2.2 Compiling and Simulating a Test with the VIP

The steps for compiling and simulating a test with the VIP are described in the following sections:

- "Directory Paths for VIP Compilation"
- "VIP Compile-time Options"
- ◆ "VIP Runtime Option"

#### 2.2.1 Directory Paths for VIP Compilation

Specify the following directory paths in the compilation commands for the compiler to load the VIP files.

```
+incdir+project_directory_path/include/sverilog
+incdir+project_directory_path/src/sverilog/vendor
```

where project directory path is your project directory and vendor is your simulator vendor.

#### For example:

```
+incdir+/home/project1/testbench/vip/include/sverilog
+incdir+/home/project1/testbench/vip/src/sverilog/vcs
```

#### 2.2.2 VIP Compile-time Options

The following are the required compile-time options for compiling a testbench with the VC VIP for AMBA AHB:

```
+define+SVT_UVM_TECHNOLOGY
+define+UVM_PACKER_MAX_BYTES=1500000
+define+UVM_DISABLE_AUTO_ITEM_RECORDING
+define+SYNOPSYS_SV
```

#### Note

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.

| Macro                           | Description                                                                         |
|---------------------------------|-------------------------------------------------------------------------------------|
| SVT_UVM_TECHNOLOGY              | Specifies SystemVerilog based VIPs that are compliant with UVM                      |
| UVM_PACKER_MAX_BYTES            | Sets to 1500000 or greater                                                          |
| UVM_DISABLE_AUTO_ITEM_RECORDING | Disables the UVM automatic transaction begin and end event triggering and recording |
| SYNOPSYS_SV                     | Specifies SystemVerilog based VIPs that are compliant with UVM                      |

The following compile-time option is required if and only if you have created a user-defined file to override the VIP default maximum values of the system constants such as maximum delay values and maximum address width.

For more information, seeSection 3.3.7, Overriding System Constants of the VC Verification IP AMBA AHB UVM User Manual.

#### 2.2.3 VIP Runtime Option

No VIP specific runtime option is required to run simulations with the VIP. Only relevant UVM runtime options are required.

For example,

+UVM TESTNAME=random wr rd test



# Summary of Commands, Documents, and Examples

#### A.1 Useful Commands

Display VIP models and examples under the VIP installation directory specified by \$DESIGNWARE\_HOME:

```
% $DESIGNWARE HOME/bin/dw vip setup -info home
```

Add VIP models to the project directory:

```
% $DESIGNWARE_HOME/bin/dw_vip_setup -path project_directory -add
VIP_model -svlog
```

Add VIP examples to the directory where the command is executed:

```
% $DESIGNWARE_HOME/bin/dw_vip_setup -e VIP_example -svlog
```

#### A.2 Primary Documentation for VC VIP AHB

#### VC Verification IP UVM Installation and Setup Guide:

\$DESIGNWARE HOME/vip/svt/common/latest/doc/uvm install.pdf

#### VC VIP AHB UVM User Manual:

\$DESIGNWARE HOME/vip/svt/amba svt/latest/doc/ahb svt uvm user guide.pdf

#### VC VIP AHB Getting Started Guide:

\$DESIGNWARE HOME/vip/svt/amba svt/latest/doc/ahb svt uvm getting started.pdf

#### VC VIP AHB Class Reference Manual:

\$DESIGNWARE\_HOME/vip/svt/amba\_svt/latest/doc/ahb\_svt\_uvm\_class\_reference/html/ index.html

#### VC VIP AHB Verification Plans:

\$DESIGNWARE HOME/vip/svt/amba svt/latest/doc/VerificationPlans

#### A.3 Example Home Directory

Directory that contains a list of VIP example directories:

\$DESIGNWARE HOME/vip/svt/amba svt/latest/examples/sverilog

View simulation options for each example:

gmake help