

# Computer Organization and Architecture

## UNIT-I

CSE : II - I

### Digital Computers

Introduction :- The digital computer is a digital system that perform various computational tasks. The first electronic digital computer, developed in the late 1940s, was used primarily for numerical computations and the discrete elements were the digits. From this application the term digital computer emerged.

→ digital computers use the binary number system, which has two digits: 0 and 1. A binary digit is called a bit. Information is represented in digital computers in groups of bits. By using various coding techniques, groups of bits can be made into representations not only binary numbers but also other discrete symbols, such as decimal digits or letters of the alphabets.

# Block diagram of Digital Computer



→ Flow of data & instructions  
----> Control Signal.

Input unit :- Input unit used to process of entering data and programs in to the computer system, the input unit takes data from us to the computer in an organized manner for processing.

(2)

CPU :- The Central Processing unit (CPU) takes data and instructions from the storage unit and makes all sorts of calculations based on the instructions given and the type of data provided.

Memory unit :- All the data and instructions are stored here before and after processing. Intermediate results of processing are also stored here.

Control unit :- It controls the all operations like input, processing and output are performed by control unit. It takes care of step by step processing of all operations inside the computer.

Output unit :- An output device is a part of computer hardware equipment which converts information into human-readable form. It can be text, graphics, tactile, audio and video.

Computer Organization :- Computer Organization refers to the level of abstraction above the digital logic level, but below the operating systems. It mainly concerned with the structure and behaviour of a computer system as seen by the user.

- It tells us how exactly all the units in the system are arranged and interconnected.
- An organization is done on the basis of architecture.
- Computer organization deals with the low level design issues. which involves physical components such as circuit design, Adders, signals and peripherals.
- The main objective of this subject to understand the overall basic computer hardware structure, including the peripheral devices.

## Computer design and Computer Architecture

Computer design:- Computer design is concerned with the hardware design of a computer. Once the computer specifications are formulated, it is the task of the designer to develop hardware for the system.

Computer Architecture:- Computer Architecture is a functional description of requirements and design implementation for the various parts of computer. It deals with the functional behaviour of computer system. It deals with high level design issue. Architecture indicates its hardware. Architecture coordinates between the hardware and software of the system.



## Register transfer Language and microoperations

Registers are a type of computer memory used to quickly accept, store, and transfer data and instructions that are being used immediately by the CPU. The registers used by the CPU are often termed as processor registers.

- A processor register may hold ~~data~~ an instruction, a storage address or any data.
- The computer needs processor registers for manipulating data and a register for holding a memory address.

Micro-operations:- A micro operation is an elementary operation performed on the information stored in one or more registers.

- The result of microoperation may be stored in source or another register.
- Examples of microoperations are load, store, clear, shift, addition, count etc.

→ A sequence of microoperations were performed to complete one operation.

For example

To add two numbers following micro operation sequence has to be performed.

1. Load first number in register 1
2. Load second number in register 2
3. Perform add micro operation
4. Store the result in the destination register 3

How can we write above lengthy description in symbolic notation.

$$R_1 \leftarrow A$$

$$R_2 \leftarrow B$$

$$R_3 \leftarrow R_1 + R_2$$

Register transfer language :-

The symbolic notation used to describe the micro-operation among registers called

Register transfer Language.

There were various methods of RTL-

- General way of representing a register by the name of the register enclosed in a rectangular box.



- Register is numbered in a sequence of 0 to n-1.



- The numbering of bits in a register can be marked on the top of the box.



- A 16-bit register PC is divided into 2 parts. Bits (0 to 7) were assigned with lower byte of 16-bit address and bits (8 to 15) were assigned with higher bytes of 16-bit address.



## Register transfer :-

The information transferred from one register to another register is represented in symbolic form by replacement operator is called Register transfer.

### Replacement Operator :-

In the statement,  $R_2 \leftarrow R_1$ ,  $\leftarrow$  acts as a replacement operator. This statement defines the transfer of content of register  $R_1$  into register  $R_2$ .

### Basic symbols of RTL:-

( )  $\rightarrow$  denotes a part of register -  $R_1$  (8-bit)

$\leftarrow$   $\rightarrow$  denotes a transfer of information -  $R_2 \leftarrow R_1$

)  $\rightarrow$  specify two micro-operations of register transfers. -  $R_1 \leftarrow R_2$   
 $R_2 \leftarrow R_1$

:  $\rightarrow$  denotes Conditional Operations -  $P: R_2 \leftarrow R_1$   
if  $P=1$

## Register transfer Operations

The operation performed on the data stored in the registers are referred to as register transfer operations.

There are different types of register transfer operations:

1. Simple transfer -  $R_2 \leftarrow R_1$

The content of  $R_1$  are copied into  $R_2$  without affecting the content of  $R_1$ . It is an unconditional type of transfer operation.

2. Conditional transfer :-

P :  $R_2 \leftarrow R_1$



It indicates that if  $P=1$ , then the content of  $R_1$  is transferred to  $R_2$ . It is a unidirectional operation.

### 3. Simultaneous Operations :-

If 2 or more operations were to occur simultaneously then they were separated with commas(,)



$n = \text{no. of bits}$

If the control function  $P=1$ , then load the content of  $R_1$  into  $R_2$  and at the same clock load the content of  $R_2$  into  $R_1$ .

## Bus and Memory transfers :-

A typical digital computer has many registers and paths must be provided to transfer information from one register to another. The number of wires will be excessive if separate lines are used between each register and all other registers in the system.

→ A more efficient scheme for transferring information between registers in a multiple-register configuration is a common bus system.

→ A bus structure consists of a set of common lines, one for each bit of a register through which binary information is transferred one at a time.

→ Here we will see two ways to construct the bus.

a) By using multiplexers

b) By using three state buffer.

2) By Using Multiplexers :- A Multiplexer is a digital switch that has multiple inputs and a single output.

→ The select lines determine which input is connected to the output.

→ Multiplexer is denoted as MUX

→ MUX Types :- 2 to 1 (1 select line)

4 to 1 (2 select lines)

8 to 1 (3 select lines)

16 to 1 (4 select lines)

# Multiplexer block diagram



One way of constructing a multiplexers. The multiplexers whose binary information is select the source register then placed on the bus.

Ex: The construction of a bus system for four registers:



## Function Table for Bus.

| $S_1$ | $S_0$ | Register Selected |
|-------|-------|-------------------|
| 0     | 0     | A                 |
| 0     | 1     | B                 |
| 1     | 0     | C                 |
| 1     | 1     | D                 |

→ Description of 4- Register bus:-

→ Each register has four bits, numbered 0 to 3. The bus consist of four  $4 \times 1$  multiplexers each having four data inputs, 0 to 3, and two (selected lines) selection inputs,  $S_1$  and  $S_0$ . In order not to complicate the diagram with 16 lines crossing each other, we use tables to show the connections from the outputs of the registers to the inputs of the multiplexers.

→  $S_1$  and  $S_0$  selection lines should be applied to all MUXO

MUX1, MUX2, MUX3.

→ each MUX receives input from all registers.

for example MUXO receives input from output 0 bit of all the registers. i.e Register A '0' bit is  $A_0$ , Register B '0' bit is  $B_0$ , Register C '0' bit is  $C_0$  and Register D '0' bit output is  $D_0$ .

and similarly MUX1 receives the inputs from '1' bit of four registers and remaining 2 mux will receive the bits from 8 bit & 3 bit of all registers.

→ The two selection lines  $S_1$  and  $S_0$  are connected to the selection inputs of all four multiplexers.

→ When  $S_1 S_0 = 00$ , the 0 data inputs of all 4 multiplexers are selected and applied to the outputs that form the bus. This causes the bus lines to receive the content of Register A

→ Similarly Register B is selected if  $S_1 S_0 = 01$  and so on.

