

8/9/23

## Syllabus

8/9/23

- 1) Overview of Computer System → Basic elements  
Instruction, Interrupts
- 2) Basic introduction (of OS)
- 3) Process description & process scheduling → FCFS  
SJF
- 4) Mutual exclusion & process synchronization → Peterson's algorithm
- 5) Threads, Processes, Deadlock & Starvation → semaphore
- 6) Memory management → Virtual Memory  
Paging  
Segmentation
- 7) Disk Scheduling & I/O Management → LOOK, SCAN, CSAN
- 8) File management & security

Intro. RAM = memory of storing temporary values of variables

- OS → interface b/w user & hardware → RAM, CPU, etc other softwares at std. int. interfaces → MS-DOS

Then windows took over becoz of its advantage of Graphical User Interface

- Basic elements of comp. sys. → CPU



Q) What is an OS?

Ans It exploits the hardware resources of 1 or more **processors** to provide a set of services to system user.

It acts as an interface b/w user hardware & user application.

Basic elements of process comp.

1. Processor - controls operation of comp. & performs data processing
2. MM - controls data & program storage
3. I/O - moves data b/w computer & its external environment
4. System bus - provides communication b/w processor, I/O modules & main memory

- \* 2 main registers present in process - MAR, MBR
- MAR - addressing memory for next read / write
- MBR - contains the data to be written onto the memory or the data read from memory

### EVOLUTION OF MICRO PROCESSOR

- Digital signal processing
- GPU uses **SIMD** { single instn / Multiple Data streams, SIMD }
  - DSP To sync audio & video }
  - Functional Units

### 1. Microprocessor

It is the fastest general purpose processor, where a single chip contains single processor unit present on single chip. However each chip unit may contain multiple processors.

### 2. GPU

Provide efficient computation on arrays of data using SIMD technique.

used for general numerical processing

DSP (Digital signal processor)

deals with streaming signals such as audio & video used in embedded systems like modems  
They provide support for security through encryption technique.

SOC (System on chip) may go at devices you carry in hand like mobile phone.

To satisfy the requirements of hand held devices the microprocessor is giving weight to SOC components such as GPUs, video & MM in association add "to processor are on the same chip".



Instruction cycle

PC → address of next instruction

IR → data in address of PC

Instruction Execution

A program consists of a set of instructions

It consists of 2 steps:

1. The processing required for a single instruction is called instruction cycle. In the inst. cycle the PC (program counter) holds the address of the next instruction to be fetched. The processor always increments the PC after each instruction fetch so it will fetch the next instruction in PC. The next fetched instruction is loaded in IR. It contains

\* Difference b/w PC & MAR?

Ans PC - Points to 2nd address of next inst. to be fetched

MAR - points to the address of data to be fetched to execute the current inst.

the bits that specify the action processor has to take. It has 4 actions:

→ Processor memory : Data may be transferred from processor to memory / vice versa

→ " i/o : Data may be transferred to or from any peripheral device.

→ Data processing: The processor may perform some arithmetic/logic operations on data.

→ Control

Any instruction may specify the sequence of execution to be altered.

## Interrupts



A mechanism is provided by all computers by which other modules may interrupt the normal sequencing of the processor. They are provided as a way to improve processor utilization.

There are 4 classes of interrupts:

1. Program{aka software interrupt}

2. Timer

3. I/O

4. Hardware failure.



In the eg above:

The user program provides a series of WRITE program interleaved with processing. code segments 1, 2, 3 refer to instruction that do not need I/O.

refer to instruction that do not need I/O.

The write calls are from I/O routine which is ~~in place~~

system:

The I/O program consists of 3 steps of instruction:

The I/O program consists of 3 steps of instruction:

- i) The preparation code to prepare for the initial I/O
- ii) " actual I/O command
- iii) The inst. to complete the operation.

without interrupt word

Without interrupt, the processor has to wait until the I/O routine is finished. It takes a long time for the external device to finish processing until then the time of processor is wasted but with use of interrupt, the processor is engaged in executing other instructions while ~~in~~ an input-output operation is in progress.

In eg we can see, when the external device completes its processing, the I/O module for that external device sends an interrupt request signal to the processor.

- The I/O program i.e., invoked consists only of preparation code & actual I/O command. This way processor works concurrently with the I/O program & improves its utilization.



13/9/23

### Instruction cycle with interrupt:



- When the interrupt processing is completed,
- The user program does not have to contain any special code to accommodate interrupts. The processor & OS is responsible for suspending the user program & then resuming it from the same point. To accommodate the interrupts, an interrupt stage is added to the instruction cycle. In the interrupt stage, the processor checks to see if any interrupts have occurred which are indicated by the presence of an interrupt signal. If no interrupts are pending, the processor proceeds to the fetch stage, and fetches the

next instruction of the current program. If an interrupt occurs:

## Interrupt Processing



- The device issues an interrupt signal to the processor.
  - The processor finishes the execution of the current instruction before responding to the interrupt.
  - The processor tests for a pending interrupt request, determines there is one, & sends an acknowledgement signal to the device that has issued the interrupt.
  - Now processor needs to prepare to transfer control to the interrupt routine. It saves the information needed to resume the current program which are PSW (program status word) & the location of next instruction to be executed. The processor then loads the program counter with the entry location of interrupt handling routine that will handle the interrupt. Once the PC has been loaded, next instruction cycle is started from interrupt handler routine. Now interrupt handler routine would need the general purpose registers

