

## Design and Verification of Functional Blocks of 32-Bit Microprocessor

## Asha G<sup>1</sup>, Dr. Jamuna S<sup>2</sup>

<sup>1</sup>PG Student (M.Tech in VLSI Design & Embedded Systems), Dept. of ECE, DSCE, Bengaluru, Karnataka <sup>2</sup>Professor, Dept. of ECE, DSCE, Bengaluru, Karnataka \*\*\*

**Abstract** - The core component of an electronic system is a processor. Processors are primarily evaluated solely by their performance, speed, and Instruction Set Architecture (ISA). RISC-V is a selected architecture for the design. RISC-V is an open standard instruction set architecture designed to be scalable for a wide range of applications. Pipelining is a standard feature in RISC-V processors. The technique where multiple instructions are overlapped during execution is known as Pipelining. Therefore, pipelining reduces the latency and improves the overall throughput of the processor.

The intended work consists of the design of functional blocks of 32-bit RISC-V processor such as I-Cache, Instruction Issuing Unit, INT ALU, D-Cache and Integer Register File. These functional blocks are designed using Verilog HDL and testbench codes are written for them. For D-cache and Integer reg file, the functional verification is performed with the help of Universal Verification Methodology (UVM). The reusable UVM testbench architecture is built to check the functional correctness of these blocks. Code coverage is performed on the functional blocks designed.

Key Words: RISC-V ISA (Instruction Set Architecture), Pipelining, I-Cache, Instruction Issuing Unit, INT ALU, D-Cache, Integer Register File, Verilog HDL, Universal Verification Methodology (UVM).

## **1.INTRODUCTION**

Processors are primarily evaluated solely by their performance, speed, and Instruction Set Architecture (ISA) [1]. RISC-V is a standard free architecture and is designed to be scalable for a wide variety of applications. RISC-V is suitable for use in some specific application fields such as storage, edge computing, and AI applications. Pipelining is a standard feature in RISC-V processors. It is the process of accumulating instructions from the processor through a pipeline. It allows storing and executing instructions in an orderly process. Pipelining increases the overall instruction throughput.

The intended work consists of the design and verification of functional blocks of 32-bit RISC-V processor such as I-Cache, Instruction Issuing Unit, INT ALU, D-Cache and Integer Register File. These functional blocks are designed using Verilog HDL and are simulated & synthesized using Xilinx Vivado. For D-Cache and Integer Register File UVM testbench has been built to check the functional correctness. Code coverage is performed on the functional blocks designed. Organization of the paper is as follows. Section 2 provides brief about related work. Section 3 describes the RISC-V processor architecture in brief. Section 4 discusses the design of functional blocks. Section 5 briefs about verification of functional blocks. In section 6 simulation results have been discussed, followed by conclusion in Section 7.

## **2. RELATED WORK**

The five- stage pipelined RISC-V processor architecture is presented in [1]. The working of pipelined architecture is explained in this paper. Many sub blocks are included in the processor's design. Design of all the sub blocks is explained in detail along with the block diagrams. The designed processor is implemented on Vertex-7 FPGA board. The maximum frequency attained is 40Mhz.

[2] In this paper authors have discussed about a new processor for a SOC. The processor is based on RISC-V Instruction Set Architecture. Verification is performed at module and integration level. The pipeline is verified for varying configurations of instructions to ensure that all corner situations are covered. The processor is built on a Virtex-7 FPGA, and the results are illustrated in terms of frequency and area.

A 16-bit RISC processor is designed in [3]. The design is done using the Verilog HDL. The processor includes the sub blocks, such as, ALU, data memory unit, controller, and register files. Xilinx ISE tool is used to analyse the design.

Design of ALU which performs addition, subtraction, multiplication, code conversion, and shifting operations is presented in [7]. Different operations are selected using multiplexer based on the select lines or control inputs. The design is developed using the Hardware Description Language (HDL). Structural and behavioural modelling are used in designing the ALU. Results of the ALU are compared with MIPS processor, which has shown reduction in power dissipation. Simulation and synthesis of each block in the design is carried using Xilinx ISE to analyse the results.

A study of UVM's characteristics is offered in [8], [9]. These papers outline the benefits, drawbacks, and prospects. To compare conventional verification with UVM-based verification, a SoC test case is provided. An overview of how to use the UVM verification methodology to create a reusable RTL verification environment is provided and also the usage of UVM in the creation of a testbench using synchronous FIFO as a subsystem undergoing evaluation is examined.

#### **3. PROCESSOR ARCHITECTURE**



Fig -1: RISC-V Pipelined Architecture [1]

A five- stage superscalar pipeline architecture is shown in Fig-1. The five stages are: Instruction Fetch (IF), Instruction Decode (ID), Execute (EX), Memory (MEM), and Write-back (WB).

The first stage is Instruction Fetch (IF), which generates the program memory address using the Program Counter (PC). Using the pc value, two consecutive instructions are obtained from the Instruction Cache and transmitted to the Instruction Decode (ID) stage. The ID stage includes an Instruction Issuing Unit, which sends one or two instructions to the pipeline depending on the dependencies between instructions. The instruction is decrypted in the decode stage, and select signals are created for the multiplexers in the EX-stage for data transmission. The ID stage provides the operands for the Execute-stage. There are three units in the Execute-stage that may execute at most two instructions in the same clock cycle; two of the three units are integer ALUs and one is a floating-point unit. Forwarding lines toggle the multiplexers, allowing either forwarded data or data from register/memory to be used in the Execute stage. The Execute-stage results are passed to the Memory stage, which performs data transactions for load, store, or atomic instructions. In other circumstances, the Execute-stage results are transferred to the Write-Back stage. In the Write-Back stage, distinct register files are implemented for integer and floating-point instructions.

#### **4. DESIGN OF FUNCTIONAL BLOCKS**

In this section the design of different functional blocks such as, I-Cache & Instruction Issuing Unit, INT ALU, D-Cache and Integer Register File are discussed. The design of all these blocks is done by using Verilog HDL.

#### 1) I-Cache & Instruction Issuing Unit

Main memory is too slow to use every time when we want an instruction or a data. Therefore, Instruction Cache and Data Cache are used to speed up memory accesses. Separate D-Cache and I-Cache makes it possible to fetch instructions and data in parallel.

The instruction memory subsystem regulates the flow of instructions. The Instruction Decode stage has an instruction issuing unit (IIU). IIU decodes both instructions from the I-Cache and compares the operand values in each instruction to determine interdependence between the instructions. When an interdependence occurs, the second instruction is placed in a hold register and a "rollback" signal is asserted to alter the next-PC value. The held instruction will be executed in the following clock cycle. The block diagram of IIU is shown in Fig. -2.



Fig -2: Instruction Issuing Unit [1]

#### 2) Arithmetic Logic Unit (ALU)

The arithmetic logic unit is a combinational circuit which is capable of executing arithmetic and logic operations. An ALU is a major component of the processor. The 32-bit ALU designed is capable of performing addition, subtraction,



