

- Management of <sup>main</sup> memory
- Management of I/O devices
- Management of storage devices

9/5/2018  
class 26

## MEMORY MANAGEMENT

### Primary or Main Memory

↳ the memory which is processed directly,  
RAM and ROM,

### Management of RAM

Why?

To execute the process, we have to load into RAM.

- How a ~~process~~ becomes a process?



Any activity during compilation is in compile time.

For example -

$$c = \boxed{2 * 3.14} \pi r.$$

$$c = 6.28 + r; \rightarrow \text{constant folding}$$

I not in  
variables.

When you are executing a process,  
then any activity at that time, is called  
run-time activity.

Variable name is a logical name for some memory  
location.

→ in source program

after that no variable names.

(Compiler removes all variable names.)

At Load module → Relocatable addresses.

Ex- int a, b, c;



Now suppose our program starts at 2000H, then  
absolute address of a will be 2000H - 2001H

LOA - 2000H ← absolute  
address programming  
comes into play when process is loaded.

If we use absolute addressing,  
implementation of multiprogramming and multitasking will become difficult.

→ we have to keep track of address (available locations oneself)

→ programmer needs to know the size of memory



### Swapping.

Swap Out

Swap In.



If we combine swapping with priority ⇒ roll out, roll in

### Memory Management Schemes.

Contiguous

non-contiguous

In Contiguous  
we load the entire process in one part of memory.  
(in contiguous memory location)

### Non-contiguous

we break the process into chunks and then store it into memory, where available.

Contiguous

Static  
(first decide degree of multiprogramming, then divide memory into degree parts)

$$\frac{M}{N}$$

and store process,

(Advantage:-

Simplest way of implementing)

Dynamic

we will not predivide the memory into parts.

When a process come, we will store in memory



(Degree of multiprogramming)  
(how many processes will be stored in RAM at particular time)  
Ex



↓ P2 terminates



duty to merge consecutive holes

### Disadvantages

- a) Spare will be waste
- b) If one process is long, then it will not be executed.



Initially, the whole RAM is a hole (single hole)

It is the job of OS, to maintain the information of where <sup>all</sup> processes have (in memory).

(1)



Where to store?

Strategies

(1) First fit

When the process first fits, we will store in it.

(2) Best fit

We will store which is larger than PF, but less than all larger.

(3) Worst fit

We load the process in the largest hole.

Advantage →



(Residual hole will be larger than Best and First fit)

Disadvantage of Contiguous

External Fragmentation

wastage of small, small memory



even though we have space, but we cannot save it.

Solution



8 we can shift ~~hello~~, process at one part of memory

### Compaction

↳ expensive process.



Numericals can come

(Easy)

9 in next class → Non-contiguous

### Paging

19/3/2018  
Class-27

Segmentation 8086

Flat address space

LDA 8000 H ↳ whole space is similar:  
It is a .  
address space.  
0000H ↳ FFFF H  
can use any memory instruction  
on any address.  
(can be used for both data &  
memory address)

Stephens Paul Morse.

felt that 8085 is good for Assembly language.  
but not for high level language. (No difference b/w part of  
relative addressing mode ↳ content of memory holding code  
memory loading data or part of  
we add the PC to the  
offset value address given in the instruction.

Jumps & Call Instruction ↳ use relative addressing.

Relative address - a positions ahead / back  
(jump)

In portion of memory, we might want to use relative addressing,

In portion of memory holding data, we might need to access  
array or string. (different parts of memory access differently  
depending on whether it holds data or code)



→ How can you implement that in microprocessor?

Morse proposed Segmentation, useful whenever need

Li developed Intel 8086 write program in HLL  
using segmentation.

\* Registers in microprocessor - today are a superset of

Registers used in 8086.

\* Most powerful microprocessor.

\* 8086

\* Several others (8086...) were advanced version of 8086.

\* Instruction set of others is a superset of 8086.

The whole family of Microprocessors influenced by 8086 is called x86 architecture

makes use of segmentation

and instruction set is called x86 instruction set. (Basic philosophy of programming same as 8086)

Now,

What is segmentation?

Segmentation is a memory management scheme where the linear memory is logically partitioned into segments each having unique purpose.



It does not exist in the chip.



Logical address space  
It does not exist on chip, but in our mind

There are many memory management schemes acc<sup>n</sup> to which we can allocate the logical address space on physical address space

→ Segmentation has nothing to do with mapping.  
 → Segmentation partitions the logical address space into some segments and each segment contains some unique part of process.



Advantage → Optimise the memory access easily.

Ex- main contain code

(To access code easily, access main part)

⇒ can have more than one code segment/data/stack segment

Whether we do segmentation or not, we need to do mapping, whether contiguous or non-contiguous memory allocation.

### Segment Table

If we segmentation, then there will be segment table.

In the memory.



Segment no., used as index,

displacement  $\rightarrow$  (what is offset of word, within that segment)  
(where is word stored in that segment).

Q10 s ; find base address

address (base address + d)

= actual address.

$\rightarrow$  processor should have necessary hardware support to implement segmentation.

$\rightarrow$  What are the commonly used segments?

① Code (CS)

It will store the code (Machine language program)

(Code can be accessed in both DS & ES) (for Dynamic Allocation)

② Data (DS)

will contain the global variables of the program.

③ Stack (SS)

program stack will be there, local variables

④ Extra (ES)

(similar to DS) (Extra data segment)

Ex - copy one array to another place, we can access these 2 segments simultaneously. We can access memory at diff. places simultaneously (DS & ES)

In modern day's processor, they use combination of segmentation & paging. (though both can be implemented independently)

CPU generates logical addresses





Linear addrs: obtained after segmentation starts from 0000 to max.

Physical addrs: Actual address space where memory word is stored in RAM.

### Intel Pentium (Microprocessor)

Not very simple and not very complex.

Before this,

8008, 8080, ... 8085, 8086 (has numerical name)

Then Why Pentium? (as invention in USA only  
for legal issues. if it has a name,  
not a number)

→ <sup>micro</sup>Processor can have upto 16K segments free <sup>process</sup>, but not necessary to access all the segments <sup>all them</sup> at a particular point of time

→ only 6 segments can be accessed

↳ because there are only 6 segment registers

→ Microprocessor doesn't know, which ~~pre~~segment has which type?  
→ segment can be of upto 4 GB.

Base address of 6 segments can be stored only in these registers



d should be b/w 0 to upto 4GB SBr

→ if we want to access any outer segment. Other than 6, load the segment base address into register. Each register will have different segments.

Segments can be overlapping

→ Intel Pentium also uses Paging



→ If we are installing OS on this MP, then ensure page size.

→ Intel Pentium uses segmentation & paging.

→ page size will be fixed

↳ 4KB and 4MB.

Not much questions

Generally

Question can be short note on Segmentation)

