COE 202, Term 203

 Digital Logic Design

Assignment# 3 Solution

Due date: Sunday, August 1, 2021

# You are required to design and implement an ALU with the following ports:

# A and B are inputs, and are n-bit signed numbers represented in 2’s complement

# F is 3-bit unsigned number for ALU function selector

# R is the signed ALU result represented in 2’s complement. You will have to determine the minimum number of bits required for R such that an overflow never occurs.

# Below is a table of ALU functions along with an illustration of its port interface

|  |  |  |
| --- | --- | --- |
| Function Code | ALU Result |  |
| F=000 | R=A+B |
| F=001 | R=A-B |
| F=010 | R=2\*A + B |
| F=011 | R=2\*A – B |
| F=100 | R=A+1 |
| F=101 | R=A-1 |
| F=110 | R=3\*A |
| F=111 | R=4\*A |

## (5 points) Determine the size of R in bits such that overflow can never occur.

The maximum value of R comes when A and B have the maximum positive value (2n-1-1) and F=111 🡺 R = 4\*(2n-1-1) = 2n+1-4 🡺 needs n+2 bits to represent this value.

The minimum value of R comes when A and B have the minimum negative value (-2n-1) and F=111 🡺 R = 4\*(-2n-1) = -2n+1 🡺 needs n+2 bits to represent this value.

🡺 to avoid overflow, R must have at least n+2-bits

## (10 points) Show the implementation of the ALU using MSI components and the minimum number of additional gates. Hint: you will have to use some form of extension (zero- or sign-extension).



## (10 points) Create behavioral Verilog modules for every MSI component you used in Part (b). Make sure the size of every module you design is parameterized, so that you can change your design easily during the testing phase.

module adder #(parameter w=4) (input [w-1:0] A,B, input Cin, output reg [w-1:0] S, output reg Cout);

 always @(\*)

 begin

 {Cout,S}=A+B+Cin;

 end

endmodule

module mux4to1 #(parameter w=4)( input [w-1:0] I0,I1,I2,I3,input [1:0] Sel, output reg [w-1:0] O);

 always @(\*)

 begin

 case (Sel)

 0: O=I0;

 1: O=I1;

 2: O=I2;

 3: O=I3;

 default: O=0;

 endcase

 end

endmodule

module mux2to1 #(parameter w=4) (input [w-1:0] I0,I1, input S, output [w-1:0] o);

 assign o = (S)? I1:I0;

endmodule

## (5 points) Create a structural model for your ALU designed in Part (b) using the modules you derived in Part (c).

module ALU1 #(parameter n=4) (input [2:0] F, input [n-1:0] A,B, output [n+1:0] R);

wire [n+1:0] m1, m2, m3, m4;

mux2to1 #(n+2) mux1 ({A[n-1],A[n-1],A}, {A[n-1],A,1'b0}, F[1], m1);

mux2to1 #(n+2) mux2 (m3, m4, F[2], m2);

mux2to1 #(n+2) mux3 ({B[n-1],B[n-1],B}, ~{B[n-1],B[n-1],B}, F[0], m3);

mux4to1 #(n+2) mux4 (1, -1, {A[n-1],A[n-1],A}, {A[n-1],A,1'b0}, F[1:0], m4);

adder #(n+2) add1 (m1, m2, !F[2]&F[0], R, Cout);

endmodule

## (5 points) Write a Verilog test bench that tests your ALU module in Part (d) assuming that A and B are 4-bits using the following input values:

|  |  |  |  |
| --- | --- | --- | --- |
| A | B | F | Expected output |
| 4 | 4 | 0 | R=+8 |
| 1 | 2 | 1 | R=-1 |
| 3 | 5 | 2 | R=+11 |
| 3 | 5 | 3 | R=+1 |
| -8 | 0 | 4 | R=-7 |
| -8 | 0 | 5 | R=-9 |
| -8 | 0 | 6 | R=-24 |
| -8 | 0 | 7 | R=-32 |

## Allow a period of 20 ps between two consecutive test cases.

module ALU1tb();

reg [3:0] inA, inB;

reg [2:0] inF;

wire [5:0] outR;

ALU1 test\_m (inF, inA, inB, outR);

initial begin

$dumpfile("dump.vcd");

$dumpvars(1, ALU1tb);

inA=4; inB=4; inF=0;

#20 inA=1; inB=2; inF=1;

#20 inA=3; inB=5; inF=2;

#20 inF=3;

#20 inA=-8; inB=0; inF=4;

#20 inF=5;

#20 inF=6;

#20 inF=7;

#20 ;

end

endmodule

## The results of simulation are given below, which show that the correct output is obtained for all applied inputs:



## (5 points) Write a single behavioral Verilog module that models the given ALU.

module ALU2 #(parameter n=4) (input [2:0] F, input [n-1:0] A,B, output reg [n+1:0] R);

always@ (\*)

begin

case(F)

0: R= {A[n-1], A[n-1], A} + {B[n-1], B[n-1], B};

1: R= {A[n-1], A[n-1], A} - {B[n-1], B[n-1], B};

2: R= {A[n-1], A,1'b0} + {B[n-1], B[n-1], B};

3: R= {A[n-1], A,1'b0} - {B[n-1], B[n-1], B};

4: R= {A[n-1], A[n-1], A} + 1;

5: R= {A[n-1], A[n-1], A} - 1;

6: R= {A[n-1], A,1'b0} + {A[n-1], A[n-1], A};

7: R= {A[n-1], A,1'b0} + {A[n-1], A, 1'b0};

default: R=0;

endcase

end

endmodule

## (5 points) Write a Verilog test bench to test your behavioral ALU model in Part (f). Assuming that A and B are 4-bits, use the following input values:

|  |  |  |  |
| --- | --- | --- | --- |
| A | B | F | Expected output |
| 4 | 4 | 0 | R=+8 |
| 1 | 2 | 1 | R=-1 |
| 3 | 5 | 2 | R=+11 |
| 3 | 5 | 3 | R=+1 |
| -8 | 0 | 4 | R=-7 |
| -8 | 0 | 5 | R=-9 |
| -8 | 0 | 6 | R=-24 |
| -8 | 0 | 7 | R=-32 |

## Allow a period of 20 ps between two consecutive test cases.

module ALU2tb();

reg [3:0] inA, inB;

reg [2:0] inF;

wire [5:0] outR;

ALU2 test\_m (inF, inA, inB, outR);

initial begin

$dumpfile("dump.vcd");

$dumpvars(1, ALU2tb);

inA=4; inB=4; inF=0;

#20 inA=1; inB=2; inF=1;

#20 inA=3; inB=5; inF=2;

#20 inF=3;

#20 inA=-8; inB=0; inF=4;

#20 inF=5;

#20 inF=6;

#20 inF=7;

#20 ;

end

endmodule

## The results of simulation are given below, which show that the correct output is obtained for all applied inputs:



##  (5 points) Submit a report (Word or PDF document) that should contain:

1. Problem description
2. Your answers to Parts (a) and (b)
3. All the behavioral models derived in Part (c), structural model in Part (d), and the test bench in Part (e)
4. The behavioral model in Part (f) and its test bench in Part (g)
5. The timing diagrams (waveforms) taken directly as snapshots from the simulator. Have as many snapshots as needed to cover all the test cases.

The assignment can be solved individually, or in groups of two students. Submit a soft copy of your solution on Blackboard in a zip file including your Verilog models.