→ The transfer of information from a bus into one of many destination registers can be accomplished by connecting the bus lines to the inputs of all destination registers and activating the load control. The symbolic statement for bus transfer

$\text{BUS} \leftarrow C, R_1 \leftarrow \text{BUS}$

The above syntax represents the content of register C is placed on the bus, and the content of bus is loaded into register  $R_1$  by activating its load control input.



Bus transfer using three state buffer :-

→ A bus system can also be constructed using three-state-buffer.  
A three state buffer is a digital circuit that has three gates,

1. logic 1

2. logic 0

3. the third gate exhibits a high-impedance state.

→ In high-impedance state the circuit behaves as a open circuit, and the output transfer is blocked.  
→ Therefore a three state buffer is a combinational circuit that acts like a simple switch.



Graphic Symbols for three-state buffers

- If control input  $C=1$  then it passes the input signal to the output.  
→ If  $C=0$  then the electrical current will be blocked. This case is called high-impedance state.

## Bus transfer using three state buffer



- The outputs generated by the four buffers were connected to form a single bus line.
- Only one buffer can be in active state at a given point of time.
- The control inputs to the buffers determine which of the four normal inputs will communicate with the bus line.
- A  $2 \times 4$  decoder ensures that no more than one control input is active at any given point of time.

→ A<sub>0</sub>, B<sub>0</sub>, C<sub>0</sub>, D<sub>0</sub> were the 0<sup>th</sup> bits of registers A, B, C, D respectively.

→ S<sub>1</sub>, S<sub>0</sub> were the selector lines used to give the control signal.

| S <sub>1</sub> | S <sub>0</sub> | control input |
|----------------|----------------|---------------|
| 0              | 0              | 0 is selected |
| 0              | 1              | 1 is selected |
| 1              | 0              | 2 is selected |
| 1              | 1              | 3 is selected |

≡

## \*Memory transfer\*

The transfer of information from a memory word to the outside environment is called a read operation.

- The transfer of a new information to be stored into the memory is called a write operation.
- A memory word will be symbolized by the letter M.
- We must specify the address of memory word while writing the memory transfer operations.

→ The address register is designated by AR and the data register is by DR.



→ A read operation can be stated as:

$$\text{Read : } DR \leftarrow M[AR]$$

The above statement indicates that a transfer of information into the data register [DR] from the memory word (M) selected by the address register (AR).

→ The Write operation can be stated as:

$$\text{Write : } M[AR] \leftarrow R_1$$

The above statement describes that a transfer of information from  $R_1$  into the memory word (M) selected by the address register (AR).

# Logic gate :-

| Name                      | Graphic symbol                                                                      | Algebraic equation             | Truth table                                                                                                                                                                                                                                                            |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|---------------------------|-------------------------------------------------------------------------------------|--------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 1 AND                     |    | $F = x * y$                    | <table border="1"> <thead> <tr> <th>x</th><th>y</th><th>F</th></tr> </thead> <tbody> <tr><td>0</td><td>0</td><td>0</td></tr> <tr><td>0</td><td>1</td><td>0</td></tr> <tr><td>1</td><td>0</td><td>0</td></tr> <tr><td>1</td><td>1</td><td>1</td></tr> </tbody> </table> | x | y | F | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 1 | 1 | 1 |
| x                         | y                                                                                   | F                              |                                                                                                                                                                                                                                                                        |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 0                         | 0                                                                                   | 0                              |                                                                                                                                                                                                                                                                        |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 0                         | 1                                                                                   | 0                              |                                                                                                                                                                                                                                                                        |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 1                         | 0                                                                                   | 0                              |                                                                                                                                                                                                                                                                        |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 1                         | 1                                                                                   | 1                              |                                                                                                                                                                                                                                                                        |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 2 OR                      |   | $f = x + y$                    | <table border="1"> <thead> <tr> <th>x</th><th>y</th><th>F</th></tr> </thead> <tbody> <tr><td>0</td><td>0</td><td>0</td></tr> <tr><td>0</td><td>1</td><td>1</td></tr> <tr><td>1</td><td>0</td><td>1</td></tr> <tr><td>1</td><td>1</td><td>1</td></tr> </tbody> </table> | x | y | F | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 1 |
| x                         | y                                                                                   | F                              |                                                                                                                                                                                                                                                                        |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 0                         | 0                                                                                   | 0                              |                                                                                                                                                                                                                                                                        |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 0                         | 1                                                                                   | 1                              |                                                                                                                                                                                                                                                                        |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 1                         | 0                                                                                   | 1                              |                                                                                                                                                                                                                                                                        |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 1                         | 1                                                                                   | 1                              |                                                                                                                                                                                                                                                                        |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 3 Inverter<br>(or)<br>NOT |  | $F = x'$                       | <table border="1"> <thead> <tr> <th>x</th><th>F</th></tr> </thead> <tbody> <tr><td>0</td><td>1</td></tr> <tr><td>1</td><td>0</td></tr> </tbody> </table>                                                                                                               | x | F | 0 | 1 | 1 | 0 |   |   |   |   |   |   |   |   |   |
| x                         | F                                                                                   |                                |                                                                                                                                                                                                                                                                        |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 0                         | 1                                                                                   |                                |                                                                                                                                                                                                                                                                        |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 1                         | 0                                                                                   |                                |                                                                                                                                                                                                                                                                        |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 4 Buffer                  |  | $F = \cancel{\text{Invert}} x$ | <table border="1"> <thead> <tr> <th>x</th><th>F</th></tr> </thead> <tbody> <tr><td>0</td><td>0</td></tr> <tr><td>1</td><td>1</td></tr> </tbody> </table>                                                                                                               | x | F | 0 | 0 | 1 | 1 |   |   |   |   |   |   |   |   |   |
| x                         | F                                                                                   |                                |                                                                                                                                                                                                                                                                        |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 0                         | 0                                                                                   |                                |                                                                                                                                                                                                                                                                        |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| 1                         | 1                                                                                   |                                |                                                                                                                                                                                                                                                                        |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |

Name

Graphic symbol

Algebraic function

Truth table

5 Nand



$$F = (xy)'$$

| x | y | F |
|---|---|---|
| 0 | 0 | 1 |
| 0 | 1 | 1 |
| 1 | 0 | 1 |
| 1 | 1 | 0 |

6 NOR



$$F = (x+y)'$$

| x | y | F |
|---|---|---|
| 0 | 0 | 1 |
| 0 | 1 | 0 |
| 1 | 0 | 0 |
| 1 | 1 | 0 |

7 Exclusive-OR (XOR)



$$\begin{aligned} f &= xy' + x'y \\ &\text{(or)} \\ &\Rightarrow x \oplus y \end{aligned}$$

| x | y | F |
|---|---|---|
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 1 |
| 1 | 1 | 0 |

8 Exclusive-NOR (XNOR)  
equivalence



$$\begin{aligned} F &= xy + x'y' \\ &\text{(or)} \\ &= (x \oplus y)' \end{aligned}$$

| x | y | F |
|---|---|---|
| 0 | 0 | 1 |
| 0 | 1 | 0 |
| 1 | 0 | 0 |
| 1 | 1 | 1 |

## Addition of two binary numbers

Eg:  $R_1 = 10010$

$$R_2 = 11010$$

$$R_3 \leftarrow R_1 + R_2$$

$\begin{array}{r} 00100 \\ 10010 \\ + 11010 \end{array} \rightarrow \text{Carry value.}$

$\overline{1101100} \rightarrow \text{Sum value}$

MSB  
(most significant bit)

## Addition of # bit binary number

Eg.  $R_1 = 1101$

$$R_2 = 1011$$

$$R_3 \leftarrow R_1 + R_2$$

$\begin{array}{r} 1110 \\ 1101 \\ + 1011 \end{array} \rightarrow \text{Carry value.}$

$\overline{111000} \rightarrow \text{Sum value.}$

MSB  
 $\overline{111000} \rightarrow \text{Sum value.}$

