

**UNIT-1**  
① Explain about basic functional blocks of Computer.

A.1) Functional Block of Computer:

- A computer organization describes the functions and design of the various units of digital system.
- A general-purpose computer system is the best-known example of a digital system. Other examples include telephone switching exchanges, digital voltmeters, digital counters, electronic calculators and digital displays.
- Computer architecture deals with the specification of instruction set and the hardware units that implement the instructions.
- Computer hardware consists of electronic circuits, displays, magnetic and optic storage media and also communication facilities.
- Functions units are a part of CPU that performs the operations and calculations called computer program.
- Functional units of a computer system are parts of CPU that perform the operations & calculation.



Input Unit

- Inputs units are used by the computer to read the data. The most commonly used input devices are keyboards, mouse, joysticks, track balls, microphones etc.
- However, the most well-known input device is a keyboard. Whenever a key is pressed, the corresponding letter or digit is automatically translated into its corresponding binary code & transmitted over a cable to either the memory or processor.

Central processing Unit:

- CPU commonly known as CPU can be referred as an electronic circuitry within a computer that carries out the instructions given by a computer program by performing the basic arithmetic, logical, control & input/output operations specified by instructions.

Memory Unit

- The memory unit can be referred to as the storage area in which programs are kept which are running, & that contain data needed by running programs.
- The memory unit can be categorized in two ways namely, primary memory and secondary memory.
- It enables a process to access running execution applications and services that are temporarily stored in specific memory location.

Arithmetic & logical Unit

- Most of all the arithmetic & logical operations of a computer are executed in ALU of the processor.

It performs arithmetic operations like add, sub, mul, div and also logical operations like AND, OR, NOT operations.

### Control Unit

The control unit is a component of a computer's central processing unit that coordinates the operations of processor. It tells the computer's memory logic unit & inputs & output devices how to respond program's instruction.

The control unit is known as the nerve center of computer system.  
Example of Addition of two operand by instruction given as Add LocA, R0.

### Output Unit

The primary function of output unit is to send the processed results to the user. Output device displays information in a way that we can understand.  
The most common example of an output device is a monitor.

## ② Explain About Instruction Set Architecture (ISA)?

A) The ISA is part of processor that is visible to programmer or compiler writer. The ISA serves as boundary between software & hardware. We will briefly describe the instruction sets found in many of microprocessor used today. The ISA of processor can be described using 5 categories:

### Operands Storage in CPU:

Where are the operands kept other than in memory?

Number of explicit named operands

How many operands are named in a typical instruction.

Operand location:

Can any few instruction operand be located in memory? Or must all operand be kept internally in CPU?

Operations

What operations are provided in ISA.

Type & Size of Operands

What is the type & size of each operand & how is it specified?

The most common 3 types of ISAs are:

① The Stack - The operand are implicitly on top of stack.

② Accumulator - One operand is implicitly the accumulator.

③ General Purpose Register (GPR) - All operands are explicitly mentioned, they are either registers or memory location.

Let's look at the assembly code of  $C = A + B;$

In all 3 architectures:

| Stack  | Accumulator | GPR        |
|--------|-------------|------------|
| PW A   | LOAD A      | Load R1,A  |
| PUSH B | ADD B       | ADD R1,B   |
| POP C  | STORE C     | STORE R1,C |
|        | -           | -          |

Note all processor can be neatly tagged into one of above categories. The i8086 has many instructions that use implicit operands although it has a general register set.

The i8051 is another example, it has 4 banks of GPRs but most instructions must have the A register as one of its operands.

### Stack

**Advantages:** Simple model of expression evaluation. Short instructions.

**Disadvantages:** A stack can't be randomly accessed this makes it hard to generate efficient code. The stack itself is accessed every operation and becomes a bottleneck.

### Accumulator

**Advantages:** Short instructions.

**Disadvantages:** The accumulator is only temporary storage so memory traffic is highest for this approach.

### GPR

**Advantages:** Makes code generation easy. Data can be stored for long periods in registers.

**Disadvantages:** All operands must be named leading to longer instructions.

### ③ Outline the instruction execution cycle and explain it.

