



**HACETTEPE  
UNIVERSITY**  
**Electrical and Electronics Engineering**

**ELE 419 Integrated Circuit Design  
Term Project  
Full Custom ALU Desgin**

**Student Name : Ertuğrul Tiyek  
Student ID : 21828916**

**Instructor:** Associate Professor Dinçer Gökcen

## Design:

Firstly I want to introduce my design concerns. I aimed a different design in this project.

- I tried to design each module in standardized size. This allowed me to put every element together without wasting space. I first specified a height to module to fit every design from inverter to whole ALU. I specified this height as 55.5 after a few design.
- The other aim was scaling whole ALU from 1 bit to whatever size that needed. The whole ALU can be scaled by adding more ALU's like construction toys (LEGO). This also allowed me not to waste space with scaling modules and assembling different sized modules with wide bus connections.
- I used **Only 2 Layers of Metal** to reduce production cost.
- I like to use complex logic, but the complex logic needs different sized transistors, so using complex logic would destroy my standardized size aim. I didn't use complex logic in this project. Instead of that, I used multi input gates and combinational gates.
- For sizing, I mostly preserve 2:1 ratio. But according to simulation results, I changed some of the sizes. For example transmission gates are implemented using 10:10 sizing.

As following my aims, I am able to design the whole circuit took only **1789 x 969.5** squares of space.

## Logic Design:

| S2 | S1 | S0 | CIN | B_inp | C_inp | OP    |
|----|----|----|-----|-------|-------|-------|
| 0  | 0  | 0  | 0   | X     | X     | A     |
| 0  | 0  | 0  | 1   | X     | X     | A'    |
| 0  | 0  | 1  | 0   | X     | X     | AND   |
| 0  | 0  | 1  | 1   | X     | X     | OR    |
| 0  | 1  | 0  | 0   | B     | 0     | XOR   |
| 0  | 1  | 0  | 1   | 0     | 1     | INC   |
| 0  | 1  | 1  | 0   | B     | 0     | ADD   |
| 0  | 1  | 1  | 1   | B     | 1     | ADD+C |
| 1  | 0  | 0  | 0   | X     | X     |       |
| 1  | 0  | 0  | 1   | B     | 1     | SUB   |
| 1  | 0  | 1  | 0   | B     | 0     | SUB-B |
| 1  | 0  | 1  | 1   | X     | X     |       |
| 1  | 1  | 0  | 0   | 0     | 0     | DEC   |
| 1  | 1  | 0  | 1   | X     | X     |       |
| 1  | 1  | 1  | 0   | X     | X     | <<    |
| 1  | 1  | 1  | 1   | X     | X     | >>    |

Karnaugh Map for Arithmetic Unit B input:

|    | 00 | 01 | 11 | 10 |
|----|----|----|----|----|
| 00 | X  | X  | X  | X  |
| 01 | B  | 0  | B  | B  |

|    |   |   |   |   |
|----|---|---|---|---|
| 11 | 0 | X | X | X |
| 10 | X | B | X | B |

$$B \leftarrow (\textcolor{brown}{S_2 S_1} + \textcolor{blue}{S_2' S_0' C_{in}})$$

Inverter Design:



Although the inverter is the smallest gate, I am able to design all gates in the height of an inverter.

Transistor Sizing:

Pmos: 10

Nmos: 5

Ratio: 2:1

Nand Gate Design:



Transistor sizes :

Pmos: 10

Nmos: 10

Ratio: 2:1

And Gate Design:



Nor Gate Design:



Transistor Sizes:

Pmos: 20

Nmos: 5

Ratio: 2:1

Or Gate Design:



Xor Gate Design:



I designed Xor Gate using **Transmission Gate** technology. Transmission gates are useful technology for saving resource and space, but because they are not supplied by direct voltage sources, it causes attenuations. Because I paid much attention not to cascade transmission gates. Using transmission gates with combination of other gates is a useful thing to both not losing signal quality and saving space and resources.

Half Adder Design:



Full Adder Design:



Again I didn't choose using complex logic to implement Full Adder. Because it would not fit in my standards. Instead I used traditional two half adder method.

Adder Subtractor Design:



## Multiplexer Design:



I used transmission technology to implement multiplexer. Sizing is done by simulation results. I used 10:10 ratio.

## Arithmetic Unit Design:

I designed two different Arithmetic Units to perform 7 of the instructions that are required from ALU. These are:

|   |   |   |   |   |   |       |
|---|---|---|---|---|---|-------|
| 0 | 1 | 0 | 0 | B | 0 | XOR   |
| 0 | 1 | 0 | 1 | 0 | 1 | INC   |
| 0 | 1 | 1 | 0 | B | 0 | ADD   |
| 0 | 1 | 1 | 1 | B | 1 | ADD+C |
| 1 | 0 | 0 | 0 | X | X |       |
| 1 | 0 | 0 | 1 | B | 1 | SUB   |
| 1 | 0 | 1 | 0 | B | 0 | SUB-B |
| 1 | 0 | 1 | 1 | X | X |       |
| 1 | 1 | 0 | 0 | 0 | 0 | DEC   |

