Alex Oswald EECE 2323

Due: 29 Sep 2020

## Pre-Lab Assignment 2

## **Simulation Screenshot:**



## **Verilog Code for Parial ALU:**

```
    module eightbit_palu(

2.
3.
        input signed[7:0] a,
4.
        input signed[7:0] b,
5.
        input [1:0] s,
6.
        output reg [7:0] f,
7.
        output reg ovf);
8.
9.
        wire [7:0] op1; // a + b
        wire [7:0] op2; // bitwise inversion of b
10.
        wire [7:0] op3; // bitwise AND of a and b
11.
12.
        wire [7:0] op4; // bitwise OR of a and b
13.
14.
        assign op1 = a + b;
15.
        assign op2 = ~b;
16.
        assign op3 = a & b;
17.
        assign op4 = a \mid b;
18.
19.
        always @(s or op1 or op2 or op3 or op4)
```

```
20. case(s)
21.
                 2'b00: begin
22.
                     f = op1;
23.
                     ovf = (a[7] \&\& b[7] \&\& \sim f[7]) \mid | (\sim a[7] \&\& \sim b[7] \&\& f[7]);
24.
25.
                 2'b01: begin
                     f = op2;
26.
                     ovf = 0;
27.
28.
                 end
                 2'b10: begin
29.
                     f = op3;
30.
31.
                     ovf = 0;
32.
                 end
33.
                 2'b11: begin
34.
                     f = op4;
                     ovf = 0;
35.
36.
                 end
37.
                 default: begin
                     f = 0;
38.
39.
                     ovf = 0;
40.
41.
             endcase
42.
43. endmodule
```

## **Verilog Code for Testbench:**

```
1. module palu_unit_tb ();
2.
       // Inputs
3.
        reg signed [7:0] a;
4.
       reg signed [7:0] b;
5.
       reg [1:0] s;
6.
       // Outputs
       wire signed [7:0] f;
7.
8.
       wire ovf;
9.
       // Initiate the Unit Under Test (UUT)
10.
11.
       eightbit_palu uut (
12.
           .a(a),
           .b(b),
13.
           .s(s),
14.
15.
           .f(f),
16.
           .ovf(ovf));
17.
18.
       // Initialize Inputs (stimulus)
19.
        initial
20.
       begin
21.
           #0
22.
           a = 8'd0; b = 8'd0; s = 0; #10;
23.
           a = 8'd5; b = 8'd6; s = 0; #10;
24.
           a = -8'd100; b = 8'd25; s = 0; #10;
25.
           a = 8'd100; b = 8'd100; s = 0; #10;
           a = -8'd100; b = -8'd100; s = 0; #10;
26.
27.
           a = 8'd75; b = 8'd100; s = 0; #10;
28.
29.
30.
           a = -8'd1; b = 8'd0; s = 1; #10;
31.
           a = 8'd0; b = -8'd1; s = 1; #10;
32.
           a = 8'd1; b = 8'd1; s = 1; #10;
33.
```