```
/* Notes Section Styling */
.note {
  font-weight: bold;
  font-size: 1.1em;
  color: #333;
  padding: 10px;
  background-color: #f8f9fa;
  border-left: 4px solid #007bff;
  margin: 15px 0;
}

.note ul {
  margin-top: 5px;
  padding-left: 20px;
}
```

# **ALU Verification Assignment**

Submitted to: Eng. Nour ElDeen ElHout

By: Amira Atef, Aya El Desouky and Mohamed Ayman



#### Note

This repo doesn't verify the shift and rotate operations due to the purpose of their exact functions being unclear.

Two files are included:

- **ALU\_1**: Verifies the ALU design in one testbench file.
- ALU\_2: Contains the testbench done using the SV Architecture.

#### **Table of Contents**

- 1. Signals Definition
- 2. **ALU Operations**
- 3. Verification Environment Architecture
- 4. Wave Diagrams
- 5. Verification Plan
- 6. QuestaSim Transcript Output
- 7. QuestaSim Waveforms and Discovered Bugs
- 8. Bug 1 (SUB Operation):
- 9. Bug 2 (SUB w/ Borrow Operation):
- 10. Bug 3 (SEL Operation):
- 11. Bug 4 (Valid out value in case of XOR Operation):

- 12. Bug 5 (INVALID Operations):
- 13. Bug 6 (Zero Flag Value):
- 14. Code Coverage Report
- 15. Statement Coverage
- 16. Branch Coverage
- 17. Toggle Coverage
- 18. Functional Coverage Report
- 19. Assertions and Cover Directives

# **Signals Definition**

| Name      | Direction | Length | Description             |
|-----------|-----------|--------|-------------------------|
| clk       | input     | 1 bit  | Clock                   |
| reset     | input     | 1 bit  | Active low async. reset |
| valid_in  | input     | 1 bit  | validate input signals  |
| а         | input     | 4 bits | port A                  |
| b         | input     | 4 bits | port B                  |
| cin       | input     | 1 bit  | carry in                |
| ctl       | input     | 4 bits | opcodes                 |
| valid_out | output    | 1 bit  | validate input signals  |
| alu       | output    | 4 bits | alu output              |
| carry     | output    | 1 bit  | carry out               |
| zero      | output    | 1 bit  | zero flag output        |

## **ALU Operations**

| OP Code | Function                                    |
|---------|---------------------------------------------|
| 4′b0000 | Select data on port B                       |
| 4'b0001 | Increment data on port B                    |
| 4′b0010 | ·                                           |
| 4′b0010 | Decrement data on port B  ADD without CARRY |
| 100011  |                                             |
| 4′b0100 | ADD with CARRY                              |
| 4'b0101 | SUB without BORROW                          |
| 4'b0110 | SUB with BORROW                             |
| 4'b0111 | AND                                         |
| 4'b1000 | OR                                          |
| 4'b1001 | XOR                                         |
| 4'b1010 | Shift left                                  |
| 4'b1011 | Shift right                                 |
| 4'b1100 | Rotate left                                 |
| 4'b1101 | Rotate right                                |



Figure 1: ALU Operations

## **Verification Environment Architecture**



Figure 2: Verification Arichitecture

# **Wave Diagrams**



Figure 3: Reset



Figure 4: Valid\_in



Figure 5: ALU Operations

| Label | Description                                                                                                    | Stimulus Generation                                                                                                                                            | Functional Coverage                                                                                                                        | Functionality<br>Check                                                    |
|-------|----------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|
| ALU_1 | When the reset is<br>deasserted, the<br>outputs values should<br>be low.                                       | Directed at the start of the simulation, then randomized with constraint that drive the reset to be off(high) most of the simulation time.                     | -                                                                                                                                          | A checker in<br>the testbench<br>to make sure<br>the output is<br>correct |
| ALU_2 | Verifying extreme values on a and b, with OPCODE = ADD, SUB, ADD_c or SUB_b.                                   | Randomization under constraints on the a and b signals to take values (MAX and ZERO) most of the simulation time.                                              | Covered the extreme values, the rest of the values and walking ones for both a and b. Covered the ADD, SUB, ADD_c and SUB_b opcode values. | A checker in<br>the testbench<br>to make sure<br>the output is<br>correct |
| ALU_3 | When OPCODE = 0 or<br>1 or 2 the operations<br>are solely done on<br>input b.                                  | Randomization under constraints on signal b to take values (MAX and ZERO) most of the simulation time.                                                         | Covered the SEL, INC and DEC opcode values.                                                                                                | A checker in the testbench to make sure the output is correct             |
| ALU_4 | When OPCODE = AND, OR or XOR, the output out value must be the ANDing, ORing or XORing of a and b.             | Randomization under constraints on the input B most of the time to have one bit high in its 3 bits while constraining the A to be low.                         | Covered the AND, OR and XOR opcode values.                                                                                                 | A checker in the testbench to make sure the output is correct             |
| ALU_5 | When OPCODE = SHIFT_L, SHIFT_R, ROTATE_L or ROTATE_R, the output value must be shifted or rotated accordingly. | Randomization under constraints on the inputs a and b when opcode= shift or rotate, do not constraint the inputs a or b when the operation is shift or rotate. | Covered the SHIFT_L, SHIFT_R, ROTATE_L and ROTATE_R values for the opcode.                                                                 | A checker in<br>the testbench<br>to make sure<br>the output is<br>correct |
| ALU_6 | When OPCODE is !=<br>ADD, SUB, ADD_c or<br>SUB_b, carry signal<br>must be low.                                 | Randomization under constraints on the opcode to be anything but ADD, SUB, ADD_c or SUB_b, do not constraint the inputs a or b.                                | Covered the SEL, INC, DEC, AND, OR, XOR, SHIFT_L, SHIFT_R, ROTATE_L and ROTATE_R values for the opcode.                                    | A checker in the testbench to make sure the output is correct             |