increment, decrement, logical, shifting and comparison operations. Fig -3 shows block diagram of ALU.



Fig -3: Block diagram of ALU

The ALU designed operates on 32-bit operands. The particular function to be performed is controlled by 4-bit opcode, whose value encodes the function according to the Table-1.

#### Table-1: ALU operations

| OPCODE  | OPERATION   | ALU OUTPUT  |
|---------|-------------|-------------|
| 4'b0000 | Addition    | A+B         |
| 4'b0001 | Subtraction | A-B         |
| 4'b0010 | Increment   | A+1         |
| 4'b0011 | Decrement   | A-1         |
| 4'b0100 | NOT         | ~A          |
| 4'b0101 | AND         | A AND B     |
| 4'b0110 | OR          | A OR B      |
| 4'b0111 | NAND        | ~ (A AND B) |
| 4'b1000 | NOR         | ~ (A OR B)  |
| 4'b1001 | XOR         | A XOR B     |
| 4'b1010 | XNOR        | ~ (A XOR B) |
| 4'b1011 | Right shift | LSR         |
| 4'b1100 | Left shift  | LSL         |

| 4'b1101 | Greater than | CMPGT |
|---------|--------------|-------|
| 4'b1110 | Less than    | CMPLT |
| 4'b1111 | Equal        | CMPEQ |

## 3) D-Cache

The data memory subsystem directs the flow of data from the main memory to the Execute and Write-Back stages using the Instruction Decode and Memory stages.

The designed D-Cache stores the 32-bit write data and gives back 32-bit read data from requested 8-bit address. It consists of 256 32-bit memory locations. At every clock cycle, the read operation will take place. The write operation takes place only when write enable signal is high.

## 4) Integer Register File

A register file is an array of processor registers in a central processing unit (CPU). Write Back (WB) stage has integer register file. This unit gets data and address from the Memory stage and stores it in its register file. It stores 32-bit data at 5-bit address. The register file is used as CPU registers for the operations defined by the given instruction.

## **5. VERIFICATION OF FUNCTIONAL BLOCKS**

The process of analysing the design to determine whether it meets the specified requirements is known as verification. For the functional blocks such as I-Cache & Instruction Issuing Unit, ALU, D-Cache and Integer Register File testbench codes are written to check whether the designs are functionally correct. For D-cache and Integer Register File UVM testbench has been built using System Verilog.

The Universal Verification Methodology (UVM) is a standardised approach for verifying integrated circuits, ASICs, and SoC architectures. The UVM method was developed by the Accellera Systems Initiative, with the support of several companies including Cadence, Mentor Graphics and Synopsys.

Some benefits of UVM are (1) Modularity and Reusability, (2)
Separating test from testbenches, (3) Simulator independent,
(4) Sequence methodology, (5) Configuration mechanisms,
(6) Factory mechanisms

A typical UVM testbench architecture contains many components. Fig 4 shows a simple UVM testbench diagram.





Fig -4: UVM testbench architecture

A typical UVM testbench architecture has the following components:

- Testbench- Testbench instantiates unit under test and the UVM test class and set-up the connection between them.
- Test- It is the top-level class responsible for configuring the testbench, start the testbench parts development measure by building a higher level down in the chain of hierarchy, and it starts the stimulus by initiating sequence.
- Environment- groups interrelated verification components such as Agents and Scoreboards.
- Scoreboard- contains checkers and verifies the functionality of the design.
- Agent- groups the verification components which deals with specific interfaces.
- Monitor- Samples the unit under test and reference model interfaces, captures and compares the data included in transactions.
- Driver- Receives data items from the sequencer and sends it to the interfaces for unit under test and reference model.
- Sequencer- The sequencer is in charge of directing transactions (sequence items) generated in sequence to driver or vice-versa.
- Sequence-contains a behavior for generating stimulus.
- Sequence item- consists of data fields required to generate the stimulus.

## 6. RESULTS

The functional blocks that are discussed in section 4 are designed using Verilog HDL and are simulated using Xilinx Vivado. Code coverage analysis is performed on the functional blocks using ModelSim SE. The simulation results and code coverage analysis report are shown below.



Fig -5: Simulation result of Instruction Issuing Unit

Here instructions are manually fed. When Control = 00, B\_Out = 78aa5495 and when Control = 01, B\_Out = 00aa5495. For other Control values B\_Out = 0. A\_Out will get values from I-Cache unit.

| Name                | Value    | 0.000 ns |          | 100.000 ne |          | 200.000 ns |
|---------------------|----------|----------|----------|------------|----------|------------|
| 🕌 clk               | 0        |          |          |            |          |            |
| 場 reset             | 0        |          |          |            |          |            |
| > 😻 dataA[31:0]     | 0000023  | *****    |          | 000000f    |          |            |
| > 😻 dataB[31:0]     | 0000028  | *****    |          | 0000000a   |          |            |
| > 😻 ALUCtrl[3:0]    | f        | x        | 0        | 1          | 2        | 3          |
| > 😽 ALUResult[31:0] | 00000000 | 00000000 | 00000019 | 00000005   | 00000010 | 00000022   |
| > 😻 Flags[4:0]      | 06       | 0        | 0        | 02         | 00       | 02         |
|                     |          |          |          |            |          |            |

Fig -6: Simulation result of Arithmetic operations

In the above simulation, addition, subtraction, increment and decrement operations are performed.



Fig -7: Simulation result of Logic operations

In the above simulation, logical operations such as NOT, AND, OR, NAND, NOR, XOR and XNOR are performed.



## International Research Journal of Engineering and Technology (IRJET) e-

T Volume: 08 Issue: 09 | Sep 2021

www.irjet.net

e-ISSN: 2395-0056 p-ISSN: 2395-0072

| Name               | Value    | 600.000 ns | 650.000 ns |
|--------------------|----------|------------|------------|
| \rm L              | 0        |            |            |
| \rm reset          | 0        |            |            |
| > 😻 dataA[31:0]    | 0000023  |            |            |
| > 😻 dataB[31:0]    | 0000028  |            |            |
| > 100 ALUCtrl[3:0] | b        | d          | c          |
| > VALUResult[31:0] | 00000011 | 0000011    | 00000046   |
| > 😽 Flags[4:0]     | 02       | 02         | 00         |
|                    |          |            |            |

Fig -8: Simulation result of Shift operations

In Fig-8 right shift and left shift operations are performed.



Fig -9: Simulation result of Comparison operations

In the above simulation comparison operation are performed

| Name             | Value    | 0.00000000 | 0 ms    |        |     | 2,000 | 0.0000 | 00000 ms |        |  |
|------------------|----------|------------|---------|--------|-----|-------|--------|----------|--------|--|
| 🕌 dk             | 0        |            |         |        |     |       |        |          |        |  |
| 🕌 reset          | 0        |            |         |        |     |       |        |          |        |  |
| > 🖬 address[7:0] | 26       |            |         | 32     |     |       |        |          | 26     |  |
| 🕌 wr_en          | 1        |            |         |        |     |       |        |          |        |  |
| 🕌 rd_en          | 0        |            |         |        |     |       |        |          |        |  |
| > 👹 w_data[31:0] | 28765402 |            | 23      | 415678 |     |       |        | 28       | 765402 |  |
| > 🗑 r_data[31:0] | 28765402 |            | 0000000 | 0      | 234 | 15678 |        | 28       | 765402 |  |
|                  |          |            |         |        |     |       |        |          |        |  |

