1 Memory Management (a). 2 Background  Program must be brought into memory and placed within a process for it to be run.  Input queue – collection of.

Slides:



Advertisements
Similar presentations
Part IV: Memory Management
Advertisements

Memory Management Chapter 7.
Fixed/Variable Partitioning
CS 311 – Lecture 21 Outline Memory management in UNIX
Modified from Silberschatz, Galvin and Gagne Lecture 16 Chapter 8: Main Memory.
Module 3.0: Memory Management
03/09/2007CSCI 315 Operating Systems Design1 Memory Management Notice: The slides for this lecture have been largely based on those accompanying the textbook.
Silberschatz, Galvin and Gagne ©2009 Operating System Concepts – 8 th Edition, Chapter 8: Main Memory.
Memory Management Chapter 5.
Memory Management Five Requirements for Memory Management to satisfy: –Relocation Users generally don’t know where they will be placed in main memory May.
A. Frank - P. Weisberg Operating Systems Real Memory Management.
Operating System Concepts
Silberschatz, Galvin and Gagne  Operating System Concepts Multistep Processing of a User Program User programs go through several steps before.
03/05/2008CSCI 315 Operating Systems Design1 Memory Management Notice: The slides for this lecture have been largely based on those accompanying the textbook.
CSCI 315 Operating Systems Design
Chapter 8: Main Memory.
Chap 8 Memory Management. Background Program must be brought into memory and placed within a process for it to be run Input queue – collection of processes.
Silberschatz, Galvin and Gagne  Operating System Concepts Chapter 9: Memory Management Background Swapping Contiguous Allocation Paging Segmentation.
Silberschatz, Galvin and Gagne  Operating System Concepts Chapter 9: Memory Management Background Swapping Contiguous Allocation Paging Segmentation.
Memory Management -1 Background Swapping Memory Management Schemes
Copyright © 2006 by The McGraw-Hill Companies, Inc. All rights reserved. McGraw-Hill Technology Education Lecture 8 Operating Systems.
Computer Architecture and Operating Systems CS 3230: Operating System Section Lecture OS-7 Memory Management (1) Department of Computer Science and Software.
Silberschatz, Galvin and Gagne ©2013 Operating System Concepts – 9 th Edition Chapter 8: Main Memory.
Swapping and Contiguous Memory Allocation. Multistep Processing of a User Program User programs go through several steps before being run. Program components.
Lecture 13 L.Mohammad R.Alkafagee1.  The concept of a logical address space that is bound to a separate physical address space is central to proper memory.
Memory Management. Process must be loaded into memory before being executed. Memory needs to be allocated to ensure a reasonable supply of ready processes.
8.1 Silberschatz, Galvin and Gagne ©2005 Operating System Principles Chapter 8: Memory-Management Strategies Objectives To provide a detailed description.
CGS 3763 Operating Systems Concepts Spring 2013 Dan C. Marinescu Office: HEC 304 Office hours: M-Wd 11: :30 AM.
Chapter 4 Storage Management (Memory Management).
Silberschatz, Galvin and Gagne  Operating System Concepts Chapter 9: Memory Management Background Swapping Contiguous Allocation Paging Segmentation.
Background Program must be brought into memory and placed within a process for it to be run. Input queue – collection of processes on the disk that are.
Silberschatz, Galvin and Gagne ©2009 Operating System Concepts – 8 th Edition, Chapter 8: Main Memory.
Silberschatz and Galvin  Operating System Concepts Module 8: Memory Management Background Logical versus Physical Address Space Swapping Contiguous.
Memory. Chapter 8: Memory Management Background Swapping Contiguous Memory Allocation Paging Structure of the Page Table Segmentation.
1 Memory Management Chapter 7. 2 Memory Management Subdividing memory to accommodate multiple processes Memory needs to be allocated to ensure a reasonable.
Memory Management. Introduction To improve both the utilization of the CPU and the speed of its response to users, the computer must keep several processes.
1 Memory Management Chapter 7. 2 Memory Management Subdividing memory to accommodate multiple processes Memory needs to be allocated to ensure a reasonable.
Main Memory. Chapter 8: Memory Management Background Swapping Contiguous Memory Allocation Paging Structure of the Page Table Segmentation Example: The.
Basic Memory Management 1. Readings r Silbershatz et al: chapters
CS6502 Operating Systems - Dr. J. Garrido Memory Management – Part 1 Class Will Start Momentarily… Lecture 8b CS6502 Operating Systems Dr. Jose M. Garrido.
Silberschatz, Galvin and Gagne  2002 Modified for CSCI 399, Royden, Operating System Concepts Operating Systems Lecture 31 Memory Management.
Memory Management. Background Memory consists of a large array of words or bytes, each with its own address. The CPU fetches instructions from memory.
Memory Management Program must be brought (from disk) into memory and placed within a process for it to be run Main memory and registers are only storage.
Background Program must be brought into memory and placed within a process for it to be run. Input queue – collection of processes on the disk that are.
Silberschatz, Galvin and Gagne ©2009 Operating System Concepts – 8 th Edition Chapter 8: Main Memory.
Memory Management 1. Outline Background Logical versus Physical Address Space Swapping Contiguous Allocation Paging Segmentation 2.
Silberschatz, Galvin and Gagne ©2009 Operating System Concepts – 8 th Edition, Chapter 8: Main Memory.
Chapter 8: Memory Management. 8.2 Silberschatz, Galvin and Gagne ©2005 Operating System Concepts Chapter 8: Memory Management Background Swapping Contiguous.
Chapter 2: Memory Management Background Swapping Contiguous Allocation Paging Segmentation Segmentation with Paging Operating System Concepts.
Chapter 7: Main Memory CS 170, Fall Program Execution & Memory Management Program execution Swapping Contiguous Memory Allocation Paging Structure.
1 Chapter 8: Main Memory. 2 Chapter 8: Memory Management Background Swapping Contiguous Memory Allocation Paging Structure of the Page Table Segmentation.
Silberschatz, Galvin and Gagne ©2013 Operating System Concepts – 9 th Edition, Chapter 8: Memory- Management Strategies.
Main Memory CSSE 332 Operating Systems Rose-Hulman Institute of Technology.
Chapter 9: Memory Management
Chapter 8: Main Memory.
Main Memory Management
Chapter 8: Main Memory.
Memory Management Lectures notes from the text supplement by Siberschatz and Galvin Modified by B.Ramamurthy Chapter 8 11/24/2018.
Multistep Processing of a User Program
Memory Management Lectures notes from the text supplement by Siberschatz and Galvin Modified by B.Ramamurthy Chapter 9 12/1/2018.
So far… Text RO …. printf() RW link printf Linking, loading
Memory Management-I 1.
Main Memory Background Swapping Contiguous Allocation Paging
Chapter 8: Memory management
Outline Module 1 and 2 dealt with processes, scheduling and synchronization Next two modules will deal with memory and storage Processes require data to.
Memory Management Lectures notes from the text supplement by Siberschatz and Galvin Modified by B.Ramamurthy Chapter 9 4/5/2019.
OPERATING SYSTEMS MEMORY MANAGEMENT BY DR.V.R.ELANGOVAN.
CSE 542: Operating Systems
Page Main Memory.
Presentation transcript:

1 Memory Management (a)

2 Background  Program must be brought into memory and placed within a process for it to be run.  Input queue – collection of processes on the disk that are waiting to be brought into memory to run the program.  User programs go through several steps before being run.

3 Memory Management Requirements  Relocation  Users generally don ’ t know where they will be placed in main memory  May want to swap in at a different place (pointers???)  Generally handled by hardware  Protection  Prevent processes from interfering with the O.S. or other processes  Often integrated with relocation  Sharing  Allow processes to share data/programs  Logical Organization  Support modules, shared subroutines  Physical Organization  Main memory verses secondary memory  Overlaying

4 von Neumann Model  Instruction cycle  CPU fetches instructions from memory  Instruction is decoded  Operands loaded from memory  Instruction is executed  Results are then stored back in memory  Memory only sees a stream of addresses  requests  stores  “ von Neumann Bottleneck ”

5 Address Binding  A process must be tied to a physical address at some point (bound)  Binding can take place at 3 times  Compile time  Always loaded to same memory address  must recompile code if starting location changes  Load time  relocatable code  stays in same spot once loaded  Execution time  Binding delayed until run time  may be moved during execution  special hardware needed

6 Multistep Processing of a User Program

7 Logical vs. Physical Address Space  The concept of a logical address space that is bound to a separate physical address space is central to proper memory management.  Logical address – generated by the CPU; also referred to as virtual address.  Physical address – address seen by the memory unit.  Logical and physical addresses are the same in compile-time and load-time address-binding schemes; logical (virtual) and physical addresses differ in execution-time address- binding scheme.

