

# Computer Organisation & Architecture.

## ① Computer Architecture:

- concerned with the structure & behavior of the comp. as viewed by a user
- it includes the info, formats, instruction set and techniques for addressing memory.

## ② Computer Organisation: (implementation of architecture of comp)

- concerned with the way the hardware components operate and the way they are connected together to form a comp. system.

## ③ Computer Design:

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

## # MICRO-OPERATIONS:

- The operations executed on data stored in registers.  
Eg: shift, count, clear & load.

### Types:

#### ① Data transfer micro-operation:

##### a) Register transfer micro-operation.

- transfer data from one register to another

##### b) Memory transfer micro-operation:

- transfer data from register to memory or memory to register.

#### ② Arithmetic microoperations

- perform arithmetic operations on data stored in registers.

#### ③ Logic microoperations

- perform bit manipulation operations on non-numeric data stored in registers.

#### ④ Shift microoperations:

- these shift the data in left or right direction stored in registers

## # REGISTER TRANSFER

- transfer of info b/w registers with help of common bus.
- The symbolic notation used to describe the microoperation transfers among registers is called a register transfer language.
- A register transfer language is a system for expressing in symbolic form, the microoperations sequences among the registers of a digital module.
- ④ Computer register → designated by capital letters followed by numbers (sometimes)

Eg: Register holding address for memory unit : MAR (memory address register)

Others → PC (program counter)

IR (instruction register)

RI (processor register)



Info transfer from one register to another :  $R_2 \leftarrow (R_1)$  After transfer, content of this register doesn't change.

④ It designates a replacement of content of  $R_2$  by the content of  $R_1$ .

④ Normally, we want transfer to occur only under a predetermined control condition.

If ( $P=1$ ) then  $(R_2 \leftarrow R_1)$

where  $P$  = control signal generated in control section.

$P : R_2 \leftarrow R_1 \Rightarrow$  control func.

↓  
Boolean variable  
(0 or 1)



Block diagram

### (P) Symbol

letters (& numbers)  
Parenthesis ()  
Arrow ( $\leftarrow$ )  
comma (,)

Description  
denotes register  
denotes part of register  
denotes transfer of info  
separates 2 microoperations

### Examples

MAR, R2  
 $R2(0-7), R2(L)$   
 $R2 \leftarrow R1$   
 $R2 \leftarrow R1, R1 \leftarrow RL$

## # BUS AND REGISTER TRANSFER

- A typical digital comp has many registers & paths may be provided to transfer info from one register to another.
- A more efficient scheme for transferring info b/w registers in a multiple-register configuration is a common bus system.
- A BVS structure consists of a set of common lines, one for each bit of a register, to carry data, connecting several devices.
- Control signals determine which register is selected by bus during each particular register transfer.



## Function Table of BVS:

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

In general, bus system with ' $k$ ' registers of ' $n$ ' bits produce ' $m$ ' line O/P  
 no. of MUX needed =  $n$   
 size of each MUX =  $k \times 1$

The transfer of info from a bus into one of many destination registers can be accomplished by connecting the bus lines to the input of all destination registers & activating the load control of particular destination register selected.

Symbolic:  $BVS \leftarrow C, RI \leftarrow BVS$ .

### # THREE-STATE BVS BUFFER:

- A three state gate is a digital ckt that exhibits three states.
- Two of the states are signals equivalent to logic 1 and 0 as in conventional gate. The third state is a high impedance state.
- High impedance state behaves like an open circuit, which means O/P is disconnected & does not have a logic significance.
- Most commonly used in design of bus system as buffer gate.



## BUS USING TRI-STATE BUFFER



