KEMBAR78
Uvm Understanding | PDF | Inheritance (Object Oriented Programming) | Method (Computer Programming)
0% found this document useful (0 votes)
164 views8 pages

Uvm Understanding

The uvm_factory is used to create UVM objects and components. Types are registered with the factory using object and component registries. The factory allows overriding component types without modifying parent classes. This allows changing a component type in verification environments or tests without changing other code.

Uploaded by

Lokesh Kumar
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as DOCX, PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
164 views8 pages

Uvm Understanding

The uvm_factory is used to create UVM objects and components. Types are registered with the factory using object and component registries. The factory allows overriding component types without modifying parent classes. This allows changing a component type in verification environments or tests without changing other code.

Uploaded by

Lokesh Kumar
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as DOCX, PDF, TXT or read online on Scribd
You are on page 1/ 8

UVM Factory

As the name implies, uvm_factory is used to create UVM objects and component. Object and
component types are registered with the factory using
and components being created.

lightweight proxies to the actual objects

The uvm_object_registry #(T,Tname) and uvm_component_registry #(T,Tname) class are used to


proxy uvm_objects and uvm_components. With create we create factory.

The type_id::create() method returns an instance of the desired type, in below case
it returns instance inherit_bot_h of inherit_bot.
The use of the factory allows the developer to derive a new class extended from inherit_bot
and cause the factory to return the extended type in place of inherit_bot. Thus, the parent component can
use the new type without modifying the parent class.

Using the factory, we can overrite the type of component created by create method
from the higher level component in verification environment or from top level test.
driver = my_driver::type_id::create("driver",this); //it is in build phase of component
For example we create any component or inherit any class inherit_bot in top class top.

Class top extends xyz..


inherit_bot inherit_bot_h
inherit_bot_h= inherit_bot:: type_id::create(inherit_bot_h,this);
endclass

Suppose inherit_bot class is changed to inherit_bot_new, I dont need to change class top. I
will override function in top level component ot test.

https://www.youtube.com/watch?v=BXLyO6s9O3Y
Or suppose any driver in any agent got changed, we dont need to change the code of
agent. We can override the driver in any top level component.

http://www.sunburst-design.com/papers/CummingsSNUG2012SV_UVM_Factories.pdf

https://www.youtube.com/watch?v=BXLyO6s9O3Y
https://verificationacademy.com/verification-methodologyreference/uvm/docs_1.1a/html/files/base/uvm_factory-svh.html

connect phase of component

seq_item_port & seq_item_export

UVM Factory

Sequence Item
The UVM Class Library provides the uvm_sequence_item base class &
uvm_transaction base class.

Data items:
Are transaction objects used as stimulus to the device under test (DUT).
Represent transactions that are processed by the verification environment.

UVM has built-in automation for many service routines that a data item needs. For
example, you can use:
print() to print a data item.
copy() to copy the contents of a data item.
compare() to compare two similar objects.
For That, `uvm_object_utils macro registers the class type with the common factory.

TLM:
https://www.youtube.com/watch?v=a_2uqhgJV3U

TLM1: TLM1 ports provide blocking & non-blocking pass by value transaction level interface. The

semantics of these interfaces are limited to message passing.

TLM2: TLM2 sockets provide blocking & non-blocking transaction level interface with well defined
completion semantic.
Sequencer port: Push/pull port with well defined semantic. It is used to connect sequencers with

drivers and layering sequences.

Analysis port:

The analysis interface is used to perform non-blocking broadcasts of transactions to


connected components.

You might also like