(zada ~~note~~ nahi aata)

Three things that do exist but are not visible →

① Family of Ghosts.

② True Love

③ Virtual Memory

→ Earlier day, no virtual memory.

\* Virtual Memory → Load process in RAM & execute.

→ Size of RAM is fixed. To increase degree of multiprogramming, it is fixed.

→ If size of process > size of RAM, can't execute that process,

∴ we use virtual memory.

RAM card is  
(Size of RAM is fixed)

→ We don't say programmer that 8 GB is your limit.

Give freedom to programmer to write very large addresses.

The address space that programmer assume RAM at time of writing the program. The illusion that programmer has while writing the program is virtual memory

If the degree of multiprogramming is ~~is~~ ~~1~~,  
~~and you~~.

### Advantages

- can have multiple processes in RAM.
- increase degree of multiprogramming.
- Give freedom to programmer to write long program.

For virtual memory implementation, we use non-contiguous memory

→ In virtual memory, do not keep all portions of ~~the~~ program in memory.

Only those portions of process are kept in RAM, that are currently been executed. The remaining part of process is stored in disk.

( Size of disk is very large. Since we use non-contiguous memory location, this is possible.

This is the concept of virtual memory.



Disk

for multiple processes running,



Disk

keep small parts of multiple processes in RAM.

( Not easy to implement Virtual memory )

## Paging

↳ Non-contiguous memory allocation scheme.



logical memory → address space of process

→ whole footprint of process in memory.

we divide this address space in different equal sized units called pages.



Pages are logical units (not in real)

(we have to store them into physical memory RAM)

RAM is divided into equal size frames,



↳ size of pages and frames are same.  
respectively.

↳ Any page can be loaded at any frame in RAM due to equality and size

Data Structure: Page Table → to keep track of which page links to which frame

Page contains code & data.  
(contains all addresses)

Page → Logical entity → (doesn't exist)

Frame → Real space in RAM

Addressing is always relative in paging

CPU generates Logical addresses.



Convert logical address to physical address using page table.

Now, we are trying to access 5<sup>th</sup> frame in RAM.

Page size is fixed.

There is no external fragmentation.

Size of page = Size of frame

Once installed on OS, page size becomes fixed.

We can access d<sup>th</sup> byte in that particular frame.

In most OS,

page size = 512 B to 16 MB  
acc to (8<sup>th</sup> edition)

### Advantages of Paging

⇒ No external fragmentation

because size of pages and size of frames are exactly same  
(No wastage)

⇒ Size of process can be independent of page size.

⇒ Multipages can be used for large process.

Let us assume page size = 1 MB.  
process size = 10 MB.

10.5 MB

It is less lossy  
and there are  
ways of handling it

10 pages  
required

11 pages  
required  
5 MB is wasted.  
Is known as internal fragmentation

For every process, there is a page table in system

↳ stored in RAM.

↳ As many page tables, as the no. of process in multiprogramming

→ How to keep track of page tables?

We have a register called page-table base register (PTBR)

→ holds the starting address of the page table of the process which is currently running.

→ when context switching, we have to just change the value of (PTBR).

↳ makes context switching very fast.

→ If we want to use LDA instruction, how many times we have to access the memory?

2 times.

① First to access the page table.

② Access physical address.

→ and then find the location and load in that

→ load in that particular location

→ it takes twice the time than continuous memory location

LDA 8000 H, Only 1 memory access

LDR in paging: we need absolute address and hence access

RAM page table to get the frame number which is

absolute address and then use frame no. for actual reading/writing.

RAM is much slower than processor  
(2 memory access needed).

You are taking more time in read and write.

- 8 B
- Paging has many advantages hence we must use paging.
- Use one special hardware chip:
- Transition Look-aside Buffer (TLB)
- ↳ dedicated & fast hardware chip. (to improve performance)
  - ↳ associative memory (context admissible memory)



If P is found, then  
TLB hit else

TLB miss,

then go to page table.

In this, page nos of process  
that are accessed frequently,  
and their frame no.  
are stored.

→ If we get P here only, we  
read, without accessing  
page table.

→ It is very fast

→ It is small in size.

(not all entries can be stored, only  
recently accessed)

$$\text{Effective Access Time} = \text{hit ratio} \times [\text{TLB access time} + \text{memory access time}]$$

$$+ (1 - \text{hit ratio}) \times (\text{TLB access time} + 2^x \text{memory access time})$$

→ If hit ratio is high, performance is very good.

→ Access time is very less than  
memory access time.

### Page Table

| frame no. | 6 bit | read only |
|-----------|-------|-----------|
| 0         | 0     |           |
| 1         | 1     |           |
| 2         | 1     |           |
| 3         | 1     |           |

→ If hit ratio is —, then small  
effective access time.

→ We can augment page table with a new  
bit called read only bit.

→ Initially rob are sets.

→ When processor make any change in a page,  
then rob = 0.

→ we have to store back to disk, in case page is modified.

↳ This is to ensure, disk has modified data.

→ In case no modification  
 $rob = 1$

& 3 doc files are simultaneously editing.



ed1, ed2 and ed3 same for 3 processes, so can have a combined page table for all 3 processes.

⇒ Page table is stored in some page of OS.

- This might take many pages to store page table,
- To access page table, we need difficult methods.

There are two techniques, → to ensure pg table is not very large.

1) Hierarchical

2) Hashed page table  
(Not much important, read from book.)

