

# COMPUTER ORGANISATION:-

Introduction: A computer is defined as a fast electronic calculating machine that accepts the (data) digitalized input information, process it as per the list of internally stored instructions and produces the resulting information.

- List of instructions are called as programs and internal storage is called Computer memory.

Different types of computer:-

- 1) personal
- 2) Note book — PC, Notepad etc.
- 3) Work stations
- 4) Enterprise systems
- 5) Super computers — for large calculations etc.

Functional units:-

5 functionally independent main parts — input, memory, ALU, output and control unit.



Memory



Central Processing Unit (CPU):- Brain of the computer

3 components — ALU, control unit, Memory Unit.

Arithmetic Logic Unit (ALU):- Most of the computer operations are executed in ALU of processor like addition, subtraction, division, multiplication, comparing etc.

→ The operands are brought into the ALU from memory and stored in high speed storage elements called registers.

→ ALU — 64 bit → 64 bit processor

→ performs operations and result is stored in ALU itself & when an instruction is given, the result gets an advice to store or display etc.

Control unit: this controls the operations of all parts of Computer but doesn't carry out actual data processing operations.

- program is set of instructions.

#### Primary memory

- \* Accessed directly by the CPU

ex:- RAM, ROM

#### Secondary memory

- \* Used where large data have to be stored and accessed infrequently

ex:- Magnetic disks & tapes, CD-Rom's, floppies etc

- \* it is external to CPU.

→ The time required to access one word is called memory access time.

#### Organisation and Architecture:-

Computer Architecture: refers to those attributes of a System that have direct impact on the logical execution of a program.

- ex:-
- instruction set
  - no. of bits used to represent various data types.
  - I/O mechanisms.
  - memory addressing techniques.

**Computer Organization:** refers to the operational units and their interconnections that realize the architectural specifications.

- ex:-
- control signals
  - Interfaces b/w computer and peripherals
  - The memory technology being used

### Structure and Function!

- structure is the way in which components relate to each other.
- function is the operation of the individual components as a part of structure.

Computer functions are : Data processing, data storage; data movement and control.

### System bus:

#### 1) Data bus

Defined as the bit length of processor  
ex:- 8 bit processor have 8 bit data bus and 8 data lines

#### 2) Address bus

Defines max memory capacity of processor  
ex:- 8 bit address lines means memory capacity is  $2^8 = 256$  bytes

#### 3) Control bus

physical connections that carry control information b/w CPU & other devices with the computer

ex:- How many data lines and what is the memory capacity of a 16-bit processor having 20 address lines?

Ans:- 16 bit  $\rightarrow$  16 data lines

$$\text{memory capacity} = 2^{20} \text{ bytes} = 1 \text{ GB}$$

### Structure:-

It is how the interconnections are made.

The four structural components are:

1) CPU

2) I/O

3) Main memory

4) System interconnections.

## CPU Structural components:-

- 1) Control Unit
- 2) ALU
- 3) Registers

### 4) Internal CPU interconnections

\* Registers store temporary data & some address. For every processor, register set will be different.

The structural components of CU(Control Unit).

- 1) Sequencing Logic → logic signals - read operation, every signal
- 2) Control Unit registers & decoders
- 3) Control memory → to store the signals - we write a logic that is stored here.

## Input / Output Subsystems:-

Controls all I/O devices

Basic fns include:

- Issuing commands to devices
- Handling interrupts from devices
- Responding errors from devices.

Temporary storage of code and results are needed.

- Main memory (RAM)

## Registers:-

It is a very small amount of very fast memory i.e. built into the CPU.

- \* they store data temporarily during execution of a program
- \* Registers are normally measured by no. of bits they can hold.

ex:- 8-bit registers means it can store 8 bits of data.

32-bit registers means it can store 32 bits of data.

- Since they store data temporarily, later we can move the data to another location to avoid loss of data
- Combination of flip flops is register
- \* LFF can hold only 1 bit

## Computer Registers:-

