CPSC 213
Introduction to Computer Systems
Unit 2d
Virtual Memory
1
CPSC 213 Introduction to Computer Systems Unit 2d Virtual Memory - - PowerPoint PPT Presentation
CPSC 213 Introduction to Computer Systems Unit 2d Virtual Memory 1 Readings for Next Two Lectures Text Physical and Virtual Addressing - Address Spaces, Page Tables - Page Faults 2nd edition: 9.1-9.2, 9.3.2-9.3.4 1st edition:
Introduction to Computer Systems
Unit 2d
Virtual Memory
1Readings for Next Two Lectures
Faults
Multiple Concurrent Program Executions
Virtual Memory
Implementing the MMU
class MMU extends MainMemory { byte [] physicalMemory; AddressSpace currentAddressSpace; void setAddressSpace (AddressSpace* as); byte readByte (int va) { int pa = currentAddressSpace.translate (va); return physicalMemory.read (pa); } }
5Implementing Address Translation
class MMU extends MainMemory { byte [] physicalMemory; AddressSpace currentAddressSpace; void setAddressSpace (AddressSpace* as); byte readByte (int va) { int pa = currentAddressSpace.translate (va); return physicalMemory.read (pa); } }
6Base and Bounds
class AddressSpace { int baseVA, basePA, bounds; int translate (int va) { int offset = va - baseVA; if (offset < 0 || offset > bounds) throw new IllegalAddressException (); return basePA + offset; } }
L M N P 7But, Address Space Use May Be Sparse
Wasted Physical Memory
8Segmentation
class AddressSpace { Segment segment[]; int translate (int va) { for (int i=0; i<segments.length; i++) { int offset = va - segment[i].baseVA; if (offset >= 0 && offset < segment[i].bounds) { pa = segment[i].basePA + offset; return pa; } } throw new IllegalAddressException (va); }}
9But, Memory Use Not Known Statically
Wasted Physical Memory Broken Program OR
10But, There May Be No Room to Expand
Maybe Some Room to Expand But, Now We’re Stuck
11But, Moving Segments is Expensive
Maybe Some Room to Expand Move Other Segments to Make Room
12Expand Segments by Adding Segments
Allocate a New Segment
virtual addresses m ... n-1 virtual addresses n ... p-1
13Eliminating External Fragmentation
Translation with Many Segments
class AddressSpace { Segment segment[]; int translate (int va) { for (int i=0; i<segments.length; i++) { int offset = va - segment[i].baseVA; if (offset > 0 && offset < segment[i].bounds) { pa = segment[i].basePA + offset; return pa; } } throw new IllegalAddressException (va); }}
15Paging
a small, fixed-sized (4-KB) segment
page table entry
virtual page number
physical page frame number
byte offset of address from beginning of page
class AddressSpace { PageTableEntry pte[]; int translate (int va) { int vpn = va / PAGE_SIZE; int offset = va % PAGE_SIZE; if (pte[vpn].isValid) return pte[vpn].pfn * PAGE_SIZE + offset; else throw new IllegalAddressException (va); }} class PageTableEntry { boolean isValid; int pfn; }
17class AddressSpace { PageTableEntry pte[]; int translate (int va) { int vpn = va >>> 12; int offset = va & 0xfff; if (pte[vpn].isValid) return pte[vpn].pfn << 12 | offset; else throw new IllegalAddressException (va); }} class PageTableEntry { boolean isValid; int pfn; }
18The MMU Hardware
19Context Switch
Demand Paging
a.out swap swap
21Summary
Address Space Translation Tradeoffs