1 / 24

Virtual Memory

Virtual Memory. Lecturer : Dr. Pavle Mogin. Plan for Virtual Memory Topic. What is a virtual memory (VM) Virtual Memory: benefits and costs How is Virtual Memory provided? The page table Address translation – from virtual to physical addresses Writes and the dirty bit

dredman
Download Presentation

Virtual Memory

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Virtual Memory Lecturer : Dr. Pavle Mogin

  2. Plan for Virtual Memory Topic • What is a virtual memory (VM) • Virtual Memory: benefits and costs • How is Virtual Memory provided? • The page table • Address translation – from virtual to physical addresses • Writes and the dirty bit • Page replacement policies • Translation lookaside buffer • Reading 7.4

  3. Virtual Memory: What Is It? • ‘Real’ or ‘physical’ computer memory is made out of • Processorregisters, e.g. $0, $1, … $31 • Cache slots, e.g. slot 0, slot 1, … slot 1023 • DRAM cells, e.g. 0, 1, … 33,554,431 (32M) • Hard disk locations, e.g. sector 108 of track 2 of cylinder 3,294 • Using more hardware and system software we can hide most of this nastiness from the programmer • ‘Virtual’ computer memory is made out of • Addresses, e.g. 0, 1, … 4,294,967,295 (232) • That’s it!

  4. The Benefits of Virtual Memory • A single, ‘flat’ address space • No need to worry about where data is in the hierarchy • (actually, you can still access the registers directly, if you want) • A large address space that is limited only by the size of your registers • A separate address space for each program (!) • No need to worry about one program corrupting another’s data • Possibility of ‘segments’ for text, data, etc • With read/write/execute permission per segment

  5. Before And After Virtual Memory A programmer has to divide a program into segments. To load and unload segments Paging and swapping is done by OS 1.2 Gbytes disk A’s stack B’s stack A’s stack Many Mbytes B’s data B’s stack A’s data 8 Mbytes A’s data B’s data program B program A program B program A Before virtual memory After virtual memory

  6. Virtual Memory Versus Physical Memory A’s stack B’s stack 100 Gbytes disk Many Mbytes B’s data 1 Gbyte DRAM A’s data program B program A The programmer’s view The computer’s view

  7. The Costs of Virtual Memory • Every address used in your HLL program… • Be it the address of the next program instruction • Or the address of some data you want to read or write must be translated on the fly into a physical address • This physical address is then satisfied from • Cache • Or DRAM if the caches misses • Or hard disk if the DRAM misses • But the translation and ‘satisfaction’ are invisible to the programmer

  8. How Is VM Provided? (1) • The computer treats each VM space as a series of ‘pages’ • Similar to blocks in the cache • Typically between 512 and 4096 words per page • With a large VM many pages are, in fact, empty and unused • Pages that contain some data, text, or stack are stored • In DRAM as a unit (of 512 to 4096 words, etc) • On disk as a block (of 512 to 4096 words, etc) • ‘Paging’ between DRAM and disk is done by OS • Pages are used to exploit spatial locality • And because disk bandwidth is better for large blocks

  9. data code program C Pages Move Between DRAM and Disk Virtual addresses data data page 2 page 2 page 2 page 1 page 1 page 1 code code page 0 page 0 page 0 program A program B DRAM A page 0 Physical addresses A page 0 C page 2 All pages are on disk A page 2 B page 2 A page 2 B page 1 B page 0 C page 2 Hard disk

  10. How Is VM Provided (2) • When the processor generates a (virtual) address • How do we know if the required page is in DRAM? • If it is, how do we know what physical address to use? • If it isn’t, how do we know where on the disk it is? • The computer maintains • A ‘page table’ for each program in the system • A page table register that points at the page table of the currently executing program • (parts of the current table my be cached in hardware to make lookup faster) • Page table must be consulted for every address generated by the program

  11. Example Page Tables Physical View Virtual memory view B page 0 data Data code data page 2 3070 (unusedpage) A page 0 B page 0 page 1 2046 C page 2 A page 2 C page 2 code code page 0 1024 A page 0 B page 1 B page 2 program A program B program C 0 DRAM Hard disk PAGE TABLE FOR PROGRAM B Page 0 is in DRAM at address 3070 Page 1 is on disk at cylinder C2, track T2, sector S2 Page 2 is on disk at cylinder C3, track T3, sector S3 PAGE TABLE FOR PROGRAM A Page 0 is in DRAM at address 0 Page 1 is not used Page 2 is on disk at cylinder C1, track T1, sector S1

  12. Address Translation • Suppose the current instruction is lw $4, 200($10) • $10 + 200 is a virtual address • It must be translated to a physical address so the read can happen address generated by processor 31 30 29 ... … 14 13 12 11 10 9 ... … 3 2 1 0 virtual page number offset inside the page page table (no translation) address presented to DRAM 29 28 27 ... … 14 13 12 11 10 9 ... … 3 2 1 0 physical page number offset inside the page

  13. Example • Suppose pages are 100 bytes in size • Suppose the currently executing program has this page table: • Page 0: maps to DRAM address 500 • Page 1: not in use • Page 2: maps to DRAM address 300 • Page 4: … • Then virtual addresses 0, 1, 2, … 99 • Map to physical addresses 500, 501, 502, … 599 respectively • and virtual addresses 200, 201, 202, …, 299 • Map to physical addresses 300, 301, 302, … 399 respectively

  14. physical page no. physicaladdress 6 600 5 500 4 400 3 300 2 200 1 100 0 0 DRAM Example Page Table All numbers in decimal, page size is 100 bytes. virtual page no. virtual address 300 data 2 200 code 1 Program A in main memory 100 code 0 Program A’s virtual address space data 0

  15. Page Table Lookups Virtual page number Offset within page Page table register Valid Physical page number Page Table 0 means on disk 1 means in DRAM 2 means page not used Physical page number or disk address Offset within page

  16. Handling Writes • Many caches use write-through, as we saw • Virtual memory uses write-back: • Since writing pages to disk is so inefficient • Writes are accumulated in the page (‘dirty’ bit is set) • On replacement, page is written back to disk • Nothing need be done if no writes to page

  17. Page Replacement Policy • A ‘page miss’ means page is on disk • The operating system initiates a disk read • (this usually takes so long that it’s worth running another program in the meantime) • An important design consideration: how to make space in DRAM • i.e. what page replacement policy to use? • Possible solutions • Keep a ‘dirty’ bit in the page table, overwrite a clean page • (saves having to flush dirty page to disk) • Keep an ‘age since last access’ count in the page table • ‘least recently used (LRU)’ policy • Other policies discussed in COMP305

  18. Where Are the Page Tables Stored? • How big are they? • Assume virtual memory space is 232 • Assume pages are 4 K in size • Each page table entry requires approx 1 word • Each page table is 232 / 212 = 220 = 1 Mwords in size • How many page tables are there? • One per program (10s of programs) • In fact, page tables are stored in DRAM • (they even get paged out to disk - but don’t think about the implications of this) • So to translate a VM address you must first search the page table in DRAM?!?

  19. Translation Lookaside Buffer • Since page tables are stored in the main memory, each memory reference from a program requires at least one memory accesses to translate virtual into physical address and then to try to satisfy it from cache • On the cache miss, there will be two memory accesses • The key to improving access performance is to rely on locality of references to page table. When a translation for a virtual page is used, it will probably be needed again in the near future because the references to the words on that page have both temporal and spatial locality • Translation lookaside buffer - a special cache used to keep track of recently used translations

  20. 0 1 1 0 0 1 0 1 0 Introducing the TLB CPU Translation Lookaside Buffer DRAM V tag PPN virt. page no. 1 0 0 virt. page no. 1 1 V PPN 1 Page table in DRAM new page Disk

  21. Using TLB • Look up VPN in TLB • On hit, concatenate PPN in TLB with offset • On miss, check page table • On hit, copy page table entry to TLB • Use replacement policy to make space in TLB • On miss, do a page fault • TLB is direct mapped (hence valid bit and tag field) • For the purpose of acting as a page table, TLB has: • Use bit (to monitor usage for replacement), • Dirty bit (to monitor alterations). • Typical performance figures • 32 - 4K entries • Block size: 1 or two PPNs • 1 cycle hit time, 50 cycles miss time

  22. Virtual Memory Summary CPU On a TLB miss Main Memory virtual address VPN Page table TLB On a Page Fault PPN physical address word disk address physical address Disk Cache page cache block On a cache miss

  23. Summary (1) • Virtual memory • hides the memory hierarchy • protects programs from each other • involves swapping pages between DRAM and disk • Operating system controls the virtual memory: • Executes paging between DRAM and disk • Maintains page table for every program in the execution • Controls page table register of the active program • Page table must be consulted for every address issued by the program

  24. Summary (2) • Page table • Valid, dirty, last-accessed-time bits • Physical address or disk address • Address translation • Virtual address = VPN + offset • Physical address = PPN + offset • Page replacement policies • TLB: a cache for the page table

More Related