Universal Verification Methodology

The Universal Verification Methodology (UVM) is a standardized methodology for verifying integrated circuit designs. UVM is derived mainly from the OVM (Open Verification Methodology) which was, to a large part, based on the eRM (e Reuse Methodology) for the e Verification Language developed by Verisity Design in 2001. The UVM class library brings much automation to the SystemVerilog language such as sequences and data automation features (packing, copy, compare) etc., and unlike the previous methodologies developed independently by the simulator vendors, is an Accellera standard with support from multiple vendors: Aldec, Cadence, Mentor, and Synopsys.

History

In December 2009, a technical subcommittee of Accellera a standards organization in the electronic design automation (EDA) industry voted to establish the UVM and decided to base this new standard on the Open Verification Methodology (OVM-2.1.1),[1] a verification methodology developed jointly in 2007 by Cadence Design Systems and Mentor Graphics.

On February 21, 2011, Accellera approved the 1.0 version of UVM.[2] UVM 1.0 includes a Reference Guide, a Reference Implementation in the form of a SystemVerilog base class library, and a User Guide.[3]

Sequencer

The sequencer is responsible for three main functions:

Initialization

In this stage the DUT (Device Under Test) and the environment it is in should be set to the conditions desired before the simulation. Likely, this includes:

Definitions

UVM Macros

UVM allows the use of Macros

name function related to parameters purpose Type of Macro
`uvm_create object constructor `uvm_send Sequence or Item to create the object and allow user to set values via overloading or parameter passing Sequence action macro
`uvm_send processor `uvm_create Sequence or Item processes what is created by `uvm_create without randomization Sequence Action Macros for Pre-Existing Sequences
`uvm_do processor `uvm_create Sequence or Item executes class or item with randomization Sequence action macro

References

External links

This article is issued from Wikipedia - version of the Monday, April 25, 2016. The text is available under the Creative Commons Attribution/Share Alike but additional terms may apply for the media files.