Fig -10: Simulation result of D-cache

Above figure shows simulation result of D-cache. The data is stored at particular address and it is read out from that address.

| Name             | Value    |   | 500.0   | 0000000 ms |          | 1,000.0000 | 00000 ms | 1,500 | .000000000 | ns | 2,00 |
|------------------|----------|---|---------|------------|----------|------------|----------|-------|------------|----|------|
| 🕌 dk             | 0        |   |         |            |          |            |          |       |            |    |      |
| 📔 reset          | 0        |   |         |            |          |            |          |       |            |    |      |
| > 👹 address[4:0] | 17       |   |         | 12         |          |            |          | 1     |            |    |      |
| 🖁 wr_en          | 1        |   |         |            |          |            |          |       |            |    |      |
| 🖁 rd_en          | 0        |   |         |            |          |            |          |       |            |    |      |
| > 👹 w_data[31:0] | 23765490 |   | 345     | 60987      |          |            |          | 23765 | 490        |    |      |
| > ₩ r_data[31:0] | 23765490 | 0 | 0000000 |            | 34560981 |            |          | 23765 | 490        |    |      |
|                  |          |   |         |            |          |            |          |       |            |    |      |

Fig -11: Simulation result of Integer Register File

In the above figure simulation results are shown for Integer Register File. Output is based on data and address.



**Fig -12:** UVM simulation result of D-Cache without error Fig-12 shows the simulation result of D-Cache without error and Fig-13 shows an example of D-Cache output without error.

> UVM\_INFO E:/Project\_code/ Expected Data UVM\_INFO E:/Project\_code/ address = 04 Read\_data = 1b1eb521 UVM\_INFO E:/Project\_code/ Actual Data

UVM\_INFO E:/Project\_code/ address = 04 Read\_data = 1b1eb521

UVM\_INFO E:/Project\_code/ Data Match - Test Passed

#### Fig -13: An example of D-Cache output without error



#### Fig -14: UVM simulation result of D-Cache with error

UVM\_INFO E:/Project\_code/xilinx\_Vivado, Expected Data

UVM\_INFO E:/Project\_code/xilinx\_Vivado, address = c5 Read\_data = 4f34fedd

UVM\_INFO E:/Project\_code/xilinx\_Vivado, Actual Data

UVM\_INFO E:/Project\_code/xilinx\_Vivado, address = c5 Read\_data = 00000000

UVM\_ERROR E:/Project\_code/xilinx\_Vivad Data Mismatch - Test Failed

Fig -15: An example of D-Cache output with error

Fig-14 shows the simulation result of D-Cache with error and Fig-15 shows an example of D-Cache output with error.



#### Fig -16: UVM simulation result of Integer Register File

#### without error



Data Match - Test Passed

# Fig -17: An example of Integer Register File output without error

Fig-16 shows the simulation result of Integer Register File without error and Fig-17 shows an example of Integer Register File output without error.



Fig -18: UVM simulation result of Integer Register File with error

UVM\_INFO E:/Project\_code/xilinx\_Vivado/1 Expected Data

UVM\_INFO E:/Project\_code/xilinx\_Vivado/1
address = 1e
Read data = 073825ca

UVM\_INFO E:/Project\_code/xilinx\_Vivado/1 Actual Data

UVM\_INFO E:/Project\_code/xilinx\_Vivado/1 address = 1e Read\_data = 00000000

UVM\_ERROR E:/Project\_code/xilinx\_Vivado, Data Mismatch - Test Failed

# Fig -19: An example of Integer Register File output with error

Fig-18 shows the simulation result of Integer Register File with error and Fig-19 shows an example of Integer Register File output with error.

| Passed:                                                             |                                |                                                                                                 |                                           |                         |                                 |          |                                                   |                                                   |                                                                                   |                                   |
|---------------------------------------------------------------------|--------------------------------|-------------------------------------------------------------------------------------------------|-------------------------------------------|-------------------------|---------------------------------|----------|---------------------------------------------------|---------------------------------------------------|-----------------------------------------------------------------------------------|-----------------------------------|
|                                                                     | 1                              |                                                                                                 |                                           |                         |                                 |          |                                                   |                                                   |                                                                                   |                                   |
| Warning:                                                            | 0                              |                                                                                                 |                                           |                         |                                 |          |                                                   |                                                   |                                                                                   |                                   |
| Error:                                                              | 0                              |                                                                                                 |                                           |                         |                                 |          |                                                   |                                                   |                                                                                   |                                   |
| Fatal:                                                              | 0                              |                                                                                                 |                                           |                         |                                 |          |                                                   |                                                   |                                                                                   |                                   |
| Coverage Sun                                                        | nmary by                       | Coverage S                                                                                      | Summa                                     | ry by T                 | ype:                            |          |                                                   |                                                   | Coverage Summa                                                                    | ry by Desig                       |
| Coverage Sun<br>Structure:                                          | nmary by                       | Coverage S                                                                                      | Summa                                     | ry by T                 | ype:                            |          | 63.52%                                            | 57.36%                                            | Coverage Summa<br>Unit:                                                           | ry by Desig                       |
| Coverage Sun<br>Structure:<br>Design Scope +                        | nmary by<br>Coverage •         | Coverage S<br>Total Covera                                                                      | Summa<br>ige:                             | ry by T                 | ype:                            | Weight   | 63.52%                                            | 57.36%                                            | Coverage Summar<br>Unit:<br>Design Scope +                                        | ry by Desig<br>Coverage           |
| Coverage Sun<br>Structure:<br>Design Scope •<br>ALU_32BIT_tb        | Coverage *                     | Coverage S<br>Total Covera<br>Coverage<br>Type -                                                | Summan<br>nge:<br>Bins •                  | ry by T<br>Hits •       | ype:<br>Misses •                | Weight - | 63.52%<br>%<br>Hit •                              | 57.36%<br>Coverage *                              | Coverage Summar<br>Unit:<br>Design Scope •<br>work ALU 32BIT tb                   | ry by Desig<br>Coverage<br>69.85% |
| Coverage Sun<br>Structure:<br>Design Scope •<br>ALU_32BIT_tb<br>uut | Coverage *<br>57.36%<br>66.24% | Coverage S<br>Total Covera<br>Coverage<br>Type •<br>Statements                                  | Summa<br>nge:<br>Bins •<br>80             | ry by T<br>Hits •<br>76 | ype:<br>Misses •                | Weight • | 63.52%<br>%<br>Hit •<br>95.00%                    | 57.36%<br>Coverage =<br>95.00%                    | Coverage Summar<br>Unit:<br>Design Scope •<br>work ALU 32BIT 1b<br>work ALU 32BIT | Coverage<br>69.85%<br>66.24%      |
| Coverage Sun<br>Structure:<br>Design Scope •<br>ALU_32BIT_tb<br>unt | Coverage 4<br>57.36%<br>66.24% | Coverage S<br>Total Covera<br>Coverage<br>Type •<br>Statements<br>Branches                      | Summa<br>nge:<br>Bins •<br>80<br>31       | Hits •                  | ype:<br>Misses •<br>4<br>6      | Weight - | 63.52%<br>%<br>Hit •<br>95.00%<br>80.64%          | 57.36%<br>Coverage =<br>95.00%<br>80.64%          | Coverage Summar<br>Unit:<br>Design Scope •<br>work_ALU_32BIT_tb<br>work_ALU_32BIT | Coverage -<br>69.85%<br>66.24%    |
| Coverage Sun<br>Structure:<br>Design Scope •<br>ALU_32BIT_tb<br>Dut | Coverage *<br>57.36%<br>66.24% | Coverage S<br>Total Covera<br>Coverage<br>Type -<br>Statements<br>Branches<br>FEC<br>Conditions | Summan<br>nge:<br>Bins •<br>80<br>31<br>4 | Hits •<br>76<br>25<br>0 | ype:<br>Misses •<br>4<br>6<br>4 | Weight - | 63.52%<br>%<br>Hit •<br>95.00%<br>80.64%<br>0.00% | 57.36%<br>Coverage *<br>95.00%<br>80.64%<br>0.00% | Coverage Summar<br>Unit:<br>Design Scope •<br>work ALU 32BIT tb<br>work ALU 32BIT | Coverage 69.85%<br>66.24%         |

