

Aug 23/24

XTRA  
Date : / /  
Page : 23

## UNIT - 1

Ques- What is Computer Architecture?

Ans- C.A. can be defined as a set of rules and methods that describe the functionality, management and implementation of computers. It is nothing but rules by which a system performs and operates.

Sub-divisions → ① Instruction Set Architecture  
or I.S.A.

① I.S.A:-

Whenever an instruction is given to processor its role is to read and act accordingly.

② Micro-Architecture:-

It describes how a particular processor will handle and implement instructions from I.S.A.

③ System Design:-

It includes hardware components within the system.

## \* Role of Computer Architecture

The main role of C.A. is to balance the performance, efficiency, cost and reliability of a computer system.

For eg. → I.S.A. act as a bridge b/w computer's software and hardware.

Computer can only understands binary language (0,1) and user understands high level lang.; so to communicate b/w user and computer, ISA plays a major role.

- ① Processor → ALU, Control Unit, Bus interface
- ② Memory → Memory Array, Address Decoder
- ③ Peripheral → Peripheral Logic, Address Decoder

Aug 5, 24

XTRA  
EDITION  
Date : / /  
Page :

## # Register Transfer Language

A digital computer system exhibit an interconnection of digital modules such as registers, decoders, arithmetic elements and control logic.

These digital modules are interconnected with some common data and control path to form a complete digital system. Moreover, digital modules are best define by the registers and operations that are performed on the data stored in them.

(S7TM)  
Operations performed on the data stored in registers are known as micro-operations.

The internal hardware organisation of a digital system is best defined by:

1. The set of registers and the flow of data b/w them.
2. The sequence of micro-operations performed on the data which are stored in the registers.
3. The control path that initiates the sequence of micro-operations.

→ The Register Transfer Language is the symbolic representations of notations used to specify the sequence of micro-operations.

In a computer system, data transfer takes place b/w processor, registers and memory as well as b/w processor, registers and Input-Output System. These data transfer can be represented by standard notations like

1. R0, R1, R2, ... represent processor registers.
2. The address of memory locations (place) are represented by names such as PLACE, MEM and LOC etc. (lateral Address complex)
3. I-O registers are represented by name such as DATA-IN, DATA-OUT.
4. The content of register or memory is denoted by placing [ ] around the name of registers and memory locations.

Cost

XTRA  
Date: / /  
Page:

## Processor



## CONTROL UNIT



DMA → Direct Memory Access

## # Register Transfer

The term register transfer refers to the availability of hardware logic circuits that can perform a given micro-operation and transfer the result of the operation to the same or another register.

Most of the standard notations used for specifying operations on various registers are as follows:-

- ① The Memory Address Register is designated by M.A.R (Memory Access Register).
- ② Program Counter (P.C.) holds the next instructions address.
- ③ Instruction Register (I.R.) holds the instruction being executed.
- ④ R1 (Process Register)
- ⑤ We can also indicate individual bits by placing them in parenthesis (brackets) for eg →

  - ( ) PC (8-10)
  - ( ) R1 (5)

- ⑥ Data Transfer from one register to another register is represented in symbolic form by means of Replacement Operator.  
( for eg → )

  - R2 ← R1

- ⑦ Typically most of the users want to transfer only in a pre-determined control conditions.

But we also use if - then statement.  
for eg. →

If  $P=1$  then  $R_2 \leftarrow R_1$   
 ↳ (Program Counter, Processor)

~~Aug 13 24~~

## \* Bus and Memory Transfer

A digital system composed of many registers and paths must be provided to transfer information from one register to another.

The number of wires are connecting all of the registers will be excessive if separate lines are used b/w each registers and all other registers in the system.

Bus A bus structure, on the other hand is more efficient for transferring information b/w registers in a multi-register configuration system.

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

Control signal determines which register is selected by the bus during a particular register transfer.

of a Bus system for four registers. For instance, output 1 of register A is connected to input

**Bus System for 4 Registers:**



The two selection lines S<sub>1</sub> and S<sub>2</sub> are connected to the selection inputs of all four multiple selection lines choose the four bits of one register and transfer them into the four-line common

electronic circuits  
which are used to  
transfer the signals  
through bus.

| S1 | S2 | R |
|----|----|---|
| 0  | 0  | A |
| 0  | 1  | B |
| 1  | 0  | C |

1 1 8

The two selection lines ~~as~~  $B_1$  and  $B_2$  are connected to the selection P/P of all four multiplexers. The selection lines chose the 4 bits of one register and transfer them into the 4 line common bus. When both of the select lines are at low logic, i.e.,  $B_1, B_2 = 0, 0$ ; the zero data P/P of all 4 multiplexers are selected and applied to the outputs that form the bus.

Similarly, when  $S_1, S_2 = 0, 1$ , register B is selected and the bus will receive the content provided by register B and so on.

Aug 14: 24

### \* 3-State Bus Buffer

The three 3-state gates can be considered as a digital circuit that has 3 gates, two of which are signals equivalent to logic 1 and 0 as in a conventional gate. However, the third gate exhibits a high impedance state.

The most commonly used 3-state gates in case of bus systems. It is known as buffer gate.

Symbol is represented

Normal I/P A

Normal I/P B



Output Y

The graphical

- ①  $Y = A$ , if  $C = 1$
- ② High impedance, if  $C = 0$

## # Memory Transfer

Memory Transfer notations are used as follows:

- ① The transfer of information from a memory to the user is called a read operation.
- ② The transfer of new information to be stored in the memory is called write operation.
- ③ A memory word is designated by the letter 'M'.
- ④ We must specify the address of memory word while writing the memory transfer operation.
- ⑤ The address register is designated 'AR' and the data register by 'DR'.
- ⑥ Thus, a read operation can be stated as

Read:  $M [AR \leftarrow R1]$

and the write operation as

Write:  $M [AR \leftarrow R1]$



## # Logic Micro-operations

It specifies binary operations stored in registers. These operations consider each bit of the register separately and treat them as binary variable.

For eg. →

The exclusive OR micro-operations with the content of two registers R1 and R2 is symbolized by the statement

$$P : R1 \leftarrow R1 \oplus R2$$

It specifies a logic micro-operation to be executed on the individual bits of the registers provided that the control variable using method  $P=1$  as a numerical example. Assume that each register has 4 bits. Let R1 be 1010 and the content of R2 be 1100. The exclusive OR micro-operation gives the following computation.

as per X-OR,

$$\begin{array}{r}
 1 \ 0 \ 1 \ 0 \\
 1 \ 1 \ 0 \ 0 \\
 \hline
 0 \ 1 \ 1 \ 0
 \end{array}
 \quad R_1$$

R2

new value of R1

The content of R1 after the execution of the micro-operation is equal to the bit by bit exclusive-OR operation on pairs of bits in R2 and previous value of R1.

Special symbols are used for the logic micro-operations OR, AND and NOT (complement).

Symbol:→

|          |       |
|----------|-------|
| $\vee$   | → OR  |
| $\wedge$ | → AND |
| $\sim$   | → NOT |

List of logic operations:-

There are 16 logic operations that can be performed with 2 binary variable  $x$  and  $y$ . The functions are determined from the 16 binary combinations that can be assigned to  $f$ .

$$F_0 = 0$$

$$F_1 = A \wedge B$$

$$f_2 = A \wedge \overline{B}$$

$$f_3 = A$$

$$F_y = \bar{A} \wedge B$$

$$f_6 = \beta$$

