# Design and Verification of a 16-bit RISC Processor using Universal Verification Methodology (UVM)

<sup>1</sup>Ajit Shridhar Gangad, <sup>2</sup>Prof.C.Prayline Rajabai <sup>1</sup>M.Tech-VLSI Design, <sup>2</sup>Assistant Professor School of Electronics Engineering VIT University, Vellore, India

*Abstract* - This paper presents Design of a 16-Bit RISC Processor supporting Arithmetic ,Logical, Data transfer, Branch instructions such as ADD , MUL , SUB , AND , OR , EXOR , EXNOR , RD , WR , BR , BRZ , NOT , NOP.RISC Processor supporting High Speed , Low Area, Low Power Uniform Carry Select Adder (UCSLA), High Speed 16-bit Hybrid Wallace Tree Multiplier .The Design is synthesized with 45nm library. Physical Design flow is performed with Cadence SoC Encounter. Verification environment is prepared by using Universal verification methodology(UVM) is most widely used methodology by verification industry word wide . Verification environment created in UVM which is reusable, efficient and well structured. The 16-bit RISC processor is a Design under test (DUT).The environment created in UVM is completely wrap a DUT. Assertion coverage is found to be 100% , Code Coverage consists of statement, Branch, Toggle, Expression coverage which is found to be 98.30%.Functional Coverage is obtained by writing cover-groups is found to be 99.87%.

Key Words - System Verilog ,DUT, UVM, Functional Coverage , Assertion Based Verification ,RISC

# **I.INTRODUCTION**

Among all kinds of CPU in use today, the Reduced Instruction Set or RISC CPU has the majority market share. It is most commonly used in embedded systems, which are in almost every consumer products on the market. RISC CPUs are basic in nature and offers low-power consumption and small size. They are sometimes referred to as load-store processor because of the basic mechanics upon which it operates. The idea of RISC CPU is to reduce the complexity of the system and increase the speed. Any complex operation can be split into smaller chucks that can be calculated simultaneously in most cases. Other important features of the RISC CPU include uniform instruction coding, which allows faster coding. A good example is that the op-code is always in the same bit position in each instruction, which is always one word long. Another advantage is a homogeneous register set, which allows any register to be used in any context and simplify compiler design. Lastly, complex addressing modes are replaced by sequences of simple arithmetic instructions. The convenience of the RISC processor is a direct explanation why it dominates the CPU market.

#### **II.ARCHITECTURE**

Reduced instruction-Set computers (RISC) are designed to

have small set of instruction that executes in short clock cycles with small number of cycle per instruction. Machine consists of three functional units: processor ,controller ,memory as shown in Figure 1.

Following steps are performed by this architectures-

[1]fetching instruction from the SRAM

[2]Decoding

[3]Execution

The 16-bit RISC processor having features such as 16-bit Uniform carry select adder (UCSLA) is designed by using single carry skip adder (CSKA) and binary to excess-1 converter (BEC) instead of using one set of ripple carry adder (RCA) to reduce area, power and delay. 16-bit High Speed Hybrid Wallace tree multiplier is configured with the help of novel compressor techniques such as 3:2 compressor, 4:2 compressor.



Figure 1. RISC Processor Architecture

#### A. processor

Processor includes registers, data paths ,control lines and

ALU capable of performing arithmetic and logical operations

on its operands ,subject to op-codes are hold in instruction register. A multiplexer Mux\_1 determine source of data

bound on Bus\_1, second Mux\_2 determine source of data for

Bus\_2.inputs to the Mux\_1 are R0, R1, R2, R3, PC as shown

in architecture .The contents of Bus\_1 can be steered to the

ALU, Mux\_1 and memory unit .Thus, an instruction can be fetched from memory ,placed on Bus\_2, and loaded into instruction register .A word of data can be fetched from

memory ,and steered to GPIO or to the operand register

(Reg\_Y) prior to the operation of ALU .Result of ALU placed in Bus\_2, loaded into a register and subsequently placed in the memory unit. A dedicated register (Reg\_Z) holds a flag indicating that result of ALU operation is 0.

#### B. Controller

Following functions are performed by the control unit-

- 1. Specifying when to load specific register
- 2. Choose multiplexer among the two, depending upon the requirement of specific bus
- 3. Specifying when data to be loaded into the SRAM
- 4. Controlling all buses according to the requirement.

Timing of all activities are determined by controller .Following Table 1 shows the control signals and action corresponding to it.

| Table I Control | Signals and Actions       |
|-----------------|---------------------------|
| Control Signal  | Action                    |
| Load_Add_Reg    | Load the address register |
| Load_PC         | Load Bus_2 to the PC      |
| Load_IR         | Load Bus_2 to the IR      |
| Inc_PC          | Increment PC              |
| Sel_Bus_1_Mux   | Select mux for Bus_1      |
| Sel_Bus_2_Mux   | Select mux for Bus_2      |
| Load_R0         | Load GPIO R0              |

| Load_R1    | Load GPIO R1                |
|------------|-----------------------------|
| Load_R2    | Load GPIO R2                |
| Load_R3    | Load GPIO R3                |
| Load_Reg_Y | Load Bus_2 to Reg_Y         |
| Load_Reg_Z | Stores the output of ALU to |
|            | Reg_Z                       |
| Write      | Memory write                |

# C. ASM Charts

ASM charts in Figure 2 and Figure 3 shows the activities to be performed during execution of each instruction.



Figure 2. ASM Chart for Arithmatic and logical Instruction



Figure 3. ASM Chart for Branch Instructions

### D. INSTRUCTION SET

Instruction set of the RISC processor is divided into two categories short instruction and the long instruction .This can be explained as follows

1) Short instruction (1 byte instruction):: This consisting of most significant 4 bits as op-code and last 4 bit are used for specifying register as shown in Table 2

| Table 2. short Instruction |       |   |   |       |    |             |  |  |  |  |  |  |
|----------------------------|-------|---|---|-------|----|-------------|--|--|--|--|--|--|
| Op-                        | -code |   |   | Sourc | ce | Destination |  |  |  |  |  |  |
| 0                          | 0     | 1 | 0 | 0     | 1  | 1 0         |  |  |  |  |  |  |

Instructions are

