Application Engineering, Design & Verification in ICs and Embedded Systems

AEDVICES Consulting 166B Rue du Rocher de Lorzier 38430 Moirans- France trainings@aedvices.com http://www.aedvices.com

Commenté [AM1]: I accept suggestions about this lab. I would like to improve it, but I would like some tips before. What do you think about to use the block to the driver and

# Training on Verification Methodologies for IP and SoC Designs

#### LAB

Threads and Clocking Blocks

### **Objectives**

This lab goes through the main programming concepts of SystemVerilog clocking blocks. It shows how to use SystemVerilog language to create clocking schemes to sample or drive signals.

#### **Instructions**

Follow instructions given in "aedv\_training\_labs\_intructions\_for\_questa.pdf". Open the file <SANDBOX>/labs-Xdays/labNN-systemverilog\_programs/lab.sv" Select

System Verilog

### Step 0: Run Simulation

- Run the simulation and look to the waveform.
- It should be something like this:



## Step 1: Declare the Clocking Block.

- Open the file: <SANDBOX>/labs-Xdays/labNN-systemverilog\_threads /adder\_if.sv
- Search for *LAB-TODO-STEP1-a*
- Declare the clocking block
- Search for *LAB-TODO-STEP1-b*
- Use the *cb* ports as driver ports

modport driver (clocking cb, input i\_clk, input i\_rstn);

## Step 1: Adapting the Driver.

Open the file: <SANDBOX>/labs-Xdays/labNN-systemverilog\_threads /project\_utils\_pkg.sv

Page 1 / 2

- Search for *LAB-TODO-STEP2-a*
- Replace the current assignments with assignments like that:

```
this.vif.cb.i addr <= tr.addr;</pre>
```

- Do not forget the *while* statement:

```
while(vif.cb.o_ready !== 'h1)
```

- Search for *LAB-TODO-STEP2-b*
- Replace the delays with:

```
@(this.vif.cb);
```

- Re-run
- Questions:
  - $\circ$  Why is there a read transaction after compute of the address 0x03?
  - o Look to the waveform. Does it show something like this:



o Why does this delay exist? (Tip: Skew and "Waiting by o\_ready")

# **Step 3: Default Skews**

- Search for *LAB-TODO-STEP3-a*
- Declare the default output skew equal to #0 (This is not advisable, but we will jut take a look)
- Re-run
- Questions:
  - o The delay disappeared now? Why?
- Search for *LAB-TODO-STEP3-b*
- Replace the default input skew with another value
- Search for LAB-TODO-STEP3-
- Replace the default output skew with #2
- Questions:
  - o What happened? And if you replace it with negedge?