$$F_6 = A \oplus B$$

$$f_7 = A \vee B$$

$$f_B = \overline{A \vee B}$$

$$f_g = \overline{A \oplus B}$$

$$f_{10} = \bar{B}$$

$$f_{11} = A \vee \bar{B}$$

$$f_a = \frac{\bar{A}}{\bar{B}}$$

$$f_{13} = A \vee B$$

$$F_{14} = \overline{A \wedge B}$$

$$f_{15} = 1$$

Aug 22, 24 Gates

① AND gate

If both IP are high, O/P is high

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

② OR gate

If one or more IP are high, O/P is high

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

③ NOT gate

O/P is inverse of IP

| A | Y |
|---|---|
| 0 | 1 |
| 1 | 0 |

(4) NAND gate

high O/P if only one or both I/P is low.

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

(5) NOR gate

high O/P if both I/P is low

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

(6) X-OR

gives a high O/P if one of its I/P is high  
not both

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

high if I/P is different.  
low if I/P is same.

## (7) X-NOR

it gives low O/P if one of its I/P is high

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

high if I/P is same.

low if I/P is different.

## # Hardware Implementation

- (1) The hardware implementation of logic micro-operations required that logic gates be inserted for each bit or pair of bits in the registers to perform the logic functions.
- (2) Although there are 16 logic micro-operations but mostly use only 4, i.e., AND, OR, X-OR, NOT

These operations are also used for manipulating the bits stored in a register.

- (3) It consists of 4 gates and multi-plexers each of the 4 logic micro-operations is generated through a gate that performs a required logic.

Aug 27, 24

- ④ The O/P of the gates are applied to the data I/P of the multiplexer. The two selection I/P's  $S_1$  and  $S_0$  choose one of the data I/P's of the multiplexer and direct its value to the O/P.



| $S_1$ | $S_0$ | Output           | Operation        |
|-------|-------|------------------|------------------|
| 0     | 0     | $f = A \wedge B$ | AND              |
| 0     | 1     | $f = A \vee B$   | OR               |
| 1     | 0     | $f = A \oplus B$ | XOR              |
| 1     | 1     | $f = \bar{A}$    | (Complement) NOT |

## # Logic - Microoperations Applications

- ① It is used for manipulating individual bit stored in a register.
- ② They can be used to change the bit value delete a group of bits or insert a new bit into a register.

for eg. → ① Selective Sets

The Selective set operation sets to 1 in register A where there are corresponding ones in register B. It does not affect bit position that have zeros in B.

$$\begin{array}{r}
 A \rightarrow 1) 0\ 9\ 1) 0 \\
 B \rightarrow 1) 1\ 0) 0 \\
 \hline
 1\ 1\ 1) 0
 \end{array}$$

② Selective Complement

The Selective complement operation complement the 1 bit in A where there are corresponding one in B. It doesn't affect bit position that has zeros in B.

$$\begin{array}{r}
 \text{complement} \\
 A \rightarrow 1) 0\ 9\ 1) 0 \\
 B \rightarrow 1) 1\ 0) 0 \\
 \hline
 0\ 1\ 1) 0
 \end{array}$$

① Selective Clear

## # Shift Micro-operations

- ① Shift micro-operations are used for serial transfer of data.
- ② The content of register can be shifted to the left or to the right.
- ③ During a shift left operation, the serial I/P transfer a bit into the right-most position.
- ④ During a shift right operation, the serial I/P transfer a bit into the left-most position.
- ⑤ There are three types of shift operations:-
  - a) logic
  - b) circular
  - c) arithmetic

### Logical Shift Micro-operation

It transfers zero (0) through the serial I/P. A symbol 'Shl' for logical shift left and 'Bsr' for logical shift right.

The micro-operation that specifies a 1 bit shift to the left of the content of register R and 1 bit shift to the right of the content of register R as shown below.

The bit transferred to the end position through the serial I/P is assumed to be (0) zero during a logical shift.

## Circular Shift Micro-operation

It is also known as Rotate Operation.

It circulates the bit of a register around the 2 ends without loss of the information.

This is accomplished by connecting a serial I/P of the ~~ashift~~ register to its serial O/P. We will use the symbols C<sub>l</sub> for the ~~ashift~~ left and C<sub>r</sub> for the ~~circulate~~ shift right.

## Arithmetic Shift Micro-operation

It is a micro-operation that shifts the signed binary number to the left or right.

An arithmetic shift left multiplies a signed binary number by 2 and arithmetic shift right divides the number by 2.

Arithmetic shift must leave the signed bit unchanged because the sign of a no. remains the same when it is multiplied or divided by 2.

- Advantages →
  1. Productive Information Controlled.
  2. Upgraded number crunching activity
  3. Bitwise Activity
  4. Utilization of memory

- Applications →
  1. Math activities
  2. Design handling

# UNIT-1 BASIC COMPUTER

## ORGANIZATION

### # Instruction Codes

A computer instruction is a binary code that determines micro-operation in a sequence to computer.

Each computer has its specific group of instruction. They can be categorized into 2 elements:

- ① Operation code (OP code)
- ② Address code

1. OP code → Specific instruction operation perform on specific instructions.

2. Address code → An address means which register can be used for this operation.

For eg. → If there is 12 bits of memory that are required to define the address mode. Therefore, the 15<sup>th</sup> bit of the instruction determine the address mode.

Therefore, the instruction format includes 12 bits of address and one bit for the addressing mode and 3 bit for the address.

0 - 12 bits

12 → instructions

1 → address mode.

$16^{th}$  bit → 8 bits ← OP code.

|   |         |                |
|---|---------|----------------|
| 1 | OP code | Memory Address |
|---|---------|----------------|

→ There are 3 parts of instruction format →

### ① Addressing Mode

- (a) Direct Addressing → for address of the operand
- (b) Indirect Addressing → It uses for the pointer of operand.

(pointer → use to display & known the address)

### ② Effective Address

It defines the address that can be executed as a target address for a branch type instruction or you can say that the address that can be used directly to create an operand for a computation type instruction without creating any changes.

### OP code (Operation code)

An OP code is a collection of bits that represent the basic operations including add, subtract, multiply, complement and shift.

The total no. of operations provided

through the computer determines the no. of bits needed for the OP code.

(if n no. of bits = n no. of operations performed)

### Address

The address is represented as the location where a specific instruction is constructed in the memory. The address bits of an instruction is used as an operand and not as an address. In such methods, the instruction has an immediate operand.

If the second part has an address, the instruction is referred to have a direct address.

There is another second part including the address of an operand. This is referred to as an indirect address. Only one bit can signify if the direct or indirect address is executed, i.e., 0 and 1.

| Mode            | OP code | Operand / Address of operand |
|-----------------|---------|------------------------------|
| Direct/Indirect |         |                              |

A basic computer has 3 instruction code formats which are -

- ① Memory - Reference instruction
- ② Register - Reference instruction
- ③ Input - Output instruction

### ① Memory Reference Instruction



In memory reference instruction, 12 bits of memory is used to specify an address and 1 bit to specify the addressing mode.

### ② Register Reference Instruction

They are represented by the OP code which is used 2 bits in a diagram.

### ③ Input Output Instruction

Just like the register reference instruction an I-O instruction does not need an any reference to into a memory and it is recognized by the operation code with a 1 in the left-most bit of the instruction.



The 3-operation code bits in position 12 to 15 should be equal to 111 otherwise the instruction is a memory add reference type, otherwise it is considered as a memory reference which is on the position of 15.

