# **UVM Learning**

My Journey to Mastering Universal Verification Methodology

Documented By: Hamza Shabbir

Revision: V2.0

# What is UVM (Universal Verification Methodology)?

Universal Verification Methodology (UVM) is a standardized framework used in the semiconductor industry for the functional verification of digital designs, such as integrated circuits (ICs) and system-on-chip (SoC) designs. It is built on top of SystemVerilog, a hardware description and verification language (HDVL), and provides a powerful, reusable, and scalable approach to building verification environments.

### Key Features of UVM:

- 1. **Standardized Framework:** UVM is maintained by Accellera Systems Initiative, ensuring standardization and compatibility across EDA tools (e.g., Synopsys VCS, Cadence Xcelium, Mentor Graphics Questa).
- 2. **Reusable Components:** UVM encourages the development of reusable components, such as drivers, monitors, and scoreboards, that can be shared across different projects or reused within the same project.
- 3. **Scalable Architecture:** UVM supports small-scale block-level verification as well as large-scale SoC-level verification through hierarchical testbench structures.
- 4. Coverage-Driven Verification (CDV): UVM integrates functional coverage techniques, enabling verification teams to measure the completeness of their tests and ensure all scenarios are exercised.
- 5. **Built-in Debugging and Reporting Mechanisms:** UVM provides powerful logging and reporting capabilities, making it easier to debug complex verification environments.
- 6. **Transaction-Level Modeling (TLM):** UVM uses TLM communication for high-level modeling, allowing for efficient data exchange and decoupling of components.

### Core Components of UVM:

UVM is structured around the concept of classes in SystemVerilog. Some core components include:

#### 1. Driver

- Stimulates the Design Under Test (DUT) by converting abstract transactions into pin-level signals.
- Example: Sending data packets to a DUT interface.

#### 2. Monitor

- Observes DUT activity and collects data from its interfaces.
- Example: Extracting responses for functional coverage or scoreboard comparison.

### 3. Sequencer

- Controls the generation of stimulus by managing sequences of transactions.
- Example: Creating randomized patterns for exhaustive testing.

### 4. Agent

 A collection of components (driver, sequencer, monitor) that handles a specific interface of the DUT

### 5. Environment

• The top-level container that instantiates and configures agents and other components.

### 6. Scoreboard

• Compares DUT output against the expected results to verify correctness.

#### 7. Test

 Controls the simulation by defining sequences, configuring environments, and monitoring overall test execution.

## Objective of this Document

This document showcases my implementation of a basic UVM framework for verifying a counter design. It serves as a guide to understanding the practical steps involved in developing a UVM-based testbench, highlighting my approach to applying UVM concepts in a simple yet effective manner. Additionally, it ties closely to my GitHub repository, "UVM\_Learning", which hosts the UVM counter example along with other resources. The repository complements this document by providing hands-on learning through code, simulations, and practical insights.

# Integration of UVM Components

### Top Module Overview

The Top Module in a UVM testbench serves as the central component that connects all the subcomponents, such as the interface and Design Under Test (DUT). It instantiates the DUT and the interface, and also typically handles the commands for starting and running the test. Additionally, it now incorporates the UVM Configuration Database (config\_db) to set and share the counter interface, enabling seamless access to the interface by all testbench components.

### Components of the Top Module

- 1. **Interface:** The interface in UVM connects the testbench to the DUT. It defines the signals that the driver and monitor use to interact with the DUT. An interface serves as a communication channel between different components of the testbench and the DUT. In this setup, the interface is registered with the config\_db, allowing it to be retrieved and utilized by the driver, monitor, sequencer, predictor, and other components.
- 2. **Design Under Test (DUT):** The Design Under Test (DUT) in this example is a simple 8-bit counter that supports three primary operations: increment, reset, and load. The counter increments by 1 on each clock cycle when the inc signal is active, resets to 0 when the rst signal is active low, and can load a specific 8-bit value when the ld signal is triggered. The integration of the config\_db in the top module ensures that the counter interface is efficiently accessible to all UVM components, streamlining their ability to interact with the DUT. This approach enhances modularity and simplifies the sharing of resources within the UVM testbench.



### **UVM** Test Overview

A UVM test is the starting point of the simulation in a UVM-based verification environment. It acts as the main control unit that initializes and coordinates the testbench components, sequences, and scenarios required for verification. The UVM test defines the high-level behavior and stimuli for the Design Under Test (DUT) by interacting with other UVM components like the environment, sequencer, and driver. It typically extends the uvm\_test base class and overrides its phases to configure and execute the testbench.

### Counter Test Overview