Fig -20: Code coverage report of ALU without fault

| ALU_32BIT_tb                                                       | 21.80%           | Statements<br>Branches | 80<br>31 | 45      | 25       | 1        | 19.35%  | 19.35%     | work.ALU_32BIT    | 10.64%   |
|--------------------------------------------------------------------|------------------|------------------------|----------|---------|----------|----------|---------|------------|-------------------|----------|
| ALU_32BIT_tb                                                       | 21.80%<br>10.64% | Statements             | 80       | 49      | 9 51     |          | 0112070 | 01.2.570   | work.ALU_32BIT    | 10.64%   |
| ALU_32BIT_tb                                                       | 21.80%           |                        |          | 40      | 21       | 1        | 61 25%  | 61 2594    |                   |          |
| Design Scope -                                                     |                  | Type •                 | Bins 4   | Hits 4  | MISSES 4 | weight 4 | Hit •   | Coverage 4 | work.ALU_32BIT_tb | 53.97%   |
| Design Scone #                                                     | Coverage *       | Coverage               |          |         |          |          | %       | C          | Design Scope 🖪    | Coverage |
| Structure:                                                         |                  | Total Cover            | ige:     |         |          |          | 18.36%  | 21.80%     | Unit:             |          |
| Error:<br>Fatal:<br>.ist of tests include<br>.ist of global attrib | ed in report     | in report              | Summa    | ry by J | Ívpe:    |          |         |            | Coverage Summar   | v by Des |
| Warning:                                                           | 0                |                        |          |         |          |          |         |            |                   |          |
| Passed:                                                            | 1                |                        |          |         |          |          |         |            |                   |          |

Fig -21: Code coverage report of ALU with fault

Fig-20 and Fig-21 shows code coverage report of ALU without fault and with fault respectively.

| Number of tests i                                                 | run: 1                         |                                                                                       |                                     |                                      |                              |                         |                                                    |                                                    |                                                                                                                                          |                                                             |
|-------------------------------------------------------------------|--------------------------------|---------------------------------------------------------------------------------------|-------------------------------------|--------------------------------------|------------------------------|-------------------------|----------------------------------------------------|----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|
| Passed:                                                           | 1                              |                                                                                       |                                     |                                      |                              |                         |                                                    |                                                    |                                                                                                                                          |                                                             |
| Warning:                                                          | 0                              |                                                                                       |                                     |                                      |                              |                         |                                                    |                                                    |                                                                                                                                          |                                                             |
| Error:                                                            | 0                              |                                                                                       |                                     |                                      |                              |                         |                                                    |                                                    |                                                                                                                                          |                                                             |
| Fatal:                                                            | 0                              |                                                                                       |                                     |                                      |                              |                         |                                                    |                                                    |                                                                                                                                          |                                                             |
| Coverage Sun                                                      | amary by                       | Coverage S                                                                            | ummar                               | y by Ty                              | pe:                          |                         |                                                    |                                                    | Coverage Summa                                                                                                                           | ıry by Desiş                                                |
| Coverage Sun<br>Structure:                                        | amary by                       | Coverage S                                                                            | Summar                              | y by Ty                              | pe:                          |                         | 16 1086                                            | 28 3084                                            | Coverage Summa<br>Unit:                                                                                                                  | ary by Desig                                                |
| Coverage Sun<br>Structure:<br>Design Scope •                      | omary by<br>Coverage •         | Coverage S<br>Total Covera                                                            | summar<br>ge:                       | y by Ty                              | ype:                         |                         | 16.19%                                             | 28.39%                                             | Coverage Summa<br>Unit:<br>Design Scope •                                                                                                | ary by Desig                                                |
| Coverage Sun<br>Structure:<br>Design Scope •<br>IFM <u>New Tb</u> | Coverage •<br>28.39%           | Coverage S<br>Total Covera<br>Coverage<br>Type •                                      | Summar<br>ge:<br>Bins 4             | y by Ty<br>Hits •                    | vpe:<br>Misses •             | Weight •                | 16.19%<br>%<br>Hit •                               | 28.39%<br>Coverage +                               | Coverage Summa<br>Unit:<br>Design Scope <<br>work IFM New Tb                                                                             | Coverage •<br>57.38%                                        |
| Coverage Sun<br>Structure:<br>Design Scope •<br>IFM_New_Tb<br>M0  | Coverage -<br>28.39%<br>24.64% | Coverage S<br>Total Covera<br>Coverage<br>Type •<br>Statements                        | ge:<br>Bins •<br>111                | y by Ty<br>Hits •<br>49              | Misses •                     | Weight •                | 16.19%<br>%<br>Hit •<br>44.14%                     | 28.39%<br>Coverage +<br>44.14%                     | Coverage Summa<br>Unit:<br>Design Scope •<br>work IFM New Tb<br>work IFM New                                                             | Coverage •<br>57.38%<br>69.27%                              |
| Coverage Sun<br>Structure:<br>Design Scope •<br>IFM_New_Tb<br>M0  | Coverage -<br>28.39%<br>24.64% | Coverage S<br>Total Coverage<br>Type •<br>Statements<br>Branches                      | ge:<br>Bins •<br>111<br>89          | Hits •                               | Misses •<br>62<br>64         | Weight •                | 16.19%<br>%<br>Hit •<br>44.14%<br>28.08%           | 28.39%<br>Coverage -<br>44.14%<br>28.08%           | Coverage Summa<br>Unit:<br>Design Scope •<br>work IFM New Tb<br>work IFM New<br>work Hold Register                                       | Coverage 4<br>57.38%<br>69.27%<br>69.79%                    |
| Coverage Sun<br>Structure:<br>Design Scope -<br>IFM New Tb<br>MO  | Coverage -<br>28.39%<br>24.64% | Coverage S<br>Total Covera<br>Coverage<br>Type •<br>Statements<br>Branches<br>Toggles | ge:<br>Bins •<br>111<br>89<br>1288  | y by Ty<br>Hits •<br>49<br>25<br>167 | Misses •<br>62<br>64<br>1121 | Weight •<br>1<br>1<br>1 | 16.19%<br>%<br>Hit •<br>44.14%<br>28.08%<br>12.96% | 28.39%<br>Coverage •<br>44.14%<br>28.08%<br>12.96% | Coverage Summa<br>Unit:<br>Design Scope •<br>work IFM New Tb<br>work IFM New<br>work Hold Register<br>work Hold Register                 | Coverage *<br>57.38%<br>69.27%<br>69.79%<br>5.79%           |
| Coverage Sun<br>Structure:<br>Design Scope -<br>IFM New Tb<br>MO  | Coverage *<br>28.39%<br>24.64% | Coverage S<br>Total Covera<br>Coverage<br>Type •<br>Statements<br>Branches<br>Toggles | ge:<br>Bins •<br>1111<br>89<br>1288 | y by Ty<br>Hits •<br>49<br>25<br>167 | Misses •<br>62<br>64<br>1121 | Weight •                | 16.19%<br>%<br>Hit •<br>44.14%<br>28.08%<br>12.96% | 28.39%<br>Coverage •<br>44.14%<br>28.08%<br>12.96% | Coverage Summa<br>Unit:<br>Design Scope •<br>work IFM_New Tb<br>work IFM_New<br>work Hold_Register<br>work Hold_Register<br>work Mux_3x1 | Coverage =<br>57.38%<br>69.27%<br>69.79%<br>5.79%<br>75.78% |

