

# Cny: Arithmetic Logic Unit

## # ALU:

Arithmetic logic unit ~~parallel~~ (ALU) is multifunctional device that can perform both A & L function. ALU is an integral part of central processing unit of CPU of a computer.

An ALU is a multiplexed combination logic digital function. It has a number of selection lines to select a particular operation in the unit.

The selection lines are decoded within the ALU

so that  $k$  selection variables can specify up to  $2^k$  distinct operations. Fig shows the block diagram of 4 bit ALU. The data inputs from A are combined with the 4 inputs from B to generate an operation at the F outputs.



fig: Block Diagram of ALU

The ALU operates on inputs A & B. Operation of the ALU are arithmetic and logic function.  $S_2$  control input line is used to select between arithmetic and logic mode of ALU. Control input lines  $S_1$  &  $S_0$  are used to select various functions of ALU like Addition, Subtraction.

### ii) Nibble Adder:

Nibble adder is the parallel adder which parallelly adds two 4 bits binary numbers.



The nibble adder is constructed using the Adders (i.e Full Adders) connected in cascade. The nibble adder has the carry in ( $C_{in}$ ) and carry out ( $C_{out}$ ).

As a result of which it can be used to make 8-bit adder.

$$A = A_3 A_2 A_1 A_0$$

$$B = B_3 B_2 B_1 B_0$$

$$S = S_3 S_2 S_1 S_0$$

$$C = C_3$$



Fig: ~~Left~~ Nibble Adder

## # Adder - Subtractor unit:-

- In Digital clc, A binary adder - subtractor is capable of both the addition & subtraction of binary no. in one clc itself.
- The operation is performed depending on the binary values the control signals holds.
- It is one of the components of the ALU.

# H Adder / Subtractor unit

$$A + B = A + B + 0$$

$$A - B = A + \bar{B} + 1$$



when  $c_{in} = 1$  for subtract  
 for add

## 9-7 STATUS REGISTER

The relative magnitudes of two numbers may be determined by subtracting one number from the other and then checking certain bit conditions in the resultant difference. If the two numbers are unsigned, the bit conditions of interest are the output carry and a possible zero result. If the two numbers include a sign bit in the highest-order position, the bit conditions of interest are the sign of the result, a zero indication, and an overflow condition. It is sometimes convenient to supplement the ALU with a status register where these status-bit conditions are stored for further analysis. Status-bit conditions are sometimes called *condition-code* bits or *flag* bits.

Figure 9-14 shows the block diagram of an 8-bit ALU with a 4-bit status register. The four status bits are symbolized by  $C$ ,  $S$ ,  $Z$ , and  $V$ . The bits are set or cleared as a result of an operation performed in the ALU.

1. Bit  $C$  is set if the output carry of the ALU is 1. It is cleared if the output carry is 0.
2. Bit  $S$  is set if the highest-order bit of the result in the output of the ALU (the sign bit) is 1. It is cleared if the highest-order bit is 0.
3. Bit  $Z$  is set if the output of the ALU contains all 0's, and cleared otherwise.  $Z = 1$  if the result is zero, and  $Z = 0$  if the result is nonzero.
4. Bit  $V$  is set if the exclusive-OR of carries  $C_8$  and  $C_9$  is 1, and cleared otherwise. This is the condition for overflow when the numbers are in sign-2's-complement representation (see Section 8-6). For the 8-bit ALU,  $V$  is set if the result is greater than 127 or less than -128.

The status bits can be checked after an ALU operation to determine certain relationships that exist between the values of  $A$  and  $B$ . If bit  $V$  is set after the addition of two signed numbers, it indicates an overflow condition. If  $Z$  is set after an exclusive-OR operation, it indicates that  $A = B$ . This is so because  $x \oplus x = 0$ , and the exclusive-OR of two equal operands gives an all-0's result which sets the  $Z$  bit. A single bit in  $A$  can be checked to determine if it is 0 or 1 by masking all bits except the bit in question and then checking the  $Z$  status bit. For example, let  $A = 101x1100$ , where  $x$  is the bit to be checked. The AND operation of  $A$  with  $x = 1$ , the  $Z$  bit is cleared since the result is 000x0000.



**Figure 9-14** Setting bits in a status register

## H Design a shifter:-