In the case of the 8-bit counter, the counter\_test class extends the uvm\_test base class and serves as the main test component. Within this class, the environment (counter\_env) is instantiated during the build phase. The environment contains all the necessary testbench components, such as agents, monitors, and drivers, that interact with the DUT to facilitate verification. Additionally, the counter\_test class includes test sequences for the reset, increment, load, and random operations. These sequences are designed to validate specific functionalities of the counter, ensuring comprehensive verification. This structure enables a modular and organized testbench while allowing flexible test scenarios.



### UVM Sequence Item Overview

A UVM Sequence Item is a fundamental element in the UVM methodology used to represent the transactions that occur between the testbench components and the DUT. It acts as a data carrier, encapsulating the stimulus information such as control signals, data, or operation types needed for a specific test scenario. The sequence item is extended from the uvm\_sequence\_item base class, which provides built-in methods for randomization, printing, comparison, and copying, making it easier to create reusable and flexible test scenarios.

### Counter Sequence Item

In the case of the 8-bit counter design, the Counter Sequence Item is a class derived from uvm\_sequence\_item. It encapsulates the data, operation type, and output value required to verify the counter's functionality, providing methods for various operations on the sequence item.

#### **Attributes:**

- 1. **Data:** An 8-bit value (logic[7:0]) representing the data to be loaded into the counter or compared with its output.
- 2. **Op:** A user-defined type (ctr\_op) representing the operation to be performed on the counter, such as increment, reset, load, or nop.
- 3. Q: An 8-bit value (logic[7:0]) used to store the output value of the counter, enabling comparisons or further analysis of the DUT's behavior during verification.

#### **Methods:**

- 1. **do\_copy:** Copies the properties (data and op) from one sequence item to another, ensuring consistency when duplicating items..
- 2. **convert2string:** Converts the attributes of the sequence item (data and op) into a string format for easy debugging and logging during simulation.
- 3. **load\_data:** A function that initializes the data and op fields with specific values. This method ensures that the sequence item can set up the desired stimuli for a test.
- 4. **compare:** Compares two sequence items to verify the equality of their attributes. This is particularly useful for checking expected versus actual results.

The Counter Sequence Item encapsulates the required attributes and utility functions for driving stimuli to the DUT, enabling the verification of the counter's increment, reset, and load functionalities. Its design ensures reusability and simplifies the process of creating various test scenarios in the UVM environment.

### **UVM Sequence Overview**

In UVM, a sequence is a set of ordered transactions or sequence items that are sent to the Design Under Test (DUT) to verify its functionality. A sequence is responsible for generating a series of operations or tests, which are driven to the DUT through a sequencer. The UVM framework allows sequences to be executed in parallel or sequentially, making them flexible for various testing scenarios.

### Counter Test Sequences

For the counter test, multiple sequences are created to test different functionalities of the 8-bit counter. These sequences simulate different operations such as reset, increment, load, and random operations, providing comprehensive test coverage for the DUT.

### 1. Reset Sequence:

This sequence is designed to send a reset signal to the DUT, forcing the counter to return to its initial state (typically zero). The reset sequence ensures that the counter can be properly initialized during simulation.

#### 2. Increment Sequence:

The increment sequence repeatedly sends increment operations to the DUT to test if the counter increments correctly. This sequence runs for 10 iterations, verifying the counter's ability to increment its value correctly after each operation.

#### 3. Load Sequence:

The load sequence is responsible for loading a random value into the counter. This tests the counter's ability to accept and store arbitrary data values.

#### 4. Random Sequence:

The random sequence randomizes both the data value and the operation type (op). This sequence can test a variety of operations (e.g., reset, increment, or load) with randomized data values to explore different corner cases.

These sequences allow for comprehensive testing of the counter's behavior under various conditions, ensuring that it functions correctly across different types of operations. By executing these sequences within the UVM framework, the testbench can verify the DUT's responses to different stimuli and confirm its correct functionality.

### **UVM Configure Database Overview**

The UVM Config DB (Universal Verification Methodology Configuration Database) is a central mechanism for sharing and retrieving configuration data between UVM components in a testbench. It allows for the decoupling of testbench components by providing a global repository where data or object handles can be set and fetched dynamically during simulation. This eliminates the need for direct connections or hardcoding, enabling better modularity and reusability in UVM-based testbenches.

### Key Features of UVM Config DB:

- 1. **Global Access:** Components can access the configuration database to set or get data without direct dependencies on other components.
- 2. **Hierarchical Scoping:** Supports hierarchical access, allowing components to share configurations based on their position in the UVM component hierarchy.
- 3. **Type Safety:** Ensures type safety when setting and retrieving configuration data, reducing runtime errors.
- 4. **Flexibility:** Useful for passing handles to interfaces, objects, or specific configuration parameters.

The UVM Config DB is particularly beneficial in complex testbenches, where multiple components need access to shared data like interfaces or configuration parameters, ensuring a clean and scalable testbench design.

### **UVM Driver Overview**

