

## Module-3 Central Processing Unit

Original ⑪

### Central Processing Unit.

The part of the computer that performs bulk of data processing operations is called the central processing unit and denoted as CPU. The CPU is made of 3 major units shown as below:-



[Major component of CPU].

- ① Register set stores the intermediate data used during the execution of instructions.
- ② The arithmetic logic unit (ALU) perform the required microoperation for executing the instructions.
- ③ The control unit supervise the transfer of information among the registers and instruct the ALU as to which operation to perform.

CPU performs a variety of functions directed by the type of instructions that are machine implemented in computer.

functions directed by the type of instructions that are machine implemented in computer.

## General Register Organization

In the programming environment, the memory locations are needed for storing pointers, counters, return addresses, temporary results and partial products during various microoperations. But memory access is most time consuming process in computer, so it is more convenient and more efficient to store these intermediate values in processor registers. When a large number of registers are included in the CPU, it is most efficient to connect them through a common bus system. The registers communicate with each other not only for direct data transfer, but also while performing various microoperations.

A bus organization for 7-CPU registers is shown in fig(a).

The output of each register is connected to two multiplexers (MUX) to form the two buses A and B. The selection line in each multiplexer select one register or the input data for the particular bus. The A and B buses form the input to a common arithmetic logic unit (ALU). Operation selected in the ALU determines the arithmetic or logic microoperation that is to be performed.



(fig-a)

[BLOCK DIAGRAM]

The result of the microoperation is available for off data and also goes into the input of all registers. The register that receives the information from the output bus is selected by decoder. The decoder activates one of the register load input, thus providing a transfer path between the data in the

output bus and the inputs of selected destination register

e.g. For example if we have to perform the following operation:-

$$R1 \leftarrow R2 + R3$$

then control must provide

binary selection variables to following selector inputs:-

① Mux A Selector (SEL<sub>A</sub>): to place the content of R2 into bus A.

② Mux B Selector (SEL<sub>B</sub>): to place the content of R3 into bus B.

③ ALU operation selector (OPR): to provide the arithmetic addition A+B.

④ Decoder Destination selector (SEL<sub>D</sub>): to transfer the content of output bus into R1.

Control word:

There are 14 binary selection inputs in the unit, and their combined value specifies a control word.

The 14-bit control word is as follows:-

|                  |                  |                  |     |
|------------------|------------------|------------------|-----|
| 3                | 3                | 3                | 5   |
| SEL <sub>A</sub> | SEL <sub>B</sub> | SEL <sub>D</sub> | OPR |

[control word].

It consists of 4-fields. Three fields contain three bits each and one field has 5-bits.

## Stack Organization

(3)

A stack is a storage device that stores information in such a manner that the item stored last is the first item retrieved. So, Stack is Last-in first-out (LIFO) device. The register that holds the address for the stack is called a stack pointer (SP), because its value always points to the top item of the stack.

Block diagram for 64-word stack is as:-



## Basic operation of a Stack

There are basic 2-operation of

Stack:-

- ① PUSH or insertion operation:- The operation of insertion of new item in ~~the stack~~ called PUSH operation, because it can be thought of the onset of pushing a

new item on top.

⑨ Pop or Deletion:- The operation of deletion is called pop-up because it can be thought of as the result of removing one item so that stack pops-up.

### PUSH OPERATION,

Initially  $SP = \text{in } \cancel{\text{and}}$  cleared to '0',  $\text{EMPTY}$  is set to 1, and  $\text{FULL}$  is cleared to '0'. So that  $SP$  points to the word at address '0' and stack is marked empty and not full. If stack is not full i.e.  $\text{FULL}=0$ , a new item can be inserted as:-

$SP \leftarrow SP + 1$  Increment stack pointer.

$M[SP] \leftarrow DR$  write item on top of stack.

$DR$  is data register that holds the binary data to be written or read out of the stack.

### Pop operation,

A new item is deleted from the stack if stack is not empty, and operation sequences are as:-

$DR \leftarrow M[SP]$  Read item from top of stack.

$SP \leftarrow SP - 1$  Decrement stack pointer

If ( $SP=0$ ) then  $\text{EMPTY} \leftarrow 1$  Check if stack is empty.

$FULL \leftarrow 0$  Mark the stack not full.

(4)

Reverse Polish Notation,

A stack organization is very effective for evaluating arithmetic expressions. Common arithmetic operations are written in infix notation, in which operator is written between operands. There are three types of notations for arithmetic operation as follows:-