A) A program residing in the memory unit of a computer consists of a sequence of instructions. These instructions are executed by processor by going through a cycle for each instruction.

① Fetch instruction from memory

② Decode the instruction

③ Read the effective address from memory.

④ Execute the instruction.

### Instruction cycle

An instruction cycle, also known as fetch-decode-execute cycle is basic operational process of computer. This process is repeated continuously by CPU from boot up to shut down of computer.

#### ① Fetch the instruction

The instruction is fetched from memory address that is stored in PC (Program Counter) & stored in instruction register IR. At the end of fetch operation, PC is incremented by 1 and it then points to next instruction to be executed.

#### ② Decode the instruction

The instruction in the IR is executed by the decoder.

#### ③ Read the Effective Address

If instruction has an indirect address, the effective address is read from the memory. Otherwise operands are directly read in case of immediate operand instruction.

#### ④ Execute the instruction:

The control unit passes the information in form of control signals to functional unit of CPU. The result generated is stored in main memory or sent to output device.



③ Classify the types of addressing modes in detail.

#### A.) Addressing Modes:

- The addressing mode specifies a rule of interpreting (or) modifying the address field of instruction before the operand is actually executed

- Addressing modes for 8086 instructions are divided into 2 categories

  - Addressing modes for data

  - Addressing modes for branch



#### ① Implied Addressing Mode:

In implied addressing the operand is specified in instruction itself. In this mode the data is 8 bits or 16 bits long and data is part of instruction. zero address instruction are designed with implied addressing mode.



Instruction format with mode field.

#### ② Immediate Addressing Mode:

In this mode data is present in address field of instruction designed like one address instruction format.



Data is directly stored here

#### ③ Register Mode:

In register addressing the operand is placed in one of 8 bit or 16 bit general purpose register. The data is register that is specified by instruction.

one register reference is required to access the data.



#### ④ Register Indirect Mode:

In this addressing the operand's offset is placed in any one of registers BX, BP, SI, DI as specified in Input.



#### ⑤ Direct Addressing Mode:

In this addressing mode,

- The address field of instruction contains the effective address of operand.
- Only one reference to memory is required to fetch the operand.
- It is also called as absolute addressing mode.



#### ⑥ Indirect Addressing Mode:

The address field of instruction specifies the address of memory location that contains the effective address of operand.

Two references to memory are required to fetch the operand.



## ⑦ Relative Addressing Mode:

- Effective address of the operand is obtained by adding the content of program counter with the address part of instruction.

Effective Address = Content of program Counter + Address part of instruction.



## ⑧ Indexed Addressing Mode

- Effective address of operand is obtained by adding the content of index register with the address part of instruction.

Effective Address = Content of Index Register + Address part of Instruction.



## Unit-2

- ① Construct ripple carry adder, look-ahead adder with example.

### A) Ripple Carry Adder

Is a combinational logic circuit. It is used for purpose of adding two n-bit binary numbers. It requires n full adder in its circuit for adding two n-bit binary numbers. It is also known as n-bit parallel adder.

### Ripple Carry Adder:

In Ripple Carry Adder,

- Each full adder has to wait for its carry in from its previous stage full adder.

Thus nth full adder has to wait until all full adder have completed their operation.

- This caused a delay and makes ripple carry adder extremely slow.

This situation becomes worst when the value of n becomes very large.

- To overcome this disadvantage, carry look-ahead adder comes into play.



### Applications

- It is used to add n-bit pip sequences
- It is applicable in digital signal processing & microprocessor.

### Carry Look-Ahead Adder

- Carry look-ahead adder is an improved version of ripple carry adder
- It generates the carry-in of each full adder simultaneously without causing

any delay.

- The time complexity of carry look-ahead adder =  $O(\log n)$

### Logic Diagram:

The logic Diagram for carry look-ahead adder



### Working:

The working of carry look-ahead adder is based on principle the carry-in of any stage full adder is independent of carry bits generated during intermediate stage.

The carry of any stage full adder depends only on following two parameters.

- i) Bits being added in previous stage
- ii) Carry-in provided in beginning.

Now,