- No more than 1 buffer may be in active state at any given time.
- The connected buffers may be controlled so that only one of these bi-state buffer has access to the bus line while all other buffers are maintained in a high impedance state.
- One way to ensure that not more than one control input is active at any given time is to use a decoder.
- When  $E = 0$ , all 4 o/p are zero & bus line is in high impedance state because all 4 buffers are disabled.
- When  $E = \text{active}$ , one of the four 3-state buffers will be active, depending on select inputs of decoder.
- To construct common bus for 4 registers of 'n' bits each using tri-state buffer, we need 'm' circuits with 4 buffers in each.
- Each group of 4 buffers receives one significant bit from the four registers.
- Only one decoder is necessary to select 5/w 4 registers.

## # MEMORY TRANSFER :

Read operation → transfer of info from a memory word to the outside environment.

Write operation → transfer of new info to be stored into the memory

① A memory word will be symbolised by letter M.

The particular memory word among many available is selected by memory address during transfer.

② It is necessary to specify the address of M when writing memory transfer operations.



Transfer of info into DR from memory word M selected by address in AR.

Write :  $M[AR] \leftarrow RI$

Transfer of info from RI to memory word M selected by the address in AR.

## # BUS ARCHITECTURE :

- A group of wires connecting 2 or more devices & providing a path to perform communication is called a bus.
- A bus that connects major components/modules (CPU, memory, I/O) is called a system bus.



### 1. Data Bus:

- consists of 8, 16, 32 or more parallel lines. The data bus lines are bidirectional.
- This means the CPU can read data on these lines from memory or from a port as well as data out on these lines to a memory location or to a port.
- it is a bidirectional bus used to carry data b/w system units.

### 2. Address Bus:

- unidirectional bus
- consists of 16, 20, 24 or more parallel lines
- The CPU sends out the address of the memory location or I/O port that is to be written or read from by using this address bus.
- its function is to select the particular device or memory location.

### 3. Control Bus:

- control lines regulate activity on the bus.
- CPU sends signals on the control bus to enable the outputs of the addressed memory device or port device.
- it is also unidirectional bus. Its function is to control the units based on the request.



→ no. of lines in data bus = width of data bus.

$$= 16, 32, 64 \dots$$

→ Each line carries 1 bit at a time, so the no. of lines in data bus determine how many bits can be transferred parallelly.

→ Data bus width determines overall system performance.

Address Bus width determines memory capacity

## BUS ARBITRATION

A mechanism which decides the selection of current master to access bus.

Three types of mechanisms:

- ① Daisy chaining
- ② Parallel Arbitration
- ③ Independent Requesting

### 1) Daisy chaining

→ cheap & simple method.

→ All masters make use of same line for bus request. The bus grant signal serially propagates through each master until it encounters the first one that is requesting access to the bus. This master blocks the propagation of bus grant signal, activates the busy line & gains control of the bus. Therefore, any other requesting module will not receive the grant signal & hence can't get bus access.

#### Adv:

→ cheap & simple

→ requires less no. of lines & this no. is independent of no. of masters in system.

#### Disadv

→ propagation time delay of bus grant signal makes its slow & limit the no. of masters.

→ priority of master is fixed by physical location of master.

→ failure of any one master causes whole system to fail.

## ② Parallel Arbitration:

- It consists of priority encoder & a decoder.
- In this mechanism, each bus arbiter has a bus request output line & a bus acknowledges input line.
- Each arbiter enables the request line when its device (processor) is requesting access to system bus.
- Each arbiter bus request output line is connected to the i/p of priority encoder.
- The output of encoder generates a 2-bit code which represents highest priority unit among those requesting.
- This 2-bit code is given to i/p of 2x4 decoder which enables the proper acknowledge line to grant bus access to highest priority unit.
- A device is utilized in the system only after it receives the acknowledge signal.

Adv:

- Priority can be changed by altering priority sequence stored in controller.
- If one module fails, entire system does not fail.

## ③ Independent Priority:

- In this scheme, each master has a separate pair of bus request & bus grant lines & each pair has a priority assigned to it.
- The built-in priority encoder within the controller selects the highest priority & asserts the corresponding bus grant signal.



