# ECE 510: Pre-Silicon Validation Laboratory 1



Nilesh Dattani

PSU ID: 958880624



# High Level Block Diagram

clkgen\_driver clkgen(.clk(clk));
alu\_test\_new i1(.clk(clk), reset\_n(reset\_n), .opcode\_valid(opcode\_valid), .opcode(opcode), .data(data), .done(done), .overflow(overflow), result(result), .simulation\_end(simulation\_end));
simple\_alu i2(.clk(clk), reset\_n(reset\_n), .opcode\_valid(opcode\_valid), .opcode(opcode), .data(data), .done(done), .overflow(overflow), result(result));
alu\_chkr chkrl(.clk(clk), reset\_n(reset\_n), .opcode\_valid(opcode\_valid), .opcode(opcode), .data(data), .done(done), .overflow(overflow), result(result), .simulation\_end(simulation\_end));





# Block Diagram with connections at high level



# Assumptions:

- FSM State IDLE should clear the done bit and should not change any other outputs, i.e. hold their values
- ➤ Logical Operators are the lowest level of code writing expected
- > Delay were not accounted for the simulation
- Race conditions could be ignored
- > Arithmetic operations are unsigned operations.



# Observations and Results

- The code was simulated and verified with the tester code provided
- > Transcript and the source codes are provided with the report in the submission folder
- Files were arranged as required and submitted to d2l.pdx.edu

Figure 1: No additional bug introduced

# Individual Bug Checking

Add separate bugs in the DUT and show the transcript that your checker flags errors for rule#1, 4 & 5. Document where you introduced your bugs in the DUT.

1. Bug introduced for rule 1.

```
always@(state) begin

case(state)

RESET : begin
    result = {ALU_SIZE{1'b0}};
    done = FALSE;
    overflow = TRUE;
    end
```

#### Result Observed:



### Result Observed when RULE\_1 disabled:

# 2. Bug Introduced for rule 4

```
module onebitparity(a,b,parity);
input a,b;
output parity;
assign parity = !a^b;
endmodule
```

#### Result Observed:

Result Observed when RULE\_4 disabled

-----SUMMARY-----

## 3. Bug introduced for rule 5



Nilesh Dattani PSU ID: 958880624

```
module NbitFullAdder(a,b,cin,sum,cout);
parameter width = 8;
input [width :1] a,b;
input cin;
output [width:1] sum;
output cout;
wire [width:0]c;

genvar i;
assign c[0]=cin;
]generate
for (i=1;i<=width;i=i+1)
onebitfulladder A(.a(a[i]),.b(b[i]),.cin(c[i-1]),.sum(sum[i]),.cout(c[i]));
endgenerate
assign cout = 'x;</pre>
```

### Result Observed:

### Result Observed when RULE\_5 disabled

Add a bug in the test generator and show the transcript that your checker flags errors for rule#2. Document where you introduced your bug in the test generator



Nilesh Dattani PSU ID: 958880624

# Bug Introduced:

#### Result Observed:

-----SUMMARY-----

```
DATTANI : RESET TEST (RULE_1):PASSED = 131069 FAILED = 0
DATTANI : VALIDITY TEST (RULE_2):PASSED = 5504856 FAILED = 262136
```

### Result Observed when RULE\_2 disabled:

-----SUMMARY------



Nilesh Dattani PSU ID: 958880624

Bonus: Introduce a bug in the DUT and see if you can get your checker to flag an error for rule#3.

# Bug Introduced:

```
COMP
       : begin
       result = result_comp;
                                          IDLE
                                                   : begin
       overflow = FALSE;
                                                   result = result;
       done=done;
                                                  done = TRUE;
       end
                                                   overflow = overflow;
DONE
       : begin
       result = result;
       overflow = overflow;
       done = FALSE;
        end
```

#### **Result Observed:**

-----SUMMARY-----

```
      DATTANI : RESET TEST
      (RULE_1):PASSED = 131069
      FAILED = 0

      DATTANI : VALIDITY TEST
      (RULE_2):PASSED = 2621360
      FAILED = 0

      DATTANI : DONE TEST
      (RULE_3):PASSED = 0
      FAILED = 131068
```