Hierarchical Page Table

Two-Level Paging

CPU will generate logical address of this form.



Recompose a large/outer page into smaller pages.

one

can be multiple page table.

## Three level paging



We can also use 4, 5-level paging  
for ~~even~~ larger code.  
It is talked only for one process.

## Problem with hierarchical (Disadvantages)

- Memory access increases

Since you will have to access memory multiple times.  
 $\hookrightarrow$  (Performance degrades).

→ programmes will have to compromise between size of page table and performance.

Every process has its own page table and stored in RAM and hence an alternative for this.

## Inverted Page Table



→ for calculating  $d$ , we need Inverted page table.

→ we use frame no. as index.

Kernel's (0). { 0<sup>th</sup> frame stored in frame no. 0.

Advantage: Only 1 page table used.

→ Inverted because frame no. is used as index.

## Problems :-

↳ No shared pages (as process id of every process is diff.)

↳ You can not implement virtual memory. (Also, take linear time as compared to O(1))

## UNIT-6 VIRTUAL Memory MANAGEMENT.

↳ allows execution of process that are not in RAM.

↳ ↳ process partial in RAM.

\* can be executed using virtual memory.

### Advantages.

↳ any arbitrarily large process can be executed. (size of process not limited by size of RAM)

↳ degree of multiprogramming increases.

→ How you implement virtual memory?

There is a technique called,

### Demand paging

↳ ↳ most widely used technique to implement V.M.

↳ Based on paging,

DEMAND → we load into the RAM, a page only when it is demanded by processor (CPU).

Some pages may never be loaded into RAM.

pager = Lazy Swapper  
(load program from disk → RAM) → only when CPU demands those particular page.



Some page in RAM & some is in disk.

How to know process has many pages and which pg is where?

→ By changing Page Table.

valid/invalid Bit.

→ If CPU wants to access a pg in RAM, then execution continues as it is.

→ If CPU wants to access a page, which is not in RAM,  
(if finds that valid = I), there is an interrupt

system generates → **page fault trap**

Trap → { highest priority  
non-maskable  
hardware interrupt }

(5-6 marks  
Question).

Q. How to handle interrupt?

Handling Page Fault -



In demand paging, pages already loaded in RAM.

Pure Demand paging. (extreme/special case of demand paging)

↳ we start a process with none of its pages loaded into RAM, and we start executing. (load contents from PCB and start)

Just in the starting, there will be a page faults.

### Advantages

→ OS does not assume which will be used. The pages which will be actually be used will be loaded.

↳ Response time, quite low.

