

Module - II  
Computer ORGANIZATION

Total - 50  
(Module 1 + 2)  
(38 + 12)

Written by : Pushpendra

A. ADDRESSING MODES -

The way, the operand are choosing during execution and Program execution on the addressing mode of the instruction.

Computer has a variety of addressing mode -

- to give programming flexibility to the user
- to use the bits in the address field of the instruction efficiently.

Advantage - It provide flexibility for writing programs that are more efficient with respect to number of instruction & execution time.

## Program Counter -

There is one register in the computer called Program Counter or PC that keeps the tracks of the instruction in the Program stored in Memory.

It holds the address of the instruction to be executed next & is incremented each time an instruction is fetched from Memory.

ex - instruction format with a distinct addressing mode.

| opcode | Mode | Address |
|--------|------|---------|
|--------|------|---------|

opcode → specifies the operation to be performed

Mode → is used to locate the operands needed for operation.

### Types -

#### Implicit / Implied mode -

In this mode, the operands are specified implicitly in the definition of the instructions.

complement Accumulator (CMA)  
(operand is in the accumulator)

ii) Immediate Mode - In this mode, the operand is specified in the instruction itself.

- These are useful for initializing registers to constant value.

iii) Direct address Mode -

The instruction contains the exact memory address where the operand (data) is located.

Ex - if data is at memory location 1000,  
then instruction will specify 1000

iv) Indirect addressing Mode -

The instruction gives the address of a location that holds another address where the actual data is stored.

Ex - instruction says to go memory location 2000, which contains 3000 & 3000 has actual data.

v) Register Mode -

The instruction refers to a register where the operand is stored.

Ex - the instruction specifies that data is in Register 1.

(vi) Register Indirect Mode - The instruction refers to a register that holds the address of the data.

ex:  $\text{MOV R}_1, [\text{R}_2]$        $\text{R}_2$  says Memory  
[ ] → means Memory      address

Register  $\text{R}_1$  contains the memory address 4000, where the actual data is stored

(vii) Immediate Mode - The instruction directly contains the value (data) to be used, not an address.

it fast since no memory lookup is needed.

ex:  $\text{MOV R}_1, 200$

(viii) Auto Increment & Auto Decrement Mode

Auto Increment - like Register Indirect Mode, but the Register's value increased after accessing the data.

ex:  $\text{ADD} [\text{R}_1] + 1$

Auto Decrement - Similar, but register value decrease before accessing the data.

ex:  $\text{SUB} - [\text{R}_1]$

