COMP 3500 Introduction to Operating Systems Memory Management: Part 1 Dr. Xiao Qin Auburn University Slides are adopted and modified from Drs. Stallings, Silberschatz, Galvin, Gagne, Nutt
The External View of the Memory Manager Slide courtesy of Dr. Gary Nutt 2
The Basic Memory Hierarchy CPU Registers Primary Memory (Executable Memory) e.g. RAM Secondary Memory e.g. Disk or Tape More Frequently Used Information Less Frequently Used Information Slide courtesy of Dr. Gary Nutt 3 Larger storage Q1: Capacity? Faster access Speed?
LBNL IT Backup Robotic Tape Libraries URL: servback.lbl.gov/backups/equipment/robots.html 4
Memory Management Requirements Q2: Can you list two functionalities? Relocation Protection Sharing Logical organization Physical organization
Address Space vs. Primary Memory 6 Mapped to object other than memory Process Address Space Hardware Primary Memory
7 Load time: Allocate primary memory Adjust addresses in address space Copy address space from secondary to primary memory Loader Process address space Primary memory Compile time: Translate elements Source code Source code C Reloc Object code Reloc Object code Link Edit Link Edit Library code Library code Other objects Other objects Secondary memory Link time: Combine elements Creating an Executable Program
A Sample Code Segment... static int gVar;... int proc_a(int arg){... gVar = 7; put_record(gVar);... }
The Relocatable Object Module Code Segment Relative AddressGenerated Code entryproc_a load=7, R1 0224storeR1, push call ‘ put_record ’ External reference table ‘ put_record ’ External definition table ‘ proc_a ’ (symbol table) (last location in the code segment) Data Segment Relative AddressGenerated variable space [Space for gVar variable] (last location in the data segment)
The Absolute Program After the link editor combines relocatable modules Code Segment Relative AddressGenerated Code 0000(Other modules) entryproc_a load=7, R1 1224storeR1, push call (End of proc_a)... (Other modules) 2334entryput_record (optional symbol table) (last location in the code segment) Data Segment Relative AddressGenerated variable space [Space for gVar variable] (last location in the data segment) Q3: What is the difference Between the absolute program and the relocatable object module?
The Program Loaded at Location 4000 Relative AddressGenerated Code 0000(Other process ’ s programs) 4000(Other modules) entryproc_a [Space for gVar variable] load=7, R1 5224storeR1, push call (End of proc_a)... (Other modules) 6334entryput_record (optional symbol table) (last location in the code segment) 7000(first location in the data segment) [Space for gVar variable] (Other process ’ s programs)
Dynamic Relocation using a Relocation Register Hardware device that maps virtual to physical address 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
Static Memory Partitioning Used in several variations in some now- obsolete operating systems Does not involve virtual memory 13 Operating System Process 3 Process 0 Process 2 Process 1 Unused In Use Issue: Need a mechanism/policy for loading p i ’s address space into primary memory pipi
14
Memory Management Terms 15 Frame vs. Page vs. Segment
Static Memory Allocation (Cont.) Hole – block of available memory; holes of various size are scattered throughout memory When a process arrives, it is allocated memory from a hole large enough to accommodate it Operating system maintains information about: a) allocated partitions b) free partitions (hole) OS process 5 process 8 process 2 OS process 5 process 2 OS process 5 process 2 OS process 5 process 9 process 2 process 9 process 10
Fixed-Partition Memory Mechanism Operating System Region 3 Region 2 Region 1 Region 0N0N0 N1N1 N2N2 N3N3 pipi p i needs n i units nini
Fixed-Partition Memory Best-Fit Operating System Region 3 Region 2 Region 1 Region 0N0N0 N1N1 N2N2 N3N3 pipi Internal Fragmentation Loader must adjust every address in the absolute module when placed in memory Q4: Pros and Cons?
Fixed-Partition Memory Worst-Fit Operating System Region 3 Region 2 Region 1 Region 0N0N0 N1N1 N2N2 N3N3 pipi Q5: Pros and Cons?
Fixed-Partition Memory First-Fit Operating System Region 3 Region 2 Region 1 Region 0N0N0 N1N1 N2N2 N3N3 pipi Q6: Pros and Cons?
Fixed-Partition Memory Next-Fit Operating System Region 3 Region 2 Region 1 Region 0N0N0 N1N1 N2N2 N3N3 pipi P i+1 Fixed-Partition strategies were used in batch multiprogramming systems (why?) Not good for timesharing systems Q7: Pros and Cons?
Disadvantages A program may be too big to fit in a partition – program needs to be designed with the use of overlays Main memory utilization is inefficient – any program, regardless of size, occupies an entire partition – internal fragmentation wasted space due to the block of data loaded being smaller than the partition 22
Summary Memory Management Requirements Dynamic Relocation using a Relocation Register Static Memory Partitioning Frame vs. Page vs. Segment 23