Operating Systems Practical Session 10, Memory Management continues.

Slides:



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

4.4 Page replacement algorithms
Virtual Memory (Chapter 4.3)
Chapter 101 The LRU Policy Replaces the page that has not been referenced for the longest time in the past By the principle of locality, this would be.
Chapter 3.3 : OS Policies for Virtual Memory
CS 333 Introduction to Operating Systems Class 14 – Page Replacement
Virtual Memory 3 Fred Kuhns
Chapter 3 Memory Management
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
Scribe for 7 th April 2014 Page Replacement Algorithms Payal Priyadarshini 11CS30023.
Chapter 4 Memory Management Page Replacement 补充:什么叫页面抖动?
MODERN OPERATING SYSTEMS Third Edition ANDREW S. TANENBAUM Chapter 3 Memory Management Tanenbaum, Modern Operating Systems 3 e, (c) 2008 Prentice-Hall,
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.
Module 9: Virtual Memory
Module 10: Virtual Memory Background Demand Paging Performance of Demand Paging Page Replacement Page-Replacement Algorithms Allocation of Frames Thrashing.
Virtual Memory Background Demand Paging Performance of Demand Paging
Virtual Memory Introduction to Operating Systems: Module 9.
Memory management, part 2: outline  Page replacement algorithms  Modeling PR algorithms o Working-set model and algorithms  Virtual memory implementation.
1 Memory Management Managing memory hierarchies. 2 Memory Management Ideally programmers want memory that is –large –fast –non volatile –transparent Memory.
Memory management, part 2: outline
CS 342 – Operating Systems Spring 2003 © Ibrahim Korpeoglu Bilkent University1 Memory Management – 4 Page Replacement Algorithms CS 342 – Operating Systems.
Memory Management Virtual Memory Page replacement algorithms
Instructor: Umar KalimNUST Institute of Information Technology Operating Systems Revisiting Virtual Memory.
CS 333 Introduction to Operating Systems Class 14 – Page Replacement Jonathan Walpole Computer Science Portland State University.
Virtual Memory Management B.Ramamurthy. Paging (2) The relation between virtual addresses and physical memory addres- ses given by page table.
1 Virtual Memory Management B.Ramamurthy Chapter 10.
CS 333 Introduction to Operating Systems Class 14 – Page Replacement
OS Spring’04 Virtual Memory: Page Replacement Operating Systems Spring 2004.
Chapter 4 Memory Management 4.1 Basic memory management 4.2 Swapping
Demand Paging Virtual memory = indirect addressing + demand paging –Without demand paging, indirect addressing by itself is valuable because it reduces.
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.
CSS430 Virtual Memory Textbook Ch9
Memory Management ◦ Operating Systems ◦ CS550. Paging and Segmentation  Non-contiguous memory allocation  Fragmentation is a serious problem with contiguous.
O RERATıNG S YSTEM LESSON 10 MEMORY MANAGEMENT II 1.
ICS 145B -- L. Bic1 Project: Page Replacement Algorithms Textbook: pages ICS 145B L. Bic.
Memory Management Page replacement algorithms, segmentation Tanenbaum, ch. 3 p Silberschatz, ch. 8, 9 p
Page 19/17/2015 CSE 30341: Operating Systems Principles Optimal Algorithm  Replace page that will not be used for longest period of time  Used for measuring.
Page Replacement Algorithms Memory Management. Optimal Page Replacement ▪The label for each page in memory is labeled with the number of instructions.
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.
Silberschatz, Galvin and Gagne ©2009 Operating System Concepts – 8 th Edition Virtual Memory.
Operating Systems CMPSC 473 Virtual Memory Management (3) November – Lecture 20 Instructor: Bhuvan Urgaonkar.
Virtual Memory Virtual Memory is created to solve difficult memory management problems Data fragmentation in physical memory: Reuses blocks of memory.
Virtual Memory. Background Virtual memory is a technique that allows execution of processes that may not be completely in the physical memory. Virtual.
Virtual Memory The memory space of a process is normally divided into blocks that are either pages or segments. Virtual memory management takes.
CS307 Operating Systems Virtual Memory Fan Wu Department of Computer Science and Engineering Shanghai Jiao Tong University Spring 2012.
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.
NETW3005 Virtual Memory. Reading For this lecture, you should have read Chapter 9 (Sections 1-7). NETW3005 (Operating Systems) Lecture 08 - Virtual Memory2.
1 Page Replacement Algorithms. 2 Virtual Memory Management Fundamental issues : A Recap Key concept: Demand paging  Load pages into memory only when.
10.1 Chapter 10: Virtual Memory Background Demand Paging Process Creation Page Replacement Allocation of Frames Thrashing Operating System Examples.
Silberschatz, Galvin and Gagne ©2011 Operating System Concepts Essentials – 8 th Edition Chapter 9: Virtual Memory.
Chapter 9: Virtual Memory. 9.2 Silberschatz, Galvin and Gagne ©2005 Operating System Concepts Background Virtual memory – separation of user logical memory.
PAGE REPLACEMNT ALGORITHMS FUNDAMENTAL OF ALGORITHMS.
COS 318: Operating Systems Virtual Memory Paging.
CS 333 Introduction to Operating Systems Class 14 – Page Replacement
ITEC 202 Operating Systems
Day 22 Virtual Memory.
Demand Paging Reference Reference on UNIX memory management
Demand Paging Reference Reference on UNIX memory management
Practical Session 8, Memory Management 2
Lecture 39 Syed Mansoor Sarwar
Demand Paged Virtual Memory
Practical Session 9, Memory Management continues
Practical Session 8, Memory Management 2
Operating Systems CMPSC 473
Chapter 9: Virtual Memory CSS503 Systems Programming
Practical Session 9, Memory Management continues
Practical Session 8, Memory Management 2
Presentation transcript:

Operating Systems Practical Session 10, Memory Management continues

PAGE REPLACEMENT ALGORITHMS Quick recap 2

Optimal Assumes the memory manager knows the “future” sequence of page references optimal The optimal algorithm: page out the page that will be used latest Problem Problem: the manager doesn’t know the future sequence of requests! 3

FIFO/FIFO Second-chance FIFO – First page In will be the First page taken Out – Problem – Problem: we may be removing a page that will be constantly in use: Assume memory size of 2 frames, and take the following sequence of page requests: 1,2,3,1,2,3,1,2,3,1… FIFO second-chance: reference bit – Add a reference bit that will be turned on whenever the page is accessed reference bit – When a “swap out” is needed: go over the pages from the oldest to newest and if the page’s reference bit is on, clear it; otherwise remove the page. Both FIFO and FIFO second-chance can be implemented as a circular queue: the “clock algorithm”. 4

2 nd chance FIFO (clock) 5

Least Recently Used (LRU) Least Recently Used If we need to remove a page, then the Least Recently Used page will be chosen  Throw out the page that has been unused for longest time period Problem Problem: have to keep “history” and remember when a page was referenced  Counter for each page, updated on every memory reference! LRU can be approximated: – Shift counter NFU o Updating every page reference can be too often! => shift only every clock tick (modified version of NFU, also known as aging) – Use n 2 bit matrix o Hardware LRU algorithm, where n is the number of page frames 6

Modified NFU (Aging) Clock tick 0Clock tick 1 Clock tick 2 Clock tick 3Clock tick 4 Page references Pages

Hardware LRU algorithm (bit tables) Reference string is: 0,1,2,3,2,1,0,3,2,

Quick recap: global vs. local The scope of the page replacement policy can be: – Local: – Local: choose a page to remove only among the pages of the process that caused the page fault – Global: – Global: choose a page to remove from all pages in main memory, independent of the process Global policies are more efficient – Dynamically allocate page frames among the runnable processes. This is useful when the size of a WS is dynamically changing. Local policies may have variable allocation of pages per process (“working set”) 9

Local vs. global algorithms Adding page A6 Adding page A6: 10 Last reference time Local policy Global policy

Question 1 each entry is one word page size of 200 words physical memory of 3 frames Assume that the array a is stored consecutively: a[0,0], a[0,1]... and also assume that the size of each entry is one word. The virtual memory has a page size of 200 words. The program code is in address in the virtual memory. a[0][0] is at virtual address 200. We run both programs on a machine with physical memory of 3 frames. Where the code of the program is in the 1'st frame and the other two are empty. If the page replacement algorithm is LRU, how many page faults will there be in each of the programs? Explain. Program A: int i, j, a[100][100]; for (i = 0; i < 100; i++) { for (j = 0; j < 100; j++) { a[i][j] = 0; } Program B: int i, j, a[100][100]; for (j = 0; j < 100; j++) { for (i = 0; i < 100; i++) { a[i][j] = 0; } 11

Question 1 Array a is stored in a[0][0],a[0][1]... in virtual pages The reference string (specifying only possible page faults) of program A will be: 0,1,0,2,0,  We'll get a total of 50 page faults. The reference string of B will be: 0,1,0,2...,0,50,0,1,0,2....0,50,..  Leading to a total of 5000 page faults. Note that due to the use of the LRU algorithm, page 0 will be in memory at all times. 12

Question 2 Consider the following page reference string: 7,0,1,2,0,3, 0,4,2,3,0,3,2,1,2,0,1,7,0,1 Assuming that the memory size is 3 frames, how many page faults would occur for the following algorithms: 1.FIFO 2.LRU 3.Optimal Note: Remember that all frames are initially empty, so your first unique pages will all cost one fault each. 13

Question 2: FIFO page faults 14

Question 2: LRU 12 page faults

Question 2: Optimal 9 page faults

Question 3 – 2001 a נתונה סדרת דרישות הדפים הבאה : 1,2,3,4,2,1,5,6,2,1,2,3,7,6,3,2 1. אם משתמשים ב -LRU, כתוב את ה -distance string עבור הסדרה הנתונה. חשב מתוך ה - distance string כמה page-faults יהיו עבור זיכרון פיזי בן 4 דפים. האם כדאי להגדיל את הזיכרון הפיזי ל -5 דפים במקרה זה ? 2. עבור אלג ' FIFO וזיכרון פיסי בן 4 דפים, חשב מספר ה page faults. 17

Question 3 – 2001 a Page faultppppppppp distance∞∞∞∞34∞∞4426∞

Question 3 – 2001 a בשביל לחשב את מספר ה -page-faults כשמשתמשים בזיכרון פיזי בן 5 דפים, נצטרך לסכום על כל המרחקים הגדולים מ -5: ישנם 8 כאלו. מנענו page-fault אחד. 19

Question 3 – 2001 a Page faultpppppppppppp

Question 4 Consider the following virtual page reference string: 0, 1, 2, 3, 0, 0, 1, 2, 3 Which page references will cause a page fault when a basic clock replacement algorithm is used? Assume that there are 3 page frames and that the memory is initially empty. Show all page faults (including frame loading). 21

Question 4 *000*3333*22 *111*0 00*3 *2222*111 Page faultpf Where: * represents the placement of the clock’s “hand” before the request pf represents a page fault 22