- 1. NOP-No any operation
- 2. ADD-Addition of source and destination register and storing data in to the destination register
- 3. SUB- Subtract of source register from destination register and storing data in to the destination register
- 4. AND/OR/EXOR/EXNOR-bitwise operation of source and destination register and stores data in destination register
- 5. NOT-bitwise negation performed

2) Long instruction(2 byte instruction):: This consisting of most significant 4 bits as opcode and afterward 4 bit are used for specifying register and last 8 bits specifies address of memory location as shown in Table 3

|   | Table 3. long Instructions |      |   |   |             |    |     |            |  |  |  |  |  |  |
|---|----------------------------|------|---|---|-------------|----|-----|------------|--|--|--|--|--|--|
|   | Opc                        | code |   |   | destination |    |     |            |  |  |  |  |  |  |
| 0 | 1                          | 1    | 0 | 0 | 1           | Do | n't | Don't care |  |  |  |  |  |  |
|   | 1                          |      |   |   |             | ca | re  |            |  |  |  |  |  |  |
|   | Address                    |      |   |   |             |    |     |            |  |  |  |  |  |  |
| 0 |                            | 0    | 0 | 1 | 1           | 1  | 0   | 1          |  |  |  |  |  |  |

Instructions are

- 1. RD-loads destination register with the address specified by second byte of instruction.
- 2. WR-write source register data into the address specified by second byte of instruction.
- 3. BR-branching occurs by addressing program counter to the SRAM memory
- 4. BRZ- branching occurs by addressing program counter to the SRAM memory if zero flag register asserted list of instruction to be executed as shown in Table 4.

| Instruction | Opcode | src | dest | Action               |
|-------------|--------|-----|------|----------------------|
| NOP         | 0000   | -   | -    | None                 |
| ADD         | 0001   | src | dest | dest<=src+dest       |
| SUB         | 0010   | src | dest | dest<=src-dest       |
| MUL         | 1001   | src | dest | dest<=src*dest       |
| AND         | 0011   | src | dest | dest<=src&dest       |
| NOT         | 0100   | src | dest | dest<=~src           |
| OR          | 1010   | src | dest | dest<= src dest      |
| EXOR        | 1011   | src | dest | dest<= src^dest      |
| EXNOR       | 1100   | src | dest | dest<=~(src^dest)    |
| RD          | 0101   | -   | dest | deat<=memory[Add_R]  |
| WR          | 0110   | src | -    | memory[Add_R]<=src   |
| BR          | 0111   | -   | -    | PC<=memory[Add_R]    |
| BRZ         | 1000   | -   | -    | PC<=memory[Add_R]    |
| HALT        | 1111   | -   | -    | Halt execution until |
|             |        |     |      | reset                |

#### Table 4. All Instructions details

#### Table 5-Synthsis Results

| Area of Design                            | 34833 um2     |
|-------------------------------------------|---------------|
| Number of Gates in Design                 | 9243          |
| Leakage power with low power constraints  | 1098.874 nW   |
| Dynamics power with low power constraints | 866654.321 nW |
| Total power with low power constraints    | 867753.195 nW |
| Operating Frequency                       | 200Mhz        |

#### **III.PHYSICAL DESIGN**

The Designed RISC Processor is synthesized with Cadence RTL Compiler. Synthesis Results are shown in Table 5.

IJEDR1502072

With help of SoC Encounter Physical Design Steps such as Floor-planning, Placement, Pin assignment, Routing are performed. Figure 4 and Figure 5 shows synthesized hardware and Physical design output respectively.



Figure 4. Synthesized Hardware



IV. UVM METHODOLOGY ARCHITECTURE



Figure 6. UVM Architecture

UVM Test Bench :

Test bench of UVM consisting of verification components which can be used to force stimulus to the Design under test(DUT) to check the 16-bit RISC Processor architecture. An UVM architecture is as shown in figure 6.

UVM Verification Components :

1]Design Under Test(DUT)-Design can be described with the help of hardware description language such as Verilog, VHDL which is intended to be verified. DUT describes whole implementation features and functionality of design.

2]Interface- Interface is a connection between DUT and verification environment (monitor and driver). There can be multiple interfaces depending upon number of agents. It is written in System Verilog. Interface is like a bus of wire which converts transactions to pin level data and vice-versa.

3]Virtual Interfaces- It separates abstract models from actual signals of the design. Virtual interface instance can be defined in multiple subprograms of verification environment. It dynamically controls the set of signals associated with subprogram which will pass same set of data to all verification components.

3]Transactions- uvm\_transaction is derived from uvm\_sequence\_item class. In test many data items need to be generated and send to the DUT via driver. Data item fields are randomized using System Verilog constraints. With many number of different constraints different test cases can be created. Communication between sequencer to driver , monitor to subscriber is through transactions

4]Agents –uvm\_agent class is extended from a uvm\_components base class .UVM agent consists of Monitor , sequencer ,Driver. Communication between driver to DUT, DUT to monitor is through pin level interface. Generally DUTs have number of interfaces, each of which has their own protocol. UVM agent provides designer to generate and monitor signal level transactions.

5] Sequencer And Sequence – A sequence class is derived from uvm\_sequence class.uvm\_sequencer class is extended from uvm\_components. uvm\_sequencer controls the flow of transaction generation. uvm\_sequencer does the generation of this sequence of transaction .For different test cases we can write different sequences with the help of constraint randomization. Each sequence is called by sequencer which takes each sequence and converts it into transaction. Further, driver which drives transaction to DUT.

6]Driver – Driver class is formed by extending uvm\_driver base class. Driver takes the transactions from the sequencer by using seq\_item\_port. These transactions will be driven to DUT through interface. Timing information can be written in run phase with the help of different tasks such as resetting of DUT and setting configuration of DUT. An instance of the driver class is created in The agent class and the sequencer is connected to it.

7]Monitor- Monitor class is derived from the uvm\_monitor base class. Instance of monitor is created in agent and connected to the DUT through interface. Basically its functionality is to collects data from interface and convert it into transactions .Converted transactions can be provided to subscriber such as scoreboard through Analysis port.

8]Scoreboard –Scoreboard class is derived from uvm\_scoreboard base class. Scoreboard has 2 analysis imports. One is used to for getting the packets from reference model and other from the monitor analysis port transactions. Packets comparison is carried out with compare function of transaction class and if doesn't match error signal is asserted. Covergroup is written with different coverpoints according to design features. Covergroup is used to define Functional coverage of design.

