



# QUANTUM Series

## Sem - 3 CSE/IT & Allied Branches

### Computer Organization & Architecture



- Topic-wise coverage of entire syllabus in Question-Answer form.
- Short Questions (2 Marks)

Session  
**2023-24**  
Odd Semester

Includes solution of following AKTU Question Papers

2014-15 • 2015-16 • 2016-17 • 2017-18 • 2018-19 • 2019-20 • 2020-21 • 2021-22 • 2022-23

**PUBLISHED BY :**

**Apram Singh**  
**Quantum Page Pvt. Ltd.**

Phone : 0120 - 4160479

Email : pagequantum@gmail.com

Delhi Office : M-28, Naveen Shahdara, Delhi-110032

Plot No. 59/27, Site -4, Industrial Area,

Sahibabad, Ghaziabad 201 010

3B (CSIT-Sem-3)

© QUANTUM PAGE Pvt. LTD.

No part of this publication may be reproduced or transmitted  
in any form or by any means, without permission.

All Rights Reserved

Information contained in this work is derived from sources believed to be reliable. Every effort has been made to ensure accuracy, however neither the publisher nor the authors guarantee the accuracy or completeness of any information published herein, and neither the publisher nor the authors shall be responsible for any errors, omissions, or damages arising out of use of this information.

**KCS 302 : Computer Organization & Architecture****UNIT - 1 : INTRODUCTION**

Functional units of digital system and their interconnections, buses, bus transfer, Processor organization, general registers organization, stack organization and addressing modes.

**UNIT - 2 : ARITHMETIC & LOGIC UNIT**

Look-ahead carries adders, Multiplication: Signed operand multiplication, Booth's algorithm and array multiplier, Division and logic operations, Floating point arithmetic operation, Arithmetic & logic unit design, IEEE Standard for Floating Point Numbers.

**UNIT - 3 : CONTROL UNIT**

Instruction types, formats, instruction cycles and sub cycles (fetch and execute etc), micro operations, execution of complete instruction, Program Control, Reduced instruction Set Computer, Pipelining, Hardware and micro programmed control, micro programme sequencing, concept of horizontal and vertical macroprogramming.

**UNIT - 4 : MEMORY**

Basic concept and hierarchy, semiconductor RAM memories, 2D & 2.5D memory organization, ROM memories, Cache memories, concept and design issues & performance, address mapping and replacement, Auxiliary memories: magnetic disk, magnetic tape and optical disks, Virtual memory, concept implementation.

**UNIT - 5 : INPUT / OUTPUT**

(4-1 B to 4-30 B)  
 Peripheral devices, I/O interface, I/O ports, Interrupts, interrupt hardware, types of interrupts and exceptions, Modes of Data Transfer, Programmed I/O, interrupt initiated I/O and Direct Memory Access, I/O channels and processors, Serial Communication: Synchronous & asynchronous communication, standard communication interfaces.

**SHORT QUESTIONS**

(SQ-1 B to SQ-17 B)

**SOLVED PAPERS (2014-15 TO 2022-23)**

(SP-1 B to SP-64 B)

**Price: Rs. 125/- only**

卷之三

卷之三

## Introduction

## CONTENTS

- Part-1 :** Introduction : Functional Units of Digital System and their Interconnection 1-2B to 1-5B

**Part-2 :** Bus, Bus Architecture, ..... 1-5B to 1-6B  
Types of Buses

- |               |                                        |                |
|---------------|----------------------------------------|----------------|
| <b>Part-3</b> | : Bus Arbitration .....                | 1-6B to 1-8B   |
| <b>Part-4</b> | : Register, Bus and<br>Memory Transfer |                |
| <b>Part-5</b> | : Processor Organization, .....        | 1-11B to 1-12B |
|               | General Register Organization          |                |
| <b>Part-6</b> | : Stack Organization .....             | 1-13B to 1-17B |
| <b>Part-7</b> | : Addressing Modes .....               | 1-17B to 1-22B |

1-2 B (CSIT-Sem-3)

Introduction

HART-1

## *Introduction : Functional Units of Digital System and their Interconnection.*

Questions-Answers

**Que 1.1.** Draw a block diagram of a computer's CPU showing all the basic building blocks such as program counter, accumulator, address and data registers, instruction register, control unit etc., and describe how such an arrangement can work as a computer, if connected properly to memory, input/output etc.

AKTU 2016-17, Marks 7.5



Fig. 1.1.1

A computer performs five major operations. These are:

- It accepts data or instructions as input.
  - It stores data and instruction.
  - It processes data as per the instructions.
  - It controls all operations inside a computer
  - It gives results in the form of output.

**Arrangement of CPU, memory, input/output to work as a computer:**



Fig. 1.1.2.

- a. **Input unit :** This unit is used for entering data and programs into the computer system by the user for processing.

- b. **Storage unit :** The storage unit is used for storing data and instructions before and after processing.

- c. **Output unit :** The output unit is used for storing the result as output produced by the computer after processing.

- d. **Processing unit :** The task of performing operations like arithmetic and logical operations is called processing.

The Central Processing Unit (CPU) takes data and instructions from the storage unit and makes all sorts of calculations based on the instructions given and the type of data provided. It is then sent back to the storage unit.

**Que 1.2.** Explain the functional units of digital system and their interconnections.

**Answer**

The main functional units of a digital computer are shown in Fig. 1.2.1.

1. **Central Processing Unit (CPU):**
  - a. The CPU is the brain of a computer system.
  - b. This unit takes the data from the input devices and processes it according to the set of instructions called program.
  - c. The output of processing of the data is directed to the output devices for use in the outside world.
  - d. CPU has two major parts called ALU and Control Unit.



Fig. 1.2.1. Functional unit of digital computer.

i. **Arithmetic Logic Unit (ALU) :**

- a. ALU is responsible for carrying out following operations :

1. Arithmetic operations on data by adding, subtracting, multiplying and dividing one set with another.

2. Logical operations by using AND, OR, NOT and exclusive-OR operation which is done by analyzing and evaluating data.

- b. ALU of a computer system is the place where actual execution of instructions takes place during processing operation.

ii. **Control Unit (CU) :**

- a. This unit is mainly used for generating the electronic control signals for the synchronization of various operations.

- b. All the related functions for program execution such as memory read, memory write, I/O read, I/O write, execution of instruction, are synchronized through the control signal generated by the control unit.

- c. It manages and controls all the operations of the computer.

- c. It manages and controls all the operations of the computer.
- a. It accepts (or reads) instructions and data from outside world.
- b. It converts these instructions and data in computer acceptable form.
- c. It supplies the converted instructions and data to computer system for further processing.

- 3. Output unit :** An output unit performs following functions :
- It accepts the results produced by a computer, which are in coded form.
  - It converts these coded results to human acceptable (readable) form.
  - It supplies the converted results to outside world.

- 4. Storage unit :** A storage unit holds (stores) :
- Data and instructions required for processing (received from input devices).
  - Intermediate results of processing.
  - Results for output, before they are released to an output device.

## PART-2

### Bus, Bus Architecture, Types of Buses.

#### Questions-Answers

#### Long Answer Type and Medium Answer Type Questions

**Que 1.3.** What is a bus in digital system ? Also explain its types.

#### Answer

- A bus is a group of wires connecting two or more devices and providing a path to perform communication.
- A bus that connects major computer components/modules (CPU, Memory, I/O) is called a system bus.
- These system buses are separated into three functional groups :
  - Data bus :**
    - The data bus lines are bidirectional.
    - The data bus consists of 8, 16, 32 or more parallel lines.
  - Address bus :**
    - It is a unidirectional bus.
    - The address bus consists of 16, 20, 24 or more parallel lines. The CPU sends out the address of the memory location or I/O port that is to be written or read by using address bus.
  - Control bus :**
    - Control lines regulate the activity on the bus.



Fig. 1.4.1. Architecture of a single shared bus.

- The principle use of the system bus is high-speed data transfer between the CPU and memory.
- Most I/O devices are slower than the CPU or the memory. The I/O devices are attached to the system bus through external interfaces.
- The Input/Output (I/O) ports are used to connect various devices to the computer and hence, enable communication between the device and the computer.

## PART-3

### Bus Arbitration.

#### Questions-Answers

#### Long Answer Type and Medium Answer Type Questions

- Que 1.4.** Describe the architecture of bus.
- Answer**
- The computer bus consists of two parts, the address bus and a data bus. The data bus transfers actual data, whereas the address bus transfers address or memory location of where the data should go.
  - The bus provides physical links and the means of controlling the communication exchange of signals over the bus. Fig. 1.4.1 depicts the organization of a single shared bus.

- The CPU sends signals on the control bus to enable the outputs of addressed memory device or port device.

**Que 1.5.** Discuss the bus arbitration.  
OR  
Write a short note on bus arbitration.

**AKTU 2014-15, Marks 05**

**Answer**

- Bus arbitration is a mechanism which decides the selection of current master to access bus.
- Among several masters and slave units that are connected to a shared bus, it may happen that more than one master or slave units will request access to the bus at the same time.
- In such situation, bus access is given to the master having highest priority.

Three different mechanisms are commonly used for this :

- Daisy chaining :**
  - Daisy chaining method is cheaper and simple method.
  - All master make use of the same line for bus request.
  - The bus grant signal serially propagates through each master until it encounters the first one that is requesting.
- Parallel arbitration :** The parallel arbitration consists of priority encoder and a decoder. In this mechanism, each bus arbiter has a bus request output line and input line.
- Independent priority :** In this each master has separate pair of bus request and bus grant lines and each pair has a priority assigned to it.

**Que 1.6.** Discuss the advantages and disadvantages of polling and daisy chaining bus arbitration schemes.

**AKTU 2015-16, Marks 10**

**OR**  
Explain daisy changing method. Write its advantages and disadvantages.

**Answer**

**Daisy chaining :**

- In this, all masters make use of the same line for bus request.
- The bus grant signal serially propagates through each master until it encounters the first one that is requesting access to the bus.
- This master blocks the propagation of the bus grant signal, activates the busy line and gains control of the bus.
- Therefore any other requesting module will not receive the grant signal and hence cannot get the bus access.



**Fig. 1.6.1. Daisy chaining method**

**Advantages of daisy chaining :**

- It is a simple and cheaper method.
- It requires the least number of lines and this number is independent of the number of masters in the system.

**Disadvantages of daisy chaining :**

- The propagation time delay of bus grant signal is proportional to the number of masters in the system. This makes arbitration time slow and hence limits the number of master in the system.
- The priority of the master is fixed by the physical location of master.
- Failure of any one master causes the whole system to fail.

**Advantages of polling bus arbitration :**

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

**Disadvantages of polling bus arbitration :**

- It requires more bus request and grant signals ( $2 \times n$  signals for  $n$  modules).
- Polling overhead can consume a lot of CPU time.

**PART-4**

**Register, Bus and Memory Transfer**

**Questions-Answers**

**Long Answer Type and Medium Answer Type Questions**



**Computer Organization & Architecture**

**1-12 B (CS/IT-Sem-3)**

**Introduction**

2. It allows compatibility and provides ease of operation and high bandwidth.

**Disadvantages of single shared bus are :**

1. The main disadvantage of the shared bus is that its throughput limits the performance boundary for the entire multiprocessor system. This is because at any time only one memory access is granted, likely causing some processors to remain idle. To increase performance by reducing the memory access traffic, a cache memory is often assigned to each processor.
2. Another disadvantage of the shared bus design is that, if the bus fails, no processor will be able to access memory.

**Que 1.10.** What is the benefit of using multiple bus architecture compared to a single bus architecture ?

**Answer**

Following are the benefits of using multiple bus architecture compared to single bus architecture :

1. Single bus have long control sequence because only the data item can be transferred over the bus in a clock cycle.
2. To reduce the number of steps needed, most commercial processor provides multiple internal paths using multiple buses.
3. The introduction of incrementer unit eliminates the need to add port to the PC using the main ALU.
4. By providing more paths for data transfer, a significant reduction in the number of clock cycles needed to execute an instruction is achieved.

## PART-5

### Processor Organization, General Register Organization:

#### Questions-Answers

##### Long Answer Type and Medium Answer Type Questions

**Que 1.11.** Explain general-purpose register based organization.

**Answer**

1. In this organization, the registers communicate with each other not only for direct data transfers, but also while performing various micro-operations.



**Fig 1.11.1. General-purpose register based organization.**

2. Seven registers are used for general purpose, the output of each register is connected to two multiplexer (MUX) inputs.
3. Three select lines are used to select any one of the seven registers and the contents of selected registers are supplied to the inputs of ALU.
4. The buses A and B are used to form the inputs to the common arithmetic logic unit (ALU).
5. The operation to be performed is selected in the ALU and is determined by the arithmetic or logic micro-operation by using function select lines (OPR).
6. The result of the micro-operation is available as output data and also goes into the inputs of all the registers.
7. Any one of the destination register receives the information from the output bus which is selected by a decoder.

**1-14 B (CSIT-Sem-3)**
**PART-6**  
**Stack Organization.**
**Questions-Answers**
**Long Answer Type and Medium Answer Type Questions**

**Que 1.12.** What is stack? Give the organization of register stack with all necessary elements and explain the working of push and pop operations.

**AKTU 2016-17, Marks 15**

**Answer**  
1. A stack is an ordered set of elements in which only one element can be accessed at a time.

2. The point of access is called the top of the stack.

3. The number of elements in the stack or length of the stack is variable.

4. Items may only be added or deleted from the top of the stack.

5. A stack is also known as a pushdown list or a Last-In-First-Out (LIFO) list.

**Organization of register stack :**  
Consider the organization of a 64-word register stack as illustrated in Fig. 1.12.1.



**Fig. 1.12.1. Block diagram of 64-word stack.**

**Answer**  
**Memory stack:** Memory stack is a series of memory spaces that is used in the processes that is done by processor and is temporarily stored in registers.  
**Role in managing subroutines :**

1. The stack supports program execution by maintaining automatic process-state data.
2. If the main routine of a program, for example, invokes function  $a()$ , which in turn invokes function  $b()$ , function  $b()$  will eventually return control to function  $a()$ , which in turn will return control to the  $main()$  function as shown in Fig. 1.13.1.
3. To return control to the proper location, the sequence of return addresses must be stored.
4. A stack is well suited for maintaining this information because it is a dynamic data structure that can support any level of nesting within memory constraints.

**Working of POP and PUSH:**  
**POP (Performed if stack is not empty i.e., if  $EMPTY = 0$ ):**

```

SP ← SP - 1           Read item from the top of stack
If (SP = 0) then (EMPTY ← 1)   Decrement stack pointer
FULL ← 0               Check if stack is empty

```

**PUSH (Performed if stack is not full i.e., if  $FULL = 0$ ):**

```

SP ← SP + 1           Increment stack pointer
MSP[ ] ← DR           Mark the stack not full
If (SP = 0) then (FULL ← 1)   Write item on top of the stack
EMPTY ← 0             Check if stack is full
Mark the stack not empty

```

**Que 1.13.** What is a memory stack? Explain its role in managing subroutines with the help of neat diagrams.

**AKTU 2016-17, Marks 15**

### 1-15 B (CSIT-Sem-3)

#### Comparison between register stack and memory stack :

- Fig. 1.13.1. Stack management.**
1. main () {
  2.     a ();
  3. }
  4. }
  5. When a subroutine is called, the address of the next instruction to execute in the calling routine is pushed onto the stack.
  6. When the subroutine returns, this return address is popped from the stack, and program execution jumps to the specified location as shown in Fig. 1.13.2.

**Fig. 1.13.2. Calling a subroutine.**

7. The information maintained in the stack reflects the execution state of the process at any given instant.
8. In addition to the return address, the stack is used to store the arguments to the subroutine as well as local (or automatic) variables.
9. Information pushed onto the stack as a result of a function call is called a frame. The address of the current frame is stored in the frame or base pointer register.
10. When a subroutine is called, the frame pointer for the calling routine is also pushed onto the stack so that it can be restored when the subroutine exits.

**Que 1.14.** What is the stack organization ? Compare register stack and memory stack.

**Answer**

Stack organization : Refer Q.1.12, Page 1-13B, Unit-1.

| S.No. | Register stack                                                                                    | Memory stack                                                                                                                                     |
|-------|---------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 1.    | Register stacks are momentary spaces for internal processes that are being done by the processor. | Memory stacks are a series of memory spaces that is used in the processes that is done by the processor and are temporarily stored in registers. |
| 2.    | Register stack is generally on (CPU).                                                             | Memory stack is on RAM.                                                                                                                          |
| 3.    | Access to register stack is faster.                                                               | Access to memory stack is slower.                                                                                                                |
| 4.    | It is limited in size.                                                                            | It is large in size.                                                                                                                             |

**Que 1.15.** Explain an accumulator based central processing unit organization with block diagram.

**Answer**

**Fig. 1.15.1. Block diagram of accumulator based CPU organization.**

1. ALU : A most generic computer system is composed of a unit to do arithmetic, shift, and logical micro-operations commonly known as ALU of CPU.
2. Program Counter (PC) : This keeps track of the instruction address in memory from where the next instruction needs to be fetched. The instructions are stored in memory in an order decided by programmer.
3. General purpose registers (R1, R2, R3) : It suggests that the registers are involved in operations like load inputs, store intermediate results of arithmetic, logical and shift micro-operations. The initial inputs are loaded into registers from memory and final results are later moved into memory.

- 4.** Accumulator (ACC) : This block acts as the default temporary storage register location for all mathematical operations in ALU.
- 5.** Instruction Register IR and Decoder : After instruction is fetched from the memory its stored in Instruction Register. The instruction is then decode by the decoder.

- 6.** Stack pointer (SP) : Stack pointer is involved in managing the stack transfers during and program execution.
- 7.** Timing and control unit : This block manages the sequencing of events on a timeline between various components of a CPU. All the blocks are controlled in a manner to optimize the computational power of the unit by minimizing the failures.
- 8.** Flags : Flags are also registers or bits inside registers which are set or cleared for a particular condition on an arithmetic operation. Some of the most common flags are :
- Sign : Is used to identify the set/reset of most significant bit of the result.
  - Carry : Is used to identify a carry during addition, or borrow during subtraction/comparison.
  - Parity : Set if the parity is even. Refer parity from here.
  - Zero : To identify when the result is equal to zero.
- 9.** Bus sub-system : All the data transfers in-between memory and CPU registers including instruction fetches are carried over bus.

**Que 1.16.** Explain various types of processor organization.

**AKTU 2015-16, Marks 10**

**Answer**

Types of processor organizations :

- General-purpose register based : Refer Q. 1.11, Page 1-11B, Unit-1.
- Stack based : Refer Q. 1.12, Page 1-13B, Unit-1.
- Accumulator based : Refer Q. 1.15, Page 1-16B, Unit-1.

**PART-7**

Addressing Modes.

**Questions-Answers**

**Long Answer Type and Medium Answer Type Questions**

**Que 1.17.** Write short note on relative addressing mode and indirect addressing mode.

OR



Fig. 1.17.1. Direct.

**1-18 B (CSIT-Sem-3)**

Introduction

Explain the following addressing modes with the help of an example each:

- Direct
- Indirect
- Register indirect
- Immediate

**AKTU 2014-15, Marks 10**

**Answer**

i. Direct :

A very simple form of addressing is direct addressing, in which the address field contain the effective address of the operand :  $EA = A$  where,  $EA =$  Actual (effective) address of the location containing the referenced operand.

$A =$  Contents of the address field in the instruction.



Fig. 1.17.1. Direct.

- ii. A direct address in instruction needs two reference to memory :
- Read instruction
  - Read operand

**Displacement addressing :**

- A very powerful mode of addressing combines the capabilities of direct addressing and register indirect addressing.
- It is known by a variety of names depending upon the content of its use but the basic mechanism is the same.
- Displacement addressing requires that the instruction have two address fields, at least one of which is explicit.
- The value contained in one address field (value = A) is used directly.
- The other address field or an implicit reference based on opcode, refers to a register whose contents are added to A to produce the effective address.

Computer Organization & Architecture

**iii. Relative addressing:** means that the next instruction to be carried out is an offset number of locations away, relative to the address of the current instruction.

1. Relative addressing means that the next instruction to be carried out is an offset number of locations away, relative to the address of the current instruction.
2. Consider this bit of pseudo-code  
Jump + 3 if accumulator is NOT = 2  
Code executed if unconditional relative jump to avoid the next line of code)
3. In the code, the first line of code is checking to see if the accumulator has the value of 2 then the next instruction is 3 lines away.
4. This is called a conditional jump and it is making use of relative addressing.

**iv. Register indirect mode:** is similar to indirect addressing.  
Register indirect mode is similar to indirect addressing.

1. Register indirect mode is similar to indirect addressing.
2. The only difference is whether the address field refers to a memory location or a register.
3. Thus, for register indirect address,  $EA = (R)$



**Fig. 1.17.3. Register indirect.**

**v. Implied mode:** In this mode, the operands are specified implicitly in the definition of the instruction.

1. All register reference instructions that use an accumulator are implied mode instructions.
2. Zero address instructions in a stack-organized computer are implied mode instructions since the operands are implied to be on top of the stack. It is also known as stack addressing mode.



**Fig. 1.17.4. Implied mode.**

**vi. Immediate mode:**

1. In this mode, the operand is specified in the instruction itself.
2. The operand field contains the actual operand to be used in conjunction with the operation specified in the instruction.

**vii. Indexed:** The effective address of the operand is generated by adding a constant value to the contents of a register.

1. The register used may be either a special register for this purpose or more commonly, it may be any one of a set of general purpose registers in the CPU.
2. It is referred to as an index register. We indicate the index mode symbolically as,  $X(R)$
3. The effective address of the operand is given by  $EA = X + [R]$
4. In the process of generating the effective address, the contents of the index register are not changed.



**Fig. 1.17.6. Indexed**

**Example :**

| PC = 200 | 200 | Load to AC       | Mode |
|----------|-----|------------------|------|
| R1 = 400 | 201 | Address = 500    |      |
| XR = 100 | 202 | Next instruction |      |
| AC       | 399 | 450              |      |
|          | 400 | 700              |      |
|          | 500 | 800              |      |
|          | 600 | 900              |      |
|          | 702 | 325              |      |
|          | 800 | 300              |      |



**Fig. 1.17.7.**

| Addressing Mode   | Effective Address | Content of AC |
|-------------------|-------------------|---------------|
| Direct address    | 500               | 800           |
| Immediate operand | 201               | 500           |
| Indirect address  | 800               | 300           |
| Indexed address   | 600               | 900           |
| Implied           | -                 | 400           |
| Register indirect | 400               | 700           |

**Que 1.18.** What is difference between implied and immediate addressing modes ? Explain with an example.

**Answer**

| S.No. | Implied addressing mode                                                 | Immediate addressing mode                                                     |
|-------|-------------------------------------------------------------------------|-------------------------------------------------------------------------------|
| 1.    | No operand is specified in the instruction.                             | Operand is specified in the instruction itself.                               |
| 2.    | The operands are specified implicitly in the definition of instruction. | The operands are contained in an operands field rather than an address field. |
| 3.    | This mode is used in all register reference instructions.               | This mode is very useful for initializing the registers to a constant value.  |
| 4.    | Example : The instruction "Complement Accumulator" written as : CMA.    | Example : The instruction : MVI 06 ADD 05                                     |

**Que 1.19.** Describe auto increment and auto decrement addressing modes with proper example ?

**Answer**

**Auto increment mode :**

- In this mode the Effective Address (EA) of the operand is the content of a register specified in the instruction.
- After accessing the operands, the contents of this register are incremented to point to the next item in the list.

Example : Add (R2) +, R0

Here the contents of R2 are first used as an EA then these are incremented.

**Auto decrement mode :**

- In this mode the contents of a register specified in the instruction are decremented.

**Example :** Add -(R2), R0

Here the contents of R2 are first decremented and then used as an EA for the operand which is added to the content of R0.

**Que 1.20.** How addressing mode is significant for referring memory ? List and explain different types of addressing modes.

**Answer**

- The addressing mode is significant for referring memory as it is a code that tells the control unit how to obtain the Effective Address (EA) from the displacement.

2. Addressing mode is a rule of calculation, or a function that uses displacement as its main argument and other hardware component as (such as PC, registers and memory locations) as secondary arguments and produce the EA as a result.  
**Types of addressing modes :** Refer Q. 1.17, Page 1-17B, Unit-1.

### VERY IMPORTANT QUESTIONS

*Following questions are very important. These questions may be asked in your SESSIONALS as well as UNIVERSITY EXAMINATION.*

**Q.1.** Draw a block diagram of a computer's CPU showing all the basic building blocks such as program counter, accumulator, address and data registers, instruction register, control unit etc., and describe how such an arrangement can work as a computer, if connected properly to memory, input/output etc.

Ans: Refer Q. 1.1.

**Q.2.** Write a short note on bus arbitration.

Ans: Refer Q. 1.5.

**Q.3.** Discuss the advantages and disadvantages of polling and daisy chaining bus arbitration schemes.

Ans: Refer Q. 1.6.

Computer Organization & Architecture  
Computer Organization & Architecture  
Computer Organization & Architecture  
Computer Organization & Architecture

Q. 4. Explain the operation of three state bus buffers and show its use in design of common bus.

Ans Refer Q. 1.8.

Q. 5. What is stack ? Give the organization of register stack with all necessary elements and explain the working of push and pop operations.

Ans Refer Q. 1.12.

Q. 6. What is a memory stack ? Explain its role in managing subroutines with the help of neat diagrams.

Ans Refer Q. 1.13.

Q. 7. Explain various types of processor organization.

Ans Refer Q. 1.16.

Q. 8. Explain the following addressing modes with the help of an example each :

- i. Direct
- ii. Register indirect
- iii. Implied
- iv. Immediate
- v. Indexed

Ans Refer Q. 1.17.

Q. 9. How addressing mode is significant for referring memory ? List and explain different types of addressing modes.

Ans Refer Q. 1.20.



## UNIT 2

### Arithmetic and Logic Unit

#### CONTENTS

|          |                                                                                        |                |
|----------|----------------------------------------------------------------------------------------|----------------|
| Part-1 : | Arithmetic and Logic Unit : Look Ahead Carries Adders                                  | 2-2B to 2-4B   |
| Part-2 : | Multiplication : Signed Operand Multiplication, Booth's Algorithm and Array Multiplier | 2-4B to 2-1B   |
| Part-3 : | Division and Logic Operations                                                          | 2-11B to 2-16B |
| Part-4 : | Floating Point Arithmetic .....<br>Operations, Arithmetic & Logic Unit Design          | 2-16B to 2-21B |
| Part-5 : | IEEE Standard for Floating Point Numbers                                               | 2-21B to 2-24B |



### 2-4 B (CSTT-Sem-3)

### Computer Organization & Architecture

### 2-5 B (CSTT-Sem-3)



Fig. 2.2.2. Logic diagram of carry look ahead generator.

### PART-2

**Multiplication : Signed Operand Multiplication, Booth's Algorithm and Array Multipliers.**



Fig. 2.3.1. 2's Complement multiplication.

**Example :** Both negative ( $-5 \times -4$ )

**Fig. 2.3.2. Flowchart for signed operand multiplication.**

**Algorithm :** Both negative ( $-5 \times -4$ )

**Que 2.3.** Explain the Booth's algorithm in depth with the help of flowchart. Give an example for multiplication using Booth's algorithm.

**AKTU 2016-17, Marks 15**

| Multiplicand (B) $\leftarrow 1011(-5)$ | Multipplier (Q) $\leftarrow 1100(-4)$ |
|----------------------------------------|---------------------------------------|
| A                                      | $Q_n$                                 |
| 0000                                   | 1100                                  |
| 0000                                   | 0110                                  |
| 0000                                   | 0011                                  |
| 0101                                   | 0011                                  |
| 0010                                   | 1001                                  |
| 0001                                   | 0100                                  |

| Multiplicand (B) $\leftarrow 1011(-5)$ | Multipplier (Q) $\leftarrow 1100(-4)$ |
|----------------------------------------|---------------------------------------|
| A                                      | $Q_n$                                 |
| 0000                                   | 1100                                  |
| 0000                                   | 0110                                  |
| 0000                                   | 0011                                  |
| 0101                                   | 0011                                  |
| 0010                                   | 1001                                  |
| 0001                                   | 0100                                  |

| Multiplicand (B) $\leftarrow 1011(-5)$ | Multipplier (Q) $\leftarrow 1100(-4)$ |
|----------------------------------------|---------------------------------------|
| A                                      | $Q_{n+1}$                             |
| 0000                                   | 0                                     |
| 0000                                   | 0                                     |
| 0000                                   | 0                                     |
| 0101                                   | 0                                     |
| 0010                                   | 1                                     |
| 0001                                   | 1                                     |

| Multiplicand (B) $\leftarrow 1011(-5)$ | Multipplier (Q) $\leftarrow 1100(-4)$ |
|----------------------------------------|---------------------------------------|
| A                                      | Operation                             |
| 0000                                   | Initial                               |
| 0000                                   | Shift right                           |
| 0000                                   | Shift right                           |
| 0101                                   | $A \leftarrow A - B$                  |
| 0010                                   | Shift right                           |
| 0001                                   | Shift right                           |

| Multiplicand (B) $\leftarrow 1011(-5)$ | Multipplier (Q) $\leftarrow 1100(-4)$ |
|----------------------------------------|---------------------------------------|
| CR                                     |                                       |
| 4                                      |                                       |
| 3                                      |                                       |
| 2                                      |                                       |
| 1                                      |                                       |
| 0                                      |                                       |

**Discuss the Booth's algorithm for 2's complement number. Also illustrate it with the some example.**

**OR**

**Explain Booth's multiplication algorithm in detail.**

**Answer**

The algorithm for 2's complement multiplication is as follows :

|          |      |       |        |
|----------|------|-------|--------|
| Result : | 0001 | .0100 | = + 20 |
|----------|------|-------|--------|

**2-6 B (CST11T-Sem-3)**  
Explain Booth's algorithm with its hardware implementation.

**Answer**

Fig. 2.4.1 shows the hardware implementation for Booth's algorithm.

1. Fig. 2.4.1 is similar to the circuit for positive number multiplication.
2. The circuit is an  $n$ -bit adder, control logic and four register  $A$ ,  $B$ ,  $Q$  and  $Q_{-1}$ .
3. It consists of an  $n$ -bit adder, control logic and four register  $A$ ,  $B$ ,  $Q$  and  $Q_{-1}$ .



**Fig. 2.4.1. Hardware implementation of signed binary multiplication for Booth's algorithm.**

4. Multiplier and multiplicand are loaded into register  $Q$  and register  $B$  respectively.
5. Register  $A$  and  $Q_{-1}$  and initially set to 0.
6. The  $n$ -bit adder performs addition. Input of adders comes from multiplicand and content of register  $A$ .
7. In case of addition,  $\overline{Add/Sub}$  line is 0, therefore,  $C_{in} = 0$  and multiplicand is directly applied as a second input to the  $n$ -bit adder.
8. In case of subtraction,  $\overline{Add/Sub}$  line is 1, therefore  $C_{in} = 1$  and multiplicand is complemented and then applied to the  $n$ -bit adder. As a result, the 2's complement of the multiplicand is added to the content of register  $A$ .
9. The control logic scans bit  $Q_0$  and  $Q_{-1}$  one at a time and generates the control signals to perform the corresponding function.
10. If the two bits are same ( $1 - 1$  or  $0 - 0$ ), then all the bits of  $A$ ,  $Q$  and  $Q_{-1}$  register are shifted to right 1 bit without addition or subtraction ( $Add/Subtract\ Enable = 0$ ).

**Computer Organization & Architecture**      **2-7 B (CST11T-Sem-3)**

11. If the two bits differ, then the multiplicand is added to or subtracted from the  $A$  register, depending on the status of bits.
12. After addition or subtraction right shift occurs such that the left most bit of  $A$  ( $A_{n-1}$ ) is not only shifted into  $A_{n-2}$  but also remains in  $A_{n-1}$ .
13. This is required to preserve the sign of the number in  $A$  and  $Q$ .

- Que 2.5.** Draw the data path of 2's compliment multiplier. Give also illustrate the algorithm for 2's compliment fraction by a suitable example.

**Answer**

Data path of 2's compliment multiplier : Refer Q. 2.3, Page 2-4B, Unit-2.

**Robertson algorithm :**

1.  $A \leftarrow 0$ ,  $B \leftarrow$  Multiplicand  $Q \leftarrow$  Multiplier and count  $\leftarrow n$ .
2. If  $Q_0 = 1$  then perform  $A \leftarrow A + B$ ,
3. Shift right register  $F.A.Q$  by 1 bit  $F \leftarrow B[n-1]$  AND  $Q[0] = 0$  OR  $F$  and count  $\leftarrow$  count - 1.
4. If count  $> 1$  Repeat steps 2 and 3, otherwise if  $Q_0 = 1$  then perform  $A \leftarrow A - B$  and set  $Q[0] = 0$ .

For example : We perform the multiplication of fraction as :

Multiplicand = 0.625

Multiplier = 0.5

Equivalent binary representation 0.625 = 0101

2's complement representation  $-0.625 = 1010 + 1 (-0.625) = 1011$

Equivalent binary representation  $+0.5 = 0100$   
2 complement representation  $-0.5 = 1011 + 1 - 0.5 = 1100$



**AKTU 2017-18, Marks 07**

2-8B (CSIT-Sem-3) Show step by step the multiplication process using Booth's algorithm when (+ 15) and (- 13) numbers are multiplied.

Que 2.6. Show step by step the multiplication process using Booth's algorithm when (+ 15) and (- 13) numbers are multiplied.

AKTU 2014-15, Marks 10

**Answer**

$15 = 01111$   
 $-13 = 2^5 \text{ complement of } 13 = 10011$ , Multiplier = 10011

Multiplicand ( $M$ ) = 01111