## # Computer Instruction Timing and Control

The timing for all registers in the basic computer is controlled by a master clock generator. The clock pulses are applied to all flip-flops and registers in the system.

The control signals are generated in the control unit and provides control input for the multiplexers in the common data bus.

Control input in the processor registers and micro-operators for the manipulations.

There are 2 types of Control Organisation →

① Hard wired control

② Micro-programmed control

### ① Hard wired Control

It is implemented with gates and other digital circuit (like multiplexers, decoders).

It can be used to provide a fast mode of operations.

### ② Micro-programmed Control

The control instruction is stored in a memory is programmed to initiate the required sequence of micro-operations.



Clr → Clr input is active when positive clock transition happens. The sequence of timing signals  $T_0, T_1, T_2, \dots$  changes in the diagram. It can represent the relationship b/w the timing signals and its corresponding positive clock transition.

for eg. → Consider the case incremented instruction timing signals are  $T_0, T_1, T_2, T_3, T_4$  in the sequence. At time of  $T_4$ , cleared action is zero and it is active after the incrementing will complete.

Sept 9:24

## # Instruction Cycle in Computer Architecture

A program consisting of the memory unit of the computer includes a series of instructions. The program is implemented on the computer by going through a cycle for each instruction.

In each instruction cycle, follow the different procedures -

- ① It can fetch instruction from memory.
- ② It is used to decode the instructions.
- ③ It can read the effective address from memory if the memory has indirect address.
- ④ It can execute the instruction (procedure)

After the following 4 procedures are done,  
the control switch back to the  
first step and repeat the similar process  
for the next instructions.

Therefore, the cycle continues until a  
halt condition is met.

The figure shows the four stages in  
the construction cycle.



① Fetch Cycle →

The instructions are stored in program counter which are going to execute.

The processor fetches the instruction from the memory i.e., pointed by the PC (program counter).

Next, the PC is incremented to display the address of the next instruction. The processor reads the instructions and execute the important procedure.

② Execute cycle →

The data transfer for implementation takes place in 2 methods -

① Processor ↔ Memory

② Processor - Input / Output

① The data sent from the processor to memory or from memory to processor.

② The data can be transferred to or from a peripheral device (hardware device) by transfer b/w a processor and I/O device.

In the execute cycle, the processor implement the important operations on the information. These 2 methods associate and complete the execute cycle.

Q1. Draw Diagram for instruction cycle →

A. ① Instruction Address Calculation  $\rightarrow$

The next instruction address is computed here. A permanent number is inserted to the address of the earlier instruction.

$$\begin{array}{ccc} \text{Input} & - & \text{Output} \\ \text{no. of bits} & n & 2n \text{ (nm)} \end{array}$$

② Instruction fetch  $\rightarrow$

The instruction is read from its specific memory location to the processor.

③ Instruction Operation Decoding  $\rightarrow$

The instruction is interpreted and the type of operations to be implementing and the operand(s) to be used are decided.

B. ④ Operand Address Calculation  $\rightarrow$

The address of the operand is evaluated if it has a reference memory through the input-output.

⑤ Operand fetch  $\rightarrow$

The operand is read from the memory or from I/O.

⑥ Data Operation  $\rightarrow$

The actual operation is executed or last store operands. It can store the result in

~~Sept 10; 24~~  
the memory or transfer it to I/O.

## # Memory Reference Instruction

There are seven memory reference instructions. The Decade Output ( $D_i$ ) for  $i=0, 1, 2, 3, 4, 5$  and 6 from the operation decoder that belongs to each instruction is included in the table.

The effective address of the instruction is in the address register AR and was placed there during timing signal  $T_2$  when  $i=0$  or during timing signal  $T_3$  when  ~~$i=1$~~ .

The execution of the memory reference instructions start with timing signal  $T_4$ .

The symbolic description of each instruction is specified in the table in terms of register transfer notation.

Memory Reference Instruction Table

| Symbol                          | Instruction/Operation | Decoder | Sybmolic Description                              |
|---------------------------------|-----------------------|---------|---------------------------------------------------|
| $AC \rightarrow$<br>Accumulator | AND                   | $D_0$   | $AC \leftarrow AC \wedge M[AR]$                   |
|                                 | ADD                   | $D_1$   | $AC \leftarrow AC + M[AR]$                        |
|                                 | LDA                   | $D_2$   | $AC \leftarrow M[AR]$                             |
|                                 | STA                   | $D_3$   | $M[AR] \leftarrow AC$                             |
|                                 | BIN                   | $D_4$   | $PC \leftarrow AR$                                |
|                                 | BOA                   | $D_5$   | $M[AR] \leftarrow PC, PC \leftarrow AR$           |
|                                 | IOPZ                  | $D_6$   | $\# M[AR] + 1 = 0$ then<br>$PC \leftarrow PC + 1$ |

### ① AND to AC

This is an instruction that performs the AND logic operation. The result of the operation is transferred to AC. The micro-operation that execute this instruction are - D<sub>0</sub> T<sub>4</sub>.

### ② ADD to AC

This instruction adds the content of the memory specified by the effective address to the value of AC.

e.g. → Accumulators are registers.

The sum is transferred into AC and the O/P carry out is transferred to the E accumulator, E = extended, i.e., extended accumulator (e.g. flip flops).

The micro-operations needed to execute these instructions are D<sub>1</sub> T<sub>4</sub>, D<sub>1</sub> T<sub>3</sub>.

Table

### ③ LDA (load to AC)

This instruction transfer the memory word specified by the effective address to AC. The micro-operations needed to execute are D<sub>2</sub> T<sub>4</sub>, D<sub>2</sub> T<sub>5</sub>.

# Input/ output interface:



The I/O Interface implement a method by which data is transferred b/w Internal storage and external I/O devices.

All the devices are connected to a computer that require a special communication connection for interfacing with the CPU.

I/O bus is the route used for peripheral devices to interact with the CPU or hardware devices.

Computer and processor. The Fig shows the typical connection of the I/O to I/O device.

The input output bus is linked to all devices and the device address with the interface.

An interface receive four commands:

- (1) Control : → A Command Control is given to activate the device and inform its next task. Each device has a sequence of control commands.
- (2) Status : → It can check or test multiple conditions. In the interface and the device.
- (3) Data o/p → It is used to create the Interface counter to the command by sending data from the bus to one of its registers.
- (4) Data i/p →

This command is opp to the data o/p. On this, the interface gets the data from hardware device and copy it to specific register.



There are 3 modes of transfer :

(1) Programmed I/O : Here the data is transferred by an instruction in the CPU programmed and it can be happened with immediate path from Register and Memory also.

(2) Interrupt-Initiated I/O :- By using interrupt facility a special command to inform the interface to issue an interrupt request signal when data is available from memory device. The CPU can proceed for its own programme. When it is determined that the device is ready for data transfer that initiate request signal to the CPU. Then the CPU stop the task it was already performing.

(3) DMA → The Data Transfer b/w a fast storage media such as Magnetic disk and memory until the speed of bus is limited avg.

Thus, we can allow the device that directly communicate with each other using bus.

# DMA:

DMA: DMA is a direct memory access act as a station Master that transfers the data with minimum intervention of the processor.

## Hardware device:

The hardware device used for direct memory Access is called DMA Controller. DMA controller is a control unit part of an I/O device interface circuit which can blocks of data b/w I/O devices and main-memory without processor.