(#)

### (ix) Relative addressing Modes -

- the instruction give an address relative to the program counter (PC), which is a register tracking the current instruction location.

ex - If PC is at address 100, an offset might take you to 120.

$$EA = \underset{\text{(Effective address)}}{PC} + \text{offset}$$

### x) Index Addressing -

- an index register is added to an address in the instruction to find the actual address of the data.

ex - instruction gives an address + IR (Index Register) to find the address.

$$EA = IR/XR + \text{displacement}$$

### xi) Base Addressing - use a base address stored in a register & an offset given in the instruction to get the final address.

$$EA = \underset{\text{(Base Register)}}{BAR} + \text{displacement}$$

Q.

PC [200]

R, [400]

XR [100]

[AC]

200

201

202

399

400

500

600

702

800

LOAD AC

500

Next  
Instruction

450

700

800

900

325

300

Address

LOAD AC, 500

opcode, operand

• Direct addressing Mode -

$$EA = 500, AC = 500$$

• Indirect addressing Mode -

$$EA = 800, AC = 300$$

• Register Direct -

$$EA = X, AC = 400$$

Registers

EA

Implied

No

because  
data

Indirect

EA

AU

E

Indirect

EA

• Register Indirect -

$$EA = 400, AC = 700$$

• Implied addressing mode -

Not applicable.

because the instructions in the given data have the accumulator by default.

• Indexed Addressing -

\*  $EA = IR + \text{displacement}$   
 $100 + 500 = 600$

$$AC = 900$$

• Auto Increment -

$$EA = 400, AC = 700$$

• Auto Decrement -

$$EA = 399, AC = 450$$

• Immediate -

$$EA = 201, AC = 500$$

• Relative Addressing -

$$EA = 202 + 500 = 702$$

$$AC = 325$$

(  $EA = \text{Next instruction} + -$  ]

## → PIPELINE -

- It is a technique of decomposing a sequential process into sub-operations, with each subprocess being executed in a segment that operates concurrently with all other segments.
- It can be visualized as a collection of processing segments through which binary information flows.

### Instruction Pipeline -

- Fetch
- Decode
- Execute

Three stages of instruction in computer.

ex.  $A_i * B_i + C_i \quad i = 1 \text{ to } 7$

The suboperation performed in each segment of the pipeline are follow:

$$R_1 \leftarrow A_i, R_2 \leftarrow B_i \quad \text{Input } A_i \text{ & } B_i$$
$$R_3 \leftarrow R_1 * R_2, R_4 \leftarrow C \quad \text{Multiply & Input } C$$

$$R_5 \leftarrow R_3 + R_4 \quad \text{Add } C_i \text{ to Product}$$



Fig

Clock  
Pulse

1.

2.

3.

4.

5.

6.

7



Fig :- Example of pipeline processing-

|             | Segment 1      |                | Segment 2                      |                | Segment 3                                       |   |
|-------------|----------------|----------------|--------------------------------|----------------|-------------------------------------------------|---|
| clock pulse | R <sub>1</sub> | R <sub>2</sub> | R <sub>3</sub>                 | R <sub>4</sub> | R <sub>5</sub>                                  |   |
| 1.          | A <sub>1</sub> | B <sub>1</sub> | —                              | —              | —                                               | — |
| 2.          | A <sub>2</sub> | B <sub>2</sub> | A <sub>1</sub> *B <sub>1</sub> | C <sub>1</sub> | —                                               | — |
| 3.          | A <sub>3</sub> | B <sub>3</sub> | A <sub>2</sub> *B <sub>2</sub> | C <sub>2</sub> | A <sub>1</sub> *B <sub>1</sub> + C <sub>1</sub> | — |
| 4.          | A <sub>4</sub> | B <sub>4</sub> | A <sub>3</sub> *B <sub>3</sub> | C <sub>3</sub> | A <sub>2</sub> *B <sub>2</sub> + C <sub>2</sub> | — |
| 5.          | A <sub>5</sub> | B <sub>5</sub> | A <sub>4</sub> *B <sub>4</sub> | C <sub>4</sub> | A <sub>3</sub> *B <sub>3</sub> + C <sub>3</sub> | — |
| 6.          | A <sub>6</sub> | B <sub>6</sub> | A <sub>5</sub> *B <sub>5</sub> | C <sub>5</sub> | A <sub>4</sub> *B <sub>4</sub> + C <sub>4</sub> | — |
| 7.          | A <sub>7</sub> | B <sub>7</sub> | A <sub>6</sub> *B <sub>6</sub> | C <sub>6</sub> | A <sub>5</sub> *B <sub>5</sub> + C <sub>5</sub> | — |
|             |                |                | A <sub>7</sub> *B <sub>7</sub> | C <sub>7</sub> | A <sub>6</sub> *B <sub>6</sub> + C <sub>6</sub> | — |
|             |                |                |                                |                | A <sub>7</sub> *B <sub>7</sub> + C <sub>7</sub> | — |

So in  $A_i * B_i + C_i$

where  $i \geq 1-7$  (1 to 7)  
 $\Rightarrow 9$  clock pulse

### A. General Four-Segment Pipeline -

Clock



### B. Space-time diagram -

|           | 1              | 2              | 3              | 4              | 5              | 6              | 7              | 8              | 9 | clock cycles |
|-----------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|---|--------------|
| Segment 1 | T <sub>1</sub> | T <sub>2</sub> | T <sub>3</sub> | T <sub>4</sub> | T <sub>5</sub> | T <sub>6</sub> |                |                |   |              |
| 2         | T <sub>1</sub> | T <sub>2</sub> | T <sub>3</sub> | T <sub>4</sub> | T <sub>5</sub> | T <sub>6</sub> |                |                |   |              |
| 3         |                | T <sub>1</sub> | T <sub>2</sub> | T <sub>3</sub> | T <sub>4</sub> | T <sub>5</sub> | T <sub>6</sub> |                |   |              |
| 4         |                |                | T <sub>1</sub> | T <sub>2</sub> | T <sub>3</sub> | T <sub>4</sub> | T <sub>5</sub> | T <sub>6</sub> |   |              |

### C. Pipeline Question -

$$(A_i + B_i) \neq (C_i + D_i) \quad i = 1 \text{ to } 6$$

- $R_1 \leftarrow A_i$        $R_3 \leftarrow C_i$
- $R_2 \leftarrow B_i$        $R_4 \leftarrow D_i$       input  $A_i, B_i \in$   
 $C_i, D_i$

- $R_5 \leftarrow R_1 + R_2$        $R_6 \leftarrow C_i + D_i$

~~Addition of R<sub>6</sub> to R<sub>5</sub>~~

- $R_7 \leftarrow R_5 * R_6$

Multiply R<sub>5</sub> & R<sub>6</sub>



Fig.: Example of Pipeline processing

|             | Segment 1      |                |                |                | Segment 2                         |                                   | Segment 3                                                             |  |
|-------------|----------------|----------------|----------------|----------------|-----------------------------------|-----------------------------------|-----------------------------------------------------------------------|--|
| Clock Pulse | R <sub>1</sub> | R <sub>2</sub> | R <sub>3</sub> | R <sub>4</sub> | R <sub>5</sub>                    | R <sub>6</sub>                    | R <sub>7</sub>                                                        |  |
| 1           | A <sub>1</sub> | B <sub>1</sub> | C <sub>1</sub> | D <sub>1</sub> | —                                 | —                                 | —                                                                     |  |
| 2           | A <sub>2</sub> | B <sub>2</sub> | C <sub>2</sub> | D <sub>2</sub> | (A <sub>1</sub> +B <sub>1</sub> ) | (C <sub>1</sub> +D <sub>1</sub> ) | —                                                                     |  |
| 3           | A <sub>3</sub> | B <sub>3</sub> | C <sub>3</sub> | D <sub>3</sub> | (A <sub>2</sub> +B <sub>2</sub> ) | (C <sub>2</sub> +D <sub>2</sub> ) | (A <sub>1</sub> +B <sub>1</sub> ) ≠ (C <sub>1</sub> +D <sub>1</sub> ) |  |
| 4           | A <sub>4</sub> | B <sub>4</sub> | C <sub>4</sub> | D <sub>4</sub> | (A <sub>3</sub> +B <sub>3</sub> ) | (C <sub>3</sub> +D <sub>3</sub> ) | (A <sub>2</sub> +B <sub>2</sub> ) ≠ (C <sub>2</sub> +D <sub>2</sub> ) |  |
| 5           | A <sub>5</sub> | B <sub>5</sub> | C <sub>5</sub> | D <sub>5</sub> | (A <sub>4</sub> +B <sub>4</sub> ) | (C <sub>4</sub> +D <sub>4</sub> ) | (A <sub>3</sub> +B <sub>3</sub> ) ≠ (C <sub>3</sub> +D <sub>3</sub> ) |  |
| 6           | A <sub>6</sub> | B <sub>6</sub> | C <sub>6</sub> | D <sub>6</sub> | (A <sub>5</sub> +B <sub>5</sub> ) | (C <sub>5</sub> +D <sub>5</sub> ) | (A <sub>4</sub> +B <sub>4</sub> ) ≠ (C <sub>4</sub> +D <sub>4</sub> ) |  |
|             |                |                |                |                | (A <sub>6</sub> +B <sub>6</sub> ) | (C <sub>6</sub> +D <sub>6</sub> ) | (A <sub>5</sub> +B <sub>5</sub> ) ≠ (C <sub>5</sub> +D <sub>5</sub> ) |  |
|             |                |                |                |                |                                   |                                   | (A <sub>6</sub> +B <sub>6</sub> ) ≠ (C <sub>6</sub> +D <sub>6</sub> ) |  |

Q. Showing a space time diagram for six segment pipeline, showing the time it takes to process 8 tasks.

Sol: No. of Segments = 6,  $K + (n-1)tp$   
 No. of Tasks = 8,  $6 + 8-1 \neq 13$   
 cycles

| Segment | 1     | 2     | 3     | 4     | 5     | 6     | 7     | 8     | 9     | 10    | 11    | 12    | 13    |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| 1       | $T_1$ | $T_2$ | $T_3$ | $T_4$ | $T_5$ | $T_6$ | $T_7$ | $T_8$ |       |       |       |       |       |
| 2       |       | $T_1$ | $T_2$ | $T_3$ | $T_4$ | $T_5$ | $T_6$ | $T_7$ | $T_8$ |       |       |       |       |
| 3       |       |       | $T_1$ | $T_2$ | $T_3$ | $T_4$ | $T_5$ | $T_6$ | $T_7$ | $T_8$ |       |       |       |
| 4       |       |       |       | $T_1$ | $T_2$ | $T_3$ | $T_4$ | $T_5$ | $T_6$ | $T_7$ | $T_8$ |       |       |
| 5       |       |       |       |       | $T_1$ | $T_2$ | $T_3$ | $T_4$ | $T_5$ | $T_6$ | $T_7$ | $T_8$ |       |
| 6       |       |       |       |       |       | $T_1$ | $T_2$ | $T_3$ | $T_4$ | $T_5$ | $T_6$ | $T_7$ | $T_8$ |

\* Pipeline Speed up -  
 let  $n$  no. of tasks to be performed

let  $K$  be the number of segments  
 pipeline with clock time  $tp$ .

Therefore, the first task  $T_1$  require  
 Time =  $K * tp$

Now remaining  $(n-1)$  task requires

$(n-1) * tp$  {the remaining  $(n-1)$  task  
 emerge from the pipe at the rate of 1}

→ To complete  $n$  tasks with  $K$  segment  
 pipeline =

$K + (n-1)$  clock cycles

for Non-Pipelined -  
 Time require to complete each task  
 $\Rightarrow t_n$

Time require to complete  $n$  tasks  $\Rightarrow n \cdot t_n$

$$\text{Speed up.} = \frac{n \cdot t_n}{[k + (n-1)] \cdot t_p}$$

$$(\text{Speed up})_{\text{Max.}} \Rightarrow \frac{t_n}{t_p}$$

- Q. A non-pipelined system takes 50 ns to process a task. The same task can be processed in a six-segment pipeline with a clock cycle of 10 ns. Determine the speed up factor of the pipeline for 100 tasks.

$$t_n = 50 \text{ ns}$$

$$K = 6$$

$$t_p = 10 \text{ ns}$$

$$n = 100$$

$$S = \frac{n \cdot t_n}{(K + n - 1) \cdot t_p} \Rightarrow \frac{100 \cdot 50}{(6 + 100 - 1) \cdot 10}$$

$$\Rightarrow 4.76$$

$$S_{\text{Max.}} = \frac{t_n}{t_p} = \frac{50}{10} = 5$$

Instruction code -

- computer Registers
- computer instructions
- Timing & control
- Instruction cycle
- Register - Reference instructions
- Memory - Reference instructions
- Input - output & interrupt

Program - A series of instruction that tells the computers what operation to perform which data to use, & in what order

Instruction - A code in binary (1s & 0s) that tells the computer to carry out a specific task.

Instruction cycle - The computer reads an instruction from memory & places it in a register. It then reads & decodes the instruction & perform the necessary steps to complete it.

Instruction Code - A set of bits that guides the computers to perform a specific action.

Parts of Instruction Code -

- opcode - specific the operation to perform (like add, subtract)

- Address (operand) - specifies where to find the data to use for the operation:



Instruction format

- operation code (opcode) :-
- Group of bits that define the operation which type of operation will perform.

ex add, subtract, multiply, shift, complement

- Address (operand) :
- specifies the location of operand (register or memory words)
- Memory words are specified by their address
- Register are specified by their k-bit binary code

Fig - Stored program organization



processor register  
(accumulator org.)

The ability to store & execute instruction is the most imp. property of general purpose computer. That type of stored program is called **stored program organization**.

- **Accumulator (AC):**

→ Computer that have a single-processor register usually assign to it the name accumulator & label it AC.

→ The operation is performed with the Memory operand & the content of AC.

### \* Addressing of operand -

- Sometimes, instead of using bits in the instruction code as an address, it can be useful to use them as the actual data.

**immediate operand** - if the second part of an instruction contains the actual data, it is called an immediate operand.

**Direct address** - if the second part of an instruction contains the exact address where the data is stored, it is called direct address.

Indirect address - if the second part of an instruction contains the address of memory location that stores the address of the data, it is called indirect address.



### • Direct Address instruction-

- This instruction is stored in Memory address 22. Since the "1" bit is 0, it is recognized as a direct address instruction.

The instruction tells the computer to perform an ADD operation. The address part of the instruction (457 in binary) point to the location where the data (operand) is stored.

The computer finds the data at memory address 457 & adds it to the content of the accumulator (AC).

#### Indirect address instruction-

This instruction is stored in memory address 35. The "I" bit is 1, so it is recognized as an indirect address instruction.

The address part is 300 in binary. The computer goes to address 300 to find another address where the data (operand) is located.

The address is stored at location 300 is 1350. So, the computer then goes to address 1350 to get the data.

The data found at address 1350 is then added to the content of the Accumulator.

#### Effective address -

The effective address is the actual location in memory where the data (operand) is found in computation-type instruction or the target in branch-type instructions.

→ for the direct address instruction, EA = 457

→ for the indirect address instruction,  
 $EA = 1350$

| Register Symbol | No. of bit's | Register Name        | Function                     |
|-----------------|--------------|----------------------|------------------------------|
| DR              | 16           | Data Register        | Holds memory operand         |
| AR              | 12           | Address Register     | Holds address for memory     |
| AC              | 16           | Accumulator          | Processor register           |
| IR              | 16           | Instruction Register | Holds instruction code       |
| PC              | 12           | Program Counter      | Holds address of instruction |
| TR              | 16           | Temporary register   | Holds temporary data         |
| INPR            | 8            | Input register       | Holds input character        |
| OUTR            | 8            | Output register      | Holds output character       |



## Main Points of Register-

The data register (DR) holds the operand 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 bit since this is width of a memory address.

The program counter (Pc) also has 12 bit's & it holds the address for the next instruction to be read from Memory after the current instruction is executed.

Two registers are used for input & output.

The input register (INPR) receives an 8 bit character from an input device.

The output register (OUTR) holds an 8-bit character for an output device.

## COMMON BUS SYSTEM-

- The basic computer has eight register & one control unit.
- There need to be ways to move data from one register to another & between memory & registers.
- Using a common bus is more efficient way to transfer data in a system with many register.
- Seven registers & Memory are connected to this common bus for transferring information.

# Basic Computer Register connected to a common bus -



- The numbers next to each output show the decimal values of required binary code.
- for ex → the number next to DR's output is 3. the 16 bit output of DR is placed on the bus when  $S_2 S_1 S_0 = 011$ .
- Five registers have three control actions, LD (load), INR (increment) & CLR (clear)
- When two numbers are added, the result goes to AC, & any overflow (carry-out) is sent to a flip-flop called E (extended-bit).
- An additional input of 8 bit comes from the input register INPR.
- The content of any register can be sent to the bus, the operation like addition can happen in the adder at the same time during one clock cycle.

## Computer Instructions -

The basic computer has the instruction code formats. & each format has 16 bits.

a) Memory - Reference Instruction -



