

# Implementazione di una Arithmetic-Logic-Unit

Corrado Santoro

Dipartimento di Matematica e Informatica

santoro@dmi.unict.it



Corso di Architettura degli Elaboratori

## Arithmetic-Logic-Unit

- Una **ALU** a  $n$  bit è un circuito logico in grado di effettuare operazioni matematiche (somme, sottrazioni) e logiche (bitwise-AND, bitwise-OR, bitwise-NOT) su due operandi a  $n$  bit
- E' un circuito presente in qualunque CPU ed è rappresentato nel seguente modo



- $n$  ingressi per l'operando  $X$
- $n$  ingressi per l'operando  $Y$
- $k$  ingressi per specificare il tipo di operazione da effettuare  $OpType$
- $n$  uscite per il risultato  $R$

Implementazione della Somma Binaria a 4 Bit  
tramite porte logiche

# Operazione di somma binaria

## Somma in base 2

L'operazione di somma binaria, in colonna, può essere svolta applicando le seguenti semplici regole:

|   |   |   |   |                    |
|---|---|---|---|--------------------|
| 0 | + | 0 | = | 0                  |
| 0 | + | 1 | = | 1                  |
| 1 | + | 0 | = | 1                  |
| 1 | + | 1 | = | 0 con riporto di 1 |

## Esempio

| Riporti         | 1 | 1 | 1 |   |
|-----------------|---|---|---|---|
| Primo addendo   | 0 | 0 | 1 | 1 |
| Secondo addendo | 0 | 1 | 0 | 1 |
| Risultato       | 1 | 0 | 0 | 0 |

$$(0011)_2 + (0101)_2 = (1000)_2$$

$$3 + 5 = 8$$

# Operazione di somma binaria

## Esempio

| Riporti         | 1 | 1 | 1 |   |   |
|-----------------|---|---|---|---|---|
| Primo addendo   | 0 | 0 | 1 | 1 | + |
| Secondo addendo | 0 | 1 | 0 | 1 | = |
| Risultato       | 1 | 0 | 0 | 0 |   |

$$(0011)_2 + (0101)_2 = (1000)_2$$
$$3 + 5 = 8$$

## Somma in base 2

- Per la *prima colonna*, sommiamo **due bit** e produciamo un **risultato** e un **riporto**
- Per le *successive colonne*, sommiamo **due bit** e il **riporto precedente**, e produciamo un **risultato** e un **nuovo riporto**

# Operazione di somma binaria

## Nomenclatura

| Riporti C         | 1 | 1 | 1 |   |   |       |       |       |       |
|-------------------|---|---|---|---|---|-------|-------|-------|-------|
| Primo addendo X   | 0 | 0 | 1 | 1 | + | $x_3$ | $x_2$ | $x_1$ | $x_0$ |
| Secondo addendo Y | 0 | 1 | 0 | 1 | = | $y_3$ | $y_2$ | $y_1$ | $y_0$ |
| Risultato S       | 1 | 0 | 0 | 0 |   | $s_3$ | $s_2$ | $s_1$ | $s_0$ |

## Somma in base 2

- Utilizziamo una variabile booleana per ogni bit coinvolto nella nostra operazione
- Rappresentiamo i 4 bit del primo addendo  $X$  con le variabili booleane  $x_3, x_2, x_1, x_0$
- Rappresentiamo i 4 bit del secondo addendo  $Y$  con le variabili booleane  $y_3, y_2, y_1, y_0$
- Rappresentiamo i 4 bit della somma  $S$  con le variabili booleane  $s_3, s_2, s_1, s_0$
- Rappresentiamo i 3 bit dei riporti con le variabili booleane  $c_3, c_2, c_1$

# Operazione di somma binaria

## Implementazione

| Riporti C         | 1 | 1 | 1 |   |   |       |       |       |
|-------------------|---|---|---|---|---|-------|-------|-------|
| Primo addendo X   | 0 | 0 | 1 | 1 | + | $c_3$ | $c_2$ | $c_1$ |
| Secondo addendo Y | 0 | 1 | 0 | 1 | = | $x_3$ | $x_2$ | $x_1$ |
| Risultato S       | 1 | 0 | 0 | 0 |   | $y_3$ | $y_2$ | $y_1$ |