The UVM Driver is a crucial component in the UVM testbench architecture. It is responsible for driving the transactions (sequence items) generated by the sequencer to the Design Under Test (DUT). The driver takes the sequence items and translates them into signal-level actions that are applied to the DUT. It typically interacts with the DUT through a set of interfaces, ensuring that the required signals are driven on the DUT's ports. The driver plays a key role in mimicking real-world behavior and ensuring that the DUT is tested in a variety of conditions, based on the sequences provided.

#### Counter Driver Overview

The Counter Driver extends from the uvm\_driver class and is specifically designed to interface with the counter\_if interface and the counter\_sequence\_item. It processes the transactions created by the UVM sequence and converts them into actual signal values that are driven onto the DUT

Key Components and Functions of the Counter Driver:

- 1. **Interface (counter\_if):** The Counter Driver uses the counter\_if interface to communicate with the DUT. This interface includes signals such as clk, rst, inc, ld, and data\_in, which the driver manipulates based on the sequence items. The interface is now accessed dynamically through the UVM config\_db, ensuring flexibility and seamless configuration for the driver.
- 2. **Counter Sequence Item (counter\_sequence\_item):** The Counter Driver takes transactions from the sequence items, which define actions like incrementing the counter, loading data, or resetting the counter. The driver converts these actions into corresponding signal drives on the DUT..
- 3. **Transfer Task:** The main function of the Counter Driver is the transfer task. This task is responsible for taking the transaction from the sequence item and converting it into the corresponding control signals and data for the DUT. This includes asserting the correct control signals (inc, ld, rst) and providing the appropriate data in to the DUT.

By utilizing the UVM config\_db to retrieve the interface, the Counter Driver promotes better modularity and reusability while ensuring alignment with the testbench architecture.



### **UVM Monitor Overview**

The UVM Monitor is a crucial component of the UVM testbench that is responsible for observing and capturing the activity in the DUT (Design Under Test). It does not interact with the DUT directly to apply inputs but rather monitors and reports on the outputs or responses from the DUT. The monitor collects data, typically in the form of transactions, and sends it to analysis ports for further analysis or reporting. The monitor typically uses the same interface as the driver to observe the DUT's signals and gather information about the DUT's operation during simulation.

### Counter Monitor Overview

The Counter Monitor extends the uvm\_monitor class and is specifically designed to observe and capture the behavior of the counter DUT. It uses the counter\_if interface to monitor signals such as data\_in, q, inc, ld, and rst.

The interface is now retrieved dynamically from the uvm\_config\_db, enabling better modularity and reuse across testbenches. The Counter Monitor captures transactions in the form of counter\_sequence\_item, which encapsulates both the request (input signals) and response (output signals) in a single object.

The monitor uses a single analysis port to broadcast the captured counter\_sequence\_item transactions to other components in the testbench, such as the scoreboard. This unified approach simplifies the design by consolidating both the input and output observations into a single sequence item, streamlining the verification process.

By leveraging the analysis port, the Counter Monitor ensures that all relevant components receive the necessary transaction data for further processing, such as functional checks and result comparison.



### **UVM Agent Overview**

A UVM Agent is a self-contained testbench component in the Universal Verification Methodology (UVM) that encapsulates a Driver, Sequencer, and Monitor. It serves as a modular entity responsible for generating, driving, and monitoring transactions for a specific interface of the Design Under Test (DUT). The UVM Agent simplifies the testbench by grouping related components, making it reusable and easy to configure.

### Counter Agent Overview

The Counter Agent is a UVM component extended from uvm\_agent. It is specifically designed to verify the 8-bit counter DUT. The Counter Agent contains the following subcomponents:

- 1. **Driver:** The driver interacts with the DUT by converting sequence items (transactions) from the Sequencer into signal-level interactions using the counter interface. It drives these signals into the DUT.
- 2. **Monitor:** The monitor observes the signals between the DUT and the interface, creating sequence items that represent the observed transactions. These are sent out through its analysis port.
- 3. **Sequencer:** The sequencer generates sequence items (transactions) for the driver to process. These sequences define the operations, such as increment, reset, and load, to be tested.
- 4. **Analysis Port:** The agent includes a UVM analysis port that connects to the Monitor's analysis port. This enables the transactions captured by the Monitor to be sent to other testbench components, such as the Scoreboard or Predictor.

By grouping the Driver, Monitor, Sequencer, and Analysis Port into a single entity, the Counter Agent encapsulates all the components needed to interact with and observe the 8-bit counter DUT in a clean, modular manner.



### Predictor / Golden Model Overview

