You are on page 1of 28

Virtual Memory

Topics
• The benefits of a virtual memory system
• The concepts of
– demand paging
– page-replacement algorithms
– and allocation of physical page frames
Background
• Till now the memory management
concern is to place as many process in the
main memory so that property of
multiprogramming is satisfied optimally.
• At the same time it limits the size of the
program that size of the program can’t
ever be larger than physical memory.
Virtual memory
– Virtual memory allows execution of such
processes which may not be completely reside in
main memory.
– Only part of the program needs to be in memory
for execution
– Logical address space can be much larger than
physical address space
– Allows address spaces to be shared by several
processes
– Virtual memory implements segmentation paging
to place pages from secondary storage to main
memory.
Virtual Memory That is
Larger Than Physical Memory
Transfer of a Paged Memory to
Contiguous Disk Space
Demand Paging for Virtual Memory
• Bring a page into memory ONLY when it is
needed
– Less I/O needed
– Less memory needed
– Faster response
– More users supported
• Check a page table entry when a page is needed
– not-in-memory  bring to memory

Valid-Invalid Bit
With each page table entry a valid–invalid bit is associated
(v  in-memory, i  not-in-memory)
• Initially valid–invalid bit is set to i on all entries
• Not found-page miss/cache miss/memory miss/page fault
• Found in memory page hit/ memory Frame #hit/cachevalid-invalid
hit bit

v
v
v
v
i

….

i
i
page table
Page Table When Some Pages
Are Not in Main Memory
Handling a Page Fault
1.Get an empty physical frame
2.Swap page from the disk into frame
3.Reset the page table
Set validation bit = v
4.Restart the instruction that caused the
page fault
Steps in Handling a Page Fault
Performance of Demand Paging

• Page Fault Rate 0  p  1.0


– if p = 0, no page faults
– if p = 1, every reference is a fault
• Effective Access Time (EAT)
EAT = (1 – p) x memory access
+ p (page fault overhead
+ swap page out
+ swap page in
+ restart overhead
)
Demand paging when there is no free
frame?
• Page replacement – find some page in memory,
but not really in use, swap it out
– Algorithm
– Performance – want an algorithm which will
result in minimum number of page faults

• Same page may be brought into memory several


times
Page Replacement
Basic Page Replacement
1. Find the location of the desired page on disk

2. Find a free frame:


- If there is a free frame, use it
- If there is no free frame, use a page replacement
algorithm to select a victim frame
3. Swap out: Use modify (dirty) bit to reduce overhead of
page transfers – only modified pages are written to disk
4. Bring the desired page into the free frame.
Update the page and frame tables
Expected behavior: # of Page Faults vs.
# of Physical Frames
Page Replacement
• 1. FIFO(first in first out), LRU,Optimal-
• Memory-2 pages(5,4),
• 3 rd page
• 4th page
• 5 th page
First-In-First-Out (FIFO) Algorithm
• Reference string: 1, 2, 3, 4, 1, 2, 5, 1, 2, 3, 4, 5
• 3 frames (3 pages can be in memory at a time per
process). Maintain a queue and select based on FIFO
order.
1 1 4 5
2 2 1 3 9 page faults
3 3 2 4

• 4 frames
1 1 5 4
2 2 1 5 10 page faults
3 3 2

4 4 3
• Belady’s Anomaly: more frames  more page faults
FIFO Page Replacement
FIFO Illustrating Belady’s Anomaly
Optimal Algorithm

• Replace page that will not be used for longest period of time
• 4 frames example
1, 2, 3, 4, 1, 2, 5, 1, 2, 3, 4, 5
1 4
2 6 page faults
3

4 5

• How do you know this?


• Used for measuring how well your algorithm performs
Optimal Page Replacement
Least Recently Used (LRU)
Algorithm
• Reference string: 1, 2, 3, 4, 1, 2, 5, 1, 2, 3, 4, 5

1 1 1 1 5
2 2 2 2 2
3 5 5 4 4
4 4 3 3 3

• Counter implementation
– Every page entry has a counter; every time page is referenced
through this entry, copy the clock into the counter
– When a page needs to be changed, look at the counters to
determine which are to change
LRU Page Replacement
Issues with Page Allocation and
Replacement
• Initial Allocation. Each process needs minimum
number of pages
– Two schemes: Fixed allocation vs. priority
allocation
• Where to find frames
• Global replacement – find a frame from all
processes.
• Local replacement – find only from its own
allocated frames
Thrashing
• If a process does not have “enough” pages, the
page-fault rate is very high. This leads to:
– low CPU utilization
– operating system thinks that it needs to
increase the degree of multiprogramming
– another process added to the system
• Thrashing  a process is busy swapping pages in
and out
Thrashing (Cont.)
Relationship of Demand Paging
and Thrashing
• Multiprogramming?

• Why does demand paging work?


Locality model
– Process migrates from one locality to another
– Localities may overlap
– Need a minimum working set to be effective
• Why does thrashing occur?
 working-sets > total memory size

You might also like