## DMA Controller Architecture:-

DMA controller provides an interface block between the bus and one or more I/O devices. Although it transfers the data without the intervention of processor but, it is controlled by the processor.

The processor initiates the DMA controller by sending the starting address number of words and direction of data i.e. from I/O device to the main memory.

More than one external device can be connected to the DMA Controller.

### Working of DMA Controller :-

It has to share the bus with the processor to make the data transferred the device that holds the bus at the given time is called the "Bus Master".

When a transfer from I/O device to memory or vice-versa has to be made. In this situation the processor stops the execution of current program if the DMAC is free, it requests the control of the Bus from the processor by raising the bus request signal. Processor grants the Bus request signal by raising the grant signal.

Now the Bus Master.

The processor initiates the address and the no. of bits to be transferred after the task is complete. The processor resumes the execution of the program after retrieving instruction from the DMAC.

### 3 Modes of DMA Transfer :-

- 1.) **Burst mode :-** In this DMA handles the buses to CPU after the completion of the task (Data transfer)
- 2.) **Cycle Stealing mode :-** In this DMA gains control of buses to CPU after transfer of every byte.
- 3.) **Transparent mode :-** Here DMA transfers data only when CPU is executing the instruction, which does not require the use of buses.

Additional AMD - pif



fig - DMA Controller

Control unit : way to complement CPU

(i) Hard wired

(ii) Micro-programme

→ CPU consists units →

(i) CU

(iii) MU

Bahr.

(ii) ALU

(iv) I/p Unit

O/p unit

CU → It is a virtual component of a Computer CPU, responsible for co-ordinating and controlling the activities of various hardware components.

→ The CU receives instructions in the form of a binary code from the memory. It decodes these instructions to determine the specific operation that need to be performed. Then it generates control signals that are sent to different part of CPU such as ALU, Registers to carry out operation.

## Computer Registers:

Registers are type of computer memory used to quickly accept, store and transfer data by the CPU.

Registers are used by the CPU known as Processor Registers.

A processor register holds on instruction storage address or Data. The computer needs to manipulate data by the registers and the memory location calculate the address for next instruction of next instruction after the execution of current instruction is completed.

### (1) Data Registers:

Symbol : DR

No. of bits : 16

Function - hold memory operations

### (2) Address Register:

Symbol : AR

No. of bits : 12

Function: hold the address for the memory

### (3) Accumulator:

Symbol : AC

No. of bits : 16

Fn : Processor Register

(8i)

### Instruction Register

Symbol : IR

No. of bits : 16 Bits

F<sup>n</sup> : Hold instruction code

(8j)

### Program Counter

Symbol : PC

No. of bits : 16 bits

F<sup>n</sup> — Holds the address of next instruction

6.) Temporary Register

Symbol : TR

No. of bits : 16 bits

F<sup>n</sup> : Holds Temporary Data

(7)

### Input Register

Symbol : INPR

No. of bits : 8 bits

F<sup>n</sup> : Carries input character

(8)

### Output Register

Symbol : OUTR

No. of bits : 8

F<sup>n</sup> — Carries O/P character

## Registers & Memory Configuration

- (1) The Memory Unit has a capacity 4096 words and each word contain 16 bits.
- (2) The DR contain 16 bits which holds the operand read from the memory location.
- (3) The Memory Address Register (MAR) holds the address for the memory locations.
- (4) The SC means Status Control or Status Condition.

Basic Operational Concept : if  $SC = 0$  - No Instruction

- (1) This instructions are stored in a memory and executed to process Data which are loaded in the Computer Memory through the Input Device.
- (2) After processing the Data the result is either stored in the memory or sent for further reference or send to the outside world through some I/O P device.
- (3) To perform the execution of an instruction including Arithmetic and control unit. The Processor contains nos of Registers used for temporary storage.
- (4) The Program Counter is one of the most critical Register in C.P.U. which keeps track on the next instruction being executed.
- (5) The IR register generates the timing signal that control timing the various processing elements involved in executing the instruction.

(6) The two Registers MAR & MDR used to handle the data transfer b/w Main-memory and Processors.

## # Complete Description of Computer

The complete computer description of a computer includes :-

It includes both Instruction cycle as well as the Interrupt cycle.

The interrupt cycle because there may arise a case of input output operations any-time during the normal operations.

Instruction cycle because in the absence of interrupt the CPU is always busy with stored programme instruction & Flip-flop are used as a condition to determine the type of operation.

When  $R=0$ , the instruction cycle is continuous and when  $R=1$ , interrupt cycle continues. So, an interrupt is signalled by IEN (i.e.) Instruction Enabled number and 'R' is just to make it ensure that another interrupt does not get entertain while processing of an interrupt.



control but generate the control signals

## Hard-wired Vs Micro-programmed Control unit

In a system or a computer most of the tasks are controlled by CPU (Central Processing Unit) which is the main component of a computer. The CPU itself has two main parts - Control unit (CU) and ALU. The 'CU' is used to synchronize the tasks with the help of sending the timing and control signals.

AND Hardwired Control units can be called two types of control unit. We can execute an instruction with the help of these control units.

In the Hardwired the execution of operation is much faster but the modification implementation and decoding are difficult. In contrast, in Micro-programmed these tasks are easy.

- Control Signals: The Control Signals are used to know about various types of them.  
① Control signals are used to know what operations is going to be performed.

- ② To know about the sequence of operations that are performed.
- ③ To know about the timing at which an operation must be executed and many other types of things.

### Hardwired Control Unit:

With the help of generating control signals Hardwired control unit is able to execute the instructions at a correct time and proper sequence.

The control-signals are generated with the help of circuit and state counter.

The instruction register is a large processor register used to contain an instruction going to be executed. The IR generates one op-code of instruction and addressing bits. The above generated op-Code are received in the field of instruction decoder. The instruction decoder interprets the operations & instructions.

Now on the basis of addressing mode, of the instructions and operations test which exist in the instruction register. The first Decoder sets the corresponding

instruction signals: INSI, INS2 . . .

Steps are used on each instruction, are ① Instruction Fetch, ② Decode, ③ Operand, ④ fetch, ⑤ ALU and ⑥ location.

→ The information about the current step of an instruction must be known by the control unit.

Now, the step counter is implemented which is used to contain the signals from  $T_1, T_2, \dots, T_5$ . On the basis of the step one of the signal of step counter will be set from  $T_1$  to  $T_5$  to 1.

### Micro-programmed Control Unit:

A micro-programmed control unit can be described as a simple logic circuit we can use it in a ways i.e. it is able to execute each instruction with the help of generating control signals and it is also able to do sequencing through micro-instruction. It will generate the control signals with the help of programme at the time of evaluation. This approach was very famous.

The program which is used to create the control signals is known as the micro-programmed. The processor chip which is placed on the memory. This memory is a type of fast memory. It is also known as control memory.

Each micro-instruction contains a set of micro-instruction. Each instruction contains different bit patterns. The 'n' bit words are contained in each micro-instruction. The bit pattern of a control word is basis of every control signal. These bit patterns differ from each other.

The instruction execution in a micro-programmed control unit is also performed in each steps so for each steps the micro-programmed contains a micro-instruction. If we want to execute a particular instruction. These process is known as micro-routine.

Control

Control  
Signal

Micro-instruction

n bit

1 bit

101010111000

signals

control

1100100011001M

100010010001C

0 running

0 obtain

0 busy

1001001001001P

0 ready