Fig -22: Code coverage report of IIU without fault

| Passed:                                                          |                                |                                                                                       |                                                |                                      |                              |          |                                                    |                                                    |                                                                                                                                  |                                                             |
|------------------------------------------------------------------|--------------------------------|---------------------------------------------------------------------------------------|------------------------------------------------|--------------------------------------|------------------------------|----------|----------------------------------------------------|----------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|
|                                                                  | 1                              |                                                                                       |                                                |                                      |                              |          |                                                    |                                                    |                                                                                                                                  |                                                             |
| Warning:                                                         | 0                              |                                                                                       |                                                |                                      |                              |          |                                                    |                                                    |                                                                                                                                  |                                                             |
| Error:                                                           | 0                              |                                                                                       |                                                |                                      |                              |          |                                                    |                                                    |                                                                                                                                  |                                                             |
| Fatal:                                                           | 0                              |                                                                                       |                                                |                                      |                              |          |                                                    |                                                    |                                                                                                                                  |                                                             |
| Coverage Sur                                                     | nmary by                       | Coverage S                                                                            | Summar                                         | y by T                               | ype:                         |          |                                                    |                                                    | Coverage Summa                                                                                                                   | ury by Desi                                                 |
| Coverage Sur<br>Structure:                                       | nmary by                       | Coverage S                                                                            | Summar                                         | y by T                               | vpe:                         |          | 17.00%                                             | 28.71%                                             | Coverage Summa<br>Unit:                                                                                                          | ury by Desi                                                 |
| Coverage Sun<br>Structure:<br>Design Scope                       | omary by<br>Coverage •         | Coverage S<br>Total Covera                                                            | Summar                                         | y by Ty                              | Miner 1                      | Weight + | 17.00%                                             | 28.71%                                             | Coverage Summa<br>Unit:<br>Design Scope •                                                                                        | Coverage                                                    |
| Coverage Sun<br>Structure:<br>Design Scope                       | Coverage +<br>28.71%           | Coverage S<br>Total Covera<br>Coverage<br>Type •                                      | Summar<br>ige:<br>Bins •                       | y by Ty<br>Hits •                    | vpe:<br>Misses •             | Weight + | 17.00%<br>%<br>Hit •                               | 28.71%<br>Coverage •                               | Coverage Summa<br>Unit:<br>Design Scope •<br>work.IFM New Tb                                                                     | Coverage +<br>57.38%                                        |
| Coverage Sur<br>Structure:<br>Design Scope •<br>IFM_New_Tb<br>M0 | Coverage *                     | Coverage S<br>Total Covera<br>Coverage<br>Type •<br>Statements                        | Summar<br>ige:<br>Bins •<br>111                | y by Ty<br>Hits •<br>49              | Misses •<br>62               | Weight • | 17.00%<br>%<br>Hit •<br>44.14%                     | 28.71%<br>Coverage +<br>44.14%                     | Coverage Summa<br>Unit:<br>Design Scope •<br>work IFM New Tb<br>work IFM New                                                     | Coverage 4<br>57.38%<br>69.79%                              |
| Coverage Sur<br>Structure:<br>Design Scope<br>IFM_New_Tb<br>M0   | Coverage •<br>28.71%<br>25.03% | Coverage S<br>Total Covera<br>Coverage<br>Type •<br>Statements<br>Branches            | Summar<br>ige:<br>Bins •<br>111<br>89          | y by Ty<br>Hits •<br>49<br>25        | Misses •<br>62<br>64         | Weight • | 17.00%<br>%<br>Hit •<br>44.14%<br>28.08%           | 28.71%<br>Coverage +<br>44.14%<br>28.08%           | Coverage Summa<br>Unit:<br>Design Scope •<br>work IFM New Tb<br>work IFM New<br>work Hold Register                               | Coverage =<br>57.38%<br>69.79%<br>69.79%                    |
| Coverage Sun<br>Structure:<br>Design Scope<br>IFM New Tb<br>M0   | Coverage •<br>28.71%<br>25.03% | Coverage S<br>Total Coverage<br>Type •<br>Statements<br>Branches<br>Toggles           | Summar<br>ige:<br>Bins •<br>1111<br>89<br>1288 | y by Ty<br>Hits •<br>49<br>25<br>179 | Misses •<br>62<br>64<br>1109 | Weight • | 17.00%<br>%<br>Hit<br>44.14%<br>28.08%<br>13.89%   | 28.71%<br>Coverage *<br>44.14%<br>28.08%<br>13.89% | Coverage Summa<br>Unit:<br>Design Scope •<br>work.IFM New Tb<br>work.IFM New<br>work.Hold Register<br>work.ICache                | Coverage =<br>57.38%<br>69.79%<br>69.79%<br>7.36%           |
| Coverage Sun<br>Structure:<br>Design Scope<br>IFM New Tb<br>MQ   | Coverage +<br>28.71%<br>25.03% | Coverage S<br>Total Covers<br>Coverage<br>Type •<br>Statements<br>Branches<br>Toggles | Summar<br>ige:<br>Bins •<br>111<br>89<br>1288  | y by Ty<br>Hits •<br>49<br>25<br>179 | Misses •<br>62<br>64<br>1109 | Weight • | 17.00%<br>%<br>Hit •<br>44.14%<br>28.08%<br>13.89% | 28.71%<br>Coverage •<br>44.14%<br>28.08%<br>13.89% | Coverage Summa<br>Unit:<br>Design Scope -<br>work/IFM New Tb<br>work/IFM New<br>work/Hold Register<br>work/Cache<br>work/Mux 3x1 | Coverage =<br>57.38%<br>69.79%<br>69.79%<br>7.36%<br>75.78% |

