

2021

# PULPINO\_SPI\_MASTER\_ SUBSYSTEM\_VERIFICATIO N

USER GUIDE

|                                                         |           |
|---------------------------------------------------------|-----------|
| <b>Contents</b>                                         | <b>1</b>  |
| <b>List of Tables</b>                                   | <b>2</b>  |
| <b>List of Figures</b>                                  | <b>3</b>  |
| <b>Chapter 1</b>                                        | <b>5</b>  |
| Introduction                                            | 5         |
| 1.1 AXI4 master avip                                    | 5         |
| 1.2 SPI slave avip                                      | 6         |
| 1.3 AXI4 Interface                                      | 6         |
| 1.4 verif_compile.f file                                | 7         |
| 1.5 rtl_compile.f file                                  | 8         |
| <b>Chapter 2</b>                                        | <b>9</b>  |
| Architecture                                            | 9         |
| <b>Chapter 3</b>                                        | <b>11</b> |
| Steps to run Test Cases                                 | 11        |
| 3.1 Git steps                                           | 11        |
| 3.2 Mentor's Questasim                                  | 12        |
| 3.2.1 Compilation                                       | 12        |
| 3.2.2 Simulation                                        | 12        |
| 3.2.3 Regression                                        | 16        |
| 3.2.4 Coverage                                          | 17        |
| 3.3 Cadence                                             | 20        |
| 3.3.1 Compilation                                       | 21        |
| 3.3.2 Simulation                                        | 21        |
| 3.3.3 Coverage                                          | 24        |
| <b>Chapter 4</b>                                        | <b>27</b> |
| Debug Tips                                              | 27        |
| 4.1 AXI4 Debugging Flow                                 | 28        |
| 4.1.1 Check for Configuration Values                    | 28        |
| 4.1.1(a) Master agent configurations                    | 28        |
| 4.1.1(b) Slave agent configurations                     | 28        |
| 4.1.1(c) Environment configuration                      | 29        |
| 4.1.2 Check for transfer size                           | 30        |
| 4.1.3 Check for transaction values                      | 30        |
| 4.1.4 Check for master and slave converter data packets | 31        |
| 4.1.5 Check for data received from BFM                  | 32        |

|                                                |           |
|------------------------------------------------|-----------|
| 4.1.6 Check for data received from monitor BFM | 33        |
| 4.2 Scoreboard Checks                          | 34        |
| 4.3 Coverage Debug                             | 35        |
| 4.4 Waveform Viewer                            | 38        |
| <b>Chapter 5</b>                               | <b>40</b> |
| References                                     | 41        |

## List of Tables

| Table No  | Table Name                 | Page No |
|-----------|----------------------------|---------|
| Table 4.1 | master configurations      | 27      |
| Table 4.2 | slave configurations       | 28      |
| Table 4.3 | environment configurations | 29      |

## List of Figures

| Figure No | Name of the Figure                           | Page No |
|-----------|----------------------------------------------|---------|
| 1.1       | Simple AXI4 AVIP                             | 4       |
| 1.2       | Directories included in verif_compile.f file | 6       |

|      |                                                          |    |
|------|----------------------------------------------------------|----|
| 1.3  | Packages included in verif_compile.f file                | 6  |
| 1.4  | Static files included in verif_compile.f file            | 7  |
| 1.5  | Packages and Static files included in rtl_compile.f file | 7  |
| 1.5  | verif_compile.f used in makefile for questasim tool      | 7  |
| 1.6  | verif_compile.f used in makefile for cadence tool        | 8  |
| 2.1  | pulpino_spi_master_avip architecture                     | 11 |
| 3.1  | Usage of the make command                                |    |
| 3.2  | Questasim WLF window                                     |    |
| 3.3  | Screenshot of adding waves in wave window                |    |
| 3.4  | Wave window                                              |    |
| 3.5  | Screenshot of unlocking the wave window                  |    |
| 3.6  | Screenshot showing way to see the name of signals        |    |
| 3.7  | Files in questasim after the regression                  |    |
| 3.8  | Coverage Report                                          |    |
| 3.9  | Screenshot of opening covergroups                        |    |
| 3.10 | Screenshot of opening slave covergroup                   |    |
| 3.11 | Shows way to open slave covergroup coverage report       |    |
| 3.12 | Screenshot of coverpoints and cross coverpoints          |    |
| 3.13 | AWADDR_CP coverpoint report                              |    |
| 4.1  | Debugging flow                                           |    |
| 4.2  | Master_agent_config values                               |    |
| 4.3  | Slave_agent_config values                                |    |
| 4.4  | Env_config values                                        |    |
| 4.5  | Transfer size for mosi and miso                          |    |
| 4.6  | Master_tx values                                         |    |
| 4.7  | Slave_tx values                                          |    |

---

## PULPINO\_SPI\_MASTER\_SUBSYSTEM\_VERIFICATION

|      |                                                              |  |
|------|--------------------------------------------------------------|--|
| 4.8  | Converted data of master req                                 |  |
| 4.9  | Converted data of slave req                                  |  |
| 4.10 | Master bfm_struct data                                       |  |
| 4.11 | Slave bfm_struct data                                        |  |
| 4.12 | Master_driver_bfm values                                     |  |
| 4.13 | Slave_driver_bfm values                                      |  |
| 4.14 | Master_monitor values                                        |  |
| 4.15 | Slave_monitor values                                         |  |
| 4.16 | Scoreboard_checks                                            |  |
| 4.17 | Coverage for master                                          |  |
| 4.18 | Coverage for slave                                           |  |
| 4.19 | Master and slave coverage                                    |  |
| 4.20 | Instance of cover group                                      |  |
| 4.21 | Master_coverage coverpoint                                   |  |
| 4.22 | Master_coverage crosses coverpoints                          |  |
| 4.23 | Slave_coverage coverpoint                                    |  |
| 4.24 | Slave_coverage crosses coverpoints                           |  |
| 4.25 | Log file for assertion test                                  |  |
| 4.26 | Assertion errors                                             |  |
| 4.27 | Assertion property-1                                         |  |
| 4.28 | Assertion property-2                                         |  |
| 4.29 | Assertion pass waveform                                      |  |
| 4.30 | Waveform for 32 bit full duplex test with initial conditions |  |
| 4.31 | Waveform for 32 bit full duplex test with c2tdelay           |  |
| 4.32 | Wave form for 32 bit full duplex test with all the delays    |  |
| 4.33 | Wave form for 32bit data transfer(1st transaction)           |  |

## Chapter 1

# Introduction



**Fig: 1.1 Simple AXI4**