8 Memory-Management Unit (MMU)  Hardware device that maps virtual to physical address.  In MMU scheme, the value in the relocation register is added to every address generated by a user process at the time it is sent to memory.  The user program deals with logical addresses; it never sees the real physical addresses.

9 Dynamic relocation using a relocation register

10

11 Dynamic Loading  Routine is not loaded until it is called  Better memory-space utilization; unused routine is never loaded.  Useful when large amounts of code are needed to handle infrequently occurring cases,such as error routines.  No special support from the operating system is required implemented through program design.

12 Dynamic Linking  Linking postponed until execution time.  Small piece of code, stub, used to locate the appropriate memory-resident library routine.  Stub replaces itself with the address of the routine, and executes the routine.  Operating system needed to check if routine is in processes’ memory address.  Dynamic linking is particularly useful for libraries.

13 Overlays  Keep in memory only those instructions and data that are needed at any given time.  Needed when process is larger than amount of memory allocated to it.  Implemented by user, no special support needed from operating system, programming design of overlay structure is complex

14 Overlays for a Two-Pass Assembler

15 Swapping  A process can be swapped temporarily out of memory to a backing store, and then brought back into memory for continued execution.  Backing store – fast disk large enough to accommodate copies of all memory images for all users; must provide direct access to these memory images.  Roll out, roll in – swapping variant used for priority- based scheduling algorithms; lower-priority process is swapped out so higher-priority process can be loaded and executed.  Major part of swap time is transfer time; total transfer time is directly proportional to the amount of memory swapped.  Modified versions of swapping are found on many systems, i.e., UNIX, Linux, and Windows.

16 Schematic View of Swapping

17 Memory Management Techniques  Fixed Partitioning  Divide memory into partitions at boot time, partition sizes may be equal or unequal but don ’ t change  Simple but has internal fragmentation  Dynamic Partitioning  Create partitions as programs loaded  Avoids internal fragmentation, but must deal with external fragmentation  Simple Paging  Divide memory into equal-size pages, load program into available pages  No external fragmentation, small amount of internal fragmentation

18  Simple Segmentation  Divide program into segments  No internal fragmentation, some external fragmentation  Virtual-Memory Paging  Paging, but not all pages need to be in memory at one time  Allows large virtual memory space  More multiprogramming, overhead  Virtual Memory Segmentation  Like simple segmentation, but not all segments need to be in memory at one time  Easy to share modules  More multiprogramming, overhead Memory Management Techniques

19 Fixed Partitioning  Main memory divided into static partitions  Simple to implement  Inefficient use of memory  Small programs use entire partition  Maximum active processes fixed  Internal Fragmentation 8 M Operating System

20 Fixed Partitioning  Variable-sized partitions  assign smaller programs to smaller partitions  lessens the problem, but still a problem  Placement  Which partition do we use?  Want to use smallest possible partition  What if there are no large jobs waiting?  Can have a queue for each partition size, or one queue for all partitions  Used by IBM OS/MFT Operating System 8 M 12 M 8 M 6 M 4 M 2 M