**Fig -23:** Code coverage report of IIU with fault

Fig-22 and Fig-23 shows code coverage report of IIU without fault and with fault respectively.

| Number of tests                                                | run: 1                                       |                                                                                       |                                        |                         |                                |          |                                          |                                                   |                                                                               |                                |
|----------------------------------------------------------------|----------------------------------------------|---------------------------------------------------------------------------------------|----------------------------------------|-------------------------|--------------------------------|----------|------------------------------------------|---------------------------------------------------|-------------------------------------------------------------------------------|--------------------------------|
| Passed:                                                        | 1                                            |                                                                                       |                                        |                         |                                |          |                                          |                                                   |                                                                               |                                |
| Warning:                                                       | 0                                            |                                                                                       |                                        |                         |                                |          |                                          |                                                   |                                                                               |                                |
| Error:                                                         | 0                                            |                                                                                       |                                        |                         |                                |          |                                          |                                                   |                                                                               |                                |
| Fatal:                                                         | 0                                            |                                                                                       |                                        |                         |                                |          |                                          |                                                   |                                                                               |                                |
| Coverage Su                                                    | mmary by                                     | Coverage S                                                                            | ummar                                  | y by Ty                 | pe:                            |          |                                          |                                                   | Coverage Sumn                                                                 | nary by De                     |
| Coverage Su<br>Structure:                                      | mmary by                                     | Coverage S                                                                            | ummar                                  | y by Ty                 | pe:                            |          | 16 184                                   |                                                   | Coverage Sumn<br>Unit:                                                        | nary by De                     |
| Coverage Su<br>Structure:<br>Design Scope                      | • Coverage •                                 | Coverage S<br>Total Covera                                                            | ummar;<br>ge:                          | y by Ty                 | pe:                            |          | 16.15%                                   | 33.31%                                            | Coverage Sumn<br>Unit:<br>Design Scope •                                      | nary by De                     |
| Coverage Su<br>tructure:<br>Design Scope<br>D Cache th         | • Coverage •                                 | Coverage S<br>Total Covera<br>Coverage<br>Type •                                      | ummar<br>ge:<br>Bins •                 | y by Ty<br>Hits •       | pe:<br>Misses •                | Weight • | 16.15%<br>%<br>Hit •                     | 33.31%<br>Coverage •                              | Coverage Summ<br>Unit:<br>Design Scope •<br>work D. Cache th                  | Coverage 4                     |
| Coverage Su<br>tructure:<br>Design Scope<br>D_Cache_tb<br>uut  | Coverage -<br>33.31%<br>23.63%               | Coverage S<br>Total Covera<br>Coverage<br>Type •<br>Statements                        | ummar<br>ge:<br>Bins •<br>39           | y by Ty<br>Hits •<br>34 | pe:<br>Misses •<br>5           | Weight • | 16.15%<br>%<br>Hit •<br>87.17%           | 33.31%<br>Coverage •<br>87.17%                    | Coverage Summ<br>Unit:<br>Design Scope •<br>work D. Cache th<br>work D. Cache | Coverage •<br>55.59%<br>23.63% |
| Coverage Su<br>tructure:<br>Design Scope<br>D_Cache_tb<br>unt  | • Coverage •<br>33.31%<br>23.63%             | Coverage S<br>Total Coverage<br>Coverage<br>Type •<br>Statements<br>Branches          | ummar<br>ge:<br>Bins •<br>39<br>5      | Hits •                  | pe:<br>Misses •<br>5<br>3      | Weight • | 16.15%<br>%<br>Hit •<br>87.17%<br>40.00% | 33.31%<br>Coverage •<br>87.17%<br>40.00%          | Coverage Sumn<br>Unit:<br>Design Scope •<br>work D. Cache th<br>work D. Cache | Coverage •<br>55.59%<br>23.63% |
| Coverage Su<br>itructure:<br>Design Scope<br>D Cache th<br>unt | mmary by<br>• Coverage •<br>33.31%<br>23.63% | Coverage S<br>Total Coverage<br>Type •<br>Statements<br>Branches<br>FEC<br>Conditions | ummar<br>ge:<br>Bins •<br>39<br>5<br>4 | Hits •<br>34<br>2<br>0  | pe:<br>Misses •<br>5<br>3<br>4 | Weight = | 16.15%<br>%<br>Hit •<br>87.17%<br>40.00% | 33.31%<br>Coverage *<br>87.17%<br>40.00%<br>0.00% | Coverage Summ<br>Unit:<br>Design Scope •<br>work D. Cache th<br>work D. Cache | Coverage *<br>55.59%<br>23.63% |