Master avip can communicate with the slave avip via AXI4 interface. Master avip and slave avip works on both simulator and emulator. To know more about avip, please go through the link : [SystemVerilog Testbench Acceleration | Acceleration](#)

### 1.1 Axi4 master avip

Axi4 master avip starts the test in the hvl top and starts the randomised sequences in base\_test and will pass the awaddr,awdata and awid to Axi4 master\_driver proxy using uvm sequencer and driver handshake. The Axi4 master driver bfm gets the awaddr,awdata and awid using inbound communication. The Axi4 master driver bfm sends the awaddr, awid and awdata an that is sampled in Axi4 master driver bfm and sends it back to the Axi4 master driver proxy. The Axi4 master monitor bfm samples the master\_tx and slave\_tx received from the Axi4 interface and sends it to the Axi4 master monitor proxy. The sampled data received by Axi4

master monitor bfm is sent to the Axi4 master scoreboard and Axi4 master coverage. Axi4 master scoreboard compares the driven data and sampled data. Axi master coverage is used to check the functional coverage of Axi4 master.

To know more about inbound and outbound communication, please go through this link :  
[Inbound and Outbound Communication](#)

## **1.2 SPI slave avip**

Spi slave avip starts the test in the hvl top and starts the randomised sequences in base\_test and will pass the miso\_data i.e., master\_in\_slave\_out to spi slave\_driver proxy using uvm sequencer and driver handshake. The spi slave driver bfm gets the miso\_data using inbound communication. The spi slave driver bfm sends the miso\_data that is sampled in spi slave driver bfm and sends it back to the spi slave driver proxy. The spi slave monitor bfm samples samples the mosi\_data and miso\_data received from the spi interface and sends it to the spi slave monitor proxy. The sampled data received by spi slave monitor bfm is sent to the spi slave scoreboard and spi slave coverage. Spi slave scoreboard compares the driven data and sampled data. Spi slave coverage is used to check the functional coverage of spi slave.

To know more about inbound and outbound communication, please go through this link :  
[Inbound and Outbound Communication](#)

## **1.3 AXI4 Interface and Spi Interface :**

APB and SPI interface has the following interface pin level signals :

1. Aclk
2. Aresetn
3. Awid
4. Awaddr
5. Awlen
6. Awsiz
7. Awburst
8. Awlock
9. Awcache
10. Awprot
11. Awqos
12. Awregion
13. Awuser
14. Awvalid
15. Awready
16. Wdata
17. Wstrb
18. Wlast

19. Wiser  
20. Valid  
21. Wready  
22. Bid  
23. Bresp  
24. Buser  
25. Valid  
26. bready  
27. sclk  
28. cs  
29. cs1  
30. cs2  
31. cs3  
32. mosi0  
33. mosi1  
34. mosi2  
35. mosi3  
36. miso0  
37. miso1  
38. miso2  
39. miso3

To know more about the spi interface signals, please go to section [3.1 Pin Interface](#).

## 1.4 verif\_compile.f file

This file contains the following things :

1. All the directories needed
  2. All the packages we needed
  3. All the modules written
  4. All the bfm interfaces written
  5. The Axi4 interface
  6. The SPI interface
- ❖ If you want to add any file in the project, please add the file or folder in the verif\_compile.f file to make it compiled.
  - ❖ If you want to add a class based component or object, you have to add that file in the respective package file and then make sure to mention the directory and path in the verif\_compile.f file.

- ❖ If you want to add a module/interface or any static component, then mention the file name along with the path of the file.
- ❖ How to add :
  1. To include directory: +incdir<path\_of\_the\_folder>
  2. To include file use file\_path/file\_name.extension
  3. / is used to force a new line
- ❖ Current verif\_compile.f file consists of all files directories and Packages mentioned in fig. 1.2, fig. 1.3 and fig. 1.4.

a. Directories included :

```
#+incdir+../../src/dv/globals/
+incdir+../../src/dv/hvl_top/test/sequences/master_sequences/
+incdir+../../src/dv/hvl_top/test/sequences/slave_sequences/
+incdir+../../src/dv/hvl_top/test/sequences/master_sequences/reg_sequences/
+incdir+../../src/dv/hvl_top/test/virtual_sequences/
+incdir+../../src/dv/hvl_top/axi4_master_agent/
+incdir+../../src/dv/hvl_top/spi_slave_agent/
+incdir+../../src/dv/hvl_top/env/virtual_sequencer/
+incdir+../../src/dv/hvl_top/env/
+incdir+../../src/dv/hvl_top/test/
+incdir+../../src/dv/systemRDL
+incdir+../../src/dv/systemRDL/output
```

**Fig: 1.2** Directories included in verif\_compile.f file

b. Packages included:

```
../../../../src/dv/globals/axi4_globals_pkg.sv
../../../../src/dv/globals/spi_globals_pkg.sv
../../../../src/dv/globals/pulpino_spi_master_subsystem_global_pkg.sv
../../../../src/dv/hvl_top/axi4_master_agent/axi4_master_pkg.sv
../../../../src/dv/hvl_top/spi_slave_agent/spi_slave_pkg.sv
../../../../src/dv/systemRDL/output/spi_master_defines_pkg.svh
../../../../src/dv/systemRDL/output/spi_master_uvm_pkg.sv
../../../../src/dv/hvl_top/test/sequences/master_sequences/reg_sequences/axi4_master_reg_seq_pkg.sv
../../../../src/dv/hvl_top/test/sequences/master_sequences/axi4_master_seq_pkg.sv
../../../../src/dv/hvl_top/test/sequences/slave_sequences/spi_slave_seq_pkg.sv
../../../../src/dv/hvl_top/env/env_pkg.sv
../../../../src/dv/hvl_top/test/virtual_sequences/pulpino_spi_master_subsystem_virtual_seq_pkg.sv
../../../../src/dv/hvl_top/test/pulpino_spi_master_subsystem_test_pkg.sv
```

**Fig: 1.3** Packages included in verif\_compile.f file

C Static files included :

```
../../../../src/dv/hdl_top/axi4_interface/axi4_if.sv  
../../../../src/dv/hdl_top/spi_interface/spi_if.sv  
../../../../src/dv/hdl_top/axi4_master_agent_bfm/axi4_master_agent_bfm.sv  
../../../../src/dv/hdl_top/axi4_master_agent_bfm/axi4_master_driver_bfm.sv  
../../../../src/dv/hdl_top/axi4_master_agent_bfm/axi4_master_monitor_bfm.sv  
../../../../src/dv/hdl_top/spi_slave_agent_bfm/spi_slave_agent_bfm.sv  
../../../../src/dv/hdl_top/spi_slave_agent_bfm/spi_slave_driver_bfm.sv  
../../../../src/dv/hdl_top/spi_slave_agent_bfm/spi_slave_monitor_bfm.sv  
../../../../src/dv/hdl_top/hdl_top.sv  
../../../../src/dv/hvl_top/hvl_top.sv
```

**Fig: 1.4** static files included in verif\_compile.f file

In Makefile, we include the verif\_compile.f file to compile all the files included.

Command used : *irun -f verif\_compile.f +UVM\_TEST\_NAME=<test\_name> +uvm\_verbosity=UVM\_HIGH.*

```
compile:  
    make clean_compile;  
    make clean_simulate;  
    vlib work;  
    vlog -sv \  
    +acc \  
    +cover \  
    +fcover \  
    -l compile.log \  
    -f ../../rtl_compile.f \  
    -f ../../verif_compile.f
```

**Fig: 1.5** verif\_compile.f used in makefile for questa\_sim tool

## Chapter 2

# Architecture

AXI4-SPI AVIP Testbench Architecture has divided into the two top modules as HVL and HDL top as shown in below fig 2



**Fig 2.1 pulpino\_spi\_master\_avip Architecture**

The whole idea of using Accelerated VIP is to push the synthesizable part of the testbench into the separate top module along with the interface and it is named as HDL TOP. and the unsynthesizable part is pushed into the HVL TOP it provides the ability to run the longer tests quickly. This particular testbench can be used for the simulation as well as the emulation based on mode of operation.

HVL TOP has the design which is untimed and the transactions flow from both master virtual sequence and slave virtual sequence onto the AXI4 I/F through the BFM Proxy and BFM and gets the data from monitor BFM and uses the data to do checks using scoreboard and coverage.

HDL TOP consists of the design part which is timed and synthesizable, Clock and reset signals are generated in the HDL TOP. Bus Functional Models (BFMs) i.e synthesizable part of drivers and monitors are present in HDL TOP, BFMs also have the back pointers to its proxy to call non - blocking methods which are defined in the proxy.

Tasks and functions within the drivers and monitors which are called by the driver and monitor proxy inside the HVL. This is how the data is transferred between the HVL TOP and HDL TOP.

HDL and HVL uses the transaction based communication to enable the information rich transactions and since clock is generated within the HDL TOP inside the emulator it allows the emulator to run at full speed.

## Chapter 3

# Steps to run Test Cases

### 3.1 Git steps

1. Checking for git, open the terminal type the command

*git version*

The output will either tell you which version of Git is installed or alert you that git is an unknown command. If it's an unknown command, install Git using following link  
[guide to install git in other platforms](#)

2. Copy the ssh public key and do the pulpino\_spi\_master\_ip\_verification.git clone of the repository in the terminal that is [pulpino\\_spi\\_master\\_subsystem\\_verification](#)  
*gitclone*

[git@github.com:mirafra-software-technologies/pulpino\\_spi\\_master\\_subsystem\\_verification.git](#)

3. After cloning, change the directory to the cloned repository

*cd pulpino\_spi\_master\_subsystem\_verification.git*

4. After cloning you will be in the main branch i.e, the production branch

*git branch*

5. Do the pull for the cloned repository to be in sync

*git pull origin main*

6. Fetch all branches in the pulpino\_spi\_master\_subsystem\_verification repository

*git fetch*

7. Check all branches present in the pulpino\_spi\_master\_subsystem\_verification repository

*git branch -a*

8. To switch from the main branch to another branch

*git checkout origin <branch\_name>*

9. Do the pull for the cloned repository to be in sync

*git pull origin <branch\_name>*

**Note:** To run any test case you should be inside the cloned directory i.e, pulpino\_spi\_master\_subsystem\_verification  
[pulpino\_spi\_master\_subsystem\_verification is considered as root path]

## 3.2 Mentor's Questasim

1. Change the directory to questasim directory where the makefile is present

Path for the mentioned directory is  
pulpino\_spi\_master\_subsystem\_verification/sim/questasim

Note: To Compile, simulate, regression and for coverage you must be in the specified path i.e, *pulpino\_spi\_master\_subsystem\_verification/sim/questasim*

2. To view the usage for running test cases, type the command

*make*

Fig 3.1 shows the usage to compile, simulate, and regression

```
----- Usage -----  
  
make target <options> <variable>=<value>  
  
To compile use:  
make compile  
  
To simulate individual test:  
make simulate test=<test_name> uvm_verbosity=<VERBOSITY_LEVEL>  
  
Example::  
make simulate test=base_test uvm_verbosity=UVM_HIGH  
  
To run regression:  
make regression testlist_name=<regression_testlist_name.list>
```

**Fig 3.1** Usage of the make command

### 3.2.1 Compilation

1. Use the following command to compile

*make compile*

2. Open the log file *compile.log* to view the compiled files  
*compile.log*

### 3.2.2 Simulation

- After compilation, use the following command to simulate individual test cases

*make simulate test=<test\_name> uvm\_verbosity=<VERBOSITY\_LEVEL>*

Example:

- To view the log file

*gvim <test\_name>/<test\_name>.log*

Ex: *basic\_write\_read\_reg\_test/basic\_write\_read\_reg\_test.log*

Note: The path for the log file will be displayed in the simulation report along with the name of the simulated test

- To view waveform

*vsim -view <test\_name>/waveform.wlf &*

Ex: *vsim -view basic\_write\_read\_reg\_test/waveform.wlf &*

Note: The command to view the waveform will be displayed in the simulation report along with the name of the simulated test

- As you run the above command, the new WLF Questasim window will appear as shown in fig 3.2



Fig 3.2 Questasim WLF window

- Right-click on intf and select Add Wave as shown in the image 3.3 to add the signals to the wave window



**Fig 3.2** Screenshot of adding waves in wave window

- After adding wave, click on Wave window as shown in the Fig 3.3



**Fig 3.3** Wave window

- Click as shown in the fig 3.4 to unlock the waveform window



**Fig 3.4** Screenshot of unlocking the wave window

8. You will be able to get a separate wave window as shown in the Fig 3.5



**Fig 3.5** Screenshot of unlocked wave window with signals

- Click on the icon signal toggle leaf name marked in fig 3.6 to see the signals as shown



**Fig 3.6** Screenshot showing way to see the name of signals

- For the analysis of waveform, go through the link below

[Waveform Viewer](#)

### 3.2.3 Regression

- To run regression for all test case

*make regression testlist\_name=<regression\_testlist\_name.list>*

Ex: *make regression testlist\_name=regression.list*

**Note: You can find all the test case names in the path given below**

*pulpino\_spi\_master\_subsystem\_verification/src/hvl\_top/testlists/regression.list*

- After regression, you can view the individual files as shown fig 3.7

*ls*

```
axi4_simple_reg_test_22032022-182024
basic_write_read_reg_test_22032022-182029
basic_write_reg_test_22032022-182035
```

**Fig 3.7** Files in questasim after the regression

- To view the log files of individual test, select the interested test case file, go inside that directory

Ex: Interested in the test case *basic\_write\_read\_reg\_test*

Go inside the directory of interested testcase with the date

*basic\_write\_reg\_test\_22032022-182035*

Inside this directory, you will be able to find the log file of the interested test case

*basic\_write\_read\_reg\_test.log*

Path:

*basic\_write\_read\_reg\_test\_22032022-182035 /basic\_write\_read\_reg\_test.log*

### 3.2.4 Coverage

1. To see coverage

- a. **After simulating**

For the individual test, use the command firefox

*firefox basic\_write\_read\_reg\_test/html\_cov\_report/index.html &*

Ex: *firefox basic\_write\_read\_reg\_test/html\_cov\_report/index.html &*

Note: The command to see the coverage will be displayed in the simulation report along with the name of the simulated test

- b. **After the regression,**

- To view the coverages of all test cases, type the below command

*firefox merged\_cov\_html\_report/index.html &*

Note: The command to see the coverage will be displayed in the simulation report along with the name of the simulated test

- To view the coverage for individual test case

See the list of files generated after regression, which is shown in fig 3.7.

Select the interested test case file, go inside that directory

Ex:

Interested in the test case *basic\_write\_read\_reg\_test*

Go inside the directory of interested testcase with the date

*ADD*

Inside this directory, you will be able to find the html coverage file of the interested test case

*html\_cov\_report/*

Inside it would be the html file

*covsummary.html*

Command to view coverage report for the above test case will be

*ADD*

2. The coverage report window appears as shown in fig 3.8



Fig 3.8 Coverage Report

3. Scroll down to the coverage summary by type and click on covergroups shown in fig 3.9.

The screenshot shows the "Coverage Summary by Type:" table from the previous figure. The "Covergroups" row has been highlighted with a red oval. The table contains the following data:

| Coverage Type   | Bins  | Hits | Misses | Weight | % Hit  | Coverage      |
|-----------------|-------|------|--------|--------|--------|---------------|
| Total Coverage: |       |      |        |        | 20.22% | <b>25.36%</b> |
| Covergroups     | 2052  | 71   | 1981   | 1      | 3.46%  | <b>13.76%</b> |
| Statements      | 4765  | 1977 | 2788   | 1      | 41.49% | <b>41.49%</b> |
| Branches        | 2800  | 601  | 2199   | 1      | 21.46% | <b>21.46%</b> |
| FEC Expressions | 78    | 22   | 56     | 1      | 28.20% | <b>28.20%</b> |
| FEC Conditions  | 133   | 28   | 105    | 1      | 21.05% | <b>21.05%</b> |
| Toggles         | 21427 | 3612 | 17815  | 1      | 16.85% | <b>16.85%</b> |
| FSMs            | 110   | 33   | 77     | 1      | 30.00% | <b>34.72%</b> |
| States          | 38    | 19   | 19     | 1      | 50.00% | <b>50.00%</b> |
| Transitions     | 72    | 14   | 58     | 1      | 19.44% | <b>19.44%</b> |

3.9 Screenshot of opening covergroups

4. After opening covergroup you will be able to see the summary.click on as shown in the fig 3.10 to slave covergroup

| Covergroups Coverage Summary:                                            |                                     |            |      |        |        |               |
|--------------------------------------------------------------------------|-------------------------------------|------------|------|--------|--------|---------------|
| Search: <input type="text"/>                                             |                                     |            |      |        |        |               |
| Covergroups/Instances                                                    | click on this to see slave coverage | Total Bins | Hits | Misses | Hits % | Goal %        |
| ① <a href="#">apb_slave_pkg/apb_slave_coverage::apb_slave_covergroup</a> |                                     | 2150       | 6    | 2144   | 0.27%  | 19.54% 19.54% |

3.10 Screenshot of opening slave covergroup

- If clicked on slave covergroup, further it opens to another window, again click on the slave covergroup as shown in fig 3.11

| Questa Covergroup Coverage Report                                                   |                         |            |      |        |        |               |
|-------------------------------------------------------------------------------------|-------------------------|------------|------|--------|--------|---------------|
| Search: cvg:apb_slave_covergroup                                                    |                         |            |      |        |        |               |
| Covergroups/Instances                                                               | click on slave coverage | Total Bins | Hits | Misses | Hits % | Goal %        |
| ① Covergroup <a href="#">apb_slave_covergroup</a>                                   |                         | 2150       | 6    | 2144   | 0.27%  | 19.54% 19.54% |
| ① Instance <a href="#">Vapb_slave_pkg::apb_slave_coverage::apb_slave_covergroup</a> |                         | 2150       | 6    | 2144   | 0.27%  | 19.54% 19.54% |

3.11 Shows way to open slave covergroup coverage report

- Further, you will be able to see coverpoints and crosses as shown in fig 3.12

Scope: [/apb\\_slave\\_pkg/apb\\_slave\\_coverage](#)

#### Covergroup type:

#### apb\_slave\_covergroup

| Summary                      | Total Bins | Hits | Hit %  |        |        |            |  |
|------------------------------|------------|------|--------|--------|--------|------------|--|
| Coverpoints                  | 102        | 5    | 4.90%  |        |        |            |  |
| Crosses                      | 2048       | 1    | 0.04%  |        |        |            |  |
| Search: <input type="text"/> |            |      |        |        |        |            |  |
| CoverPoints                  | Total Bins | Hits | Misses | Hit %  | Goal % | Coverage % |  |
| ① <a href="#">PADDR_CP</a>   | 32         | 1    | 31     | 3.12%  | 3.12%  | 3.12%      |  |
| ① <a href="#">PRDATA_CP</a>  | 32         | 1    | 31     | 3.12%  | 3.12%  | 3.12%      |  |
| ① <a href="#">PSELX_CP</a>   | 2          | 1    | 1      | 50.00% | 50.00% | 50.00%     |  |
| ① <a href="#">PSLVERR_CP</a> | 2          | 1    | 1      | 50.00% | 50.00% | 50.00%     |  |
| ① <a href="#">PWDATA_CP</a>  | 32         | 0    | 32     | 0.00%  | 0.00%  | 0.00%      |  |
| ① <a href="#">PWRITE_CP</a>  | 2          | 1    | 1      | 50.00% | 50.00% | 50.00%     |  |

Fig 3.12 Screenshot of Coverpoints and cross coverpoints

- Click on individual coverpoints and crosses to see the bins hit, here PADDR\_CP is individual coverpoint in fig 3.13

**Scope: /apb\_slave\_pkg/apb\_slave\_coverage**  
**Covergroup type: apb\_slave\_covergroup**

**Coverpoint: PADDR\_CP**

| Bin Name | At Least | Hits |
|----------|----------|------|
| addr[0]  | 1        | 5    |
| addr[1]  | 1        | 0    |
| addr[2]  | 1        | 0    |
| addr[3]  | 1        | 0    |
| addr[4]  | 1        | 0    |
| addr[5]  | 1        | 0    |
| addr[6]  | 1        | 0    |
| addr[7]  | 1        | 0    |
| addr[8]  | 1        | 0    |
| addr[9]  | 1        | 0    |
| addr[10] | 1        | 0    |

**Fig. 3.13** PADDR\_CP coverpoint report

- For the analysis of coverage report, click on the link [Coverage Debug](#)

### 3.3 Cadence

- Change the directory to questasim directory where the makefile is present

Path for the mentioned directory is APPB\_avip/sim/cadence\_sim

Note: To Compile, simulate, regression and for coverage you must be in the specified path i.e, *pulpino\_spi\_master\_subsystem\_verification/sim/cadence\_sim*

- To view the usage for running test cases, type the command

*make*

Fig 3. shows the usage to compile, simulate, and regression

```

----- Usage -----
make target <options> <variable>=<value>

To compile use:
make compile

To simulate use:
make simulate test=<test_name> uvm_verbosity=<VERBOSITY_LEVEL>

Example::
make simulate test=base_test uvm_verbosity=UVM_HIGH

```

Fig 3.14 Usage of make command in cadence

### 3.3.1 Compilation

1. Use the following command to compile  
*make compile*
2. Open the log file [compile.log](#) to view the compiled files  
*vim compile.log*

### 3.3.2 Simulation

1. After compilation, use the following command to simulate individual test cases

*make simulate test=<test\_name> uvm\_verbosity=<VERBOSITY\_LEVEL>*

Example:

**Note: You can find all the test case names in the path given below**

[\*pulpino\\_spi\\_master\\_subsystem\\_verification\\_compile/src/hvl\\_top/testlists/regression.list\*](#)

2. To view the log file  
*gvim <test\_name>/<test\_name>.log*

Ex: *basic\_write\_read\_reg\_test/basic\_write\_read\_reg\_test.log*

Note: The path for the log file will be displayed in the simulation report along with the name of the simulated test

```

----- Simulation Report -----
UVM Fatal
Number of demoted UVM_FATAL reports : 0
Number of caught UVM_FATAL reports : 0
UVM_FATAL : 0

UVM Errors
Number of demoted UVM_ERROR reports : 0
Number of caught UVM_ERROR reports : 0
UVM_ERROR : 0

UVM Warnings
Number of demoted UVM_WARNING reports: 0
Number of caught UVM_WARNING reports : 0
UVM_WARNING : 0

Testname: spi_simple_fd_8b_test
Log file path: spi_simple_fd_8b_test/spi_simple_fd_8b_test.log
Waveform: vsim -view spi_simple_fd_8b_test/waveform.wlf &

```

Fig 3.15 Simulation report in cadence

### 3. To view waveform

*simvision waves.shm/*

1. After running the simvision command , we will be able to see the waveform window as shown in the figure 3.16



Fig 3.16 Cadence waveform window

2. From the right side of the waveform window, right click on to the intf where all signals are present and select send to waveform window as shown in fig 3.17



Fig 3.17

3. All signals appears in the waveform window as shown in the fig 3.18



Fig 3.18

### 3.3.3 Coverage

1. To view coverage, type the imc command as below  
*imc -load cov\_work scope/test/ &*
  2. After running the imc command the window appears as shown in the fig 3.19



**Fig 3.19**

3. Click on the black arrow mark pointing to the uvm pkg as shown in the fig 3.20 later then click on arrow mark pointing to env\_h , then on master\_agent\_h then right click on master\_cov\_h and select



**Fig 3.20**

4. Covergroup analysis window appears as shown in the fig.3.21



5. Click on any of the covergroup to see the coverage percentage of that covergroup as shown in the fig 3.22



## Chapter 4

# Debug Tips

As design complexity continues to increase, which is contributing to new challenges in verification and debugging. Fortunately, new solutions and methodologies (such as UVM) have emerged to address growing design complexity. Yet, even with the productivity gains that can be achieved with the adoption of UVM, newer debugging challenges specifically related to UVM need to be addressed.

Here `basic_write_read_reg_test` has been used as an example test case in order to show the below debugging flow of the AXI4 protocol and all the info's have been runned using **UVM\_HIGH** verbosity

### 4.1 AXI4 Debugging Flow

Initially, open with a log file which is inside the test folder that has been run and then follow the below procedure in order to have a debug flow.



**Fig 4.1** Debugging flow

#### 4.1.1 Check for Configuration Values

At this stage, the user is trying to check for all the values related to master agent, slave agent and environment configurations which have been generated from the test.

For more information on Configurations please visit the following link:  
[Configuration Doc](#)

##### 4.1.1(a) Master agent configurations

Master agent configurations Includes

Table 4.1 master configurations

| Configurations | conditions for the configurations       |
|----------------|-----------------------------------------|
| No of Slaves   | which should not equal to zero          |
| has_coverage   | Which indicates the coverage connection |

```
UVM_INFO .../src/dv/hvl_top/test//base_test.sv(80) @ 0: uvm_test_top [basic_write_read_reg_test
axi4_master_agent_CONFIG
-----
Name          Type           Size  Value
-----
axi4_master_agent_config      axi4_master_agent_config -  @497
  is_active        string        10   UVM_ACTIVE
  has_coverage     integral       1    1
  wait_count_write_address_channel integral      32   'd0
  wait_count_write_data_channel   integral      32   'd0
  wait_count_read_address_channel integral      32   'd0
  outstanding_write_tx          integral      32   'd0
  outstanding_read_tx          integral      32   'd0
```

**Fig 4.2** master\_agent\_config values

Figure 4.2 shows the different config values that have been set in master agent config class

##### 4.1.1(b) Slave agent configurations

Slave agent configurations Includes

Table 4.2 slave configurations

| Configurations | conditions for the configurations                                                                                              |
|----------------|--------------------------------------------------------------------------------------------------------------------------------|
| spi_mode       | which is of enum type and it will indicate which type of configurations related to cpol and cpha the test running              |
| shift_dir      | which is of enum type and it tells about whether an MSB bit should start the transfer or an LSB bit should begin the transfer. |
| has_coverage   | Which indicates the coverage connection                                                                                        |
| Slave_id       | Tells which slave is selected                                                                                                  |

```
pulpino_spi_master_subsystem_SLAVE_CONFIG[0]
-----
Name          Type           Size  Value
-----
slave_agent_config[0] spi_slave_agent_config -    @502
  is_active      string        10   UVM_ACTIVE
  slave_id       integral     2    'd0
  spi_mode       string        11   CPOL0_CPHA1
  shift_dir      string        9    MSB_FIRST
  has_coverage   integral     1    1
  spi_type       string        10   SIMPLE_SPI
```

**Fig 4.3** slave\_agent\_config values

Figure 4.3 shows the different config values that has been set in slave agent config class

#### 4.1.1(c) Environment configuration

Environment configuration includes

Table 4.3 environment configurations

| Configurations   | conditions for the configurations                                                 |
|------------------|-----------------------------------------------------------------------------------|
| has_scoreboard   | which tells how many scoreboards are connected to env. Which has to be at least 1 |
| has_virtual_seqr | which tells how many virtual seqr are connected to env Which has to be at least 1 |
| No_of_slaves     | Tells how many slaves are connected Which shouldn't be 0                          |

| env_CONFIG       |            |      |       |  |
|------------------|------------|------|-------|--|
| Name             | Type       | Size | Value |  |
| env_cfg_h        | env_config | -    | @496  |  |
| has_scoreboard   | integral   | 1    | 1     |  |
| has_virtual_seqr | integral   | 1    | 1     |  |
| no_of_spi_slaves | integral   | 32   | 'd1   |  |

**Fig 4.4** env\_config values

Figure 4.4 shows the different config values that has been set in env config class

#### **4.1.2 Check for transfer size**

AXI4 follows one specific rule related to the transfer size of awdata and ardata.

The number of bits or bytes transferred by the awaddr to the write data bus size is one byte.

UVM\_INFO ../../src/dv/hvl\_top/spi\_slave\_agent//spi\_slave\_seq\_item\_converter.sv(47) @ 8280: reporter [spi\_slave\_seq\_item\_conv\_class] no\_of\_miso\_bits\_transfer = 32

**Fig 4.5** Transfer size for mosi and miso

Figure 4.5 shows the transfer size of Awdata or wdata.

#### **4.1.3 Check for transaction values**

Once the config values and size of the transfers are correct then check for the data to be transmitted from master tx class or from slave tx class

Initially check for the idle state of the transaction.(Ex: In this case pselx = 0 and penable = ). Once the present is high based on the pclk edge,when the pselx become high the data will sampled on the same clock edge.

```

# UVM_INFO ../../src/dv/hvl_top/axi4_master_agent//axi4_master_driver_proxy.sv(167) @ 530: uvm_test_top.env.axi4_master_agent.axi4_master_drv_proxy_h [axi4_master_driver_proxy] WRITE_TRANSACTION
SK:Before Sending req_write_packet =
# -----
# Name          Type      Size Value
# -----
# axi4_master_tx    axi4_master_tx -  @2329
# tx_type        string     5   WRITE
# awid           string     6   AWID_0
# awaddr         integral   32  'h1a10200c
# awlen           integral   8   'd0
# awsize          string    13  WRITE_4_BYTES
# awburst         string    10  WRITE_INCR
# awlock          string    19  WRITE_NORMAL_ACCESS
# awcache         string    16  WRITE_BUFFERABLE
# awprot          string    24  WRITE_NORMAL_SECURE_DATA
# awqos           integral   4   'h0
# wait_count_write_address_channel integral 32  'h0
# wdata[0]        integral   32  'fffffffff
# wait_count_write_data_channel    integral 32  'h0
# bid             string    5   BID_0
# bresp            string   10  WRITE_OKAY
# no_of_wait_states integral 32  'd0
# wait_count_write_response_channel integral 32  'h0
# transfer_type    string    14  BLOCKING_WRITE

```

**Fig 4.6 master\_tx values**

```

# UVM_INFO ../../src/dv/hvl_top/spi_slave_agent//spi_slave_driver_proxy.sv(140) @ 14060: uvm_test_top.env.spi_slave_agent_h[0].spi_slave_drv_proxy_h [spi_slave_driver_proxy] Received packet from spi_slave DRIVER BFM :
# -----
# Name          Type      Size Value
# -----
# spi_slave_tx    spi_slave_tx -  @2947
# master_in_slave_out[0] integral 8   'h17
# master_in_slave_out[1] integral 8   'h6
# master_in_slave_out[2] integral 8   'h20
# master_in_slave_out[3] integral 8   'hdf
# master_in_slave_out[4] integral 8   'h0
# master_in_slave_out[5] integral 8   'h0
# master_in_slave_out[6] integral 8   'h0
# master_in_slave_out[7] integral 8   'h0
# master_in_slave_out[8] integral 8   'h0
# master_out_slave_in[0] integral 8   'hf0
# master_out_slave_in[1] integral 8   'ha
# master_out_slave_in[2] integral 8   'hff
# master_out_slave_in[3] integral 8   'hff
# master_out_slave_in[4] integral 8   'h0
# master_out_slave_in[5] integral 8   'hff
# master_out_slave_in[6] integral 8   'hff
# master_out_slave_in[7] integral 8   'hf0
# master_out_slave_in[8] integral 8   'h1a
# -----

```

Activate Windows

**Fig 4.7 slave\_tx values**

Figure 4.6 and 4.7 shows the transaction data related to the master and slaves side.

#### 4.1.4 Check for master and slave converter data packets

In the master and slave converter class the data coming from the req will convert into struct packet in from class and once the data driving and sampling done the data can be revert back to req using to\_class method.

```

# UVM_INFO ../../src/dv/hvl_top/axi4_master_agent//axi4_master_seq_item_converter.sv(198) @ 1010: reporter [axi4_master_seq_item_conv_class] -----
# UVM_INFO ../../src/dv/hvl_top/axi4_master_agent//axi4_master_seq_item_converter.sv(204) @ 1010: reporter [axi4_master_seq_item_conv_class] After converting awid = 00000000000000000000
# UVM_INFO ../../src/dv/hvl_top/axi4_master_agent//axi4_master_seq_item_converter.sv(207) @ 1010: reporter [axi4_master_seq_item_conv_class] After converting awlen = 00000000
# UVM_INFO ../../src/dv/hvl_top/axi4_master_agent//axi4_master_seq_item_converter.sv(210) @ 1010: reporter [axi4_master_seq_item_conv_class] After randomizing awsize = 010
# UVM_INFO ../../src/dv/hvl_top/axi4_master_agent//axi4_master_seq_item_converter.sv(213) @ 1010: reporter [axi4_master_seq_item_conv_class] After converting awburst = 01
# UVM_INFO ../../src/dv/hvl_top/axi4_master_agent//axi4_master_seq_item_converter.sv(216) @ 1010: reporter [axi4_master_seq_item_conv_class] After converting awlock = 0
# UVM_INFO ../../src/dv/hvl_top/axi4_master_agent//axi4_master_seq_item_converter.sv(219) @ 1010: reporter [axi4_master_seq_item_conv_class] After randomizing awcache = 0000
# UVM_INFO ../../src/dv/hvl_top/axi4_master_agent//axi4_master_seq_item_converter.sv(222) @ 1010: reporter [axi4_master_seq_item_conv_class] After randomizing awprot = 000
# UVM_INFO ../../src/dv/hvl_top/axi4_master_agent//axi4_master_seq_item_converter.sv(225) @ 1010: reporter [axi4_master_seq_item_conv_class] After converting awaddr = 1a102018
# UVM_INFO ../../src/dv/hvl_top/axi4_master_agent//axi4_master_seq_item_converter.sv(228) @ 1010: reporter [axi4_master_seq_item_conv_class] After converting awqos = 0
# UVM_INFO ../../src/dv/hvl_top/axi4_master_agent//axi4_master_seq_item_converter.sv(231) @ 1010: reporter [axi4_master_seq_item_conv_class] After converting wait_count_write_address_channel = 1
# UVM_INFO ../../src/dv/hvl_top/axi4_master_agent//axi4_master_seq_item_converter.sv(236) @ 1010: reporter [axi4_master_seq_item_conv_class] After converting wdata[0] = fffff01a
# UVM_INFO ../../src/dv/hvl_top/axi4_master_agent//axi4_master_seq_item_converter.sv(243) @ 1010: reporter [axi4_master_seq_item_conv_class] After converting wstrb[0] = 0
# UVM_INFO ../../src/dv/hvl_top/axi4_master_agent//axi4_master_seq_item_converter.sv(248) @ 1010: reporter [axi4_master_seq_item_conv_class] After converting wlst = 0
# UVM_INFO ../../src/dv/hvl_top/axi4_master_agent//axi4_master_seq_item_converter.sv(251) @ 1010: reporter [axi4_master_seq_item_conv_class] After converting wuser = 0
# UVM_INFO ../../src/dv/hvl_top/axi4_master_agent//axi4_master_seq_item_converter.sv(254) @ 1010: reporter [axi4_master_seq_item_conv_class] After converting wait_count_write_data_channel = 0

```

## PULPINO\_SPI\_MASTER\_SUBSYSTEM\_VERIFICATION

**Fig 4.8** converted data of master req

```
# UVM_INFO ../../src/dv/hvl_top/spi_slave_agent/spi_slave_driver_proxy.sv(129) @ 1330: uvm_test_top.env.spi_slave_agent.h[0].spi_slave_drv_proxy_h [spi_slave_driver_proxy] Received packet from spi_slave sequencer : ,
# -----
# Name           Type      Size  Value
# -----
# req           spi_slave_tx -    @2550
# begin_time    time      64   1330
# depth         int       32   `d2
# parent sequence (name) string   24   spi_fd_basic_slave_seq_h
# parent sequence (full name) string  79   uvm_test_top.env.spi_slave_agent.h[0].spi_slave_seqr_h.spi_fd_basic_slave_seq_h
# sequencer      string   54   uvm_test_top.env.spi_slave_agent.h[0].spi_slave_seqr_h
# master_in_slave_out[0] integral 8    'hbC
# master_in_slave_out[1] integral 8    'h6B
# master_in_slave_out[2] integral 8    'h46
# master_in_slave_out[3] integral 8    'h86
```

**Fig 4.9** converted data of slave req

#### **4.1.5 Check for data received from BFM**

Once the data has been randomized and sent to master or slave BFM. The master driver BFM will drive awaddr, awvalid, awready, awdtata signals and samples the ardata, arvalid, arready depending on configurations of master and similarly slave driver BFM will drive the ardata, arvalid, arready signal and samples the awaddr, awvalid, awready ,awdata depending on configurations of slave.

The master driver BFM will print both the all the signals which has been driven by the master and sampled data master and similarly slave driver BFM will print all the signal which has been driven by the slave and sampled data. At the end both the master BFM and slave BFM data has to be the same.

**Fig 4.10** master bfm\_struct data

**Fig 4.11** slave bfm struct data

The fig 4.10 and 4.11 shows the data with respect to mosi and miso signals of both master and slave end before converting back to req using to class converter.

```

# UVM INFO ../../src/dv/hvl_top/axi4_master_agent//axi4_master_driver_proxy.sv(202) @ 8010: uvm_test_top.env.axi4_master_agent.axi4_master_drv_proxy_h [axi4_master_driver_proxy] WRITE_T
ASK:Response Received req_write_packet =
# -----
# Name          Type      Size  Value
# -----
# axi4_master_tx    axi4_master_tx  -  @2835
# tx_type        string     5   WRITE
# awid           string     6   AWID_0
# awaddr         integral   32  'h1102018
# awlen           integral   8   'd0
# awsize          string    13  WRITE_4_BYTES
# awburst         string    10  WRITE_INCR
# awlock          string    19  WRITE_NORMAL_ACCESS
# awcache         string    16  WRITE_BUFFERABLE
# awprot          string    24  WRITE_NORMAL_SECURE_DATA
# awqos           integral   4   'h0
# wait_count_write_address_channel integral 32  'h1
# wdata[0]        integral  32  'hfffff01a
# wstrb[0]        integral  4   'h0
# wait_count_write_data_channel   integral 32  'h0
# bid             string    5   BID_0
# bresp            string   10  WRITE_OKAY
# no_of_wait_states integral 32  'd0
# wait_count_write_response_channel integral 32  'h0
# transfer_type    string    14  BLOCKING_WRITE

```

**Fig 4.12 master\_driver\_bfm values**

```

# UVM INFO ../../src/dv/hvl_top/spi_slave_agent//spi_slave_driver_proxy.sv(140) @ 14060: uvm_test_top.env.spi_slave_agent_h[0].spi_slave_drv_proxy_h [spi_slave_driver_proxy] Received pa
cket from spi_slave DRIVER BFM : ,
# -----
# Name          Type      Size  Value
# -----
# spi_slave_tx    spi_slave_tx  -  @2947
# master_in_slave_out[0] integral 8   'h17
# master_in_slave_out[1] integral 8   'h6
# master_in_slave_out[2] integral 8   'h20
# master_in_slave_out[3] integral 8   'hdf
# master_in_slave_out[4] integral 8   'h0
# master_in_slave_out[5] integral 8   'h0
# master_in_slave_out[6] integral 8   'h0
# master_in_slave_out[7] integral 8   'h0
# master_in_slave_out[8] integral 8   'h0
# master_out_slave_in[0] integral 8   'hf0
# master_out_slave_in[1] integral 8   'ha
# master_out_slave_in[2] integral 8   'hff
# master_out_slave_in[3] integral 8   'hff
# master_out_slave_in[4] integral 8   'h0
# master_out_slave_in[5] integral 8   'hff
# master_out_slave_in[6] integral 8   'hff
# master_out_slave_in[7] integral 8   'hf0
# master_out_slave_in[8] integral 8   'h1a

```

**Fig 4.13 slave\_driver\_bfm values**

Fig 4.12 and 4.13 shows the mosi and miso values from master and slave bfm driver after converting back to req.

#### 4.1.6 Check for data received from monitor BFM

Once the data has been driven or sampled monitor will capture the data and it will print the driven and sampled data in the req form or transaction level

```
# UVM INFO ../../src/dv/hvl_top/axi4_master_agent//axi4_master_monitor_proxy.sv(191) @ 930: uvm_test_top.env.axi4_master_agent.axi4_master_mon_proxy_h [axi4_master_monitor_proxy] Packet received from axi4_write_data clone packet is
# -----
# Name          Type      Size Value
# -----
# axi4_master_tx    axi4_master_tx  -  @2446
# tx_type        string     5   WRITE
# awid           string     6   AWID_0
# awaddr         integral   32  'h1a102018
# awlen           integral   8   'd0
# awsize          string    13  WRITE_4_BYTES
# awburst         string    10  WRITE_INCR
# awlock          string    19  WRITE_NORMAL_ACCESS
# awcache         string    16  WRITE_BUFFERABLE
# awprot          string    24  WRITE_NORMAL_SECURE_DATA
# awqos           integral   4   'h0
# wait_count_write_address_channel integral 32  'h0
# wdata[0]        integral   32  'hfffff01a
# wstrb[0]        integral   4   'h0
# wait_count_write_data_channel    integral 32  'h0
# bid             string     5   BID_0
# bresp            string    10  WRITE_OKAY
# no_of_wait_states integral 32  'd0
# wait_count_write_response_channel integral 32  'h0
# transfer_type    string    14  BLOCKING_WRITE
```

Activate Windows

**Fig 4.14 master\_monitor values**

```
# UVM_INFO ../../src/dv/hvl_top/spi_slave_agent//spi_slave_monitor_proxy.sv(260) @ 7060: uvm_test_top.env.spi_slave_agent_h[0].spi_slave_mon_proxy_h [spi_slave_monitor_proxy] Received packet from spi_slave MONITOR BFM : ,
# -----
# Name          Type      Size Value
# -----
# spi_slave_tx    spi_slave_tx  -  @2566
# master_in_slave_out[0] integral 8   'hbc
# master_in_slave_out[1] integral 8   'h6b
# master_in_slave_out[2] integral 8   'h46
# master_in_slave_out[3] integral 8   'h80
# master_in_slave_out[4] integral 8   'h0
# master_in_slave_out[5] integral 8   'h0
# master_in_slave_out[6] integral 8   'h0
# master_in_slave_out[7] integral 8   'h0
# master_in_slave_out[8] integral 8   'h0
# master_out_slave_in[0] integral 8   'hf0
# master_out_slave_in[1] integral 8   'ha
# master_out_slave_in[2] integral 8   'hff
# master_out_slave_in[3] integral 8   'hff
# master_out_slave_in[4] integral 8   'h0
# master_out_slave_in[5] integral 8   'hff
# master_out_slave_in[6] integral 8   'hff
# master_out_slave_in[7] integral 8   'hf0
# master_out_slave_in[8] integral 8   'h1a
```

**Fig 4.15 slave\_monitor values**

## 4.2 Scoreboard Checks

And finally we have scoreboard checks which basically compares the awaddr,data\_width data of master with the slave side

```
# -----SCOREBOARD COMPARISONS-----
# UVM_INFO ../../src/dv/hvl_top/env//scoreboard.sv(131) @ 7060: uvm_test_top.env.scoreboard_h [scoreboard] axi4_awdata from axi4_master and master_out_slave.in from spi_slave is equal
# UVM_INFO ../../src/dv/hvl_top/env//scoreboard.sv(132) @ 7060: uvm_test_top.env.scoreboard_h [SB_axi4_DATA_MATCHED WITH MOSI0] Master axi4_DATA = 'hf00affff00fffff01a and Slave SPI_DATA = 'hf00affff00fffff01a
# UVM_INFO ../../src/dv/hvl_top/env//scoreboard.sv(144) @ 7060: uvm_test_top.env.scoreboard_h [scoreboard] Number of bits from axi4 packet and spi packet is equal
# UVM_INFO ../../src/dv/hvl_top/env//scoreboard.sv(145) @ 7060: uvm_test_top.env.scoreboard_h [NUMBER_OF_BITS_MATCHED] axi4_data_width=72,spi_data_width=72
# UVM_INFO ../../src/dv/hvl_top/env//scoreboard.sv(154) @ 7060: uvm_test_top.env.scoreboard_h [scoreboard] --
# -----END OF SCOREBOARD COMPARISONS-----
```

**Fig 4.16 scoreboard\_checks**

## 4.3 Coverage Debug

Coverage is a metric which basically tells how much percentage of verification has been done to the dut.

Go to the log file, Here it will get you the complete master and slave coverage for the particular test we are running.

```
UVM_INFO ../../src/dv/hvl_top/apb_master_agent//apb_master_coverage.sv(151) @ 10030: uvm_test_top.pulpino_spi_master_ip_env.apb_master_agent.apb_master_cov_h [apb_master_coverage] APB Master Agent Coverage = 29.34 %
```

Fig 4.17 coverage for master

```
UVM_INFO ../../src/dv/hvl_top/spi_slave_agent//spi_slave_coverage.sv(242) @ 10030: uvm_test_top.pulpino_spi_master_ip_env.spi_slave_agent_h[0].spi_slave_cov_h [spi_slave_coverage] spi_slave Agent Coverage = 9.38 %
```

Fig 4.18 coverage for slave

For individual bins checking goto the below html file  
firefox apb\_8b\_write\_test/html\_cov\_report/index.html &

Inside that check for covergroups in the coverage summary then check for the instance created for master and slave coverage

| Covergroups Coverage Summary:                                               |            |      |        |        |        |            |  |
|-----------------------------------------------------------------------------|------------|------|--------|--------|--------|------------|--|
| Covergroups/Instances                                                       | Total Bins | Hits | Misses | Hits % | Goal % | Coverage % |  |
| <a href="#">① /spi_master_uvm_pkg/spi_master_apb_if_status/cg_vals</a>      | 26         | 6    | 20     | 23.07% | 42.70% | 42.70%     |  |
| <a href="#">① /spi_master_uvm_pkg/spi_master_apb_if_clkdiv/cg_vals</a>      | 64         | 1    | 63     | 1.56%  | 1.56%  | 1.56%      |  |
| <a href="#">① /spi_master_uvm_pkg/spi_master_apb_if_spicmd/cg_vals</a>      | 64         | 1    | 63     | 1.56%  | 1.56%  | 1.56%      |  |
| <a href="#">① /spi_master_uvm_pkg/spi_master_apb_if_spiaadr/cg_vals</a>     | 64         | 1    | 63     | 1.56%  | 1.56%  | 1.56%      |  |
| <a href="#">① /spi_master_uvm_pkg/spi_master_apb_if_spilen/cg_vals</a>      | 192        | 3    | 189    | 1.56%  | 1.56%  | 1.56%      |  |
| <a href="#">① /spi_master_uvm_pkg/spi_master_apb_if_spidum/cg_vals</a>      | 128        | 2    | 126    | 1.56%  | 1.56%  | 1.56%      |  |
| <a href="#">① /spi_master_uvm_pkg/spi_master_apb_if_txfifo/cg_vals</a>      | 64         | 1    | 63     | 1.56%  | 1.56%  | 1.56%      |  |
| <a href="#">① /spi_master_uvm_pkg/spi_master_apb_if_rxfifo/cg_vals</a>      | 64         | 0    | 64     | 0.00%  | 0.00%  | 0.00%      |  |
| <a href="#">① /spi_master_uvm_pkg/spi_master_apb_if_intcfg/cg_vals</a>      | 132        | 6    | 126    | 4.54%  | 18.75% | 18.75%     |  |
| <a href="#">① /spi_master_uvm_pkg/spi_master_apb_if_coverage/ra_cov</a>     | 28         | 17   | 11     | 60.71% | 61.98% | 61.98%     |  |
| <a href="#">① /spi_slave_pkg/spi_slave_coverage/spi_slave_covergroup</a>    | 90         | 2    | 88     | 2.22%  | 9.37%  | 9.37%      |  |
| <a href="#">① /apb_master_pkg/apb_master_coverage/apb_master_covergroup</a> | 145        | 14   | 131    | 9.65%  | 29.34% | 29.34%     |  |

**Fig 4.19** master and slave coverage

| Questa Covergroup Coverage Report                                                       |            |      |        |        |        |            |
|-----------------------------------------------------------------------------------------|------------|------|--------|--------|--------|------------|
| Search: cvg:axi4_master_covergroup                                                      |            |      |        |        |        |            |
| Covergroups/Instances                                                                   | Total Bins | Hits | Misses | Hits % | Goal % | Coverage % |
| ① Covergroup <a href="#">axi4_master_covergroup</a>                                     | 1136       | 25   | 1111   | 2.20%  | 15.75% | 15.75%     |
| ① Instance <a href="#">Vaxi4_master_pkg::axi4_master::erage::axi4_master_covergroup</a> | 1136       | 25   | 1111   | 2.20%  | 15.75% | 15.75%     |

**Fig 4.20** instance of cover group

Then click on the master covergroup instance to check the individual bins which are hitted and missed. And here you can even check cross coverages between configuration modes, cs, delays, data widths, and baud rate.

| Search:                      |            |      |        |        |        |            |
|------------------------------|------------|------|--------|--------|--------|------------|
| CoverPoints                  | Total Bins | Hits | Misses | Hit %  | Goal % | Coverage % |
| ① <a href="#">ARBURST_CP</a> | 3          | 1    | 2      | 33.33% | 33.33% | 33.33%     |
| ① <a href="#">ARCACHE_CP</a> | 4          | 1    | 3      | 25.00% | 25.00% | 25.00%     |
| ① <a href="#">ARID_CP</a>    | 16         | 1    | 15     | 6.25%  | 6.25%  | 6.25%      |
| ① <a href="#">ARLEN_CP</a>   | 9          | 1    | 8      | 11.11% | 11.11% | 11.11%     |
| ① <a href="#">ARLOCK_CP</a>  | 2          | 1    | 1      | 50.00% | 50.00% | 50.00%     |
| ① <a href="#">ARPROT_CP</a>  | 8          | 1    | 7      | 12.50% | 12.50% | 12.50%     |
| ① <a href="#">ARSIZE_CP</a>  | 8          | 1    | 7      | 12.50% | 12.50% | 12.50%     |
| ① <a href="#">AWBURST_CP</a> | 3          | 1    | 2      | 33.33% | 33.33% | 33.33%     |
| ① <a href="#">AWCACHE_CP</a> | 4          | 1    | 3      | 25.00% | 25.00% | 25.00%     |
| ① <a href="#">AWID_CP</a>    | 16         | 1    | 15     | 6.25%  | 6.25%  | 6.25%      |
| ① <a href="#">AWLEN_CP</a>   | 9          | 1    | 8      | 11.11% | 11.11% | 11.11%     |
| ① <a href="#">AWLOCK_CP</a>  | 2          | 1    | 1      | 50.00% | 50.00% | 50.00%     |
| ① <a href="#">AWPROT_CP</a>  | 8          | 1    | 7      | 12.50% | 12.50% | 12.50%     |
| ① <a href="#">AWSIZE_CP</a>  | 8          | 1    | 7      | 12.50% | 12.50% | 12.50%     |

**Fig 4.21** master\_coverage coverpoint

Figure 4.21 shows all the coverpoints included in master coverage

| Search: <input type="text"/>                        |            |      |        |       |        |            |  |
|-----------------------------------------------------|------------|------|--------|-------|--------|------------|--|
| Crosses                                             | Total Bins | Hits | Misses | Hit % | Goal % | Coverage % |  |
| ① <a href="#">ARBURST_CP_X_ARLEN_CP_X_ARSIZE_CP</a> | 216        | 1    | 215    | 0.46% | 0.46%  | 0.46%      |  |
| ① <a href="#">ARLENGTH_CP_X_ARSIZE_X_ARBURST</a>    | 216        | 1    | 215    | 0.46% | 0.46%  | 0.46%      |  |
| ① <a href="#">AWBURST_CP_X_AWLEN_CP_X_AWSIZE_CP</a> | 216        | 1    | 215    | 0.46% | 0.46%  | 0.46%      |  |
| ① <a href="#">AWLENGTH_CP_X_AWSIZE_X_AWBURST</a>    | 216        | 1    | 215    | 0.46% | 0.46%  | 0.46%      |  |

**Fig 4.22** master\_coverage crosses coverpoints

Figure 4.22 shows all the cross coverpoints included in master coverage

If you click on the slave covergroup instance to check the individual bins which are hit and missed. And here you can even check cross coverages between configuration modes and shift directions and different data widths

| CoverPoints                             | Total Bins | Hits | Misses | Hit %  | Goal % | Coverage % |
|-----------------------------------------|------------|------|--------|--------|--------|------------|
| ① <a href="#">MISO_DATA_TRANSFER_CP</a> | 6          | 0    | 6      | 0.00%  | 0.00%  | 0.00%      |
| ① <a href="#">MOSI_DATA_TRANSFER_CP</a> | 6          | 0    | 6      | 0.00%  | 0.00%  | 0.00%      |
| ① <a href="#">OPERATION_MODE_CP</a>     | 4          | 1    | 3      | 25.00% | 25.00% | 25.00%     |
| ① <a href="#">SHIFT_DIRECTION_CP</a>    | 2          | 1    | 1      | 50.00% | 50.00% | 50.00%     |

**Fig 4.23** slave\_coverage coverpoint

Figure 4.23 shows all the coverpoints included in slave coverage

| Crosses                                                 | Total Bins | Hits | Misses | Hit % | Goal % | Coverage % |
|---------------------------------------------------------|------------|------|--------|-------|--------|------------|
| ① <a href="#">OPERATION_MODE_X_MASTER_IN_slave_OUT</a>  | 24         | 0    | 24     | 0.00% | 0.00%  | 0.00%      |
| ① <a href="#">OPERATION_MODE_X_MASTER_OUT_slave_IN</a>  | 24         | 0    | 24     | 0.00% | 0.00%  | 0.00%      |
| ① <a href="#">SHIFT_DIRECTION_X_MASTER_IN_slave_OUT</a> | 12         | 0    | 12     | 0.00% | 0.00%  | 0.00%      |
| ① <a href="#">SHIFT_DIRECTION_X_MASTER_OUT_slave_IN</a> | 12         | 0    | 12     | 0.00% | 0.00%  | 0.00%      |

**Fig 4.24** slave\_coverage crosses coverpoints

Figure 4.24 shows all the cross coverpoints included in slave coverage

## 4.4 Waveform Viewer



**Fig 4.30** wave form for 32 bit full duplex test with initial conditions

Figure 4.30 shows the waveform for 32 bit full duplex mode with all the required signals such as mosi0, miso0, sclk, chip select(cs), and reset.

1. In the waveform, initially check for the generation of the system clock(pclk), after every 10ns it will be toggled. Once the pclk is done check for the reset condition(Active low reset) if the reset is low the other signals such as sclk, mosi, miso and chip select should be in an unknown state.
2. Once the reset is high at the next posedge of pclk the cs and sclk should be in idle state.



**Fig 4.31** wave form for 32 bit full duplex test with c2t delay

3. After the idle state is completed, chip select will go low and sclk still remains as cpol. Since c2t delay is 1 and baud rate is 2 the sclk will generate after 2 clock cycles of pclk.
4. Once sclk generates, at every posedge of sclk mosi data will be driven onto the mosi signal which sends data to the slave mosi. And miso will be sampled at the negedge of the sclk.



**Fig 4.32** wave form for 32 bit full duplex test with all the delays

5. After completion of driving and sampling all the mosi and miso bits there should be a delay of 2 pclk between the sclk and next chip select(t2c delay = 1). Once the transaction completes chip select goes high for 2 clk cycles of pclk(wdelay = 1) then the next transaction will start.



**Fig 4.33** wave form for 32bit data transfer(1st transaction)

Fig 4.33 shows the waveform for whole 32 bit full duplex transfer with c2t delay and cpol\_0 and cpha\_0 configurations.



**Fig 4.34** wave form for 32bit data transfer (2nd transaction)

**Fig 4.34** shows the waveform for the 2nd transaction with a whole 32 bit full duplex transfer.

## Chapter 5

# References

<https://github.com/git-guides/install-git>