COS 318: Operating Systems Virtual Memory Paging.

Slides:



Advertisements
Similar presentations
9.4 Page Replacement What if there is no free frame?
Advertisements

4.4 Page replacement algorithms
Chapter 3.3 : OS Policies for Virtual Memory
CS 333 Introduction to Operating Systems Class 14 – Page Replacement
Background Virtual memory – separation of user logical memory from physical memory. Only part of the program needs to be in memory for execution. Logical.
Page Replacement Algorithms
Chapter 4 Memory Management Page Replacement 补充:什么叫页面抖动?
Virtual Memory. 2 What is virtual memory? Each process has illusion of large address space –2 32 for 32-bit addressing However, physical memory is much.
Caching and Virtual Memory. Main Points Cache concept – Hardware vs. software caches When caches work and when they don’t – Spatial/temporal locality.
1 Virtual Memory Management B.Ramamurthy. 2 Demand Paging Main memory LAS 0 LAS 1 LAS 2 (Physical Address Space -PAS) LAS - Logical Address.
Silberschatz, Galvin and Gagne  Operating System Concepts Chapter 10: Virtual Memory Background Demand Paging Process Creation Page Replacement.
Virtual Memory Introduction to Operating Systems: Module 9.
Lecture 34: Chapter 5 Today’s topic –Virtual Memories 1.
1 Virtual Memory vs. Physical Memory So far, all of a job’s virtual address space must be in physical memory However, many parts of programs are never.
Paging Algorithms Vivek Pai / Kai Li Princeton University.
Translation Buffers (TLB’s)
Memory Management Virtual Memory Page replacement algorithms
CS 333 Introduction to Operating Systems Class 14 – Page Replacement Jonathan Walpole Computer Science Portland State University.
Virtual Memory CSCI 444/544 Operating Systems Fall 2008.
CS 333 Introduction to Operating Systems Class 14 – Page Replacement
Page Replacement Algorithms
03/29/2004CSCI 315 Operating Systems Design1 Page Replacement Algorithms (Virtual Memory)
CS 333 Introduction to Operating Systems Class 14 – Page Replacement Jonathan Walpole Computer Science Portland State University.
CSC 322 Operating Systems Concepts Lecture - 15: by Ahmed Mumtaz Mustehsan Special Thanks To: Tanenbaum, Modern Operating Systems 3 e, (c) 2008 Prentice-Hall,
Operating Systems ECE344 Ding Yuan Page Replacement Lecture 9: Page Replacement.
Virtual Memory.
Caching and Virtual Memory. Main Points Cache concept – Hardware vs. software caches When caches work and when they don’t – Spatial/temporal locality.
O RERATıNG S YSTEM LESSON 10 MEMORY MANAGEMENT II 1.
Memory Management Page replacement algorithms, segmentation Tanenbaum, ch. 3 p Silberschatz, ch. 8, 9 p
Lecture Topics: 11/17 Page tables TLBs Virtual memory flat page tables
1 First-in, First-out Remove the oldest page Determine the age based on the loading time, not on the time being referenced Old pages may be heavily used.
CPS110: Page replacement Landon Cox. Replacement  Think of physical memory as a cache  What happens on a cache miss?  Page fault  Must decide what.
Silberschatz, Galvin and Gagne ©2013 Operating System Concepts Essentials – 9 th Edition Chapter 9: Virtual-Memory Management.
Demand Paging Reference Reference on UNIX memory management
Virtual Memory Questions answered in this lecture: How to run process when not enough physical memory? When should a page be moved from disk to memory?
Virtual Memory The address used by a programmer will be called a virtual address or logical address. An address in main memory is called a physical address.
10.1 Chapter 10: Virtual Memory Background Demand Paging Process Creation Page Replacement Allocation of Frames Thrashing Operating System Examples.
Operating Systems ECE344 Ding Yuan Page Replacement Lecture 9: Page Replacement.
1 Contents Memory types & memory hierarchy Virtual memory (VM) Page replacement algorithms in case of VM.
Virtual Memory. 2 Last Week Memory Management Increase degree of multiprogramming –Entire process needs to fit into memory Dynamic Linking and Loading.
Chapter 9: Virtual Memory. 9.2 Silberschatz, Galvin and Gagne ©2005 Operating System Concepts Background Virtual memory – separation of user logical memory.
CS 333 Introduction to Operating Systems Class 14 – Page Replacement
Virtual Memory What if program is bigger than available memory?
Logistics Homework 5 will be out this evening, due 3:09pm 4/14
CS703 - Advanced Operating Systems
Demand Paging Reference Reference on UNIX memory management
Instructor: Junfeng Yang
CSE 120 Principles of Operating
Module 9: Virtual Memory
Demand Paging Reference Reference on UNIX memory management
Chapter 9: Virtual-Memory Management
5: Virtual Memory Background Demand Paging
Demand Paged Virtual Memory
Chapter 4: Memory Management
Translation Buffers (TLB’s)
Contents Memory types & memory hierarchy Virtual memory (VM)
Practical Session 8, Memory Management 2
Translation Buffers (TLB’s)
Page Replacement FIFO, LIFO, LRU, NUR, Second chance
Operating Systems CMPSC 473
Page Allocation and Replacement
Lecture 9: Caching and Demand-Paged Virtual Memory
CSE 153 Design of Operating Systems Winter 19
Translation Buffers (TLBs)
Module 9: Virtual Memory
Chapter 9: Virtual Memory CSS503 Systems Programming
Review What are the advantages/disadvantages of pages versus segments?
Practical Session 9, Memory Management continues
Virtual Memory.
Virtual Memory 1 1.
Presentation transcript:

COS 318: Operating Systems Virtual Memory Paging

2 Today’s Topics  Paging mechanism  Page replacement algorithms

3 Virtual Memory Paging  Simple world Load entire process into memory. Run it. Exit.  Problems Slow (especially with big processes) Wasteful of space (doesn’t use all of its memory all the time) Reduces number of processes ready to run at a time  Solution Demand paging: only bring in pages actually used Paging: only keep frequently used pages in memory  Mechanism: Programs refer to addresses in virtual address space Virtual memory maps some to physical pages in memory, some to disk

4 VM Paging Steps Steps  Memory reference (may cause a TLB miss)  TLB entry invalid triggers a page fault and VM handler takes over  Move page from disk to memory  Update TLB entry w/ pp#, valid bit  Restart the instruction  Memory reference again. subl $20 %esp movl 8(%esp), %eax. vp# v i v v TLB pp# dp# pp# v VM system pp#v Reference fault Restart VP# = virtual page no. PP# = physical page no.

5 Virtual Memory Issues  How to switch a process after a fault? Need to save state and resume Is it the same as an interrupt?  What to page in? Just the faulting page or more? Want to know the future…  What to replace? Memory is a software-managed cache on disk Caches always too small, which page to replace? Want to know the future...

6 How Does Page Fault Work?  User program should not be aware of the page fault  Fault may have happened in the middle of the instruction!  Can we skip the faulting instruction?  Is a faulting instruction always restartable?. subl $20 %esp movl 8(%esp), %eax. VM fault handler() { Save states. iret }

7 What to Page In?  Page in the faulting page Simplest, but each “page in” has substantial overhead  Page in more pages each time May reduce page faults if the additional pages are used Waste space and time if they are not used Real systems do some kind of prefetching  Applications control what to page in Some systems support for user-controlled prefetching But, many applications do not always know

8 VM Page Replacement  Things are not always available when you want them It is possible that no unused page frame is available VM needs to do page replacement  On a page fault If there is an unused frame, get it If no unused page frame available, Find a used page frame If it has been modified, write it to disk Invalidate its current PTE and TLB entry Load the new page from disk Update the faulting PTE and remove its TLB entry Restart the faulting instruction  General data structures A list of unused page frames A table to map page frames to PID and virtual pages, why? Page Replacement

9 Which “Used” Page Frame To Replace?  Random  Optimal or MIN algorithm  NRU (Not Recently Used)  FIFO (First-In-First-Out)  FIFO with second chance  Clock  LRU (Least Recently Used)  NFU (Not Frequently Used)  Aging (approximate LRU)  Working Set  WSClock

10 Optimal or MIN  Algorithm: Replace the page that won’t be used for the longest time (Know all references in the future)  Example Reference string: 4 page frames 6 faults  Pros Optimal solution and can be used as an off-line analysis method  Cons No on-line implementation

11 Revisit TLB and Page Table  Important bits for paging Reference: Set when referencing a location in the page Modify: Set when writing to a location in the page offset Virtual address PPage#... PPage#... PPage# … offset VPage # TLB Hit Miss Page Table VPage#