The above two parameters are always known from beginning. So the carry in of any stage full adder can be evaluated at any instant of time. Thus any full adder need not wait until its carry in generated by previous stage full adder.

- ② Solve integer addition with example

- A) In addition operation the digits are added bit by bit from right to left and the carries are passed to next digit forward the left.

• subtraction operation can also be done using addition the appropriate operand is negated before adding.

### Addition algorithm:

when the signs of A and B are same, add the magnitude & attach the sign of A to the result.

• otherwise compare the magnitude and subtract the smaller number from the larger.

• choose the sign of result to be same as A if  $A > B$

• The complement of f if  $f < B$ .

• If  $A = B$  subtract B from A and make the sign +ve.

| operation     | Add magnitude | Subtract magnitude |             |             |
|---------------|---------------|--------------------|-------------|-------------|
|               |               | $A > B$            | $A < B$     | $A = B$     |
| $(+A) + (+B)$ | $+ (A + B)$   |                    |             |             |
| $(+A) + (-B)$ | $- (A - B)$   |                    |             |             |
| $(+A) + (-B)$ |               | $+ (A - B)$        | $- (B - A)$ | $+ (A - B)$ |
| $(+A) + (+B)$ |               | $- (A - B)$        | $+ (B - A)$ | $+ (A - B)$ |

### Example:

Adding two magnitude, when the result is the same sign of both operands.

$$\begin{array}{r}
 +3 \ 00 \ 11 \\
 +2 \ 00 \ 10 \\
 \hline
 +5 \ 01 \ 01
 \end{array}$$

$$\begin{array}{r}
 1 + 1 = 10 \\
 0 + 0 = 0
 \end{array}$$

• Adding two magnitude when the result is the different sign of both operands

$$\begin{array}{r}
 -3 \ 10 \ 11 \\
 +2 \ 00 \ 10 \\
 \hline
 (-1) \ 1001
 \end{array}$$

### Flowchart



③ Apply the integer subtraction with example:

$$A - B$$

A - minuend B - substrand

- when the sign of A & B are different add the magnitude and attach the sign of A of the result.

- Otherwise compare the magnitude and subtract the smaller number from the larger.

- choose the sign of result to be sign of A if  $A > B$ .

- or complement of A if  $A < B$

- IF  $A = B$  subtract B from A and make the result true.

### Signed Bit operation

| operation     | Add magnitude | Subtract magnitude |             |             |
|---------------|---------------|--------------------|-------------|-------------|
|               |               | $A > B$            | $A < B$     | $A = B$     |
| $(+A) - (-B)$ | $+ (A + B)$   |                    |             |             |
| $(-A) - (+B)$ | $- (A + B)$   |                    |             |             |
| $(+A) - (+B)$ |               | $+ (A - B)$        | $- (B - A)$ | $+ (A - B)$ |
| $(-A) - (-B)$ |               | $- (A - B)$        | $+ (B - A)$ | $+ (A - B)$ |

### Example :

$$\begin{array}{r}
 13 \quad 0011 \\
 - 72 \quad 0010 \\
 \hline
 +1 \quad 0001
 \end{array}$$

$$\begin{array}{r}
 -3 \quad 0011 \\
 - 72 \quad 0010 \\
 \hline
 -5 \quad 0101
 \end{array}$$

### Flowchart:



### ④ Floating point arithmetic

- This representation does not reserve any specific number of bits for integer part or the fractional part

- It reserves certain number of bits for the number called mantissa and certain number of bits with in that for exponent.

- The floating point representation has 2 parts:
  - 1st part is signed fixed point number called the mantissa.

⇒ 2nd part represents the position of decimal point and is called exponent.

- A floating point number is said to be normalised if the most significant digit of mantissa is 1



- Floating point is a scientific notation

$$I \times m \times 10^E$$

- It is used for representing
  - Speed of light
  - Age of universe
  - Charge of electron

Number mantissa Base exponent

|                  |         |    |    |
|------------------|---------|----|----|
| $9 \times 10^9$  | 9       | 10 | 9  |
| $110 \times 2^7$ | 110     | 2  | 7  |
| 4364.784         | 4364784 | 10 | -3 |