## ① Infix notation:-

In infix notation operator is placed between the operands. e.g.  $(A * B) + (C * D)$      $A + B$

## ② Prefix notation:-

In prefix notation, operator is placed before the operands. e.g.

|         |                 |
|---------|-----------------|
| $A + B$ | infix notation  |
| $+ A B$ | prefix notation |

## ③ Postfix notation:-

In postfix notation, operator is placed after the operands.

e.g.  $A + B$     infix notation  
 $AB +$     postfix notation.

→ → →  $\times$  → → →  $\times$  → → →  $\times$  → → →  $\times$  → → →

Evaluation of arithmetic operation by using stack.

Suppose we

have the arithmetic expression:-

$$\underline{(3 * 4) + (5 * 6)}$$

calculate postfix notation i.e.  $34 * 56 * +$

$$2 * 3 + 6 / 2 * 12$$

New Stack operations are as follows:-



### Instruction Formats,

An instruction format has the following

fields:-

- ① An operation code field that specifies the operation to be performed.
- ② An address field that designates a memory address or a processor register.
- ③ A mode field that specifies the way the operand or the effective address is determined, and diagrammed

Shown as:-

| MODE BIT | Operation code | ADDRESS Field |
|----------|----------------|---------------|
|----------|----------------|---------------|

[Instruction format].

### Type of instructions,

Following are the type of instructions:-

## ① Three-Address Instructions

(5)

Computer with three-address instruction formats can use each address field to specify either a processor register or a memory operand. Following program evaluates

$$X = (A * B) * (C + D) \text{ as:-}$$

ADD R1, A, B       $R1 \leftarrow M[A] + M[B];$

ADD R2, C, D       $R2 \leftarrow M[C] + M[D];$

MUL X, R1, R2       $M[X] \leftarrow R1 * R2;$

The advantage of three address format is that it results in short programs when evaluating arithmetic expressions. The disadvantage is that binary-coded instruction requires too many bits to specify three addresses.

## ② Two-Address Instructions:-

Two-address instructions are the most common in commercial computers. Each address field can specify either a processor register or a memory word.

Program to generate  $X = (A + B) * (C + D)$  in as:-

MOV R1, A       $R1 \leftarrow M[A];$

ADD R1, B       $R1 \leftarrow R1 + M[B];$

MOV R2, C       $R2 \leftarrow M[C];$

ADD R2, D       $R2 \leftarrow R2 + M[D];$

MUL R1, R2       $R1 \leftarrow R1 * R2$

MOV X, R1       $M[X] \leftarrow R1$

(3) One-Address Instructions,

One address instructions use an accumulator (AC) register for all data manipulation. For multiplication and division there is need for a second register.

Program to evaluate  $x = (A+B) * (C+D)$  in CDS:-

|       |   |                           |
|-------|---|---------------------------|
| LOAD  | A | $AC \leftarrow M[A]$      |
| ADD   | B | $AC \leftarrow AC + M[B]$ |
| STORE | T | $M[T] \leftarrow AC$      |
| LOAD  | C | $AC \leftarrow M[C]$      |
| ADD   | D | $AC \leftarrow AC + M[D]$ |
| MUL   | T | $AC \leftarrow AC * M[T]$ |
| STORE | X | $M[X] \leftarrow AC$      |

(4) zero-address Instructions: A stack organized computer does not use an address field for the instructions ADD and MUL. The PUSH and POP instructions, however, need an address field to specify the operand that communicate with Stack. Program to evaluate

$x = (A+B) * (C+D)$  in CDS follows:-

|      |   |                                  |                             |
|------|---|----------------------------------|-----------------------------|
| PUSH | A | $TOS \leftarrow A$               | $TOS = \text{Top of Stack}$ |
| PUSH | B | $TOS \leftarrow B$               |                             |
| ADD  |   | $TOS \leftarrow A+B$             |                             |
| PUSH | C | $TOS \leftarrow C$               |                             |
| PUSH | D | $TOS \leftarrow D$               |                             |
| ADD  |   | $TOS \leftarrow C+D$             |                             |
| MUL  |   | $TOS \leftarrow ((C+D) * (A+B))$ |                             |
| POP  | X | $M[X] \leftarrow TOS$            |                             |

|         |
|---------|
| 14040   |
| 311     |
| 400     |
| 3       |
| 1501413 |

