# ECE 748

#### Advanced Verification with UVM



### Class Projects – LC3

#### Project 1

 Create UVM interface package for decode input

#### Project 2

- Create a UVM environment and test bench for the decode block
- Create a UVM interface package for decode output

#### • Project 3

 Create a UVM environment and test bench for LC3 that includes the decode environment





### Project 1 – Decode\_in Interface

- Project 1
  - Create UVM interface package for decode input interface





### Project 1 – Decode\_in Interface

- From the LC3 Specification you will need to identify
  - Signals used
  - Protocol signaling
  - Transaction variables
  - Type-definitions
  - Parameters
  - Functional coverage

```
2 ▼ module Decode(/* System */ clock, reset,
                   /* decode in */ enable decode, dout, npc in,
                   /* decode out */ E_Control, Mem_Control, W_Control, IR, npc_out);
                          clock, reset, enable_decode;
 6
        input
        input [15:0]
                          dout;
        input [15:0]
                          npc_in;
        output [1:0]
                          W_Control;
10
        output
                          Mem_Control;
                                                clock
11
        output [5:0]
                          E Control;
12
        output [15:0]
                          IR:
                                             npc_in
        output [15:0]
                          npc out;
                                                                       E control
                                          enable decod
                                                                        npc_out
                                                         Decode
```

Instr dout

| Instruction | 15 |   |   | 12 | 11 9 | 8 6 | 5 | 4    | 3 |     | 0 |
|-------------|----|---|---|----|------|-----|---|------|---|-----|---|
| ADD         | 0  | 0 | 0 | 1  | DR   | SR1 | 0 | 0    | 0 | SR2 |   |
|             | 0  | 0 | 0 | 1  | DR   | SR1 | 1 | imm5 |   |     |   |
| AND         | 0  | 1 | 0 | 1  | DR   | SR1 | 0 | 0    | 0 | SR2 |   |
|             | 0  | 1 | 0 | 1  | DR   | SR1 | 1 | imm5 |   |     |   |
| NOT         | 1  | 0 | 0 | 1  | DR   | SR1 | 1 | 1    | 1 | 1 1 | 1 |



Mem Control

W\_Control

## Project 1 – Decode\_in waveforms





#### Decode Test Bench

hdl\_top

decode\_in\_if

decode\_in\_monitor\_bfm

decode\_in\_driver\_bfm

hvl\_top

decode\_in\_configuration

decode\_in\_agent

decode\_in\_random\_sequence 50x



#### Project 1 – Directory Structure

- Interface package location/name
  - verification ip/interface packages/decode in pkg
- Test package location/name
  - project\_benches/decode/tb/tests/decode\_test\_pkg
- Top level modules location/name
  - project\_benches/decode/tb/testbench/hdl\_top.sv and hvl\_top.sv
- Decode RTL location
  - project\_benches/decode/rtl
  - Decode RTL will be provided on Moodle
- Run simulation in
  - project\_benches/decode/sim
- Run simulation command: make p1\_debug
  - Create makefile using qrun command based on sequence\_sequencer\_driver example makefile



#### Project 1 – Decode\_in Requirements

- Lecture material and examples to be used as basis for completing decode\_in interface package
- Instantiate decode\_in agent, agent configuration, and decode random sequence in uvm\_test extension named test\_top
- Import decode\_test\_pkg in hvl\_top module
- Run random sequence 50 times to generate 50 random instructions



### Project 1 – Decode\_in Requirements cont'd

- Stimulus flow as shown in lecture material
- Emulatable stimulus and analysis flow as shown in lecture material
- Transaction viewing in the wave window
- Package structure as shown in ECE745 lectures
- Agent and BFM hierarchy as shown in lectures
- Agent configuration containing BFM handles
- Agent configuration retrieves BFM handles using uvm\_config\_db
- Agent retrieves its configuration using uvm\_config\_db
- Stimulus flow including sequence item, sequence base and random sequence
- Transaction coverage within agent
- Covergroup for coverage of ISA Bits 15:12 only to show 50 valid instructions
  - At least one of each valid operation, bits 15:12, must be generated. Invalid operations shall not be generated.
- Convert2string method in transaction and configuration classes



### Project 1 – Decode\_in Submission

- Deposit all source in Moodle on due date
  - Parent directory name: <unityId>\_p1
    - Contains project\_benches sub-directory
    - Contains verification\_ip sub-directory
  - Be sure to remove compiled libraries from sim directory
  - Compress the project into a single file for submission
    - File name: <unityId>\_p1.zip