Sum value = 1000

Carry value = 1110.

## Arithmetic Micro Operations :-

Arithmetic micro-operations performs arithmetic operation on numerical data stored in registers.

→ The basic arithmetic micro-operations are

- Addition
- Subtraction
- Increment
- Decrement
- Shift.

|   | Symbolic Designation                 | Description                                            |
|---|--------------------------------------|--------------------------------------------------------|
| 1 | $R_3 \leftarrow R_1 + R_2$           | contents of $R_1$ plus $R_2$ transferred to $R_3$      |
| 2 | $R_3 \leftarrow R_1 - R_2$           | contents of $R_1$ minus $R_2$ transferred to $R_3$     |
| 3 | $R_2 \leftarrow \bar{R}_2$           | complements the content of $R_2$ ( $1's$ complement)   |
| 4 | $R_2 \leftarrow \bar{R}_2 + 1$       | $2's$ complement. the content of $R_2$ (negate).       |
| 5 | $R_3 \leftarrow R_1 + \bar{R}_2 + 1$ | $R_1$ plus the $2's$ complement of $R_2$ (Subtraction) |
| 6 | $R_1 \leftarrow R_1 + 1$             | Increment the contents of $R_1$ by one                 |
| 7 | $R_1 \leftarrow R_1 - 1$             | Decrement the contents of $R_1$ by one.                |

## Addition :-

### Binary Adder

To implement the add micro operation with hardware, we need the registers that hold the data and the digital component that performs the arithmetic addition.

- The digital circuit that forms the arithmetic sum of two bits and a previous carry is called a full-adder.
- The digital circuits that generates the arithmetic sum of two binary numbers of carry length is called binary adder.
- The binary adder is constructed with full adder connected in cascade.
- The output carry from one full-adder connected to the input carry of the next full-adder.
- The interconnections of four full adders (EA) to provide a 4-bit binary adder.



4-bit binary adder

- The augend bits of A and the addend bits of B were designated by subscript numbers from right to left, with subscript '0' denoting the low order bit.
- The carries are connected in a chain through the full adders.
- The input carry to the binary adder is  $C_0$  and the output carry is  $C_4$ .
- The S outputs of the full-adders generate the required sum bits.
- An n-bit binary adder requires n full-adders.

Y

## 4-bit binary Adder-Subtractor :-

In digital circuits, A Binary-Subtractor is one which is capable of both addition and subtraction of binary numbers in one circuit itself.

→ The operation being performed depends upon the binary value the control holds.

→ This circuit requires Exor gate, Binary addition and subtraction, Full adder.



→ Let's consider two 4-bit binary numbers A and B as inputs to the digital circuit for the operation.

A0 A1 A2 A3 for A

B0 B1 B2 B3 for B

- the circuit consist of 4 full adders since we are performing operation on 4-bit numbers.
- there is a mode operation M that holds a binary value of either 0 or 1 which determines that the operation being carried out is addition or subtraction.
- When  $M=0$  the circuit is adder and when  $M=1$  the circuit becomes a subtractor.
- When  $M=0$ , we have  $B \oplus 0 = B$ .
- When  $M=1$ , we have  $B \oplus 1 = B'$  and  $C_0 = 1$ .  
When M is at a high logic, the B inputs are complemented and a 1 is added through input carry. The circuit performs the operation  $+ 1$  plus the 2's complement of B.
- it can be represented as

$$R. \leftarrow A + \overline{B} + 1$$

Z

## Binary Incrementer:-

The increment micro-operation adds one binary value to the value of binary variables stored in a register.

→ For instance a 4-bit register has a binary value 0101, when incremented by one the value becomes 0110.

→ A 4-bit combinational circuit Incrementer can be represented by the following block diagram.



→ A logic-1 is applied to one of the inputs of least significant half-adder, and the other input is connected to the least significant bit of the number to be incremented.

→ The output Carry from one half-adder is connected to one of the inputs of the next-higher-order half-adder.

\* The binary incrementer circuit receives the four bits from A<sub>0</sub> through A<sub>3</sub>, adds one to it, and generate the incremented output in S<sub>0</sub> through S<sub>3</sub>.

→ The output carry C<sub>4</sub> will be 1 only after incrementing binary 1111

### Arithmetic Circuit :-

→ The arithmetic microoperations can be implemented in one composite arithmetic circuit.

→ A 4-bit arithmetic circuit has four full-adder circuits that constitute the 4-bit adder and 4-multiplexers for choosing different operations.

→ There are two 4-bit inputs A and B and a 4-bit output D.

→ The 4 inputs from A go directly to the x inputs of the binary adder.

→ Each of output of multiplexers is go to the y inputs of the binary adder.

→ The input Carry  $C_{in}$  goes to the carry input of the full adder in the least significant position. The other carries are connected from one stage to the next.

→ Each of four inputs ( $B_0, B_1, B_2, B_3$ ) from B are connected to the data inputs ( $0, 1, 2, 3$ ) of the multiplexers.

→ The Multiplexers data inputs (1) receive the complements of B.

→ The other two data inputs (2, 3) are connected to logic-0 and logic-1

→ The four multiplexers are controlled by two Selection inputs; S, and so

The output of the binary adder is calculated from the following arithmetic sum:

$$D = A + Y + C_{in}$$

Where A is the 4-bit binary number and Y is the 4-bit binary number and the Y inputs

of the binary adder.  $C_{in}$  is the input carry, which can be equal to 0 or 1.



# Arithmetic Circuit function table

| Select<br>$S_1\ S_0\ C_{in}$ | Input<br>$y$ | Output<br>$D = A + y + C_{in}$ | Microoperation       |
|------------------------------|--------------|--------------------------------|----------------------|
| 0 0 0                        | B            | $D = A + B$                    | Add                  |
| 0 0 1                        | B            | $D = A + B + 1$                | add with carry       |
| 0 1 0                        | $\bar{B}$    | $D = A + \bar{B}$              | Subtract with borrow |
| 0 1 1                        | $\bar{B}$    | $D = A + \bar{B} + 1$          | Subtract             |
| 1 0 0                        | 0            | $D = A$                        | Transfer A           |
| 1 0 1                        | 0            | $D = A + 1$                    | Increment A          |
| 1 1 0                        | 1            | $D = A - 1$                    | Decrement A          |
| 1 1 1                        | 1            | $D = A$                        | Transfer             |

When  $S_1S_0 = 00$ , the value of B is applied to the y inputs of the adder. If  $C_{in} = 0$ , the output  $D = A + B$ , if  $C_{in} = 1$ , output  $D = A + B + 1$ . both cases perform addition operation with or without adding the input carry.

→ When  $S_1, S_0 = 01$ , the complement of B is applied to the y inputs of the adder, if  $C_{in} = 1$ . Then Output  $D = A + \bar{B} + 1$ , which is equivalent to a subtraction of  $A - B$ .

→ When  $S_1, S_0 = 10$ , all 0's are inserted into the y inputs. The output is  $D = A + 0 + C_{in}$  i.e.  $D = A + C_{in}$  when  $C_{in} = 0$ , then output  $D = A + 0$  i.e.  $D = A$ . when  $C_{in} = 1$ , then output  $D = A + 1$

→ In the first case we have a direct transfer from input A to output D, in the second case the value of A is incremented by 1.

→ When  $S_1, S_0 = 11$ , all 1's are inserted into the y inputs of the adder to produce the decrement operation  $D = A - 1$ , when  $C_{in} = 0$ , this is because a number with all 1's is equal to the 2's complement of 1 (the 2's complement of binary 0001 is 1111)

→ When  $C_{in} = 1$  then  $D = A - 1 + 1 \Rightarrow A$ , which cases a direct transfer from input A to Output D.

\* The microoperation  $D = A$  is generated twice, so there are only seven distinct microoperations in the arithmetic circuit

## Logic Microoperations