## ADDRESSING MODES

(6)

The addressing mode specifies a rule for interpreting or modifying the address field of the instruction. The way the operands are chosen during program execution is dependent on the addressing mode of instruction. Computer uses addressing mode due to following main reasons:-

- ① To give programming versatility to the user by providing such facilities as pointer to memory, counter for loop control, indexing of data and program relocation.
- ② To reduce the number of bits in the addressing field of the instruction.

### Different Type of addressing modes :-

#### ① Implied mode / Direct address mode

In implied mode, the Operands are specified implicitly in the definition of the instruction.  
e.g. the instruction "Complement accumulator" is an implied mode. because operand in, accumulators register.  
in implied in definition of instruction. Another example  
in zero-address instructions in stack-organized computer  
are implied-mode instruction since operands are  
implied to be on top of stack.

#### ② Immediate mode → / Indirect address mode

In this mode the operand is

specified in the instruction itself. In other words, immediate mode instruction has an operand field rather than an address field. The operand field contains the actual operand to be used in conjunction with the operation specified in instruction. Immediate mode instructions are useful for initializing registers to a constant value.



### ③ Register mode:

In this mode, operands are in registers. Instruction specifies a register in the CPU whose contents give the address of operand in memory. In other words selected registers contain the address of operand rather than operand itself. e.g. LDI H, 2000H - load H-L pair with 2000H

MOV A,M - move content of memory location whose address is in H-L pair (2000) to AC.

### ④ Auto incremented or auto-decremented mode:

In this mode, operands are in registers that are outside within CPU. Particular register is selected from a register field in the instruction. e.g. MOV A,B, 78, ADD B

### ⑤ Auto increment or auto-decrement mode:

This is similar to register indirect mode except that the register is incremented or decremented after its value is used to access memory. When the address stored

The register refers to a table of data in memory, (7). It is necessary to increment or decrement the register after every access to the table.

⑥ Direct address mode

In direct address mode, the effective address is equal to the address part of the instruction. The operand resides in memory and its address is given directly by address field of instruction.

⑦ Indirect address mode

In this mode, address field of instruction gives the address where the effective address is stored in memory. Control fetches the instruction from memory and uses its address part to access memory again to read the effective address.

In a few address modes requires that the address field of instruction be added to content of a specific register in CPU. The effective address in these mode is calculated as:-

$$\text{Effective Address} = \text{address of part of instruction} + \text{content of}$$

⑧ Relative Address mode

In this mode content of Program Counter is added to address part of instruction in order to obtain the effective address. The address part of instruction is usually a signed

number which can be either positive or negative. When this number is added to content of program counter, the result produces an effective address whose position in memory is relative to address of the next instruction.

e.g. Program counter = 825

Address part of instruction = 25

Effective address computation for relative address mode  
is =  $825 + 25 = 850$ .

So, effective address is at memory location  
forward from address of the next instruction.

#### ⑨ Index Addressing mode:

In index addressing mode content of index register is added to address part of instruction to obtain the effective address. The index register is a special CPU register that contains an index value. Address field of instruction defines the beginning address of data array in memory.

#### ⑩ Base Register Addressing mode:

In base register addressing mode content of base register is added to the address part of instruction to obtain effective address. This is similar to index addressing mode except that the register is now called base register instead of index register.

## Program Control - PC

(8)

Instructions are always stored in successive memory locations. When processed in the CPU, the instructions are fetched from consecutive memory locations and executed. Each time an instruction is fetch from memory, the program counter is incremented so that it contains the address of next instruction in sequence. After the execution of data transfer or data manipulation instruction, control returns to fetch cycle with the program counter containing the address of the instruction next in sequence. A program control instructions specify condition for altering the content of program counter, while data transfer and data manipulation instruction specify conditions for data processing operations.

Following are some typical instructions of Program Control

are listed as below:-

|         |      |
|---------|------|
| Branch  | BR   |
| Jump    | JMP  |
| Skip    | SKP  |
| Call    | CALL |
| Return  | RET  |
| Compare | CMP  |
| Test    | TST  |

## Reduced Instruction Set Computer (RISC) & CISC

CISC → In the early days, computer had small and simple instruction sets, forced mainly by the need to minimize the hardware used to implement them. Many computers have instruction sets that include more than 100 and sometimes even more than 200 instructions. A computer with a large number of instructions is classified as a complex instruction set computer.