b) Register - Reference Instruction -



c) Input - Output instruction -



## \* Timing of control Unit-

- The function of control unit is to generate relevant timing & control signals to all operation in the computer.
- It controls the flow of data between the process & memory & peripherals.
- The control unit must communicate with both arithmetic logic unit (ALU) & main memory.
- The control unit instructs the arithmetic logic unit that which logical or arithmetic operation is to be performed.
- Control unit generates control signal using one of the two organizations-
  - Hardwired control unit.
  - Micro-programmed control unit

### 1. Hardwired control unit -

- It is implemented as logic circuits (gates, flip-flops, decodes etc.) in the hardware.
- This technique is very complicated if we have a large control unit.

In this technique, if the design has to be Modified or changed, require changing changes in the wiring among various components. the Modification of all combination circuit may be very difficult.



- Q. consider the case where SC is incremented to provide timing signals T<sub>0</sub>, T<sub>1</sub>, T<sub>2</sub>, T<sub>3</sub> & T<sub>4</sub> in sequence.

At Timing T<sub>4</sub>, SC is cleared to 0<sup>(zero)</sup> if decoder output D<sub>3</sub> is active. This is expressed symbolically by the

## Hardwired Control unit-

Consist of a :

- Instruction register
- Number of control logic gates.
- Two - Decoders
- 4-bit Sequence Counter

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

