# UVM Framework JTAG Interface

By: Silicon Crew

## **Team members:**

Nayana T R Hemanth V

Mahadevaswamy B N Naveen V

Nancy dimri Sukeerthana B

Gopal Vamsi Radhika Joshi

Piyush Agrawal

## **Contents**

- UVM Framework
- YAML
- JTAG
- Problem Statement
- JTAG Agent/Interface code generator
- Generating the JTAG Agent/Interface Code

### **UVM Framework**

The UVM Framework is a reuse methodology that verification teams can leverage. It supports component level verification reuse across projects and environment reuse from block through chip to system level simulation.

#### **Features:-**

- UVM Code Generation.
- UVM JumpStart.
- UVM Reuse Methodology.

## YAML (YAML Ain't Markup Language.)

- YAML is a case-sensitive language. Indentations are to be taken care in Yaml.
- It generates more reusability. Reduces line of code.

• YAML configuration files are used as the inputs to the UVM Framework code generators and they

determine the content of the generated code

Data in YAML is generally defined by:

➤ Order list : Eg: clock: "clock"

Here, key is clock and value is "clock"

➤ Key value pair : Eg: - name: "TDO"

Here, the '-' symbol donates a list.

• Comments start with the number sign (#), can start anywhere on a line and continue until the end of the line.

```
interfaces:
  "jtag":
                                        COLLECTIONS
    clock: "clock"
    reset: "reset"
    ports:
      - name: "TDI"
         dir: "output"
         #type: "bit[1:0]"
                                             LIST
       - name: "TDO"
        dir: "input"
       - name: "TMS"
         dir: "output"
```

### **JTAG**

- Jtag stands for Joint Test Action Block.
- Advances in Silicon design need to increase device density; more recently, BGA packaging has reduced the efficiency of traditional testing methods.
- In order to overcome these problems JTAG protocol introduce.

### **Interface Signals**

- The JTAG interface, collectively known as a Test Access Port, or TAP, uses the following signals to support the operation of the boundary scan.
- TCK (Test Clock) this signal synchronises the internal state machine operations.
- TMS (Test Mode Select) this signal is sampled at the rising edge of TCK to determine the next state.

### **JTAG**

- **TDI** (Test Data In) this signal represents the data shifted into the device's test or programming logic. It is sampled at the rising edge of TCK when the internal state machine is in the correct state.
- **TDO** (Test Data Out) this signal represents the data shifted out of the device's test or programming logic and is valid on the falling edge of TCK when the internal state machine is in the correct state.
- **TRST** (Test Reset) This is an optional pin that, when available, can reset the TAP controller's state machine.



## **Problem statement**

Write a YAML file to generate the following interface diagram?



The below structure shows the structure for "jtag" interface. This is saved under directory name jtag\_yaml with the file name jtag\_interface.yaml

#### uvmf:

 Top level key, file being passed is in describes valid uvmf component

#### interfaces:

### "jtag":

- One or more interfaces can be described under interfaces, here "jtag" is the individual interface described.

```
uvmf:
  interfaces:
    "jtag":
```

```
clock: "clock"

reset: "reset"

reset_assertion_level: "True"
```

- Identifies the primary clock and primary reset to be used in the interface agent as "clock" and "reset" with active HIGH reset polarity.

```
clock: "clock"
reset: "reset"
reset assertion level: "True"
veloce ready: "True"
```

```
veloce_ready: "True"
```

- Default is True, if it is true the generated framework can be implemented on Veloce (Emulation tool)

### ports:

```
name: "tck"
width: "1"
dir: "output"
reset_value: "1'b0"
name: "tms"
width: "1"
dir: "output"
reset_value: "1'b0"
```

- The port list describes what goes as interface inputs; direction is defined from the test bench or interface perspective.

```
ports:
  - name: "tck"
   width: "1"
   dir: "output"
    reset value: "1'b0"
  - name: "tms"
   width: "1"
   dir: "output"
   reset value: "1'b0"
  - name: "tdi"
   width: "1"
   dir: "output"
    reset value: "1'b0"
  - name: "tdo"
   width: "1"
   dir: "input"
    reset value: "1'b0"
```

```
transaction_vars:
- name: "tck"
type: "bit"
isrand: "True"
iscompare: "True"
- name: "tms"
type: "bit"
isrand: "True"
iscompare: "True"
```

- Defines any variable to be used by the transaction class.
- Variables in the transaction class reflect the untimed information used during a transfer on the bus
- isrand specifies whether we can randomize or not
- iscompare specifies whether we can compare that variable or not

```
transaction vars:
  - name: "tck"
   type: "bit"
   isrand: "True"
   iscompare: "True"
 - name: "tms"
   type: "bit"
   isrand: "True"
   iscompare: "True"
 - name: "tdi"
   type: "bit"
   isrand: "True"
   iscompare: "True"
  - name: "tdo"
   type: "bit"
   isrand: "False"
   iscompare: "True"
```

```
config_vars:
     - name: "is_active"
      type: "bit"
      isrand: "False"
      value: "1"
     - name: "no_of_slaves"
      type: "bit [3:0]"
      value: "0"
     - name: "has_coverage"
      type: "bit"
      value: "1"
```

```
config vars:
  - name: "is active"
    type: "bit"
    isrand: "False"
    value: "1"
  - name: "no of slaves"
    type: "bit [3:0]"
    value: "0"
  - name: "has coverage"
    type: "bit"
    value: "1"
```

- Defines any variable to be used by the Config class.

• Command to generate the JTAG Interface code

python \$UVMF\_HOME/scripts/yaml2uvmf.py ./jtag\_yaml/jtag\_interface.yaml

```
python yaml2uvmf.py jtag_yaml/jtag_interface.yaml --dest_dir=Generated_code_JTAG
```

**\$UVMF\_HOME** is a path from the root directory to the present UVMF\_2022.3

```
setenv UVMF_HOME /hwetools/work_area/frontend/nayana/UVMF/UVM_Framework/UVMF_2022.3 echo $UVMF_HOME
```

> By default the generated code will be created under **uvmf\_template\_output** directory, but we can change the destination directory name using:

• using command:

```
yaml2uvmf.py <filename> --dest_dir=<dir_name>
```

```
python yaml2uvmf.py jtag_yaml/jtag_interface.yaml --dest_dir=Generated_code_JTAG
```

```
Generating /hwetools/work_area/frontend/nayana/UVMF/UVM_Framework/UVMF_2022.3/scripts/Generated_code_JTAG/verification_ip/interface_packages/jtag_pkg/jtag_filelist_hdl. f

Generating /hwetools/work_area/frontend/nayana/UVMF/UVM_Framework/UVMF_2022.3/scripts/Generated_code_JTAG/verification_ip/interface_packages/jtag_pkg/src/jtag_transacti
on_coverage.svh
Generating /hwetools/work_area/frontend/nayana/UVMF/UVM_Framework/UVMF_2022.3/scripts/Generated_code_JTAG/verification_ip/interface_packages/jtag_pkg/src/jtag_if.sv
Generating /hwetools/work_area/frontend/nayana/UVMF/UVM_Framework/UVMF_2022.3/scripts/Generated_code_JTAG/verification_ip/interface_packages/jtag_pkg/src/jtag_pkg.vinfo
Generating /hwetools/work_area/frontend/nayana/UVMF/UVM_Framework/UVMF_2022.3/scripts/Generated_code_JTAG/verification_ip/interface_packages/jtag_pkg/src/jtag_infact_co
verage_strategy.csv
Generating /hwetools/work_area/frontend/nayana/UVMF/UVM_Framework/UVMF_2022.3/scripts/Generated_code_JTAG/verification_ip/interface_packages/jtag_pkg/jtag_bfm.vinfo
```

All generated code for the **jtag** agent will be saved under the **Generated\_code\_JTAG/verification\_ip/interface\_packages/jtag\_pkg** directory

Inside jtag\_pkg directory

```
nayanarudramurthy@HweServer.scripts

[nayanarudramurthy@HweServer scripts]$ cd Generated_code_JTAG/verification_ip/interface_packages/jtag_pkg/

compile.do jtag.compile jtag_filelist_xrtl.f jtag_pkg_hdl.sv jtag_pkg_sve.F src/

jtag_bfm.vinfo jtag_filelist_hdl.f jtag_hdl.compile jtag_pkg_hdl.vinfo jtag_pkg.vinfo yaml/

jtag_common.compile jtag_filelist_hvl.f jtag_hvl.compile jtag_pkg.sv Makefile
```

> jtag\_filelist\_hdl.f

Compilation list of hdl files which includes the text files related to interface and the 2 BFMs.

> jtag\_filelist\_hvl.f

Compilation list of hdl files which includes the text files related to all other files.

> jtag\_pkg.sv

This is the verification package of HVL side that includes all the generated classes for our VIP agent (present id directory src).

### > compile.do

This file Contains the compile command for the generated agent. This file can be used on Windows or Linux.

#### Makefile

Contains the compile commands for the generated agent. This file can be used on Linux.

• Inside jtag\_pkg/src directory

```
nayanarudramurthy@HweServer:Generated_code_JTAG
[nayanarudramurthy@HweServer Generated_code_JTAG]$ cd verification_ip/interface_packages/jtag_pkg/src/
jtag2reg adapter.svh
                                   jtag if.sv
                                                                       jtag random sequence.svh
                                                                                                          jtag typedefs hdl.svh
                                   jtag_infact_coverage_strategy.csv jtag_responder_sequence.svh
jtag agent.svh
                                                                                                          jtag typedefs.svh
jtag configuration.svh
                                                                       jtag sequence base.svh
                                   jtag macros.svh
jtag driver bfm.sv
                                   jtag monitor bfm.sv
                                                                       jtag transaction coverage.svh
                                                                       jtag transaction.svh
jtag driver.svh
                                   jtag monitor.svh
```

jtag\_reg\_adaptor.svh

This file includes template adaptor for UVM register layer. User has to fill their own functionality into this file.

> jtag\_agent.svh

Agent class code in uvm.

> jtag\_configuration.svh

This is agent configuration class.

> jtag\_driver.svh

Driver class to be instantiated in the agent.

> jtag\_driver\_bfm.svh

This file has bus functional model to convert transactions to protocol pin wiggles. User has to fill their own functionality into this file.

> jtag\_if.sv

This file contains the signal interface for the agent. User can optionally add protocol assertions in here.

> jtag\_macros.sv

Defines structs type packets and configuration variables which are used to pass data between classes, HVL, BFMs and HDL.

jtag\_monitor.sv

Monitor class to be instantiated in the agent.

### jtag\_monitor\_bfm.sv

This file has bus functional model to convert the protocol pin wiggles to transactions. User has to fill their own functionality into this file.

> jtag\_random\_sequence.svh

This file contains Start sequence. Randomizes the transaction class fields and transfers it to sequencer. This is Extended from jtag\_sequence\_base

> jtag\_responder\_sequence.svh

This sequence class can be used to generate stimulus when an interface has been configured to run. User has to fill their own functionality into this file.

> jtag\_sequence\_base.svh

This is a Base class with useful methods that all inherited sequences has the permission to utilize it.

### > jtag\_transaction.svh

This is the sequence\_item class that we will use in our sequences. Extends from 'uvmf\_transaction\_base.svh' which contains global "id" which holds a unique number for every transaction. Also contains several methods for printing, comparing, etc

### > jtag\_transaction\_coverage.svh

This class records jtag transaction information using a covergroup named jtag\_transaction\_coverage.

## > jtag\_typedefs.svh

This file contains the defined typedefs which are used in the testbench (HVL) side of the testbench. Package may not contain any defines or typedefs after but will still be generated.

### jtag\_typedefs\_hdl.svh

This file contains the defined typedefs used by the interface package performing transaction level simulation activities. This package is used by the driver/monitor BFMs.