RISC → It is recommended that computers with use fewer instructions with simple construct so they can be executed much faster within the CPU without having to use memory as often. This type of computer is classified as a reduced instruction set computer or RISC.

### CISC Characteristics

- ① A large number of instructions - typically from 100 to 250 instructions.
- ② Some instructions that perform specialized tasks and are used infrequently.
- ③ A large variety of addressing modes - typically from 8 to 20 different mode.

④ Variable length instruction formats. ⑨

⑤ Instruction that manipulate operands in memory.

### RISC characteristics

\*\*\*

- ① Relatively few instructions.
- ② Relatively few addressing modes
- ③ Memory access limited to load and store instructions.
- ④ All operations done within the registers of the CPU.
- ⑤ ~~Fixed~~ <sup>Fixed</sup> length, easily decoded instruction format.
- ⑥ Single-cycle instruction execution.

- ⑦ RISC is ~~hardwired~~ <sup>Hardwired</sup> rather than ~~microprogrammed~~ <sup>microprogrammed</sup>.  
⑧ ~~hardwired~~ <sup>microprogrammed control</sup> unit.

### MULTIPLICATION ALGORITHMS

Multiplication of two fixed-point numbers in signed-magnitude representation is done with

following example:-

$$\begin{array}{r} 23 \\ \times 19 \\ \hline \end{array}$$

10111 → multiplicand  
x 10011 → multiplier

$$\begin{array}{r} 10111 \\ 10011 \times \\ 00000 \times \\ 00000 \times \times \\ 10111 \times \times \\ \hline \end{array}$$

437       $\overline{110110101}$  → Result.

## Hardware Implementation for signed-magnitude Data.



[Hardware for multiply operation]

Hardware for multiplication consists of various registers, these registers together with registers A and B as shown in figure. The multiplier is shown in Q registers and its sign in Qs. Sequence counter is initially set to a number equal to number of bits of in the multiplier. The counter is decremented by 1 after forming each partial product. When content of counter reaches to zero, product is formed and process stops.

Multiply operation



[Flow chart for multiply algorithm]

Initially the multiplicand is in B and multiplier in Q. Their corresponding signs are stored in  $B_s$  and  $Q_s$  respectively. The signs are compared and both A and Q are set to corresponding to sign of product since a double

length product will be stored in registers A and Q.  
Registers A and E are cleared and the sequence counter SC is set to a number equal to number of bits of multiplier.

After the initialization, low-order bit of multiplier in  $Q_n$  is tested. If it is a 1, multiplicand in B is added to present partial product in A. If it is 0, nothing is done. Register FAQ is then shifted once to right to form the new partial product. Sequence counter is decremented by 1 and its new value checked. If it is not equal to zero, process is repeated and new

partial product formed. Process stops when  $SC=0$ . The final product is available both in A and Q, with A holding the most significant bits and Q holds least

significant bits.

Multiplicand B = 10111

E      A      Q      SC

Multiplicand in Q

$Q_n=1$ ; add B

First partial product

Shift Right FAQ

|   |       |       |         |
|---|-------|-------|---------|
| 0 | 00000 | 10011 | 101 (5) |
|   | 10111 |       |         |

|   |       |       |         |
|---|-------|-------|---------|
| 0 | 10111 |       |         |
| 0 | 01011 | 11001 | 100 (4) |

|   |       |       |  |
|---|-------|-------|--|
| 0 | 10111 |       |  |
| 1 | 00010 | 11001 |  |

|   |       |       |         |
|---|-------|-------|---------|
| 0 | 10001 | 01100 | 011 (3) |
| 0 | 01000 | 10110 | 010 (2) |

|   |       |       |         |
|---|-------|-------|---------|
| 0 | 00100 | 01011 | 001 (1) |
|   |       |       |         |

$Q_n=1$ , add B

Second partial product

Shift Right FAQ

$Q_n=0$ , Shift Right FAQ

$Q_n=0$ , Shift Right FAQ.

(5)  $Q_{n+1}$ ; add B

Fifth partial product

Shift Right EAQ

$$\begin{array}{r} A \\ \text{---} \\ 00100 \\ 10111 \\ \hline 11011 \\ \text{---} \\ 01101 \quad 10101 \\ \hline \end{array}$$

se. enqplied  
MODULE - 3.  
Continue

Final Product in AQ = 0110110101

$Q_n$  = Stores the lower-order bit of the multiplier.

A = Registers.

E = carry holder registers.



Booth Multiplication Algorithm

