

# KCA-105

## Sub:- Computer architecture or organisation

### \* Introduction to computer organisation :-

- ① Computer organisation refers to the operational units and their interconnection.
  - ② It implements the provided computer architecture.
  - ③ Organisation is how features are implemented.
    - Control singles, interfaces, memory technology.
    - For ex- Is there are hardware multiply unit or is it done by repeated edition.
  - ④ Computer architecture is a Blue print for design or implementation of a computer system.
  - ⑤ It provides the functional details or behaviour of a computer system or comes before computer organisation.
- Note:-**
- Computer organisation deals with how to do?
  - Computer architecture deals with what do to?

### \* Difference between computer architecture and computer organisation -

#### Computer architecture

- It is concern with the way hardware components are connected together to form a computer system.
- Acts as the interface between Hardware and Software.
- It helps us to understand the functionality of a System.
- A programmer can view architecture in term of instruction addressing mode and instruction.

#### Computer organisation

- It is concern with the structure and behaviour of a computer science system as seen by the user.
- Deals with the component of a connection in a system.
- It tells us how exactly all the units in the system are arranged and interconnected.
- Organisation involves physical components (circuits, design, address, signal, peripherals).

- A programmer can view architecture in term of instruction addressing modes and register.
- While designing a computer system architecture is considered first
- It deals with high level design issues.
- Architecture involves logic (instruction sets, addressing modes, data types, cache memory)
- Organisation expresses the realisation of architecture.
- An organisation is done on the basis of architecture.
- It deals with low design issues.
- Organisation involves physical components (circuits, design, address, signal, peripherals).

### \* Functional Units of Digital System,

- ① A general purpose computer system is the best known example of a digital system.
- ② Other Ex- include telephone switching exchanges, Digital voltmeters, Digital counters, Electronic calculator and digital display etc.
- ③ A computer consists of 5 main components -  
 ① Input  
 ② Output  
 ③ Memory  
 ④ ALU  
 ⑤ CU



### \* Input Unit :-

- ① It is used by the computer to read the Data.
- ② The most commonly used input devices are keyboards, mouse, joystick, trackballs, microphones etc.
- ③ Whenever a key is pressed the corresponding letter or digit is automatically translated into its corresponding binary code and transmitted over a cable to either the memory or the processor.

### \* Control Unit :-

- ① It is a component of a computer CPU the coordinates the operations of the processor.
- ② It tells the computer memory, ALU and I/O devices how to respond to a program's instruction.
- ③ The control unit is also known as the nerve centre of a computer system.

### \* Central processing Unit :-

- ① It is commonly known as CPU can be referred as electronic circuitry within a computer.
- ② It carries out the instructions given by a computer program by performing the basic arithmetic, logical, control and I/O operations specified by the instruction.

### \* Memory Unit :-

- ① It is referred as the storage area in which programs are kept which are running and that contains data needed by the running programs.
- ② The memory unit can be categorized as primary memory and secondary memory.

- Primary Memory :- Also known as volatile form of memory means when the computer is shut down anything contained in RAM is lost.

Ex - RAM - quickly excess of data, temporary storage  
ROM - permanent storage

- Secondary Memory :- It is used when a large amount of data and program have to be stored for a long term basis. Also known as non-volatile memory.  
i.e. Data is stored permanently irrespective of shut down for ex - Magnetic disk, Magnetic tape or optical disk.

- \* Arithmetic and Logical Unit :-  
① Most of all the AL operation of a computer are executed in the Arithmetic and logical unit.
- ② It performs arithmetic operations like - addition, subtraction, multiply, division or also the logical operation like AND or NOT operation.

- \* Output Unit :-  
① Output devices displays information in a way that the user can understand.
- ② These devices display information that has been held on generated with in a computer.
- ③ The most common example of an output devices is a monitor.

- \* Interconnection between functional components :-
- The major part of micro computer are CPU, memory, I/O devices/unit -
- To connect these parts together through three sets of parallel lines called Bus.
- There are three types of Buses -
- i) Address Bus connects all internal computer component to the CPU main memory.
- ii) Data Bus
- iii) Control Bus



\* One line transfer only 1 bit.

\* Bus address Bus is unidirectional because CPU does not store anything it have no memory.



Set of Parallel lines

Address generated by CPU called logical address.

\* Bus arbitration :-

- A device that initiate data transfer on the Bus at any given time is called bus master.
- In a computer system there may be more than one bus master such as DMA. Direct memory access as a DMA controller or processor etc.

