190 likes | 209 Views
Explore storage hierarchy, memory terms, and memory allocation techniques. Learn about fixed and dynamic partitions, free space management, and solving fragmentation issues in memory allocation. Discover the drawbacks of existing memory management techniques and the concept of virtual memory.
E N D
Chapter 3.1 : Memory Management • Storage hierarchy • Important memory terms • Earlier memory allocation schemes • Contiguous memory allocation • Fixed partitions • Dynamic partitions • Managing free & allocated Memory Space Ceng 334 - Operating Systems
Storage Hierarchy • Main Memory • Cache on Chip (internal cache) • External Cache memory • RAM Access time decreases Capacity decreases • Secondary Storage • Hard Disk • Tertiary Storage • CD ROM • Floppy • Tape Cost increases Ceng 334 - Operating Systems
Important Memory Terms Ceng 334 - Operating Systems
OS & drivers User Program Contiguous Memory Allocation • After loading OS, the rest of the memory is available for user program • Size of user program is fixed by available memory • Use of overlays for larger programs Ceng 334 - Operating Systems
Dos Memory Layout Ceng 334 - Operating Systems
Basic Memory Management (Monoprogramming) Three simple ways of organizing memory - an operating system with one user process Ceng 334 - Operating Systems
Process 1 F r a g m e n t Process 2 F r a g m e n t Process 3 F r a g m e n t OS Partition 1 Partition 2 Partition 3 Multiprogramming with Fixed Partitions • Partition numbers and sizes (equal or unequal) are set by operator at system start up based on workload statistics • Used by IBM’s MFT (Multiprogramming with a Fixed Number of Tasks) OS for IBM 360 systems long time ago Ceng 334 - Operating Systems
Modeling Multiprogramming CPU utilization as a function of number of processes in memory Degree of multiprogramming Ceng 334 - Operating Systems
OS Memory at system start up OS Process 1 Process 2 Process 3 Three processes started OS Process 1 Process 3 Second processes is finished OS Process 1 Process 3 Process 4 A large fourth process arrives. Process 3 is relocated Multiprogramming with Dynamic Partitions • Partitions are created at load times Ceng 334 - Operating Systems
Problems with Dynamic Partitions • Fragmentation occurs due to creation and deletion of memory space at load time • Fragmentation is eliminated by relocation • Relocation has to be fast to reduce overhead • Free (unused) memory has to be managed • Allocation of free memory is done by a placement algorithm Ceng 334 - Operating Systems
Question: HOW DO YOU RELOCATE A PROCESS? Ceng 334 - Operating Systems
Memory allocation units: Green - used, Yellow - unused 1 1 0 1 0 1 0 0 1 1 0 1 0 1 Bit map of the above memory How to Keep Track of Unused Memory • Bit Maps • Memory is divided into allocation units of fixed size. A bit map with “0” bits for free and “1” bits for allocated units Ceng 334 - Operating Systems
1 2 3 4 5 6 7 8 9 10 11 12 13 14 Memory allocation units: Green - used, Yellow - unused U U 1 9 2 5 Linked list memory map F F 6 11 4 3 How to Keep Track of Unused Memory (Cont.) • Linked Lists Ceng 334 - Operating Systems
Placement Algorithms • First fit • Process is placed in the first hole it can fit in • Next fit • Start searching from the point where the last search has ended and perform first fit • Best fit • Process is placed in a hole which is closest to the process size Ceng 334 - Operating Systems
Performance Issues • Best Fit usually performs the worst, since it leaves behind the smallest possible hole • First Fit is simplest to implement and usually fastest and best • Next fit is usually a little worse than First Fit Ceng 334 - Operating Systems
90KB 128KB 256KB 512KB 90KB 128KB 256KB 300KB 512KB 300KB Another Allocation scheme:Buddy System • Memory is allocated in powers of 2 sized units during load time Initially 1 MB 90 KB request 300 KB request 90 KB returned Ceng 334 - Operating Systems
Buddy System (Cont.) • This method makes de-allocation fast. If a block of size 2k is released then the memory manager checks only the list of 2k holes to merge them into a 2k+1 sized partition • Internal fragmentation is caused since memory requests are fitted in 2k sized partitions Ceng 334 - Operating Systems
Problems with Memory Management Techniques so far • Unused memory due to fragmentation • Memory may contain parts of program which are not used during a run (ie., some routines may not be accessed in that particular run) • Process size is limited with the size of physical memory Ceng 334 - Operating Systems
Can We Get Rid of These Problems? • YES! VIRTUAL MEMORY Ceng 334 - Operating Systems