Logic microoperations specify binary operations for strings of bits stored in registers. These operations consider each bit of the register separately and treat them as binary variables. For example the exclusive-OR microoperation with the contents of two registers  $R_1$  and  $R_2$ :

$$P: R_1 \leftarrow R_1 \oplus R_2$$

Eg:

$$\begin{array}{r} 1010 \\ 1100 \\ \hline 0110 \end{array} \begin{array}{l} \text{contents of } R_1 \\ \text{contents of } R_2 \\ \text{content of } R_1 \text{ after } P=1 \end{array}$$

- Special symbols will be adopted for the logic microoperations OR, AND, and complement. to represent them from the corresponding symbols used to express boolean functions.
- The symbol  $\vee$  will be used to denote an OR microoperation.
- The symbol  $\wedge$  to denote an AND operation.

→ The complement microoperations is the same as the 1's complement and uses a bar on top of the symbol

### List of Logic microoperations:-

There are 16 different logic operations that can be performed with two binary variables

→ They can be determined from all possible truth tables obtained with two binary variables each of the 16 columns  $F_0$  through  $F_{15}$  represents a truth table.

| x | y | $F_0$ | $F_1$ | $F_2$ | $F_3$ | $F_4$ | $F_5$ | $F_6$ | $F_7$ | $F_8$ | $F_9$ | $F_{10}$ | $F_{11}$ | $F_{12}$ | $F_{13}$ | $F_{14}$ | $F_{15}$ |
|---|---|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|----------|----------|----------|----------|----------|----------|
| 0 | 0 | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1     | 1     | 1     | 1        | 1        | 1        | 1        | 1        | 1        |
| 0 | 1 | 0     | 0     | 0     | 0     | 1     | 1     | 1     | 0     | 0     | 0     | 0        | 1        | 1        | 1        | 1        | 1        |
| 1 | 0 | 0     | 0     | 1     | 1     | 0     | 0     | 1     | 1     | 0     | 0     | 0        | 1        | 1        | 1        | 1        | 1        |
| 1 | 1 | 0     | 1     | 0     | 1     | 0     | 1     | 0     | 0     | 1     | 0     | 1        | 0        | 0        | 1        | 0        | 1        |

The 16 boolean functions of two variables  $x$  and  $y$  are expressed in algebraic form in the first column.

## Boolean function

## Microoperation

Name

|    |                       |                                       |                 |
|----|-----------------------|---------------------------------------|-----------------|
| 1  | $f_0 = 0$             | $F \leftarrow 0$                      | clear           |
| 2  | $F_1 = xy$            | $F \leftarrow A \wedge B$             | AND             |
| 3  | $F_2 = xy'$           | $F \leftarrow A \wedge \bar{B}$       |                 |
| 4  | $F_3 = x$             | $F \leftarrow A$                      | Transfer A      |
| 5  | $F_4 = x'y$           | $F \leftarrow \bar{A} \wedge B$       |                 |
| 6  | $F_5 = y$             | $F \leftarrow B$                      | Transfer B      |
| 7  | $F_6 = x \oplus y$    | $F \leftarrow A \oplus B$             | Exclusive - OR  |
| 8  | $F_7 = x+y$           | $F \leftarrow A \vee B$               | OR              |
| 9  | $F_8 = (x+y)'$        | $F \leftarrow (\bar{A} \vee \bar{B})$ | NOR             |
| 10 | $F_9 = (x \oplus y)'$ | $F \leftarrow \bar{A} \oplus \bar{B}$ | Exclusive - NOR |
| 11 | $F_{10} = y'$         | $F \leftarrow \bar{B}$                | Complement B    |
| 12 | $F_{11} = x+y'$       | $F \leftarrow A \vee \bar{B}$         |                 |
| 13 | $F_{12} = x'$         | $F \leftarrow \bar{A}$                | Complement A    |
| 14 | $F_{13} = x'+y$       | $F \leftarrow \bar{A} \vee B$         |                 |
| 15 | $F_{14} = (xy)'$      | $F \leftarrow \overline{A \wedge B}$  | NAND            |
| 16 | $F_{15} = 1$          | $F \leftarrow \text{all } 1's$        | set to all 1's  |

## Hardware Implementation :-

The hardware implementation of logic micro-operations requires that logic gates be inserted for each bit or pair of bits.

→ Although there are 16 logic microoperations, most computers use only four - AND, OR, XOR (exclusive OR), and complement from which all others can be derived.

→ Logic microoperations are very useful for manipulating individual bits or a portion of a word stored in register.



| S <sub>1</sub> | S <sub>0</sub> | OLP                | Operation  |
|----------------|----------------|--------------------|------------|
| 0              | 0              | E = A $\wedge$ B   | AND        |
| 0              | 1              | E = A $\vee$ B     | OR         |
| 1              | 0              | E = A $\oplus$ B   | XOR        |
| 1              | 1              | E = $\overline{A}$ | Complement |

Function table

One stage of logic circuit

## Shift microoperations

Shift microoperations are used for serial transfer of data. They are also used in conjunction with arithmetic, logic and other data processing operations. The contents of a register can be shifted to the left or the right. At the same time that the bits are shifted.

- during a shift left operation the serial input transfers a bit into a bit into the rightmost position
- During a shift right operation the serial input transfers a bit into the leftmost position.
- there are three types of shifts;
  - Logical shift
  - circular shift
  - Arithmetic shift.

Logical shift :- A logical shift is one of that transfers '0' through the serial input. we will adopt the symbols shl and shr for logical shift-left and shift-right microoperations.

$$\begin{aligned} R_1 &\leftarrow \text{shl } R_1 \\ R_2 &\leftarrow \text{shr } R_2 \end{aligned}$$

The two microoperations specify a 1-bit shift to the left of the content of Register  $R_1$  and a 1-bit shift to the right of the content of register  $R_2$ . The register symbol must be the same on both sides of the arrow. The bit transferred to the end position through the serial input is assumed to be 0 during a logical shift.

Circular shift :- The circular shift also known as rotate operation circulates the bits of the register around the two ends without loss of information. This is accomplished by connecting the serial input of the shift register to its serial output. We will use the symbols  $cil$  and  $cir$  for the circular shift left and right respectively.

$$\begin{array}{ccc} R_1 & \xleftarrow{cil} & R_1 \\ R_2 & \xleftarrow{cir} & R_2 \end{array}$$

Arithmetic shift :- An arithmetic shift is a micro-operation that shifts a signed binary number to the left & right. An arithmetic shift-left multiplies a signed binary number by 2.

→ An arithmetic shift right divides the number by 2.

→ Arithmetic shift must leave the sign bit unchanged because the sign of the number remains the same when it multiplied & divided by 2.

### Shift microoperations

#### Symbolic designation

$R \leftarrow \text{shl } R$

$R \leftarrow \text{shr } R$

$R \leftarrow \text{crl } R$

$R \leftarrow \text{ctr } R$

$R \leftarrow \text{ashl } R$

$R \leftarrow \text{asher } R$

#### Description

shift-left Register R

shift-right Register R

circular shift-left Register R

circular shift-right Register R

arithmetic shift-left Register R

arithmetic shift-left R

## Hardware Implementation

Serial  
input (IR)

Select:

0 for shift right (down)  
1 for shift left (UP)



Serial input (IL)

Function table

| Select |                | output         | H <sub>0</sub> | H <sub>1</sub> | H <sub>2</sub> | H <sub>3</sub> |
|--------|----------------|----------------|----------------|----------------|----------------|----------------|
| S      |                |                |                |                |                |                |
| 0      | IR             | A <sub>0</sub> |                |                |                |                |
| 1      | A <sub>1</sub> | A <sub>2</sub> | A <sub>3</sub> | A <sub>2</sub> | A <sub>1</sub> | IL             |