12 Not Recently Used (NRU)  Algorithm Randomly pick a page from lowest-numbered non-empty class below 1.Not referenced and not modified 2.Not referenced and modified (huh?) 3.Referenced and not modified 4.Referenced and modified Clear reference bits periodically (e.g. at clock interrupts)  Example 4 page frames Reference string 8 page faults  Pros Implementable  Cons Require scanning through reference bits and modified bits

13 First-In-First-Out (FIFO)  Algorithm Throw out the oldest page  Example 4 page frames Reference string 10 page faults  Pros Low-overhead implementation  Cons May replace the heavily used pages Page out Recently loaded

14 More Frames  Fewer Page Faults?  Consider the following with 4 page frames Algorithm: FIFO replacement Reference string: 10 page faults  Same string with 3 page frames Algorithm: FIFO replacement Reference string: 9 page faults!  This is so called “Belady’s anomaly” (Belady, Nelson, Shedler 1969)

15 FIFO with 2nd Chance  Algorithm Check the reference-bit of the oldest page If it is 0, then replace it If it is 1, clear the referent-bit, put it to the end of the list (as if it had just been loaded), and continue searching  Example 4 page frames Reference string: 8 page faults  Pros Simple to implement  Cons The worst case may take a long time (moving pages around on the list) Recently loaded Page out If ref bit =

16 Clock  FIFO clock algorithm Hand points to the oldest page On a page fault, follow the hand to inspect pages  Second chance If the reference bit is 0, use it for replacement, new page replaces it, advance the hand If the reference bit is 1, set it to 0 and advance the hand Oldest page

17 Least Recently Used  Algorithm Replace page that hasn’t been used for the longest time Order the pages by time of reference Timestamp for each referenced page  Example 4 page frames Reference string: 8 page faults  Pros Good to approximate MIN  Cons Expensive: maintain list of pages by reference, update on every reference Recently loaded Least Recently used

18 Approximations of LRU  Use CPU ticks For each memory reference, store the ticks in its PTE Find the page with minimal ticks value to replace  Use a smaller counter Most recently used Least recently used N categories Pages in order of last reference LRU Crude LRU 2 categories Pages referenced since the last page fault Pages not referenced since the last page fault 8-bit count 256 categories

19 Aging: Not Frequently Used (NFU)  Algorithm Shift reference bits into counters at every clock interrupt Pick the page with the smallest counter to replace  Old example 4 page frames Reference string: 8 page faults  Main difference between NFU and LRU? NFU can’t distinguish LRU within a clock interrupt period NFU has a short history (counter length)  How many bits are enough? In practice 8 bits are quite good

20 Program Behavior (Denning 1968)  80/20 rule > 80% memory references are within <20% of memory space > 80% memory references are made by < 20% of code  Spatial locality Neighbors are likely to be accessed  Temporal locality The same page is likely to be accessed again in the near future # Pages in memory # Page faults

21 Working Set  Main idea (Denning 1968, 1970) Define a working set as the set of pages in the most recent K page references Keep the working set in memory will reduce page faults significantly  Approximate working set The set of pages of a process used in the last T seconds  An algorithm On a page fault, scan through all pages of the process If the reference bit is 1, record the current time for the page If the reference bit is 0, check the “time of last use,” If the page has not been used within T, replace the page Otherwise, go to the next Add the faulting page to the working set

22 WSClock  Follow the clock hand  If the reference bit is 1 Set reference bit to 0 Set the current time for the page Advance the clock hand  If the reference bit is 0, check “time of last use” If the page has been used within , go to the next If the page has not been used within  and modify bit is 1 Schedule the page for page out and go to the next If the page has not been used within  and modify bit is 0 Replace this page

23 Replacement Algorithms  The algorithms Random Optimal or MIN algorithm NRU (Not Recently Used) FIFO (First-In-First-Out) FIFO with second chance Clock LRU (Least Recently Used) NFU (Not Frequently Used) Aging (approximate LRU) Working Set WSClock  Which are your top two?

24 Summary  VM paging Page fault handler What to page in What to page out  LRU is good but difficult to implement  Clock (FIFO with 2 nd hand) is considered a good practical solution  Working set concept is important  Aging and WSClock do quite well and are implementable