# Wrapper Module Test Plan

# Hongkuan Yu

### Jan 2025

## Contents

| 1 | DUT                            | 2 |
|---|--------------------------------|---|
| 2 | Simulation Testbench (Dynamic) | 4 |
| 3 | Formal Verification (Static)   | 5 |
| 4 | UVM (1.1d)                     | 6 |

#### 1 DUT

This module is simple, so I include the SystemVerilog code of dut.sv below.

```
module dut(clk,
           rst_n,
           rxd,
           rx_dv,
           txd,
           tx_en);
    input clk;
    input rst_n;
    input[7:0] rxd;
    input rx_dv;
    output [7:0] txd;
    output tx_en;
    reg[7:0] txd;
    reg tx_en;
    always @(posedge clk) begin
       if(!rst_n) begin
          txd <= 8'b0;
          tx_en <= 1'b0;
       end
       else begin
          txd <= rxd;</pre>
          tx_en <= rx_dv;</pre>
       end
    end
endmodule
```

This dut.sv serves as a simple data wrapper. The I/O ports of dut.sv and their functions are shown in Table 1 below.

| input (wire) | $\operatorname{clk}$ | 1 bit  | Global clock               |
|--------------|----------------------|--------|----------------------------|
| input (wire) | $rst\_n$             | 1 bit  | Active-low reset           |
| input (wire) | $\operatorname{rxd}$ | 8 bits | Data received              |
| input (wire) | $rx_dv$              | 1 bit  | Valid for data received    |
| output (reg) | $\operatorname{txd}$ | 8 bits | Data transmitted           |
| output (reg) | $tx_en$              | 1 bit  | Valid for data transmitted |

Table 1: I/O ports of dut.sv and their functions

The module's I/O graphic overview is shown in Figure 1 below.



Figure 1: Wrapper Module's I/O Overview

#### 2 Simulation Testbench (Dynamic)

Create sim\_tb folder holding simulation testbench. Write a testbench dut\_tb.sv to verify the dut.sv dynamically by Synopsys VCS.

Create sim\_tb\_script folder for necessary scripts. Create filelist.f and Makefile containing normal simulation commands.

Create sim\_tb\_results folder for simulation testbench results. The results of the simulation testbench meet expectations: the output signals tx\_en and txd successfully get the correct value of rx\_dv and rxd after one clock period, separately. The result waveform is shown below in Figure 2 with decimal representation.



Figure 2: Simulation Testbench Result

### 3 Formal Verification (Static)

Create sva folder for formal verification. Write a formal property verification dut\_sva.sv to verify dut.sv statically.

Create sva\_script folder for necessary scripts. Create filelist.f and Makefile containing operation commands of formal verification tool.

Create sva\_results folder for formal verification results.

Since I currently do not have Synopsys VC Formal or Cadence JasperGold installed, I skipped this section, leaving unproved dut\_sva.sv and template Makefile for VCS only.

### 4 UVM (1.1d)

Create uvm folder holding all UVM components. The UVM components include (from top to bottom): a base test, environment, model, scoreboard, agent, sequencer, transaction, driver, and monitor. Two different test cases serve as two different sequences. An interface is included for portable design. top\_tb.sv connects them all.

Create uvm\_script folder for necessary scripts. Create filelist.f and Makefile containing UVM simulation commands.

Create uvm\_results folder for UVM results.

The structure of this UVM platform is shown in Figure 3 below. This platform does not contain the UVM register model.



Figure 3: Structure of UVM Platform

This platform's UVM tree is shown in Figure 4 below.



Figure 4: UVM Tree

The transaction mimics the bitstream of an ethernet connection by generating random MAC addresses and other related information. Test case 0 does not restrict the bitstream length. Test case 1 restricts the bitstream length to 60 bytes. Both test cases passed. Please refer to the .log file respectively in the uvm\_results folder.

# References