→ The instruction register is divided into three parts :- the I bit, operation code & address part.

→ First 12 bits (0-11) to specify an address, next 3-bits specify the operation code [opcode] field of the instruction & last most bit specify the addressing mode I.

I = 0 , for direct address

I = 1 , for Indirect address

→ First 12 bit's (0-11) are applied to the control logic gates.

→ The operation code bits (12-14) are decode with a  $3 \times 8$  decoder.

→ The eight output ( $D_0$  through  $D_7$ ) from a Decoder goes to the control logic

gates to perform specific operation.

- last bit 15 is transferred to a J flip-flop designated by symbol J.
- The 4 bit sequence counter SC can count in binary from 0 through 15.
- The counter output is decoded in to 16 timing pulses T<sub>0</sub> through T<sub>15</sub>.
- The sequence counter can be incremented by INR input or clear by CLR input.

## 2. Micro-programmed Control Unit -

→ Micro program consisting of Micro-instruction is stored in the control memory of the control unit.

- execution of a Microprogram Micro-instruction is responsible for generation of a set of control signals.
- A Micro ~~pro~~ instruction consist of -
- one or more micro-operation to be executed.
- Address of next micro instruction to be executed.

⇒ Micro-programs: Microprogramming is the concept for generating control signals using programs.  
These programs are called micro-program.