## Implementazione

- Utilizziamo una **rete logica** per ogni **colonna della somma**  $\Rightarrow$  **4 reti logiche**
- La prima colonna (**colonna "0"**) sarà una rete con ingressi  $x_0, y_0$  e uscite  $s_0, c_1$
- Le altre colonne ( $n, n > 0$ ) saranno delle reti con ingressi  $x_n, y_n, c_n$  e uscite  $s_n, c_{n+1}$

# Operazione di somma binaria

## Implementazione

| Riporti $C$         |   |   |   | 1 | 1 | 1 | + | $c_3$ | $c_2$ | $c_1$ |       |
|---------------------|---|---|---|---|---|---|---|-------|-------|-------|-------|
| Primo addendo $X$   | 0 | 0 | 1 | 1 |   |   | = | $x_3$ | $x_2$ | $x_1$ | $x_0$ |
| Secondo addendo $Y$ | 0 | 1 | 0 | 1 |   |   | = | $y_3$ | $y_2$ | $y_1$ | $y_0$ |
| Risultato $S$       | 1 | 0 | 0 | 0 |   |   |   | $s_3$ | $s_2$ | $s_1$ | $s_0$ |

## Somma Colonna 0

| $x_0$ | $y_0$ | $s_0$ |
|-------|-------|-------|
| 0     | 0     | 0     |
| 0     | 1     | 1     |
| 1     | 0     | 1     |
| 1     | 1     | 0     |

$$s_0 = \overline{x_0}y_0 + x_0\overline{y_0}$$

## Riporto Colonna 0

| $x_0$ | $y_0$ | $c_1$ |
|-------|-------|-------|
| 0     | 0     | 0     |
| 0     | 1     | 0     |
| 1     | 0     | 0     |
| 1     | 1     | 1     |

$$c_1 = x_0y_0$$

# Operazione di somma binaria

## Half Adder

$$S_0 = \overline{x_0}y_0 + x_0\overline{y_0}$$

$$C_1 = x_0y_0$$



# Operazione di somma binaria

## Implementazione

| Riporti C         | 1 | 1 | 1 |   |   | c <sub>3</sub> | c <sub>2</sub> | c <sub>1</sub> |                |
|-------------------|---|---|---|---|---|----------------|----------------|----------------|----------------|
| Primo addendo X   | 0 | 0 | 1 | 1 | + | x <sub>3</sub> | x <sub>2</sub> | x <sub>1</sub> | x <sub>0</sub> |
| Secondo addendo Y | 0 | 1 | 0 | 1 | = | y <sub>3</sub> | y <sub>2</sub> | y <sub>1</sub> | y <sub>0</sub> |
| Risultato S       | 1 | 0 | 0 | 0 |   | s <sub>3</sub> | s <sub>2</sub> | s <sub>1</sub> | s <sub>0</sub> |

## Somma Colonna $n > 0$

| c <sub>n</sub> | x <sub>n</sub> | y <sub>n</sub> | s <sub>n</sub> |
|----------------|----------------|----------------|----------------|
| 0              | 0              | 0              | 0              |
| 0              | 0              | 1              | 1              |
| 0              | 1              | 0              | 1              |
| 0              | 1              | 1              | 0              |
| 1              | 0              | 0              | 1              |
| 1              | 0              | 1              | 0              |
| 1              | 1              | 0              | 0              |
| 1              | 1              | 1              | 1              |

$$s_n = \overline{c_n} \overline{x_n} y_n + \overline{c_n} x_n \overline{y_n} + c_n \overline{x_n} \overline{y_n} + c_n x_n y_n = c_n \text{ XOR } x_n \text{ XOR } y_n$$



# Operazione di somma binaria

## Implementazione