| A                                                  | $Q_n$ | $Q_{n+1}$ | Operation            | SC      |
|----------------------------------------------------|-------|-----------|----------------------|---------|
| 00000                                              | 10011 | 0         | $A \leftarrow A - M$ | 101 (5) |
| 10001                                              | 10011 | 0         | $A \leftarrow A - M$ |         |
| 11000                                              | 11001 | 1         | Shift                | 100 (4) |
| 11100                                              | 01100 | 1         | $A \leftarrow A + M$ | 011 (3) |
| 01011                                              | 01100 | 0         | Shift                | 010 (2) |
| 00101                                              | 10110 | 0         | Shift                | 001 (1) |
| 00010                                              | 11011 | 0         | $A \leftarrow A - M$ |         |
| 10011                                              | 11011 | 1         | Shift                | 000 (0) |
| 11001                                              | 11101 | 1         | $A \leftarrow A + M$ |         |
| Result = (11001) $= -195$ (2's complement of +195) |       |           |                      |         |

Que 2.7. Show the contents of the registers E, A, Q, SC during the process of multiplication of two binary numbers 11111 (multiplicand) 10101 (multiplier). The signs are not included.

AKTU 2016-17, Marks 10

**Answer**

| Multiplicand B = 11111                             | E | A     | Q     | SC  |
|----------------------------------------------------|---|-------|-------|-----|
|                                                    | 0 | 00000 | 10101 | 101 |
| $Q_n = 1$ ; add B                                  |   | 00000 | 11111 |     |
| Shift right EAQ                                    | 0 | 01111 | 11010 | 100 |
| Shift right EAQ                                    | 0 | 00000 | 01101 | 011 |
| $Q_n = 0$ ; shift right EAQ                        | 0 | 00000 | 00110 | 010 |
| $Q_n = 0$ ; shift right EAQ                        | 0 | 00000 | 00011 | 001 |
|                                                    |   | 00001 | 00000 |     |
| Result = (11001) $= -195$ (2's complement of +195) |   |       |       |     |

Que 2.8. Show the multiplication process using Booth's algorithm when the following numbers are multiplied: (-13) by (+8)

AKTU 2015-16, Marks 7.5

**Answer**

True binary equivalent of +8 = 01000  
 1's complement of +13 = 01101  
 $2^5 \text{ complement of } +13 = \frac{+1}{-1} (-13)$

Multiplier = 01000

Multiplicand ( $B$ ) = 10011

| A                                                  | $Q_n$ | $Q_{n+1}$ | Operation                         | SC  |
|----------------------------------------------------|-------|-----------|-----------------------------------|-----|
| 00000                                              | 01000 | 0         |                                   |     |
| 00000                                              | 00100 | 0         |                                   | 100 |
| 00000                                              | 00010 | 0         | $\text{Ashr } AQQ_{n+1}$          |     |
| 00000                                              | 00001 | 0         | $\text{Ashr } AQQ_{n+1}$          | 011 |
| 01101                                              | 00001 | 0         | $\text{Add } B + 1 \text{ to } A$ | 010 |
| 00110                                              | 10000 | 1         | $\text{Ashr } AQQ_{n+1}$          | 001 |
| 11001                                              | 10000 | 1         | $\text{Add } B \text{ to } A$     |     |
| 11100                                              | 11000 | 0         | $\text{Ashr } AQQ_{n+1}$          | 000 |
| Result : 11100 $= 104$ (2's complement of (+ 104)) |       |           |                                   |     |

Que 2.9. Draw the flowchart of Booth's algorithm for multiplication and show the multiplication process using Booth's algorithm for  $(-7) \times (+3)$ .

AKTU 2018-19, Marks 07

**Answer**

Flowchart of Booth's algorithm for multiplication : Refer Q. 2.3, Page 2-4B, Unit-2.

Multiplication : Multiply  $(-7) \times (+3)$   
 Convert  $(-7)$  into 2's complement form :

1's complement of (+7)  $= 0111$   
 adding 1  $+7 = 0111$   
 2's complement of (+7)  $= 1000$

$(+3) = 0011$

| 2-10B (CSIT-Sem-3) |                  |                                                          |
|--------------------|------------------|----------------------------------------------------------|
| A                  | Q <sub>n+1</sub> | B = 1001<br>B + 1 = 0111<br>initial values<br>SC         |
| 0000               | 0011             | 0<br>sub B or<br>add 0111 to A                           |
| 0111               |                  | Ashr<br>AQ <sub>n</sub> Q <sub>n+1</sub>                 |
| 0111               | 1001             | 011<br>Ashr<br>AQ <sub>n</sub> Q <sub>n+1</sub>          |
| 0011               | 1100             | 010<br>Ashr AQ <sub>n</sub> Q <sub>n+1</sub><br>add 1001 |
| 1001               |                  | 001<br>Ashr AQ <sub>n</sub> Q <sub>n+1</sub>             |
| 1010               | 0110             | 000<br>Ashr AQ <sub>n</sub> Q <sub>n+1</sub>             |
| 1101               | 1011             |                                                          |
| 1110               |                  |                                                          |

Answer is 11101011  
 $(-7) \times (+3) = -21 = 11101011$  (2's complement of + 21)

**Que 2.10.** Explain array multiplier method with the help of example.

### Answer

- The combinational circuit implemented to perform multiplication is called array multiplier.
- The generalized multiplication process for array multiplier for two unsigned integers : Multiplicand  $A = A_3A_2A_1A_0$  and multiplier  $B = B_3B_2B_1B_0$  is shown in Fig. 2.10.1.



**Fig. 2.10.1.** Manual multiplication process.

- Each shifted multiplicand which is multiplied by either 0 or 1 depending on the corresponding multiplier bit is called Partial Product (PP).
- Each partial product consists of four product components.

$$\begin{aligned}P_0 &= A_0B_0 \\P_1 &= A_1B_0 + A_0B_1\end{aligned}$$

| Computer Organization & Architecture      |  |  |
|-------------------------------------------|--|--|
| 2-11B (CSIT-Sem-3)                        |  |  |
| $P_2 = A_3B_0 + A_2B_1 + A_0B_2$          |  |  |
| $P_3 = A_3B_0 + A_2B_1 + A_1B_2 + A_0B_3$ |  |  |
| $P_4 = A_3B_1 + A_2B_2 + A_1B_3$          |  |  |
| $P_5 = A_3B_2 + A_2B_3$                   |  |  |
| $P_6 = A_3B_3$                            |  |  |

- The product component bit is a logical AND of multiplier bit  $B_i$  and multiplicand bit  $A_j$ , i.e.,  $B_i \times A_j$ . Since the arithmetic and logic products coincide in the 1 bit case, Fig. 2.10.2 shows the circuit to add the product components. Here, the product components are represented by AND gates and separated to make space.



**Fig. 2.10.2.** Block diagram of combinational multiplier.

- The full adder block is represented by square block. The carries in each partial product row of full adders are connected to make 4-bit ripple adder.
- Thus, the first 4-bit ripple adder adds the first two rows of product components to produce the first partial product.
- The carry output generated is propagated to the most significant product component used to produce the next partial product.
- The subsequent adders add each partial product with the next product component.

### PART-3

#### Division and Logic Operations.

##### Questions-Answers

- Each shifted multiplicand which is multiplied by either 0 or 1 depending on the corresponding multiplier bit is called Partial Product (PP).

##### Long Answer Type and Medium Answer Type Questions

**2-12 B (CS/IT-Sem-3)** Write down the step for restoring and non-restoring of division operations.

**Que 2.11**

**Answer** Non-restoring division operation :

Restoring division operation back in  $A(A \leftarrow A - B)$   
Step 1: Shift  $A$  and  $Q$  left one binary position. and place answer back to  $A$  (that is,

Step 2: Subtract divisor from  $A$ , otherwise, set  $Q_0$  to 1;

Step 3: If the sign bit of  $A$  is 1, set  $Q_0$  to 0;

Step 4: Repeat steps 1, 2 and 3 upto  $n$  times.

Non-restoring division operation :  
Step 1: If the sign of  $A$  is 0, shift  $A$  and  $Q$  left and add divisor to  $A$ .

Step 2: If the sign of  $A$  is 1, otherwise, shift  $A$  and  $Q$  to 0;

Step 3: Repeat steps 1 and 2 for  $n$  times.

Step 4: If the sign of  $A$  is 1, add divisor to  $A$ . Step 4 is required to leave the proper positive remainder in  $A$  at the end of  $n$  cycles.

**Que 2.12.** Draw the flow chart for restoring and non-restoring division operation.

**Answer** Flowchart for restoring division operation is shown in Fig. 2.12.1.



Fig. 2.12.1. Flow chart for restoring division operation.

**Computer Organization & Architecture** **2-13 B (CS/IT-Sem-3)** A flow chart for non-restoring division operation is shown in Fig. 2.12.2.

**Que 2.13**

Draw the data path of sequential  $n$ -bit binary divider.

Give the non-restoring division algorithm for unsigned integers.

Also illustrate algorithm for unsigned integer with a suitable example.



Fig. 2.12.2. Flow chart for non-restoring division operation.

**Que 2.13** Draw the data path of sequential  $n$ -bit binary divider.  
Give the non-restoring division algorithm for unsigned integers.  
Also illustrate algorithm for unsigned integer with a suitable example.

AKTU 2017-18, Marks 07

**Answer**  
Datapath of sequential  $n$ -bit binary divider :



Fig. 2.131.

**Algorithm for non-restoring division :** Refer Q. 2.11, Page 2-12B, Unit-2.

For example, consider 4-bit dividend and 2-bit divisor :

Dividend = 1010, Divisor = 0011

| A Register          | Q Register | Dividend |
|---------------------|------------|----------|
| Initially 0 0 0 0   | 1 0 1 0    |          |
| Shift 0 0 0 1       | 0 1 0      |          |
| Subtract 1 1 1 0    | / 0 1 0    |          |
| set $Q_0$ ① 1 1 1 0 |            |          |

First Cycle

| Shift 1 1 1 0       | Add 1 0 0 0 | Quotient 1 0 0 0 |
|---------------------|-------------|------------------|
| set $Q_0$ ① 1 1 1 1 | 1 0 0 0     |                  |

Second Cycle

| Shift 1 1 1 1       | Add 0 0 1 1 | Quotient 0 0 1 1 |
|---------------------|-------------|------------------|
| set $Q_0$ ① 0 0 1 0 | 0 0 0 1     |                  |

Third Cycle

| Shift 1 1 1 0       | Add 0 0 0 1 | Quotient 0 0 0 1 |
|---------------------|-------------|------------------|
| set $Q_0$ ① 0 0 0 1 | 0 0 0 1     |                  |

Fourth Cycle

Fig. 2.132. A non-restoring division example.

In given example after 4 cycles register A is positive and hence step 3 is not required.

**Que 2.14.** Perform the division process of 00001111 by 0011 (use a dividend of 8 bits).

AKTU 2018-19, Marks 07

**Answer**

$$B = 0011 \quad \bar{B} + 1 = 1101$$

| Operation                 | E | A    | Q    | SC  |
|---------------------------|---|------|------|-----|
| Dividend in Q, A = 0      | 0 | 0000 | 1111 |     |
| shl EAQ                   |   | 0001 | 1110 | 100 |
| add $\bar{B} + 1$         |   | 1101 |      |     |
| E = 0, leave $Q_n = 0$    | 0 | 1110 | 1110 |     |
| add $B$                   |   | 0011 |      |     |
| restore partial remainder | 1 | 0011 | 011  |     |
| shl EAQ                   |   | 0011 |      |     |
| add $\bar{B} + 1$         |   | 1101 |      |     |
| E = 1, set $Q_n$ to 1     | 1 | 0000 | 1101 |     |
| shl EAQ                   |   | 0001 | 1010 | 010 |
| add $\bar{B} + 1$         |   | 1101 |      |     |
| E = 0, leave $Q_n = 0$    | 0 | 1110 | 1010 |     |
| restore partial remainder | 1 | 0011 | 001  |     |
| shl EAQ                   |   | 0011 |      |     |
| add $\bar{B} + 1$         |   | 1101 |      |     |
| E = 1, set $Q_n$ to 1     | 1 | 0000 | 0101 | 000 |

**Que 2.15.** What do you mean by overflow ? Describe the overflow detection.

**Answer**

Overflow:

- Overflow is a condition when two numbers with  $n$  digits are added and the sum is a number occupying  $n+1$  digit.
- Overflow is a problem in digital computer because the number of bits cannot be accommodated by an  $n$ -bit word.
- There are following three types of overflow :
  - Positive overflow :** Positive overflow refers to integer representations and refers to a number that is larger than that can be represented in a given number of bits.

**2-16B (CSIT-Sem-3)**

- ii. **Exponent overflow :** Exponent overflow refers to floating point representations and refers to a positive exponent that exceeds the maximum possible exponent value.

- iii. **Significand overflow :** Significand overflow occurs when the addition of two significant numbers of the same sign results in a carry out of the most significant bit.

**Overflow detection :** An overflow can be detected by observing the carry into the sign bit position. If these two carries are not equal, an overflow condition is produced.

For example :

$$\begin{array}{r}
 +35 \quad 0 \quad 100011 \quad -35 \quad 1 \quad 011101 \\
 +40 \quad 0 \quad 101000 \quad -40 \quad 1 \quad 011000 \\
 \hline
 75 \quad 1 \quad 001011 \quad -75 \quad 10 \quad 110101
 \end{array}$$

Two carries are explicitly shown. If the two carries are applied to an exclusive OR gate, an overflow would be detected when the output of the gate is 1.

**PART-4****Floating Point Arithmetic Operations, Arithmetic and Logic Unit Design.****Questions-Answers****Long Answer Type and Medium Answer Type Questions**

**Que 2.16.** Explain the basic format used to represent floating point numbers.

**Answer**

The floating point representation has three fields :

1. **The sign bit :** The sign bit determines whether the number is negative or positive. 0 denotes a positive number and 1 denotes a negative number.
2. **The exponent :** The exponent field needs to represent both positive and negative exponents. To do this, a bias is added to the actual exponent in order to get the stored exponent. For IEEE single precision the exponent field is of 8 bits and has a bias value of 127. For double precision, the exponent field is of 11 bits, and has a bias of 1023.
3. **The mantissa :** The mantissa, also known as the significand, represents the precision bits of the number. It is composed of an implicit leading bit and the fraction bits.

**Computer Organization & Architecture****2-17B (CSIT-Sem-3)**

The general structure of floating point number is

|       |        |         |                  |
|-------|--------|---------|------------------|
| S     | E'     | M       | Single precision |
| 1 bit | 8 bits | 23 bits |                  |

  

|       |         |         |                  |
|-------|---------|---------|------------------|
| S     | E'      | M       | Double precision |
| 1 bit | 11 bits | 52 bits |                  |

Where S is significant (mantissa) digits, E is exponent, B is scaling factor, which is 2 for binary number, 10 for decimal number.

**Que 2.17.** Write the steps for various floating point arithmetic operations.

**Answer**

Steps for various floating point arithmetic operations are :

i. **Addition and subtraction :**

Step 1 : Check for zeros.

Step 2 : Align the mantissas.

Step 3 : Add or subtract the mantissas.

ii. **Multiplication :**

Step 1 : Check for zeros.

Step 2 : Add the exponents.

Step 3 : Multiply the mantissas and determine the sign of the result.

iii. **Division :**

Step 1 : Check for zeros.

Step 2 : Subtract the exponents.

Step 3 : Divide the mantissas and determine the sign of the result.

Step 4 : Normalize the result.

**Que 2.18.** Explain the function of arithmetic circuit with the help of circuit diagram.

**Answer**

Arithmetic circuit performs the operation of both addition and subtraction. It has two 4-bit inputs  $A_3 A_2 A_1 A_0$  and  $B_3 B_2 B_1 B_0$ .

1. **4-bit parallel adder/subtractor :** It is an arithmetic circuit to perform the operations of addition and subtraction.
2. The EXOR gates are used as controlled inverters.



**Fig. 2.18.1.** Symbol of EXOR gate.

Table : 2.18.1. Truth table of EXOR Gate.

| Input | Output |
|-------|--------|
| X     | Y      |
| 0     | 0      |
| 0     | 1      |
| 1     | 0      |
| 1     | 1      |



Fig. 2.18.2. A 4-bit parallel binary adder/subtractor.

3. If  $C = 0$ , the input variable  $X$  is either 0 or 1 will be transferred to output terminal.

4. If  $C = 1$ , the input variable  $X$  is either 0 or 1 will be complemented and transferred to output. By using this EXORGate property we use this gate in the 4-bit adder / subtractor circuit.

- Case 1 : ADD/SUB = 1

- i. Now, the controlled inverter (EXOR gate) produces the 1's complement of  $B_3, B_2, B_1, B_0$ . Since 1 is given to  $C_{in}$  of the LSB bit of the adder, it is added to the complemented output of EXOR gate output, it is equal to 2's complement of  $B_3, B_2, B_1, B_0$ .

- ii. The 2's complemented  $B_3, B_2, B_1, B_0$  will be added to  $A_3, A_2, A_1, A_0$  to produce the sum, the produced output of  $S_3, S_2, S_1, S_0$  is the difference between  $A_3, A_2, A_1, A_0$  and  $B_3, B_2, B_1, B_0$ .

- Case 2 : ADD/SUB = 0.

- i. Now, the controlled inverter is transferred to  $B_3, B_2, B_1, B_0$  four bit to full adder, this 4 bit is added with  $A_3, A_2, A_1, A_0$  to produce sum and carry.

- Que 2.19.** Add -35 and -31 in binary using 8-bit registers, in signed 1's complement and signed 2's complement.

**AKTU 2014-15, Marks 05**

**Answer**

↓ sign bit

True binary number of  
35 = 0 0 1 0 0 0 1 1  
True binary number of  
31 = 0 0 0 1 1 1 1 1

1's complement of  
1's complement of  
-35 = 1 1 0 1 1 1 0 0  
-31 = +1 1 1 0 0 0 0 0

↓ Discard the carry

2's Complement of  
-35 = 1 1 0 1 1 1 0 0  
+1  
1 1 0 1 1 1 0 1  
1 1 1 0 0 0 0 0

2's Complement of  
-31 = 1 1 1 0 0 0 0 0  
+1  
1 1 1 0 0 0 0 1  
1 1 1 0 0 0 0 0

Adding 2's complement of -35 and -31  
+ 1 1 1 0 0 0 0 1  
1 1 1 0 0 0 0 1  
-----  
1 1 0 1 0 1 1 0 0

Discard the carry  
sign bit

- Que 2.20.** Draw the block diagram of control unit of basic computer. Explain in detail with control timing diagrams.

**AKTU 2016-17, Marks 15**

**Answer**

1. The control unit consists of 2 decoders, 1 sequence counter, number of control logic gates.

2. The instruction in IR is divided into 3 parts : 15<sup>th</sup> bit to a flip-flop (FF) called I, Operation code, and bits 0 to 11. The Op-code is decoded using 3\*8 decoder ( $D_0$  to  $D_7$ ). Bits 0 to 11 are applied to the control logic gates. The output of a 4-bit sequence counter are decoded into 16 timing signals ( $T_0$  to  $T_{15}$ ).

3. The SC responds to the positive transition of the clock. Initially CLR/IVP is active, in 1<sup>st</sup> positive transition SC = 0, timing signal  $T_0$  is active as the output of the decoder. This in turn triggers those registers whose control inputs are connected to  $T_0$ . SC is incremented and the timing signals  $T_0, T_1, T_2, T_3 \dots$  are created. This continues unless SC is cleared. We can clear the SC with decoder output  $D_3$  active, denoted as :  
 $D_3 T_4 ; SC \leftarrow 0$

### Arithmetic and Logic Unit

**2-20 B (CSIT-Sem-3)**



**Fig. 2.20.1.** Block diagram of control unit.

4. Output  $D_3$  from the operation decoder becomes active at the end of  $T_2$ . When  $T_4$  is active, the output of AND gate that implements the control function  $D_3 T_4$  becomes active. This signal is applied to CLR input of SC.
5. Example of register transfer :  $T_0 : AR \leftarrow PC$  (Activities in  $T_0$  will be, Content of PC placed on bus,  $S_2 S_1 S_0 = 010$ ). LD of AR is active, transfer occurs at the end of positive transition.  $T_0$  is inactive,  $T_1$  gets active).
6. Timing control is generated by 4-bit sequence counter and  $4 \times 16$  decoder. The SC can be incremented or cleared.  $T_0, T_1, T_2, T_3, T_4, T_0, \dots$

For example : Assume : At time  $T_4$ , SC is cleared to 0 if decoder output  $D_3$  is active.

Assume : At time  $T_4$ :  $SC \leftarrow 0$

Timing diagram :



**Fig. 2.20.2.**

**Computer Organization & Architecture**

**2-21 B (CSIT-Sem-3)**

**Answer**



**Fig. 2.21.1.**

**PART-5**

*IEEE Standard for Floating Point Numbers.*

**Questions Answers**

**Long Answer Type and Medium Answer Type Questions**

**Que 2.21.** Explain IEEE standard for floating point numbers.

How floating point numbers are represented in computer, also give IEEE 754 standard 32-bit floating point number format.

OR

**Que 2.21.** Draw a flowchart for adding and subtracting two fixed point binary numbers where negative numbers are signed 1's complement presentation.

**AKTU 2018-19, Marks 07**

**AKTU 2017-18, Marks 3.5**

**Answer**

1. The IEEE standard for floating point arithmetic (IEEE 754) is a technical standard for floating point computation.
2. IEEE 754 numbers are divided into two types :

- a. Single precision :

i. The floating point numbers in 32-bit are single precision.



Sign of number  
+ Signifies 0  
- Signifies 1

**Fig. 2.22.1. Single precision.**

- ii. 32-bit floating point number in single precision is represented as  $+1M \times 2^E$ .

- iii. The relationship between  $E$  and  $E'$  in single precision is given as  $E' = E + 127$ .

- iv. The 8-bit assigned for exponent  $E'$  (Modified exponent) is in the range  $0 < E' < 255$  for normal values. Thus the actual exponent is in the range  $-127 \leq E \leq 127$ .

- v. The values 0 and 255 are used to indicates the floating points values of exact 0 and infinite respectively.

**b. Double precision :**

- i. The floating number in 64-bit are double precision. Fig. 2.22.2 show the double precision format of IEEE standard form.

- The double precision format has increased, exponent and mantissa ranges.

- ii. The 11 bit assigned for exponent  $E'$  has range  $0 < E' < 2047$  for normal values. Thus the actual exponent  $E$  is in the range  $-1022 \leq E \leq 1023$ . The relationship between  $E$  and  $E'$  in double precision is given as  $E' = E + 1023$ .

- iv. The 52 bit is assigned for mantissa, provides a precision equivalent to about 16 decimal digits.

- v. 64-bit floating point number in double precision is represented as  $\pm 1.M \times 2^E$ .



Sign  
11-bit  
11-bit  
52-bit mantissa fraction

**Fig. 2.22.2. Double precision.**

**Answer**

- Step 1 : Convert the decimal number in binary format.  
For integer,

|   |      |   |
|---|------|---|
| 2 | 1460 | 0 |
| 2 | 730  | 0 |
| 2 | 365  | 1 |
| 2 | 182  | 0 |
| 2 | 91   | 1 |
| 2 | 45   | 1 |
| 2 | 22   | 0 |
| 2 | 11   | 1 |
| 2 | 5    | 1 |
| 2 | 2    | 0 |
|   | 1    |   |

$$(1460)_{10} = (10110110100)_2$$

For fraction,

$$\begin{aligned} 0.125 \times 2 &= 0.250 \Rightarrow 0 \\ 0.250 \times 2 &= 0.500 \Rightarrow 0 \\ 0.500 \times 2 &= 1.000 \Rightarrow 1 \end{aligned}$$

$$(0.125)_{10} = (0.001)_2$$

$$(1460.125)_{10} = (10110110100.001)_2$$

Step 2 : Normalize the number.

$$10110110100.001 = 1.011011010001 \times 2^{10}$$

**Single Precision :**

For a given floating point number,

$$1.011011010001 \times 2^{10}$$

$$S = 0$$

$$E = 10$$

$$M = 0110110100001$$

Bias (or) modified exponent for single precision

$$\begin{aligned} E' &= 127 + E \\ &= 127 + 10 = 137_{10} \\ &= 10001001_2 \end{aligned}$$

Number is single precision format

| S | E'       | M                  |
|---|----------|--------------------|
| 0 | 10001001 | 011011010001.....0 |

Double precision :

For a given number,

$$1.011011010001 \times 2^{10}$$

$S = 0, E = 10, M = 011011010001$

Bias (or) modified exponent for double precision

$$E' = E + 1023$$

$$= 10 + 1023$$

$$= (1033)_{10} = (1000001001)_2$$

| S | E'         | M                  |
|---|------------|--------------------|
| 0 | 1000001001 | 011011010001.....0 |

**VERY IMPORTANT QUESTIONS**

*Following questions are very important. These questions may be asked in your SESSIONALS as well as UNIVERSITY EXAMINATIONS.*

**Q. 1.** Describe sequential Arithmetic and Logic Unit (ALU) using proper diagram.

**Ans.** Refer Q. 2.1.

**Q. 2.** Explain Booth's multiplication algorithm in detail.

**Ans.** Refer Q. 2.3.

**Q. 3.** Draw the data path of 2's compliment multiplier. Give the Robertson multiplication algorithm for 2's compliment fractions. Also illustrate the algorithm for 2's compliment fraction by a suitable example.

**Ans.** Refer Q. 2.5.

**Q. 4.** Show step by step the multiplication process using Booth's algorithm when (+ 15) and (- 13) numbers are multiplied.

**Ans.** Assume 5-bit registers that hold signed numbers. Refer Q. 2.6.

**Q. 5.** Show the contents of the registers E, A, Q, SC during the process of multiplication of two binary numbers 11111 (multiplicand) 10101 (multiplier). The signs are not included.  
**Ans.** Refer Q. 2.7.

**Q. 6.** Show the multiplication process using Booth's algorithm when the following numbers are multiplied: (-13) by (+8)  
**Ans.** Refer Q. 2.8.

**Q. 7.** Draw the flowchart of Booth's algorithm for multiplication and show the multiplication process using Booth's algorithm for  $(-7) \times (+3)$ .  
**Ans.** Refer Q. 2.9.

**Q. 8.** Draw the data path of sequential n-bit binary divider. Give the non-restoring division algorithm for unsigned integers. Also illustrate algorithm for unsigned integer with a suitable example.  
**Ans.** Refer Q. 2.13.

**Q. 9.** Perform the division process of 000001111 by 0011 (use a dividend of 8 bits).  
**Ans.** Refer Q. 2.14.

**Q. 10.** Add -35 and -31 in binary using 8-bit registers, in signed 1's complement and signed 2's complement.  
**Ans.** Refer Q. 2.19.

**Q. 11.** Draw the block diagram of control unit of basic computer. Explain in detail with control timing diagrams.  
**Ans.** Refer Q. 2.20.

**Q. 12.** Draw a flowchart for adding and subtracting two fixed point binary numbers where negative numbers are signed 1's complement presentation.  
**Ans.** Refer Q. 2.21.

**Q. 13.** How floating point numbers are represented in computer, also give IEEE 754 standard 32-bit floating point number format.  
**Ans.** Refer Q. 2.22.

# 3

UNIT

## Control Unit

### PART-1

*Instruction Types, Formats, Instruction Cycles and Sub Cycles  
(Fetch, Execute etc), Micro-Operation.*

#### Questions-Answers

#### Long Answer Type and Medium Answer Type Questions

## CONTENTS

- Part-1 : Control Unit : Instruction ..... 3-2B to 3-4B  
Types, Formats

- Part-2 : Instruction Cycle ..... 3-4B to 3-9B  
and Sub Cycle  
(Fetch and Execute etc.)

- Part-3 : Micro-operations, Execution ..... 3-9B to 3-10B  
of Complete Instruction

- Part-4 : Program Control, Reduced ..... 3-16B to 3-18B  
Instruction Set Computer

- Part-5 : Pipelining ..... 3-18B to 3-22B

- Part-6 : Hardwired and Micro- ..... 3-23B to 3-30B  
programmed Control :  
Micro-programme  
Sequencing

- Part-7 : Concept of Horizontal and ..... 3-30B to 3-35B  
Vertical Micro-programming

**Que 3.1.** What is an instruction in the context of computer organization ? Explain the purpose of the various elements of an instruction with the help of a sample instruction format.

**AKTU 2014-15, Marks 10**

### Answer

Instruction :

1. Instruction is a command to the processor to perform a given task on specified data.
2. An instruction is a designed binary pattern which is based on the architecture of CPU to perform a specific function. The entire group of instructions is called the instruction set.

**Instruction format :**

| Opcode | Operand |
|--------|---------|
|--------|---------|

**Fig. 3.1.1.**

- Instruction has two parts opcode and operand,
1. Task to be performed, called the operation code (Opcode), and the data to be operated upon, called the operand.
  2. The operands include the input data of the operation and the results that are produced.
  3. A computer must have instructions capable of performing four types of operations :
    - a. Data transfers between the memory and the CPU registers.
    - b. Arithmetic and logic operations on data.
    - c. Program sequencing and control.
    - d. I/O transfers.
  4. The purpose of an instruction is to specify both an operation to be carried out by a CPU or also process the set of operands or data to be used in the operation.

**Example :**



Computer Organization & Architecture  
This instruction will multiply two operand A and B and result is stored in A.

- Que 3.2.** Describe the types of instructions on the basis of address fields used in the instruction with example.

**Answer**

Four types of instructions are available on the basis of referenced address fields :  
Now, Let us evaluate the following arithmetic expression, using all instruction types.

$$X = (A + B) * (C + D)$$

1. **Three address instruction :** Computers with three address instruction formats can use each address fields to specify either a processor register or a memory operand. The program in assembly language to evaluate arithmetic expression is shown as :

|     |           |                             |
|-----|-----------|-----------------------------|
| ADD | R1, A, B  | R1 $\leftarrow M[A] + M[B]$ |
| ADD | R2, C, D  | R2 $\leftarrow M[C] + M[D]$ |
| ADD | X, R1, R2 | M[X] $\leftarrow R1 * R2$   |

2. **Two address instruction :** In this format each address field can specify either a processor register or a memory word. The assembly language program to evaluate arithmetic expression is as follows :

|     |        |                           |
|-----|--------|---------------------------|
| MOV | R1, A  | R1 $\leftarrow M[A]$      |
| MOV | R1, B  | R1 $\leftarrow R1 + M[B]$ |
| ADD | R2, C  | R2 $\leftarrow M[C]$      |
| ADD | R2, D  | R2 $\leftarrow R2 + M[D]$ |
| MUL | R1, R2 | M[R1] $\leftarrow R2$     |
| MOV | X, R1  | M[X] $\leftarrow R1$      |

3. **One address instruction :** One address instruction uses an implied accumulator (AC) register for all data manipulation. The program is as follows :

|       |   |                           |
|-------|---|---------------------------|
| LOAD  | A | AC $\leftarrow M[A]$      |
| ADD   | B | AC $\leftarrow AC + M[B]$ |
| STORE | T | M[T] $\leftarrow AC$      |
| LOAD  | C | AC $\leftarrow M[C]$      |
| ADD   | D | AC $\leftarrow AC + M[D]$ |
| MUL   | T | AC $\leftarrow AC * M[T]$ |
| STORE | X | M[X] $\leftarrow AC$      |

All operations are done between the AC register and a memory operand.

4. **Zero address instruction :** A stack organized computer does not use an address field for the instructions ADD and MUL. The PUSH and POP instructions need an address field to specify the operand that communicates with the stack. The program is as follows :

|      |   |                          |
|------|---|--------------------------|
| PUSH | A | TOS $\leftarrow A$       |
| PUSH | B | TOS $\leftarrow B$       |
| ADD  |   | TOS $\leftarrow (A + B)$ |
| PUSH | C | TOS $\leftarrow C$       |

| Control Unit                   |
|--------------------------------|
| PUSH D                         |
| ADD                            |
| MUL                            |
| POP X                          |
| where TOS is TOP of the stack. |

- Que 3.3.** Evaluate the arithmetic statement  $X = (A + B) * (C + D)$  using a general register computer with three address, two address and one address instruction format a program to evaluate the expression.

**AKTU 2018-19, Marks 07**

- Answer**  
Three address instruction :

|     |           |                             |
|-----|-----------|-----------------------------|
| ADD | R1, A, B  | R1 $\leftarrow M[A] + M[B]$ |
| ADD | R2, C, D  | R2 $\leftarrow M[C] + M[D]$ |
| MUL | X, R1, R2 | M[X] $\leftarrow R1 * R2$   |

- Two address instruction :

|     |        |                           |
|-----|--------|---------------------------|
| MOV | R1, A  | R1 $\leftarrow M[A]$      |
| ADD | R1, B  | R1 $\leftarrow R1 + M[B]$ |
| MOV | R2, C  | R2 $\leftarrow M[C]$      |
| ADD | R2, D  | R2 $\leftarrow R2 + M[D]$ |
| MUL | R1, R2 | R1 $\leftarrow R1 * R2$   |
| MOV | X, R1  | M[X] $\leftarrow R1$      |

- One address instruction :

|       |   |                             |
|-------|---|-----------------------------|
| LOAD  | A | AC $\leftarrow M[A]$        |
| ADD   | B | AC $\leftarrow A[C] + M[B]$ |
| STORE | T | M[T] $\leftarrow AC$        |
| LOAD  | C | AC $\leftarrow M[C]$        |
| ADD   | D | AC $\leftarrow AC + M[D]$   |
| MUL   | T | AC $\leftarrow AC * M[T]$   |
| STORE | X | M[X] $\leftarrow AC$        |

## PART-2

### Instruction Cycle and Sub Cycle (Fetch and Execute etc.)

#### Questions-Answers

#### Long Answer Type and Medium Answer Type Questions

- Que 3.4.** Define instruction cycle and divide instruction cycle into sub cycles with the help of diagram, explain the sequence in which sub cycles are executed.

**OR**  
Explain the different cycles of an instruction execution.

**OR**  
Explain all the phases of instruction cycle.

**AKTU 2018-19, Marks 3.5**

### Answer

Steps in fetching a word from memory are as follows :

**Step 1:** The CPU has to perform opcode fetch cycle and operand fetch cycle.

**Step 2:** The opcode fetch cycle gives the operation code of fetching a word from memory to the CPU.

**Step 3:** The CPU then invokes the operand fetch cycle.

**Step 4:** The opcode specifies the address of memory location where the information is stored.

**Step 5:** The CPU transfers the address of required word of information to the Address Register (AR), which is connected to the address lines of the memory bus. Hence, the address is transferred to the memory.

**Step 6:** The CPU activates the read signal of the memory to indicate that a read operation is needed.

**Step 7:** As a result, memory copies data from the addressed register on the data bus.

**Step 8:** The CPU then reads this data from the data register and loads it in the specified register.

**Step 9:** Memory Functions Completed (MFC) is also used as a control signal for this memory transfer.

**Step 10:** Memory sets MFC to 1 to indicate that the contents of the specified location have been read and are available on the data bus.

### Difference :

| S.No. | Branch instruction                                                         | Subroutine instruction                        |
|-------|----------------------------------------------------------------------------|-----------------------------------------------|
| 1.    | Branch instruction is a machine-language or assembly-language instruction. | Subroutine is a control transfer instruction. |
| 2.    | It is used to change the sequence of instruction execution.                | It is used to call a subroutine.              |

**Que 3.6.** Assuming that all registers initially contain 0, what is the value of  $R_1$  after the following instruction sequence is executed :

MOV R<sub>1</sub>, #6  
MOV R<sub>2</sub>, #5  
ADD R<sub>3</sub>, R<sub>1</sub>, R<sub>1</sub>  
SUB R<sub>1</sub>, R<sub>3</sub>, R<sub>2</sub>  
MUL R<sub>3</sub>, R<sub>1</sub>, R<sub>1</sub>

### Answer

MOV R<sub>1</sub>, #6

{Directly move 6 to the register R<sub>1</sub>}

- Instruction cycle :**  
 1. Instruction cycle is a complete process of instruction execution.  
 2. It is a basic operational process of a computer.  
 3. It is the process by which a computer retrieves a program instruction from its memory, determines what actions the instruction dictates, and carries out those actions.
- The instruction cycle is divided into three sub cycles :**



**Fig. 3.4.1.**

- 1. Fetch cycle :** To fetch an opcode from a memory location following steps are performed :

- The program counter places the address of the memory location in which the opcode is stored, on the address bus.
- The CPU sends the required memory control signals so as to enable the memory to send the opcode.
- The opcode stored in the memory location is placed on the data bus and transferred to the CPU.

- 2. Decode cycle :**

- The opcode which is fetched from the memory is placed first of all in the Data Register (DR) (data/address buffer in case of Intel 8085). Thereafter it goes to the Instruction Register (IR). From the instruction register it goes to the decoder circuitry, which is within the CPU.
- The decoder circuitry decodes the opcode.
- After the opcode is decoded the CPU comes to know what operation is to be performed, and then execution begins.

- 3. Execute cycle :**

- In this cycle, function of the instruction is performed.
  - If the instruction involves arithmetic or logic, ALU is utilized.
- Que 3.5.** Write the steps in fetching a word from memory. Differentiate between a branch instruction and call subroutine instruction.

**AKTU 2014-15, Marks 10**

**3-8 B (CSIT-Sem-3)**

[Take another register in which directly move 5 into it]  
**MOV R<sub>2</sub>, #5**  
 (Value stored in R<sub>1</sub> added to R<sub>1</sub> again and then stored in R<sub>3</sub>)

ADD R<sub>3</sub>, R<sub>1</sub>, R<sub>1</sub>  
 Thus, R<sub>3</sub> has a value of 12.

**SUB R<sub>1</sub>, R<sub>3</sub>, R<sub>2</sub>**  
 (Value of R<sub>2</sub> is subtracted from R<sub>3</sub> and more into the R<sub>1</sub>)

Thus, R<sub>1</sub> has a value of = R<sub>3</sub> - R<sub>2</sub> = 12 - 5 = 7  
 (Multiply R<sub>1</sub> with R<sub>1</sub> and store into R<sub>3</sub>)

**MUL R<sub>3</sub>, R<sub>1</sub>, R<sub>1</sub>**  
 Thus, the final execution of this statement will give 49 and R<sub>1</sub> contains 7 as value stored in it.

**Que 3.7.** In an instruction format, there are 16 bits in an instruction word. Bit 0 to 11 convey the address of the memory location for memory related instructions. For non memory operations these bits convey various register or I/O operations. Bits 12 to 14 show the various basic memory operations such as ADD, AND, LDA etc. Bit 15 shows if the memory is accessed directly or indirectly. For such an instruction format draw block diagram of the control unit of a computer and briefly explain how an instruction will be decoded and executed, by this control unit.

**AKTU 2016-17, Marks 10****Answer**

- Consider the instruction code format shown in Fig. 3.7.1(a). It consists of a 3-bit operation code, a 12-bit address, and an indirect address mode bit designated by *I*.
- The mode bit is 0 for a direct address and 1 for an indirect address.
- A direct address instruction is shown in Fig. 3.7.1(b). It is placed in address 22 in memory. The *I* bit is 0, so the instruction is recognized as a direct address instruction.
- The opcode specifies an ADD instruction, and the address part is the binary equivalent of 457.
- The control finds the operand in memory at address 457 and adds it to the content of AC.
- The instruction in address 35 shown in Fig. 3.7.1(c) has a mode bit *I* = 1. Therefore, it is recognized as an indirect address instruction.
- The address part is the binary equivalent of 300. The control goes to address 300 to find the address of the operand.
- The address of the operand in this case is 1350. The operand found in address 1350 is then added to the content of AC.
- The indirect address instruction needs two references to memory to fetch an operand.

**Fig. 3.7.1.**

Instruction will be decoded and executed by this control unit :

**Fig. 3.7.2.** Block diagram of control unit of a computer.

- Control unit consists of :
  - Instruction register
  - Number of control logic gates
  - Two decoders
  - 4-bit sequence counter
- An instruction read from memory is placed in the Instruction Register (IR).
- The instruction register is divided into three parts : the *I* bit, operation code, and address part.

Computer Organization & Architecture

1. First 12-bits ( $0 - 11$ ) are applied to the control logic gates.

2. The operation code bits ( $12 - 14$ ) are decoded with a  $3 \times 8$  decoder.
3. The eight outputs ( $D_0$  through  $D_7$ ) from a decoder go to the control logic gates to perform specific operation.
4. The operation code bits ( $D_0$  through  $D_7$ ) from a decoder go to the control logic gates to perform specific operation.
5. The eight outputs ( $D_0$  through  $D_7$ ) from a decoder go to the control logic gates to perform specific operation.
6. The eight outputs ( $D_0$  through  $D_7$ ) from a decoder go to the control logic gates to perform specific operation.
7. Last bit 15 is transferred to a  $J$  flip-flop designated by symbol  $J$ .
8. The 4-bit Sequence Counter (SC) can count in binary from 0 through 15.
9. The counter output is decoded into 16 timing pulses  $T_0$  through  $T_{15}$ .
10. The sequence counter can be incremented by INR input or clear by CLR input synchronously.

### PART-3

*Micro-operation Execution of Complete Instruction.*

#### Questions-Answers

#### Long Answer Type and Medium Answer Type Questions

- Que 3.8.** Describe micro-operation and enlist its types.

**Answer**  
A micro-operation is a simple operation that can be performed during one clock period.

1. The result of this operation may replace the previous binary information of register or the result may be transferred to another register.
2. Examples of micro-operations are shift, move, count, add and load etc.
3. The micro-operations most often encountered in digital computers are classified into four categories :
4. Register transfer micro-operations : It transfer binary information from one register to another.

- i. Arithmetic micro-operations : It perform arithmetic operation on numeric data stored in registers.
- ii. Logic micro-operations : It perform bit manipulation operations on non-numeric data stored in registers.
- iii. Shift micro-operations : It perform shift operations on data stored in registers.
- iv. Shift micro-operations : It perform shift operations on data stored in registers.

- Que 3.9.** Write a short note on register transfer micro-operation.

#### Answer

1. Register transfer is defined as information transfer from one register to another and is designated in symbolic form by means of a replacement operator.



Fig. 3.9.1. Block diagram.

6. The letter  $n$  will be used to indicate any number of bits for the register. It will be replaced by an actual number when the length of the register is known.
7. Register  $R_2$  has a load input that is activated by the control variable  $P$ .
8. The basic symbols of the register transfer notations are listed in Table 3.9.1.

Table 3.9.1. Basic symbols for register transfers.

| S. No. | Symbol                    | Description                     | Examples                                 |
|--------|---------------------------|---------------------------------|------------------------------------------|
| 1.     | Letters<br>(and numerals) | Denotes a register              | MAR, $R_2$                               |
| 2.     | Parentheses ()            | Denotes a part of a register    | $R_2(0-7), R_2(L)$                       |
| 3.     | Arrow $\leftarrow$        | Denotes transfer of information | $R_2 \leftarrow R_1$                     |
| 4.     | Comma,                    | Separates two micro-operations  | $R_2 \leftarrow R_1, R_1 \leftarrow R_2$ |

- Que 3.10.** Write short note on arithmetic micro-operation.

#### Answer

1. The basic arithmetic micro-operations are addition, subtraction, increment and decrement. The arithmetic micro-operation defined by the statement,  $R_3 \leftarrow R_1 + R_2$  which specifies an addition micro-operation.
2. It states that the contents of register  $R_1$  are added to the contents of register  $R_2$  and the sum is transferred to register  $R_3$ .
3. Subtraction is implemented through complementation and addition, which is specified in following statement :

2. The statement denotes a transfer of the content of register  $R_1$  into register  $R_2$ .
3. It designates a replacement  $R_2 \leftarrow R_1$
4. Every statement written in a register transfer notation implies a hardware construction for implementing the transfer.
5. Fig. 3.9.1 shows the block diagram that depicts the transfer from  $R_1$  to  $R_2$ . The  $n$  outputs of register  $R_1$  are connected to the  $n$  inputs of



3-14 B (CSIT-Sem.3)

Computer Organization  
Arithmetic shift right, left operation  
R1 R2 0 insert



THE  
WIT

**FIG. 3.12.1.** Right shift operation is as follows:



卷之三

Fig. 3.12.2  
MSB generation:

- Logical shift micro-operation** transfers a 0 (zero) through the serial input, either from left or right depending on the type.

  - i. For logical shift left micro-operation, 0(zero) is transferred through the left of the data and for the logical shift right micro-operation, 0(zero) is transferred through the right of the data as shown in the figure.

Fig. 3.12.3. Register Transfer Language (RTL) for the logical shift micro-operations can be written as :

- $R \leftarrow \text{shl } R$  (shift left register ( $R$ )).
- $R \leftarrow \text{shr } R$  (shift right register ( $R$ )).

Fig. 3.12.3 showing logical shift left micro-operation on the data in a register.



Fig. 3.12.3.

**Fig. 3.12.3.**

**Que 3.13.** What are the different categories of micro-operations that may be carried out by CPU? Explain each category of micro-operations giving one example for each.



Fig. 3.12.6

**Fig. 3.12.5**



Ela 9-12

i. A circular shift micro-operation performs the shifting of bits from one end of the register to the other end of the register.

- iii. Register transfer language for the circular shift micro-operations can be written as :

  - R  $\leftarrow$  cl(R (circular shift left register (R)).
  - R  $\leftarrow$  cir(R (circular shift right register (R)).

Fig. 3.12.5 showing circular shift logic.

R ← cil R (circular shift left by n)

$R \leftarrow \text{cir } R$  (circular shift left register (R)).

IV. Fig. 3.12.5 showing circular shift left micro-operations



Computer Organization & Architecture  
The use of variable length instructions does not remove the desirability of making all of the instruction lengths integrally related to the word length.

It is more efficient, with a combination of register memory addressing modes.

**Disadvantages of using a variable length instructions** which is integrally related to word length.

1. The main disadvantage of instruction length which is integrally related to word length.
2. It does not remove desirability.

**Que 3.17.** Write a short note on RISC.

**AKTU 2014-15, Marks 05**

OR characteristics.

**AKTU 2015-16, Marks 05**

What is RISC ? Explain its various characteristics.

**Answer**  
RISC (Reduced Instruction Set Computer) processor instruction has a fixed length encoding of instruction and each instruction executes in a single clock cycle by hardwired implementation of each instruction.

1. RISC architecture focus on reducing the number of instructions and working with simpler instruction set having limited number of addressing modes and allowing them to execute more instructions in the same amount of time.
2. Programs written for RISC architectures tend to make more space in memory but RISC processor takes to execute its program in less time than a CISC processor.
3. RISC (Reduced Instruction Set Computer) processor instruction has a fixed length encoding of instruction and each instruction executes in a single clock cycle by hardwired implementation of each instruction.
4. Parameter passing through windows.
5. Single-cycle instructions (except for load and store).
6. Hardwired control.
7. Highly pipelined.
8. Simple instructions are few in number.
9. Fixed length instructions.
10. Only load and store instructions can access memory.
11. Few addressing modes.

**RISC characteristics :**

1. Simple instructions are used in RISC architecture.
2. RISC helps and supports few simple data types and synthesizes complex data types.
3. RISC utilizes simple addressing modes and fixed length instructions for pipelining.
4. RISC permits any register to use in any context.

**Que 3.18.** Differentiate between RISC & CISC based microprocessor.

OR

Differentiate between complex instruction set computer and reduced instruction set computer.

OR

### 3-18 B (CSIT-Sem-3)

#### Give the detailed comparison between RISC and CISC.

**AKTU 2016-17, Marks 10**

**Answer**

| S.No. | RISC                                                                           | CISC                                                                            |
|-------|--------------------------------------------------------------------------------|---------------------------------------------------------------------------------|
| 1.    | Multiple register sets, often consisting of more than 256 registers.           | Single register set, often consisting of 6 to 16 registers total.               |
| 2.    | Three register operands allowed per instruction (for example, add R1, R2, R3). | One or two register operands allowed per instruction (for example, add R1, R2). |
| 3.    | Parameter passing through windows.                                             | Parameter passing through inefficient off-chip memory.                          |
| 4.    | Single-cycle instructions (except for load and store).                         | Multiple-cycle instructions.                                                    |
| 5.    | Hardwired control.                                                             | Micro-programmed control.                                                       |
| 6.    | Highly pipelined.                                                              | Less pipelined.                                                                 |
| 7.    | Simple instructions are few in number.                                         | There are many complex instructions.                                            |
| 8.    | Fixed length instructions.                                                     | Variable length instructions.                                                   |
| 9.    | Complexity in compiler.                                                        | Complexity in microcode.                                                        |
| 10.   | Only load and store instructions can access memory.                            | Many instructions can access memory.                                            |
| 11.   | Few addressing modes.                                                          | Many addressing modes.                                                          |

### PART-5

#### Pipelining

Questions-Answers

**Long Answer Type and Medium Answer Type Questions**

**Que 3.19.** What is pipelining ? How the idea of pipelining used in a computer ?

Control Unit

**OR**

**AKTU 2018-19, Marks 3.5**

**Write a short note on pipelining.**

**Answer**

Pipelining is a technique of decomposing a sequential process into sub-operatons, with each sub-process being executed in a special dedicated segment, that operates concurrently by fetching and executing the processor executes a program by fetching and executing instructions, one after the other. execute steps for instruction  $I_1$ .

1. The processor executes a sequence of fetch and execute instructions, one after the other. execute steps for instruction  $I_1$ .
2. Let  $F_i$  and  $E_i$  refer to the fetch and execute steps of a sequence of fetch and execute instructions.
3. Execution of a program consists of a sequence of fetch and execute steps as shown in Fig. 3.19.1.



**Fig. 3.19.1.** Sequential execution.

5. Now consider a computer that has two separate hardware units, one for fetching instructions and another for executing them, as shown in Fig. 3.19.2.
6. The instruction fetched by the fetch unit is deposited in an intermediate storage buffer  $B_i$ .
7. The results of execution are deposited in the destination location specified by the instructions.
8. For these purposes, we assume that both the source and destination of the data operated in by the instructions are inside the block labelled "Execution unit".



**Fig. 3.19.2.** Hardware organization.

9. The computer is controlled by a clock whose period is such that the fetch and execute steps of any instruction can be completed in one clock cycle.
10. Operation of the computer proceeds as in Fig. 3.19.3.



**Fig. 3.19.3.**

11. In the first clock cycle, the fetch unit fetches an instruction  $I_1$  (step  $F_1$ ) and stores it in buffer  $B_1$  at the end of the clock cycle.

**3-20 B (CSIT-Sem-3)**

**AKTU 2018-19, Marks 3.5**

**Write short notes on instruction pipeline.**

12. In the second clock cycle, the instruction fetch unit performs the instruction fetch unit proceeds with the available to it in operation specified by the instruction  $I_1$ , which is available.
13. Instruction  $I_2$  is stored in  $B$  by replacing  $I_1$ , which is no longer needed. While instruction  $I_3$  is being fetched by the third clock cycle, both fetch and execute units are kept busy all the time.

**Que 3.20.** How pipelining is classified?

**Write short notes on instruction pipeline.** OR

**AKTU 2018-19, Marks 3.5**

**Answer**

**Classification of pipeline:**

1. **Arithmetic pipelining:**
  - a. The arithmetic logic units of a computer can be segmentized for pipeline operations in various data format as shown in Fig. 3.20.1. used in the TI-ASC, the up to 14 stages pipeline used in the Cray-1 are the example of arithmetic pipeline.



**Fig. 3.20.1.** Arithmetic pipelining.

2. **Processor pipelining:**

- a. This refers to pipeline processing of the same data stream by a cascade of processors each of which processes a specific task as shown in Fig. 3.20.2.
- b. The data stream passes the first processor with results stored in a memory block, which is also accessible, by the second processor.
- c. The second processor then passes the refine results to the third, and so on.
- d. The pipelining of multiple processors is not yet well accepted as a common practice.



Processor 1

Processor 2

Processor 3

Task 1

Task 2

Task 3

M1

M2

M3

Control Unit

Task 1

Task 2

Task 3

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

**PART-6**

**Hardwired and Micro-programmed Control:**  
Micro-programme Sequencing.

**Questions-Answers**  
**Long Answer Type and Medium Answer Type Questions**

**Que 3.23.** Explain hardwired control unit. What are the methods to design hardwired controllers ?

OR  
**AKTU 2017-18, Marks 3.5**

What do you understand by hardwired control ? Give various methods to design hardwired control unit.

**Answer**  
to design hardwired controllers. What are the methods used for designing of hardwired control unit.

**Hardwired control unit :**  
It is a controller as a sequential logic circuit or a finite state machine that generates a sequence of control signals in response to the externally supplied instructions.

The control logic is implemented with gates, flip-flops, decoders, and other digital circuits.



**Fig. 3.23.1.** General block diagram of hardwired control.

3. A hardwired control requires changes in the wiring among the various components if the design has to be modified or changed.
4. Its input logic signals are transformed into a set of output logic signals are called control signals.
5. Each step in this sequence is completed in one clock cycle.

**3-24 B (CS/IT-Sem-3)**

6. A counter may be used to keep the track of the control steps.  
information :

- a. Contents of the control step counter.
- b. Contents of the instruction register.
- c. Contents of the condition register.
- d. External input signals such as MFC and interrupt requests.

**Methods to design hardwired control :** There are four simplified systematic methods for the design of hardwired controllers.

1. State table method or one-hot method.

2. Delay element method.

3. Sequence-counter method.

4. PLA method.

**PLA method :**

1. PLA (Programmable Logic Array) is an important device of digital system.
2. We can implement a large combinational logic circuit or sequential logic circuit in a PLA.



**Fig. 3.23.2.** PLA control unit.

3. It replaces more number of MSI (Medium Scale Integration) andSSI (Small Scale Integration) by its single device chip.
4. The decision logic function and decoder functions are implemented in the Programmable Logic Array (PLA).
5. It is possible to reduce the number of ICs and the number of interconnection wires. The PLA output is the next state of the sequence register.

**Que 3.24.** Discuss the basic structure of micro-program control unit.

OR

Explain micro-programmed control unit.

**Answer**

1. Micro-programmed control is a method of control unit design in which the control signal selection and sequencing information is stored in a ROM or RAM called a Control Memory (CM).



**Computer programmed control unit and its structure :** Refer

- Answer**  
Micro-programmed control unit-3.  
Q. 3.24. Page 3-24B. Unit-3.
- Micro-instruction formats:** The micro-instruction format for the control memory is shown in the Fig. 3.26.1.

**Fig. 3.26.1. Micro-instruction format.**

The 20 bits of the micro-instruction are divided into four functional parts as follows:

1. The three fields F1, F2, and F3 specify micro-operations for the computer.
2. The three fields are subdivided into three fields of three bits each. The three bits in each field are encoded to specify seven distinct micro-operations. So, this gives a total of 21 micro-operations.
3. The CD field specifies the type of branch to use.
4. The BR field contains a branch address. The address field is seven bits wide since the control memory has  $128 = 2^7$  words.

**Organization of micro-programmed control unit :**  
The general configuration of a micro-programmed control unit is demonstrated in the block diagram of Fig. 3.26.2.

1. The control memory is assumed to be a ROM, within which all control information is permanently stored.
2. The control memory is read by the control data register.
3. The control data register is connected to the control address register.
4. The control address register is connected to the next address generator.
5. The next address generator is connected to the control memory.
6. While the micro-operations are being executed, the next address is computed in the next address generator circuit and then transferred into the control address register to read the next micro-instruction.

**Fig. 3.26.2. Micro-programmed control organization.****3-28 B (CS/IT-Sem-3)** Control Unit

7. Thus a micro-instruction contains bits for initiating micro-operations for the control memory.
8. The next address generator is sometimes called a micro-program sequencer, as it determines the address sequence that is read from control memory.
9. Typical functions of a micro-program sequencer are incrementing the address from control memory, transferring the control address register loading an initial address to start the control address, or control address register by one, loading into the control address register the next address is computed and read from memory.
10. The control data register holds the present micro-instruction while the next address is computed and read from memory.

**Que 3.27.** Explain micro-program sequencer with block diagram.

Write a short note on micro-program sequencer for control memory.

Or

Explain micro-program sequencer for a control memory using a suitable block diagram.

OR

What is a micro-program sequencer ? With block diagram, explain the working of micro-program sequencer.

**AKTU 2018-19, Marks 07**

**Answer**

1. Micro-program sequencer is a general purpose building block for micro-programmed control unit.
2. The basic components of a micro-programmed control unit are the control memory and the circuit that selects the next address.
3. The address selection part is called micro-program sequencer.
4. The main purpose of micro-program sequencer is to present an address to the control memory so that micro-instruction may be read and executed.
5. The next address logic of the sequencer determines the specific address source to be loaded into the control address register.
6. The choice of the address source is guided by the next address information bits that sequencer receives from the present micro-instruction.
7. All the instructions are loaded in the control memory.



**Fig. 3.27.1.** Block diagram of micro-programmed control with micro-program sequencer.

8. The present micro-instruction is placed in micro-instruction register for execution.

| S.No. | Horizontal Organization                          | Vertical Organization                                 |
|-------|--------------------------------------------------|-------------------------------------------------------|
| 1.    | Long format.                                     | Short format.                                         |
| 2.    | Ability to express a high degree of parallelism. | Limited ability to express parallel micro-operations. |
| 3.    | Little encoding of control information.          | Considerable encoding of the control information.     |
| 4.    | Useful when higher operating speed is desired.   | Slower operating speed.                               |

**Que 3.28.** Describe micro-program sequencing in detail.

**Answer**

1. Micro-program sequencing is a process of controlling the generation of next address.
2. Micro-program sequencing is done with the help of micro-program sequencer.
3. A micro-program sequencer attached to a control memory inputs certain bits of the micro-instruction, from which it determines the next address for control memory.
4. A typical sequencer provides the following address-sequencing capabilities:
  - a. Increment the present address for control memory.
  - b. Branches to an address as specified by the address field of the micro-instruction.

- c. Branches to a given address if a specified status bit is equal to 1.
- d. Transfer control to a new address as specified by an external source (Instruction Register).
- e. Has a facility for subroutine calls and returns.
5. Depending on the current micro-instruction condition flags, and the contents of the instruction register, a control memory address must be generated for the next micro-instruction.

### PART-7 Concept of Horizontal and Vertical Micro-programming.

#### Questions-Answers

#### Long Answer Type and Medium Answer Type Questions

**Que 3.29.** Explain the concept of vertical and horizontal multi-programming.

**Answer**

#### Vertical micro-programming :

1. In the case of vertical micro-programming, each line of the micro-program represents a micro-instruction which specifies one or more micro-operations.
2. One micro-instruction gets executed during each step of the control sequence. One can use a straight binary code to specify each micro-operation.
3. Rather than provide for only one micro-operation per step and use a single decoder for the entire micro-instruction field, it is in fact possible to partition this field into a number of mutually exclusive subfields which can be independently decoded in separate decoder.

4. This approach yields a more cost-effective design. If the system design needs in all a total of  $N$  different micro-operations one will have to provide for  $\log_2 N$  bit to specify a micro-operation.
5. If only one micro-operation per micro-instruction is allowed, then one would require  $\log_2 N$  bit per micro-instruction.

#### Horizontal micro-programming :

1. In horizontal micro-programming, one associates each bit of the micro-instruction with a specific micro-operation (bit  $I$  to represent micro-operation  $D_I$ ).
2. A specific micro-operation is executed during a micro-instruction step only if the corresponding bit is one.

- Computer Organization & Architecture
- For instance, micro-operation  $I$  is executed if the  $I$ th bit is one; it is not executed otherwise.
3. A micro-code decoder will no longer be required in this case because no coding is involved.
  4. This scheme will require a total of  $N$  bits per micro-instruction (to accommodate  $N$  different micro-operations).
  5. The advantage with horizontal micro-programming is that several micro-operations can be executed during each micro-instruction step.
  6. In fact, this scheme permits one to execute all the micro-operations provided in the computer in a single micro-instruction.

**Que 3.30.** Briefly define the following terms :

- i. Micro-operation
- ii. Micro-instruction
- iii. Micro-program
- iv. Micro-code

**AKTU 2015-16, Marks 10**

**Answer**

- i. Micro-operation : Micro-operation is a set of operations that the processor unit has to perform to execute the major phases of instruction cycle.
- ii. Micro-instructions : The instruction cycle has three major phases of fetch, decode and execute.
- iii. Micro-program : The primary function of a CPU is to execute sequence of instructions which is in accordance with the instruction cycle.

- iv. Micro-instructions : Micro-instructions are the individual control words in the micro routine.
- v. Control memory : This contains the control signals for sequencing information.

- vi. Micro-program : Micro-program is a micro-code in a particular processor implementation. Writing micro-code is often called micro-programming.

**Answer**

1. Micro-operation : Micro-operation is a layer of hardware-level instructions and/or data structures involved in the implementation of higher level machine code instructions in many computers and other processors.
2. It helps to separate the machine instructions from the underlying electronics so that instructions can be designed and altered more freely.

**v. Control memory :**

1. Control memory is a Random Access Memory (RAM) consisting of addressable storage registers.

2. It is used as a temporary storage for data.
3. Access to control memory data requires less time than to main memory, this speeds up CPU operation.

**Que 3.31.** Write an assembly level program for the following pseudo code :

SUM = 0  
SUM = SUM + A + B  
DIF = DIF - C  
  
SUM = SUM + DIF

**AKTU 2016-17, Marks 10**

**Answer**

|         |                        |
|---------|------------------------|
| CLA     | /SUM = 0               |
| STA SUM | /Load current sum      |
| LDA SUM | /Add A to SUM          |
| ADD A   | /Add B to SUM          |
| ADD B   | /Save SUM              |
| STASUM  | /Load C to AC          |
| LDA C   | /Create 2's complement |
| CMA     | /Subtract C from DIF   |
| INC     | /Add SUM to DIF        |
| ADD DIF | /Save SUM              |
| STA DIF | /Add SUM to DIF        |
| ADD SUM | /Save SUM              |
| STA SUM | /Halt                  |
| HLT     |                        |

**Que 3.32.** Explain 4-bit incrementer with a necessary diagram.

**AKTU 2016-17, Marks 15**

**Answer**

1. The diagram of a 4-bit combinational circuit incrementer is shown in Fig. 3-32.1.
2. One of the inputs to the least significant Half Adder (HA) is connected to logic-1 and the other input is connected to the least significant bit of the number to be incremented.
3. The output carry from one half-adder is connected to one of the inputs of the next-higher-order half-adder.
4. The circuit receives the four bits from  $A_0$  through  $A_3$  adds one to it, and generates the incremented output in  $S_0$  through  $S_3$ .
5. The output carry  $C_4$  will be 1 only after incrementing binary 1111. This also causes outputs  $S_0$  through  $S_3$  to go to 0.
6. This micro-operation is easily implemented with a binary counter.



Fig. 3.32.1. 4-bit binary incrementer.

7. Every time the count enable is active, the clock pulse transition increments the content of the register by one.
8. There may be occasions when the increment micro-operation must be done with a combinational circuit independent of a particular register.
9. This can be accomplished by means of halfadders connected in cascade.

**Que 3.33.** Write a program loop using a pointer and a counter to clear the contents of hex locations 500 to 5FF with 0.

**AKTU 2016-17, Marks 15**

**Answer**

```

LDA NBR          / Initialize counter
                 / 2's complement of NBR INC
CMA             / save -NBR to counter
STA CTR          / Save start address
LDA ADR          / Initialize pointer PTR
STA PTR          / Clear AC
ISZ PTR          / Reset memory word
LOP, CLA         / Increment pointer
ISZ PTR          / increment counter
BUN LOP          / Branch to LOP (CTR < 0)
HLT             / Halt when CTR = 0
NBR, HEX FF      / NBR of cleared words
CTR, -           / Counter
ADR, HEX 500     / Start address
PTR, -           / Pointer

```

**Que 3.34.** Demonstrate the process of second pass of assembler using a suitable diagram.

**AKTU 2016-17, Marks 15**

- Answer**
1. Machine instructions are translated during the second pass by means of table-lookup procedures.
  2. A table-lookup procedure is a search of table entries to determine whether a specific item matches one of the items stored in the table.
  3. The assembler uses four tables.
  4. Any symbol that is encountered in the program must be available as an entry in one of these tables; otherwise, the symbol cannot be interpreted.



Fig. 3.34.1.

Q. 5. We assign the following names to the four tables:

a. Pseudo instruction table

b. MRI table

c. Non-MRI table

d. Address symbol table

Q. 6. The entries of the pseudo instruction table are the four symbols ORG, END, DEC, and HEX.

Q. 7. Each entry refers the assembler to a subroutine that processes the pseudo instruction when encountered in the program.

Q. 8. The MRI table contains the seven symbols of the memory-reference instructions and their 3-bit operation code equivalent.

Q. 9. The non-MRI table contains the symbols for the 18 register-reference and input-output instructions and their 16-bit binary code equivalent.

Q. 10. The assembler searches these tables to find the symbol that it is currently processing in order to determine its binary value.

### VERY IMPORTANT QUESTIONS

*Following questions are very important. These questions may be asked in your SESSIONALS as well as UNIVERSITY EXAMINATION.*

### 3-36 B (CSIT-Sem-3)

Q. 6. In an instruction format, there are 16 bits in an instruction word. Bit 0 to 11 convey the addresses of the memory location for memory related instructions. For non memory operations, these bits convey various register or I/O operations such as ADD, AND, LDA etc. Bit 15 shows if the instruction format draw block diagram of the control unit of a computer and briefly explain how an instruction will be decoded and executed, by this control unit.

Ans. Refer Q. 3.7.

Q. 6. List and explain different types of shift micro-operation.

Ans. Refer Q. 3.12.

Q. 7. What are the different categories of micro-operations that may be carried out by CPU ? Explain each category of micro-operations giving one example for each.

Ans. Refer Q. 3.13.

Q. 8. What is CISC ? Explain its characteristics.

Ans. Refer Q. 2.15.

Q. 9. What is RISC ? Explain its various characteristics.

Ans. Refer Q. 3.17.

Q. 10. Give the detailed comparison between RISC and CISC.

Ans. Refer Q. 3.18.

Q. 11. Write a short note on pipelining.

Ans. Refer Q. 3.19.

Q. 12. Explain the basic concept of hardwired and software control unit with neat diagrams.

Ans. Refer Q. 3.25.

Q. 13. What is micro-programmed control unit ? Give the basic structure of micro-programmed control unit. Also discuss the micro-instruction format and the control unit organization for a typical micro-programmed controllers using suitable diagram.

Ans. Refer Q. 3.26.

Q. 14. Write a short note on micro-program sequencer for control memory.

Ans. Refer Q. 3.27.

Q. 4. Write the steps in fetching a word from memory. Differentiate between a branch instruction and call subroutine instruction.

Ans. Refer Q. 3.5.

Computer Organization & Architecture

**Q. 15.** Briefly define the following terms:

- Micro-operation
- Micro-instruction
- Micro-program
- Micro-code
- Control memory

**Q. 16.** Write an assembly level program for the following pseudo code:

$$\begin{aligned} \text{SUM} &= 0 \\ \text{SUM} &= \text{SUM} + A + B \\ \text{DIF} &= \text{DIF} - C \\ \text{SUM} &= \text{SUM} + \text{DIF} \end{aligned}$$

**Ans:** Refer Q. 3.31.

**Q. 17.** Explain 4-bit incrementer with a necessary diagram.

**Ans:** Refer Q. 3.32.

**Q. 18.** Write a program loop using a pointer and a counter to clear the contents of hex locations 500 to 5FF with 0.

**Ans:** Refer Q. 3.33.

**Q. 19.** Demonstrate the process of second pass of assembler using a suitable diagram.

**Ans:** Refer Q. 3.34.



## Memory

### CONTENTS

|                 |                                                                                                                                   |                |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------|----------------|
| <b>Part-1 :</b> | Memory : Basic Concept .....                                                                                                      | 4-2B to 4-3B   |
| <b>Part-2 :</b> | Semiconductor RAM .....                                                                                                           | 4-3B to 4-6B   |
| <b>Part-3 :</b> | 2D & 2½ D Memory .....                                                                                                            | 4-5B to 4-7B   |
| <b>Part-4 :</b> | ROM Memories .....                                                                                                                | 4-7B to 4-12B  |
| <b>Part-5 :</b> | Cache Memories : .....<br>Concept and Design<br>Issues and Performance                                                            | 4-12B to 4-14B |
| <b>Part-6 :</b> | Address Mapping .....<br>and Replacement                                                                                          | 4-14B to 4-21B |
| <b>Part-7 :</b> | Auxiliary Memories : .....<br>Magnetic Disk,<br>Magnetic Tape<br>and Optical Disks,<br>Virtual Memory :<br>Concept Implementation | 4-21B to 4-28B |

**Computer Organization & Architecture****4-3 B (CSIT-Sem-3)****Memory : Basic Concept and Hierarchy.**

**Memory hierarchy is layered into these layers :**

- Registers : Internal register in a CPU and temporary results. Internal registers are used for holding variables however they can be accessed instantly.
- Cache memory : Cache is used by the CPU for holding data in the memory which is being accessed over and over again. It acts as a buffer between the CPU and the main memory.

**Main memory :**

- Main memory is large and fairly fast external memory which stores active data and programs.
- Storage location in memory is directly addressed by the CPU's load and store instructions.

**Secondary/auxiliary memory :**

- Access time is larger because of its large capacity and as it is physically separated from the CPU.
- It stores large data files, programs and files that will not be required continuously by the CPU.
- It also acts as an overflow memory when the capacity of the main memory exceeded.

**Que 4.2. Why is memory system of a computer organized as a hierarchy ? Discuss the basic elements of a memory hierarchy.****Answer**

- The memory hierarchy system consists of all storage devices employed in a computer system from the slow but high capacity auxiliary memory to a relatively faster main memory, to as even smaller and faster cache memory accessible to the high speed processing logic.
- Fig. 4.1.1 shows the typical memory hierarchy. All the memory devices are shown in the Fig. 4.1.1.

**Fig. 4.1.1. Memory hierarchy.****PART-1****Questions-Answers****Long Answer Type and Medium Answer Type Questions****Memory : Basic Concept and Hierarchy.****Que 4.1. Explain concept of memory. Describe memory hierarchy.****Answer**

- The memory of a computer holds (stores) program instructions (what to do), data (information), operand (manipulated or operated upon data), and calculations (ALU results).
- The CPU controls the information stored in memory.
- Information is fetched, manipulated (under program control) and written (or written back) into memory for immediate or later use.
- The internal memory of a computer is also referred to as main memory, global memory, main storage.
- The secondary or auxiliary memory (also called mass storage) is provided by various peripheral devices.

**Memory hierarchy :**

- The memory hierarchy system consists of all storage devices employed in a computer system from the slow but high capacity auxiliary memory to a relatively faster main memory, to as even smaller and faster cache memory accessible to the high speed processing logic.
- Fig. 4.1.1 shows the typical memory hierarchy. All the memory devices are shown in the Fig. 4.1.1.

**Semiconductor RAM Memories.****Questions-Answers****Long Answer Type and Medium Answer Type Questions****PART-2****Questions-Answers****Long Answer Type and Medium Answer Type Questions**

**Que 4.3.** Explain semiconductor RAM. Enlist the types of semiconductor memory.

OR

Explain dynamic RAM and static RAM.

**Answer**

**Semiconductor RAM:**

1. Semiconductor Random Access Memory (RAM) is a form of computer data storage which stores frequently used program instructions to increase the general speed of a system.
2. A random access memory device allows data items to be read or written in almost the same amount of time irrespective of the physical location of data inside the memory.

Types of semiconductor RAM are :

**1. DRAM :**

- a. Dynamic RAM is a form of random access memory.
- b. DRAM uses a capacitor to store each bit of data, and the level of charge on each capacitor determines whether that bit is a logical 1 or 0.
- c. However these capacitors do not hold their charge indefinitely, and therefore the data needs to be refreshed periodically.
- d. DRAM is the form of semiconductor memory that is often used in equipment including personal computers and workstations where it forms the main RAM for the computer.

- 2. SRAM:**
- a. Static Random Access Memory is a semiconductor memory in which, the data does not need to be refreshed dynamically.
  - b. SRAM is volatile in nature.
  - c. It consumes more power, is less dense and more expensive than DRAM.
  - d. SRAM is used for cache memory.

**Que 4.4.** Give the structure of commercial 8M × 8 bit DRAM chip.

**AKTU 2017-18, Marks 07**

**Answer**



Fig. 4.4.1. Structure of a commercial 8M × 8-bit DRAM chip.

**PART-3**  
2D & 2½ D Memory Organization.

**Questions-Answers**

| Long Answer Type and Medium Answer Type Questions |
|---------------------------------------------------|
|---------------------------------------------------|

**Que 4.5.** Explain 2D, 2½ D memory organization.

**4-6 B (CSIT-Sem-3)****4-7 B (CSIT-Sem-3)**

**OR**  
**Write short note on organization of 2D and 2.5D memory**  
**AKTU 2014-15, Marks 05**

8. During a write operation, the sense/write circuits receive or write input information from the data lines and store it in the selected cells.

**Answer****2D organization :**

1. The cells are organized in the form of a two-dimensional array with rows and columns.
2. Each row refers to word line. Each column in the array refers to a bit line.

Bit lines (complement to each other)



**Fig. 4.5.1. 2D organization of a memory chip of size  $16 \times 4$ .**

1. The Memory Address Register (MAR) holds the address of the location where read/write operation is executed. In Fig. 4.5.1, MAR has 4-bit lines.
2. The content of MAR is decoded by an address decoder on the chip to activate each word line.
3. The cells in each column are connected to a sense/write circuit by two bit lines. Two bit lines are complement to each other.
4. The sense/write circuits are activated by the Chip Select (CS) lines. The sense/write circuits are connected to the data lines of the chip.
5. During a read operation, these circuits sense or read the information stored in the cells selected by a word line and transmit this information to the data lines.



**Fig. 4.5.2. 2.5D organization.**

1. In 2.5D organization there exists a segment.
2. The content of MAR is divided into two parts -  $x$  and  $y$  number of bits.
3. The number of segments  $S$  is equal to  $2^y$ .
4.  $X = 2^x$  drive lines are fed into the cell array and  $y$  number of bits decode one bit line out of  $S$  lines fed into a segment of the array. In total, there are  $Sb$  number of bit lines for a  $b$  bit per word memory.
5. Thus for any given address in the MAR, the column decoder decodes  $b$  out of  $Sb$  bit lines by using the  $y$  bits of the MAR while a particular word line is activated by using the  $x$  bits.
6. Thus only the  $b$  numbers of bits in the array are accessed by enabling the word line and  $b$  number of bit lines simultaneously.
7. Though 2.5D organized memory may need lesser chip decoding logic, it suffers from one drawback. With high density chips, a simple failure, such as external pin connection opening or a failure on one bit can render the entire chip inoperative.

**PART-4****ROM Memories****Questions-Answers****Long Answer Type and Medium Answer Type Questions**

**Que 4.6.** What is ROM ? Explain the types of ROM.

OR

Explain the semiconductor based ROM memories.

**Answer:**

**ROM :**

- The Read Only Memory is a type of semiconductor memory that is designed to hold data that is either permanent or will not change frequently. It is also known as non-volatile memory.

**Types of ROM:**

i. **Programmable read only memory (PROM) :**

- It is one-time programmable ROM (OTP) and can be written to or programmed via a special device called a PROM programmer.
- Typically, this device uses high voltages to permanently destroy or create internal links (fuses or antifuses) within the chip.
- Consequently, a PROM can only be programmed once.

ii. **Erasable programmable read only memory (EPROM) :**

- It can be erased by exposure to strong ultraviolet light (typically for 10 minutes or longer), then rewritten with a process that again requires application of higher than usual voltage.
- Repeated exposure to UV light will eventually wear out an EPROM, but the endurance of most EEPROM chips exceeds 1000 cycles of erasing and reprogramming.
- EPROM chip packages can often be identified by the prominent quartz "window" which allows UV light to enter.
- After programming, the window is typically covered with a label to prevent accidental erasure.
- Some EEPROM chips are factory-erased before they are packaged, and include no window, these are effectively PROM.

iii. **Electrically erasable programmable read only memory (EEPROM) :**

- It is based on a similar semiconductor structure to EPROM, but allows its entire contents (or selected banks) to be electrically erased, then rewritten electrically, so that they need not be removed from the computer (or camera, MP3 player, etc.).

b. Writing or flashing an EEPROM (bit) than reading from a ROM is much slower (milliseconds per in both cases).

iv. **Mask programming :**

- It is done by the company during fabrication process of the unit.
- The procedure for fabricating a ROM requires that the customer fills out the truth table he wishes the ROM to satisfy.

**Que 4.7.** How main memory is useful in computer system ? Explain the memory address map of RAM and ROM.

**AKTU 2016-17, Marks 15**

**Main memory is useful in computer system :**

- The main memory occupies a central position in a computer system.
- It is able to communicate directly with the CPU and with auxiliary memory devices through an I/O processor.
- It is relatively large and fast.

**Memory address map of RAM and ROM :**

- Memory address map is a pictorial representation of assigned address space for each chip in the system.
- To demonstrate with a particular example, assume that a computer system needs 512 bytes of RAM and 512 bytes of ROM.
- The RAM and ROM chips to be used are specified in Fig. 4.7.1. The memory address map for this configuration is shown in Table 1.
- The component column specifies whether a RAM or a ROM chip is used. The hexadecimal address column assigns a range of hexadecimal equivalent addresses for each chip. The address bus lines are listed in the third column.
- The selection between RAM and ROM is achieved through bus line 10. The RAMs are selected when the bit in this line is 0, and the ROM when the bit is 1.



Table 4.7.1: Memory address map.

| Component | Hexadecimal Address | Address bus           |
|-----------|---------------------|-----------------------|
|           |                     | 10 9 8 7 6 5 4 3 2 1  |
| RAM1      | 0000-007F           | 0 0 0 x x x x x x x x |
| RAM2      | 0080-00FF           | 0 0 1 x x x x x x x x |
| RAM3      | 0100-017F           | 0 1 0 x x x x x x x x |
| RAM4      | 0180-01FF           | 0 1 1 x x x x x x x x |
| ROM       | 0200-03FF           | 1 x x x x x x x x x x |

Fig. 4.7.1.

6. The x under the address bus lines designate those lines that must be connected to the address inputs in each chip.
7. The RAM chips have 128 bytes and need seven address lines.
8. The ROM chip has 512 bytes and need 9 address lines.
9. It is now necessary to distinguish between four RAM chips by assigning 16 KB ? Explain in words how the chips are to be connected to the address bus.

**Answer** A computer uses RAM chips of 1024\*1 capacity.

- i. How many chips are needed and how should their address lines be connected to provide a memory capacity of 1024\*8?
- ii. How many chips are needed to provide a memory capacity of 16 KB ? Explain in words how the chips are to be connected to the address bus.

AKTU 2015-16, Marks 10

$$\text{Required memory capacity} = 1024 \text{ bytes}$$

$$\text{Number of chips required} = \frac{1024 \times 8}{1024 \times 1} = 8 \text{ chips}$$

So, 8 chips are needed with address line connected in parallel.

- To provide a memory capacity of 16K bytes, chips required are  $16 \times 8 = 128$  chips

Number of address line for 16 K = 14 ( $16 K = 2^{14}$ )

So, 14 lines to specify chip address.

- Que 4.9.** A ROM chip of 1024\*8 has four select inputs and operates from a 5 volt power supply. How many pins are needed for the IC package ? Draw a block diagram and label all input and output terminals in the ROM.

AKTU 2015-16, Marks 10

- Size of ROM Chip =  $1024 \times 8$
- Number of input = 10 pin [ $2^{10} = 1024$ ]
- Number of output = 8 pin
- Number of chip select = 4 pin
- Power = 2 pin
- Total 24 pins are required.

**Questions Answers**
**Long Answer Type and Medium Answer Type Questions**

Que 4.11.

**Que 4.11.** Write short note on cache memory.

**Answer**

1. Cache memory is a small-sized type of volatile computer memory that provides high-speed data access to a processor and stores frequently used computer programs, applications and data.
2. It stores and retains data only until a computer is powered up.
3. Cache memory provides faster data storage and access by storing an instance of programs and data routinely accessed by the processor.

4. Thus, when a processor requests data that already has an instance in the cache memory, it does not need to go to the main memory or the hard disk to fetch the data.
5. Cache memory can be primary or secondary cache memory, where primary cache memory is directly integrated or closest to the processor.
6. In addition to hardware-based cache, cache memory also can be a disk cache, where a reserved portion on a disk stores and provide access to frequently accessed data/applications from the disk.

**Que 4.12.** Discuss the design issues in cache design.

**Answer**

The primary elements having strong influence on cache design are :

- i. Cache size : There are two important factor in deciding cache size at the time of its design.
  - a. Size should be small enough so that its cost is very close to the main memory.
  - b. Size should be large enough so that most of the memory reference should be available in the cache so that average access time will be close to cache alone.
- ii. Block size :
  - a. Block size of cache is an important factor in cache performance.
  - b. Larger block size could store the desired word as well as some adjacent word also. As a result hit ratio will increase automatically.
  - c. A small block size result in frequent replacement of data shortly after it is fetched increasing the overhead in cache operation.

**PART-5**

*Cache Memories : Concept and Design Issues and Performance,*



Fig. 4.9.1.

- d. As the block size increases from smaller to larger, the hit ratio will increase first and on increasing the block size further the hit ratio began to decrease.

iii. **Associativity:** It is a basic tradeoff between parallel searching versus constraints on which addresses can be stored.

iv. **Write strategy:** Its main concern is related to when do we write cache contents to main memory.

**Que 4.13:** How the performance of cache memory is measured?

### Answer

1. The performance of cache memory is frequently measured in terms of a quantity called hit ratio.
2. When the CPU refers to memory and finds the word in cache, it is said to produce a hit.
3. If the word is not found in cache, it is in main memory and it counts as a miss.
4. The ratio of the number of hits divided by the total CPU references to memory (hits plus misses) is the hit ratio.
5. The hit ratio is best measured experimentally by running representative programs in the computer and measuring the number of hits and misses during a given interval of time.

### PART-6

#### Address Mapping and Replacement.

### Answer

#### Cache mapping :

1. Cache mapping is the method by which the contents of main memory are brought into the cache and referenced by the CPU. The mapping method used directly affects the performance of the entire computer system.
2. Mapping is a process to discuss possible methods for specifying where memory blocks are placed in the cache. Mapping function dictates how the cache is organized.

**Types of mapping :**

1. **Direct mapping:**
  - a. The direct mapping technique is simple and inexpensive to implement.



Fig. 4.41



Fig. 4.42

**Que 4.14:** What is meant by cache mapping? What are different types of mapping? Discuss different mapping techniques with examples.

OR

Discuss the various types of address mapping used in cache memory.

**AKTU 2017-18, Marks 07**

- b. When the CPU wants to access data from memory, it places an address. The index field of CPU address is used to access address in the word read from the cache.
- c. The tag field of CPU address is compared with the associated tag in the word read from the cache.
- d. If the tag bits of CPU address are matched with the tag bits of cache, then there is a hit and the required data word is read from cache.
- e. If there is no match, then there is a miss and the required data word is stored in main memory. It is then transferred from main memory to cache memory with the new tag.

### 2. Associative mapping:

- a. An associative mapping uses an associative memory.
- b. This memory is being accessed using its contents.
- c. Each line of cache memory will accommodate the address (main memory) and the contents of that address from the main memory.
- d. That is why this memory is also called Content Addressable Memory (CAM). It allows each block of main memory to be stored in the cache.



Fig. 4.14.3.

### 3. Set associative mapping :

- a. In set associative mapping, each cache location can have more than one pair of tag + data items.
- b. It combines the best of the direct mapping cache and the more flexible mapping of the fully associative cache.
- c. That is more than one pair of tag and data are residing at the same location of cache memory. If one cache location is holding two pair of tag + data items, that is called 2-way set associative mapping.

| Main memory | Cache memory |      |       |      |      |
|-------------|--------------|------|-------|------|------|
| Address     | Tag          | Data | Index | Tag  | Data |
| 00 000 5670 | 00           | 5670 | 000   | 01   | 1256 |
| 00 666 7523 | 00           | 666  | 01    | 5321 | ..   |
| 01 000 1256 | 00           | 1256 | 02    | 6520 | ..   |
|             | 00           | 7523 | 03    | 2771 | ..   |
|             | 00           | 7523 | 51    | 1560 | 677  |
|             | 77           | 5423 | 77    | 5423 | 41   |
|             | 77           | 5423 | 77    | 66   | 2560 |
|             | 77           | 5423 | 66    | 4423 | ..   |

Fig. 4.14.4.

### Ques 4.15. What do you mean by cache memory ? How does it affect the performance of the computer system ?

associative cache is used in computer in which the real memory size  $2^{32}$  bytes. The line size is 16 bytes, and there are  $2^{10}$  lines per set. Calculate the cache size and tag length.

### Answer

Cache memory : Refer Q. 4.11, Page 4-13B, Unit-4.

### Cache affect the performance as follows :

1. The CPU to work at its maximum efficiency, the data transfer from the other hardware must be as fast as its speed. The purpose of a cache is to ensure this smooth and fast transition of data transfer from the hardware to the CPU.
2. As CPU speed increased to the point where the RAM is no longer able to catch up, the transferring of information again become a serious problem. To solve this issue, a cache, which was effectively a small and extremely fast memory, was added to the processor to store immediate instruction from the RAM. Since the cache runs at the same speed of the CPU, it can rapidly provide information to the CPU at the shortest time without any delay.

### Numerical :

Given, Main memory size =  $2^{32}$  bytes =  $2^{35}$  bits

$$\text{Line size} = \text{Block size} = 16 \text{ bytes} = 2^7 \text{ bits}$$

$$\text{Lines/sets} = 2^{10}$$

Since, 8-way set associative so, cache have 8 set

No. of set = 8

Total no. of lines = No. of sets × No. of lines/set  
 $= 8 \times 2^{10} = 213$

Cache size = No. of sets × No. of lines/set × size of line  
 $= 8 \times 2^{13} \times 2^7 \text{ bits} = 2^{23} \text{ bits}$   
 $= 8 \text{ MBytes}$



$$\text{Block offset} = \log_2 (\text{line size}) = \log_2 (2^7) = 7 \text{ bits}$$

$$\text{No. of set} = 8$$

$$\text{Physical address (PA)} = 35$$

$$\begin{aligned}\text{Tag size} &= \text{PA} - (\text{Block offset} + \text{No. of set}) \\ &= 35 - (7 + 8)\end{aligned}$$

$$\begin{aligned}\text{Tag size} &= 20 \text{ bit} \\ k &= 35 - (7 + 8) \\ &= 35 - 15 \\ &= 20\end{aligned}$$

**Que 4.16.** Consider a cache uses a direct mapping scheme. The size of main memory is 4 K bytes and word size of cache is 2 bytes. The size of cache memory is 128 bytes. Find the following:  
 i. The size of main memory address (assume each byte of main memory has an address)  
 ii. Address of cache block  
 iii. How many memory location address/block/location ?  
 iv. How can it be determined if the content of specified main memory address in cache ?

**AKTU 2014-15, Marks 10**

**Answer**  
 Given, Size of main memory = 4 K bytes  
 Size of cache memory = 128 bytes  
 Word size of cache = 2 bytes  
 Block size = 4 words  
 Cache size = 2048 words  
 Set size of 2 cache can accommodate =  $2048/2 = 1024$  words of cache

|       |     |       |
|-------|-----|-------|
| 7-bit | TAG | INDEX |
|-------|-----|-------|

ii.

Size of cache memory =  $1024 \times 2 (7 + 32) = 1024 \times 78$

**Que 4.18.** What is the distinction between spatial locality and temporal locality ?

**Answer**  
 Given, Size of main memory address :  
 Since, size of main memory =  $4 \text{ K bytes} = 2^{12} \text{ bytes}$   
 So, the size of main memory address = 12  
 ii. Address of cache block :  
 Since, size of cache memory = 128 bytes  
 Block size = word size of cache = 2 bytes  
 $\therefore$  Number of lines =  $\frac{128}{2} = 64$

So, address of cache block is from 0 to 63  
 iii. Since, size of main memory = 4 K bytes  
 $4 \text{ K bytes} = 4096 \text{ bytes}$

So, number of block in main memory = 4096 bytes  
 and number of block in cache = 64  
 and each block of cache = 2 bytes

$$\text{So, } \left( \frac{4096}{(64 \times 2)} \right) = 32 \text{ memory location address will be translated to cache address/block/location.}$$

iv. We can determine the content of specified main memory address in cache using this :

$$\begin{aligned}i &\bmod 2^4 \\ k &= \text{line number}\end{aligned}$$

where,

**Que 4.17.** A two way set associative cache memory uses blocks of 4 words. The cache can accommodate a total of 2048 words from memory. The main memory size is 128 K × 32.  
 i. Formulate all pertinent information required to construct the cache memory.

ii. What is the size of the cache memory ?

**AKTU 2018-19, Marks 07**

**Answer**  
 i. Main memory size =  $128K \times 32 = 2^{17}$

Cache size = 2048 words

Block size can accommodate =  $2048/2 = 1024$  words of cache



ii.

Size of cache memory =  $1024 \times 2 (7 + 32) = 1024 \times 78$

**Que 4.18.** What is the distinction between spatial locality and temporal locality ?

**AKTU 2015-16, Marks 7.5**

Computer Organization & Architecture

- d. The problem with write back is that portions of main memory are invalid and hence accesses by I/O modules can be allowed only through the cache.

**4-21 B (CSE/T.Sem-3)**

| S.No. | Spatial locality                                                                                                                                                                   | Temporal locality                                                                                                                                            |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1.    | Spatial locality refers to the tendency of execution to involve a number of memory locations that are clustered.                                                                   | Temporal locality refers to the tendency for a processor to access memory locations that have been used recently.                                            |
| 2.    | The spatial locality means that instructions stored near by to the recently executed instructions are also likely to be executed soon.                                             | The temporal locality means that a recently executed instruction is likely to be executed again very soon.                                                   |
| 3.    | The spatial aspect suggests that instead of bringing just one item from the main memory to the cache, it is wise to bring several items that reside at adjacent addresses as well. | The temporal aspect of the locality reference suggests that instruction and data of needed, this information will hopefully remain until it is needed again. |

- a. With write back, updates are made only in the cache.

- c. When an update occurs, an UPDATE bit associated with the slot is set. Then, when a block is replaced it is written back to main memory if and only if the UPDATE bit is set.

Que 4.20. Explain replacement algorithm in brief.

**Answer**

When a main memory block needs to be brought in while all the cache memory blocks are occupied, one of them has to be replaced. The replacement algorithms are given as follows:

1. **Optimal replacement :**
  - a. In this policy, replace the block which is no longer needed in the future.
  - b. If all blocks currently in cache memory will be used again, replace the one which will not be used.
  - c. The optimal replacement is obviously the best but is not realistic, simply because when a block will be needed in the future is usually not known ahead of time.
2. **LRU (Least Recently Used) :**
  - a. In this policy, replace the block in cache memory that has not been used for the longest time, i.e., the least recently used (LRU) block.
  - b. The LRU is sub-optimal based on the temporal locality of reference, i.e., memory items that are recently referenced are more likely to be referenced soon than those which have not been referenced for a longer time.

**Que 4.19. Write short note on write through and write back policy of cache memory.**

**Answer**

**Writing policy of cache memory:**

i. **Write through :**

- a. This is simplest technique.
- b. Using this technique, all write operations are made to main memory as well as to the cache, ensuring that main memory is always valid.
- c. The main disadvantage of this technique is that it generates substantial memory traffic and may create a bottleneck.

ii. **Write back :**

- a. It is another technique which minimizes memory writes.
- b. With write back, updates are made only in the cache.
- c. When an update occurs, an UPDATE bit associated with the slot is set. Then, when a block is replaced it is written back to main memory if and only if the UPDATE bit is set.

**PART-7**

**Auxiliary Memories : Magnetic Disk, Magnetic Tape and Optical Disks, Virtual Memory : Concept Implementation.**

**Questions-Answers****Long Answer Type and Medium Answer Type Questions**

**Que 4.21.** Explain auxiliary memory. What are the commonly used auxiliary memory?

- Auxiliary memory is a higher capacity external memory.
- It is non-volatile memory that is not accessible by the CPU, because it is not accessed via the input / output channels.

**Types of auxiliary memory:**

**1. Magnetic disks :**

- A disk is a circular plate constructed of metal or of plastic coated with a magnetizable material.
- Data are recorded on and later retrieved from the disk via a conducting coil, named the head.
- During a read and write operation, the head is stationary while the plate rotates beneath it.

**2. Magnetic tape :**

- A magnetic tape consists of the electrical, mechanical and electronic components to provide the parts and control mechanism for a magnetic tape unit.
- The tape itself is a strip of plastic coated with a magnetic recording medium.
- Bits are recorded as magnetic spots on the tape along several tracks.
- Usually, seven or nine bits are recorded simultaneously to form a character together with a parity bit.
- Read/write heads are mounted one in each track so that data can be recorded and read as sequence of characters.

**3. Flash memory :**

- An electronic non-volatile computer storage device that can be electrically erased and reprogrammed, and works without any moving parts.
- Examples of this are flash drives, memory cards and solid state drives.

**4. Optical disk :**

- A storage medium from which data is read and written by lasers.

**Que 4.22.** A moving arm disc storage device has the following specifications:  
Number of Tracks per recording surface = 200  
Disc rotation speed = 2400 revolution/minute  
Track storage capacity = 62500 bits  
Estimate the average latency and data transfer rate of this device.

**AKTU 2017-18, Marks 07**

Disk rotation speed = 2400 rpm

As we know that average latency =  $\frac{1}{2} \times$  Rotation time

∴ 2400 rotation in one minute so the time for one rotation =  $\frac{1}{2} \times \frac{60}{2400}$  s

$$\text{Track storage capacity} = 62500 \text{ bits}$$

$$\text{And in one rotation head cover entire track, so, disk transfer rate}$$

$$= 62500 * \frac{2400}{60} \text{ s}$$

(where 2400/60 is number of rotations per second)

$$= 2.5 * 10^6 \text{ bps}$$

**Que 4.23.** What is virtual memory?

OR

Write a short note on virtual memory.

**AKTU 2014-15, Marks 05**

**Answer**

- Virtual memory is a memory management capability of an OS that uses hardware and software to allow a computer to compensate for physical memory shortages by temporarily transferring data from Random Access Memory (RAM) to disk storage.



Fig. 4.24.1.

8. If  $k$  bits are allotted for selecting the bank as shown in Fig. 4.24.1, there have to be total  $2^k$  banks. This ensures that there are no gaps of non-existent memory locations.

- i. Associative memory :**
1. Associative memory is a memory in which location is accessed by a field of data word stored in the memory rather than by any address.
  2. It can be viewed as a random access type memory which in addition to having a physically wired-in addressing mechanism also has wired-in logic for bit comparison.

3. This logic circuit enables comparison of desired bit positions of all the words with a specified input key.
4. This comparison is done simultaneously for all the words.
5. This is also called Content Addressable Memory (CAM).

**Working principle of associative memory :**

1. The mask register specifies the key field.
2. Input data is simultaneously compared with the key field of each word.
3. The select circuit implements two functions :
  - a. It stores the word location ( $s$ ) for which match has occurred.
  - b. It reads out the word(s) in predetermined order for the match position ( $s$ ).
4. Thus, a word stored in the associative memory is a pair (key, Data). Any subfield of the word can be specified as the key.
5. The read or write instruction is preceded by the match instruction having the format,
6. Match key, Input data
7. The read/write operation can next be performed on each of the words for which match signal is generated.

4-24B (CSIT-Sem-3)  
Virtual address space is increased using active memory in RAM and inactive memory in Hard Disk Drives (HDDs) to form contiguous addresses that hold both the application and its data.

3. A system using virtual memory can load larger programs or multiple programs running at the same time, allowing each one to operate as if it has infinite memory and without having to purchase more RAM.
4. Virtual memory from local point of view, without regard to the amount of main memory.
5. A virtual memory system provides a mechanism for translating program generated addresses into correct main memory locations.
6. This is done dynamically, while programs are being executed in the CPU.

**Ques 4.24.** Explain the following memory schemes discussing why needed the:

- i. Interleaved memory
- ii. Associative memory

OR

**AKTU 2014-15, Marks:10**

- Explain the working principle of associative memory.

**Answer**

**i. Interleaved memory :**

1. Interleaved memory is a design made to compensate for the relatively slow speed of Dynamic Random Access Memory (DRAM).
2. This is done by spreading memory addresses evenly across memory banks.

Thus, in contiguous memory, reads and writes are done using each memory bank in turn, resulting in higher memory throughputs due to reduced waiting for memory banks to become ready for desired operations.

3. As shown in Fig. 4.24.1, the lower order  $k$  bits of the address are used to select the module (Memory bank) and higher order  $m$  bits give a unique memory location in the memory bank that is selected by the lower order  $k$  bits.
4. Thus in this way consecutive memory locations are stored on different memory banks.
5. Whenever requests to access consecutive memory locations are being made several memory banks are kept busy at any point in time.
6. This results in faster access to a block of data in the memory and also results in higher overall utilization of the memory system as a whole.



Fig. 4.24.2. Organization of an associative memory.

**Que 4.25.** What is associative memory? Explain with the help of a block diagram. Also mention the situation in which associative memory can be effectively utilized.

**AKTU 2018-19, Marks 07**

### Answer

Associative memory and block diagram : Refer Q. 4.24, Page 4-24B, Unit-4.

Associative memory is effectively utilized when doing a large number of pattern match and lookup.

**Que 4.26.** What do you mean by CAM? Explain its major characteristics.

### Answer

#### CAM:

- Content Addressable Memory (CAM) is computer memory that operates like a hardware search engine for search-intensive applications.
- CAM is capable of searching its entire contents in a single clock cycle.
- It does that by pairing the SRAM-based memory with additional logic comparison circuitry that is active on every clock cycle.
- The way CAM functions is almost the opposite of Random Access Memory (RAM).
- Data stored on CAM, can be accessed by searching for the content itself, and the memory retrieves the addresses where that content can be found.
- Because of its parallel nature, CAM is much faster than RAM for searching.

**The major characteristics are :**

- This memory is accessed simultaneously and in parallel rather than sequentially.
- This memory is capable of finding an empty or unused location of the word.
- This memory is uniquely suited to do parallel searches by data association.
- Each cell must have storage capability as well as logic circuits for matching its content with an external argument.

**Que 4.27.** Discuss the conceptual organization of a multilevel memory system used in computers.

**Answer**

Conceptual organization of a multilevel memory system consist of basically four elements i.e., CPU registers, cache memory, main memory and secondary memory.



Fig. 4.27.1. Conceptual organization of multilevel memories in a computer system.

- CPU registers :**
  - The high-speed registers in CPU are used as the temporary storage for instructions and data.
  - They usually form a general purpose register file for storing data as it is processed. A capacity of 32 data words is typical for a register file and each register can be accessed within a single clock cycle that is in a few nano seconds.
- Cache memory :**
  - Cache memory is positioned logically between register files and the main memory.
  - Its capacity is less than main memory but access time is much lesser, that is this types of memories are much faster than the main memory.
- It operates in three levels :**
  - Level 1 (L1) cache :** It is built directly into the processor chip. It has small capacity from 8 kb to 128 kb.

- b. **Level 2 (L2) cache :** It is built on current processors on processor chip. It has capacity from 64 kb to 16 MB.
- c. **Level 3 (L3) cache :** This cache is separate from processor chip on the motherboard. Its capacity is up to 8 MB.
- d. **Main or Primary memory :** Refer Q. 4.1, Page, Unit-4.

**Q. 4. Secondary memory :** Refer Q. 4.1, Page, Unit-4.

**Q. 4.28. What do you mean by locality of reference ? Explain with suitable example.**

**Answer**

Locality of reference is a term for the phenomenon in which the same values or related storage locations are frequently accessed, depending on the memory access pattern.

**Example :**

1. Take the example of an operating system. Ideally, we would like an unlimited amount of main memory, instantly accessible.
2. In practice, we have a limited amount of main memory, and because it is cheaper, a very large amount of secondary memory.
3. However the trade-off is that secondary memory tends to be several orders of magnitude slower than primary memory.
4. We can approach the ideal by keeping the more often used data in main memory, and everything else in secondary memory.
5. Because of the principle of Locality of Reference, we can be sure that most memory references will be to locations already stored in main memory, thereby improving efficiency and providing a flat memory model.
6. This scheme is used in modern operating systems and is called virtual memory. Virtual memory gives users the appearance of unlimited primary memory by transparently utilizing secondary memory.

**VERY IMPORTANT QUESTIONS**

*Following questions are very important. These questions may be asked in your SESSIONALS as well as UNIVERSITY EXAMINATION.*

- Q. 1. Give the structure of commercial 8M x 8 bit DRAM chip.**  
**Ans.** Refer Q. 4.4.
- Q. 2. Write short note on organization of 2D and 2.5D memory organization.**  
**Ans.** Refer Q. 4.5.

**Q. 3. How main memory is useful in computer system ? Explain the memory address map of RAM and ROM.**  
**Ans.** Refer Q. 4.7.

- Q. 4. A computer uses RAM chips of 1024\*1 capacity.**
  - i. How many chips are needed and how should they be connected to provide a memory capacity of 16 KB ? Explain in words how the chips are to be connected to the address bus.
  - ii. How many chips are needed to provide a memory capacity of 1024\*8 ? Refer Q. 4.8.

**Q. 5. A ROM chip of 1024\*8 has four select inputs and operates from a 5 volt power supply. How many pins are needed for the IC package ? Draw a block diagram and label all input and output terminals in the ROM.**  
**Ans.** Refer Q. 4.9.

- Q. 6. A computer uses a memory unit with 256 K words of memory. The instruction code is stored in one word of an operation code, a register code part to specific one of 64 register and an address part.**
  - i. How many bits are there in the operation code part ?
  - ii. Draw the instruction word format and indicate the number of bits in each part.
  - iii. How many bits are there in the data and address inputs of the memory ? Refer Q. 4.10.

- Q. 7. Discuss the various types of address mapping used in cache memory.**  
**Ans.** Refer Q. 4.14.
- Q. 8. Consider a cache uses a direct mapping scheme. The size of main memory is 4 K bytes and word size of cache is 2 bytes. The size of cache memory is 128 bytes. Find the following :**
  - i. The size of main memory address (assume each byte of main memory has an address)
  - ii. Address of cache block
  - iii. How many memory location address will be translated to cache address/block/location ?
  - iv. How can it be determined if the content of specified main memory address in cache ?

- Q. 9.** A two way set associative cache memory uses blocks of 4 words. The cache can accommodate a total of 2048 blocks of 4 words. The main memory size is  $128 \text{ K} \times 32$ .  
 i. Formulate all pertinent information required to construct the cache memory.  
 ii. What is the size of the cache memory?

**Ans.** Refer Q. 4.17.

- Q. 10.** What is the distinction between spatial locality and temporal locality?

**Ans.** Refer Q. 4.18.

- Q. 11.** A moving arm disc storage device has the following specifications:

Number of Tracks per recording surface = 200  
 Disc rotation speed = 2400 revolution/minute

Track-storage capacity = 62500 bits

Estimate the average latency and data transfer rate of this device.

**Ans.** Refer Q. 4.22.

- Q. 12.** Write a short note on virtual memory.

**Ans.** Refer Q. 4.23.

- Q. 13.** Explain the following memory schemes discussing why needed the:  
 i. Interleaved memory  
 ii. Associative memory

**Ans.** Refer Q. 4.24.

- Q. 14.** What is associative memory? Explain with the help of a block diagram. Also mention the situation in which associative memory can be effectively utilized.

**Ans.** Refer Q. 4.25.

- Q. 15.** What do you mean by CAM? Explain its major characteristics.

**Ans.** Refer Q. 4.26.

- Q. 16.** What do you mean by locality of reference? Explain with suitable example.

**Ans.** Refer Q. 4.28.



# 5

## UNIT

### Input / Output

## CONTENTS

|                 |                                                                                                     |                |
|-----------------|-----------------------------------------------------------------------------------------------------|----------------|
| <b>Part-1 :</b> | Input/Output :<br>Peripheral Devices, I/O Interface, I/O Ports                                      | 5-2B to 5-4B   |
| <b>Part-2 :</b> | Interrupts : Interrupts, Hardware, Types of Interrupts and Exceptions                               | 5-4B to 5-9B   |
| <b>Part-3 :</b> | Modes of Data Transfer : Programmed I/O                                                             | 5-9B to 5-10B  |
| <b>Part-4 :</b> | Interrupt Initiated I/O and Direct Memory Access, I/O Channels and Processors                       | 5-10B to 5-15B |
| <b>Part-5 :</b> | Serial Communication, Synchronous and Asynchronous Communication, Standard Communication Interfaces | 5-15B to 5-20B |

**Input/Output : Peripheral Devices, I/O Interface, I/O Ports.**

### PART-1

**Long Answer Type and Medium Answer Type Questions**

#### Questions Answers

**Que 5.1:** Explain the term **Peripheral devices**!

#### Answer

1. Peripheral devices are the computer devices that are connected to the computer externally such as printer, scanner, keyboard, mouse, tape device, microphone and external modem. It can be internal such as CD-ROM or internal modem.
2. Peripheral devices can be classified according to their functions:
  - i. **Input :** Input devices are the type of computer devices that are used to provide the control signals to the computer. Keyboard and mouse are the examples of the input devices.
  - ii. **Output :** Output devices are the devices that are used to display the results. Printer, scanner, speaker and the monitor are the examples of the output devices.
  - iii. **Storage :** A storage device is a device that is used to store the information such as hard-disk drive, flash drive, floppy disk and the tape drive.

**Que 5.2:** Describe I/O interface. Why they are needed ?

OR

Why input-output interface is required ? Describe in detail.

**AKTU 2015-16, Marks 15**

**I/O interface** provides a method of transferring information between internal storage and external I/O devices.

The major requirements for an I/O module can be given as :

1. Processor communication : This involves the following tasks :
  - a. Exchange of data between processor and I/O module.
  - b. Command decoding : The I/O module for a disk drive may accept the following commands from the processor : READ SECTOR, WRITE SECTOR, SEEK track, etc.

#### Answer

- c. **Status reporting** : The device must be able to report its status to the processor. For example, disk drive busy, ready etc.
- d. Status reporting may also involve reporting various errors.
- e. **Address recognition** : Each I/O device has a unique address and the I/O module must recognize this address.

2. **Device communication** : The I/O module is able to perform device communication such as status reporting.
3. **Control and timing** : The I/O module is able to co-ordinate the flow of data between the internal resources (such as processor, memory) and external devices.
4. **Data buffering** :
  - a. This is necessary as there is a speed mismatch between speed of data transfer between processor and memory and external devices.
  - b. Data coming from the main memory are sent to an I/O module in a rapid burst.
  - c. The data is buffered in the I/O module and then sent to the peripheral device at its rate.
5. **Error detection** :
  - a. The I/O module is able to detect errors and report them to the processor.
  - b. These errors may be mechanical errors (such as paper jam in a printer), or changes in the bit pattern of transmitted data. A common way of detecting such errors is by using parity bits.

**Que 5.3:** Explain I/O bus and I/O command.

#### Answer

**I/O bus :**

1. The I/O bus consists of data lines, address lines and control lines.
2. It acts as a communication link between processor and several peripheral devices.
3. It comprises of magnetic tape, magnetic disk, printer and terminal.
4. The I/O bus from processor is attached to all peripheral interfaces.

**I/O command :**

When an address is in the address lines, at the same time, the processor provides a function code in control lines which is referred to as I/O command. It is of four types :

- i. **Control command** : It is issued to activate the peripheral and to inform it what to do.
- ii. **Status command** : It is used to test various status conditions in the interface and peripheral.

- iii. **Output data command :** It causes the interface to respond by transferring data from bus into one of its registers.
- iv. **Input data command :** It is the opposite of data output. The interface receives an item of data from peripheral and places it in its buffer register.

**PART-2**

**Interrupts : Interrupt Hardware, Types of Interrupts and Exceptions**

**Questions-Answers****Long Answer Type and Medium Answer Type Questions**

- Que 5.4.** Write a short note on interrupts.

**AKTU 2014-15, Marks 05**

**Define interrupt.** When a device interrupt occurs how does the processor determine which device has issued the interrupt ?

**Answer**

**Interrupt :** An interrupt is a signal sent by an I/O interface to the CPU when it is ready to send information to the memory or receive information from the memory.

**Identifying the source of an interrupt :**

Two methods are available to determine the interrupting device :

a. **Polled interrupts :**

1. On receiving an interrupt request the micro-processor will execute a routine causing it to poll each of the devices in turn.
2. Devices have a status register containing one or more interrupt request bits.
3. If a device caused the interrupt, its interrupt flag bit will be set.
4. The appropriate service routine will then be selected and the device serviced.
5. Polling can be very inefficient if there are many devices capable of causing an interrupt.
6. This method uses only software methods to identify an interrupting device.

b. **Vectored interrupts :**

1. This is the method used in modern computers.
2. It is sometimes referred to as hardware identification since additional hardware is required.

**OR**

- Que 5.5.** Explain the sequence that takes place when an interrupt occurs.
- AKTU 2015-16, Marks 10**

When an interrupt occurs, sequence of following six steps takes place :

**1. Interrupt recognition :**

- a. The interrupt recognition is recognized by the processor of an interrupt request due to activation of an interrupt request line or an internal mechanism.

- b. In this step, the processor can determine which device or CPU, component made the request.

**2. Status saving :**

- a. The goal of this step is to make the interrupt sequence transparent to the interrupted process.

- b. Therefore, the processor saves the flags and registers that may be changed by the interrupt service routine so that they may be restored after the service routine is finished.

**3. Interrupt masking :**

- a. For the first few steps of the sequence, all interrupts are masked out so that no other interrupt may be processed before the processor status is saved.

- b. The mask is then set to accept interrupts of higher priority.

**4. Interrupt acknowledgment :**

- a. At some point, the processor must acknowledge the interrupt being serviced, so that the interrupting device becomes free to continue its task.

- b. One of the ways is to have an external signal line denoted to interrupt acknowledge.

**5. Interrupt service routine :**

- a. At this point, the processor initiates the interrupt service routine.
- b. The address of the routine can be obtained in several ways, depending on the system architecture.

- c. The simplest is found in the polling method, in which one routine polls each device to find which one interrupted.

**Ques 5.6. Restoration and return :**

- a. After the interrupt service routine has completed its processing, it restores all the registers it has changed, and the processor restores all the registers and flags that were saved at the initiation of the interrupt routine.

- b. If this is done correctly, the processor should have the same status as before the interrupt was recognized.

**Ques 5.6. How system resolve the priority of interrupt ?**

OR

**Explain polling and daisy chaining method.****Answer**

There are two methods of system to resolve the priority of interrupt :

**a. Polling method :**

1. When interrupt requests arrive from two or more devices simultaneously, the processor has to decide which request should be serviced first and which one should be delayed.
2. The processor takes the decision with the help of interrupt priorities. It accepts the request having the highest priority.
3. In this case polling is used to identify the interrupting device, priority is automatically assigned by the order in which devices are polled.
4. Therefore, no further arrangement is required to accommodate simultaneous interrupt requests. However, the priority of any device is usually determined by the way the device is connected to the processor.

**b. Chaining method :**

1. Most common way to connect the devices is to form a daisy chain, as shown in Fig. 5.6.1.
2. The Interrupt Request line (INTR) is common to all the devices and the Interrupt Acknowledge line (INTA) is connected in a daisy chain model.
3. In daisy chain fashion the signal is allowed to propagate serially through the devices.
4. When more than one devices issue an interrupt request, the INTR line is activated and processor responds by setting the INTA line.



**Fig. 5.6.1. Interrupt priority system using daisy chain.**

5. This signal is received by device 1. Device 1 passes the signal to the device 2 only if it requires any service.

6. If device 1 requires service, it blocks the INTA line and puts its identification code on the data lines. Therefore, in daisy chain arrangement, the device that is electrically closest to the processor has the highest priority.

**Ques 5.7. How interrupts are classified ?****Answer**

Basically the interrupts can be classified in the following three ways :

1. **Hardware and software interrupts :**
  - a. The interrupts initiated by an external hardware by sending an appropriate signal to the interrupt pin of the CPU is called hardware interrupt.
  - b. The software interrupts are program instructions. These instructions are inserted at desired location in a program. While running a program, if software interrupt instruction is encountered the CPU initiates an interrupt.
2. **Vectorized and non-vectorized interrupts :**
  - a. When an interrupt signal is accepted by the CPU, and the program control automatically branches to a specific address (called vector address) then the interrupt is called vectored interrupt.
  - b. In non-vectorized interrupts the interrupting device should supply the address of the ISR to be executed in response to the interrupt.
3. **Maskable and non-maskable interrupts :**
  - a. The interrupts whose request can be either accepted or rejected by the CPU are called maskable interrupts.
  - b. The interrupts whose request has to be definitely accepted by the CPU are called non-maskable interrupts.

**5-B (CSIT-Sem-3)**

**Que 5.8.** Explain the difference between vectored and non-vectored interrupt. Explain stating examples of each.

**AKTU 2018-19, Marks 07**

**Answer**

| S. No. | Vectored interrupt                                                                                                        | Non-vectored interrupt                                                                                 |
|--------|---------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|
| 1.     | Vectored interrupt are those interrupt that generates the interrupt request, identifies itself directly to the processor. | Non-vectored interrupt are those in which vector address is not pre-defined.                           |
| 2.     | Vector interrupt have fixed memory location for transfer of control for normal execution.                                 | Non-vectored interrupt do not have fixed memory location for transfer of control for normal execution. |
| 3.     | Vectored interrupt has memory address.                                                                                    | A non-vectored interrupt do not have memory address.                                                   |
| 4.     | The vectored interrupt allows the CPU to be able to know what ISR to carry out in software.                               | When a non-vectored interrupt received, it jump into the program counter to fixed address in hardware. |
| 5.     | Response time is low.                                                                                                     | Response time is high.                                                                                 |
| 6.     | TRAP is a vectored interrupt.                                                                                             | INTR is non-vectored interrupt.                                                                        |

**Que 5.9.** Explain the types of interrupt on the basis of timer.

**Answer**

There are following types of interrupt on this basis of timer :

1. Level-triggered :

- a. A level-triggered interrupt is a class of interrupts where the presence of an unserviced interrupt is indicated by a high level (1), or low level (0), of the interrupt request line.
- b. A device wishing to signal an interrupt drives line to its active level, and then holds it at that level until serviced.

2. Edge-triggered :

- a. An edge-triggered interrupt is a class of interrupts that are signaled by a level transition on the interrupt line, either a falling edge (1 to 0) or a rising edge (0 to 1).

**5-B (CSIT-Sem-3)**

b. A device wishing to signal an interrupt drives a pulse onto the line and then releases the line to its quiescent state.

- c. If the pulse is too short to be detected by the processor, hardware may be required to detect by polled I/O then special signaling. The hardware not only looks for an edge-triggered signal but also verifies that the interrupt signal stays active for a certain period of time.
- b. A common use of a hybrid interrupt is for the NMI (non-maskable interrupt) input.
- c. Because NMIs generally signal major or even catastrophic system events, a good implementation of this signal tries to ensure that the interrupt is valid by verifying that it remains active for a period of time.

**PART-3****Modes of Data Transfer : Programmed I/O.**

**Questions-Answers**

**Long Answer Type and Medium Answer Type Questions**

**Que 5.10.** Write a short note on programmed I/O.

**AKTU 2014-15, Marks 05**

**OR**  
Discuss the programmed I/O method for controlling input-output operations.

**Answer**

**Programmed I/O:**

- 1. When the CPU is executing a program and executes an instruction relating to I/O, it executes that instruction by issuing a command to the appropriate I/O module.

**Fig. 5.10.1. Programmed I/O.**

2. With programmed I/O, the I/O module will perform the requested action and then set the appropriate bits in the I/O status register.
3. The I/O module takes no further action to alert the CPU.
4. It does not interrupt the CPU.
5. Thus, it is the responsibility of CPU to periodically check the status of the I/O module until it finds that the operation is complete.

**PART-4**

*Interrupt Initiated I/O and Direct Memory Access, I/O Channels and Processors.*

**Questions-Answers****Long Answer Type and Medium Answer Type Questions****Que 5.11.** What is interrupt initiated I/O ?**Answer**

1. Interrupt initiated I/O is a mode of data transfer which removes the drawback of the programmed I/O mode.
2. The CPU issues commands to the I/O module then proceeds with its normal work until interrupted by I/O device then proceeds with its work and is ready to be retrieved by the CPU when new data has arrived.
3. For input, the device interrupts the CPU on completion of its work.
4. The actual actions to perform depend on whether the device uses I/O ports, memory mapping.
5. For output, the device delivers an interrupt either when it is ready to accept new data or to acknowledge a successful data transfer.
6. Memory-mapped and DMA-capable devices usually generate interrupts to tell the system that they are done with the buffer.
7. Although interrupt relieves the CPU of having to wait for the devices, but it is still inefficient in data transfer of large amount because the CPU has to transfer the data word by word between I/O module and memory.

**Que 5.12.** Write short note on DMA. **AKTU 2014-15, Marks 05**

Explain the working of DMA controller with the help of suitable diagrams.

**OR**

Write a short note on DMA based data transfer.

**AKTU 2017-18, Marks 07**

Give the block diagram of DMA controller. Why are the read and write control lines in a DMA controller bidirectional ?

**AKTU 2018-19, Marks 07****Answer****DMA:**

1. DMA stands for "Direct Memory Access" and is a method of transferring data from the computer's RAM to another part of the computer without processing it using the CPU.
2. While most data that is input or output from our computer is processed by the CPU, some data does not require processing or can be processed by another device.
3. DMA can save processing time and is a more efficient way to move data from the computer's memory to other devices.
4. In order for devices to use direct memory access, they must be assigned to a DMA channel. Each type of port on a computer has a set of DMA channels that can be assigned to each connected device.

their own set of DMA channels.

- their own set of DMA channels.



ΕΙΓ Σ 191

Working of DMA controller

- When the peripheral device sends a DMA request, the DMA controller activates the BR line, informing the CPU to relinquish the buses.
  - The CPU responds with its BG line, informing the DMA that its buses are disabled.



**Fig. 5.12.2: DMA transfer in a computer system.**

3. The DMA then puts the current value of its address register into the address bus, initiates the RD or WR signal, and sends a DMA acknowledge to the peripheral device.

4. The direction of transfer depends on the state of the DC line

| S.No. | <b>Isolated I/O</b>                                             | <b>Memory mapped I/O</b>                                                     |
|-------|-----------------------------------------------------------------|------------------------------------------------------------------------------|
| 1.    | Isolated I/O uses separate memory space.                        | Memory mapped I/O uses memory from the main memory.                          |
| 2.    | Limited instructions can be used. Those are IN, OUT, INS, OUTS. | Any instruction which references to memory can be used.                      |
| 3.    | The addresses for isolated I/O devices are called ports.        | Memory mapped I/O devices are treated as memory locations on the memory map. |
| 4.    | Efficient I/O operations due to separate bus.                   | Inefficient I/O operations due to single bus for data and addressing.        |
| 5.    | Comparatively larger in size.                                   | Smaller in size.                                                             |
| 6.    | Uses complex internal logic.                                    | Common internal logic for memory and I/O devices.                            |
| 7.    | Slower operations.                                              | Faster operations.                                                           |

Answer

Difference

**Q5.13 B (CSIT-Sem-3)**

- a. When  $DX = 0$ , the RD and WR are input lines to communicate with the internal DMA lines allowing the CPU to control the peripheral unit.
- b. When  $BG = 1$ , the RD and WR registers are output lines from the CPU to the peripheral device to specify the read or write operation for the data.
- c. When the peripheral device receives a DMA acknowledge, it puts a word in the data bus (for write) or receives a word from the data bus (for read).
- d. Thus, the DMA controls the read or write operations and supplies the address for the memory.
- e. The peripheral unit can communicate with memory through the data bus for direct transfer between the two units while the CPU is momentarily disabled.

**Reason for bidirectional read and write control lines:** Bidirectional control lines in a DMA controller are bidirectional because the microprocessor fetches (read) the data from the memory and writes data to the memory.

**Que 5.13.** What is the difference between isolated I/O and memory mapped I/O? Explain the advantages and disadvantages of each.

**Computer Organization & Architecture****5-15 B (CSIT-Sem-3)**

1. The devices of I/O are treated in a separate domain as compared to memory.
2. A total of 1MB address space is allowed for memory applications.
3. In order to maximize the I/O operations (isolated) separate instructions are always provided to perform these operations.

**Disadvantage of isolated I/O :**

1. The data transfer only occurs between the I/O port and the registers.
2. I/O intensive operation is fast.
3. The SQLite library needs less RAM.

**Disadvantages of memory mapped I/O :**

1. If an I/O error on a memory-mapped file cannot be caught by the application, results in a program crash.
2. Performance is reduced by the use of memory-mapped I/O.

**Que 5.14. What do you mean by Input-Output (I/O) processor ?****Answer**

1. IOP is designed to handle the details of I/O processing. Unlike the DMA controller that must be set up entirely by the CPU, the IOP can fetch and execute its own instructions.
2. IOP instructions are specifically designed to facilitate I/O transfers.

**Fig. 4.14.1.** The block diagram of a computer with IOP.

3. The memory unit occupies central position and can communicate with each processor by means of direct memory access.
4. The CPU is responsible for processing data. The IOP provides a path for transfer of data between various peripheral devices and the memory unit.

**Answer**

1. A channel is an independent hardware component that co-ordinate all I/O to a set of controllers. Computer component that contains special hardware components that handle all I/O channel have functioning which are called channel processors.
2. Channel processors are simple, but contains sufficient memory to handle all I/O tasks.
3. When I/O transfer is complete or an error is detected, the channel controller communicates with the CPU using an interrupt, and informs CPU about the error or the task completion.
4. Each channel supports one or more controllers or devices. Channel programs contain list of commands to the channel itself and for various connected controllers or devices.

**Types of I/O Channels :**

1. **Multiplexer:** The Multiplexer channel can be connected to a number of slow and medium speed devices. It is capable of operating number of I/O devices simultaneously.
2. **Selector:** This channel can handle only one I/O operation at a time and is used to control one high speed device at a time.
3. **Block-Multiplexer:** It combines the features of both multiplexer and selector channels.

**PART-5**

**Serial Communication : Synchronous and Asynchronous Communication, Standard Communication Interfaces.**

**Questions-Answers****Long Answer Type and Medium Answer Type Questions**

- Que 5.16.** What do you mean by serial communication ? What are the transmission modes of serial communication ?

**Answer**

- In serial communication bits are transferred one after the other over a single communication path.
- Serial communication is a device communication protocol that is standard on almost every PC.
- A given transmission on a communication channel between two machines can occur in several different ways.

**Modes of serial communication :****1. Simplex connection :**

- A simplex connection is a connection in which the data flows in only one direction, from the transmitter to the receiver.

**Fig. 5.16.1. Simplex connection.****2. Half-duplex connection :**

- A half-duplex connection (sometimes called an alternating connection or semi-duplex) is a connection in which the data flows in one direction or the other, but not both at the same time.

**Fig. 5.16.2. Half-duplex connection.**

- With this type of connection, each end of the connection transmits in turn.

**3. Full-duplex connection :**

- A full-duplex connection is a connection in which the data flow in both directions simultaneously.
- This can be achieved by means of a four-wire link, with a different pair of wires dedicated to each direction of transmission.

**Fig. 5.16.3. Full-duplex connection.**

**Que 5.17.** Explain synchronous communication and asynchronous communication.

**Answer****Synchronous communication :**

- In the synchronous communication scheme, after a fixed number of data bytes, a special bit pattern called SYNC is sent as shown in Fig. 5.17.1.

**Fig. 5.17.1. Synchronous communication.**

- There is no gap between adjacent characters in the synchronous communication.

- There is a continuous stream of data bits coming at a fixed speed in a synchronous communication scheme.

- Synchronous communication is used generally when two computers are communicating to each other or when a buffered terminal is communicating to the computer.

**Asynchronous communication :**

- In the asynchronous communication scheme, each character includes start and stop bits, as shown in Fig. 5.17.2.

**Fig. 5.17.2. Asynchronous communication.**

- There are some gaps between adjacent characters in the asynchronous communication.

- In the asynchronous communication scheme, the bits within a character frame (including start, parity and stop bits) are sent at the baud rate.
- Asynchronous communication is used when slow speed peripherals communicate with the computer.

**Que 5.18.** Discuss the advantages and disadvantages of synchronous and asynchronous transmission.

**Answer****Advantages of synchronous transmission :**

- Lower overhead and thus, greater throughput.

- Slightly more complex.

- Hardware is more expensive.

**Disadvantages of synchronous transmission :**

- Simple and does not require synchronization of both communication sides.

2. Hardware are cheaper as clock is not required.

3. Set-up is very fast, so well suited for applications where messages are generated at irregular intervals.

#### **Disadvantages of asynchronous transmission :**

1. Large relative overhead, a high proportion of the transmitted bits are uniquely for control purposes and thus carry no useful information.

#### **Que 5.19. Differentiate among :**

- i. Strobe control and handshaking asynchronous data transfer modes.
- ii. Processor and IOP.
- iii. Synchronous and asynchronous transmission.
- iv. Character-oriented and Bit-oriented protocols.
- v. DMA and interrupt initiated I/O techniques.

#### **AKTU 2015-16, Marks 15**

##### **i. Strobe control and handshaking asynchronous data transfer modes:**

| S.No. | Parameter       | Strobe control                                                                     | Handshaking                                                                        |
|-------|-----------------|------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|
| 1.    | Control line    | It employs a single control line to time each transfer.                            | It employs more than one control line to time each transfer.                       |
| 2.    | Acknowledgement | Reply message is not present.                                                      | Reply message is present.                                                          |
| 3.    | Block diagram   |  |  |
| 4.    | Timing diagram  |  |  |

##### **ii. Processor and IOP :**

| S.No. | Processor                             | IOP                            |
|-------|---------------------------------------|--------------------------------|
| 1.    | Processor is CPU.                     | IOP is port of CPU processing. |
| 2.    | Handles arithmetic and logical tasks. | Handles only I/O processing.   |
| 3.    | DMA controller is set-up by CPU.      | IOP is a processor with DMA.   |

#### **Computer Organization & Architecture**

##### **iii. Synchronous and asynchronous transmission :**

| S.No. | Synchronous transmission                                 | Asynchronous transmission                               |
|-------|----------------------------------------------------------|---------------------------------------------------------|
| 1.    | Transmitter and receiver are synchronized by clock.      | Transmitter and receiver are not synchronized by clock. |
| 2.    | Data bits are transmitted with synchronization of clock. | Bits of data are transmitted at constant rate.          |
| 3.    | Data transfer takes place in blocks.                     | Data transfer is character oriented.                    |

##### **iv. Character-oriented and Bit-oriented protocols :**

| S.No. | Character-oriented protocol                                                                     | Bit-oriented protocol                                                                                             |
|-------|-------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|
| 1.    | The character-oriented protocol is based on the binary code of a character set.                 | The bit-oriented protocol does not use characters in its control field and is independent of any particular code. |
| 2.    | The code has 128 characters, of which 95 are graphics characters and 33 are control characters. | It allows the transmission of serial bit stream of any length without the implication of character boundaries.    |

##### **Message format for character-oriented protocol:**

| SYN | SYN | SOH | Header | STX | Text | ETX | BCI |
|-----|-----|-----|--------|-----|------|-----|-----|
|-----|-----|-----|--------|-----|------|-----|-----|

| Flag     | Address<br>8 bits | Control<br>8 bits | Information<br>any number<br>of bits | Frame<br>check<br>16 bits | Flag     |
|----------|-------------------|-------------------|--------------------------------------|---------------------------|----------|
| 01111110 | 8 bits            | 8 bits            |                                      | 16 bits                   | 01111110 |

##### **v. DMA and interrupt initiated I/O techniques :**

| S.No. | DMA                                                                                         | Interrupt initiated I/O                                                         |
|-------|---------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|
| 1.    | As DMA initializes, CPU become idle.                                                        | CPU executes the current program, during the interrupt initiated I/O technique. |
| 2.    | As the DMA disables, memory buses are returned to CPU and CPU starts executing its program. | After the transfer, CPU returns to the previous program to continue.            |

- Que 5.20.** Describe the subroutine. Write a program which move the block of data.
- AKTU 2016-17, Marks 7.5**

OR

- Write a note on subroutines.

**Answer****Subroutine :**

1. A subroutine is a set of common instructions that can be used in a program many times.
2. A subroutine consists of a self-contained sequence of instructions that carries out a given task.
3. Each time that a subroutine is used in the main part of the program, a branch is executed to the beginning of the subroutine.
4. After the subroutine has been executed, a branch is made back to the main program.
5. A branch can be made to the subroutine from any part of the main program.
6. Because branching to a subroutine and returning to the main program is such a common operation, all computers provide special instructions to facilitate subroutine entry and return.

**Program :**

```

LXI H, XX50H      ; Set up HL as a pointer for the source memory
LXI D, XX70H      ; Set up DE as a pointer for the destination
                  ; memory
MOV B, 10H         ; Set up B as byte counter
NEXT: MOV A,M      ; Get data byte from the source memory
STAX D             ; Store the data byte in destination memory
INX H              ; Get ready to transfer next byte
INX D              ; Go back to get next byte if byte counter ≠ 0
JNZ NEXT           ; Go back to get next byte if byte counter ≠ 0
HLT

```

**VERY IMPORTANT QUESTIONS**

*Following questions are very important. These questions may be asked in your SESSIONALS as well as UNIVERSITY EXAMINATION.*

- Q. 1.** Why input-output interface is required? Describe in detail.  
**Ans.** Refer Q. 5.2.
- Q. 2.** Write a short note on interrupts.  
**Ans.** Refer Q. 5.4.

**AKTU 2016-17, Marks 15**

- Q. 3.** Explain the sequence that takes place when an interrupt occurs.  
**Ans.** Refer Q. 5.5.

- Q. 4.** Explain the difference between non-vectorized interrupt. Explain stating examples of each.  
**Ans.** Refer Q. 5.8.

- Q. 5.** Write a short note on programmed I/O.  
**Ans.** Refer Q. 5.10.

- Q. 6.** Write a short note on DMA based data transfer.  
**Ans.** Refer Q. 5.12.

- Q. 7.** What is the difference between isolated I/O and memory mapped I/O ? Explain the advantages and disadvantages of each.  
**Ans.** Refer Q. 5.13.

- Q. 8.** Differentiate among:  
i. Strobe control and handshaking asynchronous data transfer modes.  
ii. Processor and IOP.  
iii. Synchronous and asynchronous transmission.  
iv. Character-oriented and Bit-oriented protocols.  
v. DMA and interrupt initiated I/O techniques.  
**Ans.** Refer Q. 5.19.

- Q. 9.** Describe the subroutine. Write a program which move the block of data.  
**Ans.** Refer Q. 5.20.





## Processing Unit (2 Marks Questions)

- 1.6. Define memory transfer.**
- Ans:** Memory transfer involves basic operation like fetch (read) or store (write). The fetch operation transfers a copy of content from memory location to CPU. The store operation transfers the word information from CPU to specific memory location.
- 1.7. Define bus transfer.**
- Ans:** The data transfer between various blocks connected to the common bus is called bus transfer. Common bus system is shared by all the units.

- 1.1. What are the various ways of specifying the binary point in a register?**
- Ans:** There are two ways of specifying the binary point in a register which are :
- By giving it a fixed position.
  - By employing a floating-point representation.

**1.2. What are the various facts related to bus and bus system?**

- Ans:** Various facts related to bus and bus system are :
- A bus system will multiplex  $k$  registers of  $n$  bits each to produce an  $n$ -line common bus.
  - The number of multiplexers needed to construct the bus is equal to  $n$ , the number of bits in each register.
  - The size of each multiplexer must be  $k \times 1$ , since it multiplexes  $k$  data lines.

**1.3. Give various advantages of polling method.**

- Ans:** Various advantages of polling method are :
- The priority can be changed by altering the polling sequence stored in the controller.
  - If the one module fails, entire system does not fail.

**1.4. Discuss the basic component of register transfer logic.**

- Ans:** Basic components of register transfer logic are :
- Registers and their functions
  - Information
  - Operations
  - Control function

**1.5. What is the relation between bus width and number of bit transferred?**

- Ans:** Bus width is directly proportional to the number of bit transferred. The wider the data bus, then greater will be the number of bits transferred at one time.

- 1.8. Explain control word.**

- Ans:** Control word is defined as a word whose individual bits represent the control sequence of an instruction defines a unique combination of 0s and 1s.

**1.9. Compare register stack and memory stack.**

| S.No. | Register stack                                                                                                                              | Memory stack                                                                                             |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|
| 1.    | A stack can be placed in a portion of a logical memory or can be organized as a collection of number of memory words or registers.          | The stack is implemented as a standalone and also implemented as a random access memory attached to CPU. |
| 2.    | The stack pointer register (SP) contains a binary number whose value is equal to address of the word that is currently on top of the stack. | The implementation of a stack in the CPU is done by assigning a portion of memory to a stack operation.  |

**AKTU 2015-16, Marks 02**

◎◎◎

# 2

## Arithmetic and Logic Unit

### (2 Marks Questions)

#### (2 Marks Questions)

**Ques.** 2.1. What is look ahead carry adders ?

**Ans.** A look ahead carry adder is a type of adder which improves the speed by reducing the amount of time required to determine carry bits.

**Ques.** 2.2. What is arithmetic and logic circuit ?

**Ans.** Arithmetic circuit : It is a digital circuit which performs only arithmetic operations such as addition, subtraction etc. Logic circuit : It is a digital circuit which perform only logic operations such as AND, OR and NOT etc.

**Ques.** 2.3. Define following terms :

i. RTL

ii. Micro-operation

**Ans.**

i. **RTL** : Register Transfer Language (RTL) is a convenient tool for describing the internal organization of digital computers in concise and precise manner. It can also be used to facilitate the design process of digital systems.

ii. **Micro-operation** : The processor unit has to perform a set of operations to execute the major phases of instruction cycle these set of operations called micro-operations.

**Ques.** 2.4. What is the main advantage of RTL ?

**AKTU 2016-17, Marks 02**

**Ans.** Advantage of RTL are :

i. It uses register's as a primitive component in the digital system instead of flip-flops and gates.

ii. It describes the information flow and processing tasks among the data stored in the registers in a concise and precise manner.

iii. It uses a set of expressions and statements which resemble the statements used in programming languages.

iv. The presentation of digital functions in register transfer logic is very user friendly.

2.5. What is the need of having many addressing modes in machine ?

**Ques.** 2.6. How subtraction operation and other operations can be simplified in a digital system ?

**Ans.** Subtraction operation and other operations can be simplified in a digital system by using complement method. For each number system, there are two types of complement :

- $r$ 's complement
- $(r - 1)$ 's complement

**Ques.** 2.7. How many flip-flops are needed for 4-bit decimal code and 4385 in BCD representations ?

**Ans.** For 4 bit decimal code, there are 4 flip-flops used, each for one bit. For 4385 in BCD representation, there are 16 flip-flops used.

**Ques.** 2.8. State the condition for floating point number to become normalized.

**Ans.** A floating point number is said to be normalized if the most significant digit of the mantissa is non-zero.

**Ques.** 2.9. When exponent overflow and underflow occur ?

**Ans.** Exponent overflow occurs when a positive exponent exceeds the maximum possible exponent value. Exponent underflow occurs when a negative exponent exceeds the maximum possible exponent value. In such cases, the number is designed is zero.

**Ques.** 2.10. Perform the following operation on signed numbers using 2's compliment method :  $(56)_{10} + (-27)_{10}$ .

**AKTU 2017-18, Marks 02**

$$\begin{array}{r} 56 = \\ + 56 = \\ - 27 = \\ \hline \end{array} \quad \begin{array}{l} 110000 \text{ (binary form)} \\ 0111000 \text{ (signed binary form)} \\ 011011 \text{ (binary form)} \\ 100100 \text{ (1's complement)} \\ +1 \\ \hline \end{array}$$

$$\begin{array}{r} 100101 \text{ (2's complement)} \\ 0111000 \text{ (signed binary form)} \\ 1100101 \\ \hline \end{array}$$

$$\begin{array}{r} 0001101 \\ = (001101)_2 \\ = (29)_{10} \\ \hline \end{array}$$

# 3

## UNIT

### Control Unit (2 Marks Questions)

**3.1. Explain one, two and three address instruction.**

**AKTU 2016-17, Marks 02**

- Ans.** i. **One address instruction :** One address instruction uses an implied accumulator (AC) register for all data manipulation.
- ii. **Two address instruction :** In this format each address field can specify either a processor register or a memory word.
- iii. **Three address instruction :** Three address instruction formats can use each address field to specify either a processor register or a memory operand.

**3.2. What are the various facts related to operation code ?**

**Ans.** **Various facts related to operation code are :**

- i. The number of bits required for the operation code of an instruction depends on the total number of operations available in the computer.
- ii. The operation code must consist of at least  $n$  bits for a given  $2^n$  distinct operations.

**3.3. Define the necessary factors for instruction sequencing.**

**Ans.** **Necessary factors for instruction sequencing are :**

- i. It needs a counter to calculate the address of next instruction after execution of current instruction is completed.
- ii. It is also necessary to provide a register in the control unit for storing the instruction code.

**3.4. What operations are included in micro-operations ?**

**Ans.** **Micro-operations includes :**

- i. Transfer a word of data from one CPU register to another or to the ALU.
- ii. Perform the arithmetic or logic operations on the data from the CPU registers and store the result in a CPU register.
- iii. Fetch a word of data from specified memory location and load them into a CPU register.

**3.5. Define the following terms :**  
**3.6. Store a word of data from a CPU register into a specified memory location.**

**AKTU 2016-17, Marks 02**

**Ans.** **Effective address**

**Ans.** **Immediate instruction**

- Ans.** **What does the processor do when an interrupt is pending ?**
- Ans.** If an interrupt is pending, the processor does the following :
- It suspends execution of the current program being executed and saves its context.
  - It sets the program counter to the starting address of an interrupt handler routine.

**3.7. Define the goal of CISC architecture.**

**Ans.** The goal of CISC architecture is to provide a single machine instruction for each statement that is written in high-level language.

**3.8. Compare horizontal and vertical organization.**

**Ans.**

| S.No. | Horizontal organization                          | Vertical organization                                 |
|-------|--------------------------------------------------|-------------------------------------------------------|
| 1.    | Long formats.                                    | Short formats.                                        |
| 2.    | Ability to express a high degree of parallelism. | Limited ability to express parallel micro-operations. |
| 3.    | Little encoding of control information.          | Considerable encoding of the control information.     |
| 4.    | Useful when higher operating speed is desired.   | Slower operating speed.                               |

**3.9. Describe the micro-program sequencing.**

**Ans.** The simple approach of micro-programming is sequential execution of micro-instructions, except for the branch at the end of the fetch phase.

**3.10. What is the problem with simple micro-instruction?**

**Ans:** The micro-program requires several branch micro-instructions? These instructions perform no useful operation in data instructions. are needed only to determine the address of next micro-instruction. Thus, they de-tract the operating speed of computer.

**3.11. List two important instruction set design issues.**

**AKTU 2015-16, Marks 02**

- Data types: The various types of data upon which operations are performed.
- Registers : Number of CPU registers that can be referenced by instructions and their use.

**3.12. Define sequencer.**

**Ans:** A sequencer generates the addresses used to step through the micro-program of a control store. It is used as a part of control unit of CPU for address ranges.

**3.13. List the two techniques used for grouping the control signals.**

**AKTU 2015-16, Marks 02**

**Ans:** The two techniques used for grouping the control signals are :

- Hardwired control unit
- Micro-programmed control unit

**3.14. List three types of control signals.**

**AKTU 2015-16, 2018-19; Marks 02**

**Ans:** Three types of control signals are :

- ALU
- Data paths
- System

**3.15. Draw the block diagram of micro-program sequencer.**

**AKTU 2015-16, Marks 02**



**3.16. Write short note on pipelining process.**

**AKTU 2017-18, Marks 02**

**Ans:** Pipelining means realizing temporal parallelism in an economical way. In this, the problem is divided into a series of tasks that have to be completed one after the other.

**3.17. Differentiate between horizontal and vertical microprogramming.**

**AKTU 2017-18, Marks 02**

| S.No. | Horizontal microprogramming                                                                                                                               | Vertical microprogramming                                                                                                                                |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1.    | In horizontal micro-programming, one associates each bit of the micro-instruction with a specific micro-operation (bit 1 to represent micro-operation I). | In the case of vertical micro-programming, each line of the micro-program represents a micro-instruction which specifies a one or more micro-operations. |
| 2.    | A specific micro-operation is executed during a micro-instruction step only if the corresponding bit is one.                                              | One micro-instruction gets executed during each step of the control sequence. One can use a straight binary code to specify each micro-operation.        |

- 3.18. What are the difference between horizontal and vertical micro codes ?
- AKTU 2018-19, Marks 02**

| S.No. | Horizontal micro code                                                                                              | Vertical micro code                                                                                                         |
|-------|--------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|
| 1.    | In this types of code the micro code contains the control signal without any intermediary.                         | In case of vertical micro code every action is encoded in density.                                                          |
| 2.    | Horizontal micro code instruction contain a lot of signals and hence due to that the number of bits also increase. | Vertical micro code are slower but they take less space and their actions at execution time need to be decoded to a signal. |

- 4.1. What are the requirements of memory ?
- AKTU 2018-19, Marks 02**

- i. It should be fast.  
ii. It should be large.  
iii. It should be inexpensive.

#### 4.2. Differentiate between SRAM and DRAM

**AKTU 2018-19, Marks 02**

| S.No. | Static RAM                                           | Dynamic RAM                                                                     |
|-------|------------------------------------------------------|---------------------------------------------------------------------------------|
| 1.    | Static RAM contains less memory cells per unit area. | Dynamic RAM contains more memory cells as compared to static RAM per unit area. |
| 2.    | It has less access time hence faster memories.       | Its access time is greater than static RAMs.                                    |
| 3.    | Cost is more.                                        | Cost is less.                                                                   |

- 4.3. What do you mean by programming of ROM ?
- The blowing offuses in a cell, according to the truth table is called programming of ROM. The PROMs are one time programmable. Once programmed, the information stored is permanent.
- 4.4. Give the difference between PROM and EEPROM.

| S.No. | PROM                                                          | EEPROM                                             |
|-------|---------------------------------------------------------------|----------------------------------------------------|
| i     | It is one-time programmable ROM.                              | It can be programmed more than once.               |
| ii    | PROM destroys the entire data when applied with high voltage. | It allows selective erasing at the register level. |



**4.5. Why auxiliary storage is organized in records or blocks?**

**Ans.** Auxiliary storage is organized in records or blocks because the seek time is usually much longer than the transfer time.

**4.6. What is CAM ?**

**Ans.** A Content Addressable Memory (CAM) is a circuit that combines comparison and storage in a single device. Instead of supplying an address and reading a word like a RAM, we supply the data and the CAM looks to see if it has a copy and returns the index of the matching row.

**4.7. Which of L1 and L2 cache is faster ?**

**AKTU 2015-16, 2017-18, Marks 02**

**Ans.**

1. All processors rely on L1 cache, which is usually located on the processor and is very fast memory and expensive.
2. L2 cache is slower, bigger and cheaper than L1 cache.

**4.8. What is cache memory used for ?**

**AKTU 2016-17, Marks 02**

**Ans.**

1. Cache memory is used to store frequently used data or instructions.
2. Cache memory is used to improve computer performance by reducing its access time.
3. A cache holds instructions and data that are likely to be needed for the CPU's next operation.

**4.9. Give the disadvantage of direct mapping.**

**Ans.** The disadvantage of direct mapping is that the hit ratio can drop considerably if two or more words whose addresses have the same index but different tags are accessed repeatedly.

**4.10. Define access time, seek time and latency time.**

**Ans.** Access time : The disk access time is the time delay between receiving an address and the beginning of actual data transfer.

Seek time : The seek time is the time required to move the read/write head to the proper track.

Latency time : The rotational delay also known as latency time is the amount of time that elapses after the head is positioned over the correct track until the starting position of the addressed section passes under the read/write head.

**4.11. Discuss the advantages of erasable optical disk.**

**SQ-12B (CS/IT-Sem-3)**  
Advantages of erasable optical disk are :

i. Provide high storage capacity about 650 Mbytes of data on 5.25 inch disk.  
ii. It is portable and can easily be carried from one computer to another.

iii. It is highly reliable and has longer life.

**4.11. State the disadvantages of erasable optical disk.**

**Ans.** Disadvantages of erasable optical disk are :  
i. It uses constant angular velocity method, therefore lot of storage space is wasted in the outer tracks.  
ii. Overwriting data on magneto-optic media is slower than for magnetic media, since one revolution is required to erase a bit and a second is required to write back to that location.

**4.14. Explain the following terms :**

**AKTU 2016-17, Marks 02**

- i. PSW
- ii. Delayed load

**Ans.** i. **PSW (Program Status Word) :**

1. The collection of all status bit conditions in the CPU is sometimes called a program status word or PSW.
2. The PSW is stored in a separate hardware register and contains the status information that characterizes the state of the CPU.
3. It includes the status bits from the last ALU operation and it specifies the interrupts that are allowed to occur and whether the CPU is operating in a supervisor or user mode.

**ii. Delayed load :**

1. It is up to the compiler to make sure that the instruction following the load instruction uses the data fetched from memory.
2. If the compiler cannot find a useful instruction to put after the load, it inserts a no-op (no-operation) instruction.
3. This is a type of instruction that is fetched from memory but has no operation, thus wasting a clock cycle.
4. This concept of delaying the use of the data loaded from memory is referred to as delayed load.

**4.15. What do you understand by locality of reference ?**

**AKTU 2018-19, Marks 02**

**Ans.** Locality of reference is a term for the phenomenon in which the same values or related storage locations are frequently accessed, depending on the memory access pattern.

**4.16. Write the difference between RAM & ROM.**

**AKTU 2017-18, Marks 02**

| <b>Ans.</b> |                                                                                                                                                                                |                                                                                                                                                                                             |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| S. No.      | <b>RAM</b>                                                                                                                                                                     | <b>ROM</b>                                                                                                                                                                                  |
| 1.          | A random access memory (RAM) device allows data items to be read or written in almost the same amount of time irrespective of the physical location of data inside the memory. | The read only memory (ROM) is a type of semiconductor memory that is designed to hold data that is either permanent or will not change frequently. It is also known as non-volatile memory. |
| 2.          | Types of RAM:<br>i. Dynamic random access memory (DRAM)<br>ii. Static random access memory (SRAM)                                                                              | Types of ROM:<br>i. Programmable read only memory (PROM)<br>ii. Erasable programmable read only memory (EPROM)                                                                              |



## UNIT **(2 Marks Questions)**

**5**

### **Input/Output (2 Marks Questions)**

**5.1. Why I/O devices cannot be connected directly to the system bus ?**

**Ans.** I/O devices cannot be connected directly to the system bus for the following reasons:

i. A variety of peripherals with different methods of operation are available. So, it would be impractical to incorporate the necessary logic within the CPU to control a range of devices.

ii. Generally, the peripherals used in a computer system have different data formats and word lengths than that of CPU used in it.

**5.2. What is function of I/O interface ?**

**Ans.** Function of I/O interface are:

1. Input-output interface enables transfer of data between internal storage and external I/O devices.

2. In order to interface peripherals with the CPU, I/O interfaces contain special communication links. These communication links are used to overcome the difference between the CPU and peripheral such as data transfer speed, mode of operation, etc.

**5.3. Compare memory and I/O bus.**

| <b>Ans.</b> |                                                                                 |                                                                           |
|-------------|---------------------------------------------------------------------------------|---------------------------------------------------------------------------|
| S. No.      | <b>Memory bus</b>                                                               | <b>I/O bus</b>                                                            |
| 1.          | Memory bus shares entire address range.                                         | I/O bus shares only I/O address range.                                    |
| 2.          | Memory bus width is greater than I/O bus width.                                 | I/O bus width is smaller than memory bus width.                           |
| 3.          | Memory bus includes data bus, address bus and control signals to access memory. | I/O bus includes data bus, address bus and control signals to access I/O. |
| 5.4.        | State the drawbacks of programmed I/O and interrupt driven I/O.                 |                                                                           |

**Ques:** Drawbacks of programmed I/O and interrupt driven I/O.

- i. The time that the CPU spends testing I/O device status and executing a number of instructions for I/O data transfer can often be better spent on other task.
- ii. The I/O transfer rate is limited by the speed with which the CPU can test and service a device.

**Ques:** Compare programmed I/O and interrupt driven I/O.

| S.No. | Programmed I/O                                        | Interrupt driven I/O                                       |
|-------|-------------------------------------------------------|------------------------------------------------------------|
| 1.    | It is implemented without interrupt hardware support. | It is implemented using interrupt hardware support.        |
| 2.    | It does not depend on interrupt status.               | Interrupt must be enabled to process interrupt driven I/O. |
| 3.    | It does not need initialization of stack.             | It needs initialization of stack.                          |

**Ques:** Give comparison between I/O program controlled transfer and DMA transfer.

| S.No. | I/O program controlled transfer    | DMA transfer                                           |
|-------|------------------------------------|--------------------------------------------------------|
| 1.    | Software controlled data transfer. | Hardware controlled data transfer.                     |
| 2.    | Data transfer speed is low.        | Data transfer speed is high.                           |
| 3.    | CPU is involved in the transfer.   | CPU is not involved in the transfer.                   |
| 4.    | Extra hardware is not required.    | DMA controller is required to carry-out data transfer. |

**Ques:** State the characteristics of I/O channel.

- i. An I/O channel has a special-purpose processor.
- ii. The I/O instructions are stored in main memory.
- iii. The I/O program specifies the devices, the area of memory storage, priority and actions to be taken for certain error conditions.

**Ques:** Explain the type of I/O channels.

- Ans:** There are two main types of I/O channels :
- i. Selector channel
  - ii. Multiplexer channel

**Ques:** What are the modes of data transfer?

**AKTU 2016-17, Marks 02**

**Ques:** Modes of data transfer are :

- i. Programmed I/O : Programmed I/O operations are the result of I/O instructions written in computer program.
- ii. Interrupt-driven I/O : This mode avoids the drawbacks of programmed I/O by using interrupt request.
- iii. Direct memory access : The interface transfers data onto and out of the memory unit through memory bus.

**Ques:** What is an interrupt?

**Ans:** An interrupt is a signal sent by an I/O interface to the CPU when it is ready to send information to the memory or receive information from the memory.

1. When a CPU receives an interrupt signal it stops executing current normal program.
2. After stopping it saves the state of various registers in stack.
3. When this is done CPU executes a subroutine in order to perform the specific task requested by the interrupt.
4. When this is done CPU returns to the task requested by the interrupt.

**Ques:** Differentiate between synchronous and asynchronous transmission.

**AKTU 2016-17, Marks 02**

| S.No. | Synchronous serial communication                                 | Asynchronous serial communication                        |
|-------|------------------------------------------------------------------|----------------------------------------------------------|
| 1.    | Transmitter and receivers are synchronized by clock.             | Transmitter and receivers are not synchronized by clock. |
| 2.    | Data bits are transmitted with synchronization of constant rate. | Data bits are transmitted at clock.                      |
| 3.    | Data transfer takes place in blocks.                             | Data transfer is character-oriented.                     |

**Ques:** Name the different types of I/O bus.

**Ans:** There are four types of I/O bus which are :

- i. Control command
- ii. Status command
- iii. Output data command
- iv. Input data command

**Ques:** Why are read and write control lines in a DMA controller bidirectional?

**AKTU 2015-16, Marks 02**

- Ans:** Read and write control lines in a DMA controller are bidirectional so that :
1. When a BG input is 0, the CPU can communicate with the DMA registers through the data bus to read from or write to the DMA

2. When BG is 1, the CPU has relinquished the buses and the memory can communicate directly with the memory by specifying an DMA in the address bus and activating RD or WR.

**5.14. What is the use of modem in synchronous communication ?**

**Ans.** A modem converts digital signals into audio tones to be transmitted over telephone lines and also converts audio tones from the line to digital signals for machine use. The modems used in synchronous transmission have internal clocks that are set to the frequency that bits are being transmitted in the communication line.

**5.15. Describe cycle stealing in DMA.**

**AKTU 2016-16, Marks 02**

- In Direct Memory Access (DMA), cycle stealing is a method of allowing I/O controllers to read or write RAM without interfering with the CPU.
- DMA controllers can operate in cycle stealing mode in which controller take over the bus for each byte of data to be transferred and then return control to the CPU.

**5.16. Write the difference between serial and parallel communication.**

**AKTU 2017-18, Marks 02**

| Basis for comparison              | Serial communication                                                     | Parallel communication                                                |
|-----------------------------------|--------------------------------------------------------------------------|-----------------------------------------------------------------------|
| Meaning                           | Data flows in bi-direction, bit by bit                                   | Multiple lines are used to send data i.e., 8 bits or 1 byte at a time |
| Cost                              | Economical                                                               | Expensive                                                             |
| Bits transferred at 1 clock pulse | 1 bit                                                                    | 8 bits or 1 byte                                                      |
| Speed                             | Slow                                                                     | Fast                                                                  |
| Applications                      | Used for long distance communication. For example, computer to computer. | Short distance. For example, computer to printer.                     |

## (SEM. IV) EVEN SEMESTER THEORY EXAMINATION, 2014-15

### COMPUTER ORGANIZATION

Total Marks : 100

**AKTU 2018-19, Marks 02**

Time : 3 Hours  
SECTION - A

SECTION - A

Note: 1. Attempt all questions.  
2. Make suitable assumptions wherever necessary.

**b. Attempt any two parts of the following :**

- Attempt any two parts of the following :
- What is a multiplexer and demultiplexer? Explain how an  $8 \times 1$  multiplexer can be designed using two  $4 \times 1$  multiplexers.
- This question is out of syllabus since session 2017-18.

**a. Simplify the following function using K-map and draw the circuit using AND, OR, NOT gates.**  
 $F(A, B, C, D) = \sum m(0, 2, 8, 9, 10, 11, 13, 15)$

**AKTU** This question is out of syllabus since session 2017-18.

**AKT**

This question is out of syllabus since session 2017-18.

**AKTU** Refer Q. 2.15, Page 2-15B, Unit-2.

**c. Show step by step the multiplication process using booth's algorithm when (+15) and (-13) numbers are multiplied.**

**AKTU** Assume 5-bit registers that hold signed numbers.

**AKTU** Refer Q. 2.6, Page 2-8B, Unit-2.

**d. Attempt any two parts of the following :** (10  $\times$  2 = 20)

- What is an instruction in the context of computer organization? Explain the purpose of the various elements of an instruction with the help of a sample instruction format.
- Refer Q. 3.1, Page 3-2B, Unit-3.

**e. Explain the following addressing modes with the help of an example each :**

- Direct
- Register indirect
- Implied
- Immediate

**AKTU** Refer Q. 1.17, Page 1-17B, Unit-1.

Computer Organization & Architecture

SP-3 B (CS/IT-Sem-3)

- c. Write the steps in fetching a word from memory. Differentiate between a branch instruction and subroutine instruction.
- Ans.** Refer Q. 3.5, Page 3-5B, Unit-3.
3. Attempt any two parts of the following: (10 × 2 = 20)
- Compare and contrast hardwired and micro programmed control units. Also lists their advantages and disadvantages.
  - What are the different categories of micro-operations that may be carried out by CPU? Explain each category of micro operations giving one example for each.
- Ans.** Refer Q. 3.13, Page 3-14B, Unit-3.
- c. Write short notes on the following :
- Microprogram sequencer for control memory.
  - RISC.
- Ans.** Refer Q. 3.17, Page 3-17B, Unit-3.
4. Attempt any two parts of the following: (10 × 2 = 20)
- What is the difference between isolated I/O and memory mapped I/O? Explain the advantages and disadvantages of each.
  - Consider a cache uses a direct mapping scheme. The size of main memory is 4K bytes and word size of cache is 2 bytes. The size of cache memory is 128 bytes. Find the following:
- The size of main memory address (assume each byte of main memory has an address)
  - Address of cache block
  - How many memory location address will be translated to cache address/block/location?
  - How can it be determined if the content of specified main memory address in cache.
- Ans.** Refer Q. 4.16, Page 4-18B, Unit-4.
- c. Explain the following memory schemes discussing why needed the:
- Interleaved memory
  - Associative memory
- Ans.** Refer Q. 4.24, Page 4-24B, Unit-4.

5. Write short notes on any four of the following: (5 × 4 = 20)
- Interrupt
  - Bus arbitration
  - Virtual memory
  - Programmed I/O
  - DMA
  - Organization of 2D and 2.5D
  - Organization of 2D and 2.5D : Refer Q. 4.23, Page 4-23B, Unit-1.
  - Programmed I/O : Refer Q. 5.10, Page 5-9B, Unit-4.
  - DMA : Refer Q. 5.12, Page 5-11B, Unit-5.

@@@

**(SEM. V) ODD SEMESTER THEORY EXAMINATION, 2015-16**

**COMPUTER ARCHITECTURE**

Time : 3 Hours

**SECTION - A**

Total Marks : 100

Note : Attempt all parts. All parts carry equal marks. Write answer of each part in short.

( $2 \times 10 = 20$ )

1. a. What is the main advantage of RTL ?

- b. Define control word.

- c. Give block diagram of microprogram sequencer.

- d. Why are read and write control lines in a DMA controller bidirectional ?

- e. List two important instruction set design issues.

- f. List the two techniques used for grouping the control signals.

- g. Which of L1 and L2 cache is faster ?

- h. What is the use of modem in synchronous communication ?

- i. What is CAM ?

- j. List three types of control signals.

- Ans.** Refer Q. 2.4, Page SQ-3B, Unit-2, Two Marks Questions.
- Ans.** Refer Q. 1.8, Page SQ-2B, Unit-1, Two Marks Questions.
- Ans.** Refer Q. 3.15, Page SQ-7B, Unit-3, Two Marks Questions.
- Ans.** Refer Q. 5.13, Page SQ-16B, Unit-5, Two Marks Questions.
- Ans.** Refer Q. 3.11, Page SQ-7B, Unit-3, Two Marks Questions.
- Ans.** Refer Q. 3.13, Page SQ-7B, Unit-3, Two Marks Questions.
- Ans.** Refer Q. 4.7, Page SQ-11B, Unit-4, Two Marks Questions.
- Ans.** Refer Q. 5.14, Page SQ-17B, Unit-5, Two Marks Questions.

**Note :** Attempt any five questions from this section.

**2. Discuss the advantages and disadvantages of polling and daisy chaining bus arbitration schemes.**

**Ans.**

- a. Briefly define the following terms:

- i. Micro operation

- ii. Micro instruction

- iii. Micro program

- iv. Micro code

- v. Control memory

- Ans.** Refer Q. 3.30, Page 3-31B, Unit-3.

4. What do you mean by CAM ? Explain its major characteristics.

- Ans.** Refer Q. 4.26, Page 4-26B, Unit-4.

5. Explain various types of processor organization.

- Ans.** Refer Q. 1.16, Page 1-17B, Unit-1.

6. Explain the sequence that takes place when an interrupt occurs.

- Ans.** Refer Q. 5.5, Page 5-5B, Unit-5.

7. A computer uses RAM chips of  $1024 \times 1$  capacity.

- i. How many chips are needed and how should their address lines be connected to provide a memory capacity of  $1024 \times 8$  ?

- ii. How many chips are needed to provide a memory capacity of  $16 \text{ KB}$ ? Explain in words how the chips are to be connected to the address bus.

- Ans.** Refer Q. 4.8, Page 4-11B, Unit-4.

8. A ROM chip of  $1024 \times 8$  has four select inputs and operates from a 5 volt power supply. How many pins are needed for the IC package ? Draw a block diagram and label all input and output terminals in the ROM.

- Ans.** Refer Q. 4.9, Page 4-11B, Unit-4.

9. i. What are the differences between hardwired and microprogrammed control unit ?

- Ans.** Refer Q. 3.25, Page 3-25B, Unit-3.

- ii. What is RISC ? Explain its various characteristics.

- Ans.** Refer Q. 3.17, Page 3-17B, Unit-3.

B.Tech.

- Note: Attempt any two questions from this section.
10. i. What is the distinction between spatial locality and temporal locality? (15 x 2 = 30)
- Ans:** Refer Q. 4.18, Page 4-19B, Unit-4.

- ii. Show the multiplication process using Booth's algorithm when the following numbers are multiplied : (-13) by (+8)
- Ans:** Refer Q. 2.8, Page 2-9B, Unit-2.

11. Why input output interface is required ? Describe in detail.
- Ans:** Refer Q. 5.2, Page 5-2B, Unit-5.

12. Differentiate among :
- Strobe control and handshaking asynchronous data transfer modes.
  - Processor and IOP.
  - Synchronous and asynchronous transmission.
  - Character-oriented and Bit-oriented protocols.
  - DMA and interrupt initiated I/O techniques.
- Ans:** Refer Q. 5.19, Page 5-18B, Unit-5.



Time: 3 Hours

## (SEM. V) ODD SEMESTER THEORY EXAMINATION, 2016-17 COMPUTER ARCHITECTURE

### SECTION - A

Total Marks: 100

- Note: Attempt all questions : (2 x 10 = 20)
1. Define following terms :

- i. RTL      ii. Micro-operation

- Ans:** Refer Q. 2.3, Page SQ-3B, Unit-2, Two Marks Questions.

2. Define sequencer.

- Ans:** Refer Q. 3.12, Page SQ-7B, Unit-3, Two Marks Questions.

3. Explain one, two and three address instruction.

- Ans:** Refer Q. 3.1, Page SQ-5B, Unit-3, Two Marks Questions.

4. Define the following terms :

- i. Effective address    ii. Immediate instruction

- Ans:** Refer Q. 3.5, Page SQ-6B, Unit-3, Two Marks Questions.

5. Explain the following terms :

- i. PSW      ii. Delayed load

- Ans:** Refer Q. 4.14, Page SQ-12B, Unit-4, Two Marks Questions.

6. Differentiate SIMD and MIMD.

**Ans:**

| S.No. | SIMD                                                             | MIMD                                                                            |
|-------|------------------------------------------------------------------|---------------------------------------------------------------------------------|
| 1.    | It stands for Single Instruction Stream, Multiple Data Stream.   | It stands for Multiple Instruction Stream, Multiple Data Stream.                |
| 2.    | In this, a parallel computer consists of N identical processors. | In this, we have N processors, N streams of instructions and N streams of data. |

7. What are the modes of data transfer ?
- Ans:** Refer Q. 5.9, Page SQ-15B, Unit-5, Two Marks Questions.

8. What is an interrupt ?

**Ques.** Refer Q. 5.10, Page SQ-16B, Unit-5, Two Marks Questions.

**Ques.** Differentiate between synchronous and asynchronous transmission.

**Ans.** Refer Q. 5.11, Page SQ-16B, Unit-5, Two Marks Questions.

**Ques.** What is cache memory used for?

**Ans.** Refer Q. 4.8, Page SQ-11B, Unit-4, Two Marks Questions.

### SECTION - B

**Note:** Attempt any five questions:

1. Show the contents of the registers E, A, Q, SC during the process of multiplication of two binary numbers (multiplicand) and 10101 (multiplier). The signs are not included.

**Ans.** Refer Q. 2.7, Page 2-8B, Unit-2.

2. In an instruction format, there are 16 bits in an instruction word. Bit 0 to 11 convey the address of the memory location for memory related instructions. For non memory location instructions these bits convey various register or I/O operations. Bits 12 to 14 show the various basic memory operations such as ADD, AND, LDA etc. Bit 15 shows if the memory is accessed directly or indirectly. For such an instruction format draw block diagram of the control unit of a computer and briefly explain how an instruction will be decoded and executed, by this control unit.

**Ans.** Refer Q. 3.7, Page 3-7B, Unit-3.

3. Write an assembly level program for the following pseudocode:

SUM = 0

SUM = SUM + A + B

DIF = DIF.C

SUM = SUM + DIF

**Ans.** Refer Q. 3.31, Page 3-32B, Unit-3.

4. Explain microprogram sequencer for a control memory using a suitable block diagram.

**Ans.** Refer Q. 3.27, Page 3-28B, Unit-3.

5. Give the detailed comparison between RISC and CISC.

**Ans.** Refer Q. 3.18, Page 3-17B, Unit-3.

**Note:** Attempt any two questions:

**Ques.** Explain the Booth's algorithm in depth with the help of flowchart. Give an example for multiplication with the help of (15 x 2 = 30) algorithm.

**Ans.** Refer Q. 2.3, Page 2-4B, Unit-2.

**Ques.** How main memory is useful in computer system? Explain the memory address map of RAM and ROM.

**Ans.** Refer Q. 4.7, Page 4-9B, Unit-4.

1. Draw a block diagram of a computer's CPU showing all the basic building blocks such as program counter, register, control unit etc., and describe how such an arrangement can work as a computer, if connected properly to memory, input / output etc.

**Ans.** Refer Q. 1.1, Page 1-2B, Unit-1.

2. Describe the subroutine. Write a program which move the block of data.

**Ans.** Refer Q. 5.20, Page 5-20B, Unit-5.

3. Explain the operation of three state bus buffers and show its use in design of common bus.

**Ans.** Refer Q. 1.8, Page 1-9B, Unit-1.

4. Explain the operation of second pass of assembler using a suitable diagram.

**Ans.** Refer Q. 3.34, Page 3-33B, Unit-3.

5. Write a program loop using a pointer and a counter to clear the contents of hex locations 500 to 5FF with 0.

**Ans.** Refer Q. 3.35, Page 3-33B, Unit-3.

6. Demonstrate the process of second pass of assembler using a suitable diagram.

**Ans.** Refer Q. 3.34, Page 3-33B, Unit-3.

7. Explain:
- i. Vector processing
  - ii. Vector operations

Explain how matrix multiplication is carried out on a computer supporting vector computations.

**Ans.** This question is out of syllabus since session 2018-19.

8. Explain:
- i. Vector processing
  - ii. Vector operations

10. How addressing mode is significant for referring memory?  
List and explain different types of addressing modes.  
Ans: Refer Q. 1.20, Page 1-22B, Unit-1.

11. What is a memory stack ? Explain its role in managing subroutines with the help of neat diagrams.  
Ans: Refer Q. 1.13, Page 1-14B, Unit-1.

12. What is stack ? Give the organization of register stack with all necessary elements and explain the working of push and pop operations.  
Ans: Refer Q. 1.12, Page 1-13B, Unit-1.

13. Write a note on subroutines.  
Ans: Refer Q. 5.20, Page 5-20B, Unit-5.

14. Draw the block diagram of control unit of basic computer. Explain in detail with control timing diagrams.  
Ans: Refer Q. 2.20, Page 2-19B, Unit-2.

15. List and explain different types of shift micro-operation.  
Ans: Refer Q. 3.12, Page 3-12B, Unit-3.



Time : 3 Hours

Max. Marks : 70

Note: 1. Attempt all Sections. If require any missing data, then choose suitably.

### SECTION - A

1. Attempt all questions in brief. (2 x 7 = 14)

- a. Draw the circuit diagram of D flip-flop.  
Ans: This question is out of syllabus since session 2018-19.

- b. Write the difference between RAM & ROM  
Ans: Refer Q. 4.16, Page SQ-13B, Unit-4, Two Marks Questions.

- c. Write short note on pipelining process.  
Ans: Refer Q. 3.16, Page SQ-8B, Unit-3, Two Marks Questions.

- d. Write the difference between serial and parallel communication.  
Ans: Refer Q. 5.16, Page SQ-17B, Unit-5, Two Marks Questions.

- e. Perform the following operation on signed numbers using 2's compliment method :  $(56)_{10} + (-27)_{10}$

- Ans: Refer Q. 2.10, Page SQ-4B, Unit-2, Two Marks Questions.

- f. Write speed up performance laws.

- Ans: Speed up performance laws are as follow:

1. **Andahl's Law :** According to Andahl's law, if the fraction of computation that cannot be divided into concurrent tasks is  $f$ , and no overhead occurs when the computation is divided into concurrent parts, the time to perform the computation with  $n$  processors is given by,

$$f t_s + (1 - f) t_f/n$$

2. **Gustafson's Law :** This law states that any sufficiently large problem can be efficiently parallelized, the sequential operations will no longer be a bottleneck if the number of parallel operations in the problem is scaled-up sufficiently.

**3. Sun and Ni's law :** This law is a generalization of Andahl's law and Gustafson's law. This model maximizes the use of both CPU and memory capacity.

### e. Differentiate between horizontal and vertical microprogramming.

**Ans:** Refer Q. 3.17, Page SQ-8B, Unit-3, Two Marks Questions.

### SECTION-B

**2. Attempt any three of the following :**

**a. What is programmable logic device ? List various techniques to program PLD. Explain any one technique with example.**

**Ans.** PLDs are semiconductor devices that can be programmed to obtain required logic device.

**2. Because of the advantage of re-programmability they have replaced special purpose logic devices like logic gates, flip-flops, counters and multiplexers in many semicustom applications.**

**3. It consists of arrays of AND and OR gates, which can be programmed to realize required logic function.**

**4. The process of entering the information into these devices is known as programming.**

**5. Basically, users can program these devices or ICs electrically in order to implement the Boolean functions based on the requirement.**

#### Various techniques to program PLD are :

1. Programmable Read Only Memory (PROM)
2. Programmable Logic Array (PLA)
3. Programmable Array Logic (PAL)

**i. PAL is a programmable logic device that has Programmable AND array & fixed OR array.**

**ii. The advantage of PAL is that we can generate only the required product terms of Boolean function instead of generating all the main terms by using programmable AND gates.**

**iii. The block diagram of PAL is shown in Fig. 1.**



**Fig. 1.**

**Example:**  
**Full adder using PAL :** There are two functions used for the implementation of full adder :



**Fig. 2.**

$$S = \bar{A}\bar{B}C + \bar{A}B\bar{C} + A\bar{B}\bar{C} + ABC$$

$$C = ABC + A\bar{B}C + \bar{A}BC + ABC$$

- b. i. Draw the block diagram for a small accumulator based CPU.**  
**ii. How floating point numbers are represented in computer, also give IEEE 754 standard 32-bit floating point number format.**

**Ans.** i. Refer Q. 1.15, Page 1-16B, Unit-1.

ii. Floating point number : Refer Q. 2.16, Page 2-16B, Unit-2.

**c. Draw the data path of sequential  $n$ -bit binary divider. Give the non-restoring division algorithm for unsigned integers. Also illustrate algorithm for unsigned integer with a suitable example.**

**d. Datapath of sequential  $n$ -bit binary divider :**  
 Refer Q. 2.13, Page 2-13B, Unit-2.

**Algorithm for non-restoring division :**  
 Refer Q. 2.11, Page 2-12B, Unit-2.

**d. What is micro programmed control unit ? Give the basic structure of micro programmed control unit. Also discuss the microinstruction format and the control unit.**

**Ans.** Refer Q. 3.26, Page 3-26B, Unit-3.

e. What do you mean by locality of reference? Explain with suitable example.

**Ans.** Refer Q. 4.28, Page 4-28B, Unit-4.

### SECTION-C

3. Attempt any one part of the following:

a. Differentiate between RISC & CISC based microprocessors.

**Ans.** Refer Q. 3.18, Page 3-17B, Unit-3.

b. Explain booth's multiplication algorithm in detail.

**Ans.** Refer Q. 2.3, Page 2-4B, Unit-2.

4. Attempt any one part of the following:

a. Draw the data path of 2's compliment multiplier. Give the Robertson multiplication algorithm for 2's compliment fractions. Also illustrate the algorithm for 2's compliment fraction by a suitable example.

**Ans.** Refer Q. 2.5, Page 2-7B, Unit-2.

b. Describe sequential Arithmetic & Logic Unit (ALU) using proper diagram.

**Ans.** Refer Q. 2.1, Page 2-2B, Unit-2.

5. Attempt any one part of the following:

a. Give the structure of commercial 8M  $\times$  8 bit DRAM chip.

**Ans.** Refer Q. 4.4, Page 4-4B, Unit-4.

b. Explain the working of DMA controller with help of suitable diagrams.

**Ans.** Refer Q. 5.12, Page 5-11B, Unit-5.

6. Attempt any one part of the following:

a. What is hardwired control? List various design methods for hardwired control. Discuss in detail using diagram any one of the method for designing GCD processor.

**Ans.** Hardwired control and design methods : Refer Q. 3.23, Page 3-23B, Unit-3.

**FSM based design of GCD processor :**

- First write algorithms for calculation of GCD, after that data paths and control unit is designed for GCD processor.
- In this model, both the FSM and the data path circuits are manually constructed as separate units.
- The FSM and the data path are connected together in an enclosing unit using the control and status signals.



Fig. 3. Euclid's algorithm.

- The algorithm shown in Fig. 3 has five data manipulation statements in lines 1, 2, 5, 7, and 10.
- There are two conditional tests in lines 3 and 4.



Fig. 4. Datapaths of GCD processor.

- We can conclude that the data path requires two 8-bit registers, one for variable X, and one for variable Y, and a subtractor.
- The dedicated data path is shown in Fig. 4.
- In Fig. 4, we have a 2-to-1 mux for the input of each register because for each register, we need to initially load it with an input number, and subsequently load it with the result from the subtractor.

9. The two control signals, In\_X and In\_Y select which of the two sources are to be loaded into the registers X and Y respectively.
10. The two control signals, load\_X and load\_Y, load a value into the respective register.

b. How pipeline performance can be measured? Discuss Give

Pipeline performance : Refer Q. 3.21, Page 3-21B, Unit-3  
Space time graph :



Fig. 5.

7. Attempt any one part of the following:

- a. Discuss the various types of address mapping used in cache memory. (7 x 1 = 7)

Ans: Refer Q. 4.14, Page 4-14B, Unit-4.

b. A moving arm disc storage device has the following specifications:

Number of Tracks per recording surface = 200

Disc rotation speed = 2400 revolution/minute

Track-storage capacity = 62500 bits

Estimate the average latency and data transfer rate of this device.

Ans: Refer Q. 4.22, Page 4-23B, Unit-4.

☺☺☺

time : 3 Hours  
Note: 1. Attempt all Sections. If require any missing data; then choose suitably.

### SECTION - A

(2 x 7 = 14)

c. What is the difference between RAM and DRAM?

- Ans: Refer Q. 4.2, Page SQ-10B, Unit-4, Two Marks Questions.
- d. What are the difference between horizontal and vertical micro codes?

- Ans: Refer Q. 3.18, Page SQ-9B, Unit-3, Two Marks Questions.

e. Describe cycle stealing in DMA.

- Ans: Refer Q. 5.15, Page SQ-17B, Unit-5, Two Marks Questions.

f. List three types of control signals.

- Ans: Refer Q. 3.14, Page SQ-7B, Unit-3, Two Marks Questions.

g. Define the role of MMU in computer architecture.

- Ans: The role of MMU is to provide an environment for the computer processors to operate on programs which have their own instruction and data.

### SECTION-B

2. Attempt any three of the following : (7 x 3 = 21)
- a. Evaluate the arithmetic statement  $X = (A + B) * (C + D)$  using a general register computer with three address, two address

and one address instruction format a program to evaluate the expression.

**Ans:** Refer Q. 3.3, Page 3-4B, Unit-3.

- b. Perform the division process of 00001111 by 0011 (use a dividend of 8 bits).

**Ans:** Refer Q. 2.14, Page 2-15B, Unit-2.

- c. A two way set associative cache memory uses blocks of words. The cache can accommodate total of 2048 blocks of memory. The main memory size is  $128\text{ K} \times 32$ .

- i. Formulate all pertinent information required to construct the cache memory.

- ii. What is the size of cache memory?

**Ans:** Refer Q. 4.17, Page 4-19B, Unit-4.

- d. What is associative memory? Explain with the help of a block diagram. Also mention the situation in which associative memory can be effectively utilized.

**Ans:** Refer Q. 4.25, Page 4-26B, Unit-4.

- e. A computer uses a memory unit with 256 K words of 32 bits each. A binary instruction code is stored in one word of memory. The instruction has four parts: an indirect bit, an operation code, a register code part to specific one of 64 register and an address part.

- i. How many bits are there in the operation code, the register code part and the address part?

- ii. Draw the instruction word format and indicate the number of bits in each part.

- iii. How many bits are there in the data and address inputs of the memory?

**Ans:** Refer Q. 4.10, Page 4-12B, Unit-4.

### SECTION-C

(7x1=7)

3. Attempt any one part of the following :

- a. Write short notes on :

- i. Instruction pipeline  
ii. DMA based data transfer

**Ans:**

- i. Refer Q. 3.20, Page 3-21B, Unit-3.  
ii. Refer Q. 5.12, Page 5-11B, Unit-5.

- b. Explain the difference between vectored and non-vectored interrupt. Explain stating examples of each.

**Ans:** Refer Q. 5.8, Page 5-8B, Unit-5.

4. Attempt any one part of the following:

- a. Draw the flowchart of Booth's algorithm and show the multiplication algorithm for  $(-7) \times (+3)$ . Refer Q. 2.9, Page 2-9B, Unit-2.

- b. Write short notes on :

- i. Andahl's law  
ii. Pipelining

- i. Refer Q. 1(f), Page SQ-11B, Solved Paper 2017-18.  
ii. Refer Q. 3.19, Page 3-18B, Unit-3.

5. Attempt any one part of the following:

- a. What is a microprogram sequencer? With block diagram, explain the working of microprogram sequencer.

- b. Draw a flowchart for adding and subtracting two fixed point binary numbers where negative numbers are signed 1's complement presentation.

- Ans:** Refer Q. 2.21, Page 2-20B, Unit-2.

6. Attempt any one part of the following:

- a. Give the block diagram of DMA controller and write control lines in a DMA controller bidirectional?

- Ans:** Refer Q. 5.12, Page 5-11B, Unit-5.

- b. Explain all the phases of instruction cycle.

- Ans:** Refer Q. 3.4, Page 3-4B, Unit-3.

7. Attempt any one part of the following:

- a. Explain the basic concept of hardwired and software control

**Ans:** Refer Q. 3.25, Page 3-25B, Unit-3.

b.

|    | 1 | 2 | 3 | 4 | 5 | 6 |
|----|---|---|---|---|---|---|
| S1 | X |   |   |   |   | X |
| S2 |   | X |   |   |   | X |
| S3 |   |   | X |   |   |   |
| S4 |   |   |   | X |   |   |
| S5 |   | X |   |   |   | X |

- i. For the following reservation table :

- ii. Calculate the set of the forbidden latencies and collision vector.

- iii. Draw a state diagram, showing all possible initial sequences (cycles) without a collision in the pipeline.

- iii. Simple Cycles (SC)  
 iv. Greedy cycles among simple cycles  
 v. MAL (Minimum Average Latency)  
 vi. What is the minimum allowed constant cycles?  
 vii. Maximum throughput if the minimum constant cycle is used.

**Ans.** i. The forbidden latencies are 3, 4, and 5 ( $S_1 : 5$ ;  $S_2 : 3$ ;  $S_3 : 0$ ;  $S_4 : 0$  and  $S_5 : 4$ ), so that the collision vector is  $C_x = 11100$  where the permissible latencies are 1 and 2.  
 State diagram can be obtained by tracing each  $C_x$  shift as followed:

|                                          | 1 <sup>st</sup> shift | 2 <sup>nd</sup> shift | 3 <sup>rd</sup> shift | 4 <sup>th</sup> shift | 5 <sup>th</sup> shift |
|------------------------------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|
| shifted bit                              | 01110                 | 01111                 | 00111                 | 11100                 | 11111                 |
| $C_x$                                    | <u>11100</u>          | <u>11111</u>          | <u>00111</u>          | <u>11100</u>          | <u>11111</u>          |
| new value                                | 11110                 | 11111                 | 00111                 | 11100                 | 11111                 |
| <b>1-shift from 2<sup>nd</sup> shift</b> |                       |                       |                       |                       |                       |
| shifted bit                              | 01111                 | 01110                 | 00110                 | 11101                 | 11110                 |
| $C_x$                                    | <u>11111</u>          | <u>11110</u>          | <u>00110</u>          | <u>11101</u>          | <u>11110</u>          |
| new value                                | 11111                 | 11110                 | 00110                 | 11101                 | 11110                 |
| <b>2-shift from 1<sup>st</sup> shift</b> |                       |                       |                       |                       |                       |
| shifted bit                              | 00111                 | 00110                 | 00100                 | 11100                 | 11111                 |
| $C_x$                                    | <u>00111</u>          | <u>00110</u>          | <u>00100</u>          | <u>11100</u>          | <u>11111</u>          |
| new value                                | 00111                 | 00110                 | 00100                 | 11100                 | 11111                 |



Fig. 2.

- iii. The simple cycles are (2), (6), (1, 6) and (2, 6).  
 iv. The greedy cycles are (2) and (1, 6).  
 v. According to the lowest greedy cycle's average latency, the MAL (Minimum Average Latency) is 2.  
 vi. Minimum allowed constant cycle is 2.  
 vii. The maximum throughput is  $\frac{1}{\text{MAL}} = \frac{1}{2} = 0.5$  i.e., 50%.  
 viii. The minimum constant cycle is 2, so that the maximum throughput does not change, only 50%.

## (SEM. II) ODD SEMESTER EXAMINATION, 2019-20 COMPUTER ORGANIZATION AND ARCHITECTURE

**Note:** 1. Attempt all Sections. If require any missing data, then choose suitably.

Max. Marks : 100

### SECTION-A

1. Attempt all questions in brief.

**Ans.** a. Define the term computer architecture. (2 x 10 = 20)

**Ans.** Computer architecture refers to those attributes of a system that are visible to a programmer or, those attributes of a system that impact on the logical execution of a program.

- b. Draw the basic functional units of a computer.

**Ans.** Refer Q. 1.2, Page 1-3B, Unit-1.

- c. Perform the 2's complement subtraction of smaller number (101011) – (101011).

**Ans.** Step 1 : 1's complement of 101011 = 010100  
 Step 2 : 2's complement of 101011 = 010100

Step 3 : Adding minuend and 2's complement obtained in Step 2.

|             |   |             |
|-------------|---|-------------|
| 1 1 1 0 1 1 | + | 0 1 0 1 0 0 |
| —————       |   |             |
| 0 0 1 1 1 0 |   |             |

Carry  $\rightarrow$  1 0 0 1 1 1 0

The sum produce a carry because minuend > subtrahend. So, discard carry and write the remaining bits.  
 $(111001) - (101011) = 001110$

- d. What is the role of multiplexer and decoder?

**Ans.** Role of multiplexer is to combine multiple inputs into a single data stream.

Role of decoder is to translate a code into a set of control signals.

- e. Write the differences between RISC and CISC.

**Ans.** Refer Q. 3.18, Page 3-17B, Unit-3.

- c. What are the types of microinstructions available?  
**Ans.** Following types of microinstructions are available:
- Vertical/horizontal
  - Packed / unpacked
  - Hard / soft microprogramming
  - Direct / indirect encoding

**g. What is SRAM and DRAM?**

**Ans.** Refer Q. 4.3, Page 4-4B, Unit-4.

- h. What is the difference between 2D and  $2^{1/2}$  D memory?

**Ans.**

| S.No. | 2D memory organizations                                  | $2^{1/2}$ D memory organizations                        |
|-------|----------------------------------------------------------|---------------------------------------------------------|
| 1.    | In 2D organization, hardware is fixed.                   | In $2^{1/2}$ D organization, hardware changes.          |
| 2.    | 2D organization requires more number of gates.           | $2^{1/2}$ D organization requires less number of Gates. |
| 3.    | Error correction is not possible in the 2D organization. | In $2^{1/2}$ D organization, error correction is easy.  |

i. What is I/O control method?

**Ans.** Usually microprocessor controls the process of data transfer between the microprocessor and the peripherals. However, sometimes peripherals also controls the data transfer. However, such time I/O control methods are used. The I/O control methods are employed when the peripheral is capable of transferring the data at higher or slower speed than the processor.

j. What is bus arbitration?

**Ans.** Refer Q. 1.5, Page 1-7B, Unit-1.

## SECTION-B

(10 × 3 = 30)

2. Attempt any three of the following:
- a. Convert the following arithmetic expressions from infix to reverse polish notation:

- $A * B + C * D + E * F$
- $A * \{B + C * CD + EF\} * (G + H)$

$$\text{ANS. i } A * B + C * D + E * F$$

$$\text{ANS. ii } \underline{\underline{AB}} + C * D + E * F$$

$$\begin{aligned} X * C * D + E * F &= X = AB * \\ X * \underline{\underline{CD}} + E * F &= Y = CD * \\ X * Y + E * F &= XY + \underline{\underline{EF}} \\ X + Y + \underline{\underline{EF}} &= Z = EF * \\ X + Y + Z &= \underline{\underline{XY}} + Z \end{aligned}$$

$$P = XY + \\ PZ + \\ \underline{\underline{Q}} = PZ +$$

$$\text{On putting value} \\ PZ +$$

$$= XY + Z +$$

$$= XY + EF * +$$

$$= XCD * + EF * +$$

$$= AB * CD * + EF * +$$

$$= AB * [B + C * CD + E] / F * (G + H)$$

$$\text{Assume } D + E \text{ in the bracket then expression becomes} \\ A * [B + C * (D + E)] / F * (G + H)$$

$$A * [B + C * DE +] / F * (G + H)$$

$$A * [B + C * T_1] / F * (G + H)$$

$$A * [B + \underline{\underline{CT_1}}] / F * (G + H)$$

$$A * (B + T_1) / F * (G + H)$$

$$A * BT_2 / F * (G + H)$$

$$A * T_3 / F * (G + H)$$

$$A * T_3 / F * GH +$$

$$A * T_3 / F * T_4$$

$$A * T_3 F / * T_4$$

$$A * T_5 * T_4$$

$$A * T_5 * T_4$$

$$\underline{\underline{AB}} + C * D + E * F$$

$$T_5 = T_3 F /$$

$$T_3 = BT_2 +$$

$$T_4 = GH +$$

$$\begin{aligned}
 T_6 * T_4 & \\
 T_6 = A T_4 & \\
 T_7 = T_6 T_4 & \\
 \text{on putting value of } T_7 \\
 = T_6 T_4 & \\
 = A T_5 * GH + * \\
 = A T_3 F / * GH + * \\
 = A BT_2 + F / * GH + * \\
 = A BCT_1 * + F / * GH + * \\
 = A BCDE + * + F / GH + * \\
 = A BCDE + * F / GH + *
 \end{aligned}$$

b. Design a 4-bit carry look ahead adder and explain its operation with an example.

Refer Q. 2.2, Page 2-2B, Unit-2.

c. Draw the timing diagram for an instruction cycle and explain.

Give a note on subroutine.

**Ans:**

i. Let consider the instruction cycle for instruction STAX rp.

This instruction stores the contents of A register in memory whose address is specified by register pair (BC or DE).

It requires the following machine cycles :

1. **Opcode fetch :** Program counter places the memory address on low order and high order address bus. This machine cycle is required for reading the opcode of STAX rp (e.g. 0211 for STAX B) into the microprocessor and decode it.
2. **Memory write :** Higher order address is obtained from higher order register and lower address is obtained from lower order register of the specified register pair. The contents of the accumulator are stored into the addressed memory location. Thus memory write machine cycle is required for writing the data from the microprocessor (A register) to the addressed memory location.



Fig. 1.

ii. Refer Q. 5.20, Page 5-20B, Unit-5.

d. What do you mean by virtual memory? Discuss how paging helps in implementing virtual memory.

**Ans:** Virtual memory : Refer Q. 4.23, Page 4-23B, Unit-4.

Paging helps in implementing virtual memory as :

1. Virtual memory space is divided into equal size pages.
2. Main memory space is divided into equal size page frames each frame can hold any page from virtual memory.
3. When CPU wants to access page, it first looks into main memory.
4. If it is found in main memory then it is called Hit and page is transferred from main memory to CPU.
5. There are different page replacement schemes such as FIFO, LRU, LFU etc.
6. During page replacement, if the old page has been modified in the main memory, then it needs to be first copied into the virtual memory and then replaced. CPU keeps track of such updated pages by maintaining dirty bit for each page. When page is updated in main memory dirty bit is set then this dirty page first copied into virtual memory and then replaced.

**SP-26 B (CSIT-Sem-3)**

Solved Paper (2019-20)

7. Pages are loaded into main memory only when required by the CPU, then it is called demand paging. Thus pages are loaded only after page faults.

e. What is DMA? Describe how DMA is used to transfer data from peripherals.

**Ans:** Refer Q. 5.12, Page 5-11B, Unit-5.

**SECTION-C**

$$\begin{aligned} (65.175)_{10} &= (100001.0010110)_2 \\ \text{Step 2: Normalize the number.} \\ (100001.0010110) &= 1.000001001 \times 2^6 \\ \text{Step 3: Representing the floating point in single precision:} \\ \text{for a given } S = 0 \\ E = 6 \\ M = 0000010010110 \end{aligned}$$

$$\begin{aligned} \text{Bias of single precision format} &= 127 \\ E' &= 127 + 6 \\ &= 133 \\ &= (1101101)^2 \end{aligned}$$



Fig. 2.

ii.  $(-307.1875)_{10}$   
Step 1: Convert the decimal number in binary format

Integer format :

- a. Represent the following decimal number in IEEE standard floating-point format in a single precision method (32-bit) representation method :
- $(65.175)^{10}$
  - $(-307.1875)^{10}$

**Ans:** i.  $(65.175)^{10}$

Step 1 : Convert the decimal number in binary format  
Integer format :

$$\begin{array}{r} 2 \mid 65 \\ 2 \mid 32 \quad 1 \\ 2 \mid 16 \quad 0 \\ 2 \mid 8 \quad 0 \\ 2 \mid 4 \quad 0 \\ 2 \mid 2 \quad 0 \\ 1 \quad 0 \end{array} \quad (65)_{10} = (1\ 0\ 0\ 0\ 0\ 0\ 1)_2$$

Fractional format :

$$\begin{array}{l} 0.1875 \times 2 = 0.3750 \Rightarrow 0 \\ 0.3750 \times 2 = 0.750 \Rightarrow 0 \\ 0.750 \times 2 = 1.5 \Rightarrow 1 \\ 0.5 \times 2 = 1.0 \Rightarrow 1 \\ (0.1875)_{10} = (0.0011)_2 \end{array}$$

Fractional format :

$$\begin{array}{l} 0.175 \times 2 = 0.35 \Rightarrow 0 \\ 0.35 \times 2 = 0.7 \Rightarrow 0 \\ 0.7 \times 2 = 1.4 \Rightarrow 1 \\ 0.4 \times 2 = 0.8 \Rightarrow 0 \\ 0.8 \times 2 = 1.6 \Rightarrow 1 \\ 0.6 \times 2 = 1.2 \Rightarrow 1 \\ 0.2 \times 2 = 0.4 \Rightarrow 0 \end{array}$$

$$\begin{array}{l} (307.1875)_{10} = (100110011.0011)_2 \\ -307.1875_{10} = -100110011.0011_2 \\ \text{Step 2: Normalize the number} \\ -100110011.001 = -1.00110011001 \times 2^8 \end{array}$$

Step 3: Representing the number in single precision.

For a given number  
 $S = 1$  (given number is negative number)  
 $E = 8$   
 $M = 00110011001$

Bias of single precision format is = 127  
 $E' = 127 + E = 127 + 8$   
 $= (135)^{10}$   
 $= (1000\ 0111)^2$

Number in single precision format  


|   |          |                   |
|---|----------|-------------------|
| 0 | 10000111 | 00110011001.....0 |
|---|----------|-------------------|

- b. Using Booth's algorithm perform the multiplication on the following 8-bit unsigned integer  $10110011 * 11010101$ .

**Ans.** Multiplicand (M) = 10110011, Multiplier = 11010101

| A        | Q        | Q <sub>n+1</sub> | Operation                   | SC   |
|----------|----------|------------------|-----------------------------|------|
| 00000000 | 11010101 | 0                |                             | 1000 |
| 01001101 | 11010101 | 0                | $A \rightarrow A - M$       | 0111 |
| 00100010 | 11010101 | 1                | Ashr A, Q, Q <sub>n+1</sub> |      |
| 11011001 | 11010100 | 1                | $A \rightarrow A + M$       | 0110 |
| 11101100 | 11101011 | 0                | Ashr A, Q, Q <sub>n+1</sub> |      |
| 00111001 | 11101011 | 0                | $A \rightarrow A - M$       | 0101 |
| 00011100 | 11110101 | 1                | Ashr A, Q, Q <sub>n+1</sub> |      |
| 11001111 | 11110100 | 1                | $A \rightarrow A + M$       | 0100 |
| 11100111 | 11111010 | 0                | Ashr A, Q, Q <sub>n+1</sub> |      |
| 00110100 | 11111011 | 0                | $A \rightarrow A - M$       | 0011 |
| 00011010 | 01111110 | 1                | Ashr A, Q, Q <sub>n+1</sub> |      |
| 11001101 | 01111110 | 1                | $A \rightarrow A + M$       | 0010 |
| 11100110 | 10111111 | 0                | Ashr A, Q, Q <sub>n+1</sub> |      |
| 00110011 | 10111111 | 0                | $A \rightarrow A - M$       | 0001 |
| 00011001 | 11011111 | 1                | Ashr A, Q, Q <sub>n+1</sub> |      |
| 00001100 | 11101111 | 1                |                             | 0000 |

Result = 0000110011101111 (+ 33 11)

5. Attempt any one part of the following :

- a. What is parallelism and pipelining in computer architecture?

(10 × 1 = 10)

**Ans.** Parallelism in computer architecture :  
 Executing two or more operations at the same time is known as parallelism.

- The purpose of parallel processing (parallelism) is to speed up the computer processing capability i.e., it increases the speed up the speed.
- It also increases throughput, i.e., amount of computational accomplished during a given interval of time.
- Improves the performance of the computer.
- Two or more ALUs in CPU can work concurrently to increase throughput. The system may have two or more processors operating concurrently.

Pipelining : Refer Q. 3.19, Page 3-18B, Unit-3.

- b. Explain the organization of microprogrammed control unit in detail.

Refer Q. 3.26, Page 3-26B, Unit-3.

- Ans.** Attempt any one part of the following :  
 6. Discuss the different mapping techniques used in cache memories and their relative merits and demerits.  
 Different mapping techniques : Refer Q. 4.14, Page 4-14B, Unit-4.

Merits and demerits of different mapping techniques:

Merits of direct mapping:

1. Direct mapping is simplest type of cache memory mapping.
2. Here only tag field is required to match while searching word that is why it fastest cache.
3. Direct mapping cache is less expensive compared to associative cache mapping.

Demerits of direct mapping:  
 1. The performance of direct mapping cache is not good as requires replacement for data+tag value.

Merits of associative mapping:

1. Associative mapping is fast.
2. Associative mapping is easy to implement.

Demerits of associative mapping:

1. Cache Memory implementing associative mapping is expensive as it requires to store address along with the data.

Merits of Set-Associative mapping:

1. Set-Associative cache memory has highest hit-ratio compared two previous two cache memory discussed above. Thus its performance is considerably better.
1. Set-Associative cache memory is very expensive. As the set size increases the cost increases.

b. RAM chip  $4096 \times 8$  bits has two enable lines. How many pins are needed for the integrated circuits package ? Draw block diagram and label all input and outputs.

**Ans:** What is main feature of random access memory ? Draw a Size of RAM chip =  $4096 \times 8$  Number of input = 14 pins ( $2^{14} = 4096$ ) Number of output = 8 pin Number of chip select = 2 pin Number of power pin = 2 pin Total pins required =  $14 + 8 + 2 + 2 = 26$  pins



Fig. 3.

**Features of random access memory :**

1. RAM is volatile memory and requires power to store data.
2. RAM is used to store the data for processing on CPU.
3. RAM chips often range in storage capacity from 1 GB to 256 GB.
4. RAM chip is used to increase the speed of the computer.
5. RAM is attempt any one part of the following :

(10 x 1 = 10)

- a. Write down the difference between isolated I/O and memory mapped I/O. Also discuss advantages and disadvantages of isolated I/O and memory mapped I/O.

**Ans:** Refer Q. 5.13, Page 5-13B, Unit-5.

- b.

- i. Discuss the design of a typical input or output interface.
- ii. What are interrupts ? How are they handled ?

**Ans:** i. 1. The I/O interface includes control and timing requirements to coordinate the flow of traffic between internal resources (memory, system bus) and external devices.

Interface to system bus  
Interface to external devices



Fig. 4.

2. The I/O interface must able to perform device communication which involves commands, status information and data.
3. Data buffering is also an essential task of an I/O interface. Data transfer rates of peripheral devices are quite higher than that of processor and memory.
4. The data coming from memory or processor are sent to an I/O interface, buffered and then sent to the peripheral device at its data rate.
5. Data are buffered in I/O interface so as not to be up the memory in a slow transfer operation.
6. Thus the I/O interface must be able to operate at both, peripheral and memory speeds.
7. I/O interface is also responsible for error detection and for reporting errors to the processor.
8. As shown in the Fig. 4, I/O interface consist: of data register, status/control register, address decoder and external device interface logic.

9. The data register holds the data being transferred to or from the processor.
10. The status/control register contains information relevant to the operation of the I/O device. Both data and status/control registers are connected to the data bus.
11. Address lines drive the address decoder. The address decoder enables the device to recognize its address when address appears on the address lines.

12. The external device interface logic accepts inputs from address decoder, processor control lines and status signal from address device and generates control signals to control the direction of speed of data transfer between processor and I/O devices.

- ii. **Interrupts:** Refer Q. 5.4, Page 5-4B, Unit-5.  
**Handling interrupt:** Refer Q. 5.6, Page 5-6B, Unit-5.

@@@

Time : 3 Hours

Max. Marks : 100

Note: 1. Attempt all Sections. If require any missing data, then choose suitably.

#### SECTION-A

1. Attempt all questions in brief.

- a. Define the term computer architecture and computer organization.

**Ans.** Computer architecture: Computer architecture consists of rules and methods or procedures which describe the implementation functionality of the computer systems. Architecture is built as per the user's needs by taking care of the economic and financial constraints.

**Computer organization :** The computer organization is concerned with the structure and behaviour of digital computers. The main objective of this subject is to understand the overall basic computer hardware structure, including the peripheral devices.

- b. What is mean by bus arbitration ? List different types of bus arbitration.

**Ans** Refer Q. 1.6, Page 1-7C, Unit-1.

- c. Discuss biasing with reference to floating point representation.

**Ans** Refer Q. 1.34, Page 1-33C, Unit-1.

- d. What is restoring method in division algorithm ?

**Ans** A division algorithm provides a quotient and a remainder when we divide two numbers. Restoring term is due to fact that value of register A is restored after each iteration. Register Q contain quotient and register A contain remainder. Here, n-bit dividend is loaded in Q and divisor is loaded in M. Value of Register is initially kept 0 and this is the register whose value is restored during iteration due to which it is named restoring.

- i. Evaluate the arithmetic statement,  
 $X = A + B * [C * D + E * (F + G)]$   
 using a stack organized computer with zero address  
 operation instructions.



Fig. 1.

- e. Define micro operation and micro code.  
**Ans:** Refer Q. 2.29, Page 2-28C, Unit-2.

- f. Write short note on RISC.  
**Ans:** Refer Q. 2.7, Page 2-6C, Unit-2.

- g. Define hit ratio.

- Ans:** Refer Q. 3.24, Page 3-25C, Unit-3.

- h. What do you mean by page fault ?

**Ans:** A page fault is a type of exception raised by computer hardware when a running program accesses a memory page that is not currently mapped by the Memory Management Unit (MMU) into the virtual address space of a process.

- i. Explain the term cycle stealing.

**Ans:** Cycle stealing is a method of accessing computer memory or bus without interfering with the CPU. It is similar to direct memory access for allowing I/O controllers to read or write RAM without CPU intervention.

- j. What do you mean by vector interrupt ? Explain.

**Ans:** Refer Q. 4.7, Page 4-7C, Unit-4.

#### SECTION-B

(3 x 10 = 30)

2. Attempt any three of the following :  
 a. Draw a diagram of bus system using MUX which has four registers of size 4-bits each.



Fig. 2.

- i. Given expression:  
 $X = A + B * [C * D + E * (F + G)]$

Arithmetic statement with zero address :

|        |                                      |
|--------|--------------------------------------|
| PUSH F | TOS -> F                             |
| PUSH G | TOS -> G                             |
| ADD    | TOS -> (F + G)                       |
| PUSHE  | TOS -> E                             |
| MUL    | TOS -> E * (F + G)                   |
| PUSHC  | TOS -> C                             |
| PUSHD  | TOS -> D                             |
| MUL    | TOS -> C * D                         |
| ADD    | TOS -> C * D + E * (F + G)           |
| PUSH B | TOS -> B                             |
| MUL    | TOS -> B * [C * D + E * (F + G)]     |
| PUSHA  | TOS -> A                             |
| ADD    | TOS -> A + B * [C * D + E * (F + G)] |
| POP X  | M[X] <- TOS                          |

- b. Explain in detail the principle of carry look ahead adder.

**Ans**



Fig. 3.

1. Consider two 4-bit binary numbers  $A_3A_2A_1A_0$  and  $B_3B_2B_1B_0$  are to be added.

2. From here, we have

$$C_1 = C_0 (A_0 \oplus B_0) + A_0 \cdot B_0$$

$$C_2 = C_1 (A_1 \oplus B_1) + A_1 \cdot B_1$$

$$C_3 = C_2 (A_2 \oplus B_2) + A_2 \cdot B_2$$

$$C_4 = C_3 (A_3 \oplus B_3) + A_3 \cdot B_3$$

3. For simplicity, Let

$$G_i = A_i \cdot B_i \text{ where } G \text{ is called carry generator}$$

4. Then, re-writing the above equations, we have

$$C_1 = C_0 \cdot P_0 + G_0 \quad \dots(1)$$

$$C_2 = C_1 \cdot P_1 + G_1 \quad \dots(2)$$

$$C_3 = C_2 \cdot P_2 + G_2 \quad \dots(3)$$

$$C_4 = C_3 \cdot P_3 + G_3 \quad \dots(4)$$

5. Now, Clearly,  $C_1, C_2$  and  $C_3$  are intermediate carry bits.

6. So, let's remove  $C_1, C_2$  and  $C_3$  from RHS of every equation.

7. Substituting (1) in (2), we get  $C_2$  in terms of  $C_0$ .

8. Then, substituting (2) in (3), we get  $C_3$  in terms of  $C_0$  and so on.

- a. Finally, we have the following equations:

$$C_1 = C_0 \cdot P_0 + G_0$$

$$C_2 = C_0 \cdot P_0 \cdot P_1 + G_0 \cdot P_1 \cdot P_2 + G_1 \cdot P_2 \cdot G_2$$

$$C_3 = C_0 \cdot P_0 \cdot P_1 \cdot P_2 + G_0 \cdot P_1 \cdot P_2 \cdot P_3 + G_1 \cdot P_2 \cdot P_3 + G_2 \cdot P_3 \cdot G_3$$

- c. Draw the flowchart for instruction cycle with neat diagram.

**Ans** Refer Q. 2.9, Page 2-7C, Unit-2.

- d. Discuss 2D RAM and 2.5D RAM with suitable diagram.

**Ans** Refer Q. 3.4, Page 3-5C, Unit-3.

- e. Draw and explain the block diagram of typical DMA controller.

**Ans** Refer Q. 4.12, Page 4-11C, Unit-4.

## SECTION-C

3. Attempt any one part of the following:

- a. An instruction is stored at location 400 with its address field at location 401. The address field has the value 500. A processor register R1 contains with number 200. Evaluate the effective address if the addressing mode of the instruction is:

- i. Direct
- ii. Immediate
- iii. Relative

- iv. Register indirect

- v. Index with R1 as index register.

**Ans**

- i. Effective address = 400.

- ii. Effective address = 401.

- iii. Initial PC = 400. Step size is 2. So, next instruction will be at address 402.

- iv. Effective address = 402 + 500 = 902.

- v. Effective address would therefore be in R1 = 200.

- v. Effective address = Index register R1 + Address field value = 200 + 500 = 700.

- b. What do you mean by processor organization? Explain various types of processor organization.

**Ans** Refer Q. 1-14, Page 1-15C, Unit-1.

4. Attempt any one part of the following :
- Show the systematic multiplication process of  $(20) \times (-19)$  using Booth's algorithm.

**Ans.**

$$MD = 20 = 10100$$

$$AC = -19 = 10011$$

$$MD' + 1 = 01011 + 1 = 01100$$

| Operation    | AC      | MR    | $Q_{n+1}$ |
|--------------|---------|-------|-----------|
| AC + MD' + 1 | 00000   | 10011 | 0         |
| ASHR         | 01100   | 11001 | 1         |
| AC + MR      | 10011   | 11001 | 0         |
| ASHR         | 11001   | 11001 | 1         |
| ASHR         | 11100   | 11100 | 0         |
| AC + MD' + 1 | 01100   | 00111 | 1         |
| Product = AC |         | MR    |           |
|              | = 01100 |       |           |
|              |         | 00111 |           |

b.

- Explain IEEE standard for floating point representation. Represent the number  $(-1460.125)_{10}$  in single precision and double precision format.

**Ans.**

Floating point representation : Refer Q. 1.13, Page 1-14C.

Numerical : Refer Q. 1.42, Page 1-41C, Unit-1.

5. Attempt any one part of the following :

- What is a micro program sequencer? With block diagram, explain the working of micro program sequencer.

**Ans.** Refer Q. 2.26, Page 2-26C, Unit-2.

- Differentiate between hardwired and micro programmed control unit. Explain each component of hardwired control unit organization.

**Ans.** Refer Q. 2.24, Page 2-23C, Unit-2.

- Attempt any one part of the following :  $(10 \times 1 = 10)$
- Calculate the page fault for a given string with the help of LRU and FIFO page replacement algorithm. Size of frames = 4 and string 1 2 3 4 2 1 5 6 2 1 2 3 7 6 3 2 1 2 3 6.

Page reference: 1 2 3 4 2 1 5 6 2 1 2 3 7 6 3 2 1 2 3 6  
Size of frame = 4**Ans.** LRU replacement algorithm :

|      |      |      |      |     |     |      |      |     |     |      |      |     |     |      |     |     |      |     |     |      |     |
|------|------|------|------|-----|-----|------|------|-----|-----|------|------|-----|-----|------|-----|-----|------|-----|-----|------|-----|
| 1    | 2    | 3    | 4    | 2   | 1   | 5    | 6    | 2   | 1   | 2    | 3    | 4   | 5   | 6    | 2   | 1   | 2    | 3   | 4   | 5    | 6   |
| Miss | Miss | Miss | Miss | Hit | Hit | Miss | Miss | Hit | Hit | Miss | Miss | Hit | Hit | Miss | Hit | Hit | Miss | Hit | Hit | Miss | Hit |
| 1    | 2    | 3    | 7    | 7   | 7   | 3    | 3    | 7   | 7   | 1    | 1    | 1   | 1   | 1    | 1   | 1   | 1    | 1   | 1   | 1    | 1   |
| Miss | Miss | Miss | Miss | Hit | Hit | Miss | Miss | Hit | Hit | Miss | Miss | Hit | Hit | Miss | Hit | Hit | Miss | Hit | Hit | Miss | Hit |
| 1    | 2    | 3    | 2    | 2   | 2   | 6    | 6    | 6   | 6   | 6    | 6    | 6   | 6   | 6    | 6   | 6   | 6    | 6   | 6   | 6    | 6   |
| Miss | Miss | Miss | Miss | Hit | Hit | Miss | Miss | Hit | Hit | Miss | Miss | Hit | Hit | Miss | Hit | Hit | Miss | Hit | Hit | Miss | Hit |
| 1    | 2    | 3    | 1    | 1   | 1   | 1    | 1    | 1   | 1   | 1    | 1    | 1   | 1   | 1    | 1   | 1   | 1    | 1   | 1   | 1    | 1   |
| Miss | Miss | Miss | Miss | Hit | Hit | Miss | Miss | Hit | Hit | Miss | Miss | Hit | Hit | Miss | Hit | Hit | Miss | Hit | Hit | Miss | Hit |

Total page fault = 10

FIFO replacement algorithm :

|      |      |      |      |     |     |      |      |     |     |      |      |     |     |      |     |     |      |     |     |      |     |
|------|------|------|------|-----|-----|------|------|-----|-----|------|------|-----|-----|------|-----|-----|------|-----|-----|------|-----|
| 1    | 2    | 3    | 4    | 2   | 1   | 5    | 6    | 2   | 1   | 2    | 3    | 4   | 4   | 3    | 3   | 2   | 2    | 1   | 2   | 3    | 4   |
| Miss | Miss | Miss | Miss | Hit | Hit | Miss | Miss | Hit | Hit | Miss | Miss | Hit | Hit | Miss | Hit | Hit | Miss | Hit | Hit | Miss | Hit |
| 1    | 2    | 3    | 7    | 6   | 6   | 6    | 6    | 6   | 6   | 6    | 6    | 6   | 6   | 6    | 6   | 6   | 6    | 6   | 6   | 6    | 6   |
| Miss | Miss | Miss | Miss | Hit | Hit | Miss | Miss | Hit | Hit | Miss | Miss | Hit | Hit | Miss | Hit | Hit | Miss | Hit | Hit | Miss | Hit |
| 1    | 2    | 3    | 1    | 1   | 1   | 1    | 1    | 1   | 1   | 1    | 1    | 1   | 1   | 1    | 1   | 1   | 1    | 1   | 1   | 1    | 1   |
| Miss | Miss | Miss | Miss | Hit | Hit | Miss | Miss | Hit | Hit | Miss | Miss | Hit | Hit | Miss | Hit | Hit | Miss | Hit | Hit | Miss | Hit |

Total page fault = 14

- A computer uses RAM chips of  $1024 \times 1$  capacity:
- How many chips are needed and how should their address lines be connected to provide a memory capacity of  $1024 \times 8$ ?

- ii. How many chips are needed to provide a memory capacity of 16 KB?  
**Ans:** Refer Q. 3.7, Page 3-10C, Unit-3
7. Attempt any one part of the following :  
 a. What do you mean by asynchronous data transfer? Explain (10 x 1 = 10)  
**Ans:** Refer Q. 4.21, Page 4-19C, Unit-4.
- b. Discuss the different modes of data transfer.  
**Ans:** Refer Q. 4.17, Page 4-16C, Unit-4.

©©©

### SECTION-A

**Note:** 1. Attempt all Sections. If require any missing data, then choose suitably.

Time: 3 Hours

Max. Marks: 100

1. Attempt all questions in brief. (2 x 10 = 20)  
 a. List and briefly define the main structural components of a computer.  
**Ans:** Refer Q. 1.1, Page 1-2B, Unit-1.

- b. Differentiate between horizontal and vertical microprogramming.  
**Ans:** Refer Q. 3.17, Page SQ-8B, Unit-3, Two Marks Questions.
- c. Represent the following conditional control statements by two register transfer statements with control functions.  
 If (P = 1) then (R1  $\leftarrow$  R2) else if (Q = 1) then (R1  $\leftarrow$  R3)

**Ans:** P: R1  $\leftarrow$  R2  
 PQ: R1  $\leftarrow$  R3

- d. Design a 4-bit combinational incremental circuit using four full adder circuits.

**Ans:**



Fig. 1.

- e. Differentiate between Daisy chaining and centralized parallel arbitration.

**Ans:**

| S.No. | Daisy chaining                                                                                                 | Centralized arbitration                                                                                                                                               |
|-------|----------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1.    | It is a simple and cheaper method where all the bus masters use the same line for making bus requests.         | In the centralized arbitration scheme, the devices independently request the bus by using multiple request lines.                                                     |
| 2.    | The daisy chain arbitration which chains through each device from the highest priority to the lowest priority. | A centralized arbiter chooses from among the devices requesting bus access and notifies the selected device that it is now the bus master via one of the grant lines. |

**f.** What is the transfer rate of an eight-track magnetic tape whose speed is 120 inches per second and whose density is 1600 bits per inch?

**Ans:** The tape moves at a speed  $s = 120$  inches/second  
Density of tape = 1600 bits per inch.  
Total number of tracks = 8.

Data transfer rate per each track = Tape speed  $\times$  Density of tape.  
 $= 120 * 1600 = 192000$  bits / second.

Hence Data transfer speed per track = 24000 Bytes / second.

$$\begin{aligned} \text{Data transfer speed for 8 tracks} &= 24000 * 8 \text{ bytes / second.} \\ &= 192000 \text{ bytes / second.} \\ (\because 1000 &= 1 \text{ Kilo for speed calculation}) \end{aligned}$$

**g.** Register A holds the binary values 10011101. What is the register value after arithmetic shift right? Starting from the initial number 10011101, determine the register value after arithmetic shift left, and state whether there is an overflow.

**Ans:**

R = 10011101

Arithmetic shift right : 11001100  
Arithmetic shift left : 00111010 overflow because a negative number changed to positive.

**h.** What is an Associative memory ? What are its advantages and disadvantages ?

**Ans:** Associative memory : Refer Q 4.24, Page 4-24B, Unit-4.

- Advantages :**
  1. This is suitable for parallel searches.
  2. It is also used where search time needs to be short.
  3. It is very high speed searching application.

**Disadvantages :**

1. Associative memory is more expensive than a random access memory.
2. Each cell must have an extra storage capability as well as logic circuits for matching its contents with an external argument.
3. Usually associative memories are used in applications where the search time is very critical and must be very short.

**i.** Differentiate between static RAM and Dynamic RAM.

**Ans:** Refer Q. 4.2, Page SQ-10B, Unit-4, Two Marks Questions.

**j.** What are the different types of instruction formats ?

**Ans:** Refer Q. 3.2, Page 3-3B, Unit-3.

## SECTION - B

- a.** Attempt any three of the following :
1. A digital computer has a common bus system for 8 registers of 16 bit each. The bus is constructed using multiplexers.
  2. How many select input are there in each multiplexer ?
  3. What is the size of multiplexers needed ?

**b.** How many multiplexers are there in the bus ?

**Ans:** Number of registers =  $2^n$ , where  $n$  = number of selection input lines

- Number of selection inputs in each multiplexer = 3  
Therefore,  $n = 3$
- Number of registers =  $2^3$  = 8

Size of multiplexers = Number of registers  $\times$  1

Here, Number of registers = 8

Therefore, Size of multiplexers =  $8 \times 1$

Number of multiplexers = Number of bits in each register

Here, Number of bits in each register = 16

Therefore, Number of multiplexers in the bus = 16

- c.** Explain destination-initiated transfer using handshaking method.

**Ans:** In the destination-initiated the handshaking process, the process of establishing the connection is initiated by the destination.

1. In this process, the receiver needs to receive the data from the sender; hence the handshaking process is initiated by the receiver.
2. So, in this process, the receiver has to first send the request signal to the source channel.
3. After that, the source sends the 'DATA VALID' signal before sending the data and the receiver then again sends a signal 'DATA ACCEPTED' after the data is received by it.

5. When destination initiates the process of data transfer:

a. REQUEST FOR DATA : If ON requests for putting data on the data bus.

b. DATA VALID : If ON tells data is valid on the data bus otherwise invalid data



Now there is surely that source has put the data on the data bus through data valid signal.

Signals can be seen as :



- c. Explain 2-bit by 2-bit Array multiplier. Draw the flowchart for divide operation of two numbers in signed magnitude form.

Ans:

- An array multiplier is a digital combinational circuit used for multiplying two binary numbers by employing an array of full adders and half adders.
- This array is used for simultaneous addition of the various product terms involved.
- To form the various product terms, an array of AND gates is used before the Adder array.
- Checking the bits of the multiplier one at a time and forming partial products is a sequential operation that requires a sequence of add and shift micro-operations.
- For implementation of array multiplier with a combinational circuit, consider the multiplication of two 2-bit numbers as shown in figure.



- d. A digital computer has a memory unit of  $64K \times 16$  with a block size of four words.

- How many bits are there in the tag, index, block, and word fields of the address format?
- How many bits are there in each word of cache, and how they are divided into functions? Include a valid bit.

**Ans.** I. Main memory has  $64K = 64 \times 1024 = 2^6 \times 2^{10} = 2^{16}$  words

Cache memory has  $1K = 1024 = 2^10$  words

In this case to address main memory we need 16 bits ( $2^{16}$ ) and to address cache memory we need 10 bits ( $2^{10}$ ).

So Index is 10 bits wide and Tag is 6 bits wide ( $16 - 10 = 6$ ).

In this case the block is 4 words long for what we need 2 bits ( $2^2$ ) and that leaves 8 bits ( $10 - 2 = 8$ ) for addressing blocks.

Tag = 6 bits

Index = 10 bits

Block = 8 bits

Word = 2 bits

II. Valid bit = 1 bit

Tag = 6 bits

Data = 16 bits

Total bits =  $1 + 6 + 16 = 23$  bits

- III. If cache has 1K words and block size is 4 words then number of blocks is  $1K / 4 = 1024 / 4 = 256$  blocks.

- e. Explain with neat diagram, the address selection for control memory.

- Ans.** I. The control memory required the capabilities of address sequencing, which is described as follows :

- On the basis of the status bit conditions, the address sequencing selects the conditional branch or unconditional branch.
- Addressing sequence is able to increment the CAR (Control Address Register).

- It provides the facility for subroutine calls and returns.
- A mappings process is provided by the addressing sequence from the instructions bits to a control memory address.

- In the above diagram, we can see a block diagram of a control memory and associative hardware, which is required for selecting the address of next micro-instruction.
- The micro-instruction is used to contain a set of bits in the control memory. With the help of some bits, we are able to start the micro-operations in a computer register.
- The remaining bits of micro-instruction are used to specify the method by which we are able to obtain the next address.



Fig. 3.

- In this diagram, we can also see that the control address with the help of incrementer are able to recover their address with the help of four different directions.
- The CAR is incremented with the help of incrementer and then chooses the next instruction.
- The branching address will be determined in the multiple fields of microinstruction so that they can provide results in branching.
- If there are status bits of micro-instruction and we want to apply conditions on them, in this case, we can use conditional branching.
- An external address can be shared with the help of a mapping logic circuit. The return address will be saved by a special register.
- This saved address will be helpful when the micro-program requires returning from the subroutine. At that time, it requires the value from the unique register.

## SECTION - C

1. Attempt any one part of the following : (10  $\times$  1 = 10)

- A binary floating-point number has seven bits for a biased exponent. The constant used for the bias is 64.
- List the biased representation of all exponents from -64 to +63.
- Show that after addition of two biased exponents, it is necessary to subtract 64 in order to have a biased exponent's sum.

- III. Show that after subtraction of two biased exponents, it is necessary to add 64 in order to have a biased exponent's difference.

Ans.

- a.  $e = \text{exponent } e + 64 = \text{biased exponent}$

| <b>e</b> | <b>e + 64</b> | <b>Biased exponent</b> |
|----------|---------------|------------------------|
| -64      | -64 + 64 = 0  | 0 000 000              |
| -63      | -63 + 64 = 1  | 0 000 001              |
| -62      | -62 + 64 = 2  | 0 000 010              |
| -1       | -1 + 64 = 63  | 0 111 111              |
| 0        | 9 + 64 = 64   | 1 000 000              |
| +1       | 1 + 64 = 65   | 1 000 001              |
| +62      | 62 + 64 = 126 | 1 111 110              |
| +63      | 63 + 64 = 127 | 1 111 111              |

- b. The biased exponent follows the same algorithm as a magnitude comparator.  
 c.  $(e_1 + 64) + (e_2 + 64) = (e_1 + e_2 + 64) + 64$   
 subtract 64 to obtain biased exponent sum  
 d.  $(e_1 + 64) - (e_2 + 64) = e_1 + e_2$   
 add 64 to obtain biased exponent difference

- b. Show the multiplication process using Booth algorithm, when the following binary numbers,  $(+13) \times (-15)$  are multiplied.

Ans.

13 = 01101

Multiplicand ( $M$ ) = 01101, Multiplier = 10001

| <b>A</b> | <b><math>Q_n</math></b> | <b><math>Q_{n+1}</math></b> | <b>Operations</b>    | <b>SC</b> |
|----------|-------------------------|-----------------------------|----------------------|-----------|
| 00000    | 10001                   | 0                           |                      | 101(5)    |
| 10011    | 10001                   | 0                           | $A \leftarrow A - M$ | 100(4)    |
| 11001    | 11000                   | 1                           | Shift                |           |
| 00110    | 11000                   | 1                           | $A \leftarrow A + M$ | 011(3)    |
| 00011    | 01100                   | 0                           | Shift                | 010(2)    |
| 00001    | 10110                   | 0                           | Shift                | 001(1)    |
| 00000    | 11011                   | 0                           | Shift                |           |
| 10011    | 11011                   | 0                           | $A \leftarrow A + M$ | 000(0)    |
| 11001    | 11101                   | 1                           |                      |           |

Result = 11001 11101 = 195 (2's complement of + 195)

- Computer Organization & Architecture
- Attempt any one part of the following : (10 x 1 = 10)
4. Draw a diagram of a Bus system in which it uses 3 state buffers and a decoder instead of the multiplexers.



Fig. 4.

- b. Explain in detail multiple bus organization with the help of a diagram.

- b. Explain in detail multiple bus organization with the help of a diagram.

#### Multiple-Bus Organization :

1. In multiple bus organizations, two buses are used for separate communication paths.

2. In multiple bus organizations, both data and instruction transfer occur in different buses.

3. Multiple bus organization has more number of associated registers.

4. Two operands can be read from the bus using multiple bus organizations.

5. This system has faster execution as many devices work together to ensure better performance.

6. Multiple bus organization has a multi-core processor for transferring more data and information and minimizing the wait time.

- Diagram :

1. Fig. 5 shows a three bus structure used to connect the register and the ALU of the processor.

- Attempt any one part of the following :
- What is the logical address space in a computer system consists of?
  - The logical segments. Each segment can have up to 32 pages of 4K words each. Physical memory consists of 4K blocks of 4K words each. Formulate the logical and physical address formats.
  - Physical memory has address space of 4 K blocks  $\times$  4 K words  $= 4 \times 2^{10} \times 4 \times 2^{10} = 2^{24} = 24$  bits
  - Address format for logical address :
    - Segment addressing = 5 bits
    - Page addressing = 12 bits
    - Word addressing format for physical address :
      - Addressing = 12 bit
      - Block addressing = 12 bit
      - Word addressing = 7 bits

$$\text{Logical address space} = 32 \text{ pages} \times 32 \times 4 \times 2^{10} = 2^7 \times 2^5 \times 2^2 \times 2^{10} = 2^{24} = 24 \text{ bit}$$

*Note : 128  $\times$  32  $\times$  4  $\times$  2<sup>10</sup> = 2<sup>7</sup>  $\times$  2<sup>5</sup>  $\times$  2<sup>2</sup>  $\times$  2<sup>10</sup> = 2<sup>24</sup> = 24 bit*

$$\text{Physical memory has address space of } 4 \text{ K blocks } \times 4 \text{ K words} \\ = 4 \times 2^{10} \times 4 \times 2^{10} = 2^{24} = 24 \text{ bits}$$



Fig. 5. Three bus organization of the datapath.

- All general purpose registers are combined into a single block called the register file.
- It consists of three ports. There are two outputs, allowing the contents of two different registers to be accessed simultaneously and have their contents placed on bus A and B. The third port allows the data on bus C to be loaded into a third register during the same clock cycle.
- Bus A and B are used to transfer the source operands to the A and B inputs of the ALU, where an arithmetic or logic operation may be performed.
- The result is transferred to the destination over bus C.
- Incrementer unit, which is used to increment the PC by 4.



Fig. 6.

1. CPU will generate logical address for example : 346  
 2. MMU will generate a relocation register (base register) for example : 14000  
 3. In memory, the physical address is located example : (346+14000 = 14346)  
 4. The value in the relocation register is added to every address generated by a user process at the time the address is sent to memory.  
 5. The user program never sees the real physical address.  
 6. The program can create a pointer to location 346, store it in memory, manipulate it, and compare it with other addresses-all like the number 346.  
 7. The user program generates only logical addresses. However, these logical addresses must be mapped to physical addresses before they are used.
- Different methods of writing into cache :** Refer Q. 4.19, Page 4-20B, Unit-4.
6. Attempt any one part of the following : (10 x 1 = 10)
- a. Explain how the computer buses can be used to communicate with memory and I/O. Also draw the block diagram for CPU-IOP communication.
- Ans.** There are three ways that computer buses can be used to communicate with memory and I/O:
1. Use two separate buses, one for memory and the other for I/O:
    - In this case, the computer has separate sets of data, address, and control buses, one for accessing memory and the other for I/O.
    - This procedure is used in computers that provide a separate I/O processor (IOP), also called I/O channel in addition to the CPU.
    - The memory communicates with both the CPU and the IOP through a memory bus.
    - The objective of the IOP is to provide a separate path for the transfer of information between external I/O devices and internal memory.
  2. Use one common bus for both memory and I/O but have separate control lines for each :
    - In this case, computers use one common bus to transfer information between memory or I/O and the CPU. The distinction between a memory transfer and I/O transfer is made through separate read and write lines.
    - The CPU specifies whether the address on the address lines is for a memory word or for an interface register by enabling one of two possible read or write lines. I/O-read and I/O-write control lines are enabled during an I/O transfer.



Fig. 7.

- b. What are the different methods of asynchronous data transfer? Explain in detail.
- Ques. Different methods of asynchronous data transfer :**
1. Strobe control method :
    - The strobe control method of asynchronous data transfer employs a single control line to time each transfer.
    - This control line is also known as a strobe, and it may be achieved either by source or destination, depending on which initiate the transfer.
  2. Source initiated Strobe : When source initiates the process of data transfer. Strobe is just a signal.



Fig. 8.

- First, source puts data on the data bus and ON the strobe signal.
- Destination on seeing the ON signal of strobe, read data from the data bus.
- After reading data from the data bus by destination, strobe gets OFF.

**Signals can be seen as :** Fig. 9 shows that first data is put on the data bus and then strobe signal gets active.



Fig. 9.

- Destination initiated signal : When destination initiates the process of data transfer.



Fig. 10.

- First, the destination ON the strobe signal to ensure the source to put the fresh data on the data bus.
- Source on seeing the ON signal puts fresh data on the data bus.
- Destination reads the data from the data bus and strobe gets OFF signal.

**Signals can be seen as :** Fig. 11 shows that first strobe signal gets active then data is put on the data bus.



Fig. 11.

- Handshaking method :**

- The handshaking method introduces a second control signal line that replays the unit that initiates the transfer.



Fig. 12.

- Source places data on the data bus and enable Data valid signal.
- Destination accepts data from the data bus and enable Data accepted signal.
- After this, disable Data valid signal means data on data bus is invalid now.
- Disable Data accepted signal and the process ends.

**Signals can be seen as :** It shows that first data is put on the data bus then data valid signal gets active and then data accepted signal gets active. After accepting the data, first data valid signal gets off then data accepted signal gets off.



Fig. 13.

- Destination initiated handshaking :** Refer Q. 2(b), Page SP-3C, Solved Paper 2021-22.

- Attempt any one part of the following : (10 x 1 = 10)

- Write a program to evaluate arithmetic expression using stack organized computer with 0-address instructions.



- g.** List the difference between static RAM and dynamic RAM.  
**Ans:** Refer Q. 4.2, Page SQ-10B, Unit-4, Two Marks Questions.

**h.** Define virtual memory.

**Ans:** Refer Q. 4.23, Page 4-23B, Unit-4.

- i.** List down the functions performed by an Input/Output unit.

- Ans:** Functions performed by input/output unit :
- Error detection
  - Processor communication
  - Data buffering
  - Device communication
  - Control and timing

- j.** Why does the DMA get priority over CPU when both request memory transfer ?

**Ans:** The DMA gets priority over the CPU when both request memory transfer because DMA is a dedicated controller that can independently access memory without CPU intervention. This priority ensures that CPU resources remain available for critical tasks while data transfers occur seamlessly in the background.

### Section-B

- 2.** Attempt any three of the following :

- a.** Explain functional units of computer system in detail.

**Ans:** Refer Q. 1.2, Page 1-3B, Unit-1.

- b.** Explain IEEE-754 standard for floating point representation Express  $(314.175)_{10}$  in all the IEEE-754 models.

**Ans:** IEEE-754 standard for floating point representation :

Refer Q. 2.22, Page 2-21B, Unit-2.

Numerical:  $(314.175)_{10}$

Step 1: Convert the decimal number in binary format

For integer,

$$\begin{array}{r} 2 \quad | \quad 314 \quad 0 \\ 2 \quad | \quad 157 \quad 1 \\ 2 \quad | \quad 78 \quad 0 \\ 2 \quad | \quad 39 \quad 1 \\ 2 \quad | \quad 19 \quad 1 \\ 2 \quad | \quad 9 \quad 1 \\ 2 \quad | \quad 4 \quad 0 \\ 2 \quad | \quad 2 \quad 0 \\ 1 \end{array}$$

$$(314)_{10} = (100111010)_2$$

$$\text{Number of lines} = \frac{\text{Cache size}}{\text{Block size}} = \frac{2^{13}}{2^5} = 2^8 = 8$$

For fraction,

$$0.175 \times 2 = 0.350 \Rightarrow 0$$

$$0.350 \times 2 = 0.700 \Rightarrow 0$$

$$0.700 \times 2 = 1.400 \Rightarrow 1$$

$$0.400 \times 2 = 0.800 \Rightarrow 0$$

$$0.800 \times 2 = 1.600 \Rightarrow 1$$

$$0.600 \times 2 = 1.200 \Rightarrow 1$$

$$0.200 \times 2 = 0.400 \Rightarrow 0$$

$$(0.175)_{10} = (0.0010110)_2$$

$$(314.175)_{10} = (100111010.0010110)_2$$

**Step 2 :** Normalize the number

$$100111010.0010.110 = 1.001110100010110 \times 2^3$$

**Step 3 :** Representing the floating point in single precision :

For a given member

$$S = 0$$

$$E = 8$$

$M = 001110100010110$   
 Bias of single precision format is = 127

$$E = 127 + E = 127 + 8 = (135)_{10} = (10000111)^2$$

Number in single precision format  
 ↗1 bit ↗8 bits ↗ 23 bits ↗  
 S E E M

|   |          |                       |  |
|---|----------|-----------------------|--|
| 0 | 10000111 | 001110100010110.....0 |  |
|---|----------|-----------------------|--|

- c.** Explain the concept of pipelining and also explain types of pipelining.  
**Ans:** Pipelining : Refer Q. 3-19, Page 3-18B, Unit-3.  
 Types of pipelining : Refer Q. 3-20, Page 3-20B, Unit-3.

- d.** Consider a cache consisting of 256 blocks of 16 words each for a total of 4096 words and assume that the main memory is addressable by a 16 bits address and it consists of 4 K blocks. How many bits are there in each of TAG, SET, WORD field for 2-way set associative technique ?

**Ans:** Block size = 16 words =  $32B = 2^5B$   
 Cache size = 256 blocks = 4096 words =  $2^{12} \times 2^5B = 2^{17}B$   
 Main memory size (MS) = 4K blocks =  $2^{12} \times 2^5B = 2^{17}B$

$$\text{Number of lines} = \frac{\text{Cache size}}{\text{Block size}} = \frac{2^{13}}{2^5} = 2^8 = 8$$

$$\text{Sets} = \frac{\text{Lines}}{\text{Set size}} = \frac{8}{2} = 4 = 2^2$$

Number of bit for WORD = 5 bits  
Number of bit for TAG =  $17 - (2 + 5) = 10$  bits

e. Define interrupt. Also discuss different types of interrupt.

**Ans:** Interrupt : Refer Q. 5.4, Page 5-4B, Unit-5.  
Types of interrupt : Refer Q. 5.7, Page 5-7B, Unit-5.

### Section-C

3. Attempt any one part of the following :

(10 x 1 = 10)

a. Explain about stack organization used in processors. What do you understand by register stack ?

**Ans:** Stack organization : Register stack is specialized type of memory storage arrangement used within the CPU for efficient handling of data and control during program execution. A register stack operates like a stack data structure where data is pushed onto and popped off of the stack in a Last-in-First Out (LIFO).

b. What is an effective address ? How it is calculated in different types of addressing modes ? Explain.

**Ans:** Effective address : An effective address is the location of an operand which is stored in memory.

Table 1 : Computation of effective address for various addressing modes

| Address mode     | Effective address | Comments                                           |
|------------------|-------------------|----------------------------------------------------|
| Direct           | AD 16             | 16-bit address part of instruction                 |
| Relative         | PC + AD8          | Contents of PC plus signed AD8                     |
| Indexed          | XR + AD16         | Contents of XR plus AD16                           |
| Base register    | XR + AD8          | Contents of XR plus AD8                            |
| Indirect         | M[AD16]           | Address stored in location given by AD16           |
| Indexed-indirect | M[XR + AD 8]      | Address stored in location (XR + AD8)              |
| Indirect-indexed | M[AD 8] + XR      | Address stored in location AD8 plus contents of XR |

True binary equivalent of  $+16 = 10000$   
1's Complement of  $+16 = 01111$

$$2's \text{ Complement of } +16 = \frac{+1}{10000 \text{ (-16)}} \\ \text{Multiplicand (M) = 10001}$$

$A = 00000$

$Q_n = 10000$

$Q_{n+1} = 0$

Operation

SC

$00000$

$01000$

$0$

Shift

110

$00000$

$00100$

$0$

Shift

101

$00000$

$00010$

$0$

Shift

100

$00000$

$00001$

$0$

Shift

011

$01111$

$00001$

$0$

$A \leftarrow A - M$

001

Result    00111    10000    = (+240)

5. Attempt any one part of the following :

(10 x 1 = 10)

a. Write a program to evaluate the arithmetic statement.  
 $P = ((X - Y + Z) * (A \wedge B)) / (C \wedge D \wedge E)$

By using (i) Two address instructions (ii) One address instructions (iii) Zero address instructions.

**Ans:**  $P = ((X - Y + Z) * (A \wedge B)) / (C \wedge D \wedge E)$

i. Two address instructions :

4. Attempt any one part of the following :

(10 x 1 = 10)

|     |       |                           |
|-----|-------|---------------------------|
| MOV | R1, A | R1 $\leftarrow$ M[A]      |
| EXP | R1, B | R1 $\leftarrow$ M[B]      |
| ADD | R2, X | R2 $\leftarrow$ M[X]      |
| SUB | R2, Z | R2 $\leftarrow$ R2 + M[Z] |
|     | R2, Y | R2 $\leftarrow$ R2 - M[Y] |

|     |        |                                  |
|-----|--------|----------------------------------|
| MUL | R2, R1 | R2 $\leftarrow$ R2 * R1          |
| MOV | R3, C  | R3 $\leftarrow$ M[Cl]            |
| EXP | R3, D  | R3 $\leftarrow$ R3 $\wedge$ M[D] |
| MUL | R3, E  | R3 $\leftarrow$ R3 * M[E]        |
| DIV | R2, R3 | R2 $\leftarrow$ R2/R3            |
| MOV | P, R2  | M[P] $\leftarrow$ R2             |

**ii. One address instructions :**

|       |      |                                  |
|-------|------|----------------------------------|
| LOAD  | A    | AC $\leftarrow$ M[A]             |
| EXP   | B    | AC $\leftarrow$ AC $\wedge$ M[B] |
| STORE | R    | M[R] $\leftarrow$ AC             |
| LOAD  | X    | AA $\leftarrow$ X                |
| ADD   | Z    | AC $\leftarrow$ AC + M[Z]        |
| SUB   | Y    | AC $\leftarrow$ AC - M[Y]        |
| MUL   | MRI  | AC $\leftarrow$ AC * M[R]        |
| STORE | S    | M[S] $\leftarrow$ AC             |
| LOAD  | C    | AC $\leftarrow$ M[C]             |
| EXP   | D    | AC $\leftarrow$ AC $\wedge$ M[D] |
| MUL   | E    | AC $\leftarrow$ AC * M[E]        |
| DIV   | M[S] | AC $\leftarrow$ AC / M[S]        |
| STORE | P    | M[P] $\leftarrow$ AC             |

**iii. Zero address instructions :**

|      |   |                                                                      |
|------|---|----------------------------------------------------------------------|
| PUSH | A | TOS $\leftarrow$ A                                                   |
| PUSH | B | TOS $\leftarrow$ B                                                   |
| PUSH | C | TOS $\leftarrow$ A $\wedge$ B                                        |
| PUSH | X | TOS $\leftarrow$ X                                                   |
| PUSH | Z | TOS $\leftarrow$ Z                                                   |
| ADD  |   | TOS $\leftarrow$ X + Z                                               |
| PUSH | Y | TOS $\leftarrow$ Y                                                   |
| SUB  |   | TOS $\leftarrow$ (X + Z - Y)                                         |
| MUL  |   | TOS $\leftarrow$ (X + Z - Y) * (A $\wedge$ B)                        |
| PUSH | C | TOS $\leftarrow$ C                                                   |
| PUSH | D | TOS $\leftarrow$ D                                                   |
| EXP  |   | TOS $\leftarrow$ C $\wedge$ D                                        |
| PUSH | E | TOS $\leftarrow$ E                                                   |
| MUL  |   | TOS $\leftarrow$ (C $\wedge$ D * E)                                  |
| DIV  |   | TOS $\leftarrow$ ((X + Z - Y) * (A $\wedge$ B)) / (C $\wedge$ D * E) |
| POP  | P | M[P] $\leftarrow$ TOS                                                |

b. What are the differences between hardwired and micro-programmed control unit ?

**Ans.** Refer Q. 3-25, Page 3-25B, Unit-3.

6. Attempt any one part of the following : (10  $\times$  1 = 10)

a. Discuss the Memory Hierarchy in computer system with regard to Speed, Size and Cost.

**Ans.** Memory hierarchy : Refer Q. 4.1, Page 4-2B, Unit-4.

| Memory levels in terms of size, access time, speed and cost: |                  |                  |                  |                   |
|--------------------------------------------------------------|------------------|------------------|------------------|-------------------|
| Level                                                        | Register         | Cache            | Primary memory   | Secondary memory  |
| Speed                                                        | 4k to 32k MB/sec | 800 to 5k MB/sec | 400 to 2k MB/sec | 4 to 32 MB/sec    |
| Size                                                         | Less than 1KB    | Less than 4MB    | Less than 2 GB   | Greater than 2 GB |
| Access time                                                  | 2 to 5 nsec      | 3 to 10 nsec     | 80 to 400 nsec   | 5 ms              |
| Cost                                                         | Expensive        | Very high        | Low              | Very low          |

b. Write a short note on magnetic disk, magnetic tape and optical disk.

**Ans.** Refer Q. 4.21, Page 4-22B, Unit-4

c. Attempt any one part of the following:

a. With a neat schematic diagram, explain about DMA controller and its mode of data transfer.

**Ans.** DMA controller : Refer Q. 5.12, Page 5-11B, Unit-5. Modes of DMA data transfer : There are three different modes of DMA data transfer which are as follows :

1. **Burst mode :**

a. In burst mode, a whole block of data is shared in one contiguous sequence. Since the DMA controller is allowed access to the system buses by the CPU, it sends all bytes of data in the data block earlier yield control of the system buses back to the CPU.

b. This mode is beneficial for loading programs or data records into memory, but it does provide the CPU inactive for associatively long periods.

2. **Cycle stealing mode :**

a. In cycle stealing mode, the DMA controller gets access to the system buses as in burst mode, using the BR and BG signals. It can share one byte of information and then deasserts BR,

b. returning control of the system buses to the CPU.

c. It already issues requests via BR, sharing one byte of information per request, just before it has shared its whole block of data.

3. **Transparent mode :**

a. Transparent mode needed the most time to share a block of data, yet it is also important in terms of whole system performance.