9]Environment –Environment class is formed with the extension of uvm\_env class which is used to implement verification environments of UVM. Simulation steps such as building components ,connection between the components , starting the components need to be specified, which is possible through uvm\_env base class. It has methods to formalize phases of simulation. All methods are virtual which are extended from environment. virtual sequencer that is used to run sequences . environment is the top level of the class based part of the testbench.

10]Testcases – Different test case scenarios for design are defined in the uvm\_test class. Instance of environment is defined in Test case which defines environment object and defines specific functionality. Physical interface in top module is connected to virtual interface of environment in Test cases.

11]Top Module –Physical interface is instantiated in this top module. Connection between virtual interface and physical interface is defined with configuration database settings. DUT is instantiated and hooked up with interface .Clock generator is also defined here .With the help of run\_test() method we can call all possible test cases . The test name can be passed as a command line argument during simulation which is having more precedence.

### V.UVM CLASS HIERARCHY

Different components in UVM are derived from either uvm\_object or uvm\_components as shown in Figure 7.



Figure 7. UVM Hierarchy

1]Build Phase: This phase is used to build various ports/exports/ class objects by using constructor.

2]Connect Phase: This phase connects all port/exports of various objects/components.

3]End of Elaboration: Configuration of different components is done in this phase.

4]Start of Simulation : To print various messages and topology of environments.

5]Run Phase: This phase is executed by calling task where multiple threads are concurrently called. Timing delays can be inserted in this phase only.

#### VI.VERICATION PLAN

The verification plan defines what exactly needs to be verified. The 16-bit RISC processor is divided into three sub modules such as Control Unit, Memory Unit, Processing Unit. Different test case scenarios for these three sub modules are written in different sequences and are as follows:

A] Test case scenarios for Control Unit:

1]Reset Condition-it should enter to S\_idle state

2]Instruction fetch cycle check -It should enter to S\_fet1 & S\_fet2 state respectively

3]Instruction fetch cycle check -Whether appropriate Control Signal asserted or not

4]Instruction Decode Cycle Check -It should enter to S\_dec state

5]Instruction Decode Cycle Check -Selecting mentioned source register

6]Instruction Decode Cycle Whether appropriate Control Signal asserted or not

7]Instruction Execute Cycle Check -it should enter to S\_ex1 state

8]Instruction Execute Cycle Check -Selecting mentioned Destination register

9]Instruction Execute Cycle Check -Whether appropriate Control Signal asserted or not

10]Instruction fetch cycle check,Instruction decode cycle check,Instruction execute cycle check for ADD,SUB,MUL,AND,NOT,OR,XOR,XNOR,RD,WR,BR, RZ,NOP instructions

B] Test case scenarios for Processing Unit:

1]Loading data from Bus to R0,R1,R2,R3 ,PC,IR ,Reg\_Y , Add\_R,Reg\_Z after Load\_R0, Load\_R1, Load\_R2 , Load\_R3, Load\_PC, Load\_IR, Load\_Y,Load\_Add\_R , Load\_Reg\_Z signals assertions

2]Mux1 should change the channels according to Sel\_Bus\_Mux1 assertions

3]Mux2 should change the channels according to Sel\_Bus\_Mux2 assertions

4]ALU- Perform functionality according to opcode given to it for instructions (ADD,MUL,SUB,AND,OR,EXOR ,EXNOR ,EXNOR,NOT,NOP)

5]ALU-Alu zero flag condition check

6]PC Branching check –instructions BR,BRZ(Branch if alu output is zero)

C] Test case scenarios for Memory Unit:

- 1]A simple testcase to perform one write and read
- 2] Testcase to write 256 successive locations
- 3]Testcase is to demonstrate the simple random
- 4]Single Write Condition
- 5]Single Read operation

6] Multiple Write operation with delay at different conditions

- 7] Multiple Write operation without delay at different conditions
- 8]Multiple read Write operation with delay at different conditions
- 9] Multiple read Write operation without delay at different conditions.

### VII.RESULTS AND DISCUSSIONS

For 16-bit RISC Processor, Instructions and data to be loaded as operand is specified in SRAM memory. One by one instruction is called from the memory and executed in fetch1,fetch2, decode, execute1, execute2 cycles depending upon the type of instruction. Following Figure 8,9,10 shows the Modelsim Simulation output for MUL, RD, BR instructions respectively.



Figure 8.RD Instruction Output

