## What is Verification?

Verification ensures that the RTL performs the correct function.

What defines the correct function of the RTL?

Verification  $\longleftarrow$  Specification  $\longrightarrow$  Design

What is the format of the specification?

- 1. paper document
- 2. Executable spec
  - 1. SystemC
  - 2. C++
  - 3. Matlab
  - 4. etc.



### **The Verification Process**

A hardware design mostly consists of several *Verilog (.v)* files with one top module, in which all other sub-modules are instantiated to achieve the desired behavior and functionality.

An environment called *testbench* is required for the verification of a given Verilog design and is usually written in *SystemVerilog*.

The idea is to drive the design with different stimuli to observe its outputs and compare it with expected values to see if the design is behaving the way it should.

### **The Verification Process**

In order to do verification, the top level design module is instantiated within the testbench environment and design input/output ports are connected with the appropriate testbench component signals.

The inputs to the design are driven with certain values for which we know how the design should operate.

The outputs are analyzed and compared with the expected values to see if the design behavior is correct.

# How to Verify the Design?

### **Compare DUT output with expected result.**





| From: Ons |       | To:     | 85ns |     |      |   |   |        |   |    |   |    |    |    |
|-----------|-------|---------|------|-----|------|---|---|--------|---|----|---|----|----|----|
| Get Sig   | gnals | Radix - | €    | a a | 100% |   | ₩ | 🚽 48ns | ~ | ~  | × |    |    |    |
|           | 0     |         | 1    | 9   | 2    | 9 |   | 30     |   | 40 |   | 50 | 60 | 70 |
| clk       | 0     |         |      |     |      |   |   |        |   |    |   |    |    |    |
| d         | 0     |         |      |     |      |   |   |        |   |    |   |    |    |    |
| q         | 1     |         |      |     |      |   |   |        |   |    |   |    |    |    |
| resetn    | 1     |         |      |     |      |   |   |        |   |    |   |    |    |    |