- **Accumulator (AC):** The processor register AC consists of 16-bits. Here intermediate arithmetic & logical signals are stored.
- **Data register (DR):** The data register DR consists of 16-bits and is used to hold memory operands (data)
  - Register writing into memory  $\Rightarrow$  Write operation
  - Register reading from memory  $\Rightarrow$  Read operation
- **Temporary register (TR):** TR have 16-bits and it provides temporary storage of variables & results.
- **Instruction register (IR):** IR consists of 16-bits. It holds a copy of instruction which processor is to execute. IR holds instruction code which is read from memory.
- **Address register (AR):** It specifies the address in memory for next read or write operation. The AR consists of 12-bits.
- **Program counter (PC):** has 12 bits and holds the address of next instruction to be read from memory after the current execution is executed.
- **Input Register (INPR):** has 8-bits. INPR receives a character from an input device and delivers it to the
- **Output Register (OUTPR):** AC has 8-bits. It receives information from AC and transfers it to o/p device.

ex:- ADD  $\text{AC} \xrightarrow{\text{destination}}$ ,  $\text{DR} \xrightarrow{\text{source}}$

- $\text{AC} = \text{AC} + \text{DR}$   $\rightarrow$  this instruction adds the contents of AC and DR and stores the result in accumulator.

$$\text{AC} = 1234\text{H}$$

$$\text{DR} = 2222\text{H}$$

After execution  $\text{AC} = 3456\text{H}$

## Instruction:

A computer instruction is a binary code that specifies a sequence of micro operations for the computer.

An instruction set:- Is a group of bits that instruct computer to perform a specific operation.

The basic computer have 3 instruction code formats, each of 16-bit.

There are 3 types of instruction.

- ① Memory reference instruction: Instruction that has 1 or more of its operand address referring to a location in memory.
- ② Register reference instruction: Specifies an operation on or a test of the AC register.

An operand from memory is not needed, so other 12-bits are used to specify operation or test to be executed.

- ③ Input-output Instruction: Doesn't require a reference to memory and it is recognised by opcode 111 & I=1

Various Instruction format:

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

a) Memory-reference Instruction (I=0 direct addressing mode, I=1 indirect addressing mode)

|         |                    |                     |
|---------|--------------------|---------------------|
| 15      | 12 11              | 0                   |
| 0 1 1 1 | Register operation | (opcode = 111, I=0) |

b) Register-reference Instruction

|         |               |                     |
|---------|---------------|---------------------|
| 15      | 12 11         | 0                   |
| 1 1 1 1 | I/O operation | (opcode = 111, I=1) |

c) Input-output Instruction

## Instruction cycle:-

- The time period during which one instruction is fetched from memory and execute when a computer gives an instruction in machine language.

## phases of Instruction cycle:-

1. fetch the instruction — (from memory)
2. Decode the instruction — from our readable lang to machine language
3. Read the effective Address from memory if the instruction has an indirect address.
4. execute the instruction.

- The program counter PC is loaded with address of the 1<sup>st</sup> instruction in the program.
- The sequence counter SC is cleared to 0, providing a decoded timing signal T<sub>0</sub>.
- After each clock pulse, SC is incremented by 1, so that the timing signals go through a sequence T<sub>0</sub>, T<sub>1</sub>, T<sub>2</sub> and so on.
- The microoperations from the fetch and decode phases can be specified by the following register transfer statements.

T<sub>0</sub> : AR  $\leftarrow$  PC

T<sub>1</sub> : IR  $\leftarrow$  M[AR], PC  $\leftarrow$  PC + 1

T<sub>2</sub> : D<sub>1</sub>, ..., D<sub>7</sub>  $\leftarrow$  Decode IR(12-14), AR  $\leftarrow$  IR(0-11)

I  $\leftarrow$  IR(15)

Here IR  $\leftarrow$  M[AR] means the contents of AR are moved into IR.

\* In memory-reference Instruction, in direct addressing mode, it will directly go to register having address and access its contents.

\* In indirect addressing mode, the address is present in some other register. So it should first go to that register & read that address & go to that address then reads its contents.

## Register transfer for fetch phase:-



