# NCTU-EE IC LAB - 2022 Spring

### Formal Verification – Bonus Exercise

- 1. Using Assertion Based Verification IP (ABVIP) to verify AXI-4 Lite Master
- 2. Using Scoreboard & Customized SVA for Verification

#### **Data Preparation**

- 1. Data Extraction: tar xvf ~iclabta01/Bonus/Bonus\_formal\_verification.tar
- 2. The extracted LAB directory contains

```
00_TESTBED/
Contain TA's Usertype_PKG.sv & INF.sv
01_RTL/
Contain bridge.sv (bug inserted)
02_JG/
```

Contain run\_jg, run.tcl, top.sv, jg.f, license.sh

3. The answer of this lab: tar xvf ~iclabta01/Bonus/Bonus\_formal\_verification\_ans.tar

### **Description**

In this bonus exercise, you are going to use ABVIP to verify the offered Customized I/O to AXI4-Lite bridge. Main focus of this exercise is to check the protocol, and find some bug inside the bridge with build-in scoreboard and customized SVA by Formal Verification tool - JasperGold.

With ABVIP, we could use the build-in SVA property to check our design's AXI4-Lite interface part to make sure our design is reliable to handle any situation on the bus.

As for the interface connected to the design module, it required customized SVA properties to check the remain of our design.

Different from previous lab (Simulation Based Verification with SVA), this lab demonstrates another perspective of verification – Formal Verification.

Formal Engine would transform our verification environment (including our design, SVA property and auxiliary logic) into another equivalent simplified mathematical problem, such that it uses different algorithms in the backend to finite number of traces to prove whether our design is verified or not.

### **Block Diagram of the Verification Environment**



# **Customized Signal Behavior**

### Input:

| name       | width  | Send to |                                             |
|------------|--------|---------|---------------------------------------------|
| C_addr     | 7-bit  | bridge  | C_addr Indicates which address we want to   |
|            |        |         | access.(Bridge would do Address Conversion) |
| C_data_w   | 32-bit | bridge  | The data to over right DRAM.                |
| C_in_valid | 1-bit  | bridge  | High when the system is ready to            |
|            |        |         | communicate with bridge.                    |
| C_r_wb     | 1-bit  | bridge  | 1'b1: Read axi_slave.                       |
|            |        |         | 1'b0: Write axi_slave.                      |

# **Output:**

| name        | type   | Send to | note                                   |
|-------------|--------|---------|----------------------------------------|
| C_out_valid | 1-bit  | design  | High when returned data from is ready. |
| C_data_r    | 32-bit | design  | The returned data from DRAM.           |

- I. There are 4 hardware bugs TA has insert in the design.
- II. You should finish the blank in the top.sv to check data integrity
  - A. Scoreboard Port Connection (inf.AW\_ADDR) ScoreBoard compare the incoming\_data with outgoing\_data, so the answer of this two blanks is "inf.C\_in\_valid && !inf.C\_r\_wb" and "inf.AW\_ADDR"

```
// ----
// Using JasperGold Buid-In ScoreBoard IP
// to verify the data integrity for "AW_ADDR" address translation
// Just Fill in the blanks of port !

jasper_scoreboard_3 #(
    .CHUNK_WIDTH(32),
    .SINGLE_CLOCK(1),
    .ORDERING(`JS3_IN_ORDER),
    .MAX_PENDING(1)
)sc_addr_w_demo(
    .clk(SystemClock)
    ,.rstN(inf.rst_n)
    ,.incoming_vld()
    ,.incoming_data({1'b1,7'b0,inf.C_addr,2'b0})
    ,.outgoing_vld(inf.AW_VALID && inf.AW_READY)
    ,.outgoing_data()
);
```

- B. Customized Assertion (inf.C\_data\_w & W\_DATA)
  - ✓ Method1. Glue Logic + Assertion (used in Bonus\_formal\_verification\_ans)
  - ✓ Method2. Undetermined Constant

#### Suggestion:

Finish top.sv first (part A and part B), then use JasperGold to find four bugs in bridge.sv. You can find the bug using JasperGold, and try to debug by yourself.

If you cannot debug by yourself, please open the answer and use ctrl+F to find it.

#### **Note of Submission**

- 1. No need to submit Verilog files, but you need to submit the answer of Quick Test, which include the answer of this lab, before 2022/05/15 23:59
- 2. Naming Rule: QT\_iclabXXX.docx

# **Enjoy Bug Hunting!!!**



#### Step to run

- 1. Go to Directory
  - ~/Bonus\_formal\_verification/Exercise/02\_JG/
- 2. Finish top.sv
- 3. execute the command: source license.sh (Important!!!)
- 4. execute the command: ./run\_jg

JasperGold would automatically start reading files (01\_RTL/bridge.sv , 02\_JG/top.sv)



After running proof You could double click the read check to see the waveform which follow the property





If there is assertion violation in your design, open the waveform and try your best to analyze the root cause of this violation and debug it.

# **Basic Tutorial to view waveform**







### The figure of full proof of your assertion property



If the AXI-Lite Interface is already been proven, you could start debugging in the other scope such as scoreboards and or your customized SVA property in the top

The assertion property should not be violated, you could double click to check the waveform to see whether it match your property. You could scrutinize your assumption, assertion or glue logic to find the bugs with your SVA.

### **Development Log:**

Li-Wei, Liu @OASIS LAB ICLAB2019Fall
Kai-Jyun, Hung @OASIS LAB ICLAB2020Spring
Kai-Jyun, Hung @OASIS LAB ICLAB2020FALL
Lin-Hung, Lai @Si2 LAB ICLAB2021Spring
Wen-Yue, Lin @Si2 LAB. ICLAB2021Fall
Wen-Yue, Lin @Si2 LAB. ICLAB2022Spring