Booth algorithm works for both positive or negative multipliers in 2's complement representation. For example, a multiplier equal to  $-14$  is represented in 2's complement as  $110010$  and is treated as  $-2^4 + 2^2 - 2^1 = -14$ .

Binary Number of  $14 = 01110$   $01110$  ( $+14$ ).

1's complement =  $10001$

2's " =  $110010$  ( $+14$ ) 2's complement.

Hardware implementation of Booth algorithm require following registers configuration.

Hardware requirement is same as

with previous example except here we rename registers.

A, B and Q, as AC, BR and QR.  $Q_n$  designates the least significant bit of multiplier. An extra flip flop  $Q_{n+1}$  is appended to QR.



Flowchart for Booth algorithm,

AC and appended bit  $Q_{n+1}$  are initially cleared to 0 and sequence counter SC is set to number equal to bits of the multiplier. The two bits of the multipliers in  $Q_n$  and  $Q_{n+1}$  are tested, if two bits are equal to 10, it means that the first '1' in a string of 1's has been encountered. This requires subtraction of multiplicand from partial product in AC. If two bits are equal to 01, it means that first '0' in string of 0's has been encountered. This requires addition of multiplicand to partial product of AC. When two bits are equal, partial product does not change. Next step is to shift Right partial product and multiplier. Sequence counter is decremented and computational loop replicated n-times.



(Flow chart for Booth algorithm)

e.g.  $(-9) \times (-13)$

Example of Booth algorithm with the help of

$(-9)$   
Multiplicand = 10111 and

Multipplier = 10011 is shown in table  
 $(-13)$

as below:-

$$\begin{aligned} t_9 &= 0100 \\ (-9) &= 10110 \quad 1's \text{ complement} \\ &= 10111 \quad 2's \text{ complement} \end{aligned}$$

$$\begin{aligned} t_{13} &= 01101 \\ (-13) &= 10010 \quad 1's \text{ complement} \\ &= 10011 \quad 2's \text{ complement} \end{aligned}$$

$$(-9 \times -13) = 117$$

$\text{BR} = 10111$

| $Q_{n+1}$ | $\text{BR} + 1 = 01001$                                                        | AC               | QR              | $Q_{n+1}$ | SC      |
|-----------|--------------------------------------------------------------------------------|------------------|-----------------|-----------|---------|
|           |                                                                                | Initial<br>00000 | 10011           | 0         | 101 (5) |
| 1 0       | Subtract BR<br>$\begin{array}{r} 01001 \\ - 01001 \\ \hline 00000 \end{array}$ | 00000            | 11001           | 1         | 100 (4) |
| 1 1       | ashr                                                                           | 00100            | 01100           | 1         | 011 (3) |
| 0 1       | ADD BR<br>$\begin{array}{r} 10111 \\ + 11001 \\ \hline 11000 \end{array}$      | 10111            | 10110           | 0         | 010 (2) |
| 0 0       | ashr<br>$\begin{array}{r} 11000 \\ \downarrow \\ 00110 \end{array}$            | 00110            | 01011           | 0         | 001 (1) |
| 1 0       | Subtract BR<br>$\begin{array}{r} 01001 \\ - 00111 \\ \hline 00000 \end{array}$ | 01001            | 00000           | 0         | 000 (0) |
|           | ashr                                                                           | $\boxed{00011}$  | $\boxed{10101}$ |           |         |
|           |                                                                                |                  |                 |           | +117.   |

### Array multiplier

multiplication of two binary numbers can be done with one microoperation by means of a circuit that forms the product of bits all at once. This is the fast way of multiplying two numbers since all it takes is the time for the signals to propagate through gates that form the multiplication array. However, an array multiplier requires a large number of gates.

## Booth Algorithm

MODULE 3

11 (1)

$$(a) (+15) \times (+13) = +195 = (00110000011)_2$$

$$BR = 0111 \quad (+15); \quad 0111$$

$$\overline{BR+1} = 10001 \quad (-15)$$

$$QR = 01101 \quad (+13)$$

-15x13

Q<sub>n</sub> Q<sub>n+1</sub>

AC

QR

Q<sub>n+1</sub>

SC.

Initial 00000 01101 0 101

1 0 sub BR 10001

①

10001

ashr 11000 10110 1 100  
00001

② 0 1 sub BR add BR

00111 10110

①

ashr. 00011 11011 0 011  
10001

③ 1 0 Sub BR