### Unit-3

① Explain in detail in pipeline and its execution.

A) Pipelining: Pipelining is an implementation technique in which multiple instructions are executed simultaneously by overlapping them in execution to save time and resource. The previous instruction will be in the execution phase when the current instruction is fetched from the memory.

Need for Pipelining: Without a pipeline, a computer processor fetches the first instruction from memory, performs the operation mentioned in it, and then goes to fetch the next instruction from memory. While fetching the instruction, the arithmetic unit of the processor is idle. It must wait until it is loaded with next instruction.

#### Stages in MIPS pipelining:

The following are the various stages in pipelining:

① Instruction fetch(IF): Fetch instruction from memory  
 ② Instruction Decode(RD): Read registers while decoding the instruction. The format of MIPS instructions allows reading and decoding to occur simultaneously

③ Execute: Execute the operation or calculate an address. This involves ALU operations.

④ Memory access (MEM): Access an operand in data memory.

⑤ Write Back(WB): Write the result into a register.



5 stage pipelining of MIPS architecture.

The pipelining speed can be manipulated using the expression:

$$\frac{\text{Time b/w instructions}}{\text{pipelined}} = \frac{\text{Time b/w instr. non-pipeline}}{\text{No. of pipe stages}}$$

Pipelining improves performance by increasing instruction throughput. It is not decreasing the execution time of an individual instruction, but increases the no. of instructions that complete its execution for a give time period.



Fig. shows the comparison of execution of instructions with and without pipelining on some hardware components.

Q) Develop in detail about control implementation scheme?

### A) Control Implementation Scheme:

For any instruction, the following 2 steps are same:

- Send the program counter (PC) to memory that contains the code and fetch the instruction from the memory.
- Read one or two registers, using fields of the instruction to select the registers to read.

Load instruction needs to read only one register, but most other instructions require reading two registers. The remaining actions required to complete the instruction depend on the inst. class. This is due to the simplicity and regularity of MIPS instruction set.



An Abstract view of MIPS implementation Instruction Formats of MIPS.

| Field         | 0     | rs    | rt    | rd    | shamt | func |
|---------------|-------|-------|-------|-------|-------|------|
| Bit Positions | 31:26 | 25:21 | 20:16 | 15:11 | 10:6  | 5:0  |

R-Format Instruction.

Instruction format for R-format instruction have an op code of 0. These inst. have 3 register operands: sources: rs, rt, destination : rd. This inst. type is used to implement core add, sub, and, or, slt. The shamt field is for shifting operation.

| Field        | 35(0)43 | rs    | rt    | address |
|--------------|---------|-------|-------|---------|
| Bit Position | 31:26   | 25:21 | 20:16 | 15:0    |

Load (or) Store Inst.

Instruction format for load specified by op code = 35 ten and store is specified by op code 43 ten instructions. The register rs is the base register that is added to the 16-bit address field to form the memory address.

| Field        | 4     | rs    | rt    | address |
|--------------|-------|-------|-------|---------|
| Bit Position | 31:26 | 25:21 | 20:16 | 15:0    |

Branch Instructions.

Inst. format for branch equal (op code=4). The registers rs and rt are the source registers that are compared for equality. The 16-bit address field is sign extended, shifted, and added to the PC to compute the branch target address.

→ All inst. classes, except jump, use the arithmetic-logical Unit (ALU) after reading the registers.

→ The memory reference instructions use the ALU for an address calculation, the arithmetic logical inst. for the operation execution, and branches for comparison.

→ After using the ALU, the actions required to complete various inst. classes differ.

→ A memory reference inst. will need to access the memory either to read data for a load (or) write data for a store. ~~Reading data. Writing data.~~

### ③ Organize the MIPS Architecture ?

→ MIPS (Million Instructions Per Second) is a simple, streamlined, highly scalable RISC architecture with adopted by the industries.

→ The features that makes its widely useable

① Simple load & store with large no. of registers

② The number & the character of the inst.

③ Better pipelining efficiency with visible pipeline delay slots.

④ Efficiency with compilers.