| Riporti C         | 1 | 1 | 1 |   | + | $c_3$ | $c_2$ | $c_1$ |       |
|-------------------|---|---|---|---|---|-------|-------|-------|-------|
| Primo addendo X   | 0 | 0 | 1 | 1 | = | $x_3$ | $x_2$ | $x_1$ | $x_0$ |
| Secondo addendo Y | 0 | 1 | 0 | 1 | = | $y_3$ | $y_2$ | $y_1$ | $y_0$ |
| Risultato S       | 1 | 0 | 0 | 0 |   | $s_3$ | $s_2$ | $s_1$ | $s_0$ |

## Somma Colonna $n > 0$

| $c_n$ | $x_n$ | $y_n$ | $c_n \text{ XOR } x_n$ | $s_n = (c_n \text{ XOR } x_n) \text{ XOR } y_n$ |
|-------|-------|-------|------------------------|-------------------------------------------------|
| 0     | 0     | 0     | 0                      | 0                                               |
| 0     | 0     | 1     | 0                      | 1                                               |
| 0     | 1     | 0     | 1                      | 1                                               |
| 0     | 1     | 1     | 1                      | 0                                               |
| 1     | 0     | 0     | 1                      | 1                                               |
| 1     | 0     | 1     | 1                      | 0                                               |
| 1     | 1     | 0     | 0                      | 0                                               |
| 1     | 1     | 1     | 0                      | 1                                               |

$$s_n = \overline{c_n} \overline{x_n} y_n + \overline{c_n} x_n \overline{y_n} + c_n \overline{x_n} \overline{y_n} + c_n x_n y_n = c_n \text{ XOR } x_n \text{ XOR } y_n$$



# Operazione di somma binaria

## Implementazione

| Riporti C         | 1 | 1 | 1 |   |   | c <sub>3</sub> | c <sub>2</sub> | c <sub>1</sub> |                |
|-------------------|---|---|---|---|---|----------------|----------------|----------------|----------------|
| Primo addendo X   | 0 | 0 | 1 | 1 | + | x <sub>3</sub> | x <sub>2</sub> | x <sub>1</sub> | x <sub>0</sub> |
| Secondo addendo Y | 0 | 1 | 0 | 1 | = | y <sub>3</sub> | y <sub>2</sub> | y <sub>1</sub> | y <sub>0</sub> |
| Risultato S       | 1 | 0 | 0 | 0 |   | s <sub>3</sub> | s <sub>2</sub> | s <sub>1</sub> | s <sub>0</sub> |

## Riporto Colonna $n > 0$

| c <sub>n</sub> | x <sub>n</sub> | y <sub>n</sub> | c <sub>n+1</sub> |
|----------------|----------------|----------------|------------------|
| 0              | 0              | 0              | 0                |
| 0              | 0              | 1              | 0                |
| 0              | 1              | 0              | 0                |
| 0              | 1              | 1              | 1                |
| 1              | 0              | 0              | 0                |
| 1              | 0              | 1              | 1                |
| 1              | 1              | 0              | 1                |
| 1              | 1              | 1              | 1                |

$$c_{n+1} = x_n y_n + y_n c_n + x_n c_n$$



# Operazione di somma binaria

## Full Adder

$$s_n = \overline{c_n} \overline{x_n} y_n + \overline{c_n} x_n \overline{y_n} + c_n \overline{x_n} \overline{y_n} + c_n x_n y_n = x_n \text{ XOR } y_n \text{ XOR } c_n$$

$$c_{n+1} = x_n y_n + y_n c_n + x_n c_n$$



# Operazione di somma binaria

## 4 Bit Adder



## Implementazione della Sottrazione Binaria a 4 Bit tramite porte logiche

## Sottrazione in base 2

L'operazione di **sottrazione**  $X - Y$  (con  $X$  e  $Y$  due variabili a  $n$  bit) può essere trasformata in una **somma** sfruttando il complemento a 2:

$$X - Y = X + (-Y) = X + (\bar{Y} + 1)$$

dove  $\bar{Y}$  è la **negazione “bitwise”** (cioè bit per bit) di  $Y$ .