0 error

0 busy

0 error

Micro-programmed Control Unit Organization:

(1) Instruction fetch: It is the first step. In this step, the instruction fetch from the IR with the help of micro-instruction 'AR'

(2) Decoder: It is 2nd step. In this step the instruction is obtained from the IR will be decoded with the help of a micro-instruction address generator.

(3) Increment: It is the 3rd step. The

Value of the micro-programmed Counter will be increased so that it can execute the next micro-routine.

(4) 'End' bit is the fourth bit step.

Micro-routine contains a bit known as end bit. When instruction will be successfully complete. The end bit is set to '1'.

(5) The last step the micro-programmed address generator will again go back to step '1' so that it can fetch a new-instruction.

### Differences:

| HARDWIRED CONTROL UNIT                                                                              | Micro-programmed Control Unit                                                              |
|-----------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|
| (1) with the help of hard-wired circuit we can implement <sup>the</sup> only hardwired control unit | (1) In this approach we use programming                                                    |
| (2) HCU uses control circuit and generate the control signals which are required by the processor   | 2) It is very easy to modify                                                               |
| (3) It is very difficult to modify.                                                                 | (3) It uses micro-instructions and generates the control signals required memory for this. |
| (4) In one form of logic gates everything has to be realized in the HCU that's why its very costly  | 4) Less cost because the control unit only requires the Micro-operations                   |

5. The Complex I/S  
Cannot be handled by Hardwired Control Unit bcz when we design a Ckt it will become complex.
- (6.) Limited no. of I/S
- (7.) Used for types of computer that implement RISC (Reduced I/S Set Computer)
- (8.) It is faster

If it is able to handle the Complex I/S

Many I/S

Used for CISC (Complex I/S - Set Computer)

It is slow.

## Unit - II Part II

### # CENTRAL PROCESSING UNIT

#### General Register Organization:

A set of flip-flops forms a register.

A register is a <sup>unique</sup> high speed storage area in the CPU. They include Combinational Ckt. that implement Data Processing.

The information is always defined in a Register before processing. The Register speeds up the implementation of the Program.

There are 8 important function of the Register in the CPU operation.

- (1) It can spot a temporary storage location for data. It means it directly implemented programs to have fast access. It can save the states of the CPU and data about the directly implemented programme.



The CPU bus system is managed by the Control Unit.

The Control Unit explicit the data flow through the ALU. By choosing the function of the ALU and component of the system.

$$\text{Consider } R_1 \leftarrow R_2 + R_3$$

The following are the function implemented within the CPU.

- MUX A (SEL A) - It can replace  $R_2$  into bus A.
- MUX B (SEL B) - It can replace  $R_3$  into bus B
- ALU operation selector (opr) - It can select the Arithmetic Addition.
- Decoder destination selector - It can transfer the result into  $R_1$  (CSEL D)

The Multiplexor of 3 state gate are performed with the Bus, and the state of 14 Binary selection input determine the control word.

## # STACK ORGANISATION:

- Stack is also known as a LIFO (Last in First Out). It is the most important feature in CPU. It saves

data such that the element stored last is retrieved first. A stack is a memory unit with an address register.

This register influences the address for the stack which is known as Stack Pointer (SP).

The Stack Pointer continually influences the address of the element that is located at the top of the stack.

- It can insert an element into or delete an element from the stack. The insertion operation is known as Push-operation. And the deletion operation is known as pop-operation. In a Computer Stack. These operations are simulated by incrementing or decrementing the SP Register.

### Register Stack:

The stack can be arranged as a set of memory words or Registers.

Consider a 64 words Register Stack arranged. The SP <sup>Registers</sup> includes a binary number which is the address of the element present at the top of the stack.

A, B and C are located in the 3 Elements. The element 'C' is at the top of the stack i.e. 3. The top element is popped from the stack.

through reading memory word at address '3' and decrementing the stack pointer by '1'.



Then B is at the top of the stack and the SP holds the address of B i.e 2 if we can insert a new word. The stack is pushed by incrementing the stack pointer by 1 and inserting a word.

in that incremented locations.

The stack pointer includes 6 bits because  $2^6 = 64$ , and the SP cannot exceed.

Q3. After all if 63 is incremented by 1. Therefore the result is 30.

SP holds only the 6 LSB.

to, when the stack is full the one bit register FULL is said to 1

IF the stack is null then the one bit register empty is said to zero.

The Data Register (DR) holds the information which is composed into or created out of the stack.

First, the SP is set to 0, EMPTY is set to 1, and Full is set to 0. Now, as the stack is not Full ( $Full=0$ ), a new element is inserted using the Push operation.

The Push operation is executed as follows -

|                                                 |                                           |
|-------------------------------------------------|-------------------------------------------|
| $SP \leftarrow SP + 1$                          | It can increment stack pointer.           |
| $K[SP] \leftarrow DR$                           | It can write element on top of the stack. |
| $IF (SP = 0) \text{ then } (Full \leftarrow 1)$ | Check if stack is full.                   |
| $EMPTY \leftarrow 0$                            | Mark the stack not empty.                 |

The stack pointer is incremented by 1 and the address of the next higher word is saved in the SP.

The word from DR is inserted into the stack using memory <sup>write</sup> 1 operation.

The first element is saved at address 1 and the final element is saved at address 0.

If the SP is at 0, then the stack is 'Full' is set to 1. This is the condition.

when the SP was in location 63 and after incrementing SP, the final element is saved at address 0. During an element is saved at address 0, there are no more empty registers in the stack. The stack is full and the 'EMPTY' is set to 0.

A new element is deleted from the stack if the stack is not empty (if EMPTY=0).

The Pop operations includes the following sequence of micro-operations:

- $DR \leftarrow K[SP]$  → It can read an element from the top of the stack
- $SP \leftarrow SP - 1$  → It can determine the stack pointer
- IF  $(SP = 0)$  then  
 $(EMPTY \leftarrow 1)$  — Check if stack is empty
- $FULL \leftarrow 0$  — Mark the stack not Full

The top element from the stack is read and transferred to DR. and thus the stack pointer is decremented. If the stack pointer reaches 0, then the stack is empty and 'EMPTY' is set to 1. This is the condition when the element in location 1 is read out and the SP is decremented by 1.

## INSTRUCTION FORMAT:

- 1) Instruction includes a set of operation code and operands, that manages with the operation codes.
- Instruction Format supports the design of bits in an instruction.
- It contains fields including op code, operand and addressing mode.
- The instruction length is generally preserved in multiple of the character length, which is of 8 bits.
- When the instruction length is permanent several bits are assigned to op-code, operands and addressing mode.
- The function of allocating bits considered the following elements :-
  - (i) No. of addressing mode.
  - (ii) Number of operand.
  - (iii) Number of CPU registers.
  - (iv) Number of register sets.
  - (v) Number of address lines.
- The journal architecture of 32 bits instruction format, micro-processor includes 4 fields :-

|            |                 |                       |            |
|------------|-----------------|-----------------------|------------|
| opcode     | Addressing Mode | Displacement - offset | Immediates |
| 1080 bytes | 1080 bytes      | 1080 bytes            | 1080 bytes |

- In the addressing mode field instruction needs only 1 byte.
- The field start directly follows the address mode as the displacement field.
- If an effective address for a memory operand is computed using the displacement value then it uses 1 byte or more bytes.
- If an operand is an immediate value then it is located in the immediate field and uses 1 byte.

## ADDRESSING MODE:

- An instruction contain an operation field and address field and the mode field.
- The operation field indicates what operation is to be performed. For example; Addition, Subtraction etc.
  - The mode field indicates how the memory address of the operand which is involved in operation is determined.

### Types of Addressing Mode:

To understand the various types of Addressing Mode it is important to understand how the computer deals with instruction.

The instruction cycle of a Computer goes through the following 3 Phases :-

- (1) Fetch the instruction from the memory
- (2) Decode the instruction
- (3) Execute the instruction.

### TYPES:

- (1) Implied mode :
  - In this mode, the instruction contains an indirect definition of the operand.

For eg - CMA (Complement Accumulator)  
Operant means Complement here.

#### d. Immediate A. Mod:

In this mode one instruction contains both op code and one operand. It can be said that one instruction contains one immediate Addressing mode. Contains one number in form of an address in operand field.

Field eg  $\rightarrow$  ADD one instructions which has operation and number 10, which is in operation operand.

3. Register Mode: In this mode it specifies a register. This Register operand and example of Register mode is  $AC = AC + [R]$ . This will add the operands stored at the register R to the operand stored in the Accumulator.

#### i) Register Indirect Mode:

In this mode, one instruction specify a register. This register store effective address of some operand.

eg  $\rightarrow AC = AC + [R]$

Here the content which resides in the memory location specified by the register are will be added to the contents of the Accumulator.

**5.) Direct Addressing Mode:** In this Mode, the instruction specifies the address. This address is the address of an operand.

For eg  $\rightarrow AC = AC + [X]$ , this will add the operand store at address  $X$  with the

Operand stored in the accumulator.

- This is also known as Absolute A Mode.

#### (6.) Indirect Addressing Mode:

In this Mode the instruction specify an address of the memory location specified by the address contain the address of an Operand

eg  $\rightarrow AC = AC + [X]$

This will Add the operand store at the address specified by the memory location  $X$  with the operand of the Accumulator.

#### (7.) Auto Increment or Decrement Mode:

- In this Mode the instruction specify a register which points to a memory Address that contain the operand. After that the address is incremented or decremented as specified.

8.) Relative Address Mode: In this Mode, the contents of the Address field are constants stored in the program

Counter. The result of this Addition gives the address of the Operand.

For e.g:

Suppose the Address Field contains 850 and 'PC' contains 20 then the operand will be at memory location  $850 + 20 = 870$ .

### 8) Index Addressing Mode:

In this Mode the address of the Operand is determined by adding the Content of the Address field and the Content of index Register.

### 9) Base Register Addressing Mode:

In this Mode, the address of the Operand is determined by adding the Content of the Address Field and the Content of base register.

⇒ DATA TRANSFER AND MANIPULATION

### Data Transfer:

Computers provides an extensive set of instruction to give the user flexibility to carry out various Computational task.

The instruction set of different computer differ from each other mostly in the way, the operands are determined from Address & Mode field.

The actual operations Available in the instruction from one compiler to other.

Data transfer can be classified into 3 categories :-

- (1) Data transfer instruction
- (2) Data Manipulation
- (3) Program Controlled instruction.

#### (1) Data Transfer instruction :

Data Transfer instruction cause of data From one location to another without changing the information content.

#### (2) Data Manipulation Instruction :

These are those that perform Arithmetic, logic and shift operation.

#### (3) Program Controlled if :

- These provides decisions Making capability and change the path taken by the program when executed in the computer.

# Data Transfer operations & Methods

- 1) LOAD (LD)
- 2) STORE (ST)
- 3) MOVE (MOV)
- 4) Exchange (XCH)
- 5) INPUT (IN)
- 6) OUTPUT (OUT)
- 7) Push (PUSH)
- 8) Pop (POP)

→ Operations on Data are in above set table

⇒ Data manipulation instruction are also divided into 3 categories:-

## 1) Arithmetic IIS

- (a) → Increment (INC)
- (b) → Decrement (DEC)
- (c) → Add (ADD)
- (d) → Subtract (SUB)
- (e) → Multiply (MUL)
- (f) → Divide (DIV)
- (g) → Add with Carry (ADD)
- (h) → Subtract with Borrow (SUB)
- (i) → Negation (NEG)

## (2) Logical and Bit Manipulation Instruction

|                   |      |
|-------------------|------|
| Clear             | CLR  |
| Complement        | COM  |
| And               | AND  |
| Or                | OR   |
| Exclusive OR      | XOR  |
| Clear Carry       | CLRC |
| Set Carry         | SETC |
| Complement Carry  | COMC |
| Enable interrupt  | EI   |
| Disable interrupt | DI   |

## (3) Shift I/S

|                               |       |
|-------------------------------|-------|
| 1) Logical shift right        | SHR   |
| 2) Logical shift left         | SHL   |
| 3) Arithmetic shift right     | SHR A |
| 4) Arithmetic shift left      | SHL A |
| 5) Rotate right               | ROR   |
| 6) Rotate left                | ROL   |
| 7) Rotate right through carry | ROR C |
| 8) Rotate left through carry  | ROL C |

## (4) Programmed Control I/S.

|     |                   |      |
|-----|-------------------|------|
| (1) | Branch            | BR   |
| 2.  | Jump              | JMP  |
| 3.  | Skip              | SKP  |
| 4.  | Call              | CALL |
| 5.  | Return            | RET  |
| 6.  | Compare           | CMP  |
| 7.  | (By subtraction)  |      |
| 8.  | Test<br>( ANDing) | TST  |

Oct 15, 24

## RISC Architecture:

It means Reduced Instruction Set Computing. It is very simple and streamline execution Architectures. In this Architecture, the I/S set is designed to include a minimum set of simple and frequently used instruction.

Each instruction will perform a specific operation on a small amount of data. This approach enables faster instruction execution. As the processor can complete instructions in a few clock cycle.

## Features :-

### Features of RISC Architecture :-

- (1) Simple and Uniform Architecture. Its set with the ~~fixed~~ no. of Format.
- (2) Single cycle I/S execution.
- (3) Load Store Architecture where memory operation are limited to load and store instructions.
- (4) A large number of Registers for efficient data ~~access~~ access.
- (5.) Pipelined Execution to achieve higher throughput.

### Advantages :-

- (1). Faster execution due to simple I/S.
- (2). Efficient use of Registers.
3. Well suited for applications like multimedia processing and scientific computing.
4. Simplified hardware design facility and higher clock speed.

### Disadvantages :-

- (1) Complex operations may require more I/S to complete. More I/S may lead to larger program size.

# CISC ARCHITECTURE

It stands for Complex Instruction Set Computing Architecture.

It approach by offering a rich set of complex ILs that can perform multiple task in a single ILs.

CISC processor aims to reduce the number of instruction required to accomplish a specific task. thereby potentially reducing the overall program size and enhancing programmer productivity.

## Features:

- 1) Complex instruction capable of performing multiple operations.
- (2) A variety of addressing modes for flexible memory access.
- 3) ILs may take a more than single clock cycle to get executed.
- (4) less no. of general purpose of registers as operations get performed in memory itself.
- (5) complex addressing mode.

## ADVANTAGES:

(1) Reduce Code Size:

CISC Processor use complex I/S that can perform multiple operation reducing the amount of code needed to perform a task.

2.) More Memory Efficient:

Because CISC Instruction are more complex they require ~~more~~ fewer I/S to perform complex tasks which can result in more efficient memory.

3.) Widely used:

