# LAB Assignment #5 for ECE 443

Assigned: Wed., Sept 30, 2009 Due: Mon., Oct 7, 2009

## Description: Implement the remaining components of the ALU for the microcontrollers.

You built the adder portion of the ALU last lab. This lab will focus on building the remaining components of the ALU, including a Boolean function unit and shifter. The input/output signals to the entire ALU are given as follows:

### Input:

- A, B: input buses (12 bits wide)
- inv\_ins: Invert **B** bits
- and\_ins: AND A and B bits
- or\_ins: OR A and B bits
- xor\_ins: XOR A and B bits
- add\_ins: Add A and B
- sub\_ins: Subtract B from A (A-B)
- shltf\_ins: Shift **B** left by 1 bit
- shrtf\_ins: Shift **B** right by 1 bit
- skwlf\_ins: set *skw\_success* to 1 if register W is less than register F
- skwgf\_ins: set skw\_success to 1 if register W is greater than register F
- skwnf\_ins: set skw\_success to 1 if register W is NOT equal to register F
- skwef\_ins: set ske\_success to 1 if register W is equal to register F
- movf\_ins: pass the B operand to the output unchanged
- movlw\_ins: pass the B operand to the output unchanged

#### **Output**:

- DEST\_OUT: output bus (12 bits wide)
- skw\_success: Boolean (carry-out bit of adder)

Last week, you wrote the AddUnit which took parameters (parameter *skw1* is explained below): ADD\_OUT, A, B, skw1, skwlf\_ins, skwgf\_ins, sub\_ins, add\_ins

For this lab, you will need to build the Boolean function unit and Shifter unit and a parent (ALU) that combines all three modules. The Boolean function unit uses the following parameters (first two are output parameters, others are input):

BOOL\_OUT, skw2, A, B, and\_ins, or\_ins, inv\_ins, xor\_ins, skwnf\_ins, skwef\_ins

The operation of the Boolean function unit is straightforward for the *and\_ins*, *or\_ins*, *inv\_ins*, and *xor\_ins* instructions -- simply carry out the logic operation on the A and B operands in a bitwise fashion. Note that operands A and B are used for the binary logical instructions while ONLY operand B is used for the *inv\_ins* instruction. Use a tri-state to select the logical operation that drives the output bus BOOL\_OUT. For the *skwnf\_ins* (not equal) and *skwef\_ins* (equal), you should XOR the A and B operands and use a reduction OR or NOR (or both) to decide if any of the 12 bits are zero or if they are all zero (dependent on the operation). You can assume that only one of the *xxx\_ins* will be 1 and the others will be 0.

The parameters of the Shifter Unit are (only the first parameter is an output -- others parameters are inputs):

SHIFT\_OUT, B, shltf\_ins, shrtf\_ins, movf\_ins, movlw\_ins

Only operand B is needed as input. SHIFT\_OUT is the output bus. If *shlft\_ins* is 1, then left shift operand B by 1 bit (shifting a '0' in as the new rightmost bit). If *shrtf\_ins* is 1, then right shift operand B preserving the sign bit. If either *movf\_ins* or *movlw\_ins* are 1, then pass the B operand through with NO shifting. Use a tri-state to select the appropriate operation that drives the output bus SHIFT\_OUT. You can assume that only one of the *xxx\_ins* will be 1 and the others will be 0.

In the main module (ALU), you should tri-state the appropriate bus, either ADD\_OUT, BOOL\_OUT or SHIFT\_OUT, to the output bus DEST\_OUT based on the *xxx\_ins* that is set to 1. You can assume that only one of the *xxx\_ins* will be 1 and the others will be 0. You should OR *skw1* and *skw2* to create *skw\_success*.

# Laboratory Report Requirements:

1) Turn in a commented copy of your VHDL code along with a schematic.

2) Write a test bench and run simulation(s) that shows the inputs and output behavior of the circuit (be sure to include a set of 'sample' waveforms in your report).

3) Be prepared to give a demonstration in class on Wed. I will provide the UART driver code to enable you to type values into hyperterminal that will be delivered to the FGPA and converted into numbers. You will enter a decimal number for operand A, hit return, and enter a second number of operand B, hit return, and then you will press one of the pushbutton (or combinations of puttons) to carry out an operation using your ALU. The result of the operation will be automatically displayed in the hyperterminal screen. I will include comments in the code on how to use the driver.

#### Grading:

Your lab grade will consist of two parts. The first part is associated with the in-class demo, and is worth 50% of the total grade (50 pts). Successful demonstration of the lab's stated requirements is worth 50 pts. Partial implementations will be given only partial credit. The second portion of the lab grade is derived from your lab report. Correct implementation counts for 15 pts (of the 50 pts). Well documented simulation results are also worth 15 pts. The remaining 20 pts will be given according to how well the VHDL code is written and documented (comments). Bonus points will be given to any implementation feature that goes above and beyond the requirements.