- L'operazione  $\bar{Y}$  può essere facilmente implementata usando  $n$  porte NOT
- Occorrerebbe quindi un ulteriore circuito sommatore per poter effettuare l'operazione  $\dots + 1$ , tuttavia ....

## Verso la sottrazione in base 2

- Supponiamo di voler implementare la seguente operazione:

$$X + Y + 1$$

- Possiamo pensare al .. + 1 come alla presenza di un “riporto” già nella prima colonna (bit 0) della nostra operazione
- Allora usiamo un “Full Adder” anche sul primo bit, e sfruttiamo il suo ingresso di carry (CarryIn) per ottenere i seguenti casi:

$$\begin{array}{ll} X + Y & \text{se } \text{CarryIn} = 0 \\ X + Y + 1 & \text{se } \text{CarryIn} = 1 \end{array}$$

# Verso la sottrazione in base 2

## 4 Bit Adder con CarryIn



|             |                 |
|-------------|-----------------|
| CarryIn = 0 | $S = X + Y$     |
| CarryIn = 1 | $S = X + Y + 1$ |

# Operazione di sottrazione binaria

## Verso la sottrazione in base 2

- A questo punto, se riuscissimo a sfruttare il “CarryIn” per pilotare anche un ulteriore circuito in grado di invertire i bit di  $Y$  otterremmo il seguente effetto:

$$\begin{array}{ll} X + Y & \text{se } \text{CarryIn} = 0 \\ X + \bar{Y} + 1 & \text{se } \text{CarryIn} = 1 \end{array}$$

- Chiamando l'ingresso “CarryIn” come **OpType** potremmo raggiungere il nostro obiettivo:

$$\begin{array}{ll} X + Y & \text{se } \text{OpType} = 0 \\ X + \bar{Y} + 1 & \text{se } \text{OpType} = 1 \end{array}$$

- Cioè un circuito in grado di comportarsi come **sommatore** se  $\text{OpType} = 0$ , e come **sottrattore** se  $\text{OpType} = 1$

## Verso la sottrazione in base 2

- Sintetizziamo un “invertitore su comando”:

| $y_i$ | <i>OpType</i> | $y'_i$ |
|-------|---------------|--------|
| 0     | 0             | 0      |
| 0     | 1             | 1      |
| 1     | 0             | 1      |
| 1     | 1             | 0      |

- Otteniamo  $y'_i = y_i \ xor \ OpType$

# ALU a 4 Bit

## ALU a 4 Bit

- Mettiamo “tutto insieme” in un unico circuito:



## Operazioni Logiche Bitwise

## Inclusione di Operazioni Logiche

- Estendiamo la nostra ALU includendo anche la possibilità di effettuare le seguenti **operazioni logiche bitwise**:

$$\begin{array}{ccc} X & \text{AND} & Y \\ X & \text{OR} & Y \\ & \text{NOT}(X) & \end{array}$$

- A tale scopo, possiamo modificare il **Full Adder** includendo la possibilità di fare le operazioni citate sul singolo bit
- Aggiungiamo dunque un **multiplexer** che consente di mandare in output, alternativamente, l'uscita del:
  - Sommatore,  $x_i + y_i$ ;
  - Porta AND,  $x_i \text{ AND } y_i$ ;
  - Porta OR,  $x_i \text{ OR } y_i$ ;
  - Negazione,  $\overline{x_i}$

# Inclusione di Operazioni Logiche



# 4-bit ALU Completa



| $OpType_0$ | $OpType_1$ | $OpType_2$ | $R$                |
|------------|------------|------------|--------------------|
| 0          | 1          | 0          | $X + Y$            |
| 1          | 1          | 0          | $X - Y$            |
| 0          | 0          | 0          | $X \text{ AND } Y$ |
| 0          | 0          | 1          | $X \text{ OR } Y$  |
| 0          | 1          | 1          | $NOT(X)$           |

# Implementazione di una Arithmetic-Logic-Unit

Corrado Santoro

Dipartimento di Matematica e Informatica

santoro@dmi.unict.it



Corso di Architettura degli Elaboratori