(CPU's executing fetching instructions from one locality of mem.

Locality of References. (also seen in case of second memory & cache memory.)

↳ for code (instructions)

↳ for data. (we will be doing load/store in one locality of memory)

Most computer programs exhibit this phenomena.

→ Global variables

(stored in one part/ locality of memory as variables stored in one part.)

Here we talk about paging.

→ If we want to implement virtual memory, disk, paging related h/w needed.

Let us define,  
page fault ratio is  $p = \frac{\text{No. of page-faults}}{\text{No. of memory access}}$ .

$$0 \leq p \leq 1, p \rightarrow 0$$

Effective access time =  $(1-p) \times \text{memory access time}$   
 $+ p \times \text{page fault service time}$   
more time as it is disk access

$P \downarrow$  then,

effective access time = memory access time.

We have to minimize  $P$ .

We need to keep page fault service time small

4<sup>th</sup> step in 6 step process

If we did not find a frame, then we have to use

\* Page replacement.

copy one page to RAM and remove the page from frame to disk

(When no free frame in RAM) (which should happen)

→ Step B :-

→ Back the old page in disk.

→ Put new page

→ update page table for both incoming and outgoing page.



read only bit / dirty bit  
modify bit  
alternate name

If the page has not been modified yet, then no need to store back to disk, as old copy is available as it is.  
→ save time.

For Page Replacement, we use two types of algorithms.

parameters (OS uses 1 of many types of algos)

Page Replacement Algorithms → Page fault ratio.  
(Try to minimise this)

To measure page fault ratio, we use reference string.

other type → Frame allocation  
high priority allocation  
will be given algorithms  
how many frames?  
(triggered as long term scheduler)

sequence of random numbers:

(1), 0, 2, 4, 0, 1, 4, 5, 7

page number

- we want to decide which page to remove from RAM & store in disk.
- The victim is chosen by page replacement algo.
- Page replacement algo used very frequently even frequently than CPU scheduling algo.
- had to be very fast.
- Assume that a process wants to access page no. 1, page no. 0, 2 ..
- different random reference string run on replacement algos.
- and then avg. values are taken.
- No. of page faults suffered by process depends on page replacement algo
- It is common for all processes.
- There is another factor on which page fault depends:-  
no. of frames.
- (if we allocate less frame, then large Pg. faults,  
if allocate more frame, then small Pg. faults)



→ if we try to ↑ multiprogramming, by allocating less no of frames to each process, then large no. of page faults will occur.

if no. of frames allocated  $>$  no. of pages.  
then, page fault = 0.

Two types of algorithms

- Page Replacement
- Frame Allocation.

### Page Replacement algorithms.

#### ① FIFO page replacement algorithm.

First In First Out.

Whichever page has been loaded into memory, will be replaced first.

→ do not need to load the time when loaded.

→ just maintain a queue.

→ It is the simplest placement algorithm.

→ Performance is not good.

∴ page fault ratio/rate increases.

Ques. A process is allocated 3 frames in the memory

and has given reference string = 7, 0, 1, 2, 0, 3, 0, 4,

2, 3, 0, 3, 2, 1, 2, 0, 1, 7, 0, 1,  
page numbers.

there are atleast 8 pages,

here can be more.

→ Calculate the no. of page faults. we use first added (pure demand paging)



In which we remove, put page in the same frame,  
not a single page



2<sup>nd</sup> Numerical

Reference string:- 1, 2, 3, 4, 1, 2, 5, 1, 2, 3, 4, 5

No. of frames = 5.

Calculate no. of page fault



9 page faults.

when no. of frames = 4



### 10 page faults

No. of frames should be decreased, when we increase frames,  
page faults  
fault

but it is happening opposite here,

∴ This is the problem.

FIFO shows,

Belady's anomaly — paradox

-ve thing  
drawbacks

### ③ Optimal Page Replacement algorithm.

It gives the minimal no. of page faults.  
because

Here, we replace the page that will not be used  
for the longest period of time, in the future.

and there is no,

Belady's anomaly. here



Solve, same numerical,

7, 0, 1, 2, 0, 3, 0, 4, 7, 3, 0, 3, 2, 1, 2, 0, 1, 7, 0, 1,



7 is  
not being  
used for  
the longer  
period of



No. of page faults = 9 (215) FIFO.

#### Main Problem

- ↳ Not implementable
- ↳ How would you know that which page will be needed when
- ↳ theoretical only.
- ↳ This algo is taken as a datum for comparison, to compare performance.



③ Least-recently used (LRU) page replacement algorithm -

99% chance to solve numerical in this -

In the next past, page did not use  
remove that page

→ Possible to implement  
→ does not show Belady's anomaly.

two ways,

using counters.

using stacks.

Solve Numerical



2 page faults



If a page is accessed, quite frequently,  
possibility that page will never be replaced.  
like 0 in this example.

### ① Counter-based implementation —

- Used as a logical clock.
- Page table will have extra column, "time-of-use" field.
  - integer type
  - not → dd-mm-yy X
- whenever, a CPU is accessing any page, counter is incremented.
- when a reference is made to the page, its time-of-use is set to counter. for a particular page,  
 $\text{time-of-use} = \text{counter}$
- The page with the lowest value of (time-of-use) field, will be replaced
- you have to make sure that this counter is not overflowing

### ② Stack based Implementation.

- We use data structure what looks like stack (but not actually stack)
- we maintain a stack of page no's that are being referenced.
- When a page is referenced, we remove it from stack and place it on the top of the stack



Two more algorithms left

21/4/2018

### INPUT-OUTPUT MANAGEMENT (Question <sup>Ques</sup> short note).

Computer will be performing processing & I/O.

There are some processes which are called I/O bound processes. (maximum time - I/O).

If there are such processes, then I/O <sup>management</sup> become more important.

- Kernel ~~part~~ of OS has an I/O subsection
- is part of a kernel which interacts with the input output devices.
- responsible for all I/O management.

#### advantages

- The rest of the kernel did not need to worry about I/O activities.



J/O subsystem uses device drivers.  
Device drivers are programs.

- They act as an interface b/w particular device and OS.
- They are software.

→ Device drivers are device specific.

→ printer has different.

→ camera has different.

Job of device driver is

→ Is to provide uniform interface to the J/O subsystem.

### Device controller

are implemented in hardware.

→ hardware part through which devices are connected.

→ to connect I/O device to your computer.

I/O devices are of different types.

Types -

① Storage devices  
(they are part of memory hierarchy)

External hard disk, USB drive.

② transmission devices

Ex - Modem

which allow your computer to send or receive data.

most common form of I/O devices.

### ③ Human-interface devices.

all users can provide input to the computer and output can provided to the user.

Input device → Keyboard. }  
Output device ⇒ Monitor } Most common.

Printer, touchpad, JoyStick, (touch screen.)  
both input & output.

speakers, earphones, scanners, cameras.

→ how smartphone screen works?

resistive type

capacitive type

(in our smartphones)

(capacitors).

### ④ Specialized device

they are <sup>not</sup> used by general users.

for specialist.

Ex- astronauts,

biologists.

MRI machines, CT scans.

light control computer of aircrafts.

## Hardware

what are different hardwares for I/O management

### ① Port

Most common - USB port.

Earlier - different type of port for different  
for printer, - .