10100 11011 0

ashr. 11010 01101 1 001

④ 1 1 ash. 11101 00110 1  
01111

⑤ 0 1 add BR.

01100 00110  
00110 00011 0 000

0 - 01100 00110  
0 0110 00011 1

$$\textcircled{b} \quad (+15) \times (-13) = -195$$

$$195 = \underline{(011000011)}_2$$

$$1's \text{ comp of } 195 = 100111100$$

$$2's \text{ comp of } 195 = 100111101$$

$$-195 = \underline{(\cancel{100}00 (100111101))}_2 \text{ complement}$$

$$BR = 01111 (+15)$$

$$\bar{BR} + 1 = (10000 + 1) = (10001) (-15)$$

$$QR = (-15) \Rightarrow (+13) = \underline{01101}$$

$$= (-13) = \underline{10010}$$

$$= \underline{(10011) (-13)}$$

$$= \underline{(10011) 2's \text{ complement}}$$

$$BR = -01111$$

$$BR+1 = 10001$$

11(2)

Qn Qn+1 AC QR Qn+1 SC

|         |       |       |   |     |     |
|---------|-------|-------|---|-----|-----|
| initial | 00000 | 10011 | 0 | 101 | (5) |
|         | 10001 |       |   |     |     |

① | 0 subBR

|       |       |   |
|-------|-------|---|
| 10001 | 10011 | 0 |
|-------|-------|---|

ashr

|       |       |   |            |     |
|-------|-------|---|------------|-----|
| 11000 | 11001 | 1 | <u>100</u> | (4) |
|-------|-------|---|------------|-----|

② | 1 ashx. | 11100 01100 1 011 | (3)

|       |
|-------|
| 01111 |
|-------|

③ 0 1 Add BR

|               |
|---------------|
| 01011 01100 1 |
|---------------|

aShr

|                              |
|------------------------------|
| 00101 10110 0 <u>010</u> (2) |
|------------------------------|

|                  |
|------------------|
| <del>10001</del> |
|------------------|

④ . 0 0 subBR

ashr 0010 11011 0 001 (1)

|       |
|-------|
| 10001 |
|-------|

⑤ . 1 0 sub BR

|               |
|---------------|
| 10011 11011 0 |
|---------------|

ashr

|              |
|--------------|
| -11001 11101 |
|--------------|

000 (0)

in 2's complement form

|      |
|------|
| -195 |
|------|

Ans.

How to check → 11 001 11101

6 1's complement → 00 11000010

2's " "

+195

|            |
|------------|
| 0011000011 |
|------------|

$$(-9) \times (-13) = +117$$

$$\begin{aligned} BR = -9 &= 01001 = 10110+1 \\ &= (10111) \text{ 2's complement.} \end{aligned}$$

$$\begin{aligned} \overline{BR+1} &= 01001, \\ QR &= 01101 = 10010+1 = (10011) \text{ 2's complement} \\ &\quad (-13). \end{aligned}$$

$$\text{Ans} = (+117) = 01110101$$

$$(-9) \times (-13) = +117$$

(2)

11(3)

$Q_n$   $Q_{n+1}$  AC QR  $Q_{n+1}$  SC.

|         |       |       |   |     |
|---------|-------|-------|---|-----|
| initial | 00000 | 10011 | 0 | 101 |
|         | 01001 |       |   |     |

① 1 0 SUBBR

|       |       |   |
|-------|-------|---|
| 01001 | 10011 | 0 |
|-------|-------|---|

|      |       |       |   |     |
|------|-------|-------|---|-----|
| ashr | 00100 | 11001 | 1 | 100 |
|------|-------|-------|---|-----|

|             |       |       |   |     |
|-------------|-------|-------|---|-----|
| ② 1 1 ashri | 00010 | 01100 | 1 | 011 |
|             | 10111 |       |   |     |

|             |       |       |   |
|-------------|-------|-------|---|
| ③ 0 1 addBR | 11001 | 01100 | 1 |
|-------------|-------|-------|---|

|      |       |       |   |     |
|------|-------|-------|---|-----|
| ashr | 11100 | 10110 | 0 | 010 |
|------|-------|-------|---|-----|

|             |       |       |   |     |
|-------------|-------|-------|---|-----|
| ④ 0 0 ashri | 11110 | 01011 | 0 | 001 |
|             | 01001 |       |   |     |

⑤ 1 0 SubDR

|       |       |   |
|-------|-------|---|
| 00111 | 01011 | 0 |
|-------|-------|---|

ashr

|       |       |   |     |
|-------|-------|---|-----|
| 00011 | 10101 | 1 | 001 |
|-------|-------|---|-----|

(AC & QR)

Result.

$1 + 4 + 16 + 32 + 64$

|       |       |
|-------|-------|
| 91765 | 43210 |
| 11001 | 11101 |

64

32

16

5

117.

\* Booth algorithm requires examination of the multiplier bits and shifting of the partial product. Prior to shifting, the multiplicand may be added to partial product, subtracted from the partial product or left unchanged according to following rules:-

- 1) multiplicand is subtracted from partial product upon encountering the first bit least significant 1 in string of 1's in multiplier.
- 2) multiplicand is added to partial product upon encountering the first '0' in string of 0's in multiplier.
- 3) Partial product does not change when the multiplier bits are identical to previous multiplier bit.