A Combinational Circuit Shifter can be constructed with multiplexers. The 4-bit shifter has four data inputs,  $A_0$  through  $A_3$  and four data outputs,  $H_0$  through  $H_3$ . There are two serial inputs, one for shift left ( $I_L$ ) and the other for shift right ( $I_R$ ). When the selection input  $S=0$  the input data core shifted right. The function table shows. When  $S=1$  the input data were shifted left. The two serial inputs can be controlled by another multiplexer to provide the three possible types of shifts.

\* Arithmetic logic shift unit - Instead of having individual registers performing the micro operations directly, Computer Systems employ a number of storage registers connected to a common operational unit called arithmetic logic unit, abbreviated ALU.

one stage of arithmetic logic shift unit



→ the above diagram represents the one stage of arithmetic logic shift unit. The subscript 'i' describes a typical stage. Inputs  $A_i$  and  $B_i$  are applied to both the arithmetic and logic units. A particular microoperation is selected with inputs  $S_1$  and  $S_0$ .

→ A  $4 \times 1$  multiplexer at the output chooses between an arithmetic circuit output  $D_i$  and a logic output  $E_i$ . The data in the multiplexer are selected with inputs  $S_3$  and  $S_2$ . The other two data inputs to the multiplexer receive inputs  $A_{i-1}$  for the shift right operation and  $A_{i+1}$  for the shift left operation.

→ The output carry  $C_{i+1}$  of a given arithmetic stage must be connected to the input carry  $C_i$  of the next stage in sequence.

→ The circuit whose one stage is specified provides eight arithmetic operations, four logic operations and two shift operations.

→ The first eight are arithmetic operations and are selected with  $S_3 S_2 = 00$ . The next four are logic operations and are selected with  $S_3 S_2 = 01$ .

→ The last two operations are shift operations and are selected with  $S_3 S_2 = 10$  and  $11$ .

The other

# Function table for Arithmetic logic shift unit

operation select :-

| $S_3$ | $S_2$ | $S_1$ | $S_0$ | $C_{in}$ | Operation             | function             |
|-------|-------|-------|-------|----------|-----------------------|----------------------|
| 0     | 0     | 0     | 0     | 0        | $F = A$               | Transfer A           |
| 0     | 0     | 0     | 0     | 1        | $F = A + 1$           | Increment A          |
| 0     | 0     | 0     | 1     | 0        | $F = A + B$           | Addition             |
| 0     | 0     | 0     | 1     | 1        | $F = A + \bar{B} + 1$ | Add with carry       |
| 0     | 0     | 1     | 0     | 0        | $F = A + \bar{B}$     | Sub with borrow      |
| 0     | 0     | 1     | 0     | 1        | $F = A + \bar{B} + 1$ | Subtraction          |
| 0     | 0     | 1     | 1     | 0        | $F = A - 1$           | Decrement A          |
| 0     | 0     | 1     | 1     | 1        | $F = A$               | Transfer A           |
| 0     | 1     | 0     | 0     | X        | $F = A \wedge B$      | AND                  |
| 0     | 1     | 0     | 1     | X        | $F = A \vee B$        | OR                   |
| 0     | 1     | 1     | 0     | X        | $F = A \oplus B$      | XOR                  |
| 0     | 1     | 1     | 1     | X        | $F = \bar{A}$         | Complement A         |
| 1     | 0     | X     | X     | X        | $F = \text{shr } A$   | shift right A into F |
| 1     | 1     | X     | X     | X        | $F = \text{shl } A$   | shift left A into F  |

# Basic Computer Organization and Design

24

## Instruction codes :-

- A digital computer is capable of executing several microoperations.
- An instruction code is a group of bits that instructs the computer to perform a specific operation.

Program:- A program is a set of instructions that specify the operations, operands, and the sequence by which processing has to be done.

→ An instruction code is a group of bits that instructs the computer to perform specific operation. It is usually divided into two parts, each having its own particular interpretation.

→ Operation code (opcode)

→ Operands.

The most basic part of an instruction code is its operation part.

→ The operation code (opcode) of an instruction is a group of bits that define each operation such as add, subtract, multiply, shift and complement.

- it must consist of at least  $n$  bits for a given  $n$  distinct operations.
- Suppose we are having 64 ( $2^6$ ) operation - then the length of opcode will be 6.
- the operation part of instruction code specifies the operation to be performed.
- there are many ways to arrange the binary code of instructions, and each computer has its own particular instruction code format.

### stored program organization

- the simplest way to organize a computer is to have one processor register and an instruction code format with two parts.
- the first part specifies the operation to be performed and the second part specifies an address.

- the memory address tells the ~~computer~~ control where to find a operand in memory.



Instruction format



processor register

(AC) accumulator

→ Instructions are stored in one section of memory

→ and data in another

→ For a memory unit with 4096 words we need 12 bits to specify an address since  $2^{12} = 4096$ .

→ If we store each instruction code in one 16-bit memory word, we have available four bits for the operation code (OpCode) to specify one out of ~~16~~ 16 possible operations, and 12 bits to specify the address of an operand.

→ The control reads a 16 bit instruction from the program portion of memory.

→ It uses 10 bit address part of instruction to read 16-bit operand from the data portion of memory, it then executes the operation specified by the operation code.

→ The computers that have a single-processor registers usually assign to it the name accumulator and label it AC.

→ The operation is performed with the memory operand and the content of AC.

Immediate Operand:- Sometimes address bits of an instruction code is used to hold actual operand when second part of an instruction code specifies an operand, the instruction is said to have an immediate operand.

Direct address:- When second part of an instruction specifies the address of an operand, the instruction is said to have a direct address.

Indirect address:- When the bits of the second part of the instruction designates an address of a memory word in which the address of the operand is found.

# Direct and Indirect addressing example

26



(a) Instruction format



(b) Direct address



(c) Indirect address

Computer registers :-

the basic Computer has 8 registers.

- Data registers
- Address registers
- Accumulators
- Instruction registers
- Program Counter
- Temporary registers

- Input registers
- Output registers.



Basic Computer registers and memory

- The memory unit has a capacity of 4096 words and each word contains 16 bits. Twelve bits of an instruction word will be needed to specify the address of an operand.
- The DR (data register) holds the operand read from memory.
- The accumulator (AC) register is a general purpose processing register. The instruction read from memory is placed in the Instruction register (IR).
- The temporary register (TR) is used for holding temporary data during the processing.

- The memory address register (AR) has 12 bits since this is the width of a memory address.
- The program counter (PC) also has 12 bits and it holds the address of the next instruction.
- Two registers are used for input and output. The input register (INPR) receives an 8-bit character from an input device. The output (OUTR) holds an 8-bit character for an output device.

### Computer Instructions :-

The basic computer has three instruction code formats. Each format has 16 bits. The three instruction formats are

1. Memory - reference instruction
2. Register - reference instructions
3. Input - output reference instructions.

#### 1. Memory - reference instruction :-

Memory reference instruction uses 12 bits to specify an address and one bit to specify the addressing mode I. I is equal to 0 for direct address and to 1 for indirect address.

|    |        |         |  |                            |
|----|--------|---------|--|----------------------------|
| 15 | 14     | 12 11   |  | 0                          |
| I  | Opcode | Address |  | (opcode = 000 through 110) |

(a) Memory - reference instruction

2. Register - reference instruction format :-

The register - reference instructions were recognized by the operation code 111 with a 0 in the leftmost bit (bit 15) of the instruction. A register - reference instruction specifies an operation or a test of the AC register. An operand from memory is not needed, the other 12 bits are used to specify the operation or test to be executed.

|        |                    |  |   |
|--------|--------------------|--|---|
| 15     | 12 11              |  | 0 |
| 0 11 1 | Register operation |  |   |

opcode = 111, I = 0

(b) Register - reference instruction

3. Input - output operation instructions :-

Input - output instructions does not need a reference memory and is recognized by the operation code 111 with 1 in the leftmost bit of the instruction.

→ the remaining 12 bits are used to specify the type of input-output operation or test performed.



