# AXI4-Stream Verification IP v1.1

# LogiCORE IP Product Guide

**Vivado Design Suite** 

PG277 October 30, 2019





# **Table of Contents**

#### **IP Facts**

| Chapter 1: Overview                          |     |
|----------------------------------------------|-----|
| Feature Summary                              | . 6 |
| Applications                                 | . 6 |
| Licensing and Ordering                       | . 7 |
| Chapter 2: Product Specification             |     |
| Standards                                    | . 8 |
| Performance                                  | . 8 |
| User Parameters                              | . 8 |
| Port Descriptions                            | . 9 |
| AXI Protocol Checks and Descriptions         | 11  |
| Xilinx Configuration Checks and Descriptions | 12  |
| Chapter 3: Designing with the Core           |     |
| General Design Guidelines                    | 13  |
| Clocking                                     | 14  |
| Resets                                       | 14  |
| Chapter 4: Design Flow Steps                 |     |
| Customizing and Generating the Core          | 15  |
| AXI4-Stream VIP in Vivado IP Integrator      | 18  |
| Constraining the Core                        | 23  |
| Simulation                                   | 24  |
| Synthesis and Implementation                 | 25  |
| Chapter 5: Example Design                    |     |
| Overview                                     | 26  |
| Chapter 6: Test Bench                        |     |
| AXI4-Stream VIP Example Test Bench and Test  | 28  |
| Useful Coding Guidelines and Examples        |     |



| Appendix A:  | Upgrading                                  |    |
|--------------|--------------------------------------------|----|
| Upgrading in | the Vivado Design Suite                    | 37 |
| Appendix B:  | axi4stream_vip_v1_1_top APIs               |    |
| Appendix C:  | AXI4-Stream VIP Agent and Flow Methodology |    |
| AXI4-Stream  | Master Agent                               | 39 |
| AXI4-Stream  | Slave Agent                                | 41 |
| AXI4-Stream  | Pass-Through Agent                         | 43 |
| READY Gene   | ration                                     | 44 |
| Appendix D:  | Debugging                                  |    |
| Finding Help | on Xilinx.com                              | 51 |
| Appendix E:  | Additional Resources and Legal Notices     |    |
| Xilinx Resou | rces                                       | 53 |
| Documentat   | ion Navigator and Design Hubs              | 53 |
| References . |                                            | 54 |
|              | tory                                       |    |
| Please Read: | Important Legal Notices                    | 56 |





# Introduction

The Xilinx<sup>®</sup> LogiCORE™ AXI4-Stream Verification IP (VIP) core has been developed to support the simulation of customer designed AXI-based IP. The AXI4-Stream VIP core supports the AXI4-Stream protocol.

The AXI4-Stream VIP is unencrypted SystemVerilog source that is comprised of a SystemVerilog class library and synthesizable RTL.

The embedded RTL interface is controlled by the AXI4-Stream VIP through a virtual interface. AXI4-Stream transactions are constructed in the customer's verification environment and passed to the AXI4-Stream driver class. The driver class then manages the timing and drives the content on the interface.

### **Features**

- Supports the following widths:
  - Data widths up to 512 bytes
  - ID widths up to 32 bits
  - DEST widths up to 32 bits
- Arm®-based protocol transaction level checker for tools that support assertion property [Ref 1]
- Behavioral SystemVerilog Syntax
- SystemVerilog class-based API

| LogiCORE™ IP Facts Table                  |                                                                             |  |  |
|-------------------------------------------|-----------------------------------------------------------------------------|--|--|
| Core Specifics                            |                                                                             |  |  |
| Supported<br>Device Family <sup>(1)</sup> | UltraScale+™, UltraScale™,<br>Zynq®-7000 SoC,<br>7 series FPGAs             |  |  |
| Supported User<br>Interfaces              | AXI4-Stream                                                                 |  |  |
| Resources                                 | N/A                                                                         |  |  |
|                                           | Provided with Core                                                          |  |  |
| Design Files                              | N/A                                                                         |  |  |
| Example Design                            | SystemVerilog                                                               |  |  |
| Test Bench                                | N/A                                                                         |  |  |
| Constraints File                          | N/A                                                                         |  |  |
| Simulation<br>Model                       | Unencrypted SystemVerilog                                                   |  |  |
| Supported<br>S/W Driver                   | N/A                                                                         |  |  |
| Т                                         | Tested Design Flows <sup>(2)(3)</sup>                                       |  |  |
| Design Entry                              | Vivado® Design Suite                                                        |  |  |
| Simulation <sup>(4)</sup>                 | For supported simulators, see the Xilinx Design Tools: Release Notes Guide. |  |  |
| Synthesis                                 | Vivado Synthesis                                                            |  |  |
|                                           | Support                                                                     |  |  |
| Release Notes<br>and Known<br>Issues      | Master Answer Record: 68726                                                 |  |  |
| All Vivado IP<br>Change Logs              | Master Vivado IP Change Logs: 72775                                         |  |  |
| Xilinx Support web page                   |                                                                             |  |  |

#### **Notes:**

- For a complete list of supported devices, see the Vivado IP catalog.
- 2. For the supported versions of third-party tools, see the Xilinx Design Tools: Release Notes Guide.
- This IP does not deliver VIP for Zynq PS. It only delivers the VIP core for AXI4-Stream interfaces.
- 4. To take advantage of the full features of this IP, it requires simulators supporting advanced simulation capabilities.
- 5. The AXI4-Stream VIP can only act as a protocol checker when contained within a VHDL hierarchy.
- 6. To use the virtual part of the AXI Verification IP, it must be in a Verilog hierarchy.
- Do not import two different revisions/versions of the axi4stream\_vip packages. This causes elaboration failures.
- 8. All AXI4-Stream VIP and parents to the AXI4-Stream VIP must be upgraded to the latest version.





# Overview

The Xilinx<sup>®</sup> LogiCORE™ AXI4-Stream Verification IP (VIP) core is used in the following manner:

- Generating master AXI4-Stream commands and write payload
- Generating slave AXI4-Stream read payload and write responses
- Checking protocol compliance of AXI4-Stream transactions

The AXI4-Stream VIP can be configured in three different modes:

- AXI4-Stream master VIP
- AXI4-Stream slave VIP
- AXI4-Stream pass-through VIP

Figure 1-1 shows the AXI4-Stream master VIP which generates AXI4-Stream payloads and sends it to the AXI4-Stream system.



Figure 1-1: AXI4-Stream Master VIP

Figure 1-2 shows the AXI4-Stream slave VIP which responds to the AXI4-Stream and generates a Ready signal.



Figure 1-2: AXI4-Stream Slave VIP



Figure 1-3 shows the AXI4-Stream pass-through VIP which protocol checks all AXI4-Stream transactions that pass through it. The IP can be configured to behave in the following modes:

- Monitor only
- Master
- Slave



Figure 1-3: AXI4-Stream Pass-Through VIP

# **Feature Summary**

- Supports AXI4-Stream interface
- Configurable as an AXI4-Stream master, AXI4-Stream slave, and in pass-through mode
- Configurable simulation messaging
- Provides simulation AXI4-Stream protocol checking
- An example design that demonstrates the usage of this VIP is available for reference

# **Applications**

The AXI4-Stream VIP is for verification and system engineers who want to:

- Monitor transactions between two AXI4-Stream connections
- Generate AXI4-Stream transactions
- Check for AXI4-Stream protocol compliance



# **Licensing and Ordering**

This Xilinx LogiCORE™ IP module is provided at no additional cost with the Xilinx Vivado Design Suite under the terms of the Xilinx End User License.

Information about other Xilinx LogiCORE IP modules is available at the Xilinx Intellectual Property page. For information about pricing and availability of other Xilinx LogiCORE IP modules and tools, contact your local Xilinx sales representative.



# **Product Specification**

### **Standards**

The AXI4-Stream interfaces conform to the Arm<sup>®</sup> Advanced Microcontroller Bus Architecture (AMBA<sup>®</sup>) AXI version 4 specification [Ref 2].

### **Performance**

The AXI4-Stream VIP core synthesizes to wires and does not impact performance.

# **User Parameters**

Table 2-1 shows the AXI4-Stream VIP core user parameters.

Table 2-1: AXI4-Stream VIP User Parameters