- (III) These devices share the system bus and when a current master relinquishes another bus can acquire the control of the process.
- (IV) Bus arbitration is a process by which next device becomes the controller by transferring bus mastership to another bus.
- (V) Bus arbitration schemes usually tried to balance two factors -
- Bus priority :- The highest priority device should be serviced first.
  - Fairness :- Even the lowest priority device should never be completely lock from the bus.

### Types of Bus arbitration

#### Central arbitration

- In centralized arbitration a single bus arbiter performs the required arbitration.
- The bus arbiter may be the processor or a separate controller connected to the bus.

#### Distributed arbitration

- In distributed arbitration all devices participate in the next bus master.

### \* Centralized Bus arbitration :-

- ① In centralized arbitration a single bus arbiter performs the required arbitration.

⑪ There are three different arbitration schemes that used the centralized Bus arbitration approach.

### Central Bus arbitration



### ① Daisy chaining Method:-

① It is a simple and cheaper method.

② All the masters use the same line for making Bus request.



It's working! In section 3 we will see how it works.

- All Bus masters use the same line for bus request.
- If the Bus busy line is inactive the bus controller gives the bus grant.
- Bus grant signal is propagated serially through all master starting from nearest one.
- The bus master which requires system bus stops this signal, activates the bus busy line and takes control of System bus.

## Advantages

- (i) Simplicity
- (ii) Less number of control lines
- (iii) Scalability
- (iv) The user can add more devices along the chain upto certain maximum value number.

## Disadvantages

- (i) Priority assign to a device depends on the position of the bus master.
- (ii) Propagation delay arises due to serially grounding of bus.
- (iii) If one device fails then the entire system will stop working.

## \* Polling or rotating priority method :-

- (i) controller is use to generate address lines for the master.
- (ii) for ex - If there are 8 master in a system atleast three address lines are required.



### Working:-

- ① All bus master use the same lines for bus request.
- ② Controller generates binary address for the master.  
(To connect 8 bus master we need three address lines  $2^3 = 8$ )
- ③ In response to a bus request the controller polls the bus master by sending a sequence of bus masters address on address lines.
- ④ When requesting master recognises its address it activates the bus busy line and takes control of the bus.

### Advantages:-

- ① This method does not favor any particular device and processor.
- ② Simple method.
- ③ If one device fails than the system will not stop working.

### Disadvantages:-

- ① Adding bus masters is difficult as it increase the number of address lines of the circuit.

### (iii) Fixed Priority on independent request method:-

- ① Each bus master has its own Bus request and a grant.
- ② The built-in priority decoder selects the highest priority request and asserts the system.



### Working :-

- ① All bus masters have their individual bus request and bus grant lines.
- ② The controller thus knows which master has request so bus is granted to that master.
- ③ Priority of the masters are predefined so based on the priority provided line is not active.
- ④ The controller consists of encoder or decoder logic for priorities.

### \* Advantages :-

- ① Fast response
- ② Speed independent of number of devices connected.

### \* Disadvantages :-

- ① Hardware cost is high as a large number of control line is required.
- ② Number of control lines required is more therefore connecting large no. of bus master is difficult.



## \* Distributed arbitration :-

- ① All devices waiting to use the bus share the responsibility of carrying out the arbitration process.
- ② Arbitration process does not depend on a central arbiter and hence distributed arbitration has higher reliability.
- ③ Each device is assigned a 4 bit Id number.
- ④ All the devices are connected using 5 lines, 4 arbitration lines to transmit the id and one line for the start arbitration.



$$\begin{aligned}
 \text{Device A} = 5 &\rightarrow 0101 \\
 \text{B} = 6 &\rightarrow 0110 \\
 &\xrightarrow{\text{OR}} 0110 \rightarrow 0R \\
 &\quad 0101 \\
 &\hline
 &011000 \\
 &0110 \\
 &\hline
 &0110
 \end{aligned}$$

| A | B |   |
|---|---|---|
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 1 |
| 1 | 1 | 1 |

## Working -

### \* To request the Bus a Device:-

- ① Asserts the Start arbitration signal signal
- ② Places its 4 bit Id number on the arbitration lines.
- ③ The Pattern that appears on the arbitration lines is the logical or of all the 4 bit devices id placed on the arbitration lines.
- ④ Device A has the Id 5 and wants to request the bus it transmits the pattern 0101 on the arbitration lines.
- ⑤ Device B has the id 6 and want to request the bus transmits the pattern 0110 on the arbitration lines.
- ⑥ Pattern that appears on the arbitration lines is the logical or of the patterns. Pattern 0111 appears on the arbitration lines.

## Arbitration process :-

