KEMBAR78
UVM Interview Questions | PDF | Class (Computer Programming) | Interface (Computing)
0% found this document useful (0 votes)
289 views5 pages

UVM Interview Questions

Uploaded by

Anindita Dash
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)
289 views5 pages

UVM Interview Questions

Uploaded by

Anindita Dash
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/ 5

UVM Interview Questions

Q1. What is UVM?


Ans:
Universal Verification methodology.
It provides 4 service mechanisms.
i. Reporter – uvm_report_server
ii. Factory – uvm_factory
iii. Configuration Database – uvm_config_db
iv. Simulation Execution Manager – uvm_root
These service mechanisms are enabled when we import the uvm_pkg.

Q2. What is a “Sequencer”?


Ans:
A sequencer is an advanced stimulus generator, which controls the items that are provided to the driver.
It returns a random data item/transaction upon request from the driver.

Q3. What is a “Monitor”?


Ans:
i. A monitor is a passive entity which samples the DUT signals but doesn’t drive them.
ii. A monitor can collect coverage information and can be used for checking.

Q4. What is an “Agent”?


Ans:
i. Agent is an abstract container which encapsulates Driver, Sequencer and Monitor.
ii. Agents are configurable as either active or passive. Active agents emulate devices and
drive transactions (i.e sequencer and driver). Passive agents only monitor the DUT actively.
Q5. What is an “ENV”?
Ans:
ENV is the top level component of the verification components, which contains one or more agents,bus monitors,
configuration properties that enables to customize the topology and behavior and make it reusable.
Example : Active agents can be re-used as Passive agents when its used in system verification.

Q6. What is UVM class Library?


Ans:
UVM class Library provides all the building blocks to develop reusable verification components and
Test environments.
The library consists of base classes, utilities and macros.
Q.7. What are advantages of using UVM class Libraries?
Ans:
It provides robust set of built in features for example copying cloing,printing and more.
It correctly implements UVM concepts.
It provides utilities which support debugging by providing a user controllable messaging utility.
It provides global messaging facilities which can be used for failure reporting.
It provides a standard communication infrastructure between verification components (TLM)
It provides flexible verification environment construction(UVM Factory).
Q.8. What is UVM Factory?
Ans:
Q.9. What Is The Difference Between Uvm_component And Uvm_object? Or We Already Have
Uvm_object, Why Do We Need Uvm_component Which Is Actually Derived Class Of Uvm_object?
Ans:
uvm_component is a static entity and always tied(bind) to a given hardware and/or a TLM interface

uvm_object is a dynamic entity and is not tied to any hardware/TLM interface

uvm_component like uvm_driver is always connected to a particular DUT interface because throughout
the simulation its job is fixed i.e. to drive the designated signals into DUT

uvm_object like uvm_transaction is not connected to any particular DUT interface and its fields can
take any random value based on randomization constraints.

Though uvm_component is derived from uvm_object, uvm_component has got these additional
interfaces

* Hierarchy provides methods for searching and traversing the component hierarchy.
* Phasing defines a phased test flow that all components follow, with a group of standard phase
methods and an API for custom phases and multiple independent phasing domains to mirror DUT
behavior e.g. power
* Configuration provides methods for configuring component topology and other parameters ahead
of and during component construction.
* Reporting provides a convenience interface to the uvm_report_handler. All messages, warnings,
and errors are processed through this interface.
* Transaction recording provides methods for recording the transactions produced or consumed by
the component to a transaction database (vendor specific).
* Factory provides a convenience interface to the uvm_factory. The factory is used to create new
components and other objects based on type-wide and instance-specific configuration
Q.10 . Why do we have two utilities macros uvm_object_utils for uvm_object and uvm_component_utils
for uvm_component though uvm_component is extended from uvm_object?
Ans:
The reason there are two macros is because the factory design pattern fixes the number of arguments
that a constructor can have. Classes derived from uvm_object have constructors with one argument,
a string name. Classes derived from uvm_component have two arguments, a name and
a uvm_component parent. The two `uvm_*utils macros inserts code that gives you a
factory create() method that delegates calls to the constructors of uvm_object or uvm_component.
You need to use the respective macro so that the correct constructor arguments get passed through.
This means that you cannot add extra constructor arguments when you extend these classes in order
to be able to use the UVM factory.
Q.11. What are UVM phases?
Ans:
In order to have a consistent testbench execution flow, the UVM uses phases to order the major steps
that take place during the simulation.
i. Build Phase
a. Build
b. Connect
c. End of elaboration
ii. Run Phase
a. Start_of_simulation
b. Pre_reset
c. Reset
d. Post_reset
e. Pre_configure
f. Configure
g. Post_configure
h. Pre_main
i. Main
j. Post_main
k. Pre_shutdown
l. Shutdown
m. Post_shutdown
iii. Clean Up Phases
a. Extract
b. Check
c. Report
d. final
Q.11. Which Uvm Phase Is Top - Down, Bottom – Up & Parallel?
Q.12. Which Phase Is Function & Which Phase Is Task?
Q.13. Why Build Phase Is Top – Down & Connect Phase Is Bottom – Up?
Q.14. Which Phase Takes More Time And Why?
Q.15. How Uvm Phases Initiate?
Q.16. How Test Cases Run From Simulation Command Line?
Q.17. What Is Uvm_config_db? What Is Difference Between Uvm_config_db & Uvm_resource_db?
Q.18. What Is The Advantage And Difference Of `uvm_component_utils() And
`uvm_object_utils()?

Q.19. Difference Between `uvm_do And `uvm_rand_send ?


Q.20. Difference Between Uvm_transaction And Uvm_seq_item?
Q.21. What Are The Benefits Of Using Uvm?
Q.22. Can We Have User Defined Phase In Uvm?
Ans:
Yes, We can define our own phase and insert it between any of the existing phases.
Define a new phase class inherited from uvm_task_phase, implement the exec_task or exec_func method and insert
the phase into existing schedule or domain object.
What Are The Types Of Sequencer? Explain Each?
What Is The Difference Between Copy And Clone?
What Is The Difference Between Active Mode And Passive Mode With Respect To Agent?
What Is M_sequencer and P_Sequencer? Or Difference Between M_sequencer And P_sequencer?
Ans:
P_Sequencer is a handle to the sequencer on which the current sequence should be executed and is made available in
a sequence by the macro `uvm_declare_p_sequencer .