CISC Processors have been in use for a longer time than RISC Processors. So they have a large user and more available software.

Disadvantages:

1.) Slow Execution:

Because I/S are complex. CISC processors take a long time to execute and also more time to decode.

2.) More Complex design:

Because of complex I/S it is more difficult to design and manufacture.

(3) Higher Power Consumption:

Use more power consumption because of complex I/S set.

# CPU Performances:

Both approaches tries to increase the CPU Performance. RISC: Reduces the cycles per instruction at the cost of the no. of instruction per program.

CISC: It minimises the no. of I<sub>s</sub> per Program but at the cost of an increase in the no. of cycles per instruction.

## Difference:

### RISC

- (1) Focus on Software.
- (2) Transistors are used for more registers.
- (3) Fixed size I<sub>s</sub>.
- (4) Can perform only Register to Register Arithmetic operations.
- (5) Requires more no. of Registers.
- (6) Code size is large.
- (7) An I<sub>s</sub> Executed in a single clock cycle.
- (8) An I<sub>s</sub> Fit in 1 word.

### CISC

- (1) Focus on Hardware.
- (2) Transistors are used for storing complex I<sub>s</sub>.
- (3) Variable size I<sub>s</sub>.
- (4) Can perform Register to Register or Register to Memory or also Memory to Memory.
- (5) Less no. of Registers required.
- (6) Code size is small.
- (7) More than one clock cycle.
- (8) An I<sub>s</sub> Fit in larger than the size of 1 word.

- |                                       |                                       |
|---------------------------------------|---------------------------------------|
| (9) Simple & limited Addressing Modes | → Complex & More Addressing Modes.    |
| (10) It consumes the low Power.       | CISC consumes high Power.             |
| (11) RISC is highly pipelined         | RISC is less pipelined.               |
| (12) Used in Hardwired Control Unit   | Used in Microprogrammed Control Unit. |

Oct 21; 24

## ~~#~~ Input - Output Interface



I-O interface is used as a method which helps in transferring information b/w the memory and external hardware devices. A hardware device is that which provide I/P and O/P for the computer. It's also called I-O devices.

for e.g. → A keyboard and mouse → I/P devices  
 → Monitor and printer → O/P devices

In micro-programmed computer base system the only purpose of hardware devices is just to provide special communication links for the interfacing them with the CPU and resolve the differences b/w hardware devices and CPU.

The major differences are as follows-

① The nature of hardware devices is electromagnetic and electromechanical but the nature of CPU is electronic.

There is a lot of difference in the mode of operations of both CPU and hardware devices.

② There is also a synchronisation mechanism b/w the data transfer rate of hardware devices and CPU are different.

Hardware devices are slower than CPU.

③ In hardware devices data code and formats are differ from the format in the CPU and memory.

④ The operating mode also different of both devices. So, there is a special need of

the additional hardware to resolve the difference b/w CPU & hardware device to supervise and synchronise whole operations.

### → Functions of I-O Interface

- ① It is used to synchronise the operating speed of CPU and I-O devices.
- ② It selects the I-O devices which is appropriate for the interpretations of the I-O signals.
- ③ It is capable of providing signals like control signals.
- ④ It is used for error detection.
- ⑤ It converts serial data into parallel data and vice-versa.
- ⑥ It also converts digital data into analog and vice-versa.

### → Modes of Data transfer

The primary modes of data transfer are-

#### ① Programmed Input Output (PIO)

In PIO, the CPU actively managed the data transfer b/w itself and I-O device. The CPU checks the status of the I-O device and transfer data b/w memory and device as needed.

### Characteristics -

- ① CPU involvement in every data transfer.
- ② Inefficient for high speed devices and large data transfer.
- ③ Simple to implement.

### ② Interrupt - driven Input - Output

In this mode, the CPU initiate the I-O operation and then continues the other tasks. When the I-O operation is complete, the I-O devices generate an interrupt because the CPU suspend its current task and handle the interrupt by servicing the I-O operation.

### Characteristics -

- ① A synchronous operation
- ② Reduces the CPU involvement during <sup>ideal</sup> idle time.  
(means - CPU is free)
- ③ Efficient for devices with unpredictable or slow response time.
- ④ DMA mode

→ \* The main purpose of different modes are -

- ① Efficiency
- ② Resource utilization
- ③ Flexibility

Ques- What is the purpose of I-O interface?

Ans- To resolve the differences b/w CPU and peripheral devices. Differences occurs on the terms -

- ① Speed
- ② Signal conversion
- ③ Format
- ④ Data records

Advantage of I-O interface →

- ① Efficiency
- ② Modularity
- ③ Standardisation

Let 22/24

### Input - Output Processor

The DMA mode of data transfer reduces the CPU overhead in handling I-O operations.

It also allows parallelism in CPU and I/O operations. Such parallelism is necessary to avoid the wastage of CPU time while handling I/O devices whose speeds are

much slower as compared to CPU.

The concept of DMA operations can be extended to relieve the CPU further from getting involved with the execution of I/O operations. This gives rise to the development of special purpose processors called I/O processors or I/O channels.

The I/O processor is just like a CPU that handles the details of I/O operations by the DMA. It's more equipped with facilities than those available in a typical DMA controller.

The I/O processor can fetch and execute its own instructions that are specifically designed for I/O transfers. After it can perform other processing tasks like arithmetic, logic, branching and code translation.

Memory communicates with the processor by means of DMA. The I/O processor is specialised processor which loads and stores data in memory along with the execution of I/O instructions. It acts as an interface b/w the system and devices. It involves a sequence of events to execute I/O operations and then store the result in memory.



## Features of an I/O processor

- ① Specialized hardware
  - I/O ports
  - DMA controller
  - Interrupt controller
- ② DMA capability
  - direct communication with DMA and memory without going through CPU
- ③ Interrupt handling
  - this allows the CPU to focus on executing application programs while the I/O processor handles interrupt.

#### ④ Protocol handling

- This allows wide range of devices to interface without requiring additional software.

#### ⑤ Parallel processing

- This allows the system to handle multiple task simultaneously.

Oct 24 2020

## # Serial Communication

S.C. in Computer organisation is the process of sequentially transferring the information or bits on the same channel.

Due to this, the cost of wire will be reduced but it slows the transmission speed.

Generally, communication can be described as the process of interchanging information b/w individuals in the form of audio, video, verbal words and written documents.

The serial protocol is run on every device that can be a mobile, PC, and many more. The protocol is reliable and secure that contains a set of rules addressed with the help of a source host and a destination host.

In Serial communication, binary pulses are used to show the data. Binary contains 2 nos. 0 and 1. 0 is used to show the low volt and 1 is used to show the high volt.

It can be either synchronous or asynchronous.



### → Synchronous Communication

In this communication, the frames of data will be constructed with the help of combining the group of bits. That frame will be continuously sent in time with the master clock. It uses a synchronised clock frequency to operate the data of sender and receiver. The time taken by the sender and receiver is synced, that's why the frequency of timing error will be less and the data will be more faster. The data accuracy is totally dependent on it.

## Synchronous Communication



## Synchronous Communication

In this communication, the groups of bits will be treated as an independent unit and these data bits will be send at any point in time. In order to make synchronization b/w sender and receiver, the start bits and stop bits are used b/w the data bytes. These bits are useful to ensure that the data is correctly sent. The time taken by data bits of sender and receiver is not constant and the time b/w transmission will be provided by the gaps.