- ① Each device compares the pattern that appears on the arbitration lines to its own Id starting with MSB (most significant bit)
- ② If it detects a difference it transmits 0's on the arbitration lines for that and all lower bit position.
- ③ Device A compares its Id 5 with a pattern 0101 to pattern 0111.
- ④ It detects a difference at bit position 0 as a result it transmit a pattern 0100 on the arbitration line.

- ① The pattern that appears on the arbitration lines is the logical OR of 0100 and 0110 which is 0110.
- ② This pattern is the same as device ID of B hence B has won and hence we has won the arbitration.

### Introduction to Bus :-

- ① Bus is a sub system that is used to transfer Data and other information between devices.
- ② Various devices in computer such as memory, CPU, I/O etc communication with each other through bus.
- ③ In general a bus is said to as a communication way connecting two or more devices.
- ④ A key characteristics of a bus is that it is a Shared transmission medium because multiple devices are attached to a bus.
- ⑤ A bus consists of multiple communication pathways or lines which are either in a form of wire or metallines etched in a card or board (Printed circuit board).
- ⑥ Each line is capable of transmitting Binary 1 and Binary 0.
- ⑦ Computer System contains a number of different buses that provides path ways between components at various levels of computer system hierarchy.



Three types of buses are -

- (i) Address Bus
- (ii) Data Bus
- (iii) Control Bus

### Data Bus:-

- (i) Data lines provides a path for moving data b/w system modules.
- (ii) It is bidirectional which means data lines are used to transfer data in both directions.
- (iii) for ex - CPU can read data on these lines from memory as well as send data out of these lines to a memory location or to a port.
- (iv) In any bus the number of lines in data lines are either 8, 16, 32 or more depending on size of bus, these lines collectively are called as data bus.

### Address Bus:-

- (i) Address lines are collectively called as address bus.
- (ii) In any bus the number of lines in addresses are usually 16, 20, 24 or more depending on types of architecture of bus.
- (iii) On these lines CPU sends out the address of memory location on the I/O Port.
- (iv) The communication is one way i.e. the address is sent from the CPU to memory and I/O Port but not memory or I/O Port send address to CPU on that lines hence these lines are Unidirectional.

### 3- Control Bus:-

- ① Control lines are collectively called as control bus.
- ② They are used by CPU's for communicating with other devices within the computer.  
for ex- CPU sends signals on the control bus to enable the outputs of address memory devices and port devices.
- ③ Typical control line signals are -
  - i) Memory read , memory write
  - ii) I/O read , I/O write
  - iii) Bus request
  - iv) Bus grant

### \* Operation of Bus:-

The operation of bus is as follows -

- 1) If one module wishes to send data to another it must do two things
  - obtained the use of module bus
  - transfer data to the bus
- If one module wishes to request data from another module it must
  - obtained the use of Bus
  - transfer a request to other module over the appropriate control or address line and then it must wait for that second module to send the data.

### Types of Buses !-

- ① There are variety of Buses but some of widely use bus are -
- ② System Bus :-
  - \* A Bus that connects major computer components (Processor, memory, I/O) is called a System Bus.

- (i) It is signal computer bus among all buses that connects all these components of a computer system.
- (ii) It is the only bus in which data lines address and control lines all are present, it is also known as front side bus.
- (iii) It is faster than peripheral bus (PCI, ISA) etc. but slower than back side bus.

#### \* Peripheral Bus (I/O Bus or External bus) :-

- (i) peripheral Bus also known as I/O Bus.
- (ii) It is data path way that connects peripheral devices to the CPU.
- (iii) In computing a peripheral bus is a computer bus design to support computer peripheral like - printers, harddrives etc.
- (iv) The PCI and USB buses are commonly used peripheral buses and are today used in commonly PC's.

#### \* PCI (Peripheral component Interconnect) :-

- (i) PCI Bus connects the CPU and expansion board such as modem cards, network card and sound card.
- (ii) These expansion boards are normally plugged into expansion slot on the motherboard.
- (iii) That is used by PCI bus is also known as expansion or external bus.

#### \* USB (Universal Serial bus) :-

- (i) Universal serial bus is use to attach USB devices like Pendrive etc to CPU.

#### \* Local Bus :-

- (i) Local Bus are the traditional I/O (peripheral bus) Such as ISA, MCA or EISA Buses.

- ISA - Industry Standard Architecture Bus -
  - ① The ISA bus permit Bus mastering i.e. It unable to peripheral connected directly to the bus to communicate directly with other peripheral without going to processor.
  - ② One of the consequences of Bus mastering is direct memory access.
  - ③ Up to <sup>end the</sup> 1990's, almost all PC's were equipped with ISA Bus it was gradually replaced by the PCI bus which offered a better performance.