⇒ Micro-instruction: The instructions that make micro-program are called Micro-instructions.

⇒ Micro-Code: Micro-program is a group of Micro-instructions. The Micro-program can also be termed as Micro-code.

⇒ Control-Memory: Micro-programs are stored in the read only memory (ROM). That memory is called Control Memory.





- The address of micro-instruction that is to be executed is stored in the control address register (CAR).
- Micro-instruction corresponding to the address stored in CAR is fetched from control memory & is stored in the control data register (CDR).
- The Micro-instruction contains control word to execute one or more micro-operation.
- After the execution of all micro-operations of micro-instruction, the address of next micro instruction is located.

Diff: between Hardwired & Micro-programmed control unit.

|                                       | Hardwired                                                   | Micro-programmed                                    |
|---------------------------------------|-------------------------------------------------------------|-----------------------------------------------------|
| Speed -                               | Fast                                                        | Slow                                                |
| cost of implementation -              | More                                                        | Cheaper                                             |
| Flexibility                           | Not flexible.<br>difficult to modify<br>for new instruction | Flexible, new<br>instruction can<br>be easily added |
| Ability to handle complex instruction | Difficult                                                   | Easier                                              |
| Decoding                              | Complex                                                     | Easy                                                |
| Application                           | RISC<br>Microprocessor                                      | CISC<br>Microprocessor                              |
| Instruction set size                  | Small                                                       | Large                                               |
| Control Memory                        | Absent                                                      | Present                                             |
| CHIP Area required                    | Less                                                        | More                                                |

