

# UVM Cheat Sheet

A quick reference guide covering core UVM concepts - what they are, why we use them, and how they fit into a verification testbench.

---

## 1. What is UVM? Why Do We Use It?

### Definition:

**UVM (Universal Verification Methodology)** is a standardized, SystemVerilog-based methodology for building reusable, modular, and scalable verification environments.

### Why We Use It:

-  **Reusability:** Same components (driver, monitor, agent) can be reused across multiple projects.
-  **Scalability:** Works for block-level to SoC-level verification.
-  **Automation:** Handles complex tasks like sequences, coverage, and reporting.
-  **Standardization:** Common structure across teams → easier debugging and collaboration.

### In short:

UVM gives you a professional, organized way to test chips instead of writing ad-hoc testbenches from scratch.

---

## 2. Difference: SystemVerilog vs. UVM Testbench

| Aspect    | SystemVerilog Testbench | UVM Testbench                                    |
|-----------|-------------------------|--------------------------------------------------|
| Structure | Flat, ad-hoc            | Hierarchical (test → env → agent → drv/seqr/mon) |

|              |                                             |                                                 |
|--------------|---------------------------------------------|-------------------------------------------------|
| Reuse        | Manual (copy/paste)                         | Built-in via UVM factory & components           |
| Stimulus     | Procedural ( <code>initial</code> blocks)   | Class-based (sequences on sequencers)           |
| Checking     | Manual <code>\$display</code> or assertions | Monitors + Scoreboards + Coverage               |
| Flow control | Manual delays                               | UVM phases (build, connect, run, etc.)          |
| Reporting    | <code>\$display</code>                      | UVM report macros (info, warning, error, fatal) |

 **Reason:** UVM provides structure, modularity, and reusability — essential for complex designs.

---

## 3. Testbench Architecture (UVM Layers)



| Component         | Role                                                |
|-------------------|-----------------------------------------------------|
| <b>test</b>       | Top-level, controls configuration & scenario        |
| <b>env</b>        | Holds multiple agents, scoreboard, coverage         |
| <b>agent</b>      | Groups driver, monitor, sequencer for one interface |
| <b>driver</b>     | Drives signals to DUT via virtual interface         |
| <b>sequencer</b>  | Sends transaction-level stimulus to driver          |
| <b>monitor</b>    | Observes DUT signals and sends data to scoreboard   |
| <b>scoreboard</b> | Checks DUT outputs against expected behavior        |

---

## 4. UVM Class Hierarchy

| Base Class                      | Used For                 | Example Classes                   | Phases                                                                                  |
|---------------------------------|--------------------------|-----------------------------------|-----------------------------------------------------------------------------------------|
| <code>uvm_compon<br/>ent</code> | Structural hierarchy     | env, agent, driver, monitor, test |  Yes |
| <code>uvm_object</code>         | Lightweight data objects | transaction, sequence item        |  No  |

 **Reason:** Components form the testbench structure; objects pass data between them.

---

## 5. Simulation Phases Overview

| Phase                           | Purpose                                      | Example Actions                                                      |
|---------------------------------|----------------------------------------------|----------------------------------------------------------------------|
| <code>build_phase</code>        | Create components & configure objects        | <code>drv = my_driver::create()</code>                               |
| <code>connect_phas<br/>e</code> | Connect TLM ports, exports                   | <code>driver.seq_item_port.connect(seqr.seq_it<br/>em_export)</code> |
| <code>run_phase</code>          | Time-based phase where simulation runs       | <code>seq.start(seqr)</code>                                         |
| <code>extract_phase</code>      | Collect results from monitors/scoreboar<br>d | Count transactions, coverage                                         |
| <code>check_phase</code>        | Verify results (pass/fail)                   | Check scoreboard errors                                              |
| <code>report_phase</code>       | Print summary report                         | <code>UVM_INFO</code> summary                                        |

 **Reason:** Phases provide consistent simulation flow across all components.

---

## 6. Configuration Database (`uvm_config_db`)

## Purpose:

A global database to share configuration handles (like virtual interfaces) between components without hard-coded paths.

## Example:

```
// In test  
i = my_if_if;  
uvm_config_db#(virtual my_if)::set(null, "uvm_test_top.env.agent.*", "vif", i);  
  
// In driver  
uvm_config_db#(virtual my_if)::get(this, "", "vif", vif);
```

 **Reason:** Makes environments reusable and avoids hard-coding signal connections.

---

## 7. UVM Factory & Overrides

**Factory:** Creates objects/components dynamically using:

```
obj = my_class::type_id::create("obj", this);
```