*From flow chart*

- $D_7'IT_3$  :  $AR \leftarrow M[AR]$  (indirect addressing mode)
- $D_7'I'IT_3$  : Nothing
- $D_7'I'T_3$  : Execute a register-reference instruction (direct addressing mode)
- $D_7IT_3$  : Execute a I/O instruction

# Flow chart for instruction cycle:-



# Definition of Register reference Instructions:-

## Register reference instructions:-

Accumulator - 16 bit  $D + I^1 T_3 = r$  (common to all register-reference instructions)  
 we get carry then  
 16 bit is not enough  $I R(i) = B_i$  [bit in IR(0-11) that specifies the operation]  
 those will be stored in  $\textcircled{E}$

$r : SC \leftarrow 0$

clear SC → initially

CLA  $r B_{11} : AC \leftarrow 0$

clear AC → 11th Bit

CLE  $r B_{10} : E \leftarrow 0$

clear  $\textcircled{E}$  → extended accumulator as 1

CMA  $r B_9 : AC \leftarrow \overline{AC}$

Complement AC

CME  $r B_8 : E \leftarrow \overline{E}$

complement E

CIR  $r B_7 : AC \leftarrow \text{shr } AC, AC(15) \leftarrow E,$

circular right shift  $E \leftarrow AC(0)$



circular right

CLL  $r B_6 : AC \leftarrow \text{shl } AC, AC(0) \leftarrow E,$

Circular left-

$E \leftarrow AC(15)$

INC  $r B_5 : AC \leftarrow AC + 1$

Increment AC

SPA  $r B_4 : \text{if } (AC(15)=0) \text{ then } (PC \leftarrow PC+1)$  MSB = 0 (+ve no)

Skip if +ve = 1 (-ve no)

SNA  $r B_3 : \text{if } (AC(15)=1) \text{ then } (PC \leftarrow PC+1)$  Skip if -ve

SZA  $r B_2 : \text{if } (AC=0) \text{ then } (PC \leftarrow PC+1)$  Skip if AC zero

SZE  $r B_1 : \text{if } (E=0) \text{ then } (PC \leftarrow PC+1)$  Skip if E zero

HLT  $r B_0 : S \leftarrow 0$  (S is a start-stop flip flop) Halting computer

- There are a total 12 register reference instructions in computer architecture that are in use they are 1) CLA, 2) CMA, 3) CIL, 4) CIR, 5) INC, 6) SPA, 7) SNA, 8) SZA, 9) CLE, 10) CME 11) SZE 12) HLT

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

### Memory reference instructions

There are 7 different types of Memory reference instructions.

(at least one input must be high)

| Symbol                               | Operation decoder | Symbolic description.                                                          |
|--------------------------------------|-------------------|--------------------------------------------------------------------------------|
| AND                                  | D0                | $AC \leftarrow AC \wedge M[AR]$ Both the inputs must be high                   |
| ADD                                  | D1                | $AC \leftarrow AC + M[AR]$ , $E \leftarrow [Cout]$ → if any carry is present   |
| LDA                                  | D2                | $AC \leftarrow M[AR]$                                                          |
| STA                                  | D3                | $M[AR] \leftarrow AC$                                                          |
| Branch                               | D4                | $PC \leftarrow AR$                                                             |
| Unconditional BUN                    | D5                | $M[AR] \leftarrow PC$ , $PC \leftarrow AR + 1$                                 |
| Branch & Save the return address BSA | D6                | $M[AR] \leftarrow M[AR] + 1$<br>if $M[AR] + 1 = 0$ then $PC \leftarrow PC + 1$ |
| increment & ISZ                      |                   |                                                                                |
| ISZ                                  |                   |                                                                                |