## Instruction cycle-

- The program is executed by the computer by going through a cycle for each instruction.

→ In the basic computer, each instruction cycle consists of the following phases-

- Fetch an instruction from Memory
- Decode the instruction
- Read the effective address from memory.
- Execute the instruction.

## Operation for Fetch & Decode-

|                                                         |                                                     |                                                         |
|---------------------------------------------------------|-----------------------------------------------------|---------------------------------------------------------|
| common<br>to<br>all<br>Micro-<br>processor<br>operation | T <sub>0</sub> :                                    | AR $\leftarrow$ PC                                      |
|                                                         | T <sub>1</sub> :                                    | IR $\leftarrow$ M[AR], PC $\leftarrow$ PC + 1           |
|                                                         | T <sub>2</sub> :                                    | Do ... D <sub>7</sub> $\leftarrow$ Decode<br>IR (12-14) |
|                                                         | AR $\leftarrow$ IR (0-11)<br>I $\leftarrow$ IR (15) |                                                         |

- Initially program counter (PC) is loaded with the address of the first instruction in the program.
- Place the content of PC into AR.
- The instruction is extracted in IR (Instruction register) from AR (Address register).
- Last decode the instruction register.

## Flow chart -



### A. Register- Reference Instruction -

Register - reference instructions are recognized by the control when  $D7 = 1$ , &  $I = 0$ .