| │ <b>□·☞⊌</b> ७७७।⊁୭隆≌⊇⊇│◎•₩≌┺││                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 🥂 🛧 🛶 🛛                                 | 100         | ps 🕏 🖺 🕅                                | 😫 🌋 🍩   77)                         | ው ው ው - 🚆                               | ) 🔊 🖓 🔜 🖄                               | - 🎯 🗍 🦻                                 | R 5   |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|-------------|-----------------------------------------|-------------------------------------|-----------------------------------------|-----------------------------------------|-----------------------------------------|-------|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                         | <b>_</b>    | 🔹 🕮 🚜 🖻                                 | 1                                   |                                         |                                         |                                         |       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Msgs                                    |             | 7                                       |                                     |                                         |                                         |                                         |       |
| Image: Contract of the second seco | 000000000000000000000000000000000000000 | 0000000000  | 000000000000000000000000000000000000000 | 000 0000000000                      | 000                                     | 0000000xxxxxxx                          | xx (0000000)                            |       |
| Hest_RISC_SPM_modified/M2/M0_Processor/ALU/multiplier/n117/a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 000000000000000000000000000000000000000 | 00000000000 | 000000000000000000000000000000000000000 | 000 0000000000000000000000000000000 | 000000000000000000000000000000000000000 | 000000000000000000000000000000000000000 | 000000000000000000000000000000000000000 | 00000 |
| Hest_RISC_SPM_modified/M2/M0_Processor/ALU/multiplier/n117/b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 000000000000000000000000000000000000000 | 00000000000 | 000000000000000000000000000000000000000 | 000 00000000000                     | 000000000000000000000000000000000000000 | 000000xxxxxxxxx                         | xxx (00000000                           | 00000 |
| #/test_RISC_SPM_modified/M2/M0_Processor/ALU/multiplier/n117/p                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 000000000000000000000000000000000000000 | 00000000000 | 000000000000000000000000000000000000000 | 000 0000000000                      | 000000000000000000000000000000000000000 | 000000xxxxxxxx                          | xxx (00000000                           | 00000 |
| #+                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 000000000000000000000000000000000000000 | 0000000000  | 000000000000000000000000000000000000000 | 0000000                             |                                         |                                         |                                         |       |
| /test_RISC_SPM_modified/M2/M0_Processor/ALU/multiplier/n117/c                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 000000000000000000000000000000000000000 | 00000000000 | 000000000000000000000000000000000000000 | 0000000                             |                                         | و و و و و و                             | المحد بعد                               |       |
| /test_RISC_SPM_modified/M2/M1_Controller/Load_R0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0                                       |             |                                         |                                     |                                         |                                         |                                         |       |
| /test_RISC_SPM_modified/M2/M1_Controller/Load_R1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0                                       |             |                                         |                                     |                                         |                                         | لسواعد                                  |       |
| /test_RISC_SPM_modified/M2/M1_Controller/Load_R2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0                                       |             |                                         |                                     |                                         |                                         | ومعدادهم                                |       |
| /test_RISC_SPM_modified/M2/M1_Controller/Load_R3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0                                       |             |                                         |                                     |                                         |                                         | يصوعه                                   |       |
| /test_RISC_SPM_modified/M2/M1_Controller/Load_PC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0                                       |             |                                         |                                     |                                         |                                         |                                         |       |
| /test_RISC_SPM_modified/M2/M1_Controller/Inc_PC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0                                       |             |                                         |                                     |                                         |                                         |                                         |       |
| Image: Approximate Action of the Action o | 100                                     | (100        | DXXX                                    | (100                                | XXX                                     |                                         | [100                                    |       |
| <pre>/test_RISC_SPM_modified/M2/M1_Controller/Load_Reg_Y</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0                                       |             |                                         |                                     |                                         |                                         |                                         |       |
| /test_RISC_SPM_modified/M2/M1_Controller/Load_Reg_Z                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0                                       |             |                                         |                                     |                                         |                                         |                                         |       |
| /test_RISC_SPM_modified/M2/M1_Controller/Sel_Bus_2_Mux                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 01                                      | 01          | 110                                     | 101                                 | 110                                     |                                         | 01                                      |       |
| /test_RISC_SPM_modified/M2/M0_Processor/Sel_Bus_1_Mux                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 100                                     | 100         | xxx                                     | 100                                 | xxx                                     |                                         | 100                                     |       |
| /test_RISC_SPM_modified/M2/M0_Processor/Sel_Bus_2_Mux                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 120                                     | 01          | ,10                                     | 101                                 | 10                                      |                                         | 01                                      |       |
| + /test_RISC_SPM_modified/M2/M0_Processor/PC_count                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 139                                     | 15          |                                         | ,16                                 |                                         |                                         | ,139                                    |       |
| test_DISC_SDM_modified/M2/M1_Controller/Load_ID                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0                                       | 3           |                                         |                                     |                                         |                                         |                                         |       |
| <pre>/test_RISC_SPM_modified/M2/M1_Controller/Load_IR</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 1                                       |             |                                         |                                     |                                         |                                         |                                         |       |
| /test_PLSC_SPM_modified/M2/M1_controller/ipstruction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 000000001110011                         | 00000000000 | 110001                                  | 100000000                           | 110011                                  |                                         |                                         |       |
| /test_RISC_SPM_modified/M2/M1_Controller/state                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1                                       | 1           | 12                                      | 13                                  | No No                                   | 110                                     | 1                                       |       |
| + /test RISC SPM modified/M2/M1 Controller/next state                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 2                                       | 2           | 3                                       | iq.                                 | 110                                     | 1                                       | 12                                      |       |
| /test_RISC_SPM_modified/M2/M1_Controller/dest                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 111                                     | 01          |                                         | 111                                 | 10                                      |                                         |                                         |       |
| + /test RISC SPM modified/M2/M2 SRAM/data out                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 139                                     | 49          | 1115                                    |                                     | 134                                     | 139                                     |                                         |       |
| +                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 139                                     | 15          | x                                       | 16                                  | ×                                       |                                         | 139                                     |       |
| +                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 134                                     | 14          | 15                                      |                                     | 16                                      | (134                                    |                                         |       |
| /test_RISC_SPM_modified/M2/M2_SRAM/dk                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0                                       |             |                                         |                                     |                                         |                                         | الكار الك                               |       |
| /test_RISC_SPM_modified/M2/M2_SRAM/write                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0                                       |             |                                         |                                     |                                         |                                         | ألاكت وعدم                              |       |
| Now Now                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 2800 pc                                 | a ra che    | a sala conta                            | and transfer                        |                                         |                                         |                                         |       |
| NOW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 2000 ps                                 |             | 500 ps                                  | 510 ps                              | 520 ps                                  | 530 ps                                  | 540 ps                                  | 550   |

Figure 9.BR Instruction Output



Figure 10-256 Location Read Write Operation

For verification point of view, design is divided into three blocks Memory Unit, Control Unit and Processing Unit. Covergroup is written with all possible cover points to get functional coverage. Cross coverage also introduced to cover shared coverpoints. Code coverage consisting of Block coverage, Expression coverage, Toggle coverage and FSM coverage is maximized with various test case scenarios.

1]Memory Unit-First of all for Memory unit earlier mentioned test cases passed. Figure 10 shows questasim simulation output for 256 location write and read operations.

Questasim report shown in Figure 11 shows that, for Memory Unit 100% assertion passed,96 % Code coverage achieved and 100% functional coverage achieved with cover group and cross cover points.

| Questa Co                                                      | op/DU           | V              |           |                  | ^      | Questa Covergroup Coverage Report |                |         |                                     |                                                   |             |                 |            |              |          |  |  |
|----------------------------------------------------------------|-----------------|----------------|-----------|------------------|--------|-----------------------------------|----------------|---------|-------------------------------------|---------------------------------------------------|-------------|-----------------|------------|--------------|----------|--|--|
| Number of texts out                                            |                 | I              | ocal Ins  | stance           | Covera | ige Detail                        | s:             |         | Scope: /mem_test_pkg/mem_scoreboard |                                                   |             |                 |            |              |          |  |  |
| Promoter Octave Tall. 1<br>Passed: 4<br>Weighted Average: 96.0 |                 |                |           |                  |        |                                   | 5.00%          |         | Show All Show Show Missing          |                                                   |             |                 |            |              |          |  |  |
| Error:                                                         |                 |                | Statement | 1                |        | 3 3                               | 0 10           | 0.00%   |                                     | Covergroups / Instances                           |             |                 | Total Bins | Covered Bins | Coverage |  |  |
| Fatal:                                                         | 0               |                | Branch    |                  |        | 2 2                               | 0 10           | 0.00%   |                                     | Covergroup mem fcov1                              |             |                 | 70         | 70           | 100.00%  |  |  |
| List of tests included in                                      | report          |                | Toggle    |                  | 1      | 00 88                             | 12 88          | <u></u> |                                     | Instance <u>Vmem test pkr</u><br>per_instance tru | e scorel    | oard::mem fcovl | 70         | 70           | 100.00%  |  |  |
| [                                                              |                 |                | one       |                  |        |                                   |                |         |                                     |                                                   |             |                 |            |              |          |  |  |
| Coverage Summar                                                | y by Structure: | Coverage Su    | mmary b   | by Type          | e:     |                                   |                |         | 1                                   | Covergroup type:mem fcov                          | 1           | 100.            | 00%        |              |          |  |  |
|                                                                |                 | -              | 52.5      | 151 <u>3</u> 181 |        |                                   |                |         | Ì                                   | Coverpoints / Bins                                | At Least Hi | s Goal Cove     | rage       |              |          |  |  |
| Design Scope 4                                                 | Coverage (%) 4  | Weighted Ave   | rage:     |                  |        |                                   | 77.64%         |         | Ì                                   | Coverpoint: DATA IN                               |             | 100.00% 100.    | 00%        |              |          |  |  |
| top                                                            | 96.03%          | Coverage Ty    | pe 4 B    | Bins 4           | Hits 4 | Misses 4                          | Coverage (%) 4 |         | ľ                                   | Coverpoint: DATA OUT                              |             | 100.00% 100.    | 00%        |              |          |  |  |
| <u>in0</u>                                                     | 88.00%          | Covergroup     |           | 70               | 70     | 0                                 | 100.00%        |         | ľ                                   | Coverpoint: WRITE                                 |             | 100.00% 100     | 00%        |              |          |  |  |
| DUV                                                            | 96.00%          | Statement      |           | 189              | 131    | 58                                | 69.31%         |         | ł                                   | Covernoint: ADDRESS                               |             | 100.00% 100     | 0.096      |              |          |  |  |
| uvm pkg                                                        | 100.00%         | Branch         |           | 78               | 24     | 54                                | 30.76%         |         | ł                                   | Crown CROSS1                                      |             | 100.007.007.00  | 00.70      |              |          |  |  |
| uvm callbacks                                                  | 100.00%         | Toggle         |           | 202              | 178    | 24                                | 88.11%         |         |                                     | <data_in,address></data_in,address>               |             | 100.00% 100.    | 00%        |              |          |  |  |
| uvm phase                                                      | 100.00%         | Assertion Att  | empted    | 40               | 40     | 0                                 | 100.00%        |         |                                     | Cross: CROSS2<br><data in.write=""></data>        |             | 100.00% 100.    | 00%        |              |          |  |  |
| bym component                                                  | 100.00%         | Assertion Fail | ures      | 40               | 10     | -                                 | 0.00%          |         | h                                   | Cross: CROSS3                                     |             |                 |            |              |          |  |  |
| mem test pkg                                                   | 74.26%          | Assertion Suc  | esses     | 40               | 40     | 0                                 | 100.00%        |         |                                     | <data_in,data_out></data_in,data_out>             |             | 100.00% 100.    | 00%        |              |          |  |  |
| mem test seq1<br>mem test seq2                                 | 100.00%         |                |           |                  |        |                                   |                |         |                                     | Cross: CROSS4<br><address.write></address.write>  |             | 100.00% 100.    | 00%        |              |          |  |  |
| mem test seg3                                                  | 100.00%         |                |           |                  |        |                                   |                |         |                                     | Cross: CROSS5                                     |             | 100.00% 100.    | 00%        |              |          |  |  |
| mem test seq4                                                  | 100.00%         |                |           |                  |        |                                   |                |         | l                                   | <write,data_out></write,data_out>                 |             |                 |            |              |          |  |  |
| mem scoreboard                                                 | 100.00%         |                |           |                  |        |                                   |                |         | ſ                                   |                                                   |             |                 |            |              |          |  |  |

Figure 11-Coverage Report for Memory Unit

#### 2]Control Unit-

Testcase scenarios mentioned in the verification plan of Control Unit are passed. Questasim Simulation Output for ADD Instruction fetch, decode, execute cycle is as shown in Figure 12.



# Figure 12-ADD Instruction testcase Output

| Questa Cov                | Scope: / <u>top/DUV</u> |           |           |                                                     |           |             |                  | Scope: / <u>con_test_pkg/con_scoreboard</u> Show All Conserved Mission |                        |                           |          |          |         |          |        |  |
|---------------------------|-------------------------|-----------|-----------|-----------------------------------------------------|-----------|-------------|------------------|------------------------------------------------------------------------|------------------------|---------------------------|----------|----------|---------|----------|--------|--|
| Number of tests run:      | y Instan                | ce:       |           | Covergroups / Instances Total Bins Covered Bins Cov |           |             |                  |                                                                        |                        |                           | Coverage |          |         |          |        |  |
| Passed:                   |                         |           |           | 1                                                   | Lange and |             |                  | Covergroup <u>con_fcov1</u>                                            |                        | 145                       | 144      | 99.62%   |         |          |        |  |
| Warning:<br>Error:        |                         | Scope 4   | TOTAL     | Cvg                                                 | Cover 4   | Statement 4 | Branch 4         | 8                                                                      | Instance Vcon test pkg | con score                 | board:   | con feov | 145     | 144      | 99.62% |  |
| Fatal:                    | 0                       |           | TOTAL     | 100.00%                                             | •         | -           | 100.00%          | 100.00%                                                                | Ļ                      | [ <i>P</i>                |          |          |         |          |        |  |
|                           |                         |           | DUV       | 100.00%                                             | 6         |             | 100.00%          | 100.00%                                                                | 1                      | Covergroup type:con_fcov1 |          |          |         | 99.62%   |        |  |
| List of tests included in | report                  |           | <         |                                                     |           |             |                  | >                                                                      |                        | Coverpoints / Bins        | At Least | Hits     | Goal    | Coverage |        |  |
|                           |                         |           | Done      |                                                     |           |             |                  |                                                                        |                        | Coverpoint: SRC REG       |          |          | 100.00% | 100.00%  |        |  |
| <b>a</b>                  |                         | <u> </u>  |           |                                                     |           |             |                  |                                                                        |                        | Coverpoint: DEST REG      |          |          | 100.00% | 100.00%  |        |  |
| Coverage Summar           | y by Structure:         | Coverage  | e Summai  | y by 1y                                             | pe:       |             |                  |                                                                        |                        | Coverpoint: OPCODE        |          |          | 100.00% | 100.00%  |        |  |
| Design Scone 4            | Coverage (%) 4          | Weighted  | Average:  |                                                     |           |             | 88.24%           |                                                                        |                        | Coverpoint: ADDRESS       |          |          | 100.00% | 100.00%  |        |  |
| top                       | 100.00%                 | Coverage  | Type 4    | Bine 4                                              | Hite 4    | Missos 4    | Coverage (9/     |                                                                        |                        | Coverpoint: ZERO          |          |          | 100.00% | 100.00%  |        |  |
| in 0                      | 100.0000                | Contrage  | T)pc -    | 145                                                 | 144       | 1           | 99.62%<br>80.04% |                                                                        |                        | Coverpoint: WRITE         |          |          | 100.00% | 100.00%  |        |  |
| <u>miv</u>                | 100.00%                 | Covergiou | ф         | 145                                                 | 144       | 1           |                  |                                                                        |                        | Coverpoint: LOAD RO       |          |          | 100.00% | 100.00%  |        |  |
| DUV                       | 100.00%                 | Statement |           | 461                                                 | 369       | 92          |                  |                                                                        |                        | Coverpoint: LOAD R1       | 100.00%  |          | 100.00% |          |        |  |
| uvm_pkg                   | 100.00%                 | Branch    |           | 143                                                 | 88        | 55          | 61.53%           |                                                                        |                        | Coverpoint: LOAD R2       |          |          | 100.00% | 100.00%  |        |  |
| uvm_callbacks             | 100.00%                 | Toggle    |           | 190                                                 | 190       | 0           | 100.00%          |                                                                        |                        | Coverpoint: LOAD R3       |          |          | 100.00% | 100.00%  |        |  |
| uvm_phase                 | 100.00%                 | Assertion | Attempted | 193                                                 | 193       | 0           | 100.00%          |                                                                        |                        | Coverpoint: LOAD_PC       |          |          | 100.00% | 100.00%  |        |  |
| uvm_component             | 100.00%                 | Assertion | Failures  | 193                                                 | 0         | -           | 0.00%            |                                                                        |                        | Coverpoint: <u>INC_PC</u> |          |          | 100.00% | 100.00%  |        |  |
| con test pkg              | 74.02%                  | Assertion | Successes | 193                                                 | 193       | 0           | 100.00%          |                                                                        |                        | Coverpoint: MUX1          |          |          | 100.00% | 100.00%  |        |  |
| con test seal             | 100.00%                 |           |           | JLJL                                                |           |             |                  |                                                                        |                        | Coverpoint: MUX2          |          |          | 100.00% | 100.00%  |        |  |
| con test seg?             | 100.00%                 |           |           |                                                     |           |             |                  |                                                                        | Coverpoint: LOAD IR    |                           |          | 100.00%  | 100.00% |          |        |  |
|                           |                         |           |           |                                                     |           |             |                  |                                                                        |                        | Coverpoint: LOAD ADDR     |          |          | 100.00% | 100.00%  |        |  |
| con_test_seq3             | 100.00%                 |           |           |                                                     |           |             |                  |                                                                        |                        | Coverpoint: LOAD Y        |          |          | 100.00% | 100.00%  |        |  |
| con_test_seq4             | 100.00%                 |           |           |                                                     |           |             |                  |                                                                        |                        | Coverpoint: LOAD Z        |          |          | 100.00% | 100.00%  |        |  |
| con_test_seq5             | 100.00%                 |           |           |                                                     |           |             |                  |                                                                        |                        | Coverpoint: <u>RST</u>    |          |          | 100.00% | 100.00%  |        |  |

Figure 13- Coverage Report for Control Unit

Questasim report shown in Figure 13 shows that, for Control Unit 100% assertion passed,100 % Code coverage achieved and 99.62% functional coverage achieved with cover group and cross cover points.

### 3]Processing Unit-

Testcase scenarios mentioned in the verification plan of Processing Unit are passed. Questasim Simulation Output for AND instruction is as shown in Figure 14

| III                          | 0000000000110000                        | 00000000001100000                       | 1010100011011101                        | 0011101100100111              | 0 100000 10 100 1 100                 | 0110110100111011               |
|------------------------------|-----------------------------------------|-----------------------------------------|-----------------------------------------|-------------------------------|---------------------------------------|--------------------------------|
| /top/DUV/IR/load             | St0                                     |                                         |                                         |                               |                                       |                                |
| /top/DUV/IR/dk               | St1                                     |                                         |                                         |                               | المعار ومحوالا                        |                                |
| Itop/DUV/IR/rst              | St1                                     |                                         |                                         |                               |                                       |                                |
| 📻 🛶 /top/DUV/PC/count        | 000000000000000000000000000000000000000 | 00000000000000000                       | عدعه تصحي الجريبة ومحية و               | والمراجع والمحادية المحادي ال | والمحادثة والمحادة والمحادثة الم      |                                |
| 📻 🍫 /top/DUV/PC/data_in      | 0000000000110000                        | 0000000000110000                        | (1010100011011101                       | 0011101100100111              | <u>)0 100000 10 100 1 100</u>         | 0110110100111011               |
| /top/DUV/PC/Load_PC          | St0                                     |                                         |                                         |                               |                                       | السعية المستقلة                |
| /top/DUV/PC/Inc_PC           | St0                                     |                                         |                                         |                               |                                       |                                |
| /top/DUV/PC/dk               | St1                                     |                                         |                                         | <u> </u>                      | ا ا ا ا ا ا ا ا ا ا ا ا ا ا ا ا ا ا ا | ا <u>کی میں محمد اور میں</u> ا |
| /top/DUV/PC/rst              | St1                                     |                                         |                                         |                               |                                       |                                |
| =// /top/DUV/Mux_1/mux_out   | 1110011111100110                        | 0011011001011001                        | (00000000000000000000000000000000000000 |                               | 0011101100100111                      |                                |
| 🖅 🚽 /top/DUV/Mux_1/data_a    | 1110011111100110                        | 0011011001011001                        | 20000000000000000                       |                               | 0011101100100111                      |                                |
| 🚛 👆 /top/DUV/Mux_1/data_b    | 000000000000000000000000000000000000000 | 0000000000000000                        |                                         |                               |                                       |                                |
| H_ /top/DUV/Mux_1/data_c     | 000000000000000000000000000000000000000 | 0000000000000000                        |                                         |                               |                                       |                                |
| 🚛 🍫 /top/DUV/Mux_1/data_d    | 000000000000000000000000000000000000000 | 000000000000000000000000000000000000000 |                                         |                               |                                       |                                |
| 🚛 👆 /top/DUV/Mux_1/data_e    | 000000000000000000000000000000000000000 | 000000000000000000000000000000000000000 |                                         |                               |                                       |                                |
| +/top/DUV/Mux_1/sel          | 000                                     | 000                                     |                                         |                               |                                       |                                |
| 🚛 🍫 /top/DUV/Mux_2/mux_out   | 0000000000110000                        | 0000000000110000                        | <u>1010100011011101</u>                 | 0011101100100111              | X0 100000 10 100 1 100                | 0110110100111011               |
| 💶 🍫 /top/DUV/Mux_2/data_a    | 1110000100000110                        | 0010010001001000                        | (00000000000000000000000000000000000000 |                               |                                       |                                |
| 😐 🍫 /top/DUV/Mux_2/data_b    | 1110011111100110                        | 0011011001011001                        | (00000000000000000000000000000000000000 |                               | 0011101100100111                      |                                |
| 💻 🔸 /top/DUV/Mux_2/data_c    | 0000000000110000                        | 0000000000110000                        | (1010100011011101                       | )0011101100100111             | 0 100000 10 100 1 100                 | 0110110100111011               |
| =                            | 10                                      | 10                                      |                                         |                               |                                       |                                |
| /top/DUV/ALU/alu_zero_flag   | St0                                     |                                         |                                         |                               |                                       |                                |
| + 🔶 /top/DUV/ALU/alu_out     | 1110000100000110                        | 0010010001001000                        | 000000000000000000000000000000000000000 |                               |                                       |                                |
| + 🔶 /top/DUV/ALU/data_1      | 1110100100010111                        | 0110110001101010                        | 000000000000000000000000000000000000000 |                               |                                       |                                |
| + 🔶 /top/DUV/ALU/data_2      | 1110011111100110                        | 0011011001011001                        | (00000000000000000000000000000000000000 |                               | 0011101100100111                      |                                |
| + 🔶 /top/DUV/ALU/sel         | 0011                                    | 0011                                    | )0000                                   |                               |                                       | استان ومعالية المستان          |
| /top/DUV/ALU/Cout            | St1                                     |                                         |                                         |                               |                                       |                                |
| 💻 🔷 /top/DUV/ALU/alu_out_csa | 1101000011111101                        | 1010001011000011                        | 000000000000000000000000000000000000000 |                               | 0011101100100111                      |                                |
| 🖅 🎝 /top/DUV/ALU/alu_out_mul | *****                                   |                                         |                                         |                               |                                       |                                |
| /top/DUV/ALU/alu_in_wallace  | 11010011001001010                       | 000101110000010000001100                |                                         | 0000000                       |                                       | أككر كالكر المحدية             |
| 🛎 📰 🐵 👘 Now                  | 1890 ns                                 | 240.00 2                                | - 1 · · · · · · · · · · · · · · · · · · | 20.50 220.50 20               | 400 mg 4                              | 10.55 420.55                   |
| C 40 00001                   | 1030                                    | JHO TIS 3.                              | 300 Hs 300 Hs 3.                        | 1011s 36011s 35               |                                       | 10 HS 420 HS                   |

Figure 14-AND Instruction Testcase Output

Questasim report shown on Figure 15 shows that, for Processing Unit 100% assertion passed,98.90 % Code coverage achieved and 100% functional coverage achieved with cover group and cross cover points.

| Questa Coverage      | Questa Coverage Report |                         |                |        |          | 1                            | +           |                         | Quest         | a Coverage Report                              |                   | +     |                 |          |         |
|----------------------|------------------------|-------------------------|----------------|--------|----------|------------------------------|-------------|-------------------------|---------------|------------------------------------------------|-------------------|-------|-----------------|----------|---------|
| Questa Co            | verage R               | eport Statem            | ge Type ৰ      | Bins 4 | Hits  A  | fisses 4 C                   | Coverage (% | 6) •                    | Scope: /      | pro test pkg/p                                 | ro scorel         | oard  |                 |          |         |
|                      |                        | Branch                  |                | 60     | 60       | 0                            | 100.00%     |                         | Show          | All                                            | SI                |       |                 |          |         |
| Number of tests run: | 22                     | FEC Ex                  | pression       | 1898   | 1897     | 1                            | 99.94%      |                         |               | Covered                                        | 1 Mi              | ssing |                 |          |         |
| Passed:<br>Warning:  | Toggle                 |                         | 2808           | 2686   | 122      | 95.65%                       |             | Covergroups / Instances |               |                                                |                   |       | Covered<br>Bins | Coverage |         |
| Error:               | 0                      | Scope                   | Details:       |        |          |                              |             |                         | Covergro      | up pro fcov1                                   |                   |       | 83              | 83       | 100.00% |
| Fatal:               | n report               | Instance<br>/to<br>Done | Path:<br>p/DUV |        |          |                              |             | >                       | Insta<br>⊻pro | nce<br>test pkg::pro_scor<br>[per_instance_tru | eboard::pro<br>ie | fcov1 | 83              | 83       | 100.00% |
| Coverage Summa       | ry by Structure:       | Coverage Sumn           | ary by 1       | ype:   |          |                              |             |                         | Covergro      | up type:pro fcov1                              |                   |       |                 | 100.00%  |         |
| Design Scope 4       | Coverage (%) 1         | Weighted Average        | c              | 1      |          | 90.8                         | 5%          |                         | Cove          | erpoints / Bins                                | At Least          | Hits  | Goal            | Coverage |         |
| top                  | 98.96%                 | Coverage Type 4         | Bins ◀         | Hits 4 | Misses · | <ul> <li>Coverage</li> </ul> | e (%) ◀     |                         | Coverpoi      | nt: INSTRUCTION                                | 1                 |       | 100.00%         | 100.00%  |         |
| <u>in0</u>           | 100.00%                | Covergroup              | 83             | 83     | 1        | 0 100.0                      | 00%         |                         | Coverpoi      | nt: ADDRESS                                    |                   |       | 100.00%         | 100.00%  |         |
| DUV                  | 98.90%                 | Statement               | 1217           | 1107   | 11       | 0 90.9                       | 6%          |                         | Coverpoi      | nt: <u>BUS 1</u>                               |                   |       | 100.00%         | 100.00%  |         |
| uvm_pkg              | 100.00%                | Branch                  | 132            | 1807   | 2        | 58.3                         | 3%          |                         | Coverpoi      | nt: ZFLAG                                      |                   |       | 100.00%         | 100.00%  |         |
| uvm_canbacks         | 100.00%                | Toggle                  | 2074           | 2852   | 12       | 0 05.8                       | 00%         |                         | Coverpoi      | nt MEM WORD                                    |                   |       | 100.00%         | 100.00%  |         |
| uwm_component        | 100.00%                | Assertion Attempt       | ed 171         | 171    | 12       | 0 100 (                      | 0.0%        |                         | Coverpoi      | nt LOAD RO                                     |                   |       | 100.00%         | 100.00%  |         |
| pro test pkg         | 74.55%                 | Assertion Failures      | 171            | 0      |          | - 0.00                       | 0%          |                         | Coverpoi      | nt LOAD R1                                     |                   |       | 100.00%         | 100.00%  |         |
| pro test seq1        | 100.00%                | Assertion Success       | es 171         | 171    | ))       | 0 100.0                      | 00%         |                         | Coverpoi      | nt LOAD R2                                     |                   |       | 100.00%         | 100.00%  |         |
| pro_test_seq2        | 100.00%                | L                       |                |        |          |                              |             |                         | Covernoi      | nt LOAD R3                                     |                   |       | 100.00%         | 100.00%  |         |
| pro_test_seq3        | 100.00%                |                         |                |        |          |                              |             |                         | Coverpoi      | TTLOAD RC                                      |                   |       | 100.00%         | 100.00%  |         |
| pro_test_seq4        | 100.00%                |                         |                |        |          |                              |             |                         | Coverpor      | at INC DC                                      |                   |       | 100.00%         | 100.00%  |         |
| pro test seq5        | 100.00%                |                         |                |        |          |                              |             |                         | Coverpor      | ne <u>inc pc</u>                               |                   |       | 100.00%         | 100.00%  |         |

Figure 15- Coverage Report for Processing Unit

Thus for 16-bit RISC processor on average 100 % assertions are completed, 98.3% Code Coverage achieved and 99.87 % Functional Coverage achieved.

#### VIII.ACKNOWLEDGEMENT

I would like to thank Prof.Prayline Rajabai for her precious and valuable guidance and also VLSI lab, VIT University for Cadence RTL compiler, SoC Encounter, NC Launch software support.

#### **IX.REFERENCES**

[1] Seung Pyo Jung, Jingzhe Xu, Donghoon Lee, Kang-joo Kim, Koon-shik Cho, Ju Sung Park, "Design & Verification of 16 Bit RISC Processor", 2008, IEEE.

[2] Pravin S. Mane, Indra Gupta, M. K. Vasantha,"Implementation of RISC Processor on FPGA",2006,IEEE

[3] Mamun Bin Ibne Reaz, Md. Shabiul Islam, Mohd. S. Sulaiman," A Single Clock Cycle MIPS RISC Processor Design using VHDL".

[4] HE Jing-yu, LI Li-li, ZHU Yan-chao, YANG Wen-tao, and YANG Jian-hong, "Multiply-Accumulator Using Modified Booth Encoders Designed for Application in 16-bit RISC Processor" ,2013 ,IMSNA.

[5] Jinde Vijay Kumar, Boya Nagaraju, Chinthakunta Swapna and Thogata Ramanjappa, "Design and Development of FPGA Based Low Power Pipelined 64-Bit RISe Processor with Double Precision Floating Point Unit", 2014.

[6] C.Vinoth, V. S. Kanchana Bhaaskaran, B. Brindha, S. Sakthikumaran, V. Kavinilavu, B. Bhaskar, M. Kanagasabapathy and B. Sharath"A Novel Low Power and High Speed Wallace Tree Multiplier for RISC Processor", 2011,IEEE

[7] P.Sadhasivam, Dr.M.Manikandan, "Low Area and High Speed Confined Multiplier using Multiplexer based Full Adder", IEEE, 2014

[8] Haihua Shen, Heng Zhang, Tong Xu, "Verification of a Configurable Processor Core for System-on-a-Chip Designs"

[9] K. Jancy Bery, A. Beno, "Design of 64 Bit UCSLA for Low Power VLSI Application", International Journal of Scientific & Engineering Research, Volume 4, Issue 5, May-2013

[10] System Verilog for Verification by Chris Spear

[11] Learning UVM methodology - www.testbench.in

[12] Verification Academy Cookbooks for UVM and System Verilog -www.verificationacademy.com



**Ajit Gangad** was born in Maharashtra,India, in 1990. He received the B.E.Degree in Electronics and Telecommunication Engineering from Vidya Pratishthan's College of Engineering Baramati, Pune University, Maharashtra, India in 2012. He is currently pursuing M.Tech in VLSI Design in Vellore Institute of Technology (VIT) University, Tamil Nadu, India. His area of interest includes Modeling and Simulation of Nanoscale Devices-Multigate FETs, Digital system design, RTL Design with Verilog HDL,RTL verification using UVM.

**Prof.C.Prayline Rajabai** received M.E. degree in the Faculty of Information and Communication Engineering from Anna University, Chennai, India in 2014. She received B.E. degree in Electronics and Communication Engineering from Madurai Kamaraj University, Madurai, India in 2003. Currently, she is working as Assistant Professor in the School of Electronics, VIT University, Vellore, India. Her research interests include FPGA/ASIC Implementation of video compression and encryption algorithms and video processing.