| Label   | Description                                                                                         | Stimulus Generation | Functional Coverage                                                                                                 | Functionality<br>Check                                                    |
|---------|-----------------------------------------------------------------------------------------------------|---------------------|---------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|
| ALU_7   | When alu= 4'b0 and carry = 1'b0, zero flag should be 1.                                             | Randomization       | -                                                                                                                   | A checker in<br>the testbench<br>to make sure<br>the output is<br>correct |
| ALU_8   | When Valid_in = 0,<br>input is not valid, so<br>output values don't<br>change and valid_out<br>= 0. | Randomization       | Covering valid inputs and outputs.                                                                                  | A checker in<br>the testbench<br>to make sure<br>the output is<br>correct |
| ALU_9   | When Valid_in = 1,<br>input is valid, so<br>output values adjust<br>and valid_out = 1.              | Randomization       | Covering valid inputs and outputs.                                                                                  | A checker in<br>the testbench<br>to make sure<br>the output is<br>correct |
| ALU_10  | When OPCODE = 14<br>or 15. output stays the<br>same and valid_out =<br>0.                           | Randomization       | Covering ctl values that aren't opcodes.                                                                            | A checker in<br>the testbench<br>to make sure<br>the output is<br>correct |
| CROSS 1 | a, b at ADD, SUB,<br>ADD_c or SUB_b.                                                                | Randomization       | When the ALU is addition or subtraction, a and b should have taken all permutations of maxpos and zero.             | Output<br>Checked<br>against<br>reference<br>model.                       |
| CROSS 2 | cin                                                                                                 | Randomization       | When the ALU is addition w/ carry or subtracition w/ carry, cin should have taken 0 or 1                            | Output Checked against reference model.                                   |
| CROSS 3 | a, b at OR & XOR &<br>AND                                                                           | Randomization       | When the ALU is AND,<br>OR or XOR, then a<br>and b take all walking<br>one patterns (0001,<br>0010, 0100 and 1000). | Output Checked against reference model.                                   |

| Label              | Description                                                                                                                                      | Stimulus Generation | Functional Coverage                                                                                   | Functionality<br>Check                              |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|-------------------------------------------------------------------------------------------------------|-----------------------------------------------------|
| CROSS 4            | a, b at OR & XOR &<br>AND                                                                                                                        | Randomization       | When the ALU is AND,<br>OR or XOR, then a<br>and b take all ones<br>and all zeroz (0000<br>and 1111). | Output Checked against reference model.             |
| Reference<br>model | when the randomized inputs enter it, the output should be accurately equal to correct output of the design                                       | Randomization       | -                                                                                                     | Output<br>Checked<br>against<br>reference<br>model. |
| Check<br>Result    | when the expected values from the golden model are not equal to the outputs of the DUT, the error_count increased, else correct_count increased. | Randomization       | -                                                                                                     | Output<br>Checked<br>against<br>reference<br>model. |

#### **QuestaSim Transcript Output**

```
Incorrect zero IIag:,
                                  9900000
** Error: Assertion error.
   Time: 9970 ns Started: 9960 ns Scope: alu top.dut.SVA inst File: alu SVA.sv Line: 142
                             9975000
Incorrect alu!,
** Error: Assertion error.
  Time: 9980 ns Started: 9970 ns Scope: alu_top.dut.SVA_inst File: alu_SVA.sv Line: 28
** Error: Assertion error.
  Time: 9980 ns Started: 9970 ns Scope: alu_top.dut.SVA_inst File: alu_SVA.sv Line: 142
Incorrect valid_out!,
                                  9985000
** Error: Assertion error.
   Time: 9990 ns Started: 9980 ns Scope: alu_top.dut.SVA_inst File: alu_SVA.sv Line: 156
** Error: Assertion error.
   Time: 9990 ns Started: 9980 ns Scope: alu_top.dut.SVA_inst File: alu_SVA.sv Line: 142
Incorrect zero flag!,
                                  9995000
** Error: Assertion error.
   Time: 10 us Started: 9990 ns Scope: alu_top.dut.SVA_inst File: alu_SVA.sv Line: 142
Incorrect zero flag!,
                                 10005000
The simulation has been finished: Error Count = 992, Correct Count = 10
** Note: $stop
                : alu_monitor.sv(91)
   Time: 10005 ns Iteration: 2 Instance: /alu_top/monitor
Break in Module alu_monitor at alu_monitor.sv line 91
```

