# NCTU-EE ICLAB - Autumn 2023

## **Lab10 Exercise: Coverage & Assertion**

### Verification: Tea House (From Lab09)

#### **Data Preparation**

1. Extract test data from TA's directory:

#### % tar xvf ~iclabTA01/Lab10.tar

2. The extracted LAB directory contains:

Exercise/

3. DO NOT paste the pseudo DRAM.sv from Lab09 to the Lab10.

#### **Description**

You need to write the verification pattern for the BEV from Lab09. You need to complete following things:

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

Generate pattern data.

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

You also need to check the correctness of the output signals of the design.

2. CHECKER.sv (Lab09/Exercise/00\_TESTBED/CHECKER.sv)

Write your cover groups and assertions here.

#### **Specifications**

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

- 1. Each case of **Beverage** Type should be select at least 100 times.
- 2. Each case of **Bererage Size** should be select at least 100 times.
- 3. Create a cross bin for the SPEC1 and SPEC2. Each combination should be selected <u>at least 100 times</u>. (Black Tea, Milk Tea, Extra Milk Tea, Green Tea, Green Milk Tea, Pineapple Juice, Super Pineapple Tea, Super Pineapple Tea) x (L, M, S)
- 4. Output signal inf.err\_msg should be "No\_Err", "No\_Exp", "No\_Ing" and "Ing\_OF", each at least 20 times. (Sample the value when inf.out valid is high)
- 5. Create the transitions bin for the inf.D.act[0] signal from [Make\_drink:Check\_Valid\_Date] to [Make\_drink:Check\_Valid\_Date]. Each transition should be hit at least 200 times. (sample the value at posedge clk iff inf.sel\_action\_valid)
- 6. Create a covergroup for material of supply action with auto\_bin\_max = 32, and each bin have to hit at least one time.

#### Notice:

- 1. When you send the pattern to the BEV.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 demo, TA will also use wrong design (4 cases) 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.
  - "./00\_run\_cov" for normal design
  - "./00 run cov FAIL X" for error answer design, e.g. "./00 run cov FAIL 1"
  - 4 Error Answer Cases, from FAIL\_1 to FAIL\_4
- 4. Under 01\_RTL, you can use bellowing commands to check your coverage result.
  - A. "00\_run\_cov" for running your design and generate the coverage related files.
  - B. "02\_cov\_detail" for generating the detail report (01\_RTL/Report/Coverage\_Detail.log) of your coverage result.
  - C. "03\_cov\_summary" for generating the brief report

    (01\_RTL/Report/Coverage\_Summary.log) of your coverage result. You should ensure both of CoverGroup Average/Covered to 100% coverage.

| . name  | CoverGroup Average | CoverGroup Covered |
|---------|--------------------|--------------------|
| Checker | 100.00%            | 100.00% (80/80)    |

- D. "imc &" for starting Cadence IMC (Incisive Metrics Center) in gui mode. (Please refer to appendix)
- E. "imc -batch" for starting Cadence IMC (Incisive Metrics Center) in batch (shell) mode.

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

- 1. All outputs signals (including BEV.sv and bridge.sv) should be zero after reset.
- 2. Latency should be less than 1000 cycles for each operation.
- 3. If action is completed (complete=1), err msg should be 2'b0 (no err).
- 4. Next input valid will be valid 1-4 cycles after previous input valid fall.
- 5. All input valid signals won't overlap with each other.
- 6. Out valid can only be high for exactly one cycle.
- 7. Next operation will be valid 1-4 cycles after out valid fall.

- 8. The input date from pattern should adhere to the real calendar. (ex: 2/29, 3/0, 4/31, 13/1 are illegal cases)
- 9. C\_in\_valid can only be high for one cycle and can't be pulled high again before C\_out\_valid

#### Notice:

- 1. You can't use PATTERN.sv to check the spec above.
- 2. 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 can directly copy the messages provided by TA in student.txt. For normal design, please use "01\_run"; For testing error design, use "01\_run SPEC\_X\_Y", please refer to the table in grading policy.
- 3. The definition of cycle and latency is the same as Lab09.

#### Note

#### 1. Grading Policy

- Coverage: 50%
- 10%: Pass each item of the command "./00 run cov" in the table below.
- 30%: 100% Coverage (requires passing the previous item).
- 10%: Simulation time of coverage (You need to pass all specs in coverage and assertion and will get the simulation time score.).
- Assertion: 50%
- Please refer to the table for each item's (./01 run) point (Total 10 items).

```
Congratulations!
You have passed all patterns!

Simulation complete via $finish(1) at time 3700 NS + 0
./PATTERN.v:242 $finish;
ncsim> exit
```

|              | Command                  | Print From | You should Print        | Points |
|--------------|--------------------------|------------|-------------------------|--------|
| ./00_run_cov | (None)                   | PATTERN.sv | Congratulations         | 2%     |
|              | FAIL_1~FAIL_4            | PATTERN.sv | Wrong Answer            | 8%     |
| ./01_run     | (None)                   | PATTERN.sv | Congratulations         | 6%     |
|              | SPEC_1_1 ~ SPEC_1_4      | CHECKER.sv | Assertion 1 is violated | 5%     |
|              | $SPEC_2_1 \sim SPEC_2_4$ | CHECKER.sv | Assertion 2 is violated | 5%     |
|              | $SPEC_3_1 \sim SPEC_3_2$ | CHECKER.sv | Assertion 3 is violated | 5%     |
|              | SPEC_4_1 ~ SPEC_4_4      | CHECKER.sv | Assertion 4 is violated | 5%     |
|              | SPEC_5_1 ~ SPEC_5_4      | CHECKER.sv | Assertion 5 is violated | 5%     |
|              | SPEC_6_1                 | CHECKER.sv | Assertion 6 is violated | 4%     |
|              | SPEC_7_1                 | CHECKER.sv | Assertion 7 is violated | 4%     |

| SPEC_8_1 ~ SPEC_8_6 | CHECKER.sv | Assertion 8 is violated | 6% |
|---------------------|------------|-------------------------|----|
| SPEC_9_1~ SPEC_9_2  | CHECKER.sv | Assertion 9 is violated | 5% |

(The info that need to print can be copied from 00\_TESTBED/message.txt)

The second demo will be 30% off.

- 2. 1st demo: 12/4 (MON) 12:00; 2nd demo: 12/6 (WED) 12:00
- 3. Please submit the following files by 09\_submit before 12:00 on 12/4:
  - PATTERN.sv
  - CHECKER.sv
  - dram.dat
  - Remember using dram.dat when you read your data in pattern. Or you will be failed at demo.
  - Usertype BEV.sv
- 4. Since the purpose of this Lab is to use SystemVerilog to do verification. You should generate pattern in the PATTERN.sv directly instead of using read file method.
- 5. Don't use any wire/reg/submodule/parameter name called \*error\*, \*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.

## **Using GUI Mode of Cadence IMC (Incisive Metrics Center)**

1. % ./00\_run\_cov



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



#### Panel



#### 4. Covergroup analysis



#### 5. Detail of items inside covergroup



#### 6. Check your source code

