# Arithmetic & Logic Unit (ALU)

Azael Zamora

San Jose State University

azael.zamora12@gmail.com

Abstract: This report will focus on the design and implementation of a 32-bit Arithmetic and Logic Unit (ALU) using ModelSim simulator. The report will contain the following:

- 1) Installation of ModelSim.
- 2) Implementing the arithmetic & logic unit (ALU) using Verilog HDL.
- 3) Running a simulation by implementing the test bench code to test the ALU.
- Create and observe the single waveforms using the ALU test bench code.

#### I. INSTALLATION OF MODELSIM

The ModelSim simulator program can be dowloaded for free from <a href="https://www.mentor.com/company/higher\_ed/modelsim-student-edition">https://www.mentor.com/company/higher\_ed/modelsim-student-edition</a> from any web browser. Select "Download Student Edition" in order to download the free student version. Open the installation file and complete the installation steps as needed. When the installation is done, a form will appear in the browser, that will require you to provide your name, address, phone number, email, the name of the university. Once the information has been filled out, click "finish". Shortly after, you will receive an email from ModelSim that will contain the license file named "student\_license.dat". The email will also tell you where you will need to save the license file, in order to use the simulator. Once the file has been saved in the appropriate directory, you should now be able to run the ModelSim PE Student Edition.

#### II. PREPARATION OF A PROJECT IN MODELSIM

In order to prepare a project in ModelSim, first we will need to download the .zip file that is provided for this project. Once you unzip the .zip file, the following files should be contained: 'alu.v', 'prj\_definition.v', and 'proj\_01\_tb.v'. For this project you will only need to modify 'alu.v' and 'proj\_01\_tb', do not modify 'prj\_definiton.v'.

Next, open the ModelSim program, and navigate to File > New > Project. The following window should appear:



Once the the project folder has been created, you can add the files to the project. Since the necessary files for the project have been downloaded, use 'Add Existing File' to the files into the project.



Click on the icon "Add Existing File"

You will need to navigate to the directory of the downloaded zip file to select three files in order to add them to the project folder you have created.



Click on "Browse" to find the three files.



Once the files have been added to the project as shown, the next step is compiling all the files in the project folder by pressing the compile button. The files need to be compiled in order for them to run once the implementation is completed. After compiling the files, the simulator can now be started by pressing the simulation button. A separate window will open, and you will need to click on the 'work' library, and will then click on the file 'proj\_01\_tb.v' so that the simulation may start on the correct file.



Under 'work' select 'prj\_01\_tb'

To be able to observe the signal waveforms as the simulator is running, right click on the file 'prj\_01\_tb' and click the option 'Add Wave'.



Click 'Add Wave' to add signal waveforms

To run, reset, or specify how long the simulation should last, the following image will display the buttons for the functions.



The tools to run the simulation.

### III. THE ALU REQUIREMENTS

The ALU (Arithmetic and Logic Unit) provides the basic function of a computer. The ALU is mainly a circuit that can handle the logical operations of the processor like logical AND, NOR, OR, the basic arithmetic operations like addition, subtraction, multiplication, bitwise AND, bitwise OR, and even the logical right and left shifts.

Mathematical and logical functions are often broken down in terms of operands and operations by the ALU. For the purpose of this project, 'op1\_reg' and 'op2\_reg' are used to define the operands, while 'oprn\_reg' is utilized to define the operation. The ALU of this project will take two 32-bit registers 'op1\_reg' and 'op2\_reg', and the operation that will be applied in a 6-bit register 'oprn\_reg' also know as the opcode, and will save the result in a 32-bit register called 'r net'.

#### IV. DESIGNING AND IMPLEMENTING THE ALU

The implementation of the ALU is relatively easy to program the necessary functions using ModelSim. The following section will focus on the design of the ALU using Verilog Hardware Language.

### A. Design

The ALU design is very simple, as it is designed to take in two operators, and an operation and return the result as the output. For this project, the ALU that is built is a 32-bit processor, and each operand is 32-bit, the operand is 6-bit, and the output is 32-bit. All the nine operations that are implemented in this program are defined with 'ALU\_WIDTH\_OPRN'h0X where the X is used to define the specific operation. In the project, 'h03' is multiplication, while the operants are called 'op1' and 'op2' respectively, and the resulting output is referred to as 'golden'.

## B. The Operations that are handled by the ALU

For the purpose of this project, there are nine operations that are handled by the ALU. The following operations are listed along with their implementations:

• 'h01': Addition: golden = op1 + op2

• 'h02': Subtraction: golden = op1 - op2

• 'h03': Multiplication: golden = op1 \* op2

• 'h04': Logical Shift Right: golden = op1 >> op2