Figure 6: Transcript

#### **QuestaSim Waveforms and Discovered Bugs**

#### **Bug 1 (SUB Operation):**

• We can see that when the SUB operation is performed between 11 and 5 as highlighted below, the golden module produces the correct result which is 6 while the ALU produces an incorrect result which is 7.



Figure 7: Waveform Snippet 1

#### Bug 2 (SUB w/ Borrow Operation):

-We can see that when the SUB with borrow operation is performed between 15 and 9 with cin = 0 as highlighted below, the golden module produces the correct result which is 6 while the ALU produces an incorrect result which is 5.



Figure 8: Waveform Snippet 2

#### **Bug 3 (SEL Operation):**

-We can see that when the SEL operation is performed with b = 10 as highlighted below, the golden module produces the correct result which is 10 (selects the value of b) while the ALU produces an incorrect result which is 7 (selects the value of a).



Figure 9: Waveform Snippet 3

## Bug 4 (Valid out value in case of XOR Operation):

• We can see that when the XOR operation is performed with a = 14 and b = 15 as highlighted below, BOTH the ALU and the golden module produce the correct result which is 1, however the value of the valid out in the ALU is 0 which is incorrect while the value of the valid out in the golden module is 1 which is correct.



Figure 10: Waveform Snippet 4

## **Bug 5 (INVALID Operations):**



Figure 11: Waveform Snippet 5



Figure 12: Waveform Snippet 6

# **Code Coverage Report**

## **Statement Coverage**

```
Statements - by instance (/alu_top/dut)
-- alu.sv
              6 assign clk = intf.clk;
              7 assign reset = intf.reset;
             8 assign a = intf.a;
             9 assign b = intf.b;
             10 assign cin = intf.cin;
             11 assign ctl = intf.ctl;
             12 assign valid in = intf.valid in;
             25 assign result = alu_out(a,b,cin,ctl);
             26 assign zero result = z flag(result);
             28 always@(posedge clk, negedge reset) begin
             30 valid out R <= 0;
             31 valid out
                            <= 0;
             32 alu
                            <= 0;
             33 carry
                            <= 0;
             34 zero
                            <= 0;
             37 valid out R <= valid in;
             39 valid out <= ~valid in;
             42 valid out <= valid out R;
             45 valid out <= valid in;
             48 alu <= result[3:0];
             49 carry <= result[4];
             50 zero <= zero result;
             59 4'b00000: alu out=a;
             60 4'b0001: alu_out=b+4'b0001;
             61 4'b0010: alu out=b-4'b0001;
             62 4'b0011: alu_out=a+b;
             63 4'b0100: alu_out=a+b+cin;
             64 4'b0101: alu_out=a-b+1 ;
             65 4'b0110: alu_out=a-b+(~cin);
             66 4'b0111: alu_out=a&b;
            67 4'bl000: alu out=a|b;
            68 4'bl001: alu out=a^b;
   -E
            69 4'bl010: alu out={b[3:0],1'b1};
   —3
            70 4'b1011: alu_out={b[0],1'b0,b[3:1]};
   —E
            71 4'b1100: alu out={b[3:0],cin};
   —3
            72 4'bl101: alu_out={b[0],cin,b[3:1]};
            74 alu out=9'bxxxxxxxxx;
            75 $display("Illegal CTL detected!!");
            82 z_{flag} = ^(a4[0]|a4[1]|a4[2]|a4[3]);
```

Figure 13: Statement Coverage

#### **Branch Coverage**

```
Branches - by instance (/alu_top/dut)
- alu.sv
             29 if(reset == 0) begin
             36 else begin
             38 if(ctl == 4'b1001) begin
             41 else if(ctl == 4'b0110) begin
             44 else begin
             47 if (valid in) begin
             59 4'b00000: alu out=a;
             60 4'b0001: alu out=b+4'b0001;
             61 4'b0010: alu out=b-4'b0001;
             62 4'b0011: alu out=a+b;
             63 4'b0100: alu out=a+b+cin;
             64 4'b0101: alu_out=a-b+1;
             65 4'b0110: alu_out=a-b+(~cin);
             66 4'b0111: alu out=a&b;
             67 4'b1000: alu_out=a|b;
             68 4'b1001: alu out=a^b;
     - 3
             69 4'b1010: alu_out={b[3:0],1'b1};
    -E
             70 4'b1011: alu_out={b[0],1'b0,b[3:1]};
    -0
             71 4'b1100: alu_out={b[3:0],cin};
     -E
             72 4'b1101: alu_out={b[0],cin,b[3:1]};
             73 default : begin
```

Figure 14: Branch Coverage

#### **Toggle Coverage**



Figure 15: Toggle Coverage

#### **Functional Coverage Report**





Figure 16: Functional Coverage Report

#### **Assertions and Cover Directives**



Figure 17: Assertions



Figure 18: Cover Directives