$$\text{opcode} = 111, I = 1$$

### (b) Input-Output Instruction

The type of instruction is recognized by the computer control from the four bits in positions 12 through 15 of the instruction. If the three opcode bits in positions 12 through 14 are not equal to 111, the instruction is a memory-reference type and the bit in position 15 is taken as the addressing mode I.

→ If the 3-bit opcode is equal to 111, the 15 bit is 0, the instruction is a registers-reference type. If the 15 bit is 1, the instruction is an input-output type.

# Basic Computer Instructions

| Symbol | <u>Hexadecimal code</u> |      | Description                                  |
|--------|-------------------------|------|----------------------------------------------|
|        | I=0                     | I=1  |                                              |
| AND    | 0XXX                    | 8XXX | AND memory word to AC                        |
| ADD    | 1XXX                    | 9XXX | ADD memory word to AC                        |
| LDA    | 2XXX                    | AXXX | LOAD memory word to AC                       |
| STA    | 3XXX                    | BXXX | Store content of AC in memory                |
| BUN    | 4XXX                    | CXXX | Branch unconditionally                       |
| BSA    | 5XXX                    | DXXX | Branch and Save return address               |
| ISZ    | 6XXX                    | EXXX | Increment and skip if zero.                  |
| CLA    | 7800                    |      | clear AC                                     |
| CLE    | 7400                    |      | clear E                                      |
| CMA    | 7900                    |      | Complement AC                                |
| CME    | 7100                    |      | complement E                                 |
| CIR    | 7080                    |      | Circulate right AC and E                     |
| CIL    | 7040                    |      | Circulate left AC and E                      |
| INC    | 7020                    |      | Increment AC                                 |
| SPA    | 7010                    |      | skip next instruction                        |
| SNA    | 7008                    |      | if AC positive<br>skip next instruction      |
| SZE    | 7002                    |      | if AC negative<br>skip next instruction & E0 |
| HLT    | 7001                    |      | Halt Computer                                |

| Symbol | Hexadecimal code | Description              |
|--------|------------------|--------------------------|
| INP    | F800             | Input character to AC    |
| out    | F400             | Output character from AC |
| SKI    | F200             | Skip on input flag.      |
| SKO    | F100             | Skip on output flag      |
| ION    | F080             | Interrupt on             |
| IOF    | F040             | Interrupt off            |

- A memory reference ~~register~~ instruction has an address part of 12 bits. The address part is denoted by three x's and stand for the three hexadecimal digits being equivalent to ~~12~~ bits address.
- The last bit of the instruction is designated by the symbol I.
- When  $I=0$ , the last four bits of an instruction have a hexadecimal digit equivalent from 0 to 6 since the last bit is 0.
- When  $I=1$ , the hexadecimal digit equivalent of the last four bits of the instruction ranges from 8 to E since the last bit is 1.

→ Register reference instructions use 16 bits to specify an operation. The leftmost four bits are always 0111, which is equivalent to hexadecimal 7. The other three hexadecimal digits give the binary equivalent of the remaining 12 bits.

→ The input-output instructions also use all 16 bits to specify an operation. The last four bits are always 1111, equivalent to hexadecimal F.

### Common bus system (Computer registers).

The basic computer has eight registers, a memory unit, and a control unit. Paths must be provided to transform information from one register to another and between memory and registers. The number of wires will be excessive if connections are made between the outputs of each register and the inputs of the other registers.

A more efficient scheme for transferring information in a system with many registers is to use a common bus.



Basic Computer registers Connected to a Common bus

Connections:- The output of all the registers except the OUTR (Output register) were connected to the common bus. The output selected depends upon the binary value of variables  $S_2, S_1$  and so. The lines from common bus are connected to the inputs of the registers and memory.

→ A register receives the information from the bus when its LD (load) input is activated. While in case of memory the write input must be enabled to receive the information. The contents of memory are placed onto the bus when its Read input is activated.

### Various registers :-

4 registers DR, AC, IR and TR have 16 bits and 2 registers AR and PC have 12 bits. The INPR and output have 8 bits each. The INPR receives characters from input device and delivers it to the AC while the output register receives characters from AC and transfers it to the output device. 5 registers have 3 control inputs. LD (load), INR (increment) and CLR (clear). These type of registers are similar to a binary counter.

## Adder and logic circuit :-

The adder and logic circuit provides the 16 inputs of AC. This circuit has 3 sets of inputs. One set comes from the outputs of AC which implements register microoperations. The other set comes from DR (Data Register) which are used to perform arithmetic logic and microoperations. The result of these operations is sent to AC while the end around carry is stored in E. as the third set PS from INPR.

## Instruction set completeness (Computer Instructions)

A computer should have a set of instructions so that the user can construct machine language programs to evaluate any function that is known to be computable.

→ The set of instructions are said to be complete if the computer includes a sufficient number of instructions in each of the following categories.

1. Arithmetic, logical and shift instructions.
2. Instructions for moving information to and from memory and processor registers.
3. Program control instructions to gether with instructions that check status conditions.
4. Input and output instructions.

→ Arithmetic, logic and shift instructions provide computational capabilities for processing the type of data the user may wish to employ.

→ A huge amount of binary information is stored in the memory unit, but all computations are done in processor registers. Therefore, one must possess the capability of moving information between these two units.

→ Program control instructions such as branch instructions are used change the sequence in which the program is executed.

→ Input and output instructions act as an interface between the computer and the user. Programs and data must be transferred into memory, and the results of computations must be transferred back to the user.

## Timing & Control :-

(32)

Timing and control units are present in CPU. Control unit mainly useful to generate the timing and control signals. Control unit coordinates between CPU, main memory, Input and output devices. The control unit is classified into two major categories.

1. Hardwired control

2. Microprogrammed control.

### Hardwired control :-

The hardwired control organization, the control logic is implemented with gates, flip-flops, decoders, and other digital circuits.

→ The following image shows the block diagram of a Hardwired control organization.

→ A Hard-wired control consists of two decoders, a sequence counter, and a number of logic gates.

→ An instruction fetched from the memory unit is placed in the instruction register (IR).

→ The component of an instruction register includes; 1 bit, the operation code, and bits 0 through 11.

- The operation code in bits 12 through 14 are coded with a 3x8 decoder.
- The outputs of the decoder are designated by the symbols  $D_0$  through  $D_7$ .
- The operation code at bit 15 is transferred to a flip-flop designated by the symbol I.
- The operation codes from bits 0 through 11 are applied to the control logic gates.
- The sequence counter (SC) can count in binary from 0 through 15.

Instruction register



Control unit of a basic computer

(35)

As an example, consider the case where SC is incremented to provide timing signals  $T_0, T_1, T_2, T_3$  &  $T_4$  in sequence. At time  $T_4$ , SC is cleared to 0 if decoder output  $D_3$  is active. This is expressed symbolically by the statement.

$$D_3 T_4 : \text{SC} \leftarrow 0$$



example of control timing signal.

## 2. Microprogrammed control Organization:-

In the microprogrammed organization, the control information is stored in a control memory. The control memory is programmed to initiate the required sequence of microoperations.

→ In the microprogrammed control, any required changes & modifications can be done by updating the microprogram in control memory.

## Instruction Cycle :-

A program residing in the memory unit of the computer consists of a sequence of instructions. The program is executed in the computer by going through a cycle for each instruction. Each instruction cycle in turn is subdivided into a sequence of subcycles or phases. In the basic computer each instruction cycle consists of the following phases:

1. Fetch an instruction from memory.
2. Decode the instruction.
3. Read the effective address from memory if the instruction has an indirect address.
4. Execute the instruction.

The completion of step 4, the control goes back (34) to step 1 to fetch decode, and execute the next instruction. This process continues indefinitely unless a HALT instruction is encountered.

### Fetch and Decode:-