• 'h05': Logical Shift Left: golden = op1 << op2

• 'h06': Bitwise AND: golden = op1 & op2

• 'h07': Bitwise OR: golden = op1 | op2

• 'h08': Bitwise NOR: golden =  $\sim$ (op1 | op2)

• 'h09': Set Less Than: golden = op1 < op2

#### V. TESTING STRATEGY AND TESTING IMPLEMENTATION

As the implementation is completed in the file called 'alu.v', the testing of the project is accomplished in the other file called 'prj\_01\_tb.v', which will provide the test cases and

record the results that are necessary to make sure that the design of the ALU is done correctly. By following the instructions from Section II to compile and simulate the program, it is possible to make sure that the ALU was implemented correctly. The following tests are done in which the results named 'golden' from the file 'prj\_01\_tb.v' are compared against the results that are collected from 'alu.v' methods.

#### A. Addition

oprn\_reg = `ALU\_OPRN\_WIDTH'h01 op1\_reg = 10 op2\_reg = 3



The Waveform for Addition

### B. Subtraction

oprn\_reg = 'ALU\_OPRN\_WIDTH'h02 op1\_reg = 10

 $op2\_reg = 3$ 

|                               | Msgs         |               |              |
|-------------------------------|--------------|---------------|--------------|
| /prj_01_tb/total_test         | 32'h00000001 | 32'h00000001  | i            |
| /prj_01_tb/pass_test          | 32'h00000001 | 32'h00000001  |              |
| /prj_01_tb/oprn_reg           | 6'h01        | 6'h01         | (6'h02       |
| <pre>/prj_01_tb/op1_reg</pre> | 32'h0000000a | 32'h00000000a |              |
| <pre>/prj_01_tb/op2_reg</pre> | 32'h00000003 | 32'h00000003  |              |
| /prj_01_tb/r_net              | 32'h0000000d | 32'h0000000d  | (32'h0000000 |
|                               |              |               |              |
|                               |              |               |              |
|                               |              |               |              |
|                               |              |               |              |

The Waveform for Subtraction

# C. Multiplication

oprn\_reg = `ALU\_OPRN\_WIDTH'h03 op1\_reg = 12

op2 reg = 5