In this communication, we don't require synchronization b/w the sender and receiver which is the main advantage. This is cost effective and sometimes the transmission is done but not compulsory.

## UNIT-3



### Introduction

Arithmetic instructions in digital computer manipulate data to produce result necessary for the solution of computational problems.

These instructions perform arithmetic calculations and are responsible for the bulk of activity involved in processing data.

The 4 basic arithmetic operations are -

- ① Addition
- ③ Multiplication
- ② Subtraction
- ④ Division

These 4 basic operations formulate other arithmetic functions and solve scientific problems by means of numerical analysis method. In arithmetic instructions I may specify binary or decimal data and in each case the data may be in fixed point or floating point form.

Fixed point no. may represent integers or fractions. Negative no. maybe in signed magnitude or signed complement representation. The arithmetic processor is very simple if only a binary

fixed point add instructions is included. It would be more complicated if it includes all 4 arithmetic operations for binary and decimal data in fixed point and floating point representation.

## \* OPERATIONS

### ① ~~Addition and Subtraction~~

There are 3 ways of representing negative fixed point binary numbers.

1. Signed magnitude
2. Signed 1's complement
3. Signed 2's complement

Mostly we used 2's complement representation when performing arithmetic operations with integers.

But on floating point, most computers use the signed magnitude representation. It's important to realize that the adopted representation for negative numbers refers to the representation of no. in the registers before and after the execution of the arithmetic operation. It doesn't mean that complement arithmetic may not be used in an intermediate step.  
for eg. →

It is convenient to employ complement arithmetic when performing a subtraction

operation with no. in signed magnitude representation. As long as the initial minuend and subtrahend as well as the final difference are in signed magnitude form the fact that complements have been used in an intermediate step doesn't alter the fact that the representation is in signed magnitude.

### Addition and Subtraction with signed magnitude data

The representation of numbers in signed magnitude is familiar because we used it in arithmetic calculations. The procedure of adding or subtracting 2 signed binary no.'s is simple and straight forward. We designate the magnitude of the 2 numbers by 'A' and 'B'. When the signed no.'s are added or subtracted, there are 8 different conditions to consider, depending on the sign of the no.'s and the operation performed. These conditions are shown below in the table.

The first column shows the conditions, the other column in the table shows the actual operation to be performed with the magnitude of the no.'s. The last column is needed to prevent a negative zero, in other words when 2 equal no.'s are subtracted the result should be zero not minus zero (-0).

The algorithm for addition and subtraction are derived from the table.

## \* Addition (subtraction) Algorithm

1. When the sign of A and B are different,  
Add the two magnitudes and attach  
the sign of A to the result.
2. When the sign of A and B are different,  
compare the magnitude and subtract the  
smaller no. from the larger. Choose the  
sign of result to be the same as A,  
~~If~~ if  $A > B$  or the complement of sign of  
A if  $A < B$ .
3. The two algorithms are similar except for  
the sign comparison. If the two magnitudes  
are equal, subtract B from A and  
make the sign of the result positive.

# Introduction

It means the system achieve data processing task at the same time to increase the computational speed of a computer system.

A parallel processing system can carry out simultaneous data processing to achieve faster execution time.

for eg → while an I/O is being processed in the CPU, the next I/O can be read from the memory.

The purpose of 11<sup>th</sup> processing is to enhance the computer processing capability and increase its throughput.

The 11<sup>th</sup> processing system can be achieved by having a multiplicity of functional unit that perform identical or different operations at the same time.

The following diagram shows one possible way of operating the execution unit into eight functional units operating in parallel.



1. The adder and integer multiplier performs the arithmetic operations with integers numbers.
2. The floating point operations are separated into 3 units operating in parallel.
3. The logic shift and increment operation can be performed concurrently on different data. All units are independent so one number can be shifted while another number is being incremented.

\* There are a variety of ways that parallel processing can be classified -

It can be considered from the internal organisation of the Processors from the interconnection structure b/w the processors or from the flow of information through the system.

One classification is introduced by M. J. Flynn's considers an organisation of computer system by no. of ~~1/0~~ 1/0 and data items that are manipulating simultaneously.

The normal job of the comp. system is to fetch 1/0s from the memory & execute them in the Processor.

- \* The sequence of I/Os read from memory constitutes an I/O stream.
- \* The operation performs on the data in the processor constitutes a data stream.

Parallel Processing may occurs in the I/Os streams, in the Data stream or in both.

Flynn's classification divides computers into  
4 major groups

- 1 Single I/O stream, Single data Stream (SISD)
- 2 Single I/O stream, multiple data stream (SIMD)
- 3 Multiple I/O streams, Single data stream (MISD)
- 4 Multiple I/O stream, multiple data stream (MIMD)

### SISD

It represents the organisation of a single computer containing a control unit, a processor unit and a memory unit.

I/Os are executed sequentially and the system may or may not have internal parallel processing capabilities.

Parallel Processing in this case, maybe achieved by means of multiple functional units or by

Pipeline processing.



### 2. SIMD

It represents an organization that includes many processing units under the supervision of a common control unit. All processors receive the same I/O from the control unit but operate on different items of data.

The shared memory unit must contain multiple modules so that it can communicate with all the processors simultaneously.



### 3. MIMD

It's a system uses multi-processor machine capable of executing different I/Os on different processing elements but operating on the same data set. This model is not useful in most of applications.



(more than 1 processor)

#### 4. MIMD

- It's a system in which we use multiple I/Os on multiple data sets. Each processing element has separate I/O and data stream.
- This model is widely used for multiple applications.

#### MIMD



Flynn's classification depends on the distinction b/w the performance of the control unit and the data processing unit.

#### \* Parallel Processing

It's dividing into 3 categories

- Pipelined Processing
- Vector Processing
- Array Processing

## \* Arithmetic Pipeline (used for fast speed)

Pipelined arithmetic units are usually found in many high speed computers and used for high speed calculations. Also they are used to implement floating point operations, multiplications of fixed point nos and similar computations.

The inputs to the floating point adder pipeline are to normalized floating point binary numbers.

$$x = A \times 2^a$$

$$y = B \times 2^b$$

A and B are 2 fractions that represent the mantissas and a, b are the exponents.

The floating point add " and Sub " can be performed in 4 segments. The registers labelled 'R' placed before the segments to store intermediate results.

- The Sub - operations that are performed in the 4 - segments are
1. Compare the exponents.
  2. Align the mantissas.
  3. Add or subtract the mantissas.
  4. Normalize the result.

# - ARITHMETIC PIPELINE



store in register,  
 $x = 0.9504 \times 10^3$   
 $y = 0.8500 \times 10^2$

compare,

$$3-2=1$$

↳ 1 no. of bits shift/align

→ in register

$$0.8500$$

$$0.0850 \times 10^3$$

→ in register

add or sub,

equal expn - add"

unequal expn - sub"

cso adding,  $0.0850 + 0.9504$   
 $= 1.0354$

$$\begin{array}{r} 0.0850 \times 10^3 \\ + 0.9504 \times 10^3 \\ \hline 1.0354 \times 10^3 \end{array}$$

→ in register

normalize,

$\begin{array}{c} - \cdot - - - \\ \swarrow \searrow \end{array} \neq 0$  normalised  
 $\swarrow = 0$  not normalised

cso,

$$1.0354 \times 10^3$$

$$\Rightarrow 0.1035 \times 10^4$$

→ in register

normalised,

$$0.1035 \times 10^4$$