### Implementation of MIPS

MIPS has 32 General Purpose Registers (GPR)

① Integer registers (32 bit) holding integer data

Floating point registers (FPR) are also available in MIPS capable of holding both single precision (32 bit) and double precision data (64 bit). The following are the data types available for MIPS:

| <u>Size</u> | <u>Name</u> | <u>Registers</u>        |
|-------------|-------------|-------------------------|
| 8 Bits      | Byte        | Integer register.       |
| 16 Bits     | Half word   | "                       |
| 32 Bits     | word        | Floating point register |
| 64 Bits     | Double word | "                       |

With these resources the MIPS performs the following operations:

→ Memory referencing: Load word (lw) and store word (sw)

→ Arithmetic-logical inst: add, sub, and, or, sllt

→ Branch inst: equal (beq) and jump (j)

⑦ Set the program counter (PC) to the address of the code and fetch the inst. from that memory.

⑧ Read one (or) two registers, using fields of instruction to select the registers to read

Program Counter (PC): This register contains the address of inst. currently getting executed. The PC is incremented to read the next inst. to be executed.

→ The operand in the inst. are fetched from the registers. In case of branch inst., the result of the branch operation is used to determine the next inst. to be executed. The multiplexor (MUX1), selects one input control line from multiple inputs. This acts as a data selector. This helps to control several units depending on type of inst.

### MIPS instruction format

There are only 3 inst. formats in MIPS. The inst. belongs to any one of following type:

→ Arithmetic/logical-shift/comparison.

→ Control inst. (branch and jump)

→ Load / store.

→ Other (exception register movement)

I-type: load and store instructions.

|         |    |    |           |
|---------|----|----|-----------|
| OP code | Rs | Rt | Immediate |
|---------|----|----|-----------|

R-type: Register to Register operations.

|         |    |    |    |       |       |
|---------|----|----|----|-------|-------|
| OP code | Rs | Rt | Rd | shamt | Funct |
|---------|----|----|----|-------|-------|

J-type: Jump instructions.

|        |        |
|--------|--------|
| Opcode | Offset |
|--------|--------|

→ The multiplexor is controlled by the AND gate that operates on the zero output of the ALU and a control signal that indicates that the instruction is a branch.

④ Explain in detail Instruction Fetch?

A) Instruction Fetch: The fundamental operation in Inst. Fetch is to send the address in the PC to the Inst. memory & obtain the specified inst., & then increment the PC.



Instruction Fetch

R type inst.:

→ They all read two registers, perform an ALU operation on the contents of the registers and write the result.

→ This inst. class includes add, sub, and, or, and slt.

→ The processor have general-purpose registers are stored in a structure called a register file.

→ The R-format always performs ALU operation that has three register operands...

Load & Store Instructions.

→ The load & store inst. compute a memory address by adding the base register.

→ If the inst. is a store, the value to be stored must also be read from register.



Data memory Out

sign-extension Unit

→ The processor has a sign extension unit to sign extend the 16-bit offset field in the Inst. to a 32-bit signed value.

Branch Inst.:



→ Branch target is the address specified in a branch, which is used to update the PC if the branch is taken. In the MIPS architecture the branch target is computed as sum of the offset field of Inst. and address of the inst. following the branch.

→ J. The beg inst. has 3 operands, two registers that are compared for equality, and a 16-bit offset to compute the branch target address. beg1, t2, offset.

→ K. Thus, the branch data path must do two operations: compute the branch target address and compare the register contents.

→ L. Branch taken is where the branch condition is satisfied and the program counter (PC) loads the branch target.

→ M. Branch not taken is where the branch condition is false and the program counter (PC) loads the address of the Inst.

→ N. The branch target is calculated by taking the address of the next Inst. after the branch instruction.

→ O. The offset field is shifted left 2 bits to increase the effective range of the offset field by a factor of four.

