

# Training on Functional Verification Methodology Using UVM

## LAB SystemVerilog Basics

#### **Objectives**

This lab goes through the main programming concepts of SystemVerilog language. It shows how to use SystemVerilog language to create programs, manipulate data and the main control flow of SystemVerilog language constructs.

### **Global Explanation**

In this lab we will implement tests to verify a extension of the previous adder, which includes additional registers.



It is not necessary to know the new DUT in details to follow this lab or the next ones, since all the necessary information will be exposed in each lab document. However, if you have the curiosity to know this new design an explanatory document called *AEDV-FA01* in the instructions directory.

The provided testbench "tb" instantiates the design under test and a SystemVerilog program "lab\_prog" as followed:



The task drive\_and\_verify() is already implemented and provide a Bus Functional Model (BFM) to drive the design.

It receives a transaction as an argument a variable of the type trans\_adder\_s defined in the file "lab\_utils\_pkg".

Therefore in this lab, we will create variables of the type trans\_adder\_s and we will then call this task to drive our design.

This will be done in the initial block of the "lab prog" program (in the file lab prog.sv)

#### Notes:

At the beginning of the programs, the following arrays, dynamic arrays and queues are instantiated and will be used in the lab:

#### **Get Started**

To launch the simulation,

```
cd simulation/<SIMULATOR>
./runsim.sh
```

Note: in order to launch using LSF, you must first setup the variable LAB\_LAUNCHER

```
setenv LAB_LAUNCER 'bsub -I -q gui -P mcdverif -R "select[rh60]"'
```

Alternatively you can run the command:

```
bsub -I -q gui -P mcdverif -R "select[rh60]" ./runsim.sh
```

In this lab, we will use the SystemVerilog mode. So the following checkbox should be set:

System Verilog

Browse and load the labs/NN-LABNAME/lab.sv file

#### **Instructions**

- Open the file <SANDBOX>/labs-Xdays/labNN-systemverilog\_basic/tb.sv" in your favourite editor.
- Search for "LAB-TODO"
- Instantiates the program "lab\_prog"
- Open the file <SANDBOX>/labs-Xdays/labNN-systemverilog\_basic/lab\_prog.sv" in your favourite editor.
- Search for "LAB-TODO"
- Follow the instructions present in this file.
- Compile, load and run.
- Don't hesitate to rerun on each step to understand your changes.

#### Questions:

STEP1 – Why changing single\_trans content does not affect values in the list?

STEP5 & 6: What is the difference between pop\_back / pop\_front?

STEP9 – What happens if you try to read a key which does not exist directly without checking its existence before?