These instructions use bits 0 through 11 of the instruction code to specify one of 12 instruction.

These 12 bits are available in IR (0-11)

## A. Memory - Reference Instructions

| symbol | operation-decoder | symbolic description                                                              |
|--------|-------------------|-----------------------------------------------------------------------------------|
| · AND  | D <sub>0</sub>    | $AC \leftarrow AC \wedge M[AR]$                                                   |
| · ADD  | D <sub>1</sub>    | $AC \leftarrow AC + M[AR], E \leftarrow Cout$                                     |
| · LDA  | D <sub>2</sub>    | $AC \leftarrow M[AR]$                                                             |
| · STA  | D <sub>3</sub>    | $M[AR] \leftarrow AC$                                                             |
| · BUN  | D <sub>4</sub>    | $PC \leftarrow AR$                                                                |
| · BSA  | D <sub>5</sub>    | $M[AR] \leftarrow PC, PC \leftarrow AR + 1$                                       |
| · ISZ  | D <sub>6</sub>    | $M[AR] \leftarrow M[AR] + 1$<br>if $M[AR] + 1 = 0$ then<br>$PC \leftarrow PC + 1$ |

- The decoded output  $D_i$  for  $i = 0, 1, 2, 3, 4, 5, 6$  comes from the operation decoder & is listed in the table for each instruction.
- The effective address of the instruction is stored in the address register/AR. It's put there during timing signal T<sub>2</sub> when  $I=0$  or during timing signal T<sub>3</sub> when  $I=1$ .
- The execution of memory-reference instructions begins with timing signal T<sub>4</sub>.

**★ AND to Ac :**

- This instruction performs an AND operation between each pair of bits in the accumulator (Ac) & the memory word at the effective address.

- The result of this operation is stored in Ac.
- The micro-operation for this instruction are:

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

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

**★ ADD to Ac :**

→ This instruction adds the memory word at the effective address to the value in Ac.

→ The sum is stored in Ac, & the carry-out (cout) is moved to the E (Extended accumulation) flip-flop.

- The micro-operation for this instruction are:-

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

$$D_1 T_5 : AC \leftarrow AC + DR, \quad \cancel{E \leftarrow Cout}$$

$$E \leftarrow Cout,$$

$$SC \leftarrow 0$$

## ~~A~~. LDA ( LOAD To Ac) -

- This instruction moves the data from a memory location (specified by the effective address) into the Ac (Accumulator).

steps :

- T<sub>4</sub> : copy data from memory to DR (Data Register)
- T<sub>5</sub> : Add data from DR to Ac, adjust carry, & reset sequence counter (sc).

$$D, T_4 : DR \leftarrow M[AR]$$

$$D, T_5 : AC \leftarrow AC + DR, E \leftarrow Cout \\ SC \leftarrow 0$$

## ~~A~~. STA (Store Ac) -

- This instruction saves the content of the Ac into the memory location specified by the effective address.

Execution

Steps -

- T<sub>4</sub> : store the content of Ac into memory, then reset ~~SC~~ SC.

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

**\*. BUN (Branch unconditionally) -**

- This instruction changes the program flow to a new address specified by the effective address.

Execution steps :-

T<sub>4</sub> : Transfer the effective address to PC & reset SC.

D<sub>4</sub> T<sub>4</sub> : PC  $\leftarrow$  AR, SC  $\leftarrow$  0

**\*. BSA (Branch & save Return Address)**

- This instruction is ~~called~~ useful for branching to a portion of the program. It's called a subroutine OR procedure.

What it does -

- Saves the address of next instruction (from PC) into the memory at the effective address.
- Updates PC to point to the first instruction of the subroutine (EA + 1).

steps -

- Save PC into Memory
- increment the effective address & updates PC.

M[AR]  $\leftarrow$  PC, PC  $\leftarrow$  AR + 1

## Memory-organization

- Memory Hierarchy -

- i) Main Memory - memory unit that communicates directly with CPU (RAM)
- ii) Auxiliary Memory - device that provide backup storage (Disk Drives)
- iii) Cache Memory - Special very high-speed memory to increase the processing speed (Cache RAM)