21 Placement Algorithm with Partitions  Equal-size partitions  because all partitions are of equal size, it does not matter which partition is used  Unequal-size partitions  can assign each process to the smallest partition within which it will fit  queue for each partition  processes are assigned in such a way as to minimize wasted memory within a partition

22 Dynamic Partitioning  Partitions are of variable length and number  Process is allocated exactly as much memory as required  Eventually get holes in the memory.  external fragmentation  Must use compaction to shift processes so they are contiguous and all free memory is in one block

23 Memory Management OS 400 K Process Memory P1 600 P P3 300 P4 700 P K 1000 K P K P K P3 P K P4 P1 900 K P5

24 Allocation Strategies  First Fit  Allocate the first spot in memory that is big enough to satisfy the requirements.  Best Fit  Search through all the spots, allocate the spot in memory that most closely matches requirements.  Next Fit  Scan memory from the location of the last placement and choose the next available block that is large enough.  Worst Fit  The largest free block of memory is used for bringing in a process.

25 Which Allocation Strategy?  The first-fit algorithm is not only the simplest but usually the best and the fastest as well.  May litter the front end with small free partitions that must be searched over on subsequent first-fit passes.  The next-fit algorithm will more frequently lead to an allocation from a free block at the end of memory.  Results in fragmenting the largest block of free memory.  Compaction may be required more frequently.  Best-fit is usually the worst performer.  Guarantees the fragment left behind is as small as possible.  Main memory quickly littered by blocks too small to satisfy memory allocation requests. First-fit and best-fit better than worst-fit in terms of speed and storage utilization.

26 Dynamic Partitioning Placement Algorithm Last allocated block (14K) Before 8K 12K 22K 18K 6K 8K 14K 36K Free block Allocated block After 8K 12K 6K 8K 14K 6K 2K 20K Allocate 18K First Fit Next Fit Best Fit

27 Fragmentation  External Fragmentation – total memory space exists to satisfy a request, but it is not contiguous.  Internal Fragmentation – allocated memory may be slightly larger than requested memory; this size difference is memory internal to a partition, but not being used.  Reduce external fragmentation by compaction  Shuffle memory contents to place all free memory together in one large block.  Compaction is possible only if relocation is dynamic, and is done at execution time.  I/O problem  Latch job in memory while it is involved in I/O.  Do I/O only into OS buffers.

28 Solution of Fragmentation  Statistical analysis shows that given N allocated blocks, another 0.5 N blocks will be lost due to fragmentation.  On average, 1/3 of memory is unusable  (50-percent rule)  Solution – Compaction.  Move allocated memory blocks so they are contiguous  Run compaction algorithm periodically  How often?  When to schedule? Memory Fragmentation

29 Memory Compaction OS 400 K Process Memory Time P P P P P K 1000 K P K P K P K P K P K P5 700 K P K P K P5 Memory Fragmentation

30 Buddy System  Tries to allow a variety of block sizes while avoiding excess fragmentation  Blocks generally are of size 2 k, for a suitable range of k  Initially, all memory is one block  All sizes are rounded up to 2 s  If a block of size 2 s is available, allocate it  Else find a block of size 2 s+1 and split it in half to create two buddies  If two buddies are both free, combine them into a larger block  Largely replaced by paging  Seen in parallel systems and Unix kernel memory allocation Buddy System

31 A128KB512K 1M 256KD E128K256KD EC 64K 256KD 128KC 64K 256KD AC 64K 256KD AC 64K BD256K AC 64K B512K A128K256K512K Buddy System 1 Mbyte Block 1 M Request 100 Kb (A) Request 240 Kb (B) Request 64 Kb (C) Request 256 Kb (D) Release B Release A Request 75 Kb (E) Release C Release E Release D Buddy System Example