Main Points. Address Transla+on Concept. Flexible Address Transla+on. Efficient Address Transla+on
|
|
- Lindsay Norton
- 5 years ago
- Views:
Transcription
1 Address Transla+on
2 Main Points Address Transla+on Concept How do we convert a virtual address to a physical address? Flexible Address Transla+on Segmenta+on Paging Mul+level transla+on Efficient Address Transla+on Transla+on Lookaside Buffers Virtually and physically addressed caches
3 Address Transla+on Concept Processor Virtual Address Translation Invalid Raise Exception Valid Data Physical Address Physical Memory Data
4 Address Transla+on Goals Memory protec+on Isolate process to its only memory Prevent virus from re- wri+ng machine instruc+ons Memory sharing Shared libraries, interprocess communica+on Sparse addresses Dynamically allocated regions: heaps, stacks, mmap Efficiency Reduce fragmenta+on and copying Run+me lookup cost and TLB hit rate Transla+on table size Portability
5 Bonus Feature What if the kernel can regain control whenever a program reads or writes a par+cular virtual memory loca+on? Examples: Copy on write Zero on reference Fill on demand Demand paging Memory mapped files
6 Virtually Addressed Base and Bounds Processor s View Implementation Physical Memory Processor Virtual Address Virtual Memory Processor Virtual Address Base Physical Address Base Bound Base+ Bound Raise Exception
7 Virtually Addressed Base and Bounds Pros? Simple Fast (2 registers, adder, comparator) Safe Can relocate in physical memory without changing process Cons? Can t keep program from accidentally overwri+ng its own code Can t share code/data with other processes Can t grow stack/heap as needed
8 Process Regions or Segments Every process has logical regions or segments Con+guous region of process memory Code, data, heap, stack, dynamic library (code, data), memory mapped files, Each with its own protec+on: read- only, read- write, execute- only sharing: code vs. data access pa[ern: code vs. mmap file
9 Segmenta+on Segment is a con+guous region of virtual memory Each process has a segment table (in hardware) Entry in table = segment Segment can be located anywhere in physical memory Each segment has: start, length, access permission Processes can share segments Same start, length, same/different access permissions
10 Process View Processor Virtual Address Virtual Memory Code Data Heap Segmenta+on Processor Segment Virtual Address Implementation Offset Segment Table Base Bound Access Read R/W R/W R/W Physical Memory Stack Code Base 3 Base+ Bound 3 Base 0 Base+ Bound 0 Base 1 Stack Physical Address Raise Exception Data Base+ Bound 1 Base 2 Heap Base+ Bound 2
11 2 bit segment # 12 bit offset Virtual Memory main: 0:240 store #108, r2 0:244 store pc+8, r31 0:248 jump 360 0:24c strlen: 0:360 loadbyte (r2), r3 0:420 jump (r31) x: 1:108 a b c \0 Segment start x: 108 a b c \0 main: 4240 store #1108, r store pc+8, r jump c strlen: 4360 loadbyte (r2),r jump (r31) length code 0x4000 0x700 data 0 0x500 heap - - stack 0x2000 0x1000 Physical Memory
12 Processor s View Process 1`s View Implementation Physical Memory Virtual Memory P2`s Data Processor Virtual Address 0x0500 Code Data Heap Processor Seg. Offset Virtual Address Code Data Heap Stack Segment Table Base Bound Access Read R/W R/W R/W P1`s Heap P1`s Stack P1`s Data Process 2`s View Stack Physical Address P2`s Heap Processor Virtual Address 0x0500 Code Data Processor Seg. Offset Code Segment Table Base Bound Access Read P1 s+ P2`s Code P2`s Stack Heap Virtual Address Data Heap R/W R/W Stack R/W Stack
13 Ques+on With segmenta+on, what is saved/restored on a process context switch?
14 Pros? Segmenta+on Can share code/data segments between processes Can protect code segment from being overwri[en Cons? Complex memory management Need to find chunk of a par+cular size May need to rearrange memory to make room for new segment or growing segment (e.g., sbrk) External fragmenta+on: wasted space between chunks
15 Paged Transla+on Manage memory in fixed size units, or pages Finding a free page is easy Bitmap alloca+on: Each bit represents one physical page frame Each process has its own page table Stored in physical memory Hardware registers pointer to page table start page table length
16 Proces View Physical Memory Code0 Frame 0 VPage 0 VPage 1 Code Data Heap Data0 Heap1 Code1 Heap0 Data1 VPage N Stack Heap2 Stack 1 Stack 0 Frame M
17 Physical Memory Physical Address Frame 0 Frame 1 Processor Frame Offset Virtual Address Frame Page Table Access Page # Offset Virtual Address Page # Offset Physical Address Frame Offset Frame M
18 Process View A B C D E F G H I J K L Physical Memory Page Table I J K L E F G H A B C D
19 Paging Ques+ons With paging, what is saved/restored on a process context switch? Pointer to page table, size of page table Page table itself is in main memory What if page size is very small? What if page size is very large? Internal fragmenta+on: if we don t need all of the space inside a fixed size chunk
20 Paging and Sharing Can we use page tables to share memory between processes? Set page tables to point to same page frame Need core map Array of informa+on about each physical page frame Set of processes poin+ng to that page frame When reference count goes to zero, can reclaim!
21 Ques+on How big a user stack should I allocate? What if some programs need a large stack and others need a small one?
22 Expand Stack on Reference When program references memory beyond end of stack Page fault into OS kernel Kernel allocates some addi+onal memory How much? Remember to zero the memory to avoid accidentally leaking informa+on! Modify page table Resume process
23 UNIX fork seems inefficient Makes a complete copy of process Throw copy away on exec Do we need to make the copy? One solu+on: change the syscall interface!
24 Copy on Write Paging allows an efficient fork Copy page table of parent into child Mark all pages (in new/old page tables) as read- only Start child process; restart parent Trap into kernel on write (in child or parent) Copy page Mark both as writeable Resume execu+on
25 Ques+on Can I start running a program before all of its code is in memory?
26 Fill On Demand Set all page table entries to invalid When a page is referenced for first +me, kernel trap Kernel brings page in from disk Resume execu+on Remaining pages can be transferred in the background while program is running
27 Beyond Paging: Sparse Address Spaces Might want many separate segments Per- processor heaps Per- thread stacks Memory- mapped files Dynamically linked libraries What if virtual address space is large? 32- bits, 4KB pages => 500K page table entries 64- bits => 4 quadrillion page table entries
28 Mul+- level Transla+on Tree of transla+on tables Paged segmenta+on Mul+- level page tables Mul+- level paged segmenta+on All have pages as lowest level; why?
29 Mul+level Transla+on with Pages at Lowest Level Efficient memory alloca+on (vs. segments) Efficient for sparse addresses (vs. 1 level paging) Efficient disk transfers (fixed size units) Easier to build transla+on lookaside buffers Efficient reverse lookup (from physical - > virtual) Variable granularity for protec+on/sharing Except: see discussion of superpages
30 Paged Segmenta+on Process memory is segmented Segment table entry: Pointer to page table Page table length (# of pages in segment) Access permissions Page table entry: Page frame Access permissions Share memory or set access permissions at either page or segment- level
31 Implementation Physical Memory Processor Segment Virtual Address Page Offset Exception Page Table Frame Access Read Read Segment Table Page Table Size Access Frame Read R/W R/W R/W Physical Address Offset
32 Ques+on With paged segmenta+on, what must be saved/restored across a process context switch?
33 Mul+- level or hierarchical page tables Ex: 2- level page table Level 1 table: each PTE points to a page table Level 2 table: each PTE points to a page Can share/protect/page in/out at either level 1 or level 2 Level 1 Table... Level 2 Tables...
34 Implementation Physical Memory Processor Virtual Address Index 1 Index 2 Index 3 Level 1 Offset Frame Physical Address Offset Level 2 Level 3
35 Ques+on Write pseudo- code for transla+ng a virtual address to a physical address for a system using 3- level paging, with 8 bits of address per level
36 x86 Mul+level Paged Segmenta+on Global Descriptor Table (segment table) Each segment descriptor Pointer to (mul+level) page table Segment length Segment access permissions Context switch change global descriptor table register (GDTR), pointer to global descriptor table Side effect: invalidates TLB
37 x86 Mul+level Paging Omit sub- tree if no valid addresses Good for sparse address space 4KB pages Each level of page table fits in one page 32- bit: two level page table (per segment) 64- bit: four level page table (per segment)
38 x86-32 Paging VPN3 VPN4 12 VPO Virtual address Page Directory Page Table PDE PTE CR3 20 PPN 12 PPO Physical address
39 x86-64 Paging 16 Sign 9 VPN VPN2 VPN3 VPN4 12 VPO Virtual address Page Directory Page Map Level 4 Pointer Table Page Directory Page Table PM4LE PDPE PDE PTE CR3 36 PPN 12 PPO Physical address
40 Page directory entries (x86 32 bit) Empty Ignored 0 4MB page Bits 31:22 of address of 4MB page frame 0 Ign G 1 D A P C D P U W / T S R / 1 W Page table Bits 31:12 of address of page table Ign 0 I g n A P C D P U W / T S R / 1 W
41 Page table entries (x86 32 bit) Empty Ignored 0 4KB page Bits 31:12 of address of page frame Ign G 0 D A P C D P U W / T S R / 1 W
42 Small page transla+on CR3 register Address of page directory SBZ Virtual address PDE index PTE index Offset Address of PDE PDE Address of page directory PDE index 0 0 Page table base address Access control 1 Note: addresses in physical memory! Address of PTE Page table base address PTE index 0 0 PTE Small page base address Access control 1 Physical address Small page base address Offset
43 Page table for small pages Base address entries 4kB 4kB page 1024 entries 4kB Translates VA[21:12] Page table 4kB page Page directory VA[11:0] = offset in page Translates VA[31:22] Page table
44 Mul+level Transla+on Pros: Allocate/fill only page table entries that are in use Simple memory alloca+on Share at segment or page level Cons: Space overhead: one pointer per virtual page Mul+ple lookups per memory reference
45 Page Transla+on in the OS OS s need to keep their own data structures List of memory objects (segments) Virtual page - > physical page frame Physical page frame - > set of virtual pages Keep track of copy on write, load on demand, Why not just use the hardware page tables?
46 Kernel Page Transla+on Kernel maintains its own page transla+on data structures Portable, flexible Copy changes down into hardware page tables Example: Inverted page table Hash from virtual page - > physical page Space propor+onal to # of physical pages Example: virtual/shadow page table Linux kernel tables mirror x86 structure, even on ARM
47 Efficient Address Transla+on Transla+on lookaside buffer (TLB) Cache of recent virtual page - > physical page transla+ons If cache hit, use transla+on If cache miss, walk mul+- level page table Cost of transla+on = Cost of TLB lookup + Prob(TLB miss) * cost of page table lookup
48 TLB and Page Table Transla+on Processor Virtual Address TLB Virtual Address Miss Page Table Invalid Raise Exception Hit Valid Frame Frame Data Offset Physical Address Physical Memory Data
49 Virtual Address TLB Lookup Physical Memory Page# Offset Translation Lookaside Buffer (TLB) Virtual Page Page Frame Access Physical Address Matching Entry Frame Offset Page Table Lookup
50 Ques+on What happens on a context switch? Reuse TLB? Discard TLB? (xk resets TLB) Solu+on: Tagged TLB Each TLB entry has process ID TLB hit only if process ID matches current process
51 Processor Virtual Address Implementation Physical Memory Page Frame Page# Offset Process ID Matching Entry Translation Lookaside Buffer (TLB) Process ID Page Frame Access Frame Physical Address Offset Page Table Lookup
52 MIPS Address Transla+on Soxware- Loaded Transla+on lookaside buffer (TLB) Cache of virtual page - > physical page transla+ons If TLB hit, physical address If TLB miss, trap to kernel Kernel fills TLB with transla+on and resumes execu+on Kernel can implement any page transla+on Page tables Mul+- level page tables Inverted page tables
53 Ques+on What is the cost of a TLB miss on a modern processor? Cost of mul+- level page table walk MIPS: plus cost of trap handler entry/exit
54 Hardware Design Principle The bigger the memory, the slower the memory
55 Intel i7
56 Memory Hierarchy i7 has 8MB as shared 3 rd level cache; 2 nd level cache is per- core
57 Ques+on What is the cost of a first level TLB miss? Second level TLB lookup What is the cost of a second level TLB miss? 64 bit x86: 4- level page table walk How expensive is a 4- level page table walk?
58 Virtually Addressed vs. Physically Addressed Caches First level cache has at most a few cycles Delays every instruc+on fetch and data reference Lookup TLB to get physical address, then lookup physical address in the cache? Too slow! Instead, lookup virtual address in cache In parallel, lookup TLB in case of a cache miss
59 Virtually Addressed Caches Processor Virtual Address Virtual Cache Virtual Address Virtual Address Miss TLB Miss Page Invalid Table Raise Exception Hit Hit Valid Data Frame Frame Data Offset Physical Address Physical Memory Data
60 Ques+on With a virtual cache, what do we need to do on a context switch?
61 Physically Addressed Cache Processor Virtual Address Virtual Cache Virtual Address Miss TLB Virtual Address Miss Page Table Invalid Raise Exception Hit Hit Valid Data Frame Frame Data Offset Physical Address Physical Cache Hit Miss Physical Address Physical Memory Data Data
62 TLB Size (Intel Kaby Lake, 2017) First level TLB Instruc+on: 128 entries Data: 64 entries Second level TLB 1536 entries Modern server can have 10 TB (!) of DRAM 10-20% of server CPU +me spent in TLB misses
63 When Do TLBs Work/Not Work? Video Frame Buffer: 32 bits x 1K x 1K = 4MB Page# Video Frame Buffer 2017 laptop: 3K x 2K = 24MB 4K display: 4K x 3K = 48MB
64 Superpages On x86 and ARM, TLB entry can be A page A superpage: a set of con+guous, aligned pages x86: superpage is set of pages in one page table One page: 4KB One page table: 2MB One page table of page tables: 1GB One page table of page tables of page tables: 0.5TB
65 Virtual Address Superpages Physical Memory Page# SP Offset Offset Translation Lookaside Buffer (TLB) Matching Entry Superpage (SP) or Page# Superframe (SF) or Frame Access Frame Physical Address Offset Matching Superpage Page Table Lookup SF Offset
66 When Do TLBs Work/Not Work, part 2 What happens when the OS changes the permissions on a page? For demand paging, copy on write, zero on reference, TLB may contain old transla+on OS must ask hardware to purge TLB entry On a mul+core: TLB shootdown OS must ask each CPU to purge TLB entry
67 TLB Shootdown Processor 1 TLB = = Process ID 0 VirtualPage PageFrame Access 0x0053 0x0003 R/W 1 0x4OFF 0x0012 R/W Processor 2 TLB = = 0 0x0053 0x0003 R/W 0 0x0001 0x0005 Read Processor 3 TLB = = 1 0x4OFF 0x0012 R/W 0 0x0001 0x0005 Read
68 Virtual Cache Shootdown When permissions change for a page, we must shoot down the TLB entry on every CPU What about the contents of the virtual cache? Lazy shootdown of the virtual cache: Lookup virtually addressed cache and TLB in parallel Use the TLB to verify virtual address is s+ll valid! Evict entry from cache if not
69 Virtual Cache Aliases Alias: two (or more) virtual cache entries that refer to the same physical memory A consequence of a tagged virtually addressed cache! A write to one copy needs to update all copies Solu+on: Virtual cache keeps both virtual and physical address for each entry Lookup virtually addressed cache and TLB in parallel Check if physical address from TLB matches any other entries, and update/invalidate those copies
70 x86 caches 64 byte line size Physically indexed Physically tagged Write buffer
71 Mul+core and Hyperthreading Modern CPU has several func+onal units Instruc+on decode Arithme+c/branch Floa+ng point Instruc+on/data cache TLB Mul+core: replicate func+onal units (i7: 4) Share second/third level cache, second level TLB Hyperthreading: logical processors that share func+onal units (i7: 2) Be[er func+onal unit u+liza+on during memory stalls No difference from the OS/programmer perspec+ve Except for performance, affinity,
72 Address Transla+on Uses Process isola+on Keep a process from touching anyone else s memory, or the kernel s Efficient interprocess communica+on Shared regions of memory between processes Shared code segments E.g., common libraries used by many different programs Program ini+aliza+on Start running a program before it is en+rely in memory Dynamic memory alloca+on Allocate and ini+alize stack/heap pages on demand
73 Address Transla+on (more) Cache management Page coloring Program debugging Data breakpoints when address is accessed Zero- copy I/O Directly from I/O device into/out of user memory Memory mapped files Access file data using load/store instruc+ons Demand- paged virtual memory Illusion of near- infinite memory, backed by disk or memory on other machines
74 Address Transla+on (even more) Checkpoin+ng/restart Transparently save a copy of a process, without stopping the program while the save happens Persistent data structures Implement data structures that can survive system reboots Process migra+on Transparently move processes between machines Informa+on flow control Track what data is being shared externally Distributed shared memory Illusion of memory that is shared between machines
Lecture 13: Address Translation
CS 422/522 Design & Implementation of Operating Systems Lecture 13: Translation Zhong Shao Dept. of Computer Science Yale University Acknowledgement: some slides are taken from previous versions of the
More informationCIS Operating Systems Memory Management Address Translation. Professor Qiang Zeng Fall 2017
CIS 5512 - Operating Systems Memory Management Address Translation Professor Qiang Zeng Fall 2017 Outline Fixed partitions Dynamic partitions Con$guous alloca$on: Each process occupies a con$guous memory
More informationCl. Cl. ..., V, V, -I..., - QJ d.
)> Cl. Cl...., m V, V, -I..., QJ :J V, - QJ d. 0 :J Main Points Address Translation Concept - How do we convert a virtual address to a physical address? Flexible Address Translation I R. lz G.z: f1..t:?z:.mo/2_'-(
More informationCIS Operating Systems Memory Management Address Translation for Paging. Professor Qiang Zeng Spring 2018
CIS 3207 - Operating Systems Memory Management Address Translation for Paging Professor Qiang Zeng Spring 2018 Previous class What is logical address? Who use it? Describes a location in the logical memory
More informationMain Memory. CS 4410, Opera3ng Systems. Lorenzo Alvisi Anne Bracy. Spring 2017 Cornell University. See: Ch 8 & 9 in OSPP textbook
Main Memory Lorenzo Alvisi Anne Bracy CS 4410, Opera3ng Systems See: Ch 8 & 9 in OSPP textbook Spring 2017 Cornell University The slides are the product of many rounds of teaching CS 4410 by Professors
More informationVirtual Memory: Concepts
Virtual Memory: Concepts Instructor: Dr. Hyunyoung Lee Based on slides provided by Randy Bryant and Dave O Hallaron Today Address spaces VM as a tool for caching VM as a tool for memory management VM as
More informationOpera&ng Systems ECE344
Opera&ng Systems ECE344 Lecture 8: Paging Ding Yuan Lecture Overview Today we ll cover more paging mechanisms: Op&miza&ons Managing page tables (space) Efficient transla&ons (TLBs) (&me) Demand paged virtual
More informationVirtual Memory. Samira Khan Apr 27, 2017
Virtual Memory Samira Khan Apr 27, 27 Virtual Memory Idea: Give the programmer the illusion of a large address space while having a small physical memory So that the programmer does not worry about managing
More informationCS 162 Operating Systems and Systems Programming Professor: Anthony D. Joseph Spring Lecture 13: Address Translation
CS 162 Operating Systems and Systems Programming Professor: Anthony D. Joseph Spring 2004 Lecture 13: Address Translation 13.0 Main Points 13.1 Hardware Translation Overview CPU Virtual Address Translation
More informationCIS Operating Systems Memory Management Cache and Demand Paging. Professor Qiang Zeng Spring 2018
CIS 3207 - Operating Systems Memory Management Cache and Demand Paging Professor Qiang Zeng Spring 2018 Process switch Upon process switch what is updated in order to assist address translation? Contiguous
More informationThis lecture. Virtual Memory. Virtual memory (VM) CS Instructor: Sanjeev Se(a
Virtual Memory Instructor: Sanjeev Se(a This lecture (VM) Overview and mo(va(on VM as tool for caching VM as tool for memory management VM as tool for memory protec(on Address transla(on 2 Virtual Memory
More informationCIS Operating Systems Memory Management Cache. Professor Qiang Zeng Fall 2017
CIS 5512 - Operating Systems Memory Management Cache Professor Qiang Zeng Fall 2017 Previous class What is logical address? Who use it? Describes a location in the logical memory address space Compiler
More informationVirtual Memory: Concepts
Virtual Memory: Concepts 5-23 / 8-23: Introduc=on to Computer Systems 6 th Lecture, Mar. 8, 24 Instructors: Anthony Rowe, Seth Goldstein, and Gregory Kesden Today VM Movaon and Address spaces ) VM as a
More informationCS162 Operating Systems and Systems Programming Lecture 12. Address Translation. Page 1
CS162 Operating Systems and Systems Programming Lecture 12 Translation March 10, 2008 Prof. Anthony D. Joseph http://inst.eecs.berkeley.edu/~cs162 Review: Important Aspects of Memory Multiplexing Controlled
More informationMain Memory: Address Translation
Main Memory: Address Translation (Chapter 8) CS 4410 Operating Systems Can t We All Just Get Along? Physical Reality: different processes/threads share the same hardware à need to multiplex CPU (temporal)
More informationVirtual Memory: Systems
Virtual Memory: Systems 5-23 / 8-23: Introduc2on to Computer Systems 7 th Lecture, Mar. 22, 22 Instructors: Todd C. Mowry & Anthony Rowe Today Virtual memory ques7ons and answers Simple memory system example
More informationCIS Operating Systems Memory Management Cache. Professor Qiang Zeng Fall 2015
CIS 5512 - Operating Systems Memory Management Cache Professor Qiang Zeng Fall 2015 Previous class What is logical address? Who use it? Describes a location in the logical address space Compiler and CPU
More informationLecture 8: Memory Management
Lecture 8: Memory Management CSE 120: Principles of Opera>ng Systems UC San Diego: Summer Session I, 2009 Frank Uyeda Announcements PeerWise ques>ons due tomorrow. Project 2 is due on Friday. Milestone
More informationAdvanced Memory Management
Advanced Memory Management Main Points Applications of memory management What can we do with ability to trap on memory references to individual pages? File systems and persistent storage Goals Abstractions
More informationCaching and Demand- Paged Virtual Memory
Caching and Demand- Paged Virtual Memory Defini8ons Cache Copy of data that is faster to access than the original Hit: if cache has copy Miss: if cache does not have copy Cache block Unit of cache storage
More informationTransla'on, Protec'on, and Virtual Memory. 2/25/16 CS 152 Sec'on 6 Colin Schmidt
Transla'on, Protec'on, and Virtual Memory 2/25/16 CS 152 Sec'on 6 Colin Schmidt Agenda Protec'on Transla'on Virtual Memory Lab 1 Feedback Ques'ons/Open-ended discussion Hand back Lab 1 Protec'on Why? Supervisor
More informationAddress Translation. Tore Larsen Material developed by: Kai Li, Princeton University
Address Translation Tore Larsen Material developed by: Kai Li, Princeton University Topics Virtual memory Virtualization Protection Address translation Base and bound Segmentation Paging Translation look-ahead
More informationCOS 318: Operating Systems. Virtual Memory and Address Translation
COS 318: Operating Systems Virtual Memory and Address Translation Andy Bavier Computer Science Department Princeton University http://www.cs.princeton.edu/courses/archive/fall10/cos318/ Today s Topics
More information16 Sharing Main Memory Segmentation and Paging
Operating Systems 64 16 Sharing Main Memory Segmentation and Paging Readings for this topic: Anderson/Dahlin Chapter 8 9; Siberschatz/Galvin Chapter 8 9 Simple uniprogramming with a single segment per
More informationPaging. Jin-Soo Kim Computer Systems Laboratory Sungkyunkwan University
Paging Jin-Soo Kim (jinsookim@skku.edu) Computer Systems Laboratory Sungkyunkwan University http://csl.skku.edu Paging Allows the physical address space of a process to be noncontiguous Divide virtual
More informationVirtual Memory. CS 351: Systems Programming Michael Saelee
Virtual Memory CS 351: Systems Programming Michael Saelee registers cache (SRAM) main memory (DRAM) local hard disk drive (HDD/SSD) remote storage (networked drive / cloud) previously: SRAM
More informationChapter 8 Virtual Memory
Chapter 8 Virtual Memory Digital Design and Computer Architecture: ARM Edi*on Sarah L. Harris and David Money Harris Digital Design and Computer Architecture: ARM Edi>on 215 Chapter 8 Chapter 8 ::
More informationAddress spaces and memory management
Address spaces and memory management Review of processes Process = one or more threads in an address space Thread = stream of executing instructions Address space = memory space used by threads Address
More informationMemory Management. Disclaimer: some slides are adopted from book authors slides with permission 1
Memory Management Disclaimer: some slides are adopted from book authors slides with permission 1 CPU management Roadmap Process, thread, synchronization, scheduling Memory management Virtual memory Disk
More information15 Sharing Main Memory Segmentation and Paging
Operating Systems 58 15 Sharing Main Memory Segmentation and Paging Readings for this topic: Anderson/Dahlin Chapter 8 9; Siberschatz/Galvin Chapter 8 9 Simple uniprogramming with a single segment per
More informationAddress Translation. Jinkyu Jeong Computer Systems Laboratory Sungkyunkwan University
Address Translation Jinkyu Jeong (jinkyu@skku.edu) Computer Systems Laboratory Sungkyunkwan University http://csl.skku.edu Today s Topics How to reduce the size of page tables? How to reduce the time for
More informationECE 571 Advanced Microprocessor-Based Design Lecture 12
ECE 571 Advanced Microprocessor-Based Design Lecture 12 Vince Weaver http://web.eece.maine.edu/~vweaver vincent.weaver@maine.edu 1 March 2018 HW#6 will be posted Project will be coming up Announcements
More informationRecap: Memory Management
, 4/13/2018 EE445M/EE360L.12 Embedded and Real-Time Systems/ Real-Time Operating Systems : Memory Protection, Virtual Memory, Paging References: T. Anderson, M. Dahlin, Operating Systems: Principles and
More informationVirtual memory Paging
Virtual memory Paging M1 MOSIG Operating System Design Renaud Lachaize Acknowledgments Many ideas and slides in these lectures were inspired by or even borrowed from the work of others: Arnaud Legrand,
More informationLecture 21: Virtual Memory. Spring 2018 Jason Tang
Lecture 21: Virtual Memory Spring 2018 Jason Tang 1 Topics Virtual addressing Page tables Translation lookaside buffer 2 Computer Organization Computer Processor Memory Devices Control Datapath Input Output
More informationChapter 8. Virtual Memory
Operating System Chapter 8. Virtual Memory Lynn Choi School of Electrical Engineering Motivated by Memory Hierarchy Principles of Locality Speed vs. size vs. cost tradeoff Locality principle Spatial Locality:
More informationCS24: INTRODUCTION TO COMPUTING SYSTEMS. Spring 2018 Lecture 24
CS24: INTRODUCTION TO COMPUTING SYSTEMS Spring 2018 Lecture 24 LAST TIME Extended virtual memory concept to be a cache of memory stored on disk DRAM becomes L4 cache of data stored on L5 disk Extend page
More informationCarnegie Mellon. Bryant and O Hallaron, Computer Systems: A Programmer s Perspective, Third Edition
Carnegie Mellon Virtual Memory: Concepts 5-23: Introduction to Computer Systems 7 th Lecture, October 24, 27 Instructor: Randy Bryant 2 Hmmm, How Does This Work?! Process Process 2 Process n Solution:
More informationVirtual Memory. Daniel Sanchez Computer Science & Artificial Intelligence Lab M.I.T. November 15, MIT Fall 2018 L20-1
Virtual Memory Daniel Sanchez Computer Science & Artificial Intelligence Lab M.I.T. L20-1 Reminder: Operating Systems Goals of OS: Protection and privacy: Processes cannot access each other s data Abstraction:
More informationRecall: Address Space Map. 13: Memory Management. Let s be reasonable. Processes Address Space. Send it to disk. Freeing up System Memory
Recall: Address Space Map 13: Memory Management Biggest Virtual Address Stack (Space for local variables etc. For each nested procedure call) Sometimes Reserved for OS Stack Pointer Last Modified: 6/21/2004
More informationCS 134: Operating Systems
CS 134: Operating Systems More Memory Management CS 134: Operating Systems More Memory Management 1 / 27 2 / 27 Overview Overview Overview Segmentation Recap Segmentation Recap Segmentation Recap Segmentation
More informationMemory Management Topics. CS 537 Lecture 11 Memory. Virtualizing Resources
Memory Management Topics CS 537 Lecture Memory Michael Swift Goals of memory management convenient abstraction for programming isolation between processes allocate scarce memory resources between competing
More informationPaging. Jinkyu Jeong Computer Systems Laboratory Sungkyunkwan University
Paging Jinkyu Jeong (jinkyu@skku.edu) Computer Systems Laboratory Sungkyunkwan University http://csl.skku.edu SSE3044: Operating Systems, Fall 2016, Jinkyu Jeong (jinkyu@skku.edu) Paging Allows the physical
More informationMulti-level Translation. CS 537 Lecture 9 Paging. Example two-level page table. Multi-level Translation Analysis
Multi-level Translation CS 57 Lecture 9 Paging Michael Swift Problem: what if you have a sparse address space e.g. out of GB, you use MB spread out need one PTE per page in virtual address space bit AS
More informationVirtual Memory. Daniel Sanchez Computer Science & Artificial Intelligence Lab M.I.T. April 12, 2018 L16-1
Virtual Memory Daniel Sanchez Computer Science & Artificial Intelligence Lab M.I.T. L16-1 Reminder: Operating Systems Goals of OS: Protection and privacy: Processes cannot access each other s data Abstraction:
More informationCS5460: Operating Systems Lecture 14: Memory Management (Chapter 8)
CS5460: Operating Systems Lecture 14: Memory Management (Chapter 8) Important from last time We re trying to build efficient virtual address spaces Why?? Virtual / physical translation is done by HW and
More informationComputer Architecture Lecture 13: Virtual Memory II
18-447 Computer Architecture Lecture 13: Virtual Memory II Lecturer: Rachata Ausavarungnirun Carnegie Mellon University Spring 2014, 2/17/2014 (with material from Onur Mutlu, Justin Meza and Yoongu Kim)
More informationVirtual Memory Virtual memory first used to relive programmers from the burden of managing overlays.
CSE420 Virtual Memory Prof. Mokhtar Aboelaze York University Based on Slides by Prof. L. Bhuyan (UCR) Prof. M. Shaaban (RIT) Virtual Memory Virtual memory first used to relive programmers from the burden
More informationAdministrivia. Lab 1 due Friday 12pm. We give will give short extensions to groups that run into trouble. But us:
Administrivia Lab 1 due Friday 12pm. We give will give short extensions to groups that run into trouble. But email us: - How much is done & left? - How much longer do you need? Attend section Friday at
More informationProcesses and Virtual Memory Concepts
Processes and Virtual Memory Concepts Brad Karp UCL Computer Science CS 37 8 th February 28 (lecture notes derived from material from Phil Gibbons, Dave O Hallaron, and Randy Bryant) Today Processes Virtual
More informationVirtual Memory: From Address Translation to Demand Paging
Constructive Computer Architecture Virtual Memory: From Address Translation to Demand Paging Arvind Computer Science & Artificial Intelligence Lab. Massachusetts Institute of Technology November 12, 2014
More informationOperating Systems (1DT020 & 1TT802) Lecture 9 Memory Management : Demand paging & page replacement. Léon Mugwaneza
Operating Systems (1DT020 & 1TT802) Lecture 9 Memory Management : Demand paging & page replacement May 05, 2008 Léon Mugwaneza http://www.it.uu.se/edu/course/homepage/os/vt08 Review: Multiprogramming (with
More informationHow to create a process? What does process look like?
How to create a process? On Unix systems, executable read by loader Compile time runtime Ken Birman ld loader Cache Compiler: generates one object file per source file Linker: combines all object files
More informationVirtual Memory II CSE 351 Spring
Virtual Memory II CSE 351 Spring 2018 https://xkcd.com/1495/ Virtual Memory (VM) Overview and motivation VM as a tool for caching Address translation VM as a tool for memory management VM as a tool for
More informationCS 152 Computer Architecture and Engineering CS252 Graduate Computer Architecture. Lecture 9 Virtual Memory
CS 152 Computer Architecture and Engineering CS252 Graduate Computer Architecture Lecture 9 Virtual Memory Krste Asanovic Electrical Engineering and Computer Sciences University of California at Berkeley
More informationComputer Systems. Virtual Memory. Han, Hwansoo
Computer Systems Virtual Memory Han, Hwansoo A System Using Physical Addressing CPU Physical address (PA) 4 Main memory : : 2: 3: 4: 5: 6: 7: 8:... M-: Data word Used in simple systems like embedded microcontrollers
More informationCPS 104 Computer Organization and Programming Lecture 20: Virtual Memory
CPS 104 Computer Organization and Programming Lecture 20: Virtual Nov. 10, 1999 Dietolf (Dee) Ramm http://www.cs.duke.edu/~dr/cps104.html CPS 104 Lecture 20.1 Outline of Today s Lecture O Virtual. 6 Paged
More informationCS162 - Operating Systems and Systems Programming. Address Translation => Paging"
CS162 - Operating Systems and Systems Programming Address Translation => Paging" David E. Culler! http://cs162.eecs.berkeley.edu/! Lecture #15! Oct 3, 2014!! Reading: A&D 8.1-2, 8.3.1. 9.7 HW 3 out (due
More informationCS 550 Operating Systems Spring Memory Management: Paging
CS 550 Operating Systems Spring 2018 Memory Management: Paging 1 Recap: Memory Management Ideally programmers want memory that is large fast non volatile Memory hierarchy small amount of fast, expensive
More informationCS 318 Principles of Operating Systems
CS 318 Principles of Operating Systems Fall 2018 Lecture 10: Virtual Memory II Ryan Huang Slides adapted from Geoff Voelker s lectures Administrivia Next Tuesday project hacking day No class My office
More informationVirtual Memory. CS61, Lecture 15. Prof. Stephen Chong October 20, 2011
Virtual Memory CS6, Lecture 5 Prof. Stephen Chong October 2, 2 Announcements Midterm review session: Monday Oct 24 5:3pm to 7pm, 6 Oxford St. room 33 Large and small group interaction 2 Wall of Flame Rob
More informationVirtual Memory. Patterson & Hennessey Chapter 5 ELEC 5200/6200 1
Virtual Memory Patterson & Hennessey Chapter 5 ELEC 5200/6200 1 Virtual Memory Use main memory as a cache for secondary (disk) storage Managed jointly by CPU hardware and the operating system (OS) Programs
More informationCSE 153 Design of Operating Systems
CSE 53 Design of Operating Systems Winter 28 Lecture 6: Paging/Virtual Memory () Some slides modified from originals by Dave O hallaron Today Address spaces VM as a tool for caching VM as a tool for memory
More informationCS24: INTRODUCTION TO COMPUTING SYSTEMS. Spring 2015 Lecture 23
CS24: INTRODUCTION TO COMPUTING SYSTEMS Spring 205 Lecture 23 LAST TIME: VIRTUAL MEMORY! Began to focus on how to virtualize memory! Instead of directly addressing physical memory, introduce a level of
More informationMemory Hierarchy. Mehran Rezaei
Memory Hierarchy Mehran Rezaei What types of memory do we have? Registers Cache (Static RAM) Main Memory (Dynamic RAM) Disk (Magnetic Disk) Option : Build It Out of Fast SRAM About 5- ns access Decoders
More informationCSE 120 Principles of Operating Systems
CSE 120 Principles of Operating Systems Spring 2018 Lecture 10: Paging Geoffrey M. Voelker Lecture Overview Today we ll cover more paging mechanisms: Optimizations Managing page tables (space) Efficient
More informationMemory Hierarchy Requirements. Three Advantages of Virtual Memory
CS61C L12 Virtual (1) CS61CL : Machine Structures Lecture #12 Virtual 2009-08-03 Jeremy Huddleston Review!! Cache design choices: "! Size of cache: speed v. capacity "! size (i.e., cache aspect ratio)
More informationECE 598 Advanced Operating Systems Lecture 14
ECE 598 Advanced Operating Systems Lecture 14 Vince Weaver http://www.eece.maine.edu/~vweaver vincent.weaver@maine.edu 22 March 2016 Announcements 1 Got a Pi3 over break Pi3 Notes Very impressive performance,
More informationVirtual to physical address translation
Virtual to physical address translation Virtual memory with paging Page table per process Page table entry includes present bit frame number modify bit flags for protection and sharing. Page tables can
More informationCPS104 Computer Organization and Programming Lecture 16: Virtual Memory. Robert Wagner
CPS104 Computer Organization and Programming Lecture 16: Virtual Memory Robert Wagner cps 104 VM.1 RW Fall 2000 Outline of Today s Lecture Virtual Memory. Paged virtual memory. Virtual to Physical translation:
More informationLecture 4: Memory Management & The Programming Interface
CS 422/522 Design & Implementation of Operating Systems Lecture 4: Memory Management & The Programming Interface Zhong Shao Dept. of Computer Science Yale University Acknowledgement: some slides are taken
More informationADRIAN PERRIG & TORSTEN HOEFLER Networks and Operating Systems ( ) Chapter 6: Demand Paging
ADRIAN PERRIG & TORSTEN HOEFLER Networks and Operating Systems (5-006-00) Chapter 6: Demand Paging http://redmine.replicant.us/projects/replicant/wiki/samsunggalaxybackdoor (0) # Inverted page table One
More informationLecture 19: Virtual Memory: Concepts
CSCI-UA.2-3 Computer Systems Organization Lecture 9: Virtual Memory: Concepts Mohamed Zahran (aka Z) mzahran@cs.nyu.edu http://www.mzahran.com Some slides adapted (and slightly modified) from: Clark Barrett
More informationVIRTUAL MEMORY II. Jo, Heeseung
VIRTUAL MEMORY II Jo, Heeseung TODAY'S TOPICS How to reduce the size of page tables? How to reduce the time for address translation? 2 PAGE TABLES Space overhead of page tables The size of the page table
More informationVirtual Memory: Concepts
Virtual Memory: Concepts 5-23: Introduction to Computer Systems 7 th Lecture, March 2, 27 Instructors: Franz Franchetti & Seth Copen Goldstein Hmmm, How Does This Work?! Process Process 2 Process n Solution:
More informationCS 61C: Great Ideas in Computer Architecture. Virtual Memory III. Instructor: Dan Garcia
CS 61C: Great Ideas in Computer Architecture Virtual Memory III Instructor: Dan Garcia 1 Agenda Review of Last Lecture Goals of Virtual Memory Page Tables TranslaFon Lookaside Buffer (TLB) Administrivia
More informationChapter 5: Memory Management
ADRIAN PERRIG & TORSTEN HOEFLER ( 252-0062-00 ) Networks and Operating Systems Chapter 5: Memory Management http://support.apple.com/kb/ht562 Description: The ios kernel has checks to validate that the
More informationECE 598 Advanced Operating Systems Lecture 14
ECE 598 Advanced Operating Systems Lecture 14 Vince Weaver http://web.eece.maine.edu/~vweaver vincent.weaver@maine.edu 22 March 2018 HW#6 was due. Announcements HW#7 will be posted eventually. Project
More informationvirtual memory. March 23, Levels in Memory Hierarchy. DRAM vs. SRAM as a Cache. Page 1. Motivation #1: DRAM a Cache for Disk
5-23 March 23, 2 Topics Motivations for VM Address translation Accelerating address translation with TLBs Pentium II/III system Motivation #: DRAM a Cache for The full address space is quite large: 32-bit
More informationLearning Outcomes. An understanding of page-based virtual memory in depth. Including the R3000 s support for virtual memory.
Virtual Memory 1 Learning Outcomes An understanding of page-based virtual memory in depth. Including the R3000 s support for virtual memory. 2 Memory Management Unit (or TLB) The position and function
More informationVirtual Memory. Virtual Memory
Virtual Memory Virtual Memory Main memory is cache for secondary storage Secondary storage (disk) holds the complete virtual address space Only a portion of the virtual address space lives in the physical
More informationChapter 6: Demand Paging
ADRIAN PERRIG & TORSTEN HOEFLER ( 5-006-00 ) Networks and Operating Systems Chapter 6: Demand Paging Source: http://redmine.replicant.us/projects/replicant/wiki/samsunggalaxybackdoor If you miss a key
More information18-447: Computer Architecture Lecture 18: Virtual Memory III. Yoongu Kim Carnegie Mellon University Spring 2013, 3/1
18-447: Computer Architecture Lecture 18: Virtual Memory III Yoongu Kim Carnegie Mellon University Spring 2013, 3/1 Upcoming Schedule Today: Lab 3 Due Today: Lecture/Recitation Monday (3/4): Lecture Q&A
More informationCS370 Operating Systems
CS370 Operating Systems Colorado State University Yashwant K Malaiya Fall 2017 Lecture 20 Main Memory Slides based on Text by Silberschatz, Galvin, Gagne Various sources 1 1 Pages Pages and frames Page
More informationUniversity of Washington Virtual memory (VM)
Virtual memory (VM) Overview and mo-va-on VM as tool for caching VM as tool for memory management VM as tool for memory protec-on Address transla-on Processes Defini=on: A process is an instance of a running
More informationLearning Outcomes. An understanding of page-based virtual memory in depth. Including the R3000 s support for virtual memory.
Virtual Memory Learning Outcomes An understanding of page-based virtual memory in depth. Including the R000 s support for virtual memory. Memory Management Unit (or TLB) The position and function of the
More informationMemory Management. Disclaimer: some slides are adopted from book authors slides with permission 1
Memory Management Disclaimer: some slides are adopted from book authors slides with permission 1 Recap Paged MMU: Two main Issues Translation speed can be slow TLB Table size is big Multi-level page table
More information238P: Operating Systems. Lecture 5: Address translation. Anton Burtsev January, 2018
238P: Operating Systems Lecture 5: Address translation Anton Burtsev January, 2018 Two programs one memory Very much like car sharing What are we aiming for? Illusion of a private address space Identical
More informationVirtual Memory 2. q Handling bigger address spaces q Speeding translation
Virtual Memory 2 q Handling bigger address spaces q Speeding translation Two considerations with page tables Mapping must be fast Done on every memory reference, at least 1 per instruction With large address
More informationSystems Programming and Computer Architecture ( ) Timothy Roscoe
Systems Group Department of Computer Science ETH Zürich Systems Programming and Computer Architecture (252-6-) Timothy Roscoe Herbstsemester 26 AS 26 Virtual Memory 8: Virtual Memory Computer Architecture
More informationHY225 Lecture 12: DRAM and Virtual Memory
HY225 Lecture 12: DRAM and irtual Memory Dimitrios S. Nikolopoulos University of Crete and FORTH-ICS May 16, 2011 Dimitrios S. Nikolopoulos Lecture 12: DRAM and irtual Memory 1 / 36 DRAM Fundamentals Random-access
More informationMulti-Process Systems: Memory (2) Memory & paging structures: free frames. Memory & paging structures. Physical memory
Multi-Process Systems: Memory (2) What we will learn A detailed description of various ways of organizing memory Discuss various memory-management techniques, including paging and segmentation To provide
More informationMemory: Page Table Structure. CSSE 332 Operating Systems Rose-Hulman Institute of Technology
Memory: Page Table Structure CSSE 332 Operating Systems Rose-Hulman Institute of Technology General address transla+on CPU virtual address data cache MMU Physical address Global memory Memory management
More informationPROCESS VIRTUAL MEMORY. CS124 Operating Systems Winter , Lecture 18
PROCESS VIRTUAL MEMORY CS124 Operating Systems Winter 2015-2016, Lecture 18 2 Programs and Memory Programs perform many interactions with memory Accessing variables stored at specific memory locations
More informationCS24: INTRODUCTION TO COMPUTING SYSTEMS. Spring 2018 Lecture 23
CS24: INTRODUCTION TO COMPUTING SYSTEMS Spring 208 Lecture 23 LAST TIME: VIRTUAL MEMORY Began to focus on how to virtualize memory Instead of directly addressing physical memory, introduce a level of indirection
More informationPROCESS VIRTUAL MEMORY PART 2. CS124 Operating Systems Winter , Lecture 19
PROCESS VIRTUAL MEMORY PART 2 CS24 Operating Systems Winter 25-26, Lecture 9 2 Virtual Memory Abstraction Last time, officially introduced concept of virtual memory Programs use virtual addresses to refer
More informationVirtual Memory: From Address Translation to Demand Paging
Constructive Computer Architecture Virtual Memory: From Address Translation to Demand Paging Arvind Computer Science & Artificial Intelligence Lab. Massachusetts Institute of Technology November 9, 2015
More informationMemory System Case Studies Oct. 13, 2008
Topics 15-213 Memory System Case Studies Oct. 13, 2008 P6 address translation x86-64 extensions Linux memory management Linux page fault handling Memory mapping Class15+.ppt Intel P6 (Bob Colwell s Chip,
More informationOutline. V Computer Systems Organization II (Honors) (Introductory Operating Systems) Advantages of Multi-level Page Tables
Outline V22.0202-001 Computer Systems Organization II (Honors) (Introductory Operating Systems) Lecture 15 Memory Management (cont d) Virtual Memory March 30, 2005 Announcements Lab 4 due next Monday (April
More informationCSE 120. Translation Lookaside Buffer (TLB) Implemented in Hardware. July 18, Day 5 Memory. Instructor: Neil Rhodes. Software TLB Management
CSE 120 July 18, 2006 Day 5 Memory Instructor: Neil Rhodes Translation Lookaside Buffer (TLB) Implemented in Hardware Cache to map virtual page numbers to page frame Associative memory: HW looks up in
More information