# **Computer Organization, Fall 2013**

Lab 1: 32-bit ALU

Due: 2013/10/21

#### 1. Goal

The goal of this LAB is to implement a 32-bit ALU (Arithmetic Logic Unit). ALU is the basic computing component of a CPU. Its operations include AND, OR, addition, subtraction, etc. This LAB will help you understand the CPU architecture. LAB 1 will be reused; you will use this module in later LABs. The function of testbench is to read input data automatically and output erroneous data. Please unzip the files in the same folder.

## 2. HW Requirement

- a. Please use ModelSim PE Student Edition 10.2c as your HDL simulator.
- b. Please attach your names and student IDs as comments at the top of each file.Please zip the archive and name it as "ID1\_ID2.rar" (e.g., 0016001\_0016002.rar) before uploading to e3.
- c. Testbench module is provided.
- d. Any work by fraud will absolutely get a zero point.
- e. The names of top module and IO ports must be named as follows:

Top module: alu.v

```
module alu (
                                         // negative reset (input)
                rst n,
               src1,
                                         // 32 bits source 1 (input)
               src2,
                                         // 32 bits source 2 (input)
                ALU_control,
                                        // 4 bits ALU control input (input)
                                        // 32 bits result (output)
               result,
                                        // 1 bit when the output is 0, zero must be set (output)
               zero,
               cout,
                                         // 1 bit carry out (output)
               overflow
                                         // 1 bit overflow (output)
             );
```

ALU starts to work when the signal rst\_n is 1, and then catches the data from src1 and

src2. In order to have a good coding style, please obey the rules below:

- . One module in one file.
- . Module name and file name must be the same.

For example: The file "alu.v" only contains the module "alu".

f. instruction set: basic operation instruction (60%)

| ALU action | Name          | ALU control input |
|------------|---------------|-------------------|
| And        | And           | 0000              |
| Or         | Or            | 0001              |
| Add        | Addition      | 0010              |
| Sub        | Subtract      | 0110              |
| Nor        | Nor           | 1100              |
| Nand       | Nand          | 1101              |
| Slt        | Set less than | 0111              |

zcv three control signal : zero  $\, \cdot \,$  carry out  $\, \cdot \,$  overflow (30%)

zero must be set when the result is 0.

cout must be set when carry out.

overflow must be set when overflow.

## 3. Architecture diagram



## 32-bit ALU



Blue frame is 1-bit ALU (Bottom)

## **4. Bonus:** Extra instruction set, will get extra score if you do successfully • (10%)

| ALU action | Name            | ALU control input |
|------------|-----------------|-------------------|
| Slt        | Set less than   | 0111_000          |
| Sgt        | Set great than  | 0111_001          |
| Sle        | Set less equal  | 0111_010          |
| Sge        | Set great equal | 0111_011          |
| Seq        | Set equal       | 0111_110          |
| Sne        | Set not equal   | 0111_100          |

Hint: Add a module named Compare in 1-bit ALU, it needs extra 3-bit control input – Compare\_sel

There is a reference architecture diagram.



## 5. Grade

a. Total: 110 points (plagiarism will get 0 point)

b. Document: 10 points

c. Late submission: 10 points off per day

## 6. Hand in

E3: http://dcpc.nctu.edu.tw/

Please put all the .txt files and project in the same folder, after simulation finishes, you will get some information.

```
| vsim -voptargs=+acc work.testbench
| Loading work.testbench
| Loading work.bit_alu_top
| Loading work.bit_alu_top
| Loading work.bit_alu_bot
| No.12 error!
| No.12 error!
| Currect result: 01111100 | Currect ZCV: 000
| Your result: 7fffffff | Your ZCV: 000
| Your result: 7fffffff | Your ZCV: 000
| Break in Module testbench at C:/Users/kayeoc279/Downloads/9817262/aluu/testbench.v line 130
```

## Partial error

#### All case pass