## # ARITHMETIC MICROOPERATIONS

Arithmetic microoperations are elementary operations performed with data stored in registers.

The basic arithmetic microoperations are:

- addition, subtraction, increment, decrement & shift

### Symbolic Designation

$$R_3 \leftarrow R_1 + R_2$$

$$R_3 \leftarrow R_1 - R_2$$

$$R_2 \leftarrow \overline{R_2}$$

$$R_2 \leftarrow \overline{R_2} + 1$$

$$R_3 \leftarrow R_1 + \overline{R_2} + 1$$

$$\begin{cases} R_1 \leftarrow R_1 + 1 \\ R_1 \leftarrow R_1 - 1 \end{cases}$$

Implemented with updown counter.

- ④ Multiplication is implemented by sequence of add & shift microoperations.
- ⑤ Division is implemented by sequence of subtract & shift microoperations.

## # ARITHMETIC CIRCUIT



4-bit arithmetic ckt.

| $S_1$ | $S_0$ | Cin | I/P            | O/P            | $D = A + Y + \text{Cin}$ | M/o                  |
|-------|-------|-----|----------------|----------------|--------------------------|----------------------|
| 0     | 0     | 0   | B <sub>0</sub> | B <sub>0</sub> | $D = A + B$              | Add                  |
| 0     | 0     | 1   | B <sub>0</sub> | B <sub>0</sub> | $D = A + B + 1$          | Add with carry       |
| 0     | 1     | 0   | $\bar{B}_0$    | $\bar{B}_0$    | $D = A + \bar{B}$        | subtract with borrow |
| 0     | 1     | 1   | $\bar{B}_0$    | $\bar{B}_0$    | $D = A + \bar{B} + 1$    | subtract             |

| <u>S<sub>1</sub></u> | <u>S<sub>0</sub></u> | <u>Cin</u> | <u>Y</u> | <u>Output D = A + Y + Cin</u> | <u>Micro-Op<sup>n</sup></u> |
|----------------------|----------------------|------------|----------|-------------------------------|-----------------------------|
| 1                    | 0                    | 0          | 0        | D = A                         | Transfer A                  |
| 1                    | 0                    | 1          | 0        | D = A + 1                     | Increment A                 |
| 1                    | 1                    | 0          | 1        | D = A + 1 - 1                 | Decrement A                 |
| 1                    | 1                    | 1          | 1        | D = A                         | Transfer A                  |

$D = A$  → generated twice  
 $\therefore$  Only 7 distinct microoperations.

When  $Cin = 0$   
 all 4 i/p goes 1 in FA

1 → 0001 → 2's complement = 1111

& 2's complement means subtraction.

So,  $D = A - 1$

When  $Cin = 1$

$D = A - 1 + 1 = A$

## # LOGIC MICROOPERATIONS

16 diff logic operations.

Truth Table

| <u>a<sub>4</sub></u> | <u>f<sub>0</sub></u> | <u>f<sub>1</sub></u> | <u>f<sub>2</sub></u> | <u>f<sub>3</sub></u> | <u>f<sub>4</sub></u> | <u>f<sub>5</sub></u> | <u>f<sub>6</sub></u> | <u>f<sub>7</sub></u> | <u>f<sub>8</sub></u> | <u>f<sub>9</sub></u> | <u>f<sub>10</sub></u> | <u>f<sub>11</sub></u> | <u>f<sub>12</sub></u> | <u>f<sub>13</sub></u> | <u>f<sub>14</sub></u> | <u>f<sub>15</sub></u> |
|----------------------|----------------------|----------------------|----------------------|----------------------|----------------------|----------------------|----------------------|----------------------|----------------------|----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|
| 00                   | 0                    | 0                    | 0                    | 0                    | 0                    | 0                    | 0                    | 1                    | 1                    | 1                    | 1                     | 1                     | 1                     | 1                     | 1                     | 1                     |
| 01                   | 0                    | 0                    | 0                    | 0                    | 1                    | 1                    | 1                    | 1                    | 0                    | 0                    | 0                     | 0                     | 1                     | 1                     | 1                     | 1                     |
| 10                   | 0                    | 0                    | 1                    | 1                    | 0                    | 0                    | 1                    | 1                    | 0                    | 0                    | 1                     | 1                     | 0                     | 0                     | 1                     | 1                     |
| 11                   | 0                    | 1                    | 0                    | 1                    | 1                    | 0                    | 1                    | 1                    | 0                    | 1                    | 0                     | 1                     | 0                     | 1                     | 0                     | 1                     |