- JJ. The unit labelled shift left adds 2 zeros to the low-order end of sign extended offset field.
- \* KK. The control logic decides whether the incremented PC (or) branch target should replace the PC.
- LL. The jump inst. operates by replacing the lower 28 bits of the PC with the lower 26 bits of the inst. shifted left by 2 bits.
- MM. Delayed branch is where the inst. immediately following the branch is always executed.
- NN. MIPS architecture implements delayed branch the inst. immediately following the branch is always executed.
- JJJ. When the condition is false, the execution looks like a normal branch.
- \* KKK. When the condition is true, a delayed branch first executes the instruction immediately following branch.
- KKK. Delayed branches facilitate pipelining.
- To implement branch instructions the data path must include an adder circuitry to complete branch target.
- To control Unit for this data path must take inputs and generate a write signal for each state element.
- The operations of arithmetic logical (or R-type) instructions and the memory instructions data path are almost similar.

## flynn's taxonomy

## UNIT - 4

- single instruction single Data (SISD)
  - traditional sequential computing systems.
- single instruction multiple Data (SIMD)
- multiple instructions multiple Data (MIMD)
- multiple instructions single Data (MISD)



### (i) SISD

- At one time, one instruction operates on one data.
- → traditional sequence operator
- single data stream is being processed by one instruction stream



### (ii) SIMD

- At one time, one instruction operates on many data.
- Data parallel architecture
- Vector architecture has similar characteristics, but achieve the parallelism with pipeling.
- Array Processors.



- SIMD (single-instruction stream, multiple-data streams)
- SIMD works best when dealing with array in for loops

### (iii) MIMD



- MIMD (multiple-instruction streams, multiple-data streams)

• most common and general parallel machine.

- each processor has a separate program.
- each instruction operates different data.

### (iv) MISD

- systolic array is one example of a MISD architecture.
- systolic array is homogeneous network of tightly coupled data processing units (DPUs) called nodes

- each processor executes a different sequence of instruction.



### Multicore processor

A multicore processor is an integrated circuit with two or more processors connected to it for faster simultaneous processing of several tasks, reduced power consumption and for greater performance.

### Architecture of multicore processor

- A multicore processor design enables the communication b/w all available core and they divide and assign all processing duties approximately.
- The processed data from each core is transmitted back to the computer's main board via a single common gateway over all

of the processing operations have been finished.

- The methods beats a single core CPU in terms of total performance.



### construct parallel processor



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

- The adder and integer multiplier performs the arithmetic operation with integer number.
- The floating point operations are separated into three circuits operating.
- The logic, shift and increment operations can be performed concurrently on different data.
- All units are independent of each other.
- so one number can be shifted while another is being incremented.

### Instruction level parallelism

IIP is used to refers to the architecture, in which multiple operations can be performed in a particular process with its own set of resources (address space, registers, identifiers).

IIP processors have the same execution b/w a RISC processors.

The machines without IIP have compile b/w which is hard to implement.

A typical IIP allows multiple cycle operations to be prelined.

#### Example

Let the sequence of instructions be

$$1. y_1 = x_1 + 100 \quad 2. y_2 = x_3 + 100$$

$$3. z_1 = y_1 + 0010 \quad 4. z_2 = y_2 + 0101$$

$$5. t_1 = t_1 + 1 \quad 6. p = q \times 1000$$

$$7. c1r = c1r + 0010 \quad 8. r = r + 0001$$

#### cycle operation

$$1. y_1 = x_1 + 1000$$

| cycle | Int ALU        | Int ALU                 | Float ALU               | float ALU               |
|-------|----------------|-------------------------|-------------------------|-------------------------|
| 1     | $t_1 = n+1$    | $c1r =$<br>$c1r + 1000$ | $y_1 =$<br>$x_1 + 1000$ | $y_2 =$<br>$x_2 + 1100$ |
| 2.    | $r = r + 0001$ |                         |                         |                         |
| 3.    | nop            |                         | $z_2 = y_2 + 0101$      |                         |

fig : ILP record of execution.

No operator in the fig are used to show idle time of processor since latency of floating point operators is 3. hence multiplication take 3 cycles and processor has to remain idle for that time period. But in IPL execution the processor can utilize those nop's to execute other operations while previous are still being executed.

## Unit 5

Utilize virtual memory and how it works efficiently in computer system.

### A) Virtual memory:

Virtual memory is a storage scheme that provides user an illusion of having a very big main memory. This is done by treating a part of secondary memory as the main memory.

Instead of loading one big process in the main memory the OS loads the different parts of more than one processes in the main memory.

By doing this the degree of multiprogramming will be increased in the CPU utilization will also be increased.

### How virtual memory works?

Whenever some pages need to be loaded in the main memory for execution & the memory is not available for those many pages, then in that case instead of stopping the pages from entering in the main memory.

OS searches for the RAM areas that are not referenced and copy into the secondary memory to make the space for new page in main memory.

Let us assume 2 processes, P<sub>1</sub> and P<sub>2</sub> contains 4 pages each. Each page size is 1KB. The main memory contains 8 frames of 1KB each. The OS resides in first two partitions.

| Frame | Present/ Absent | DBit | RBit | PBit | Protection |
|-------|-----------------|------|------|------|------------|
| 0     | 0               | 0    | 0    | 0    | 0          |
| 1     | 1               | 0    | 0    | 1    | 0          |
| 2     | 1               | 1    | 0    | 0    | 0          |
| 3     | 0               | 0    | 0    | 0    | 0          |
| 4     | 0               | 0    | 0    | 0    | 0          |
| 5     | 0               | 0    | 0    | 0    | 0          |
| 6     | 0               | 0    | 0    | 0    | 0          |
| 7     | 0               | 0    | 0    | 0    | 0          |

Main mem → off P<sub>2</sub> Secondary memory

| Frame | Present/ Absent | DBit | RBit | PBit | Protection |
|-------|-----------------|------|------|------|------------|
| 4     | 1               | 0    | 1    | 0    | 0          |
| 5     | 0               | 0    | 0    | 0    | 0          |
| 6     | 0               | 0    | 0    | 0    | 0          |
| 7     | 0               | 0    | 0    | 0    | 0          |

CPU

5

7

Page table base(P<sub>1</sub>) Page table base(P<sub>2</sub>)

The page tables of both the pages are 1KB size each and therefore they can be fit in one frame each. The page tables of both the processes contain various information that are shown in above fig.

The CPU contains a register which contains the base address of page table that is 5 in case of P<sub>1</sub> and 7 in case of P<sub>2</sub>. This page table base address will be added to page number of the logical address when it comes to accessing the actual corresponding entry.

### Advantages:

- The degree of multiprogramming will be increased.
- User can run large application with less real RAM.
- There is no need to buy more memory RAMs.

### Disadvantages:

- The system becomes slower since swapping takes time.
- It takes more time in switching between applications.
- The user will have the lesser hard disk space for its use.

② Dissect about direct and set associative map technique in cache.

### a.) Direct Mapping:

A particular block of main memory can be brought a particular block of cache memory so, it is not flexible.

6 bits 9 bits



The CPU address of 15 bits is divided two field, The nine least significant bits constitute the index field & remaining six bits from tag field. The main memory needs an address that includes both the tag & index bits.



The direct mapping cache organization uses the n-bit address to access the main memory & the k-bit to access the cache. Each word in cache consists of data word and associated tag.

Index Tag Data

|     |    |      |
|-----|----|------|
| 000 | 01 | 3450 |
| 001 | 01 | 6570 |
| 010 |    |      |
| 011 |    |      |
| 110 | 02 |      |
| 111 | 02 | 6780 |



The Index field is divided two parts, Block field & the Word field. In 512 word cache 64 blocks of 8 words, since  $64 \times 8 = 512$ .

### Associative mapping:

In mapping function, any block of main memory can potentially reside in any cache block position. This is much more flexible mapping method.

CPU address (15 bits)



Argument register

| Address → | ↓ Data → |
|-----------|----------|
| 01000     | 3450     |
| 02345     | 6710     |
| 22345     | 1234     |

### Set Associative Mapping:

In this method, blocks of cache are grouped into sets, and mapping allows a block of main memory to reside in any block of specific set. From flexibility point of view, it is in between to other two methods.