- MCA - Micro channel architecture -
  - ① It is an imprecise proprietary bus designed by IBM in 1987 to be used in their PS/2 lines by computer.
  - ② This 16 to 32 bit bus was incompatible with the ISA bus but had put reach throughput ~~rate~~ of 20 Mbps.
- EISA - Extended industry standard architecture -
  - It was developed in 1988 by a consortium team.
  - The EISA bus use connectors that were same size as the ISA connectors with 4 rows of contacts instead of 2 (two) for 32 bit addressing.

## Bus Structure :-

- ① Single Bus Structure :-
- ② All units are connected to a single bus so it provides all the sole means of interconnection.
- ③ It has advantages of simplicity, no cost, and many devices can be connected.
- ④ It has disadvantages of limited speed, since usually only two units can participate in a data transfer at any one time therefore an arbitration system is required and those units will be forced to wait.
- ⑤ Bus control lines are used to arbitrate multiple requests for the use of the bus.



## 2) Double Bus Structure :-

- ① Double Bus Structure is used to overcome the bottleneck of single bus structure.
- ② It uses two buses
  - One bus is used to fetch instructions
  - Other is used to fetch data required for execution.
- ③ In the first configuration the processor is placed between the Input output unit and the memory unit.
- ④ The processor is responsible for any data transfer between the I/O unit and the memory unit.
- ⑤ The processor acts as a messenger.



### Double bus structure

\* Single bus v/s Double bus :

#### Single bus

- \* One common bus is used for communication between peripheral or processor.
- \* Instructions and data both are transferred in same bus.
- \* Its performance is low.
- \* Cost of single bus structure is low.
- \* No. of cycle for execution is more.
- \* Execution process is slow.
- \* No. of registers associated are less.
- \* At a ~~time~~ time single operand can be read from bus.

#### Double Bus

- \* Two Buses are used one for communication from peripheral and other for processor.
- \* Instruction and data both are transferred in different buses.
- \* Its performance is High.
- \* Cost of Double bus structure is high.
- \* No. of cycle for execution is less.
- \* Execution process is fast.
- \* No. of registers associated are more.
- \* At a time two operand can be read.

## \* Introduction to Register :-

- ① Register is a very fast computer memory used to store data/instruction in execution.
- ② A register is a group of flip-flops with each flip-flop capable of storing 1 bit of information.
- ③ A  $n$ -bit register has a group of  $n$  flip-flops and capable of storing  $n$  bits of information.
- ④ A register consists of a group of flip-flops and gates.
- ⑤ The flip-flops hold the binary information and gates control when and how new information is transferred into a register.
- ⑥ Various types of register are available commercial.
- ⑦ The Simplest is one that consists of only flip-flops and with no external gates.

Some of the commonly used register are:-

- ① Accumulator :- This is the most common register used to store data taken out from the memory.
- ② General Purpose register :- This is used to store data intermediate result during program execution it can be accessed by assembly programming.
- ③ Special purpose register :- User do not access these register these register are for computer system.
- ④ MAR (Memory address register), are those register that holds the address for memory unit.
- ⑤ MDR/MBR (Memory Data/Buffer register) :- Store instruction and data received from the memory and send to the memory.

- PC (Program counter) - Program counter points to the next instruction to be executed.
- IR (Instruction register) ! - Holds the ~~instruction~~<sup>instruction</sup> to be executed.

\* Addressing modes:

① Implied mode -

INCA  
increment  
accumulator

② Immediate mode -

③ Direct -

④ Indirect -

Indirect addressing mode is used to access memory locations through pointers. It is also called pointer addressing mode. In this mode, the address of the variable is stored in another memory location. This memory location is called the base register. The value stored in the base register is added to the offset value to get the effective address of the variable.

Indirect addressing mode is also known as pointer addressing mode.

Indirect addressing mode is used to access memory locations through pointers. It is also called pointer addressing mode. In this mode, the address of the variable is stored in another memory location. This memory location is called the base register. The value stored in the base register is added to the offset value to get the effective address of the variable.

Indirect addressing mode is used to access memory locations through pointers. It is also called pointer addressing mode. In this mode, the address of the variable is stored in another memory location. This memory location is called the base register. The value stored in the base register is added to the offset value to get the effective address of the variable.

Indirect addressing mode is used to access memory locations through pointers. It is also called pointer addressing mode. In this mode, the address of the variable is stored in another memory location. This memory location is called the base register. The value stored in the base register is added to the offset value to get the effective address of the variable.

