

# **4-Bit Arithmetic Logic Unit (ALU) using Verilog**

## **Tools Used**

**Language:** Verilog HDL

**Software/IDE:** Xilinx Vivado

**Kayilainathan J**  
[Linkedin](#)

## Description

This project focuses on the design, implementation, and behavioral simulation of a **4-Bit Arithmetic Logic Unit (ALU)**. The ALU is a purely combinational digital circuit capable of performing eight distinct arithmetic and bitwise logical operations. The design was developed using **Verilog HDL** and validated through the **Xilinx Vivado Design Suite** to ensure logical accuracy across various input stimuli.

## ALU

An **Arithmetic Logic Unit (ALU)** is the fundamental building block of a Central Processing Unit (CPU). It serves as the primary engine for mathematical calculation and logical decision-making within a computer system.

- **Role in CPU:** The ALU receives data from CPU registers, performs an operation based on an "opcode" (selection signal), and outputs the result back to a register.
- **Arithmetic Operations:** It handles fundamental math such as addition and subtraction.
- **Logical Operations:** It performs bitwise comparisons (AND, OR, XOR) and shifts, which are essential for data processing and conditional branching.

## Functional Table

The ALU accepts two 4-bit inputs (a, b) and a 3-bit selector (select).

| Select Code | Operation          | Verilog Operator | Description                            |
|-------------|--------------------|------------------|----------------------------------------|
| 000         | <b>Addition</b>    | $a + b$          | Adds inputs.                           |
| 001         | <b>Subtraction</b> | $a - b$          | Subtracts B from A.                    |
| 010         | <b>AND</b>         | $a \& b$         | Bitwise AND.                           |
| 011         | <b>OR</b>          | $a   b$          | Bitwise OR.                            |
| 100         | <b>XOR</b>         | $a ^ b$          | Bitwise Exclusive OR.                  |
| 101         | <b>NOT</b>         | $\sim a$         | Bitwise Inversion of A.                |
| 110         | <b>Shift Right</b> | $a \gg 1$        | Logical Right Shift<br>(Divide by 2).  |
| 111         | <b>Shift Left</b>  | $a \ll 1$        | Logical Left Shift<br>(Multiply by 2). |

*(Note: If the selection is outside the specified range, the result defaults to 0000).*

## Hardware Architecture (RTL)

The synthesis results confirm a parallel architecture. As seen in the schematic below, the inputs feed into all operation blocks (RTL\_ADD, RTL\_SUB, RTL\_AND, etc.) simultaneously. The RTL\_MUX at the end ensures stable output selection.



# Code

```
41
42
43 module alu_4b(
44     input [3:0] a, //4 bit input
45     input [3:0] b, //4bit input
46     input [2:0] select, //3bit select
47     output reg [3:0] result //4bit result
48 );
49
50     always @(*) begin //@(*) - wave up and runs the block whenever the input changes
51         // combinational logic no clock memory
52         case(select)
53             3'b000: result = a + b; //Addition
54             3'b001: result = a - b; //Subtraction
55             3'b010: result = a & b; //Bitwise AND
56             3'b011: result = a | b; //Bitwise OR
57             3'b100: result = a ^ b; //Bitwise XOR
58             3'b101: result = ~a; //Bitwise NOT
59             3'b110: result = a >> 1; //Right Shift - divides a by 2
60             3'b111: result = a << 1; //Left Shift - multiplies a by 2
61         default: result = 4'b0000; //sets the result to 0000 if the input is not in select range
62     endcase
63 end
64 endmodule
65
```

# Testbench

```
21
22
23 module tb_alu4b();
24     reg [3:0] a;
25     reg [3:0] b;
26     reg [2:0] select;
27
28     wire [3:0] result;
29
30     alu_4b ln(a,b,select,result);
31     initial begin
32         //to display the result in the tcl
33         $monitor("Time=%t | Select=%b | a = %d | b = %d | Result=%b", $time, select, a, b, result);
34
35         a = 0; b = 0; select = 0; #10
36         a = 3; b = 5;
37         select = 3'b000; #10 //addition 3 + 5 = 8
38         a = 5; b = 2;
39         select = 3'b001; #10 //subtraction 5 - 2 = 3
40         select = 3'b010; #10 //AND 0101 & 0010 = 0000
41         select = 3'b011; #10 //OR 0101 & 0010 = 0111
42         select = 3'b100; #10 //XOR 0101 & 0010 = 0111
43         select = 3'b101; #10 //NOT 0101 = 1010
44         select = 3'b110; #10 //Right Shift 0101 >> 1 5/2 = 2 - 0010
45         select = 3'b111; #10 //Left Shift 0101 << 1 5*2 = 10 - 1010
46         $finish;
47     end
48
49 endmodule
50
```

# Console Log

```
# run 1000ns
Time=0 | Select=000 | a = 0 | b = 0 | Result=0000
Time=10000 | Select=000 | a = 3 | b = 5 | Result=1000
Time=20000 | Select=001 | a = 5 | b = 2 | Result=0011
Time=30000 | Select=010 | a = 5 | b = 2 | Result=0000
Time=40000 | Select=011 | a = 5 | b = 2 | Result=0111
Time=50000 | Select=100 | a = 5 | b = 2 | Result=0111
Time=60000 | Select=101 | a = 5 | b = 2 | Result=1010
Time=70000 | Select=110 | a = 5 | b = 2 | Result=0010
Time=80000 | Select=111 | a = 5 | b = 2 | Result=1010
$finish called at time : 90 ns : File "C:/Users/kayil/Projects/Project_ALU/Project_ALU.srccs/sim_1/new/tb_alu4b.v" Line 46
INFO: [USF-XSim-96] XSim completed. Design snapshot 'tb_alu4b_behav' loaded.
INFO: [USF-XSim-97] XSim simulation ran for 1000ns
launch_simulation: Time (s): cpu = 00:00:01 ; elapsed = 00:00:08 . Memory (MB): peak = 4783.660 ; gain = 0.000
```

# Simulation & Analysis

The design was verified using behavioral simulation in Vivado.

**Key Observation: Unsigned vs Signed Output** In the waveform below, the addition of 3 + 5 results in 8 (Binary 1000).

- Unsigned View: 1000 is correctly displayed as 8.



- Signed Context: If interpreted as a 4-bit signed number, 1000 represents -8 (Overflow), as the magnitude exceeds the 4-bit signed limit (+7).



## Constraints

- **Arithmetic Overflow:** Since the output is limited to 4 bits, adding  $a=3$  and  $b=5$  results in 1000. In a 4-bit signed system, the range is **-8 to +7**, meaning the positive result "8" overflows into the negative range.

## Room for Improvement

### 5th Bit Necessity (Signed & Unsigned)

- **The Problem:** In the current 4-bit implementation, adding  $3 + 5$  results in the binary value 1000.
- **Unsigned Issue:** While the mathematical result is **8**, a 4-bit output can only represent up to 15. If a carry occurs at the MSB (e.g.,  $8+9$ ), the data is lost because there is no 5th bit to store the carry-out.
- **Signed Issue:** In 2's complement, 1000 is interpreted as **-8**. Because the result exceeded the 4-bit signed maximum of **+7**, it "overflowed" into the negative range, leading to an incorrect result for positive addition.
- **The Solution:** Expanding the result bus to **5 bits** allows the ALU to capture the carry bit for unsigned math (representing up to 31) and provides the necessary headroom to represent **+8** in signed math without flipping the sign bit.