② Bus.  
soft

Thro  
ave

③

II

① St

⑤

③

⑥

⑦

⑧

⑨

⑩

- ② Bus  
collection of wires.  
Through these buses, data and control information  
are flow.
- ③ Controller  
→ electronic logic unit  
controls the bus and the port.  
Ex - MUX, tri-state buffer.
- I/O ports contains four register.
- ① Status register  
↳ tells the current status of the device.  
(how many page no,  
left pages)
- ↳ read only register.
- ② Control register  
Processor write the command or control word.  
Ex: - how many pages to print, speed of  
printer etc.
- ③ Data in register  
When computer is taking input, data in register  
acts as buffer and is stored here.  
Processor reads from here.
- ④ Data-out register,  
Processor places data bit in the register.
- You may require subset of these registers.  
not all used.

For example → for keyboard  
data-out register is not used.

In many devices, status register and control register can  
be multiplexed. Similarly, data in and data out can  
be multiplexed.

## Modes of I/O -

### ① Polling.

worst possible technique.

→ processor keeps checking input register or other for data in loop to check available data,

→ called (busy-waiting)

### ② Interrupts

when any input is available, then interrupt occurs,  
otherwise, processor keeps busy in other work.

INTEL 8085 has 40 pins -

5 pins,

RST → 5.5

6.5

7.5

TRAP,

INTR,

I acknowledge INTERRUPT

### Software Interrupts

8

5.0 to 5.7

### ③ DMA

(Direct Memory Access.)

who is accessing the memory directly?

copying can be directly from input devices to RAM

or RAM to input device,

(in other, first place in register)  
(intermediate)

DMA

burst mode.

cycle stealing

read Morris Mano (is)

### Complementary devices :-

- (1) teletype = keyboard + display.  
In some computer, there is one device driver for One teletype.
- (2) plotter = scanner + printer.

### Virtual devices -

→ PDF printers. (Ex - in MS Word)

### Properties of I/O devices -

- character stream vs block  
character by character (dot matrix printer)  
blocks of data (or chunk)  
(hard disk)
- sequential vs random access  
(one by one  
in a particular order)  
(Punch cards,  
tapes drives)  
(any of the byte  
can be accessed)  
(Most of the pendrives)
- synchronous vs asynchronous  
(one byte send)  
if send  
then other byte.  
(if devices are fast, then  
use synchronous)  
(send at a time)  
(for slower  
devices)
- shareable vs dedicated.  
(monitor)  
Printer is non-shareable  
Sj (VT based OS)  
then dedicated (difficult to share)

→ speed

Vary widely. → processing amount of data varies.

Processing speed varies.

(\*) Scanners do very fast.

If we write-type, then take time.

→ read-only, write-only, read-write.

Some only input devices, some only output devices, others act as both.

Services provided by I/O subsystem —

① I/O scheduling

If two pages are downloading then which page download first?

② Buffering

Creation, maintenance of buffer is a job of I/O subsystem.

Buffer is temporary storage.

③ Spooling

MS Word, MS Excel,  
↓  
Print Point

Special type of  
buffer

↓  
spool.

then

~~Printer is a dedicated device,~~  
If data is sent to printer in interleaved fashion, ~~then the~~  
when one process has completed sending data, it will print.

Spooling is responsibility of I/O Subsystem to manage dedicated devices.  
↳ spooling more important than I/O scheduling.

④ Error handling

If you are trying to print, and there are no pages in

the printer, then message occurs,

So, it is responsibility of I/O subsystem.

Error handling.

⑤ I/O protection

Processor should not misuse I/O devices.

I/O subsystem handle this.

(You read all these stories in the book) (NO numerical)  
(short question can come)

5/4/2018

### Stack algorithm.

- We have studied three algorithms before.
  - They satisfy some sort of stack property.
  - They do not suffer from Bellady's anomaly.
- for all condition, always, all position time  
if you can show this property,

$$\text{Pages in memory for } n \text{ frames} \subseteq \text{pages in memory for } (n+1) \text{ frames.}$$

then that page replacement algorithm is stack algorithm.

### Test this for LRU algorithm

$n$  frames :  $n$  most recently accessed pages =  $S_1$ ,  
 $(n+1)$  frames ;  $n+1$  " " " " " =  $S_2$

$$S_1 \subseteq S_2 \quad (\\text{Clearly})$$

Hence LRU is stack algo

LRU does not suffer from Bellady's anomaly.

Also can be shown for Optimal page replacement.

### (4) LRU - Approximation Page Replacement Algorithms — (not exactly LRU)

principle is LRU.

There is one column of reference bit in page number  
when a new page loaded reference bit is cleared to 0  
reference bit = 1, when page is accessed (either  
for read/write)

Reference bit = 0, when pg is not accessed

(a) Additional Reference bit page replacement algorithm.

→ We use a 8-bit shift register for each page table entry.

After fixed interval, all register are shifted to right.

In MSB we fill reference bit →



LRU page = min. value of the shift register

There can be a tie,

To break the tie, we use FIFO.

(b) Second Chance page replacement algorithm

→ It works like FIFO.

→ If ref. bit == 0, then replace it.

however,

ref. bit == 1, then give it a second chance

↳ do not replace it

↳ ref. bit ← 0

Good thing about it,

→ If a page is frequently accessed, then that page will not be replaced

→ It is feasible or quite easy to implement

Queue is maintained for all pages, like FIFO

(not exactly FIFO)

### ③ Enhanced Second Chance PR A.

(Better)  
Performance