| •                                  | Msgs         |              |         |        |
|------------------------------------|--------------|--------------|---------|--------|
| - <pre>/prj_01_tb/total_test</pre> | 32'h00000001 | 32'h00000002 |         |        |
| <pre>-</pre> /prj_01_tb/pass_test  | 32'h00000001 | 32'h00000002 |         |        |
| /prj_01_tb/oprn_reg                | 6'h02        | 6'h02        | (6'h03  |        |
| -🔷 /prj_01_tb/op1_reg              | 32'h0000000a | 32'h0000000a | (32'h00 | 00000c |
| /prj_01_tb/op2_reg                 | 32'h00000003 | 32'h00000003 | (32'h00 | 000005 |
| <pre>/prj_01_tb/r_net</pre>        | 32'h00000007 | 32'h00000007 | 32'h00  | 00003c |
|                                    |              |              |         |        |
|                                    |              |              |         |        |
|                                    |              |              |         |        |
|                                    |              |              |         |        |
|                                    |              |              |         |        |
|                                    |              |              |         |        |

# D. Logical Shift Right

oprn\_reg = `ALU\_OPRN\_WIDTH'h04

 $op1\_reg = 9$ 

 $op2\_reg = 5$ 



The Waveform for Logical Shift Right

# E. Logical Shift Left

oprn\_reg = `ALU\_OPRN\_WIDTH'h05

 $op1\_reg = 8$ 

op2 reg = 3



The Waveform for Logical Shift Left

#### F. Bitwise AND

oprn\_reg = `ALU\_OPRN\_WIDTH'h06

 $op1_reg = 23$ 

 $op2\_reg = 10$ 



The Waveform for Bitwise AND

# G. Bitwise OR oprn\_reg = `ALU\_OPRN\_WIDTH'h07 op1\_reg = 6 op2\_reg = 18



The Waveform for Bitwise OR

# H. Bitwise NOR oprn\_reg = `ALU\_OPRN\_WIDTH'h08 op1\_reg = 8 op2\_reg = 2

| <u>{</u>                       | Msgs         |       |         |         |        |
|--------------------------------|--------------|-------|---------|---------|--------|
|                                | 32'h00000007 | 32'h0 | 0000007 |         |        |
| -//prj_01_tb/pass_test         | 32'h00000007 | 32'h0 | 0000007 |         |        |
|                                | 6'h07        | 6'h07 |         | 6'h08   |        |
| <b>- /</b> /prj_01_tb/op1_reg  | 32'h00000006 | 32'h0 | 0000006 | 32'h00  | 800000 |
| <b>≖</b> -∜ /prj_01_tb/op2_reg | 32'h00000012 | 32'h0 | 0000012 | 32'h00  | 000002 |
| <b></b> /prj_01_tb/r_net       | 32'h00000016 | 32'h0 | 0000016 | 32'hfff | fff5   |
|                                |              |       |         |         |        |
|                                |              |       |         |         |        |
|                                |              |       |         |         |        |
|                                |              |       |         |         |        |
|                                |              |       |         |         |        |
|                                |              |       |         |         |        |
|                                |              |       |         |         |        |

The Waveform for Bitwise NOR

# I. Set Less Than oprn\_reg = `ALU\_OPRN\_WIDTH'h09 op1\_reg = 6 op2\_reg = 14

|              |              |      |          |              |   | _  |
|--------------|--------------|------|----------|--------------|---|----|
|              | Msgs         |      |          |              |   |    |
| o/total_test | 32'h00000008 | 32'h | 0000007  | 32'h00000008 |   |    |
| pass_test    | 32'h00000008 | 32'h | 0000007  | 32'h00000008 |   |    |
| o/oprn_reg   | 6'h08        | 6'h0 | 8        |              | 6 | 'n |
| o/op1_reg    | 32'h00000008 | 32'h | 8000000  |              |   | 2  |
| o/op2_reg    | 32'h00000002 | 32'h | 00000002 |              |   | 2  |
| /r_net       | 32'hfffffff5 | 32'h | ffffff5  |              | 3 | 2  |
|              |              |      |          |              |   |    |
|              |              |      |          |              |   |    |
|              |              |      |          |              |   |    |
|              |              |      |          |              |   |    |

The Waveform for Set Less Than

While the ALU test cases can be displayed by the wavelengths, it can also be represented in text format.

| 32'h  | 32'h     | 32'h0   | 32'h     | 32'h     | 32'h0   | 32'h    | 32'h     | 32'h0    |
|-------|----------|---------|----------|----------|---------|---------|----------|----------|
| 32'h  | 32'h     | 32'h0   | 32'h     | 32'h     | 32'h0   | 32'h    | 32'h     | 32'h0    |
| (6'h0 | 1 (6'h0  | 2 (6'h0 | 3 (6'h0  | 4 (6'h0  | 5 (6'h0 | 6 (6'h0 | 7 (6'h0  | 8 (6'h09 |
| (32'h | 0000000a | (32'h   | (32'h    | 0 ( 32'h | (32'h   | (32'h   | 0 ( 32'h | ) 32'h   |
| (32'h | 00000003 | (32'h   | 00000005 | (32'h    | (32'h   | (32'h   | 0 32'h   | (32'h    |
| 32'h  | 0 (32°h  | (32'h   | (32'h    | 0 ( 32'h | (32'h   | (32'h   | 0 ( 32'h | f ) 32'h |
|       |          |         |          |          |         |         |          |          |
|       |          |         |          |          |         |         |          |          |
|       |          |         |          |          |         |         |          |          |
|       |          |         |          |          |         |         |          |          |
|       |          |         |          |          |         |         |          |          |
|       |          |         |          |          |         |         |          |          |
|       |          |         |          |          |         |         |          |          |

The entire Waveform of the simulation

```
# [TEST] 10 + 3 = 13 , got 13 ... [PASSED]
# [TEST] 10 - 3 = 7 , got 7 ... [PASSED]
# [TEST] 12 * 5 = 60 , got 60 ... [PASSED]
# [TEST] 9 >> 5 = 0 , got 0 ... [PASSED]
# [TEST] 8 << 3 = 64 , got 64 ... [PASSED]
# [TEST] 23 && 10 = 2 , got 2 ... [PASSED]
# [TEST] 6 || 18 = 22 , got 22 ... [PASSED]
# [TEST] 8 ~| 2 = 4294967285 , got 4294967285 ... [PASSED]
# [TEST] 6 < 14 = 1 , got 1 ... [PASSED]
# Total number of tests 9
# Total number of pass 9
# ** Note: $stop : C:/Users/azael/Downloads/prj_01/prj_01
# Time: 95 ns Iteration: 0 Instance: /prj_01 tb
```

The text output of the simulation

#### VI. CONCLUSION

In short, after completing the project, I learned how to use VirtualBox in order to create a virtual machine that is able to boot up Windows. I was also able to install the ModelSim simulator and was able to create a project using Verilog Hardware language. This has enabled me to create a 32-bit ALU, and was able to implement the nine operations defined in the 'CS147 DV'. To conclude, I was able to learn how to use ModelSim, and run the simulations as well as observe the waveforms that were produced.