Divisor

B = 10001

11010

Quotient = Q

13 1

Dividend = A

43210

= 17

01110 | 5-bits of A < B, Quotient has 5-bit.

011100 | 6-bits of A > B.

- 10001 | Sub. Enter 1 in Q.

001011

= 17

0010110 | 7-bits of remainder > B.

- 10001 | Sub. Enter 1 in Q.

00001010 | Remainder < B. enter '0' in Q.

000010100

- 10001

0000000110 | Remainder < B enters  
'0' in Q.

00110 → 6.

Final remainder.

26

17 | 448

X

6

## Divide operation



The divisor is stored in B register and the double-length dividend is stored in registers A and Q. The dividend is shifted to left and divisor is subtracted from by adding 2's complement value. The information about the relative magnitude is available in E.

✓ If  $E=1$ .

It signifies that  $A \geq B$ . A quotient bit '1' is inserted into Qn and partial remainder is shifted to the left to repeat the process.

≤ If  $E=0$ , it signifies that  $A < B$   
 so the quotient in  $Q_n$  remains a '0'.  
 The value of  $B$  is then added to  
 restore the partial remainder in  $A$   
 to its previous value. The partial  
 remainder is shifted to the left &  
 the process is repeated again until  
 all five quotient bits are formed.

The final remainder  
 stored in register  $A$  and the quotient in  
 register  $Q$ .

### Hardware Configuration:



13(3)



common algo. from diagram

divide-overflow flip flop DVF is set and operation is terminated. If  $A < B$ , no divide overflow occurs, so value of dividend is restored by adding B to A.

The division of the magnitudes starts by shifting the dividend in AQ to the left with the higher-order bit shifted into E. If bit shifted into E is 1, then 'B' must be subtracted from A and 1 inserted into Qn for quotient bit.

If the shift-left operation inserts a '0' into E, the divisor is subtracted by adding its 2's complement value and carry is transferred into E. If  $E=1$ , it signifies that  $A \geq B$ , therefore Qn is set to 1. If  $E=0$ , it signifies that  $A < B$  and original number is restored by adding B to A. And value of sequence counter is decremented by 1. This process is repeated again with register A holding partial remainder until value of sequence counter (SC) is not equal to '0'.

Explanation of division algorithm with help of example.

Explanation of division algorithm is shown as:-

P.T.O.

Divisor  $B = 10001$

$\bar{B}+1 = 01111$

E A Q SC

Dividend  $\quad \quad \quad 01110 \quad \quad \quad 00000 \quad \quad \underline{5(101)}$

Shl EAQ  $\quad \quad \quad 0 \quad \quad \quad 11100 \quad \quad \quad 00000$

Add  $\bar{B}+1 \quad \quad \quad \underline{01111}$

E=1  $\quad \quad \quad 1 \quad \quad \quad 01011$

Set  $Q_n < 1 \quad \quad \quad 1 \quad \quad \quad 01011 \quad \quad \quad 00001 \quad \quad \underline{4(100)}$

Shl EAQ  $\quad \quad \quad 0 \quad \quad \quad 10110 \quad \quad \quad 00010$

Add  $\bar{B}+1 \quad \quad \quad \underline{01111}$

E=1  $\quad \quad \quad 1 \quad \quad \quad 00101$

Set  $Q_n < 1 \quad \quad \quad 1 \quad \quad \quad 00101 \quad \quad \quad 00011 \quad \quad \underline{3(011)}$