Initially, the program counter PC is loaded with the address of the first instruction in the program. The sequence counter SC is cleared to 0, providing a decoded timing signal  $T_0$ . After each clock pulse, SC is incremented by one, so that the timing signals go through a sequence  $T_0, T_1, T_2$  and so on. The microoperations for the fetch and decode phases can be specified by the following register transfer statements.

$T_0: AR \leftarrow PC$

$T_1: [IR \leftarrow M[AR]], PC \leftarrow PC + 1$

$T_2: D_0 \dots D_7 \leftarrow \text{Decode } IR(12-14), AR \leftarrow IR(0-11), I \leftarrow IR(15)$



Registers transfers for the fetch Phase

The first two registers statements are implemented in the bus system. To provide the data path for the transfer of PC to AR we must apply timing signal T0.

1. place the content of PC onto bus by making the bus selection inputs  $S_2, S_1, S_0$  equal to 010.
2. Transfer the content of bus to AR by enabling the LD input of AR.

The next clock transition initiates the transfer from PC to AR since  $T_0 = 1$ . In order to implement the second statement

$$T_1: IR \leftarrow M[AR], PC \leftarrow PC + 1$$

It is necessary to use timing signal  $T_1$  to provide the following connections in the bus system.

1. Enable the read input of memory bus
2. Place the content of memory onto bus by making  $S_2, S_1, S_0 = 111$ .
3. Transfer the content of the bus to IR by enabling the LD input of IR.
4. Increment PC by enabling the INR input of PC.

The next clock transition initiates the read and increment operations since  $T_1 = 1$ . Multiple input OR gates were included in the diagram because there are other control functions that will initiate similar operations.

Determine the type of instruction :-  
 The timing signal that is active after the decoding is  $T_3$ . During the time  $T_3$ , the control units determine the type of instruction that was just read from memory.



Decoder output  $D_7$  is equal to 1 if the operation code is equal to binary 111. we determine that if  $D_7=1$ , the instruction must be a register-reference & input-output type. If  $D_7=0$ , the operation code must be one of other seven values 000 through 110, specifying a memory-reference instruction.

→ If  $D_7=0$  and  $I=1$ , we have a memory-reference instruction with an indirect address. It is then necessary to read the effective address from memory.

→ The microoperation for the indirect address condition can be symbolized by the register transfer statement.

$$AR \leftarrow M[AR]$$

→ The three instruction types are subdivided into four separate paths. The selected operation is activated with the clock transition associated with timing signal  $T_3$ . This can be symbolized as follows.

$$D_7^I T_3 : AR \leftarrow M[AR]$$

$$D_7^I I^I T_3 : \text{Nothing}$$

$$D_7^I R^I T_3 : \text{Execute a register-reference instruction}$$

## Register reference instructions :-

Register reference instructions are recognized by the control when  $D_7=1$  and  $I=0$ . These instructions use bits 0 through 11 of the instruction code to specify of the 12 instructions. These 12 bits are available in  $IR[0-11]$ . They were also transferred to AR during time  $T_2$ .

## Execution of Register-reference instructions

$D_7 I T_3 = \gamma$  (common to all register-reference instructions)  
 $IRC_i = B_i^i$  (bit in (0-11) that specifies the operation).

|     |                                                                                               |                      |
|-----|-----------------------------------------------------------------------------------------------|----------------------|
|     | $\gamma: SC \leftarrow 0$                                                                     | clear SC             |
| CLA | $\gamma B_{11}: AC \leftarrow 0$                                                              | Clear AC             |
| CLE | $\gamma B_{10}: E \leftarrow 0$                                                               | Clear <del>E</del> E |
| CMA | $\gamma B_9: AC \leftarrow \overline{AC}$                                                     | Complement AC        |
| CME | $\gamma B_8: E \leftarrow \overline{E}$                                                       | Complement E         |
| CIR | $\gamma B_7: AC \leftarrow \text{Shr } AC,$<br>$AC(15) \leftarrow E,$<br>$E \leftarrow AC(0)$ | Circulate right      |
| CIL | $\gamma B_6: AC \leftarrow \text{Shl } AC, AC(0) \leftarrow E,$<br>$E \leftarrow AC(15)$      | Circulate left       |
| INC | $\gamma B_5: AC \leftarrow AC + 1$                                                            | Increment AC         |
| SPA | $\gamma B_4: \text{if } (AC(15)=0) \text{ then}$<br>$(PC \leftarrow PC+1)$                    | Skip if positive     |
| SNA | $\gamma B_3: \text{if } (AC(15)=1) \text{ then}$<br>$(PC \leftarrow PC+1)$                    | Skip if negative     |

|     |                                                                   |                 |
|-----|-------------------------------------------------------------------|-----------------|
| STA | $\tau_{B_2}$ : if ( $AC = 0$ ) then<br>( $PC \leftarrow PC + 1$ ) | skip if AC zero |
| SZE | $\tau_{B_1}$ : if ( $E = 0$ ) then<br>( $PC \leftarrow PC + 1$ )  | skip if E zero  |
| HLT | $\tau_{B_0}$ : $S \leftarrow 0$ ( $S$ is a start-stop flip-flop)  | halt computer.  |

There are a total 12 register reference instructions in computer architecture that are in use and they are listed in table.

→ Each instruction has its own functionality and all these register reference instructions operate on accumulator only.

Functionality of all register reference instructions :-

CLA :- It clears the accumulator and in result it puts a zero in the accumulator.

CLE : Clears the extended accumulator (E) and to place a zero in it.

CMA: It is used to complement the value in the accumulator (AC)

CME: Complements the extended accumulator (E)

CIR: It is used to circulate the accumulator rightwards.

CIL: Circulates the accumulator leftwards.

INC: It is used to increment the value in the accumulator (AC)

SPA: It states that skip to any other location that is specified if the value in the accumulator is positive.

SNA: Skips to some other location if the accumulator has a negative value.

SZA: is used to skip to some other location or instruction if the result stored is zero in the accumulator (A)

SZE:- is used to skip to some other memory location & instruction, if the result acquired is zero in the extended accumulator (A)

HLT :- halts the execution of the program.

## (38)

### Memory reference Instructions :-

The Seven memory reference instructions are decoded output  $D_i$  for  $i = 0, 1, 2, 3, 4, 5$  and 6 from the operation decoder that belongs to each instruction is in the address register AR and was placed there during timing signal  $T_2$  when  $I=0$ , & during timing signal  $T_3$  when  $I=1$ . The execution of the memory-reference instructions starts with timing signal  $T_4$ .

### Memory reference Instructions

| symbol | operation decoder | symbolic description                                  |
|--------|-------------------|-------------------------------------------------------|
| AND    | $D_0$             | $AC \leftarrow AC \cap M[AR]$                         |
| ADD    | $D_1$             | $AC \leftarrow AC + M[AR], F \leftarrow \text{Carry}$ |
| LDA    | $D_2$             | $AC \leftarrow M[AR]$                                 |
| STA    | $D_3$             | $M[AR] \leftarrow AC$                                 |
| BUN    | $D_4$             | $PC \leftarrow AR$                                    |
| BSA    | $D_5$             | $M[AR] \leftarrow PC, PC \leftarrow AR+1$             |
| SSZ    | $D_6$             | if $M[AR]+1 = 0$ then<br>$PC \leftarrow PC+1$         |

### AND to AC :-

- Performs the AND logic operations on pairs of bits in AC and the memory word specified by the effective address.
- Two timing signals are needed.
  - In  $T_1$  transferring Operand from memory into DR
  - In  $T_5$  transferring result of AND logic operation between the contents of DR and AC.
  - In  $T_3$  SC is cleared to 0 and control is transferred to  $T_0$  to start a new instruction cycle.

Example :-

Do  $T_4$ :  $DR \leftarrow M[AR]$

Do  $T_5$ :  $AC \leftarrow AC \wedge DR, SC \leftarrow 0$