If a page has not modified, then no need to copy page into disk.

Pages which are written once are bad candidate for replacement

↳ concept,

Again it works like FIFO.

We use reference bit, modify bit]

∴ we basically have 4 classes of pages,

class → 00, 01, 10, 11  
not referenced but write      referenced but only read access

We check.

from  
front → rear

→ try to find out class of 00,  
first page we find with class 00, we

replace it.

→ if did not find,  
then search for 01

→ if did not find  
then search for 10

→ then 11

This concept known as enhanced second chance).

## 5.) Counting Based page replacement algorithms -

- Counter for each page
- Counter is initially cleared to 0
- Every time page is reference, counter is increased.

If page fault occur, then which page replace,

### 5a.) Least Frequently Used (LFU) page replacement algorithm



Replace page with minimum value of counter.

as it is referenced the least.

### 5b.) Most frequently used (MFU) - page replacement algorithm.

Replace page with maximum value of counter,

→ Concept behind this, is that, it thinks that which page has used most, will not be needed later

→ Page having least counter, may be <sup>just</sup> arrived & and needed more later,

Performance of both of them are bad.

Both are expensive as we count in both of them

## 5.) Counting Based page replacement algorithms

- Counter for each page
- Counter is initially cleared to 0
- Every time page is referenced, counter is increased

if page fault occurs, then which page replace,

### 5a) Least frequently used (LFU) page replacement algorithm



Replace page with minimum value of counter,

as it is referenced the least.

### 5b) Most frequently used (MFU) . page replacement algorithm.

Replace page with maximum value of counter,

→ Concept behind this is that, it thinks that which page has used most, will not be needed later

→ Page having least counter, may be <sup>just</sup> arrived & and needed more later.

Performance of both of them are bad.

Both are expensive as we counter in both of them.



## Numerical.

Reference String,

7, 0, 1, 2, 0, 3, 0, 4, 2, 3, 0, 3, 2, 1, 2, 0, 1, 7, 0, 1

Frames = 3,

Q Calculate no. of page faults.

FIFO  $\rightarrow$  15  
 optimal  $\rightarrow$  9  
 LRU  $\rightarrow$  12

Second chance  $\rightarrow$  11  
 LFU  $\rightarrow$  13  
 MFU  $\rightarrow$  14,

Now calculate for second chance algorithm.

Second Chance



base replacement, ] to implement virtual memory

frame allocation

Frame allocation: few no. of frames are allocated to a process to increase degree of multiprogramming. At least some minimum no. of pages be allocated to each process to avoid too many page faults.

9/4/2018

## Frame Allocation algorithms.

### ① Equal allocation

If we have  $m$  frames and  $n$  processes, then we allocate  $m/n$  frames to one process.  
Allocate equal frames to all process.

#### Problem:

Large process require more frame and small processes require less frames. Hence not good algo

### ② Proportional Allocation.

Here we allocate no. of frames to a process proportional to a size of its virtual memory (size of its address space)

Large process  $\rightarrow$  more frames.

## Local page replacement.

In case of page fault in page replacement, One page of process was replaced by another page of same process.

(Page replacement within the process)

## Global page replacement

In case of page fault, we bring a page from disk & replace any page of any process in memory.

One page of 1 process can replace other page of other process.

## Local

$\rightarrow$  easy to implement

$\rightarrow$  Process has more control over its execution

### Global

- throughput performance is better
- process will lose its autonomy
- more commonly used.

### Thrashing (Short note on this)

- Taking more time in servicing page fault, but actual processing time taken is less.
- It does not good ~~when this happens.~~

When this happens?

- If a process has less frames, page fault very frequently, spend time in page fault & no useful work happening in system & CPU utilization go down.

Another module, long term scheduler.

System performance is increasing, hence its increasing degree of multiprogramming.

So its loads some processes in memory. But frames increases even more and more page fault. Then its induces more processes & chain reaction occurs.

This is thrashing.



→ Threshing is not a good thing.

→ You have to try to avoid this.

→ Computer Engineers have found out two techniques to avoid threshing

### ① Working Set Model

→ Based on locality of reference.

→ A process is accessing a particular set of pages again at current point of time is working set.

Working set of a process  $i =$

→  $WS_i = \{ \text{pages referenced in the last } k \text{ accesses} \}$

(size of  $P_i \leq k$ )

→  $D = \leq |WS_i|$

$m = \text{no. of frames in the memory.}$

If  $D > m$ , then threshing.

① Should not try to increase degree of multiprogramming.  
② don't push processes, ③ try to swap out processes.

from memory

to avoid threshing

Maintaining & keeping track of working set of all processes is difficult. Hence another disadvantage

## ② Page Fault Frequency.



We need to ensure that page fault b/w upper or lower bound or below upper bound.

- If we decrease page fault below lower bound, then lots of frames to a process, degree of multiprogramming decreasing and CPU utilisation goes down.
- Above upper bound, thrashing occurs.
- Try to ensure no. of frames within the box,

Here ends, Virtual management.

two units left → By the end of this week  
(Syllabus complete)

10/4/2019

## STORAGE Management (Management of secondary storage devices).

RAM is volatile and disk is permanent. It is something different from Memory Management. Difference is size of RAM is much smaller than size of disk.

→ Hard disk are the most common forms of secondary storage. → Magneto electronic device.

- It is not a purely electronic device. → if it is, needs of capacitors to store, and will lose info when power turned off
- Operating system abstracts the physical properties of the disk.
- Operating System interprets the bits stored in the magnetic files.
- Files are the named collection.
  - collection of related information.