| Number of tests i                                                  | run: 1                         |                                                                                                 |                               |                                   |                                |          |                                                   |                                                   |                                                                               |                                |
|--------------------------------------------------------------------|--------------------------------|-------------------------------------------------------------------------------------------------|-------------------------------|-----------------------------------|--------------------------------|----------|---------------------------------------------------|---------------------------------------------------|-------------------------------------------------------------------------------|--------------------------------|
| Passed:                                                            | 1                              |                                                                                                 |                               |                                   |                                |          |                                                   |                                                   |                                                                               |                                |
| Warning:                                                           | 0                              |                                                                                                 |                               |                                   |                                |          |                                                   |                                                   |                                                                               |                                |
| Error:                                                             | 0                              |                                                                                                 |                               |                                   |                                |          |                                                   |                                                   |                                                                               |                                |
| Fatal:                                                             | 0                              |                                                                                                 |                               |                                   |                                |          |                                                   |                                                   |                                                                               |                                |
|                                                                    |                                | 1                                                                                               |                               |                                   |                                |          |                                                   |                                                   |                                                                               |                                |
| Coverage Sun<br>Structure:                                         | nmary by                       | Coverage S                                                                                      | ummar                         | y by Ty                           | pe:                            |          | 17.07%                                            | 35.23%                                            | Coverage Sumr<br>Unit:                                                        | nary by Des                    |
| Coverage Sun<br>Structure:<br>Design Scope                         | nmary by<br>Coverage •         | Coverage S<br>Total Covera                                                                      | ummar                         | y by Ty                           | pe:                            |          | 17.07%                                            | 35.23%                                            | Coverage Sumr<br>Unit:<br>Design Scope •                                      | nary by Des<br>Coverage •      |
| Coverage Sun<br>Structure:<br>Design Scope -<br>D_Cache_tb         | Coverage -                     | Coverage S<br>Total Covera<br>Coverage<br>Type •                                                | ge:<br>Bins •                 | y by Ty<br>Hits •                 | pe:<br>Misses •                | Weight • | 17.07%<br>%<br>Hit •                              | 35.23%<br>Coverage •                              | Coverage Sumr<br>Unit:<br>Design Scope •<br>work D Cache th                   | Coverage 4<br>55.59%           |
| Coverage Sun<br>Structure:<br>Design Scope -<br>D. Cache_th        | Coverage -<br>35.23%<br>30.45% | Coverage S<br>Total Covera<br>Coverage<br>Type •<br>Statements                                  | ge:<br>Bins •<br>39           | y by Ty<br>Hits •<br>37           | pe:<br>Misses •<br>2           | Weight - | 17.07%<br>%<br>Hit •<br>94.87%                    | 35.23%<br>Coverage =<br>94.87%                    | Coverage Summ<br>Unit:<br>Design Scope •<br>work D Cache th<br>work D Cache   | Coverage •<br>55.59%<br>30.45% |
| Coverage Sun<br>tructure:<br>Design Scope<br>D_Cache_tb<br>mut     | Coverage *<br>35.23%<br>30.45% | Coverage S<br>Total Covera<br>Coverage<br>Type 4<br>Statements<br>Branches                      | ge:<br>Bins •<br>39<br>5      | y by Ty<br>Hits •<br>37<br>2      | pe:<br>Misses •<br>2<br>3      | Weight + | 17.07%<br>%<br>Hit -<br>94.87%<br>40.00%          | 35.23%<br>Coverage =<br>94.87%<br>40.00%          | Coverage Summ<br>Unit:<br>Design Scope •<br>work D Cache th<br>work D Cache   | Coverage •<br>55,59%<br>30.45% |
| Coverage Sun<br>Structure:<br>Design Scope -<br>D Cache th<br>Just | Coverage =<br>35.23%<br>30.45% | Coverage S<br>Total Covera<br>Coverage<br>Type •<br>Statements<br>Branches<br>FEC<br>Conditions | ge:<br>Bins •<br>39<br>5<br>4 | y by Ty<br>Hits •<br>37<br>2<br>0 | pe:<br>Misses •<br>2<br>3<br>4 | Weight • | 17.07%<br>%<br>Hit •<br>94.87%<br>40.00%<br>0.00% | 35.23%<br>Coverage =<br>94.87%<br>40.00%<br>0.00% | Coverage Summ<br>Unit:<br>Design Scope -<br>work D. Cache th<br>work D. Cache | Coverage -<br>55.59%<br>30.45% |

Fig -25: Code coverage report of D-Cache with fault

Fig-24and Fig-25 shows code coverage report of D-Cache without fault and with fault respectively.

| Passed:                                                            | m: 1                            |                                                                              |                                    |                            |                      |          |                                          |                                          |                                                                            |                                                                    |
|--------------------------------------------------------------------|---------------------------------|------------------------------------------------------------------------------|------------------------------------|----------------------------|----------------------|----------|------------------------------------------|------------------------------------------|----------------------------------------------------------------------------|--------------------------------------------------------------------|
| Passed:                                                            |                                 |                                                                              |                                    |                            |                      |          |                                          |                                          |                                                                            |                                                                    |
|                                                                    | 1                               |                                                                              |                                    |                            |                      |          |                                          |                                          |                                                                            |                                                                    |
| Warning:                                                           | 0                               |                                                                              |                                    |                            |                      |          |                                          |                                          |                                                                            |                                                                    |
| Error:                                                             | 0                               |                                                                              |                                    |                            |                      |          |                                          |                                          |                                                                            |                                                                    |
| Fatal:                                                             | 0                               |                                                                              |                                    |                            |                      |          |                                          |                                          |                                                                            |                                                                    |
| -                                                                  | utes included                   | in report                                                                    |                                    |                            |                      |          |                                          |                                          |                                                                            |                                                                    |
| Coverage Sumi<br>Structure:                                        | nary by                         | in report<br>Coverage S                                                      | ummary                             | by Ty                      | pe:                  |          |                                          |                                          | Coverage Sum<br>Unit:                                                      | mary by Des                                                        |
| Coverage Sumi<br>Structure:                                        | nary by                         | Coverage S<br>Total Coverag                                                  | ummary<br>ge:                      | by Ty                      | pe:                  |          | 21.64%                                   | 54.34%                                   | Coverage Sum<br>Unit:                                                      | mary by Des                                                        |
| Coverage Sumi<br>Structure:<br>Design Scope *                      | mary by<br>Coverage •           | Coverage S<br>Total Coverage                                                 | ummary<br>ge:<br>Bins •            | by Ty<br>Hits •            | pe:                  | Weight • | 21.64%                                   | 54.34%<br>Coverage +                     | Coverage Sum<br>Unit:<br>Design Scope •                                    | mary by Des<br>Coverage •                                          |
| Coverage Sum<br>Structure:<br>Design Scope •<br>Int_Reg_tb         | mary by<br>Coverage •<br>54.34% | Coverage S<br>Total Coverage<br>Coverage<br>Type •                           | ummary<br>ge:<br>Bins •            | by Ty<br>Hits              | pe:<br>Misses •      | Weight - | 21.64%<br>%<br>Hit •                     | 54.34%<br>Coverage *                     | Coverage Sum<br>Unit:<br>Design Scope •<br>work.Int_Reg_tb                 | mary by Des<br>Coverage *<br>58.55%                                |
| Coverage Sum<br>Structure:<br>Design Scope •<br>Int_Reg_tb<br>Int  | Coverage •<br>54.34%<br>44.76%  | Coverage S<br>Total Coverage<br>Coverage<br>Type •<br>Statements             | ummary<br>ge:<br>Bins -<br>43      | by Ty<br>Hits •<br>40      | pe:<br>Misses •<br>3 | Weight - | 21.64%<br>%<br>Hit •<br>93.02%           | 54.34%<br>Coverage +<br>93.02%           | Coverage Sum<br>Unit:<br>Design Scope •<br>work Int_Reg_tb<br>work Int_Reg | mary by Des<br><u>Coverage</u> •<br><u>58.55%</u><br><u>44.76%</u> |
| Coverage Summ<br>Structure:<br>Design Scope •<br>Int Reg_th<br>unt | Coverage =<br>54.34%<br>44.76%  | Coverage S<br>Total Coverage<br>Coverage<br>Type •<br>Statements<br>Branches | ummary<br>ge:<br>Bins •<br>43<br>5 | by Ty<br>Hits •<br>40<br>3 | Misses •             | Weight + | 21.64%<br>%<br>Hit •<br>93.02%<br>60.00% | 54.34%<br>Coverage +<br>93.02%<br>60.00% | Coverage Sum<br>Unit:<br>Design Scope •<br>work Int_Reg_tb<br>work Int_Reg | mary by Des<br><u>Coverage</u> •<br><u>58.55%</u><br><u>44.76%</u> |