[AND to AC:

This is an instruction that performs

Let AND instruction be current instruction and ADD  
be next instruction  $\rightarrow (PC)$

BSA  $\rightarrow$  saves written instruction and jumps to next instruction

$$PC \leftarrow AR + 1$$

Branching:-  $M[AR] \leftarrow PC$

to break the current flow and executing some another set of instructions where label is present

AND to AC.

This is an instruction that performs the AND logic operation on pairs of bits in AC and the memory word specified by the effective address. The result of the operation is transferred to AC.

The microoperations involved are:

D<sub>0T4</sub>: DR  $\leftarrow$  M[AR]

D<sub>0T5</sub>: AC  $\leftarrow$  AC  $\wedge$  DR SC  $\leftarrow$  0

## FLOW CHART FOR MEMORY REFERENCE INSTRUCTIONS!

### Memory-reference instruction

AND



ADD



LDA



STA



BUN



BSA



ISZ



## Input and Output Instructions:

$DFT_3 = P$  (common to all input-output instructions)

$IR(i) = Bi$  [in IR(6-11) that specifies the instruction]



## Addressing modes:-

- The way of accessing the operands
- The operation field of an instruction specifies the operation to be performed
- This operation must be executed on some data stored in computer registers or memory words.
- The way the operands are chosen during program execution is dependent on the addressing mode.

## Types of addressing modes:-

- 1) Implied mode
- 2) Immediate mode
- 3) Register mode
- 4) Register Indirect mode
- 5) Autoincrement or Autodecrement mode
- 6) Direct Address mode
- 7) Indirect Address mode
- 8) Relative Address mode
- 9) Indexed Addressing mode
- 10) Base Register addressing mode

## Implied addressing mode:

- In this mode the operands are specified implicitly in the definition of the instruction
- Example:- all register reference instructions (CMA, CLA, CLE) means we are not referring any register or memory to access the operand.

## Immediate mode:

- Operands are part of the instruction. In other words, an immediate-mode instruction has an operand field rather than an address field.
- These instructions are useful for initializing registers to a const value.

Eg:- ADD A, 1234H

$$A = 2222H$$

After execution  $A = 3456H$

## Register Mode:

- In this mode the operands are in registers that reside within the CPU.
- A particular register is selected from a register field in the instruction.

Eg:- Add A & DR → data register  
↓      ↓  
1111H + 2222H  
= 3333H

## Register indirect mode:

DR ← address

Contents ← address

Add ← contents

- the selected register contains the address of the operand rather than the operand itself.

- Advantage is that the address field of the instruction uses fewer bits to select a register than could have been required to specify a memory address directly.

Eg:- ADD A, [AR] → indicates address.

- AR = 5000H
- 5000H = 1234H

(or)

Add A, [5000H]

occupies less memory

Autoincrement or Autodecrement Mode:

→ Similar to register indirect mode except that the register is incremented (or) decremented after (or before) its value is used to access memory

Ex:-  
 MOVE A, [AR] → 5000  
 [INCR] → [5001]  
 LOOP      [DEC AR] → 4999

Direct Address Mode:-

- In this mode the effective address = address part of the instruction. The operand resides in memory & its address is given directly by the address field of instruction.
- In a branch-type instruction the address field specifies the actual branch address.

Eg:- ADD A, [5000H]

→ eg:- BUN 2000H  
nxt instruction address

Indirect Addressing Mode:

- Register → Address →

Again → operand.

Address



effective address

## Relative Address Mode:

- In this mode the content of the program counter is added to the address part of the instruction in order to obtain the effective address.
- either it can add address to the program counter ( $PC + \text{addr}$ ) or it can subtract address from the PC to get the effective address whose position in memory is relative to the address of next instruction

## Indexed Addressing Mode:-

- In this mode the content of an index register is added to the address part of the instruction to obtain effective address.
- Index register  $\rightarrow$  Special CPU register  $\rightarrow$  contains index value
- The address field of the instruction defines the beginning address of a data array in memory

## Base Register Addressing Mode:-

- This is similar to the indexed addressing mode except that the register is now called the base register instead of an index register

### Index register:

holds index number  
that is relative to the  
address part of the  
instruction.

### Base Register:

holds a base address  
and the address field  
of the instruction

# Numeric example for Addressing modes