How Sequence Starts?


Ans:
A Sequence can be started by calling its start() method or by using the macro `uvm_do.
What Is Objection?
What Is Analysis Port?
Ans:
An Analysis port is a TLM mechanism which allows classes to broadcast the data objects to multiple listeners so
that they can implement different methods to perform different operations on the data items it receives.
What Is Uvm Ral Model? Why It Is Required?
Ans:
i. RAL is short for Register Abstraction Layer.
ii. It is a set of base classes that can be used to create register models to mimic the register contents in a
design.
iii. It is much easier to write and read from the design using a register model than sending a bus
transaction for every read and write.
iv. Register model stores the current state of the design in a local copy called as a mirrored value.
What Is The Difference Between Uvm Ral Model Backdoor Write/read And Front Door
Write/read?
What is uvm_transaction, uvm_seq_item, uvm_object, uvm_component?
What is the advantage of `uvm_component_utils() and `uvm_object_utils() ?
What is the difference between `uvm_do and `uvm_ran_send?
What is the difference between uvm_transaction and uvm_seq_item?
Ans:
What is the difference between uvm _virtual_sequencer and uvm_sequencer?
What are the benefits of using UVM?
What is the super keyword? What is the need of calling super.build() and super.connect()?
Is uvm is independent of systemverilog ?
Ans:
No. UVM is built on System Verilog language and hence you can not run UVM with any tool that does not support
System Verilog.
Can we have a user-defined phase in UVM?
Why do we need to register a class with Factory?
Ans:
It is registered with a factory simply to make the testbench more reusable and have the capability to override it with
some other derivative components later.
What is the difference between new() and create?
Ans:
i. The new() method is the classical way of creating object instance.
ii. The create() is added in UVM for creating object instance which allows the class to be registered with
factory. SO that upon asking the factory can return the object of type that we want.
What is TLM FIFO?
Ans:
When two components at different clocks need to be operating independently, a TLM FIFO can be inserted in
between. One component can send data at a faster rate while the other component can receive at a slower rate.

What is the difference between UVM RAL model backdoor write/read and front door write/read?
What is an objection?
What is the advantage of `uvm_pre_body and `uvm_post_body?
What is the difference between Active mode and Passive mode?
What is the difference between copy and clone?
What is the UVM factory?
What are the types of sequencer? Explain each?
What are the different phases of uvm_component? Explain each?
How set_config_* works?
What are the advantages of the uvm RAL model?
What is the different between set_config_* and uvm_config_db?
What are the different override types?
What is virtual sequence and virtual sequencer?
Ans:
i. A Virtual Sequence is a container that holds and executes multiple other smaller sequences.
ii. A virtual Sequencer is a container that holds the handles to other sequencers in an environment so that
each sequence in a virtual sequence can be executed on the appropriate sequencer.
Q.Explain the end of the simulation in UVM?
Q.How to declare multiple imports?
Q.What is the symbolic representation of port, export and analysis port?
Q. What is the difference in usage of $finish and global stop request in UVM?
Q. Can we use set_config and get_config in sequence?
Ans:
set_config_* can be used only for the components not for the sequences.

Q. What is the uvm_heartbeat ?


Ans:
i. Heartbeats provide a way for environments to easily ensure that their descendants are alive. or in other
words, the uvm_heart beat catches the deadlock or hang states of the verification components.
ii. UVM_heartbeat watches for an activity in the test bench and if it finds that there is no activity in the
specified interval of time, then uvm_heratbeat issue a fatal message which leads to the end of the
simulation.

Q. How to access DUT signal in uvm_component/uvm_object?


Ans:
i. Interface Signals can be accessed via a virtual interface handle that points to the actual interface.
ii. Signals within the DUT can be accessed directly by providing a hierarchical RTL path to the signal
such as top.eatable.fruits.apple.slice

You might also like