so it starts by saving the contents of all registers to STACK.

- The interrupt handler now proceeds to process the interrupt, when the interrupt processing is complete, the same values are taken back by the control STACK.
- The final act is to restore the values of PSW & the program counter values from the STACK.

### Multiple Interrupts

One or More interrupts can occur while an interrupt is being processed, so there are 2 approaches that can be taken into account to deal with multiple interrupts:

- first one to disable an interrupt when an interrupt is processed. A disabled interrupt means that the processor will ignore any new processor interrupts. If an interrupt comes during this time, it will remain pending & will be checked by processor after the processor has enabled interrupts. Thus if an interrupt occurs while a user program is executing, the interrupt is disabled immediately.

Drawbacks - It does not take account, relative priority / time critical needs.

Eg - When an input arises from communication line, its priority is higher & it needs to be serviced immediately. But as interrupts are disabled, it has to wait for a very long time until the previous interrupt has executed its execution.

(user program)

Processor



Priority

Total time

to complete

$t = 0$ ,  $40 \leftarrow$  user prog starting

$t = 10, 10$

$t = 15, 7$

$t = 20, 5$

Suppose there are 3 I/O devices, a printer, a disk & a communication line with priorities 2, 4, 5.

A user program begins at  $t = 0$ , a printer interrupt occurs the user information is stored on control stack & execution continues at interrupt service routine. While this routine is still continuing, another interrupt from communication line arise at  $t = 15$ . As the communication line has higher priority, the interrupt request of this I/O device is serviced. At  $t = 20$ , an interrupt with much higher priority arise, so the processor services the interrupt request of this I/O device. When all the interrupts are handled, the previous processor state is restored which is the execution of printer interrupt. After the interrupt routine of printer is completed the execution of user program continues.

IS/9/23

## Memory Hierarchy



memory in

- The computer system is divided in the form of levels. The smaller, more expensive, faster memory are supplemented by larger, cheaper & slower memory.
- The smallest, fastest & most expensive type of memory, consists of registers. Skipping to 2 levels main memory is the principle internal memory of the computer. The cache is usually visible to the programmes for staging the movement of data b/w MM & registers. These 3 types of memory is volatile.
- External non-volatile memory is referred to as secondary memory which include USB & flash memory. They store programs & data files.
- The magnetic disks & magnetic tapes are usually used to take back up of the data & are slower than other memories in the above levels of the memory hierarchy.

## Cache Memory





LRU : Least Recently Used

↳ data replaced from cache

- Cache Memory is intended to provide memory access time approaching that of fastest memories available & secondly support a large memory size that has a price of less expensive type of memory. It contains a copy of the portion of the MM. When the processor attempts to read / write a word of memory, a check is made to determine if the word or byte is present in cache. If it is there, the byte / word is delivered to the CPU, if not a block of MM consisting of fine words is read into the cache then the byte / word is delivered to the processor. Because of the concept of locality of reference, when a block of data is fetched into the cache to satisfy a single memory reference, it is likely the next future memory references will be to other bytes of the block.

RA = read address



RA : Read address



- The fig illustrates the read operations: The processor generates the address RA of a word to be read. If the word is contained in cache it is delivered to the processor otherwise the block containing that word is loaded in the cache & the word is delivered to the processor.

Now there are design issues that must be addressed in dealing with virtual memory & cache design.

- Points to consider :
  - 1) Cache size
  - 2) Block "
  - 3) Replacement Algo
  - 4) Mapping to
  - 5) Write policy
  - 6) No. of cache level.

### (i) Cache size

According to hierarchy, small caches have significant impact on performance. Cache is closer to CPU. Hence size of cache is usually smaller.

### (ii) Block Size

It is the unit of data exchanged b/w cache & main memory.

### (iii) Replacement Algo

It chooses which block to replace when a new block is to be loaded into the cache & cache already has all slots filled other blocks. One of the way is replacing the block that is least likely to be needed again in the near future such as LRU.

### (iv) Mapping

When a new block of data is read into the HF cache, when a new block of data is read into the HF cache, the mapping determines which cache location the block will occupy.

### (v) Write Policy

If the contents of a block in cache are altered, then it is necessary to write it back to the MM before replacing it. One way is writing can occur every time when block is updated.

Another way is writing only when block is replaced.

### (vi) No. of Cache levels

Multiple levels of cache provide fast access time to CPU & enhance the performance.

## Techniques DMA to execute I/O operation

When the processor is executing a program and encounters an instruction related to I/O, 3 techniques are possible for I/O operations.

i) Programmed I/O

ii) DMA Interrupt driven I/O

iii) DMA

→ In case of programmed I/O, the I/O module performs the requested action & sets the respective bits in I/O status register & takes no further action to allow the processor. The processor periodically checks the status of I/O module, until it finds the operation is complete.

→ Interrupt driven I/O : It is more efficient than programmed I/O. It still requires active intervention of the processor to transfer data b/w memory & I/O module. Its drawback is the processor is busy in managing I/O transfer and its utilization in running current program decreases. So that user's priority solution to this problem is DMA, where large volumes of data is to be moved by a separate module. DMA is more efficient technique. The DMA can be performed by a I/O module. It can be incorporated combined with I/O module. The processor issues a command to the DMA module by sending these 4 informations:

- i) whether a read/write is required
- ii) The address of I/O device involved
- iii) The starting location of memory to read data from & rewrite data to
- iv) The no. of words to be read/written

The processor then continues with other work.