- Files exist only on hard disk, floppy drives
- File is the smallest allocation allotment of logical data.
- File can store both code and data.
- All files have their formats.
- OS imposes file system on the hard disk.
- Using a file system, it is easy to store files, retrieve files and search files.  
Two issues?
  - how the users see files? ← user perspective
  - how the files stored on disk? (break hard disk, mapped on the disk? no file physically)

Application Program (say Ms Word: ) Kavita.docx.



There is something called directory.

Now they are called folders (in windows)

There are three techniques for storing file in a disk.

→ 1) Contiguous Allocation

2) Linked Allocation,

3) Indexed Allocation.

First 500 bytes  
are at  
this  
location  
  
for e?  
or

next bytes  
are at  
this  
(some  
other  
location)

Here store diff. parts of  
file at diff. location  
and have a contents  
like in above.

### Free Space Management.

You have to maintain a linked list of free spaces.



→ R/W heads can be placed ~~anywhere~~ over any position of the disk.

→ these R/W heads and Arm assembly move together.

→ This is a circle, how will you stored the bits?

→ A track is a ~~imaginary~~ circle

→ All tracks have sectors.

→ We write bits in the sectors.

→ Set of all such tracks which can be accessed for one particular position of the arm assembly is called cylinder  
(that can be accessed by a particular position of R/W head)

$$= 2 \times \text{no. of platters.}$$

↗  
no. of bottom surface

Cylinders are logical entity, not physical.

→ More than 1000 cylinders in disk.

→ We have to define some parameters for performance

① Rotational Latency. (Mostly hardware independent)

It is time taken to reach R/W head on the top of required sector.

② Seek Time

To move the arm assembly so that R/W head reach the required cylinder or track. (Rectilinear motion)

→ H/W dependant (cannot change).

→ (It can be minimised by the operating system) using S/W  
(What are off addresses of hard disk?)

→ We tried to store the filing in contiguous sectors.

specified by sector no.

also track no.



honor 7x

when all tracks are full,  
then we move to another cylinder.

→ So, we also store,

Cylinder no.

Cylinders should be numbers from 0 to max.

inner - max  
outer - 0

\* 0<sup>th</sup> cylinder is at the periphery of the cylinder.

In numerical

There are two ways of storing bits:-

① Uniform bit density.

Distance is same b/w every bit.

② Non-uniform bit density.

↔ at corner

↔ at center.

There is something  
called (block)

↳ is the unit of memory which is read or write  
In one go, or in one operation.

Using software, we can play with seek time,  
how?

use can improve seek  
time of disk.

① Disk Scheduling,

Different → You have one queue to access different cylinders.

programs → Objective to minimize seek time.

to access People have developed some algorithms.

diff. cylinders. called disk scheduled algorithms.

## Disk Scheduling Algorithms

~~Hard disk~~  $\Rightarrow$  we receive request  
to perform input/output  
on following cylinder.

Ex- Queue = 98, 183, 37, 122, 14, 124, 65, 67

No. of cylinders = 200.

curr. pos of R/W head = 53.

We have to find seek time.

but we find  
no. of cylinders traversed by R/W heads

### ① FCFS

first come first service.

No. of cylinders

FCFS  $\rightarrow$  640 cylinders.

In exam,

first we have to draw trace diagram.

Trace of R/W head

### ② Shortest-seek-time-first (SSTF)

SSTF  $\rightarrow$  236 cylinders

SJF, optimal. not possible

This is possible to implement

### ③ Scan algo $\equiv$ Elevator algo.

Read write heads move from 0 to 199 then

$\overbrace{199 \text{ to } 0}$ ,  
whichever request it gets, it ~~immediately~~ executes it.

Total number of cylinders = 33

In this, we have to specify current direction.



#### ④ LOOK algo

Outward from me,

Look algorithm is smarter than Scan algorithm

#### ⑤ Circular-SCAN = C-SCAN

It will go to 199,

then return to 0

but in return journey it will not service

anyone.

It will look like  
it is solving the  
squares in  
circular  
manner,

#### ⑥ C-LOOK Algorithm

It is just like the CSLAN

but here it will not move to 199

but it will ~~not~~ move to 199  
only



## Disk Formatting

Manufacturer formats the disk and stores OS and other software info. 13/4/18

Hard Disk → main storage device.

Without formatting the disk, you can store anything in this.

### Formatting

↳ two types

(1) Physical Formatting ≡ low level formatting. (takes long time)

Whenever there is a new disk, you have to perform this,

After Formatting

In this, first of all you have to fill all the space (platters) with special data structures (filled in each of these sectors).

(Once you do this, your disk is ready to use.)

When you perform this, then only tracks, cylinders are created.

### Data Structure



Now the OS can store the files in the data area,

Manufacturer selling ~~the~~ Hard disk, first have to do physical formatting

## ② Logical formatting.

→ In logical formatting, you do not create sectors.

→ You just create a new file system.

(it formates all the data)

Block → that amount of data to and from from the disk in one operation.

OS allow some application program to perform raw I/O. (I/O without the help of file system)

This will make things faster.

Bad Block →

we used to use floppy disk.

of logically formatted, a disk, only a part of floppy disk was problem and most is fine

those areas by these blocks on which we can not perform read/write operation.  
on which sector has become defected.

DIR :- Total memory and bad blocks  
(LS) :- Linux

Some of the bad block can be detected by logical formatting

(That is all about storage management)

(read about file management)

short note on operation of disks

Practice

(Numericals)

