Virtual Memory Systems
References
Review: Virtual Memory and Physical Memory
data:image/s3,"s3://crabby-images/e986e/e986e9022d6638458fb98caaa5b64bc7bc0cd7bd" alt=""
- A page table contains page table entries (PTEs) that map virtual pages to physical pages
Translating with a k-level Page Table
data:image/s3,"s3://crabby-images/7c603/7c603262cf4717f919cab4852df8bbf19118ea2c" alt=""
Translation Lookaside Buffer (TLB)
data:image/s3,"s3://crabby-images/da973/da973176d71d4d6bf604400af1f4d6e1c1dd0839" alt=""
- A TLB hit eliminates the \(k\) memory accesses required to do a page table lookup
Recall: Set Associative Cache
Cache Organization
Review of Symbols
- Basic Parameters
- \(N = 2^{n}\): number of addresses in virtual address space
- \(M = 2^{m}\): number of addresses in physical address space
- \(P = 2^{p}\): page size (bytes)
- Components of the virtual address (VA)
- TLBI: translation lookaside buffer index
- TLBT: translation lookaside buffer tag
- VPO: virtual page offset
- VPN: virtual page number
- Components of the physical address (PA)
- PPO: physical page offset (same as VPO)
- PPN: physical page number
Simple Memory System Example
- Addressing
- 14-bit virtual addresses
- 12-bit physical addresses
- Page size = 64 bytes
data:image/s3,"s3://crabby-images/3d2de/3d2decd2cb7001e7a5a106757d9397935aa6af8c" alt=""
Simple Memory System TLB
- 16 entries
- 4-way associative
data:image/s3,"s3://crabby-images/f4f7e/f4f7e66d86446f6110861d124ec97c9314295da0" alt=""
Simple Memory System Page Table
- Only showing the first 16 entries (out of 256)
data:image/s3,"s3://crabby-images/b0775/b07751eb67857838d8f1d9326452efbc38e915b2" alt=""
Simple Memory System Cache
- 16 lines, 4-byte cache line size
- Physically addressed
- Direct mapped
data:image/s3,"s3://crabby-images/87565/87565f79a592c3de5a99b842be651ec0f6a8e59b" alt=""
Address Translation Example
- Virtual Address:
0x3d4
= 00001111 010100
- VPN:
0x0F
, TLBI: 0x03
, TLBT: 0x03
, PPN: 0x0D
- Hit, no fault
data:image/s3,"s3://crabby-images/f4f7e/f4f7e66d86446f6110861d124ec97c9314295da0" alt=""
Address Translation Example
- Physical Address:
- PPN:
001101
, PPO: 010100
- CO:
0
, CI: 0x5
, CT: 0x0D
, Hit: yes, Byte: 0x36
data:image/s3,"s3://crabby-images/87565/87565f79a592c3de5a99b842be651ec0f6a8e59b" alt=""
Intel Core i7 Memory System
data:image/s3,"s3://crabby-images/0df05/0df05de3e57e41e9fc55f5bdd1b8e36bd75a3657" alt=""
End-to-end Core i7 Address Translation
data:image/s3,"s3://crabby-images/54948/54948a7faf7d31e03b7cb91b038d230d6c32d2f7" alt=""
Core i7 Level 1-3 Page Table Entries
data:image/s3,"s3://crabby-images/1fc8d/1fc8d8b5e66abb17db532e1243191fc5bbaf80d5" alt=""
- Each entry references a 4K child page table:
- P: child page table present in physical memory
- R/W: read-only or read-write access permission for all reachable pages
- U/S: user or supervisor (kernel) mode access permission for all reachable pages.
- WT: Write-through or write-back cache policy for child page table
- A: reference bit (set by MMU on reads and writes, cleared by software)
- PS: Page size either 4KB or 4MB (defined for level 1 PTEs only)
- Page table physical base address: 40 most significant bits or physical page table address (forces page tables to be 4KB aligned)
- XD: disable or enable instruction fetches from all pages reachable from this PTE
Core i7 Page Table Translation
data:image/s3,"s3://crabby-images/e8201/e8201fa2978bf556fa4fcc7f82f56a939bfbaff6" alt=""
Trick for Speeding Up L1 Access
- Observation
- Bits that determine the CI are identical in virtual and physical address
- Can index into cache while address translation is taking place
- Generally there is a hit in the TLB, so PPN bits (CT bits) are available quickly
- “Virtually indexed, physically tagged”
- Cache carefully sized to make this possible
Virtual Address Space of a Linux Process
data:image/s3,"s3://crabby-images/6334b/6334b883eaf368dcdc944e2914626da47aa9dfc2" alt=""
Linux Organizes VM as Collection of “Areas”
data:image/s3,"s3://crabby-images/65c5d/65c5dd37583e0062885a449b9eb69bd4fcf77b3d" alt=""
pgd
: page global directory address; points to L1 page table
vm_prot
: read/write permissions for this area
vm_flags
: pages shared with other processes or private to this process
Linux Page Fault Handling
- Read from a non-existing page: segmentation fault
- Read from data area: normal page fault
- Write to text area: violating permission by writing to a read-only page; Linux reports a segmentation fault
Memory Mapping
- VM areas initialized by associating them with disk objects
- Area can be backed by (that is, get its initial values from):
- Regular file on disk (for example, an executable object file)
- Initial page bytes come from a section of a file
- Anonymous file (that is, nothing)
- First fault will allocate a physical page full of zeros
- Once the page is written to (dirtied), it is like any other page
- Dirty pages are copied back and forth between memory and a special swap file
Review: Memory Management and Protection
- Code and data can be isolated or shared among processes
data:image/s3,"s3://crabby-images/f3e2f/f3e2f7a17ecec406ae1069de53b5d8b6a9c24187" alt=""
Sharing Revisited: Shared Objects
- Process 1 maps the shared object (on disk)
- Process 2 maps the same shared object
- Note that the virtual addresses can be different, but the difference must be a multiple of the page size
- Two processes mapping a private copy-on-write (COW) object
- Area flagged as private copy-on-write
- PTEs in private areas are flagged as read-only
data:image/s3,"s3://crabby-images/efb05/efb05599822b85d0f947d1cffe1af06cdce17316" alt=""
Sharing Revisited: Private Copy-on-Write (COW) Objects
- Instruction writing to private page triggers protection fault
- Handler creates new R/W page
- Instruction restarts upon handler return
- Copying deferred as long as possible
data:image/s3,"s3://crabby-images/039ab/039ab201fe1a77a82ce7c3c4de2caaf6e4629d73" alt=""
Finding Shareable Pages
- Kernel Same-Page Merging
- OS scans through all of physical memory looking for duplicate pages
- When found, merge into a single copy marked as copy-on-write
- Implemented in Linux kernel in 2009
- Limited to pages marked as likely candidates
- Especially useful when processor running many virtual machines
Summary
- VM requires hardware support
- Exception handling mechanism
- TLB
- Various control registers
- VM requires OS support
- Managing page tables
- Implementing page replacement policies
- Managing file system
- VM enables many capabilities
- Loading programs from memory
- Providing memory protection