| Addressing Mode   | Effective Address | Content of AC |
|-------------------|-------------------|---------------|
| Direct            | 1001              | 6001          |
| Indirect          | 1101              | 5102          |
| Register          | 1100              | 3404          |
| Register Indirect | 1100              | 2202          |
| Relative          | 1010              | 1003          |
| Indexed           | 1000              | 9000          |

## Instruction set:

- 1) Data transfer instructions
  - 2) Data manipulation instructions
  - 3) program control Instructions

- ① Data transfer instructions  
Operands are changing from one location to another without changing the binary information
- ✓ Data manipulation instructions.  
These instructions performs arithmetic, logic & shift operations.

## Data transfer instructions:

| Name     | Mnemonic                        |
|----------|---------------------------------|
| Load     | LD → AC will be the destination |
| Store    | ST                              |
| Move     | MOV → MOV AC, RI                |
| Exchange | XCH → XCH AC, RI                |
| Input    | IN                              |
| Output   | OUT                             |
| SHpush   | PUSH                            |
| POP      | POP                             |

Addressing modes for load instruction:

| Mode              | Assembly Convention | Register Transfer                                |
|-------------------|---------------------|--------------------------------------------------|
| Direct address    | LD ADR              | $AC \leftarrow M[ADR]$                           |
| Indirect address  | LD @ADR             | $AC \leftarrow M[M[ADR]]$                        |
| Relative address  | LD \$ADR            | $AC \leftarrow M[PC+ADR]$                        |
| Immediate operand | LD #NBR             | $AC \leftarrow NBR$                              |
| Index addressing  | LD ADR(X)           | $AC \leftarrow M[ADR+XR]$                        |
| Register          | LDR1                | $AC \leftarrow RI$                               |
| Register indirect | LD(R1)              | $AC \leftarrow M[RI]$                            |
| Auto increment    | LD(R1) +            | $AC \leftarrow M[RI],$<br>$RI \leftarrow RI + 1$ |

- ② → Data manipulation instructions  
 performs operations on data & provide the computational capabilities of the computer.
- i, Arithmetic instructions
  - ii, logical & bit manipulation instructions
  - iii, Shift instructions.

**Arithmetic Instructions:** (Operates on Bytes)

or word

| <u>Name</u>          | <u>Mnemonic</u> |
|----------------------|-----------------|
| Increment            | INC             |
| Decrement            | DEC             |
| Add                  | ADD             |
| Subtract             | SUB             |
| Multiply             | MUL             |
| Divide               | DIV             |
| Add with carry       | ADDC            |
| Subtract with borrow | SUBB            |
| Negate (2's comp)    | NEG             |

**Logical & Bit Manipulation Instructions:** (Operates on single bits)

| <u>Name</u>           | <u>Mnemonic</u>  |
|-----------------------|------------------|
| Clear                 | CLR              |
| Complement (2's comp) | COM              |
| AND                   | AND              |
| OR                    | OR               |
| Exclusive - OR        | XOR              |
| clear carry           | CLRC → C is both |
| Set carry             | SETC             |
| Complement carry      | COMC             |
| Enable interrupt      | EI               |
| Disable interrupt     | DI               |

## SHIFT Instructions

| <u>Name</u>                | <u>Mnemonic</u> |
|----------------------------|-----------------|
| Logical shift right        | SHR             |
| logical shift left         | SHL             |
| Arthematic Shift right     | SHRA            |
| Arthematic shift left      | SHLA            |
| Rotate right               | ROR             |
| Rotate left                | ROL             |
| Rotate right through carry | RORC            |
| Rotate left through carry  | ROLC            |

## Program Control:-

provides decision-making capabilities and change the path taken by the program when executed in computer

ex:- Branching (BUNI, -)

- The instruction set of a particular Computer determines the register transfer operations and control decisions that are available to the user

| <u>Name</u>      | <u>Mnemonic</u> |
|------------------|-----------------|
| Branch           | BR              |
| Jump             | JMP             |
| Skip             | SKP             |
| call             | CALL            |
| Return           | RET             |
| Compare (by sub) | CMP             |
| Test (by ANDING) | TST             |