Disk scheduling algs

## SYSTEM PROTECTION AND SECURITY

(Short notes)

### Protection and security

They are related  
but not synonyms.

#### Protection

From whom?

↳ from genuine and internal errors

(Some files have overwritten other  
or files.)

Process does not read OS  
model).

#### Security

↳ from intention external threads.

OS generally takes care of protection, do not provide security.

OS allows or <sup>cooperate with</sup> specialized programs which provides  
security.

Ex- Antivirus ..

#### Protection

→ Any hardware or software ~~object~~ resource  
is called object

→ Collection of / set of permissions. → domain

Process can be in one domain

Process P<sub>i</sub> in one domain can have only those permissions.

Access matrix

|    | O1  | O2  | O3 | O4 |
|----|-----|-----|----|----|
| D1 | (R) |     |    |    |
| D2 |     | RW. |    |    |
| D3 |     |     |    |    |

- Any process of type D1 can perform Read operation on the resources of type O1.
- Any process of type D2 can perform Read/Write operation on the resources of type O2

There are three types of access.

- ① Read Access (R)
- ② Write Access (W) can change the resource
- ③ Executable (E)

Let O3 is an executable file.  
Process in D3 can execute the file in O3.

|    | O1 | O2 | O3 | O4 |
|----|----|----|----|----|
| P1 | R  |    |    | R  |
| P2 |    | RW | R  | RW |
| P3 |    |    | E  |    |

- A process may require to change its domain.  
(gt is allowed.)

gt is also shown in adjacency Access matrix.

S stands for switch.

Any process in D2 can switch to domain D1.

|    | O1 | O2 | O3  | O4 | D1 | D2 | D3 |  |
|----|----|----|-----|----|----|----|----|--|
| D1 | R  |    |     | R  | .  |    |    |  |
| D2 |    | R  | RW* | S  | S  | S  |    |  |
| D3 | R  | E  |     | S  | S  |    |    |  |

\* Any process in type D2 can allow permission to other process to access resources of type O4.

### Copy permission

↳ can be of three types.

#### ① transfer

after allowing, itself will not be allowed to do access

#### ② copy limited

Let  $P_7$



$P_{10}$  can access resources

but cannot grant permission to other process

(further copy not allowed)

#### ③ copy unlimited

$P_7 \leftarrow P$

$P_7$   
 T  
 $P_{10}$   
 ↑  
 $P_{20}$   
 ↑  
 $P_{30}$ .

All information shown in the matrix

Called

Access matrix

Very large matrix

(But it is also very  
sparse one)

(Most of  
the cells  
are empty)

(Storing sparse matrix is always tricky)

(You are wasting a lot of memory)

Better way to store access matrix

↳ You can store it like this,

For each  
non-empty  
entry.

$\langle \text{domain, object, rights} \rangle$  (as triplets)

$\langle D_1, O_1, R \rangle$

$\langle D_2, O_2, R^w \rangle$

Still this will be a long one.

Other methods

① Access lists of objects  
For each object, we will be having access  
list. (same as column of access list but leaving blank  
spaces)

Ex:  $O_1 \Rightarrow \langle D_1, R \rangle, \langle D_3, R \rangle$

## ② Capability list of domains.

Here you have one capability list of each domain. (Equivalent to one row of access matrix)

$$D_3 \Rightarrow \langle D_1, R \rangle, \langle D_3, E \rangle, \langle D_1, S \rangle, \langle D_2, S \rangle$$

Just this, for system protection.

Go through this.

(Short note on this)

(In book, recursive (contd.))

## Security

We require to secure against external and intentional threats.

Threats → are proven techniques through which our computer can damage, which stealing the data.  
Nowadays, also include, (illegal access with malicious intent)

Most talked threat is

① Computer virus.

(is infamous threat)

What is a virus?

a computer program

Dangerous property → It is self replicating  
And it is infectious

(capability to infect more and more parts),

What it will do?

→ It will modify or destroy your file.

→ These computer viruses can't exist alone.

They are code fragments.

(they attach with different files)

Viruses are spread through Internet,

CDs, DD, floppy disks,  
Pen drives

Viruses are of different types

→ Macro viruses  
affect MS office files.

→ Stealth, (stage as a  
code of macro).

→ Multipartite

→

→

→

Read from  
book  
(shortnote)

Study of computer virus is known as computer  
virology.

②

Trojan horses

(Things look good from outside but <sup>very</sup> not from inside)  
that has harmless and attractive looks  
files. (look attractive)

but when we click, it affect our computer

(copies virus into our system)

They are generally used as virus carriers. They will  
transfer virus to system

### ⑤ Worm

→ are standalone programs/files (Do not need other programs)

Unlike Virus -

→ generally spread through local area network

→ worms can go through lab to another.

→ spread through networks  
infectious programs

In book, diagram



→ Worm wants to effect to target computer

→ Worm creates a hook

→ Hook sends requests for copying the worm,

→ Once worm reaches the system, it look for other on the n/w.

→ Each computer knows the address of other comp. in system

More threats are there,  
in the book

(read from book)

may not increase your marks

but increase your knowledge) ☺

Antivirus / Antimalware

try to delete worm/trojan horse

## Firewall

- are not meant to neutralise threats.
- to maintain the flow of information, what is downloading, what is uploading.
- for security
- stop you from accessing certain sites, or connecting to some LAN.

Firewall can do,  
both good or bad thing.

Ex) file, CV cannot sent through mail.

Encryption  
Digital Signature  
read  
from  
yourself ☺

## Ends