### ADD to AC :-

- Adds the contents of memory word specified by the effective address to the value of AC
- Sum is transferred into AC and the output carry Cout is transferred to the E (extended accumulator) flipflop.

$D_1T_4: DR \leftarrow M[AR]$

$D_1T_5: AC \leftarrow AC + DR, E \leftarrow C_{out}, SC \leftarrow 0$

LDA: Load to AC :-

→ Transfers the memory word specified by the effective address to AC.

→ Necessary to read the memory word into DR first and transfer the contents of DR ~~into~~ into AC

→ There is no direct path from bus into AC  
→ to maintain one clock cycle as well.

$D_2T_4: DR \leftarrow M[AR]$

$D_2T_5: AC \leftarrow DR, SC \leftarrow 0$

STA: Store AC :-

→ Stores the content of AC into the memory word specified by the effective address.

→ The output of AC is applied to the bus and the data input of memory is connected to the bus.

$D_3T_4: M[AR] \leftarrow AC, SC \leftarrow 0$

BUN :- Branch unconditionally :-

- PC is incremented at time  $T_1$  to prepare it for the address of the next instruction in the program sequence.
- BUN transfers the program to the instruction specified by the effective address.
- Allows the programmer to specify an instruction out of sequence and we say that the program branches (jumps) unconditionally.

$DUT_4$ :  $PC \leftarrow AR$   $SC \leftarrow 0$  (resetting SC transfers control to  $T_4$ )

BSA: Branch and save return address:-

- useful for branching to a portion of the program called a subroutine or procedure.
- When executed, it stores the address of the next instruction in sequence (which is available in memory location specified by the PC) into a memory effective address.

→ (Effective address + 1) is then transferred to PC to save as the address of the first instruction in the subroutine.

→ The return to the original program is accomplished by the BUN instruction placed at the end of the subroutine.

$$D_5 T_4 : M[AR] \leftarrow PC, AR \leftarrow AR+1$$

$$D_5 T_5 : PC \leftarrow AR, SC \leftarrow 0$$



(a) Memory, PC, and AR at time  $T_4$ .



(b) Memory and PC after execution

Example of BSA instruction execution

ISZ : Increment and skip if zero :-

→ Increments the word specified by zero effective address.

→ If the incremented value is equal to 0, PC is incremented by 1.

→ When a negative number (in 2's complement) stored in memory word is repeated, incremented by 1 until it eventually reaches zero.

→ It is necessary to read the word into DR, increment DR and store the word back into memory since it is not possible to increment a word inside the memory.

D<sub>6</sub>T<sub>4</sub> : DR  $\leftarrow$  M[AR]

D<sub>6</sub>T<sub>5</sub> : DR  $\leftarrow$  DR + 1

D<sub>6</sub>T<sub>6</sub> : M[AR]  $\leftarrow$  DR, if (DR = 0) then

(PC  $\leftarrow$  PC + 1), SC  $\leftarrow$  0

# Flow chart of Memory reference instructions

## Memory-reference Instructions



## Program Interrupt :-

An interrupt is a special signal which needs to be executed immediately whenever the CPU receives interrupt signal, then CPU stops the execution of current running program and CPU control will be shifted to the interrupt related program.

→ Once CPU has completed the execution of interrupt related program CPU control will shift to the original program. Now CPU will execute the remaining instructions of the currently running program.

→ The interrupt enable flip flop - IEN can be set and cleared with two instructions. When IEN is cleared to 0 (with the ION instruction), the flags cannot interrupt the computer. When IEN is set to 1 (with ION instruction), the computer can be interrupted.

## Flow chart for interrupt cycle :-

An interrupt flip flop R is included in the computer. When  $R=0$ , the computer goes through an instruction cycle. whereas as  $R=1$  the computer goes through an interrupt cycle.



flow chart for interrupt cycle.

During the execute phase of instruction cycle  $IEN$  is checked by the control. If it is 0, it

Indicates that the programmer does not want to use the interrupt, so control continues with the next instruction cycle. If IEN is 1 control checks the flag bits. If both flags are zero (0), it indicates that neither the input nor the output registers are ready for transfer information. → In this case, control continues with the next instruction cycle. If either flag is set to 1 while  $IEN = 1$ , flip-flop R is set to 1. At the end of the execute phase, control checks the value of R, and if it is equal to 1, it goes to an interrupt cycle instead of an instruction cycle.

- The interrupt cycle is a hardware implementation of a branch and save return address operation. The return address available in PC is stored in a specific location where it can be found later when the program returns to the instruction at which it was interrupted.
- This location may be a processor register, a memory stack, or a specific memory location.
- Here we choose the memory location at address 0 as the place for storing the return address.

(1)

control then inserts address 1 into PC and clears IEN and R, so that no more interruptions can occur until the interrupt request from the flag has been serviced.

### Demonstration of the Interrupt Cycle:-



(a) Before interrupt



(b) After interrupt cycle

→ The above example happens during the

→ Suppose that an instruction is set to 1 while the control is executed the

instruction at address 255.

that shows that what interrupt cycle is shown.

interrupt occurs and R

the control is executed the

→ At this time, the return address 256 is in PC. The programmer has previously placed an input-output service program in memory starting from address 1120 and a BUN 1120 instruction at address 1.

→ When control reaches timing signal T<sub>0</sub> and finds that R=1, it proceeds with the interrupt cycle.

→ The content of PC(256) is stored in memory location 0, PC is set to 1, and R is cleared to 0.

→ At the beginning of the next instruction cycle, the instruction that is read from the memory is in address 1. Since this is the content of PC.

→ The branch instruction at address 1 causes the program to transfer to the input-output service program at address 1120.

→ This program checks the flags, determine which flag is set, and then transfers the required input or output information.

(u)

Once this is done, the instruction ION is executed to set IEN to 1, and the program returns to the location where it was interrupted.

→ Finally the instruction returns the computer to the original place in the main program is a branch indirect instruction with an address part of 0. This instruction is placed at the end of the I/O service program.

→ after this instruction is read from memory during the fetch phase, control goes to the indirect phase (because  $I=1$ ) to read the effective address.

→ The effective address is in location 0 and is return address that was stored there during the previous interrupt cycle.

→ The execution of the indirect BUN instruction results in placing into PC the return address from location 0.

the interrupt cycle initiated after the last execute phase if the interrupt flip-flop R is equal to 1. This flip-flop is set to 1 if  $IEN=1$  and either  $FGI$  or  $FGO$  are equal to 1. This can happen with any clock transition except when timing signals

$T_0, T_1$  or  $T_2$  are active.

→ The condition for the setting flip-flop R to 1 can be expressed with the following register transfer statement.

$$T_0 \bar{T}_1 \bar{T}_2 (IEN) (FGI + FGO) : R \leftarrow 1$$

The symbol + between  $FGI$  and  $FGO$  in the control function designates a logic OR operation. This is ANDed with  $IEN$  and  $\bar{T}_0 \bar{T}_1 \bar{T}_2$ .

→ This can be done with the following sequence of microoperations.

$$RT_0 : AR \leftarrow 0, TR \leftarrow PC$$

$$RT_1 : M[AR] \leftarrow TR, PC \leftarrow 0$$

$$RT_2 : PC \leftarrow PC + 1, IEN \leftarrow 0, R \leftarrow 0, SC \leftarrow 0$$

During the first timing signal AR is cleared to 0, and the content of PC is transferred to the

(u5)

temporary register TR. with the second timing signal,  
the return address is stored in memory at location  
0 and PC is cleared to 0. The third timing  
signal increments PC to 1, clears IEN and R, and  
control goes back to T0 by clearing SC to 0. The  
beginning of the next instruction cycle has the  
condition R<sup>T0</sup> and the content of PC is equal  
to 1. The control then goes through an instruction  
cycle that fetches and executes the BUN instruction  
in location 1.

\* UNIT - 1 Completed \*