**Fig -26:** Code coverage report of Integer Register File without fault

| Number of tests                                                                       | run: 1              |                                                                               |                               |                       |                           |          |                                          |                                          |                                                                            |                                                 |
|---------------------------------------------------------------------------------------|---------------------|-------------------------------------------------------------------------------|-------------------------------|-----------------------|---------------------------|----------|------------------------------------------|------------------------------------------|----------------------------------------------------------------------------|-------------------------------------------------|
| Passed:                                                                               | 1                   |                                                                               |                               |                       |                           |          |                                          |                                          |                                                                            |                                                 |
| Warning:                                                                              | 0                   |                                                                               |                               |                       |                           |          |                                          |                                          |                                                                            |                                                 |
| Error:                                                                                | 0                   |                                                                               |                               |                       |                           |          |                                          |                                          |                                                                            |                                                 |
| Fatal:                                                                                | 0                   |                                                                               |                               |                       |                           |          |                                          |                                          |                                                                            |                                                 |
| ist of global attr                                                                    | ibutes included     | in report                                                                     |                               |                       |                           |          |                                          |                                          |                                                                            |                                                 |
| ist of global attr<br>Coverage Sur<br>Structure:                                      | mmary by            | in report<br>Coverage S                                                       | ummary                        | by Ty                 | pe:                       |          |                                          |                                          | Coverage Sum<br>Unit:                                                      | mary by Desi                                    |
| ist of global attr<br>Coverage Sur<br>Structure:                                      | nibutes included.   | Coverage S                                                                    | ummary<br>ge:                 | by Ty                 | pe:                       |          | 20.36%                                   | 53.16%                                   | Coverage Sum<br>Unit:                                                      | mary by Desi;                                   |
| ist of global attr<br>Coverage Sur<br>Structure:<br>Design Scope                      | mmary by            | Coverage S<br>Total Coverage                                                  | ummary<br>ge:<br>Bins •       | by Ty                 | pe:                       | Weight • | 20.36%                                   | 53.16%<br>Coverage •                     | Coverage Sum<br>Unit:<br>Design Scope •                                    | mary by Desi<br>Coverage •                      |
| ist of global attr<br>Coverage Sur<br>Structure:<br>Design Scope<br>Int_Reg_tb        | * Coverage *        | in report<br>Coverage S<br>Total Coverage<br>Type •                           | ummary<br>ge:<br>Bins •       | by Ty<br>Hits         | pe:<br>Misses •           | Weight • | 20.36%<br>%<br>Hit •                     | 53.16%<br>Coverage •                     | Coverage Sum<br>Unit:<br>Design Scope •<br>work.lat_Reg_tb                 | mary by Desi<br>Coverage •<br>57.89%            |
| Coverage Sur<br>Structure:<br>Design Scope<br>Int_Reg_tb<br>junt                      | * Coverage * 53.16% | in report<br>Coverage S<br>Total Coverage<br>Coverage<br>Type •<br>Statements | ummary<br>ge:<br>Bins •<br>44 | by Ty<br>Hits •<br>40 | pe:<br>Misses •<br>4      | Weight - | 20.36%<br>%<br>Hit •<br>90.90%           | 53.16%<br>Coverage +<br>90.90%           | Coverage Sum<br>Unit:<br>Design Scope •<br>work Int_Reg_tb<br>work Int_Reg | mary by Desig<br>Coverage •<br>57.89%<br>41.21% |
| ist of global attr<br>Coverage Sur<br>Structure:<br>Design Scope<br>Int_Reg_th<br>unt | * Coverage * 53.16% | Coverage S<br>Total Coverage<br>Coverage<br>Type •<br>Statements<br>Branches  | ge:<br>Bins •<br>44<br>5      | Hits •<br>40<br>3     | pe:<br>Misses •<br>4<br>2 | Weight • | 20.36%<br>%<br>Hit •<br>90.90%<br>60.00% | 53.16%<br>Coverage •<br>90.90%<br>60.00% | Coverage Sum<br>Unit:<br>Design Scope •<br>work Int Reg th<br>work Int Reg | mary by Desig<br>Coverage =<br>57.89%<br>41.21% |

Fig -27: Code coverage report of Integer Register File with fault

Fig-26and Fig-27 shows code coverage report of Integer Register File without fault and with fault respectively.

## 7. CONCLUSION

This paper contains the brief discussion of RISC-V superscalar processor architecture. The work includes design of functional blocks of the architecture such as I-Cache & Instruction Issuing Unit, INT ALU, D-Cache and Integer Register File. They are designed using Verilog HDL. UVM testbench architecture has been discussed briefly and UVM testbench has been built D-Cache and Integer Register File. Functional blocks are simulated using Xilinx Vivado. Code coverage analysis is performed on the functional blocks using ModelSim SE.

## REFERENCES

- [1] T. Gokulan, A. Muraleedharan and K. Varghese, "Design of a 32-bit, dual pipeline superscalar RISC-V processor on FPGA," 2020 23rd Euromicro Conference on Digital System Design (DSD), Kranj, Slovenia, 2020.
- [2] Suseela Budi, Pradeep Gupta, Kuruvilla Varghese, and Amrutur Bharadwaj, "A RISC-V ISA Compatible

e-ISSN: 2395-0056 p-ISSN: 2395-0072

Processor IP for SoC", International Symposium on Devices, Circuits and Systems (ISDCS) 2018.

- [3] Shraddha M. Bhagat, Sheetal U. Bhandari, "Design and Analysis of 16-bit RISC Processor", Fourth International Conference on Computing Communication Control and Automation (ICCUBEA), 2018.
- [4] Don Kurian Dennis, Ayushi Priyam, Sukhpreet Singh Virk, Sajal Agrawal, Tanuj Sharma, Arijit Mondal, and Kailash Chandra Ray, "Single Cycle RISC-V Micro Architecture Processor and its FPGA Prototype", 7th International Symposium on Embedded Computing and System Design (ISED), 2017.
- [5] Andrew Waterman, "Design of the RISC-V Instruction Set Architecture", PhD thesis, EECS Department, University of California, Berkeley, Jan 2016.
- [6] A. Raveendran, V. B. Patil, D. Selvakumar and V. Desalphine, "A RISC-V instruction set processor-microarchitecture design and analysis," 2016 International Conference on VLSI Systems, Architectures, Technology and Applications (VLSI-SATA), Bangalore, 2016.
- [7] R. Samanth, A. Amin and S. G. Nayak, "Design and Implementation of 32-bit Functional Unit for RISC architecture applications," 2020 5th International Conference on Devices, Circuits and Systems (ICDCS), Coimbatore, India, 2020.
- [8] K. Salah, "A UVM-based smart functional verification platform: Concepts, pros, cons, and opportunities," 2014
   9th International Design and Test Symposium (IDT), Algiers, 2014.
- [9] T. M. Pavithran and R. Bhakthavatchalu, "UVM based testbench architecture for logic sub-system verification," 2017 International Conference on Technological Advancements in Power and Energy (TAP Energy), Kollam, 2017.