## Boolean func

$$F_0 = 0$$

$$F_1 = xy$$

$$F_2 = xy'$$

$$F_3 = x$$

$$F_4 = x'y$$

$$F_5 = y$$

$$F_6 = x \oplus y$$

$$F_7 = x + y$$

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

$$F_9 = (x \oplus y)'$$

$$F_{10} = y'$$

$$F_{11} = x+y'$$

$$F_{12} = x'$$

$$F_{13} = x' + y$$

$$F_{14} = (xy)'$$

$$F_{15} = 1$$

## Microoperations

$$F \leftarrow 0$$

$$F \leftarrow A \wedge B$$

$$F \leftarrow A \wedge \bar{B}$$

$$F \leftarrow A$$

$$F \leftarrow \bar{A} \wedge B$$

$$F \leftarrow B$$

$$F \leftarrow A \oplus B$$

$$F \leftarrow A \vee B$$

$$F \leftarrow \bar{A} \vee B$$

$$F \leftarrow \bar{A} \oplus B$$

$$F \leftarrow \bar{B}$$

$$F \leftarrow A \vee \bar{B}$$

$$F \leftarrow \bar{A}$$

$$F \leftarrow \bar{A} \vee B$$

$$F \leftarrow \bar{A} \wedge \bar{B}$$

$$F \leftarrow \text{all } 1's$$

## Name

Clear

AND

Transfer A

Transfer B

Ex-OR

OR

NOR

Ex-NOR

complement B

complement A



NAND

set to all 1's



## Hardware Implementation



## SHIFT MICROOPERATIONS

→ used for serial transfer of data

Types of shifts → logical (1-left shift to left/right)  
 circular (around 2 ends)  
 arithmetic (shifts signed binary no. to left/right)  
 left (multiplies by 2)  
 right (divides by 2)

### Symbol 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{ashr } R$

### Description

shift - left register R

shift - right register R

circular shift left register R

circular shift right register C

arithmetic shift-left R

arithmetic - shift-right R

select { 0 for shift right (down)  
 { 1 for shift left (up) }



| S | O/P |    |    |    |
|---|-----|----|----|----|
|   | H0  | H1 | H2 | H3 |
| 0 | Ia  | A0 | A1 | A2 |
| 1 | A1  | A2 | A3 | Ib |

bidirectional  
shift register  
with parallel load.

## # ARITHMETIC LOGIC SHIFT UNIT :

- Instead of having individual registers performing microoperations directly, computer systems employ a no. of storage devices connected to common operational unit called an ALU.
- ALU is a combinational ckt so that entire register transfers operation from source registers through the ALU & into the destination register can be performed during one clock pulse period.



One - stage of Arithmetic logic  
Shift Unit

| $S_3$ | $S_2$ | $S_1$ | $S_0$ | Cin | 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 + B + 1$       | Add with carry          |
| 0     | 0     | 1     | 0     | 0   | $F = A + \bar{B}$     | Subtraction 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     |

Shift-left  $\rightarrow$  serial i/p transfers a bit into rightmost pos<sup>n</sup>  
 Shift-right  $\rightarrow$  serial i/p transfers a bit into leftmost pos<sup>n</sup>.

Note: see notes below.