| Parameter Name          | Format/Range                                                   | Default<br>Value | Description                                                                              |
|-------------------------|----------------------------------------------------------------|------------------|------------------------------------------------------------------------------------------|
| INTERFACE_MODE          | Type: string<br>Value range:<br>PASS_THROUGH,<br>MASTER, SLAVE | PASS_<br>THROUGH | Used to control the mode of protocol to be configured as master, slave, or pass-through. |
| HAS_TREADY              | Type: long<br>Value range: 0, 1                                | 0                | Used to control the enablement of the TREADY ports.                                      |
| TDATA_WIDTH             | Type: long<br>Value range: 0512                                | 1                | Width of the *_AXI4STREAM_tdata                                                          |
|                         |                                                                |                  | Used to control whether user bits per byte is ON or OFF.                                 |
| HAS_TUSER_BITS_PER_BYTE | Type: long value range: {0, 1}                                 | 0                | 1: user bits per byte, this means tuser size are per byte based                          |
|                         |                                                                |                  | 0: user bits per transfer, this means tuser size are per transfer based                  |



Table 2-1: AXI4-Stream VIP User Parameters (Cont'd)

| Parameter Name      | Format/Range                       | Default<br>Value | Description                                                                                                                  |
|---------------------|------------------------------------|------------------|------------------------------------------------------------------------------------------------------------------------------|
| TUSER_BITS_PER_BYTE | Type: long<br>value range: {0, 32} | 0                | When HAS_TUSER_BITS_PER_BYTE is 1, then the value of TUSER is calculated.  TUSER_WIDTH = (TUSER_BITS_PER_BYTE × TDATA_WIDTH) |
| HAS_TSTRB           | Type: long<br>Value range: 0, 1    | 0                | Used to control the enablement of the TSTRB ports.                                                                           |
| HAS_TKEEP           | Type: long<br>Value range: 0, 1    | 0                | Used to control the enablement of the TKEEP ports.                                                                           |
| HAS_TLAST           | Type: long<br>Value range: 0, 1    | 0                | Used to control the enablement of the TLAST ports.                                                                           |
| TID_WIDTH           | Type: long<br>Value range: 032     | 0                | Width of the *_AXI4STREAM_tid.                                                                                               |
| TDEST_WIDTH         | Type: long<br>Value range: 032     | 0                | Width of the *_AXI4STREAM_tdest.                                                                                             |
| TUSER_WIDTH         | Type: long<br>Value range: 04096   | 0                | Width of the *_AXI4STREAM_tuser                                                                                              |
| HAS_ACLKEN          | Type: long<br>Value range: {0, 1}  | 0                | Used to control the enablement of the ACLKEN port. User parameter only (no corresponding model parameter).                   |
| HAS_ARESETN         | Type: long<br>Value range: {0, 1}  | 0                | Used to control the enablement of the ARESETN port. User parameter only (no corresponding model parameter).                  |

# **Port Descriptions**

Table 2-2 shows the AXI4-Stream VIP independent port descriptions.

Table 2-2: AXI4-Stream VIP Independent Port Descriptions

| Signal Name | 1/0 | Default  | Width | Description                                     | Enablement       |
|-------------|-----|----------|-------|-------------------------------------------------|------------------|
| aclk        | I   | Required | 1     | Interface clock input                           | Always ON        |
| aresetn     | I   | Optional | 1     | Interface reset input (active-Low)              | HAS_ARESETN == 1 |
| aclken      | I   | Optional | 1     | Interface Clock enable signal.<br>(active-High) | HAS_ACLKEN == 1  |



Table 2-3 lists the interface signals for the AXI4-Stream VIP core in master or master pass-through mode.

Table 2-3: AXI4-Stream Master or Pass-Through VIP Port Descriptions

| Signal Name         | 1/0 | Default  | Width           | Description                              | Enablement      |
|---------------------|-----|----------|-----------------|------------------------------------------|-----------------|
| m_axi4stream_tdata  | 0   |          | TDATA_WIDTH × 8 | Streaming data                           | TDATA_WIDTH > 0 |
| m_axi4stream_tdest  | 0   |          | TDEST_WIDTH     | Routing information for data stream      | TDEST_WIDTH > 0 |
| m_axi4stream_tid    | 0   | 0        | TID_WIDTH       | Stream data identifier                   | TID_WIDTH > 0   |
| m_axi4stream_tkeep  | I   |          | TDATA_WIDTH     | Byte qualifier (data byte or null byte)  | HAS_KEEP is 1   |
| m_axi4stream_tlast  | 0   | 0b1      | 1               | Last data beat of streaming packet       | HAS_LAST is 1   |
| m_axi4stream_tready | I   |          | 1               | Slave ready to accept stream data        | HAS_TREADY is 1 |
| m_axi4stream_tstrb  | 0   |          | TDATA_WIDTH     | Byte qualifier of streaming data         | HAS_STRB is 1   |
| m_axi4stream_tuser  | 0   |          | TUSER_WIDTH     | User defined sideband signals for stream | TUSER_WIDTH > 0 |
| m_axi4stream_tvalid | 0   | Required | 1               | Streaming data valid                     | Always          |

Table 2-4 lists the interface signals for the AXI4-Stream VIP core when it has been configured to be in slave or slave pass-through mode.

Table 2-4: AXI4-Stream Slave or Pass-Through VIP Port Descriptions

| Signal Name         | 1/0 | Default | Width           | Description                              | Enablement      |
|---------------------|-----|---------|-----------------|------------------------------------------|-----------------|
| s_axi4stream_tdata  | 0   |         | TDATA_WIDTH × 8 | Streaming data                           | TDATA_WIDTH > 0 |
| s_axi4stream_tdest  | 0   |         | TDEST_WIDTH     | Routing information for data stream      | TDEST_WIDTH >0  |
| s_axi4stream_tid    | 0   | 0       | TID_WIDTH       | Stream data identifier                   | TID_WIDTH > 0   |
| s_axi4stream_tkeep  | I   |         | TDATA_WIDTH     | Byte qualifier (data byte or null byte)  | HAS_KEEP is 1   |
| s_axi4stream_tlast  | 0   | 0b1     | 1               | Last data beat of streaming packet       | HAS_LAST is 1   |
| s_axi4stream_tready | 1   |         | 1               | Slave ready to accept stream data        | HAS_TREADY is 1 |
| s_axi4stream_tstrb  | 0   |         | TDATA_WIDTH     | Byte qualifier of streaming data         | HAS_STRB is 1   |
| s_axi4stream_tuser  | 0   |         | TUSER_WIDTH     | User defined sideband signals for stream | TUSER_WIDTH > 0 |
| s_axi4stream_tvalid | 0   |         | 1               | Streaming data valid                     | Always          |



# **AXI Protocol Checks and Descriptions**

Table 2-5 lists the AXI protocol checks and descriptions which are essentially the same as the assertions that are found in the AXI Protocol Checker LogiCORE IP Product Guide (PG101) [Ref 4].

Table 2-5: AXI Protocol Checks and Descriptions

| Name of Protocol Check          | Description                                                                                                                                                    |
|---------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AXI4STREAM_ERRM_TVALID_RESET    | TVALID is Low for the first cycle after aresetn goes High. This assertion is not available when the system_resetn port is not enabled.                         |
| AXI4STREAM_ERRM_TID_STABLE      | TID remains stable when TVALID is asserted, and TREADY is Low. This assertion is only valid if both TREADY and TID are enabled on the interface.               |
| AXI4STREAM_ERRM_TDEST_STABLE    | TDEST remains stable when TVALID is asserted and TREADY is Low. This assertion is only valid if both TREADY and TDEST are enabled on the interface.            |
| AXI4STREAM_ERRM_TKEEP_STABLE    | TKEEP remains stable when TVALID is asserted and TREADY is Low. This assertion is only valid if TDATA, TREADY, and TKEEP are enabled on the interface.         |
| AXI4STREAM_ERRM_TDATA_STABLE    | TDATA remains stable when TVALID is asserted and TREADY is Low. This assertion is only valid if both TREADY and TDATA are enabled on the interface.            |
| AXI4STREAM_ERRM_TLAST_STABLE    | TLAST remains stable when TVALID is asserted and TREADY is Low. This assertion is only valid if both TREADY and TLAST are enabled on the interface.            |
| AXI4STREAM_ERRM_TSTRB_STABLE    | TSTRB remains stable when TVALID is asserted and TREADY is Low. This assertion is only valid if TDATA, TREADY, and TSTRB are enabled on the interface          |
| AXI4STREAM_ERRM_TVALID_STABLE   | When TVALID is asserted, it must remain asserted until TREADY is High. This assertion is only valid if TREADY is enabled on the interface.                     |
| AXI4STREAM_ERRM_TREADY_MAX_WAIT | Xilinx recommends that TREADY is asserted within MAXWAITS cycles of TVALID being asserted. This assertion is only valid if TREADY is enabled on the interface. |
| AXI4STREAM_ERRM_TUSER_STABLE    | TUSER remains stable when TVALID is asserted and TREADY is Low. This assertion is only valid if both TREADY and TUSER are enabled on the interface.            |
| AXI4STREAM_ERRM_TKEEP_STABLE    | If TKEEP is deasserted, then TSTRB must also be deasserted. This assertion is only valid it TDATA, TSTRB, and TKEEP are enabled on the interface.              |



# **Xilinx Configuration Checks and Descriptions**

Table 2-6 lists the Xilinx configuration checks and descriptions.

Table 2-6: Xilinx Configuration Check and Description

| Name of Protocol Check                       | Description                                                                                                                                                                   |
|----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| XILINX_AXI4STREAM_ERRM_RESET_<br>PULSE_WIDTH | ARESETN must stay at least 16 clock cycles long when it goes Low. For more information, see the <i>Vivado Design Suite User Guide</i> : AXI Reference Guide (UG1037) [Ref 3]. |



# Designing with the Core

This chapter includes guidelines and additional information to facilitate designing with the core.

# **General Design Guidelines**

The AXI4-Stream VIP core should be inserted into a system as shown in Figure 3-1 for AXI4-Stream master VIP, Figure 3-2 for AXI4-Stream slave VIP, and Figure 3-3 for AXI4-Stream pass-through VIP.



Figure 3-1: AXI4-Stream Master VIP Example Topology





Figure 3-2: AXI4-Stream Slave VIP Example Topology



X18779-021317

Figure 3-3: AXI4-Stream Pass-Through VIP Example Topology

# **Clocking**

This section is not applicable for this IP core.

# Resets

The AXI4-Stream VIP requires one active-Low reset, aresetn. The reset is synchronous to aclk.



# Design Flow Steps

This chapter describes customizing and generating the core, constraining the core, and the simulation, synthesis and implementation steps that are specific to this IP core. More detailed information about the standard Vivado <sup>®</sup> design flows and the IP integrator can be found in the following Vivado Design Suite user guides:

- Vivado Design Suite User Guide: Designing IP Subsystems using IP Integrator (UG994) [Ref 5]
- Vivado Design Suite User Guide: Designing with IP (UG896) [Ref 6]
- Vivado Design Suite User Guide: Getting Started (UG910) [Ref 7]
- Vivado Design Suite User Guide: Logic Simulation (UG900) [Ref 8]

# **Customizing and Generating the Core**

This section includes information about using Xilinx tools to customize and generate the core in the Vivado Design Suite.

If you are customizing and generating the core in the Vivado IP integrator, see the *Vivado Design Suite User Guide: Designing IP Subsystems using IP Integrator* (UG994) [Ref 5] for detailed information. IP integrator might auto-compute certain configuration values when validating or generating the design. To check whether the values do change, see the description of the parameter in this chapter. To view the parameter value, run the validate bd design command in the Tcl console.

You can customize the IP for use in your design by specifying values for the various parameters associated with the IP core using the following steps:

- 1. Select the IP from the Vivado IP catalog.
- 2. Double-click the selected IP or select the **Customize IP** command from the toolbar or right-click menu.

For details, see the Vivado Design Suite User Guide: Designing with IP (UG896) [Ref 6] and the Vivado Design Suite User Guide: Getting Started (UG910) [Ref 7].

**Note:** Figures in this chapter are an illustration of the Vivado Integrated Design Environment (IDE). The layout depicted here might vary from the current version.



Figure 4-1 shows the AXI4-Stream VIP Vivado IDE **Component Name** tab configuration screen.



Figure 4-1: AXI4-Stream VIP Customize IP – Component Name Tab

For the runtime parameter descriptions, see Table 2-1.

- **Component Name** The component name is used as the base name of output files generated for the module. Names must begin with a letter and must be composed from characters: a to z, 0 to 9 and "\_".
- Interface Mode Controls the mode of protocol to be configured as master, slave, or pass-through.
- **Signal Properties** Selects the specific signal properties.

#### **User Parameters**

For the relationship between the fields in the Vivado IDE and the User Parameters (which can be viewed in the Tcl Console), see Table 2-1.

### **Output Generation**

For details, see the Vivado Design Suite User Guide: Designing with IP (UG896) [Ref 6].



The AXI4-Stream VIP deliverables are organized in the directory <project\_name>/
<project\_name>.srcs/sources\_1/ip/<component\_name> and are designated as
the <ip\_source\_dir>. The relevant contents or directories are described in the following
sections.

#### **Vivado Design Tools Project Files**

The Vivado design tools project files are located in the root of the <ip\_source\_dir>.

**Table 4-1:** Vivado Design Tools Project Files

| Name                                        | Description                                                                                                                                           |
|---------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| <component_name>.xci</component_name>       | Vivado tools IP configuration options file. This file can be imported into any Vivado tools design and be used to generate all other IP source files. |
| <component_name>.{veo vho}</component_name> | AXI4-Stream VIP instantiation template.                                                                                                               |

#### **IP Sources**

The IP sources are held in the subdirectories of the <ip\_source\_dir>.

Table 4-2: IP Sources

| Name                                        | Description                                                                                                 |
|---------------------------------------------|-------------------------------------------------------------------------------------------------------------|
| hdl/*.sv                                    | AXI4-Stream VIP source files.                                                                               |
| synth/ <component_name>.sv</component_name> | AXI4-Stream VIP generated top-level file for synthesis. Optional, generated if synthesis target selected.   |
| sim/ <component_name>.sv</component_name>   | AXI4-Stream VIP generated top-level file for simulation. Optional, generated if simulation target selected. |



# **AXI4-Stream VIP in Vivado IP Integrator**

This section contains information about how to use the AXI4-Stream VIP in a design and test bench environment. Figure 4-2 shows a possible design with the AXI4-Stream VIPs.



Figure 4-2: AXI4-Stream VIP Design

The AXI4-Stream VIP uses similar naming and structures as the Universal Verification Methodology (UVM) for core design. It is coded in SystemVerilog. The AXI4-Stream VIP is comprised of two parts. One is instanced like other traditional IP (modules in the static/physical world) and the second part is used in the dynamic world in your verification environment. The AXI4-Stream VIP is an IP which has a static world connected to the dynamic world with a virtual interface. The virtual interface is the only mechanism that can bridge the dynamic world of objects with the static world of modules and interfaces.

#### AXI4-Stream Master VIP

Figure 4-3 shows the AXI4-Stream master VIP with its test bench. The test bench has three parts:

- User environment
- Master agent
- AXI4-Stream master VIP

The user environment and master agent are in the dynamic world while the AXI4-Stream master VIP is in the static world. The user environment communicates with the master agent and the master agent communicates with the AXI4-Stream VIP interface though a virtual interface. The master agent has four class members:

- Master driver
- Monitor
- Virtual interface



For more information about the master agent, see Appendix C, AXI4-Stream VIP Agent and Flow Methodology.



Figure 4-3: AXI4-Stream VIP Master Test Bench

Figure 4-4 shows how stream data is constructed and sent to the AXI4-Stream VIP interface. The user environment first declares a stream transaction variable and the master driver constructs it with a new() function. The user environment then sets up the stream transaction members by either filling in or randomization. The master write then sends it to



the AXI4-Stream VIP interface through a virtual interface and the AXI4-Stream VIP interface pins start to wiggle.



Figure 4-4: Stream Transaction Flow

#### **AXI4-Stream Slave VIP**

Figure 4-5 shows the AXI4-Stream slave VIP with its test bench. The test bench has three parts:

- User environment
- Slave agent
- AXI4-Stream slave VIP

The user environment and slave agent are in the dynamic world, while the AXI4-Stream slave VIP is in the static world. The user environment communicates with the slave agent and the slave agent communicates with the AXI4-Stream VIP interface though a virtual interface. The slave agent has three class members.

- Slave driver
- Monitor
- Virtual interface

For more information about the slave agent, see Appendix C, AXI4-Stream VIP Agent and Flow Methodology.





Figure 4-5: AXI4-Stream VIP Slave Test Bench

Figure 4-6 shows how a ready generation is constructed and sent to the AXI4-Stream VIP interface. The user environment first declares a variable of ready. The user environment then fills in the ready by either randomization or direct values.



The Slave Driver then sends it to the AXI4-Stream VIP interface through a virtual interface and the AXI4-Stream VIP interface related pins start to wiggle. If no ready is being created and generated in the user environment, the default randomized ready pattern is generated and sent to interface.



Figure 4-6: Ready Generation Flow

### Multiple AXI4-Stream VIP

Figure 4-7 shows multiple AXI4-Stream VIPs in one design and its test bench. Similar to the single AXI4-Stream VIP, it has dynamic and static worlds that are bridged through a virtual interface.



Figure 4-7: Multiple AXI4-Stream VIP Test Bench



### Finding the AXI4-Stream VIP Hierarchy Path in IP Integrator

As mentioned earlier, the user environment has to declare the agent for the AXI4-Stream VIP. Also, the AXI4-Stream VIP interface has to be passed to the agent when the user environment constructs it to set it as a virtual interface. The following guidelines describe how to find the hierarchy path of the AXI4-Stream VIP in the IP integrator.

- 1. Create a **bd design** and add the VIP like other IPs into the design.
- 2. After connection and validation checks for the IP integrator design, click the **Simulation Settings**, set up the tool, and then click **Run Simulation**. Figure 4-8 shows the Mentor Graphics Questa Advanced Simulator results. After the hierarchy is identified, it is used in the SystemVerilog test bench to drive the AXI4-Stream VIP APIs.

```
🖚 🗴 Find: 🛗
📠 Library 🗶 🋺 sim 🗵
Transcript
  Loading work.ex_sim(fast)
  Loading work.ex_sim_axi4stream_vip_mst_0(fast)
# Loading axi4stream_vip_v1_0_0.axi4stream_vip_v1_0_0_top(fast)
 # Loading axi4stream_vip_v1_0_0.axi4stream_vip_v1_0_0_if(fast)
 # Loading axi4stream_vip_vl_0_0.axi4stream_vip_vl_0_0_axi4streampc(fast)
 # Loading axis_protocol_checker_vl_1_11.axis_protocol_checker_vl_1_11_top(fast)
# Loading axis_protocol_checker_v1_1_11.axis_protocol_checker_v1_1_11_asr_inline(fast)
 # Loading axis_protocol_checker_vl_1_11.axis_protocol_checker_v1_1_11_reporter(fast)
 # Loading work.ex_sim_axi4stream_vip_passthrough_0(fast)
 # Loading axi4stream_vip_v1_0_0.axi4stream_vip_v1_0_0_top(fast
 # Loading work.ex_sim_axi4stream_vip_slv_0(fast)
# Loading axi4stream vip vl 0 0.axi4stream vip vl 0 0 top(fast 2)
  Loading work.glbl(fast)
  .main_pane.wave.interior.cs.body.pw.wf
  .main pane.structure.interior.cs.body.struct
  Xilinx AXI STREAM VIP Found at Path: axi4stream_vip_0_exdes_tb.DUT.ex_design.axi4stream_vip_m
  Xilinx AXI STREAM VIP Found at Path: axi4stream_vip_0_exdes_tb.DUT.ex_design.axi4stream_vip_passthrough.inst
  Xilinx AXI STREAM VIP Found at Path: axi4stream_vip_0_exdes_tb.DUT.ex_design.axi4stream_vip_slv.inst
VSIM 2>
```

Figure 4-8: AXI4-Stream VIP Instance in IP Integrator Design Hierarchy

After the AXI4-Stream VIP is instantiated in the IP integrator design and its hierarchy path found, the next step is using the AXI4-Stream VIP in the test bench. See Chapter 5, Example Design.

# **Constraining the Core**

This section contains information about constraining the core in the Vivado Design Suite.

### **Required Constraints**

This section is not applicable for this IP core.



### **Device, Package, and Speed Grade Selections**

This section is not applicable for this IP core.

# **Clock Frequencies**

This section is not applicable for this IP core.

### **Clock Management**

This section is not applicable for this IP core.

#### **Clock Placement**

This section is not applicable for this IP core.

# **Banking**

This section is not applicable for this IP core.

#### **Transceiver Placement**

This section is not applicable for this IP core.

# I/O Standard and Placement

This section is not applicable for this IP core.

# **Simulation**

For comprehensive information about Vivado simulation components, as well as information about using supported third-party tools, see the *Vivado Design Suite User Guide: Logic Simulation* (UG900) [Ref 8].



**IMPORTANT:** For cores targeting 7 series or Zynq-7000 devices, UNIFAST libraries are not supported. Xilinx IP is tested and qualified with UNISIM libraries only.



# **Synthesis and Implementation**

The AXI4-Stream VIP core is a verification IP set to synthesize as wires. There is no implementation for the AXI4-Stream VIP.



# Example Design

This chapter contains information about the example design provided in the Vivado<sup>®</sup> Design Suite.



**IMPORTANT:** The example design of this IP is customized to the IP configuration. The intent of this example design is to demonstrate how to use the AXI4-Stream VIP. The AXI4-Stream VIP can only act as a protocol checker when contained within a VHDL hierarchy. All AXI4-Stream VIP and parents to the AXI4-Stream VIP must be upgraded to the latest version.

### **Overview**

Figure 5-1 shows the AXI4-Stream VIP example design.



Figure 5-1: AXI4-Stream VIP Example Design

This section describes the example tests used to demonstrate the abilities of the AXI4-Stream VIP core. Example tests are delivered in SystemVerilog.

When the core example design is open, the example files are delivered in a standard path test bench and bd design are under directory imports. The packages are under the directory example.srcs/sources\_1/bd/ex\_sim/ipshared.

The example design consists of three components:

- AXI4-Stream VIP in master mode
- AXI4-Stream VIP in pass-through mode
- AXI4-Stream VIP in slave mode



The AXI4-Stream master VIP creates stream transactions and sends them to the AXI4-Stream pass-through VIP. The AXI4-Stream pass-through VIP receives stream transactions from the AXI4-Stream master VIP and sends them to the AXI4-Stream slave VIP. The AXI4-Stream slave VIP generates ready and sends the responses back to the AXI4-Stream pass-through VIP and then back to AXI4-Stream master VIP when it is configured to ready.

Monitors for the AXI4-Stream VIP (master, pass-through, and slave) are always on and collect all of the information from the interfaces. The monitors convert the interface information back to the transaction level and sends it to the scoreboard. Two scoreboards are built in the test bench which performs self-checking for the AXI4-Stream master VIP against the AXI4-Stream pass-through VIP and the AXI4-Stream slave VIP against the AXI4-Stream pass-through VIP.

The AXI4-Stream VIP core is not fully autonomous. If tests are written using the APIs, there are different methods from the user environment to set up the transaction. It is possible that the AXI4-Stream protocol can be accidentally violated. Xilinx recommends accessing all the members through the APIs instead of accessing them directly.

When the AXI4-Stream VIP is configured in pass-through mode, it can change to either master or slave mode in the runtime and then changed back to pass-through mode based on your requirements.

When it is switched to runtime master mode, it behaves exactly as an AXI4-Stream master VIP. When it is switched to runtime slave mode, it behaves exactly as an AXI4-Stream slave VIP.



**IMPORTANT:** When the AXI4-Stream VIP is configured in pass-through mode, ensure all transactions have completed before switching modes. Examples of how to wait for the transactions to finish can be found in the example design.



# Test Bench

This chapter contains information about the test bench for the example design provided in the Vivado<sup>®</sup> Design Suite.

To open the example design either from the Vivado IP catalog or Vivado IP integrator design, follow these steps:

- 1. Open a new project and click **IP Catalog**.
- 2. Search for **AXI4-Stream Verification IP**. Double-click it, configure the IP, and generate the IP.
- 3. Right-click the IP and choose **Open IP Example Design**.

**Note:** If you have the AXI4-Stream VIP as one component in the IP integrator design, right-click AXI4-Stream VIP and click **Open IP Example Design...** 

In both scenarios, a new project with the example design is created. The example design has the master, pass-through, and slave VIP connected directly to each other as shown in Figure 5-1. The configuration of the example design matches the original VIP configuration.

# **AXI4-Stream VIP Example Test Bench and Test**

Because the example design is generated to match the VIP's configuration, the test bench is also configured to match the AXI4-Stream VIP configuration. The following scenarios are covered in the example design:

- AXI4-Stream pass-through VIP in pass-through mode. The AXI4-Stream master VIP generates a simple sequential randomized stream transfer and passes them to the AXI4-Stream slave VIP.
- Switches AXI4-Stream pass-through VIP into the runtime master mode and generates a simple sequential randomized stream transfer and passes them to the AXI4-Stream slave VIP.
- Switches AXI4-Stream pass-through VIP into the runtime slave mode. The AXI4-Stream master VIP generates a simple sequential randomized stream transfer.



# **Useful Coding Guidelines and Examples**

#### Must Haves in the Test Bench

While coding the test bench for the AXI4-Stream VIP, the following requirements must be met. Otherwise, the AXI4-Stream VIP does not work.

1. Import two required packages: axi4stream\_vip\_pkg and <component\_name>\_pkg. The axi4stream\_vip\_pkg includes agent classes and its subclasses for AXI4-Stream VIP. For each VIP instance, it has a component package which is automatically generated when the outputs are created. This component package includes a typedef class of a parameterized agent. Xilinx recommends importing this package because reconfiguration of the VIP has no impact on the test bench. Figure 6-1 shows the AXI4-Stream VIP in a standalone IP.



Figure 6-1: Standalone <component\_name>\_pkg



Figure 6-2 shows how to retrieve the <component\_name>\_pkg from an IP integrator design. First, select the VIP and in the **Block Properties** window click **Properties**. Then, under the **CONFIG** column select **Component\_Name**.



Figure 6-2: IP Integrator <component\_name>\_pkg

2. Place the code snippet into your test bench.

```
import axi4stream_vip_pkg::*
import <component_name>_pkg::*;
```

For a standalone AXI4-Stream VIP, see Figure 6-1 for the <component\_name>\_pkg and for IP integrator design, see Figure 6-2 for <component\_name>\_pkg.

In the example design, three AXI4-Stream VIPs are being instantiated so the total test bench has four packages to import which are listed below:

```
import axi4stream_vip_pkg::*;
import ex_sim_axi4stream_vip_mst_0_pkg::*;
import ex_sim_axi4stream_vip_slv_0_pkg::*;
import ex_sim_axi4stream_vip_passthrough_0_pkg::*;
```

In the example design, the component name for each AXI4-Stream VIP are:

- AXI4-Stream master VIP is ex\_sim\_axi4stream\_vip\_mst\_0
- AXI4-Stream slave VIP is ex\_sim\_axi4stream\_vip\_slv\_0
- AXI4-Stream pass-through VIP is ex\_sim\_axi4stream\_vip\_passthrough\_0



The corresponding packages are:

```
ex_sim_axi4stream_vip_mst_0_pkg
ex_sim_axi4stream_vip_slv_0_pkg
ex_sim_axi4stream_vip_passthrough_0_pkg
```

3. Create module test bench as all other standard SystemVerilog test benches.

```
module testbench();
...
endmodule
```

4. Declare transaction class handles and ready class handles for use (when tready is High).

```
// write transaction created by master VIP
axi4stream_transaction wr_transaction;
// Ready signal created by slave VIP when TREADY is High
axi4stream ready gen ready gen;
```

5. Declare agents. Normally, one agent for one AXI4-Stream VIP has to be declared. Even when the AXI4-Stream VIP is being configured in pass-through mode and monitor is not necessary. But, it might switch to master or slave mode in the runtime so it is better to have it ready.

Therefore, in a design which has six AXI4-Stream VIPs, six component packages have to be imported, six agents have to be declared and constructed (new here), and the right interfaces have to be assigned. For master VIP, component\_name\_mst\_t has to be declared, for slave VIP, component\_name\_slv\_t has to be declared, and for pass-through VIP, component\_name\_passthrough\_t has to be declared. When the agent is being constructed, be sure to assign the instance's interface to the agent. See step 2, page 23 to find the hierarchy path.

6. To start the agent, start\_master is called for AXI4-Stream master VIP or AXI4-Stream pass-through VIP in the runtime master mode. The start\_slave is called for AXI4-Stream slave VIP or AXI4-Stream pass-through VIP in the runtime slave mode.

To stop the agent, stop\_master is called for AXI4-Stream master VIP or AXI4-Stream pass-through VIP in the runtime master mode. The stop\_slave is called for AXI4-Stream slave VIP or AXI4-Stream pass-through VIP in the runtime slave mode. Pass-through VIP can only be either in runtime master, runtime slave, or pass-through modes.



APIs used to switch pass-through VIP into runtime master, runtime slave, and runtime pass-through modes are set\_master\_mode, set\_slave\_mode, and set\_passthrough mode.

Use the following code to switch the AXI4-Stream pass-through VIP into runtime slave mode. The <hierarchy\_path> can be found in step 2, page 23:

```
< hierarchy_path>.set_slave_mode();
Passsthrough_agent.start_slave();
```

Use the following code to switch the AXI4-Stream pass-through VIP into runtime master mode. The <hierarchy\_path> can be found in step 2, page 23:

```
< hierarchy_path>.set_master_mode();
Passsthrough_agent.start_master();
```

Use the following code to switch the AXI4-Stream pass-through VIP into runtime pass-through mode. The <hierarchy\_path> can be found in step 2, page 23:

```
< hierarchy_path>.set_passthrough_mode();
Passsthrough_agent.start_monitor();
```

For more information about the usage, see Chapter 5, Example Design.

Consequently, the start\_master and start\_slave of the pass-through VIP agent cannot be called at the same time. When the pass-through VIP is switching from the runtime master mode to the runtime slave mode, the stop\_master is called. Vice versa, stop\_slave is called.

```
// start master/slave VIP agent
mst_agent.start_master();
slv_agent.start_slave();
...
// stop master/slave VIP agent
mst_agent.stop_master();
slv_agent.stop_slave();
...
// passthrough VIP switch to run time master mode
passthrough_agent.start_master();
....
// passthrough VIP switch to run time slave mode
passthrough_agent.stop_master();
passthrough_agent.start_slave();
...
// passthrough VIP switch to run time master mode
passthrough_agent.start_slave();
passthrough_agent.stop_slave();
passthrough_agent.start_master();
```

7. When bus is in idle, it drives everything to zero. The cause is the AXI4-Stream protocol checker is used in the AXI4-Stream VIP. Because the AXI4-Stream protocol checker is synthesizable, it does not have case equality which triggers false assertions. If this is not set, false assertions fire. For more information about the AXI4-Stream protocol checker,



see the Arm<sup>®</sup> Advanced Microcontroller Bus Architecture (AMBA<sup>®</sup>) AXI version 4 specification [Ref 2].

```
mst_agent.vif_proxy.set_dummy_drive_type(XIL_AXI_VIF_DRIVE_NONE);
slv_agent.vif_proxy.set_dummy_drive_type(XIL_AXI_VIF_DRIVE_NONE);
passthrough_agent.vif_proxy.set_dummy_drive_type(XIL_AXI_VIF_DRIVE_NONE);
```

8. Create transaction. For the AXI4-Stream master VIP or AXI4-Stream pass-through VIP in runtime master mode, it has to create transaction, randomize it, and then send it to the VIP interface. The code shows how one transaction is created and sent to the VIP interface.

```
// Master agent create write transaction
wr_transaction = mst_agent.driver.create_transaction("write transaction");
// randomize the transaction
    WR_TRANSACTION_FAIL: assert(wr_transaction.randomize());
// send the transaction to VIP interface
    mst_agent.driver.send(wr_transaction);
```

### **Optional Haves in the Test Bench**

1. To create a ready signal, use the AXI4-Stream slave VIP or AXI4-Stream pass-through VIP in runtime slave mode. When tready is being configured to be enabled and if you want to create specific ready signals, use the create ready, set the low and high pattern, and send them to the VIP interface. Otherwise, default ready signals are generated by the AXI4-Stream VIP. For more information on different modes of the READY handshake, see the READY Generation section.

The following codes show how to generate two ready with different policies of XIL\_AXI4STREAM\_READY\_GEN\_OSC and XIL\_AXI4STREAM\_READY\_GEN\_SINGLE. Also, you can call set\_use\_variable\_range() to randomly generate the Low and High time of ready.

```
// slave agent driver create ready and set it up
   ready_gen = slv_agent.driver.create_ready("ready_gen");
   ready_gen.set_ready_policy(XIL_AXI4STREAM_READY_GEN_OSC);
   ready_gen.set_low_time(1);
   ready_gen.set_high_time(2);
   slv_agent.driver.send_tready(ready_gen);
```

- 2. While coding the test bench for the AXI4-Stream VIP, it is optional to enable the monitor. The codes are displayed for monitor and scoreboard purposes.
- 3. Declare monitor transaction and construct it for the scoreboard purpose. The following is a code snippet of a scoreboard which checks master VIP against pass-through VIP.



```
axi4stream_monitor_transaction
                                          mst_scb_transaction;
  //monitor transaction from passthrough VIP
  axi4stream monitor transaction
                                         passthrough monitor transaction;
  //monitor transaction queue for passthrough VIP for scoreboard 1
  axi4stream monitor transaction
passthrough_master_moniter_transaction_queue[$];
  //size of passthrough_master_moniter_transaction_queue;
  xil axi4stream uint
passthrough master moniter transaction queue size =0;
  //scoreboard transaction from passthrough VIP monitor transaction queue
  axi4stream monitor transaction
                                       passthrough mst scb transaction;
// Master VIP monitor collect its interface information and put it into transaction
aueue
  initial begin
    forever begin
     mst agent.monitor.item collected port.get(mst monitor transaction);
      master_moniter_transaction_queue.push_back(mst_monitor_transaction);
      master_moniter_transaction_queue_size++;
    end
  end
// passthrough vip monitors all the transaction from interface and put then into
transaction queue
  initial begin
    forever begin
      passthrough agent.monitor.item collected port.
get(passthrough monitor transaction);
      if (exdes state != EXDES PASSTHROUGH SLAVE) begin
passthrough_master_moniter_transaction_queue.push_back(passthrough_monitor_transact
ion):
        passthrough master moniter transaction queue size++;
      end
      if (exdes state != EXDES PASSTHROUGH MASTER) begin
passthrough_slave_moniter_transaction_queue.push_back(passthrough_monitor_transacti
on);
        passthrough_slave_moniter_transaction_queue_size++;
      end
    end
  end
//simple scoreboard doing self checking
 //comparing transaction from master VIP monitor with transaction from passsthrough
VIP in slave side
  // if they are match, SUCCESS. else, ERROR
  initial begin
  forever begin
      wait (master_moniter_transaction_queue_size>0 ) begin
        mst scb transaction = master moniter transaction queue.pop front;
        master moniter transaction queue size--;
        wait( passthrough_slave_moniter_transaction_queue_size>0) begin
          passthrough_slv_scb_transaction =
passthrough_slave_moniter_transaction_queue.pop_front;
          passthrough_slave_moniter_transaction_queue_size--;
         if (passthrough slv scb transaction.do compare(mst scb transaction) == 0)
begin
```



4. Using APIs to set agents' tag and verbosity for debug purpose.

```
//set tag for agents for easy debug
mst_agent.set_agent_tag("Master VIP");
slv_agent.set_agent_tag("Slave VIP");
passthrough_agent.set_agent_tag("Passthrough VIP");
//verbosity level which specifies how much debug information to produce
// 0 - No information will be shown.
// 400 - All information will be shown.
mst_agent.set_verbosity(mst_agent_verbosity);
slv_agent.set_verbosity(slv_agent_verbosity);
passthrough_agent.set_verbosity(passthrough_agent_verbosity);
```

# **Loop Construct Simple Example**

While coding directed tests, for loops are typically employed to efficiently generate large volumes of stimulus for both the master and/or slave VIP. For example:

```
wr_transaction = mst_agent.driver. create_transaction("write transaction");
mst_agent.driver.set_transaction_depth(2);
for(int i = 0; i < 16; i++) begin
    WR_TRANSACTION_FAIL_1a: assert(wr_transaction.randomize());
    mst_agent.driver.send(wr_transaction);
end</pre>
```

In this for loop, the master VIP agent generates 16 transactions and sends them over to the VIP interface. The WR\_TRANSACTION\_FAIL\_1a is added here for debugging randomization failure purpose.

### **Transaction Examples**

There are different methods of configuring the transaction after it is created. In the example design, two methods are shown for write and read transactions. Method 1 is to fully randomize the transaction after it is being created. Method 2 shows how to use the APIs to set the transaction.



#### **Method 1 for Write Transaction**

```
wr_transaction = mst_agent.driver.create_transaction("write transaction");
WR_TRANSACTION_FAIL_1b: assert(wr_transaction.randomize());
mst_agent.driver.send(wr_transaction);
```

#### Method 2 for Write Transaction

```
wr_transaction = mst_agent.driver.create_transaction("write transaction");
wr_transaction.set_id(mtest_id);
wr_transaction.set_data(mtest_data);
wr_transaction.set_dest(mtest_dest);
wr_transaction.set_last(mtest_last);
wr_transaction.set_strb(mtest_strb);
....
mst_agent.driver.send(wr_transaction);
```



# **Upgrading**

# **Upgrading in the Vivado Design Suite**

This section provides information about any changes to the user logic or port designations between core versions.

## Changes from v1.0 to v1.1

The axi4stream\_vip package changed from axi4stream\_vip\_v1\_0 to axi4stream\_vip\_v1\_1.



# axi4stream\_vip\_v1\_1\_top APIs

This appendix contains information about the axi4stream\_vip\_v1\_1\_top APIs. These APIs can be called through the following code. The set\_passthrough\_mode, set\_master\_mode, and set\_slave\_mode are used to switch the pass-though VIP into different runtime modes. Other APIs are used for assertion purposes. These APIs can be called through the test bench by hierarchy pointing to the top. An example would be set\_passthrough\_mode.

```
<hierarchy path>.set passthrough mode()
For <hierarchy path>, see Figure 4-8 in Chapter 4, Design Flow Steps.
set passthrough mode
function void set passthrough mode()
Sets AXI4STREAM VIP passthrough into run time passthrough mode
set_master_mode
function void set master mode()
Sets AXI4STREAM VIP passthrough into run time master mode
set slave mode
function void set_slave_mode()
Sets AXI4STREAM VIP passthrough into run time slave mode
set max wait cycles
function void set max wait cycles (
input integer unsigned new num)
Sets max wait cycles of PC(Arm AXI4 Stream Protocol Checker), not available in Vivado
Simulator.
get max wait cycles
function integer unsigned get max wait cycles()
Returns max wait cycles of PC(Arm AXI4 Stream Protocol Checker), not available in
Vivado Simulator.
set_fatal_to_warnings
function void set fatal to warnings()
Sets fatal to warnings of PC(Arm AXI4 Stream Protocol Checker) to be 1, not available
in Vivado Simulator.
clr_fatal_to_warnings
function void clr fatal to warnings()
Sets fatal to warnings of PC(Arm AXI4 Stream Protocol Checker) to be 0, not available
in Vivado Simulator.
```



# AXI4-Stream VIP Agent and Flow Methodology

This appendix contains information about the AXI4-Stream VIP agents and flow methodologies. The AXI4-Stream VIP has three agents:

- AXI4-Stream Master Agent
- AXI4-Stream Slave Agent
- AXI4-Stream Pass-Through Agent

# **AXI4-Stream Master Agent**

When instantiating an AXI4-Stream master VIP, a master agent has to be declared and constructed. Class axi4stream\_mst\_agent contains other components that consist of the entire master Verification IP. These are the monitor, driver, and vif proxy.



Figure C-1: AXI4-Stream Master VIP Agent



#### **AXI4-Stream Master Driver**

- Receives transactions from the user environment and drives stream interface.
- Returns a completed transaction when the transaction is accepted.

#### **AXI4-Stream Monitor**

- Monitors AXI4-Stream interface.
- Collects transaction into analysis port.

#### Write Transaction Flow

The AXI4-Stream master write transaction flows through the master agent in the following steps:

- 1. Driver asks for the next transaction through a try\_next\_item. This is a blocking get.
- 2. The user environment creates a single transaction. The transaction contains the following:
  - Command Information TID, TDEST, TSTRB, TKEEP, TUSER, TLAST, and TDATA when available
  - Master Controlled Timing Delay between two transfers
- 3. The user environment pushes the transaction to the driver.
- 4. The driver pops the transaction from the REQUEST port and places it on a queue to be processed and driven onto the interface.
- 5. When the interface receives the TREADY from the slave, the master driver returns a copy of the transaction (with the same transaction\_id) to the user environment.
- 6. The user environment receives the completed transaction. Because the ID of the transaction is updated, the sequence knows that it has completed.



Figure C-2: Write Transaction Flow



# **AXI4-Stream Slave Agent**

When instantiating an AXI4-Stream slave VIP, a slave agent has to be declared and constructed. Class axi\_slv\_agent contains other components that consist of the entire slave Verification IP. These are monitor and driver.



Figure C-3: AXI4-Stream Slave VIP Agent

#### **AXI4-Stream Slave Driver**

- Receives TREADY transactions from the user environment and drives the TREADY signal if HAS\_TREADY is ON.
- If HAS\_TREADY is OFF, TREADY is set to High all the time.

#### **AXI4-Stream Monitor**

- Monitors AXI4-Stream interface.
- Collects completed transaction into analysis port.

## **TREADY Timing Flow**

- TREADY is generated independently of the stream transaction.
- Configuration of the TREADY is not from the same transaction.



• See the Configurable Ready Delays for different timing options.



Figure C-4: TREADY Timing Flow



# **AXI4-Stream Pass-Through Agent**

When instantiating an AXI4-Stream pass-through VIP, a pass-through agent has to be declared and constructed. Class axi4stream\_passthrough\_agent contains other components that consist of the entire pass-through Verification IP. The pass-through VIP can be switched to runtime master or runtime slave modes. It includes monitor, master driver, and slave driver.



Figure C-5: AXI4-Stream Pass-Through VIP Agent

#### **AXI Master Read Driver**

The same features as the AXI master read driver in axi mst agent.

#### **AXI Master Write Driver**

The same features as the AXI master write driver in axi mst agent.

#### **AXI Slave Read Driver**

The same features as the AXI slave read driver in axi\_slv\_agent.

#### **AXI Slave Write Driver**

The same features as the AXI slave write driver in axi\_slv\_agent.

#### **AXI4-Stream Master Driver**

The same features as the AXI4-Stream master driver in mst agent.



#### **AXI4-Stream Slave Driver**

The same features as the AXI4-Stream slave driver in slv\_agent.

#### **AXI4-Stream Monitor**

The same features for both master/slave agent monitors.

#### **READY Generation**

READY signals are generated independently from other attributes. The axi4stream\_ready\_gen is the class used for READY generation.

## **Configurable Ready Delays**

There is no one way that the READY signals on a channel are supposed to behave. There are no requirements for when READY should be asserted or how long READY should remain asserted, nor any that states that the READY must be asserted following a power up.

The control of the READY signal is set in the DRIVER of the slave AGENT. To control the generation of the READY signal there are two main configurations, however, to simplify the programming model these might be presented as different configurations.

Table C-1 shows the configurable READY delay description.

Table C-1: Configurable Ready Delays

| Member Name         | Default | Range                | Description                                                                                                                                                                                                                                                               |
|---------------------|---------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| use_variable_ranges | FALSE   | 01                   | When set TRUE, this property instructs the ready_gen class to generate a random value for high_time, low_time, and event_count based on the minimum/maximum ranges.  When set FALSE, the ready_gen uses the programmed value of the high_time, low_time, and event_count. |
| max_low_time        | 5       | 02 <sup>32</sup> - 1 | Used to constrain the low_time value. Indicates the maximum range of the low_time constraint.                                                                                                                                                                             |
| min_low_time        | 0       | 02 <sup>32</sup> - 1 | Used to constrain the low_time value. Indicates the minimum range of the low_time constraint.                                                                                                                                                                             |
| low_time            | 2       | 02 <sup>32</sup> - 1 | When used, indicates the number of cycles that *READY is driven Low.                                                                                                                                                                                                      |
| max_high_time       | 5       | 02 <sup>32</sup> - 1 | Used to constrain the high_time value. Indicates the maximum range of the high_time constraint.                                                                                                                                                                           |
| min_high_time       | 0       | 02 <sup>32</sup> - 1 | Used to constrain the high_time value. Indicates the minimum range of the high_time constraint.                                                                                                                                                                           |



Table C-1: Configurable Ready Delays (Cont'd)

| Member Name       | Default | Range                | Description                                                                                         |
|-------------------|---------|----------------------|-----------------------------------------------------------------------------------------------------|
| high_time         | 5       | 02 <sup>32</sup> - 1 | When used, indicates the number of cycles that *READY is driven High.                               |
| max_event_count   | 1       | 12 <sup>32</sup> - 1 | Used to constrain the event_count value. Indicates the maximum range of the event_count constraint. |
| min_event_count   | 1       | 12 <sup>32</sup> - 1 | Used to constrain the event_count value. Indicates the minimum range of the event_count constraint. |
| event_count       | 1       | 02 <sup>32</sup> - 1 | When used, indicates the number of handshakes that are sampled before the end of the policy.        |
| event_count_reset | 2000    | 02 <sup>32</sup> - 1 | Watchdog wait time.                                                                                 |

## GEN\_SINGLE/RAND\_SINGLE (Default Policy)

While this policy is active, it drives the \*READY signal 0 for low\_time cycles and then drives 1 until one handshake (also called event in ready generation policy) occurs on this channel. The policy repeats until the channel is given a different policy.



Figure C-6: GEN\_SINGLE/RAND\_SINGLE



#### GEN\_OSC/RAND\_OSC - Assert and Remain Asserted for a Number of Cycles

When this policy is active, it drives the \*READY signal 0 for low\_time cycles and then drives 1 for high time cycles.

**Note:** The \*READY does not drop until the specified number of cycles has occurred. The policy repeats until the channel is given a different policy.

Figure C-7 shows that following event A, there is a delay of low\_time ACLKs, then READY is asserted. After high\_time cycles of ACLK, READY is deasserted and the counter restarts at A.



Figure C-7: GEN\_OSC/RAND\_OSC

# GEN\_EVENTS/RAND\_EVENTS – Assert and Remain Asserted for a Number of Events

When this policy is active, it drives the \*READY signal 0 for low\_time cycles and then drives 1 until event\_count handshakes occur.

**Note:** There is a built-in watchdog that triggers after the event\_cycle\_count\_reset cycles and the programmed number of events has not been satisfied. This terminates that part of the policy. The policy repeats until the channel is given a different policy.

The value of low\_time can range from 0 to 256 cycles. The READY remains asserted for N channel accept events, where N can be from 1 to N beats. This allows you to assert a READY after some number of cycles and keep it asserted indefinitely or for some number of events.

When attempting to model a self-draining FIFO, an event cycle count time reset is provided. This allows you to configure the READY to be deasserted after some number of events,



unless the event cycle count time has expired. In this case, the event count resets and the READY remains asserted for N more events.

Figure C-8 shows that following event A, there is a delay of low\_time ACLKs, then the READY is asserted. It remains asserted for events E1 to E4 then deasserts since the event count is satisfied. The algorithm then restarts at A.



Figure C-8: GEN\_EVENTS/RAND\_EVENTS



#### GEN\_AFTER\_VALID\_SINGLE/RAND\_AFTER\_VALID\_SINGLE

This policy is active when \*VALID is detected to be asserted. When enabled, it drives the \*READY Low for low\_time and then asserts the \*READY until one handshake has been detected. The policy repeats until the channel is given a different policy.



Figure C-9: GEN\_AFTER\_VALID\_SINGLE/RAND\_AFTER\_VALID\_SINGLE

#### GEN\_AFTER\_VALID\_EVENTS/RAND\_AFTER\_VALID\_EVENTS

This policy is active when \*VALID is detected to be asserted. When enabled, it drives the \*READY Low for low\_time and then drives the \*READY High until either event\_count handshakes have been received OR event\_count\_reset number of cycles have passed. The policy repeats until the channel is given a different policy.





Figure C-10: GEN\_AFTER\_VALID\_EVENTS/RAND\_AFTER\_VALID\_EVENTS

#### GEN\_AFTER\_VALID\_OSC/RAND\_AFTER\_VALID\_OSC

This policy is active when the \*VALID is detected to be asserted. When enabled, it drives the \*READY Low for low\_time and then drives the \*READY High for high\_time. The policy repeats until the channel is given a different policy.



Figure C-11: GEN\_AFTER\_VALID\_OSC/RAND\_AFTER\_VALID\_OSC



#### GEN\_NO\_BACKPRESSURE

This policy generates a **ready** signal staying asserted and does not change until the driver detects a policy change.

#### **GEN\_RANDOM**

This policy randomly generates different policies including low\_time, high\_time, and event\_count. When used, it randomly selects a new policy when the previous policy has completed.

This uses the minimum/maximum pairs for generating the value of the low\_time, high\_time, and event\_count values.





# Debugging

This appendix includes details about resources available on the Xilinx® Support website and debugging tools.

# Finding Help on Xilinx.com

To help in the design and debug process when using the AXI4-Stream VIP, the Xilinx Support web page contains key resources such as product documentation, release notes, answer records, information about known issues, and links for obtaining further product support.

#### **Documentation**

This product guide is the main document associated with the AXI4-Stream VIP. This guide, along with documentation related to all products that aid in the design process, can be found on the Xilinx Support web page or by using the Xilinx Documentation Navigator.

Download the Xilinx Documentation Navigator from the Downloads page. For more information about this tool and the features available, open the online help after installation.

#### **Answer Records**

Answer Records include information about commonly encountered problems, helpful information on how to resolve these problems, and any known issues with a Xilinx product. Answer Records are created and maintained daily ensuring that users have access to the most accurate information available.

Answer Records for this core can be located by using the Search Support box on the main Xilinx support web page. To maximize your search results, use proper keywords such as

- Product name
- Tool message(s)
- Summary of the issue encountered

A filter search is available after results are returned to further target the results.



#### Master Answer Record for the AXI4-Stream VIP

AR: 68726

## **Technical Support**

Xilinx provides technical support at the Xilinx Support web page for this LogiCORE™ IP product when used as described in the product documentation. Xilinx cannot guarantee timing, functionality, or support if you do any of the following:

- Implement the solution in devices that are not defined in the documentation.
- Customize the solution beyond that allowed in the product documentation.
- Change any section of the design labeled DO NOT MODIFY.

To contact Xilinx Technical Support, navigate to the Xilinx Support web page.



# Additional Resources and Legal Notices

# **Xilinx Resources**

For support resources such as Answers, Documentation, Downloads, and Forums, see Xilinx Support.

# **Documentation Navigator and Design Hubs**

Xilinx<sup>®</sup> Documentation Navigator provides access to Xilinx documents, videos, and support resources, which you can filter and search to find information. To open the Xilinx Documentation Navigator (DocNav):

- From the Vivado<sup>®</sup> IDE, select Help > Documentation and Tutorials.
- On Windows, select **Start > All Programs > Xilinx Design Tools > DocNav**.
- At the Linux command prompt, enter docnav.

Xilinx Design Hubs provide links to documentation organized by design tasks and other topics, which you can use to learn key concepts and address frequently asked questions. To access the Design Hubs:

- In the Xilinx Documentation Navigator, click the **Design Hubs View** tab.
- On the Xilinx website, see the Design Hubs page.

**Note:** For more information on Documentation Navigator, see the Documentation Navigator page on the Xilinx website.



## References

These documents provide supplemental material useful with this product guide:

- 1. Arm<sup>®</sup> AMBA<sup>®</sup> 4 AXI4, AXI4-Lite, and AXI4-Stream Protocol Assertions User Guide (DUI0534B)
- 2. Instructions on how to download the Arm AMBA AXI specifications are at Arm AMBA Specifications. See the:
  - AMBA AXI4-Stream Protocol Specification
  - AMBA AXI Protocol v2.0 Specification
- 3. Vivado Design Suite User Guide: AXI Reference Guide (UG1037)
- 4. AXI Protocol Checker LogiCORE™ IP Product Guide (PG101)
- 5. Vivado Design Suite User Guide: Designing IP Subsystems using IP Integrator (UG994)
- 6. Vivado Design Suite User Guide: Designing with IP (UG896)
- 7. Vivado Design Suite User Guide: Getting Started (UG910)
- 8. Vivado Design Suite User Guide: Logic Simulation (UG900)
- 9. ISE to Vivado Design Suite Migration Guide (UG911)
- 10. Vivado Design Suite User Guide: Implementation (UG904)
- 11. LogiCORE IP AXI Interconnect Product Guide (PG059)
- 12. AXI4-Stream VIP API Documentation

**Note:** VIP API documentation source codes are different from the Install area implementation codes, refer to the Install area for the source codes.



# **Revision History**

The following table shows the revision history for this document.

| Date       | Version | Revision                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10/30/2019 | 1.1     | Updated API documentation link in References.                                                                                                                                                                                                                                                                                                                                                                                          |
| 05/22/2019 | 1.1     | Updated API documentation link in References.                                                                                                                                                                                                                                                                                                                                                                                          |
| 12/05/2018 | 1.1     | <ul> <li>Updated Finding the AXI4-Stream VIP Hierarchy Path in IP Integrator section.</li> <li>Fixed driver code in Method 2 for Write Transaction.</li> <li>Updated GEN_RANDOM heading in AXI4-Stream VIP Agent and Flow Methodology.</li> </ul>                                                                                                                                                                                      |
| 04/04/2018 | 1.1     | Updated to latest Vivado Design Suite.                                                                                                                                                                                                                                                                                                                                                                                                 |
| 12/20/2017 | 1.1     | <ul> <li>Updated note #6 in IP Facts table.</li> <li>Updated AXI4-Stream Master/Slave or Pass-Through VIP Port<br/>Descriptions tables.</li> </ul>                                                                                                                                                                                                                                                                                     |
| 10/04/2017 | 1.1     | <ul> <li>Added note #6 in IP Facts table.</li> <li>Added Xilinx Configuration Check and Description in Product Specification chapter.</li> <li>Updated Overview section in Example Design chapter.</li> <li>Updated Optional Haves and Must Haves in the Test Bench section.</li> <li>Added GEN_NO_BACKPRESSURE section to Configurable Ready Delays section.</li> <li>Added APIs to axi4stream_vip_v1_1_top APIs appendix.</li> </ul> |
| 06/07/2017 | 1.0     | <ul> <li>Added note #5-7 in IP Facts table.</li> <li>Updated AXI Protocol Checks and Descriptions table.</li> <li>Updated note in Example Design chapter.</li> </ul>                                                                                                                                                                                                                                                                   |
| 04/05/2017 | 1.0     | Initial Xilinx release.                                                                                                                                                                                                                                                                                                                                                                                                                |



# **Please Read: Important Legal Notices**

The information disclosed to you hereunder (the "Materials") is provided solely for the selection and use of Xilinx products. To the maximum extent permitted by applicable law: (1) Materials are made available "AS IS" and with all faults, Xilinx hereby DISCLAIMS ALL WARRANTIES AND CONDITIONS, EXPRESS, IMPLIED, OR STATUTORY, INCLUDING BUT NOT LIMITED TO WARRANTIES OF MERCHANTABILITY, NON-INFRINGEMENT, OR FITNESS FOR ANY PARTICULAR PURPOSE; and (2) Xilinx shall not be liable (whether in contract or tort, including negligence, or under any other theory of liability) for any loss or damage of any kind or nature related to, arising under, or in connection with, the Materials (including your use of the Materials), including for any direct, indirect, special, incidental, or consequential loss or damage (including loss of data, profits, goodwill, or any type of loss or damage suffered as a result of any action brought by a third party) even if such damage or loss was reasonably foreseeable or Xilinx had been advised of the possibility of the same. Xilinx assumes no obligation to correct any errors contained in the Materials or to notify you of updates to the Materials or to product specifications. You may not reproduce, modify, distribute, or publicly display the Materials without prior written consent. Certain products are subject to the terms and conditions of Xilinx's limited warranty, please refer to Xilinx's Terms of Sale which can be viewed at https://www.xilinx.com/legal.htm#tos; IP cores may be subject to warranty and support terms contained in a license issued to you by Xilinx. Xilinx products are not designed or intended to be fail-safe or for use in any application requiring fail-safe performance; you assume sole risk and liability for use of Xilinx products in such critical applications, please refer to Xilinx's Terms of Sale which can be viewed at https://www.xilinx.com/legal.htm#tos.

#### **AUTOMOTIVE APPLICATIONS DISCLAIMER**

AUTOMOTIVE PRODUCTS (IDENTIFIED AS "XA" IN THE PART NUMBER) ARE NOT WARRANTED FOR USE IN THE DEPLOYMENT OF AIRBAGS OR FOR USE IN APPLICATIONS THAT AFFECT CONTROL OF A VEHICLE ("SAFETY APPLICATION") UNLESS THERE IS A SAFETY CONCEPT OR REDUNDANCY FEATURE CONSISTENT WITH THE ISO 26262 AUTOMOTIVE SAFETY STANDARD ("SAFETY DESIGN"). CUSTOMER SHALL, PRIOR TO USING OR DISTRIBUTING ANY SYSTEMS THAT INCORPORATE PRODUCTS, THOROUGHLY TEST SUCH SYSTEMS FOR SAFETY PURPOSES. USE OF PRODUCTS IN A SAFETY APPLICATION WITHOUT A SAFETY DESIGN IS FULLY AT THE RISK OF CUSTOMER, SUBJECT ONLY TO APPLICABLE LAWS AND REGULATIONS GOVERNING LIMITATIONS ON PRODUCT I I ARIJITY

© Copyright 2017–2019 Xilinx, Inc. Xilinx, the Xilinx logo, Alveo, Artix, Kintex, Spartan, Versal, Virtex, Vivado, Zynq, and other designated brands included herein are trademarks of Xilinx in the United States and other countries. AMBA, AMBA Designer, Arm, ARM1176JZ-S, CoreSight, Cortex, PrimeCell, Mali, and MPCore are trademarks of Arm Limited in the EU and other countries. All other trademarks are the property of their respective owners.