

Assignment No- 01

Title : 4 bit ALU Simulation and Hardware  
Implementation

Course No: CSE 306

Course Name: Computer Architecture Sessional

Submitted By -

Group B2 - Group 01

1805091

1805093

1805105

1805106

1805111

Date : June, 2022

### Introduction:

An Arithmetic Logic Unit (ALU) is a multi-operation, combinational logic digital function. It can perform a set of basic arithmetic operations and a set of logical operations. The ALU has a number of selection lines to select a particular operation in the unit. The selection lines are decided within, so that  $k$  selection variables can specify upto  $2^k$  distinct operations.

In our experiment, we have three selection variables ( $cs_2, cs_1, cs_0$ ) which enable us to perform 8 distinct operations. A combinational circuit is prepared to modify the data inputs ( $A$  and  $B$ ) to produce the inputs ( $X, Y, T$ ) for the parallel adders to get the desired output bits ( $F$ ).

In our demonstration,  $cs_2$  signifies the carry input and  $cs_1$  acts as the mode selector.

A 4bit status register is used to understand changes during arithmetic operations. They are C (carry), S (sign), V (overflow) and Z (zero). These

4 bits indicates -

- ① C : Set when output (unsigned) carry is 1, unset otherwise.
- ② S : Set when the MSB of the output is set and unset otherwise.
- ③ V : Set when the output / result overflows. This is the signed overflow which we got by XOR-ing the two most significant carries.
- ④ Z : Set when the result is zero, unset otherwise.

## Problem Specifications with assigned instructions

Design and demonstration of a 4bit ALU with three selection bits which performs the following operations:

| cs2(cin) | cs 1 | cs0 | function             |
|----------|------|-----|----------------------|
| 0        | 0    | 0   | Subtract with borrow |
| 0        | 0    | 1   | Decrement A          |
| 1        | 0    | 0   | Subtract             |
| 1        | 0    | 1   | Transfer A           |
| X        | 1    | 0   | AND                  |
| X        | 1    | 1   | XOR                  |

## Detailed Design Steps with KMap

① For a 4-bit ALU, a 4-bit parallel adder is to be used. IC 7483 serves that purpose but it cannot be directly used as the carry propagation happens internally and we do not have access from outside to change it. The reason we need to change it is for logical operations we want to keep them off.

As a solution, two 7483 were used to simulate a 4-bit adder with access to the carry propagation. How that works is demonstrated below.



① The combinational circuit is designed on the basis of the truth table formulated in the next section of the report. The truth table minimizes the equation for  $x_i, y_i, z_i$ , the adder inputs of 4bit ALU. All of them are functions of  $A_i, B_i, C_i, cs_2, cs_1$  and  $cs_0$ .

| $cs_2(cin)$ | $cs_1$ | $cs_0$ | function     | $x_i$        | $y_i$                          | $z_i$ |
|-------------|--------|--------|--------------|--------------|--------------------------------|-------|
| 0           | 0      | 0      | $A - B - 1$  | $A_i$        | $B_i'$                         | $C_i$ |
| 0           | 0      | 1      | $A - 1$      | $B_i A_i$    | <del><math>B_i'</math></del> 1 | $C_i$ |
| 1           | 0      | 0      | $A - B$      | $A_i$        | $\oplus B_i'$                  | $C_i$ |
| 1           | 0      | 1      | $A$          | $A_i$        | 1                              | $C_i$ |
| X           | 1      | 0      | $AB$         | $A_i + B_i'$ | $B_i'$                         | 0     |
| X           | 1      | 1      | $A \oplus B$ | $A_i$        | $B_i$                          | 0     |

K-Map for  $x_i$  :



K Map for  $y_i$ :

|                |   | B <sub>i</sub> |    |    |    |
|----------------|---|----------------|----|----|----|
|                |   | 00             | 01 | 11 | 10 |
| B <sub>i</sub> | 0 | 1              | 1  | 0  | 1  |
|                | 1 | 0              | 1  | 1  | 0  |

$$\begin{aligned}y_i &= m_0' s_0 + s_0' B_i' + s_0 B_i \\&= \overline{s_0 \oplus B_i} + s_0' s_0 \\&= s_0 \oplus B_i' + s_0' s_0\end{aligned}$$

K Map for  $z_i$ :

|                |   | B <sub>i</sub> |    |    |    |
|----------------|---|----------------|----|----|----|
|                |   | 00             | 01 | 11 | 10 |
| B <sub>i</sub> | 0 | 0              | 0  | 0  | 0  |
|                | 1 | 1              | 1  | 0  | 0  |

$$Z_i = s_1' C_i$$

## Truth Table :

| $cs_2(cin)$ | $cs_1$ | $cs_0$ | $x_i$        | $y_i$  | $g_i$ | $F_8$        | $F$ | Description          |
|-------------|--------|--------|--------------|--------|-------|--------------|-----|----------------------|
| 0           | 0      | 0      | $A_i$        | $B_i'$ | $C_i$ | $A - B - 1$  |     | Subtract with borrow |
| 0           | 0      | 1      | $A_i$        | 1      | $C_i$ | $A - 1$      |     | Decrement A          |
| 1           | 0      | 0      | $A_i$        | $B_i'$ | $C_i$ | $A - B$      |     | Subtract             |
| 1           | 0      | 1      | $A_i$        | 1      | $C_i$ | $A$          |     | Transfer A           |
| X           | 1      | 0      | $A_i + B_i'$ | $B_i'$ | 0     | $AB$         |     | AND                  |
| X           | 1      | 1      | $A_i$        | $B_i$  | 0     | $A \oplus B$ |     | XOR                  |

## Block Diagram:



ICs used with count as Charf:

| IC   | Gate       | Count |
|------|------------|-------|
| 7404 | NOT        | 1     |
| 7408 | AND        | 3     |
| 7432 | OR         | 3     |
| 7483 | 4bit Adder | 2     |
| 7486 | XOR        | 2     |

Simulator Used

Logisim - generic - 2.7.1

Discussion

While implementing the circuit we had to change our design several times to reduce the number of ICs used. We reused some outputs so that we don't waste any IC.

Implementing the 4bit Adder with 2 7483 needed a bit of calculation and research.