Indirect addressing mode is used to access memory locations through pointers. It is also called pointer addressing mode. In this mode, the address of the variable is stored in another memory location. This memory location is called the base register. The value stored in the base register is added to the offset value to get the effective address of the variable.

Indirect addressing mode is used to access memory locations through pointers. It is also called pointer addressing mode. In this mode, the address of the variable is stored in another memory location. This memory location is called the base register. The value stored in the base register is added to the offset value to get the effective address of the variable.

Indirect addressing mode is used to access memory locations through pointers. It is also called pointer addressing mode. In this mode, the address of the variable is stored in another memory location. This memory location is called the base register. The value stored in the base register is added to the offset value to get the effective address of the variable.

Indirect addressing mode is used to access memory locations through pointers. It is also called pointer addressing mode. In this mode, the address of the variable is stored in another memory location. This memory location is called the base register. The value stored in the base register is added to the offset value to get the effective address of the variable.

Indirect addressing mode is used to access memory locations through pointers. It is also called pointer addressing mode. In this mode, the address of the variable is stored in another memory location. This memory location is called the base register. The value stored in the base register is added to the offset value to get the effective address of the variable.

Indirect addressing mode is used to access memory locations through pointers. It is also called pointer addressing mode. In this mode, the address of the variable is stored in another memory location. This memory location is called the base register. The value stored in the base register is added to the offset value to get the effective address of the variable.

Indirect addressing mode is used to access memory locations through pointers. It is also called pointer addressing mode. In this mode, the address of the variable is stored in another memory location. This memory location is called the base register. The value stored in the base register is added to the offset value to get the effective address of the variable.

Addressing modes! - These different ways of specifying the location of an operand in an instruction are called as addressing modes.

### Types of Addressing modes!

① Implied! - (Implicit) The definition of the Instruction itself specify the Operands implicitly.

- Zero address instruction are implied mode instruction ex- increment, decrement

② Stack! - The operand is contained at the top of the stack.

- This instruction simply pops out two symbols contained at top of the stack.
- The addition of those two operand is performed.
- The result so obtained after addition is pushed again at the top of the stack.

③ Immediate! -

- The operand is specified in the instruction explicitly.
- Instead of address field, an operand field is present that contains the operand.



④ Direct addressing mode! Absolute -

- The address field of the Instructions contain the effective address of the operand.
- Only one reference to memory is required to fetch the operand.



⑤ Indirect addressing mode :- The address field of the instruction specifies the address of memory location that contains the effective address of the operand.



- Two references to memory are required to fetch the operand.

⑥ Register direct addressing mode :-

- The operand is contained in a register set.
- The address field of the instruction refers to a CPU register that contain the operand.
- No reference memory required.



- Same as direct addressing mode only difference is address field of the instruction refers to a CPU register instead of main memory.

⑦ Register-Indirect addressing mode :- The address field of the instruction refers to a CPU register that contain the effective address of operand.

- Only one memory references is require to fetch the operand.



⑧ Intrasegment Relative addressing mode:- effective address of operand is obtained by adding the content of program counter with the address part of the instruction.



- after fetching the address of the instruction the value of program counter immediately increase.

⑨ Indexed addressing mode:- effective address of the operand is obtained by adding the content of index register with the address part of instruction.

Effective = Content of Index register + address part of the instruction.



⑩ Base register:- Effective address of the operand is obtained by adding the content of base register with the address part of instruction.

$$EA = \text{Content of base R} + \text{address part of instruction}$$

|        |               |   |
|--------|---------------|---|
| Opcode | Base register | A |
|--------|---------------|---|



### ⑪ Auto-increment -

- After accessing the operand the content of the register is automatically incremented by step size 'd'
- Only one memory reference required to fetch the operand.

EA = Content of register

|        |      |       |
|--------|------|-------|
| Opcode | mode | Rauto |
|--------|------|-------|



operand size = 2 bytes

- After fetching operand 6B, the instruction register Rauto will be automatically incremented by 2.

### ⑫ Auto Decrement! -

EA = Content of register - Step size

- First the content of register decremented by step size 'd'.
- Only one reference to memory is required to fetch the operand.



- Rauto will be decremented first then update value.
- \* Applications of addressing modes !-
- \* Immediate! - To initialize registers to a constant value.
- \* Register/Direct addressing mode! - To access static data To implement variables
- \* Register / Indirect! - To implement pointers because pointers are memory location that store address of another variable.
- \* Relative - for program relocation at run time i.e. for position independent code for branch type instruction.
- \* Index - For array implementation are or array addressing.
- \* Base register - for relocation of program in memory even at run time .
- \* Auto increment/decrement! for implementing
  - for stepping through arrays in a loop
  - for push - pop .