Shl EAQ  $\quad \quad \quad 0 \quad \quad \quad 01010 \quad \quad \quad 00110$

Add  $\bar{B}+1 \quad \quad \quad \underline{01111}$

0  $\quad \quad \quad 10001 \quad \quad \quad 00110$

E=0,  $Q_n < 0$

100 B

$10001$

$00110$

$\underline{2(010)}$

Restore Remainder

1  $\quad \quad \quad 01010$

$00110$

Shl EAQ

0  $\quad \quad \quad 10100$

$01100$

Add  $\bar{B}+1$

$01111$

$01100$

E=1, ~~Set~~

1  $\quad \quad \quad 00011$

$01101$

Set  $Q_n < 1$

1  $\quad \quad \quad 00011$

$01101$

$\underline{1(001)}$

Shl EAQ

0  $\quad \quad \quad 00110$

$11010$

Add  $\bar{B}+1$

$01111$

$11010$

$\underline{\text{Continues...}}$

$E=0$ , set  $Q_n \leftarrow 0$   
Add B.

0 10101 11010

IS(1)

10001

| 00110

11010

000(0).

Remainder

Quotient

(1)

An array multiplier can be implemented with a combinational circuit, consider multiplication of following 2-bit numbers:-

$$\begin{array}{r} b_1 \quad b_0 \\ a_1 \quad a_0 \\ \hline a_0 b_1 & a_0 b_0 \\ a_1 b_1 & a_1 b_0 \\ \hline c_3 & c_2 & c_1 & c_0 \end{array}$$

The first partial product is formed by multiplying  $a_0$  by  $b_{01}$ . Multiplication of two bits produces a 1, if both bits are 1, otherwise it produces '0'. This is identical to AND operation and can be implemented with AND Gate.

Second partial product is formed by multiplying  $a_1$  by ' $b_{10}$ ' and in shifted one position to the left. These two partial products are added with the two-half adder circuits and accordingly sum and carry will be generated to find out the required 'product bits'.

And 2-bit by 2-bit array multiplier is shown as below:-

P.T.O.



[2-bit by 8-bit array multiplier]

Division Algorithm

The division process is illustrated in the following example. The divisor  $B$  consists of 8-bits and the dividend  $A$ , of ten bits. The 5-most significant bit of dividend is compared with the divisor. Since 5-bit number is smaller than  $B$ , we will try by taking the sixth most significant bit of  $A$  and compare this number with  $B$ . 6-bit number is greater than  $B$  so we place a '1' for quotient bit.



(Addition OR Subtraction of floating point numbers.)

$A_1$  = most Significant of mantissa,

- ④ The magnitude comparator attached to exponents a and b provide three outputs that indicate their relative magnitude. If two exponents are equal, we perform the arithmetic operation. If exponents are not equal, mantissa having smaller exponent is shifted to <sup>left</sup> right and its exponent is incremented. Process is repeated until two exponents are equal.
- ⑤ Magnitude part is now added or subtracted depending upon the operation and sign of two mantissas. If an overflow occurs when magnitudes are added, it is transferred into flip flop E. If E is equal to 1, bit is transferred into A, and all other bits of A are shifted right. Exponent must be unincremented to maintain correct number.

- ⑥ → If the manif magnitudes were subtracted, the result may be zero or may have an underflow. If mantissa is zero, entire floating number in A is zero. Otherwise mantissa must have at least one bit that is equal to 1. The mantissa has an underflow if most significant bit in position A<sub>1</sub> is 0. In this case mantissa is shifted left and exponent decremented by 1. Bit in A<sub>1</sub> is checked again and process is repeated until it is equal to 1. When A mantissa is normalized and operation is complete.

# Multiplication of floating point numbers

(18)



[multiplication of floating-point number].

① The Two operands are checked to determine if they contain a zero. If either operand is equal to zero, product in AC is set to 0. and operation is terminated. If neither of operands is equal to zero, process continues with exponent addition.

The exponent of multiplier is in 'q' and add in between exponents 'a' and 'b'. If it is necessary to transfer exponents from 'q' to 'a', add two exponents and transfer sum unto 'a'.

② Multiplication of mantissa is done as same with fixed point multiplication algorithm.

③ The product may have an underflow, so most significant bit in A is checked. If it is equal to 1, product is already normalized. If it is equal to 0, mantissa in A is shifted left and exponent decremented. And finally multiplication operation for floating point number is completed.



(add more trigonometric to this algorithm)