- The shift unit attached to a processor transfers the op of the ALU onto the op bus.
- The shifter may transfer the information directly without a shift, or it may shift the information to the right or left.
- The shifter provides the shift micro-operation commonly not available in an ALU.
- It is a bidirectional shift register with parallel load. The information from the ALU can be transferred to the register in parallel & then shifted to the right or left.
- The transfer from a source register to a destination register can be done with one clock pulse if the shifter is implemented with a Combinational cbt.



**Figure 9-15** 4-bit combinational-logic shifter

**TABLE 9-7** Function table for shifter

| $H_1$ | $H_0$ | Operation                    | Function                       |
|-------|-------|------------------------------|--------------------------------|
| 0     | 0     | $S \leftarrow F$             | Transfer $F$ to $S$ (no shift) |
| 0     | 1     | $S \leftarrow \text{shr } F$ | Shift-right $F$ into $S$       |
| 1     | 0     | $S \leftarrow \text{shl } F$ | Shift-left $F$ into $S$        |
| 1     | 1     | $S \leftarrow 0$             | Transfer 0's into $S$          |

## # Design of arithmetic logic unit

- The basic component of the arithmetic section of an ALU is a parallel adder.
- A parallel adder is constructed with a no. of full adder cells connected in cascade.

(a) Addition:-



(b) Addition with carry



(c) subtraction



(d) A plus 1's complement of B.



(e) Transfer A



(f) Increment A



(g) Decrement A:



(h) Transfer A



Note! -

① A - 1

$$A - \bar{1} + 1 \quad \{ A - B = A - \bar{B} + 1 \}$$

~~②~~

$$A - \overline{0001} + 1$$

$$A - \overline{1110} + 1$$

$$A - \overline{1111}$$

$$\cancel{A - \bar{1}}$$

$$\cancel{- \bar{1}}$$

$$= \cancel{\bar{1} - \bar{1}}$$

②

$$A + \overline{1111}$$

$$A + \overline{1110} + 1$$

$$A + \overline{1111} + 1$$

# Function table for True, Complement, one or zero cbt:-

| $S_1$ | $S_0$ | $Y$       |
|-------|-------|-----------|
| 0     | 0     | 0         |
| 0     | 1     | B         |
| 1     | 0     | $\bar{B}$ |
| 1     | 1     | 1         |



**TABLE 9-1** Function table for the arithmetic circuit of Fig. 9-8

| Function select | Y equals | X        | Output equals                     | Function                         |
|-----------------|----------|----------|-----------------------------------|----------------------------------|
| $s_1$           | $s_0$    | $C_{in}$ |                                   |                                  |
| 0               | 0        | 0        | 0: $A$                            | Transfer $A$                     |
| 0               | 0        | 1        | 0: $F = A + 1$                    | Increment $A$                    |
| 0               | 1        | 0        | $B$ : $F = A + B$                 | Add $B$ to $A$                   |
| 0               | 1        | 1        | $\bar{B}$ : $F = A + B + 1$       | Add $B$ to $A$ plus 1            |
| 1               | 0        | 0        | $\bar{B}$ : $F = A + \bar{B}$     | Add 1's complement of $B$ to $A$ |
| 1               | 0        | 1        | $\bar{B}$ : $F = A + \bar{B} + 1$ | Add 2's complement of $B$ to $A$ |
| 1               | 1        | 0        | All 1's: $F = A - 1$              | Decrement $A$                    |
| 1               | 1        | 1        | All 1's                           | Transfer $A$                     |



Fig: Logic diagram of Arithmetic circuit.

## # Design of Accumulator:-

- Some processor units distinguish one register from all others & call it an accumulator register.
- The block diagram of an accumulator that forms a sequential circuit is shown below



Fig: Block diagram of accumulator.

- Accumulator register is essentially bi-directional shift register with parallel load which is connected to an ALU.
- In above figure, 'A' register & the associated combinational circuit constitute a sequential ckt.
- The Combinational ckt replaces the ALU but cannot be separated from the register, since it is only the Combinational ckt part of a sequential ckt.
- The 'A' register is referred to as the accumulator register & it is sometimes denoted by the symbol AC.
- Here, accumulator register refers to both the 'A' register & its associated combinational circuit.
- The external i/p's to the accumulator are the data i/p's from B & the control variables that determine the microoperations for the register.
- The next state of register 'A' is a fcn of its present state & of the external i/p's.