# NCTU-EE IC LAB - Spring 2023

# **Lab10 Exercise**

## Verification: OS (From Lab09) Coverage

#### **Data Preparation**

1. Extract test data from TA's directory:

% tar xvf ~iclabta01/Lab10.tar

- 2. The extracted LAB directory contains:
  - a. Exercise/

#### **Description**

you need to write the verification pattern for the OS(from Lab9). You need to complete following things:

1. PATTERN.sv (Lab10/ Exercise /00\_TESTBED/PATTERN.sv)

Generate pattern data.

Send pattern data to OS.sv and bridge.sv and make sure that it will achieve coverage goals.

You also need to do the reset first.

2. CHECKER.sv (Lab10/ Exercise /00\_TESTBED/CHECKER.sv) Write your cover groups and assertions here.

#### **Specifications**

#### Coverage: (TA's DESIGN + TA's CHECKER + Your PATTERN)

- 1. Create a covergroup including coverpoint inf.D.d \_money (means 0~15 bits of input signal D when typing your money amount). There are five bins which range 16'd0~16'd12000, 16'd12001~16'd24000, 16'd24001~16'd36000, 16'd36001~16'd48000, 16'd48001~16'd60000, respectively. Each bin should be hit at least 10 time. (sample the value at posedge clk when amnt\_valid is high)
- 2. Create a covergroup including coverpoint inf.D.d\_id[0] (means 0~7 bits of input signal D when typing your ID) with auto\_bin\_max = 256. (means that you need to divide the inf.D.d\_id[0] signal into 256 bins averagely). And each bin has to be hit at least 2 time. (sample the value at posedge clk when id\_valid is high)
- 3. Create a covergroup including coverpoint inf.D.d\_act[0] (means 0~3 bits of input signal D when typing your action). There are four actions for inf.D.d\_act[0]: buy, check, deposit, return. Create the transition bins from one action to itself or others. such as: buy to check, buy to deposit, buy to return and so on. There are total 16 transition bins. Each transition bin should be hit at least 10 times. (sample the value at posedge clk when act valid is high).

- 4. Create a covergroup including coverpoint inf.D.d\_item[0](Large \( \) Medium \( \) Small). Each of these three bins needs at least 20 times. (sample the value at posedge clk when item valid is high)
- 5. Create a covergroup including coverpoint inf.err\_msg. Every case of inf.err\_msg except No\_Err should occur at least 20 times. (sample the value at negedge clk when inf.out\_valid is high)
- 6. Create a covergroup including coverpoints inf.complete. The bins of inf.complete need to be 0 and 1, and each bin should be hit at least 200 times. (sample the value at negedge clk when inf.out\_valid is high)

#### Notice:

- 1. When you send the pattern and dram to the OS.sv, you need to follow the specs from the Lab09. For example, all input valid signals won't overlap with each other. You can write some assertions in your CHECKER.sv to check. If you violate the specs and your assertions didn't discover but TA discover during demo, you will fail.
- 2. After passing the last pattern, your PATTERN should finish immediately. (Still remember not to violate any specs.)
- 3. During the demo, TA will also use wrong design to test if your pattern can check the correctness of the output signals of the design. When the answer is wrong, you should stop the program immediately and display "Wrong Answer" on the terminal.
- 4. Do not print anything else except from "Wrong Answer" when the answer is wrong, or you will fail this lab.

#### Assertion: (TA's DESIGN + TA's PATTERN+ Your CHECKER)

#### \*You should hand in the code of this part.

- 1. All outputs signals (including OS.sv and bridge.sv) should be zero after reset.
- 2. If action is completed, err msg must be 4'b0.
- 3. If action is not completed, out info should be 32'b0.
- 4. All input valid can only be high for exactly one cycle.
- 5. The gap between each input valid is at least 1 cycle and at most 5 cycles(including the correct input sequence).
- 6. The five valid signals won't overlap with each other.( id\_valid, act\_valid, amnt\_valid, item\_valid, num\_valid)
- 7. Out valid will be high for one cycle.
- 8. Next operation will be valid 2-10 cycles after out valid fall.

9. Latency should be less than 10000 cycle for each operation.

Notice that once the spec is violated, you should stop the program immediately and show the assertion message on the terminal. Your assertion warning messages should be "Assertion X is violated", where X is the number of assertions. You must directly copy the messages provided by TA in student.txt, or you will fail this lab. The definition of cycle and latency is the same as Lab09.

#### Note

#### 1. Grading Policy

- Pattern + Coverage + Assertion: 70%
- Simulation time of coverage: 30%

```
Congratulations!
You have passed all patterns!
Simulation complete via $finish(1) at time 3700 NS + 0
./PATTERN.v:242 $finish;
ncsim> exit
```

You need to pass all specs and will get the simulation time score.

The second demo will be 30% off.

### 2. Please upload the following file in Lab10/EXERCISE/09\_SUBMIT

- PATTERN.sv
- CHECKER.sv
- dram.dat (Your dram.dat must follow the spec in Lab09.)
- Usertype OS.sv
- No need to submit clk period, we will use 1ns as period when demoing.
- ./01\_submit
- 3. Deadlines:
  - 1st deadline: 2022/05/08(Mon.) 12:00:00
  - 2nd deadline: 2022/05/10(Wed.) 12:00:00
- 4. Since the purpose of this Lab is to use SystemVerilog to do verification. You should generate a pattern in the PATTERN.sv directly instead of using the read file method.
- 5. Don't use any wire/reg/submodule/parameter name called \*error\*, \*congratulation\*, \*latch\* or \*fail\* otherwise you will fail the lab. Note: \* means any char in front of or behind the word. e.g: error note is forbidden.
- 6. Please do not display any other information on the CHECKER.sv and PATTERN.sv except for the information written in the student.txt.

#### **Using Cadence IMC (Incisive Metrics Center)**

1. % irun TESTBED.sv -define RTL -debug -coverage U -covoverwrite (./02 run cov)



- 2. % imc &
- 3. Load the coverage database (default path: /01\_RTL/cov\_work/scope/test)





#### 4. Covergroup analysis



5. Detail of items inside covergroup



# 6. Check your source code