A Predictor (or Golden Model) is a key component in a UVM testbench used to model the expected behavior of the DUT (Design Under Test). It acts as a reference model, simulating how the DUT is supposed to operate under given input conditions. The Predictor receives transactions (sequence items) from the monitor, processes them based on a known algorithm or specification, and generates expected results. These predicted results are sent to a comparator, typically through a scoreboard, to verify that the DUT's output matches the expected behavior.

The Predictor ensures correctness by providing a "golden" output, making it a crucial part of functional verification.

### Counter Predictor Overview

The Counter Predictor extends the uvm\_component class and is designed to predict the behavior of the 8-bit counter DUT. It models the counter's operations, including increment, reset, and load, based on the inputs provided by the sequence items.

#### **Key Features:**

- 1. **TLM Analysis FIFO:** The predictor uses a UVM TLM analysis FIFO to receive sequence items from the monitor. The FIFO acts as a buffer, ensuring that the predictor processes transactions in the correct order.
- 2. **UVM Put Port:** The predictor includes a UVM put port to send the predicted results (expected counter outputs) to the comparator or scoreboard. This allows seamless integration into the verification environment.
- 3. **Transaction Processing:** The predictor processes the received sequence items by simulating the counter's operations (increment, load, reset) and generates the predicted results.



### **UVM Scoreboard Overview**

The UVM Scoreboard is a critical component in a UVM testbench used to validate the DUT's output by comparing it against the expected (predicted) results. The scoreboard collects actual data from the monitor and predicted data from the predictor and performs a comparison to identify mismatches. It acts as the central checker in the verification environment, ensuring that the DUT behaves as specified.

A well-designed scoreboard isolates the comparison logic, making it reusable and easy to debug when mismatches occur

### Counter Scoreboard Overview

The Counter Scoreboard extends the uvm\_component class and is tailored to verify the outputs of the 8-bit counter DUT. It performs the following key tasks:

- 1. **Analysis FIFO:** Receives actual results from the monitor via a UVM TLM analysis FIFO.
- 2. Get Port: Obtains predicted results from the predictor using a UVM get port.
- 3. **Comparison:** Compares the actual results from the DUT with the predicted results from the predictor and logs any mismatches for debugging.



### **UVM Environment Overview**

The UVM Environment serves as the top-level container for all testbench components in a UVM-based verification setup. It integrates drivers, monitors, sequencers, scoreboards, and other verification components, managing their interactions and data flow. The environment provides a structured and modular way to build reusable and scalable testbenches, ensuring that all components work together seamlessly to verify the DUT.

### Counter Environment Overview

The Counter Environment extends from the uvm\_env base class and is specifically designed for the 8-bit counter verification. It encapsulates the critical components needed to validate the counter's functionality in an efficient and modular way.

#### Components:

- 1. **Agent:** Combines the driver, monitor, and sequencer into a single unit. The monitor's analysis port is connected to both the predictor and scoreboard analysis FIFOs, enabling seamless data flow.
- 2. **Predictor:** Serves as the golden model, generating expected results based on transactions received from the agent's monitor. It is connected to the scoreboard through a TLM FIFO, which ensures smooth transmission of predicted results.
- 3. **Scoreboard:** Compares the actual results from the DUT with the predicted results provided by the predictor to validate functionality.
- 4. **TLM FIFO:** Facilitates the connection between the predictor and the scoreboard, enabling the transfer of predicted results for comparison.

### **Key Features:**

- 1. The agent's analysis port is the central data provider, linking the monitor to both the predictor and the scoreboard for accurate and efficient data handling.
- 2. The predictor and scoreboard are connected via a TLM FIFO to ensure proper synchronization and flow of predicted results.
- 3. Test sequences are no longer executed within the environment but are managed externally, maintaining a clean separation of responsibilities and enhancing modularity.

This streamlined structure focuses on efficient coordination between components, ensuring robust and reusable verification infrastructure.

### Pictorial Representation



### Conclusion

The verification of the 8-bit counter using the Universal Verification Methodology (UVM) successfully demonstrated the creation of a modular and reusable testbench. By using UVM, we defined key components such as the driver, monitor, sequencer, predictor, and scoreboard, ensuring thorough functional verification of the DUT.

A significant update to the testbench was the introduction of the agent, which now contains the driver, monitor, and sequencer, simplifying the structure and enhancing modularity. The agent's analysis port is connected to the predictor and scoreboard via TLM FIFOs for seamless data communication. The Counter Environment was simplified to include only the agent, predictor, and scoreboard, with test sequences managed externally, providing greater flexibility.

The integration of UVM Config DB enabled dynamic configuration, streamlining communication and setup across components. UVM sequences ensured robust coverage of the DUT's operations, including reset, increment, load, and random scenarios. This project reinforced the power of UVM in structuring verification tasks, highlighting the importance of modularity and reusability in testbench development.

This document provides a comprehensive guide to UVM-based verification, offering a practical reference for similar projects, and welcomes feedback for further improvements.