### Type Override (global)

```
factory.set_type_override_by_type(base::get_type(), derived::get_type());
```

 Replaces all instances of `base` with `derived`.

### Instance Override (specific path)

```
factory.set_inst_override_by_name("base", "derived", "uvm_test_top.env.agent.drv");
```

 Replaces only the specific instance.

 **Reason:** Enables flexible swapping of components without editing source code → reusability.

---

## 8. UVM Macros Overview

| Macro                                       | Used For                                 | Explanation                                                  | Example                                                   |
|---------------------------------------------|------------------------------------------|--------------------------------------------------------------|-----------------------------------------------------------|
| <code>uvm_object_utils(TY<br/>PE)</code>    | Register<br>non-compo<br>nent<br>objects | Enables<br>factory<br>creation for<br>transactions           | <code>pkt::type_id::create("tr")</code>                   |
| <code>uvm_component_utils<br/>(TYPE)</code> | Register<br>component<br>s               | Enables<br>factory<br>creation in<br>hierarchy               | <code>my_driver::type_id::create<br/>("drv", this)</code> |
| <code>uvm_do(tr)</code>                     | Sequence<br>shorthand                    | <code>create +<br/>start +<br/>randomize<br/>+ finish</code> | <code>\uvm_do_with(tr, {addr==8'hA5;})`</code>            |

 **Reason:** Macros save typing, register classes for factory use, and ensure consistent UVM structure.

---



## 9. UVM Reporting Macros

| Macro                                    | Purpose                | Stops<br>Sim? | Example                                                      |
|------------------------------------------|------------------------|---------------|--------------------------------------------------------------|
| <code>uvm_info(ID,<br/>MSG, VERB)</code> | Info/debug<br>messages | ✗             | <code>UVM_INFO("DRV", "Driving<br/>data", UVM_MEDIUM)</code> |
| <code>uvm_warning(ID,<br/>MSG)</code>    | Warning                | ✗             | <code>UVM_WARNING("TIMING", "Late<br/>signal")</code>        |
| <code>uvm_error(ID,<br/>MSG)</code>      | Error (counts)         | ✗             | <code>UVM_ERROR("PROT", "Protocol<br/>violation")</code>     |
| <code>uvm_fatal(ID,<br/>MSG)</code>      | Fatal stop             | ✓             | <code>UVM_FATAL("CFG", "Missing<br/>interface")</code>       |

## Controlling Verbosity

Command-line: `+UVM_VERBOSITY=UVM_HIGH`

Runtime: `uvm_top.set_report_verbosity_level(UVM_HIGH);`

 **Reason:** Gives structured, filterable logs instead of raw `$display` — easier debugging.

---

## 10. UVM Objections

### Purpose:

Controls **when simulation ends** automatically.

```
task run_phase(uvm_phase phase);
    phase.raise_objection(this);
    seq.start(seqr);
    phase.drop_objection(this);
endtask
```

- `raise_objection(this)` → keeps simulation running.
- `drop_objection(this)` → allows simulation to end.
- UVM ends sim only when **all objections are dropped**.

### Analogy:

Everyone raises a hand  when busy — simulation ends only when all hands go down.

 **Reason:** Ensures all components finish their work before simulation stops.

---



## Recap Table

| Concept                        | Description                                          | Reason                                 |
|--------------------------------|------------------------------------------------------|----------------------------------------|
| <b>UVM</b>                     | Reusable verification framework                      | Standardized & scalable testing        |
| <b>SV vs. UVM</b>              | SV = manual, UVM = structured                        | UVM simplifies reuse & debugging       |
| <b>Testbench Arch</b>          | test → env → agent → drv/mon/seq<br>r                | Modular and hierarchical               |
| <b>Hierarchy Classes</b>       | <code>uvm_component</code> , <code>uvm_object</code> | Components = structure, Objects = data |
| <b>Phases</b>                  | build → connect → run → report                       | Defines simulation flow                |
| <b>Config DB</b>               | Shared settings via DB                               | Avoid hard-coded connections           |
| <b>Factory &amp; Overrides</b> | Dynamic creation & replacement                       | Reusability and flexibility            |
| <b>Macros</b>                  | Boilerplate shortcuts                                | Less typing, consistent factory use    |
| <b>Reporting Macros</b>        | Structured logging                                   | Easier debug with verbosity control    |
| <b>Objections</b>              | Simulation control                                   | Coordinated ending for all components  |

---

## ★ Final Takeaway

UVM brings **structure, reusability, and control** to complex verification.

Learn each concept step-by-step, and soon they'll all connect naturally into one complete flow!