The reason I designed two of the Arithmetic units is the first bit of the ALU needed less logic than other bits, so I removed C/B\_in logic from first bit, than I opened some space to insert other logic (inverters for selection bits).

### Arithmetic Unit for normal bits:



D-Latch Design:





Edge Triggered D-FlipFlop Design:



Shift Register Design:



Other Logic Designs for Midparts:

Dual Output Gates:

Three Input Gates:

Gates With Different Layouts:

1-Bit ALU Design:





Scaling ALU:



I used metal 2 only when I needed while designing submodules. The Metal 2 is used to connect common signals like Selection bits as long vertical lines. Metal 2 layer is shown below and long vertical lines carry power lines and common signals. Mostly horizontal lines are used inside of submodules to connect internal signals.



With this design, I am able to fit the whole 8 bit ALU inside of **1789x969.5** squares. It can be shrinkable by adding a third layer of metal and using common signals jointly. But for this project the size is smaller than I expected.

## Simulation:

Inverter Simulation:

And Gate Simulation:

Or Gate Simulation:

Xor Gate Simulation:

Full Adder Simulation:

Adder Subtractor Simulation:

Multiplexer Simulation:

2x1 transmission mux spice sim results:

10:5



10:10



To prevent ripples and transition delays on 10:5 transistor sizing, I used 10:10 ratio by simulation results.

### Arithmetic Unit Simulation:



### Edge Triggered D-FlipFlop Simulation:



## Shift Register Simulation:



## Other Gate Simulations:

3 input nand gate spice simulation results:

$10:5 \rightarrow \text{Pmos} = 10, \text{Nmos} = 15$



$10:3.33 \rightarrow \text{Pmos} = 10, \text{Nmos} = 10$



1-Bit ALU Simulation:



## Buffer Operation



## Inverter Operation



### Or Operation



### And Operation



## Shift Operations



There is an issue about input logic of Arithmetic unit. So I have to reconsider my logic design. It normally works. Most probably I changed some connection and I forgot to update whole design. So remaining of the system the Arithmetic unit not performing well. I realized there is a problem too late. So I have no time to fix this issue. I expect your forgiveness.

Overall ALU Simulation:

## 8 Bit Buffer Operation Spice Simulation:

```
vdd vdd 0 dc 5
** Buffer (A)
vs2 S[2] 0 dc 0
vs1 S[1] 0 dc 0
vs0 S[0] 0 dc 0
vcin Cin 0 dc 5

va0 A[0] 0 DC 0 pulse 5 0 1n 1n 1n 16m 32m
va1 A[1] 0 DC 0 pulse 5 0 1n 1n 1n 2m 4m
va2 A[2] 0 DC 0 pulse 5 0 1n 1n 1n 8m 16m
va3 A[3] 0 DC 0 pulse 5 0 1n 1n 1n 2m 4m
va4 A[4] 0 DC 0 pulse 5 0 1n 1n 1n 8m 16m
va5 A[5] 0 DC 0 pulse 5 0 1n 1n 1n 4m 8m
va6 A[6] 0 DC 0 pulse 5 0 1n 1n 1n 2m 4m
va7 A[7] 0 DC 0 pulse 5 0 1n 1n 1n 1m 2m

vb0 B[0] 0 DC 0 pulse 5 0 1n 1n 1n 16m 32m
vb1 B[1] 0 DC 0 pulse 5 0 1n 1n 1n 2m 4m
vb2 B[2] 0 DC 0 pulse 5 0 1n 1n 1n 16m 32m
vb3 B[3] 0 DC 0 pulse 5 0 1n 1n 1n 2m 4m
vb4 B[4] 0 DC 0 pulse 5 0 1n 1n 1n 8m 16m
vb5 B[5] 0 DC 0 pulse 5 0 1n 1n 1n 2m 4m
vb6 B[6] 0 DC 0 pulse 5 0 1n 1n 1n 16m 32m
vb7 B[7] 0 DC 0 pulse 5 0 1n 1n 1n 2m 4m

vclk clk 0 DC 0 pulse 5 0 1n 1n 1n 0.8m 2m
.tran 0 32m
```



## 8 Bit Inverter Operation Spice Simulation:

```

vdd vdd 0 dc 5
** Buffer (A)
vs2 S[2] 0 dc 0
vs1 S[1] 0 dc 0
vs0 S[0] 0 dc 0
vcin Cin 0 dc 0

va0 A[0] 0 DC 0 pulse 5 0 1n 1n 1n 16m 32m
va1 A[1] 0 DC 0 pulse 5 0 1n 1n 1n 2m 4m
va2 A[2] 0 DC 0 pulse 5 0 1n 1n 1n 8m 16m
va3 A[3] 0 DC 0 pulse 5 0 1n 1n 1n 2m 4m
va4 A[4] 0 DC 0 pulse 5 0 1n 1n 1n 8m 16m
va5 A[5] 0 DC 0 pulse 5 0 1n 1n 1n 4m 8m
va6 A[6] 0 DC 0 pulse 5 0 1n 1n 1n 2m 4m
va7 A[7] 0 DC 0 pulse 5 0 1n 1n 1n 1m 2m

vb0 B[0] 0 DC 0 pulse 5 0 1n 1n 1n 16m 32m
vb1 B[1] 0 DC 0 pulse 5 0 1n 1n 1n 2m 4m
vb2 B[2] 0 DC 0 pulse 5 0 1n 1n 1n 16m 32m
vb3 B[3] 0 DC 0 pulse 5 0 1n 1n 1n 2m 4m
vb4 B[4] 0 DC 0 pulse 5 0 1n 1n 1n 8m 16m
vb5 B[5] 0 DC 0 pulse 5 0 1n 1n 1n 2m 4m
vb6 B[6] 0 DC 0 pulse 5 0 1n 1n 1n 16m 32m
vb7 B[7] 0 DC 0 pulse 5 0 1n 1n 1n 2m 4m

vclk clk 0 DC 0 pulse 5 0 1n 1n 1n 0.8m 2m
.tran 0 32m

```



## 8 Bit Or Operation Spice Simulation:

```

vdd vdd 0 dc 5
** Buffer (A)
vs2 S[2] 0 dc 0
vs1 S[1] 0 dc 0
vs0 S[0] 0 dc 5
vcin Cin 0 dc 0

va0 A[0] 0 DC 0 pulse 5 0 1n 1n 1n 16m 32m
va1 A[1] 0 DC 0 pulse 5 0 1n 1n 1n 2m 4m
va2 A[2] 0 DC 0 pulse 5 0 1n 1n 1n 8m 16m
va3 A[3] 0 DC 0 pulse 5 0 1n 1n 1n 2m 4m
va4 A[4] 0 DC 0 pulse 5 0 1n 1n 1n 8m 16m
va5 A[5] 0 DC 0 pulse 5 0 1n 1n 1n 4m 8m
va6 A[6] 0 DC 0 pulse 5 0 1n 1n 1n 2m 4m
va7 A[7] 0 DC 0 pulse 5 0 1n 1n 1n 1m 2m

vb0 B[0] 0 DC 0 pulse 5 0 1n 1n 1n 16m 32m
vb1 B[1] 0 DC 0 pulse 5 0 1n 1n 1n 2m 4m
vb2 B[2] 0 DC 0 pulse 5 0 1n 1n 1n 16m 32m
vb3 B[3] 0 DC 0 pulse 5 0 1n 1n 1n 2m 4m
vb4 B[4] 0 DC 0 pulse 5 0 1n 1n 1n 8m 16m
vb5 B[5] 0 DC 0 pulse 5 0 1n 1n 1n 2m 4m
vb6 B[6] 0 DC 0 pulse 5 0 1n 1n 1n 16m 32m
vb7 B[7] 0 DC 0 pulse 5 0 1n 1n 1n 2m 4m

vclk clk 0 DC 0 pulse 5 0 1n 1n 1n 0.8m 2m
.tran 0 32m

```



## 8 Bit And Operation Spice Simulation:

```

vdd vdd 0 dc 5
** Buffer (A)
vs2 S[2] 0 dc 0
vs1 S[1] 0 dc 0
vs0 S[0] 0 dc 5
vcin Cin 0 dc 5s

va0 A[0] 0 DC 0 pulse 5 0 1n 1n 1n 16m 32m
va1 A[1] 0 DC 0 pulse 5 0 1n 1n 1n 2m 4m
va2 A[2] 0 DC 0 pulse 5 0 1n 1n 1n 8m 16m
va3 A[3] 0 DC 0 pulse 5 0 1n 1n 1n 2m 4m
va4 A[4] 0 DC 0 pulse 5 0 1n 1n 1n 8m 16m
va5 A[5] 0 DC 0 pulse 5 0 1n 1n 1n 4m 8m
va6 A[6] 0 DC 0 pulse 5 0 1n 1n 1n 2m 4m
va7 A[7] 0 DC 0 pulse 5 0 1n 1n 1n 1m 2m

vb0 B[0] 0 DC 0 pulse 5 0 1n 1n 1n 16m 32m
vb1 B[1] 0 DC 0 pulse 5 0 1n 1n 1n 2m 4m
vb2 B[2] 0 DC 0 pulse 5 0 1n 1n 1n 16m 32m
vb3 B[3] 0 DC 0 pulse 5 0 1n 1n 1n 2m 4m
vb4 B[4] 0 DC 0 pulse 5 0 1n 1n 1n 8m 16m
vb5 B[5] 0 DC 0 pulse 5 0 1n 1n 1n 2m 4m
vb6 B[6] 0 DC 0 pulse 5 0 1n 1n 1n 16m 32m
vb7 B[7] 0 DC 0 pulse 5 0 1n 1n 1n 2m 4m

vclk clk 0 DC 0 pulse 5 0 1n 1n 1n 0.8m 2m
.tran 0 32m

```