| Index | Tag | Data | Tag | Data |
|-------|-----|------|-----|------|
| 000   | 01  | 3450 | 02  | 5670 |
| 777   | 02  | 6710 | 00  | 2340 |

The octal numbers listed with reference to main memory contents, when the CPU generates a memory request, the index value of address is used to access the cache. The comparison logic done by associative search of tags in sets similar to a associativity memory search thus name "set associative".

### Replacement policies:

When the cache is full & there is necessity to bring new data to cache, then a decision must be made as to which data from cache is to be removed.

### In case of set associative memory:

- Random replacement

- First-in First-out (FIFO)

- Least Recently Used (LRU)

### ③ Construct and explain Central Storage Unit.

a) Main memory is the central storage unit in a computer system. It relatively large and fast memory used to store programs and data during the computer operation. The principal technology used for main memory is based on semi conductor integrated circuits. Integrated circuit RAM chips are available in two possible operating modes, static & dynamic.

- Static RAM - consists of internal flip flops that store the binary information.

- Dynamic RAM - stores the binary information in form of electric charges that are applied to capacitors.

Most of the main memory in general purpose computer is made up of RAM integrated circuit chips, but a portion of memory may be constructed with ROM chips.

- Read only memory - Store programs that are permanently resident in computer and for tables of constant that do not change in value once the production of computer is completed.

- Boot strap loader - function is start the computer software operating when power is turned on.

- Boot strap program loads a portion of operating system from disc to main memory & controls then transferred to operating system.

### Memory Address Map

The interconnection b/w memory and processor is then established from knowledge of size of memory needed and type of RAM & ROM chips available. The addressing of memory can be established by means of table that specify the memory address assigned to each chip.

### Memory connection to CPU:

RAM and ROM chips are connected to CPU through the data address buses.

The low order lines in address bus select the byte within the chips and other lines in address bus select a particular chip through its select input. Each RAM receives the seven low-order bits of address bus to select one of 128 possible bytes. The particular RAM chip selected is determined from lines 8 and 9 in the address bus. This is done through a  $2 \times 4$  decoder whose outputs go to CS1 input in each RAM chip.

### ④ Develop how I/O devices can be interfaced with a block diagram.

a) I/O Interface is used as a method which helps in transferring of information b/w the internal storage devices memory and the external peripheral device. It is also called Input-output device. Just like the external hard drives there is also availability of some peripheral devices which able to provide both input and output.



### Functions of I/O Interface

- It is used to synchronize the operating speed of CPU with respect to input-output.
- It selects the input-output device which is appropriate for interpretation of the input-output device.
- It is capable of providing signals like control and timing signals.
- In this data buffering can be possible through data bus.
- There are various error detectors.

### SCSI (Small Computer System Interface)

- SCSI is a b/w bus specification for connecting peripherals to a computer using parallel transmission interface.
- SCSI devices come in 2 types

#### ① Single ended devices:

Use one data lead & one ground lead to establish single ended signal transmission over the bus.

#### ② Differential devices:

Use two data leads, neither of which are at ground potential. These devices are generally more expensive but are resistant to effects of noise.

#### Common SCSI components:

There are several components used in SCSI storage systems.

- Initiator: An initiator issues request for service by SCSI devices & receive response.

\* Target: SCSI target is typically a physical storage device. The target can be hard disk or an entire storage array.

#### Service delivery subsystem

The mechanism that allows communication to occur b/w the initiator & target. It usually takes form of cabling.

\* Expander: only used with serial-attach SCSI (SAS). It allows multiple devices to share a single initiator port.

#### USB (Universal Serial Bus)

• USB is standard interface for connecting a wide range of devices to computer such as keyboard, mouse, smartphones, speakers, cameras etc.

• USB was introduced for commercial use in the year 1995.

#### USB Architecture:

When multiple I/O devices are connected to computer through USB they are organized in tree structure.



The tree structure connecting I/O devices to computer using USB hub nodes which are referred to as a hub.

HUB is intermediary connecting b/w I/O devices & computer.

#### Types of USB connection:

- i) USB Type A (ii) Type B (iii) Micro USB
- (iv) Mini (v) USB Type C (vi) USB 3.0 micro B.