Review. You Are Here! Precise Traps. Terminology 8/11/15. CS 61C: Great Ideas in Computer Architecture Lecture 23: Virtual Memory Part 2
|
|
- Benedict Park
- 5 years ago
- Views:
Transcription
1 CS 6C: Great Ideas in Computer Architecture Lecture : Virtual Memory Part Instructor: Sagar Karandikar sagark@eecs.berkeley.edu Review Programmed I/O Polling vs. Interrupts BooNng a Computer BIOS, Bootloader, OS Boot, Init Supervisor Mode, Syscalls Base and Bounds Simple, but doesn t give us everything we want Intro to VM hfp://inst.eecs.berkeley.edu/~cs6c Parallel Requests Assigned to computer e.g., Search Katz Parallel Threads Assigned to core e.g., Lookup, Ads Soware Parallel InstrucNons > one Nme e.g., 5 pipelined instrucnons Parallel > data one Nme e.g., Add of 4 pairs of words Hardware descripnons All one Nme Programming Languages You Are Here! Harness Parallelism & Achieve High Performance Hardware arehouse Scale Computer Today s Lecture Core Memory Input/Output InstrucNon Unit(s) Main Memory Computer () Core Core FuncNonal Unit(s) A 0 +B 0 A +B A +B A +B Smart Phone Logic Gates Traps/Interrupts/ExecepNons: altering the normal flow of control program I i- HI I i I i+ HI HI n trap handler An external or internal event that needs to be processed by another (system) program. The event is usually unexpected or rare from program s point of view. 4 Terminology In CS6C (you ll see other defininons in use elsewhere): Interrupt caused by an event external to current running program (e.g. key press, mouse acnvity) Asynchronous to current program, can handle interrupt on any convenient instrucnon ExcepNon caused by some event during execunon of one instrucnon of current running program (e.g., page fault, illegal instrucnon) Synchronous, must handle excepnon on instrucnon that causes excepnon Trap acnon of servicing interrupt or excepnon by hardware jump to trap handler code Precise Traps Trap handler s view of machine state is that every instrucnon prior to the trapped one has completed, and no instrucnon amer the trap has executed. Implies that handler can return from an interrupt by restoring user registers and jumping to E Interrupt handler somware doesn t need to understand the pipeline of the machine, or what program was doing! More complex to handle trap caused by an excepnon Providing precise traps is tricky in a pipelined superscalar out- of- order processor! But handling imprecise interrupts in somware is even worse. 5 6
2 Trap Handling in 5- Stage Pipeline Mem address Exception D Decode E + M Illegal Opcode Asynchronous Interrupts Overflow Mem address Exceptions How to handle mulnple simultaneous excepnons in different pipeline stages? How and where to handle external asynchronous interrupts? Select Handler Save ExcepNons UnNl Commit Mem address Exception Kill F Stage D Decode E + M Exc D D Illegal Opcode Kill D Stage Exc E E Overflow Kill E Stage Exc M Commit Point Mem address Exceptions Cause E M Asynchronous Kill Interrupts riteback 7 8 Handling Traps in In- Order Pipeline Hold excepnon flags in pipeline unnl commit point (M stage) ExcepNons in earlier pipe stages override later excepnons for a given instruc>on Inject external interrupts at commit point (override others) Trap Pipeline Diagram time t0 t t t t4 t5 t6 t7.... (I ) 096: ADD IF ID EX MA - overflow! (I ) 00: XOR IF ID EX - - (I ) 04: SUB IF ID (I 4 ) 08: ADD IF (I 5 ) Trap Handler code IF 5 ID 5 EX 5 MA 5 B 5 If excepnon/interrupt at commit: update Cause and E registers, kill all stages, inject handler into fetch stage 9 0 Bare 5- Stage Pipeline D Decode E + M Virtual Memory Memory Controller Main Memory (DRAM) In a bare machine, the only kind of address is a physical address
3 hat do we need Virtual Memory for? Reason : Adding Disks to Hierarchy Need to devise a mechanism to connect memory and disk in the memory hierarchy hat do we need Virtual Memory for? Reason : Simplifying Memory for Apps ApplicaNons should see the straightorward memory layout we saw earlier - > User- space applicanons should think they own all of memory So we give them a virtual view of memory ~ FFFF FFFF hex stack heap stanc data code ~ hex 4 hat do we need Virtual Memory for? Reason : ProtecNon Between Processes ith a bare system, addresses issued with loads/ stores are real physical addresses This means any program can issue any address, therefore can access any part of memory, even areas which it doesn t own Ex: The OS data structures e should send all addresses through a mechanism that the OS controls, before they make it out to DRAM - a transla5on mechanism 5 Spaces The set of addresses labeling all of memory that we can access Now, kinds: Virtual Space - the set of addresses that the user program knows about Space - the set of addresses that map to actual physical cells in memory Hidden from user applicanons So, we need a way to map between these two address spaces 6 Blocks vs. Pages In caches, we dealt with individual blocks Usually ~64B on modern systems e could divide memory into a set of blocks In VM, we deal with individual pages Usually ~4 KiB on modern systems Now, we ll divide memory into a set of pages Common point of confusion: Bytes, ords, Blocks, Pages are all just different ways of looking at memory! 6 KiB Bytes, ords, Blocks, Pages 6 KiB DRAM, 4 KiB Pages (for VM), 8 B blocks (for caches), 4 B words (for lw/sw) Memory Page Can think of Page memory as: - 4 Pages OR - 8 Blocks Page OR ords Page 0 Page Block Block ord Can think of a page as: - Blocks OR - 04 ords 7 Block 0 ord 0 8
4 TranslaNon TranslaNon So, what do we want to achieve at the hardware level? Take a Virtual, that points to a spot in the Virtual Space of a parncular program, and map it to a, which points to a physical spot in DRAM of the whole machine Virtual Virtual Page Number TranslaNon Page Number Copy Bits Virtual Virtual Page Number The rest of the lecture is all about implemennng Page Number 9 0 Processor- generated address can be split into: 0 Space of Program # Paged Memory Systems Virtual Page Number 0 of Program # 0 Page tables make it possible to store the pages of a program non-contiguously. A page table contains the physical address of the base of each page Memory Prog Prog Prog Private (Virtual) Space per Program Each prog has a page table Page table contains an entry for each prog page OS pages free Memory here Should s Reside? Space required by the page tables (PT) is propornonal to the address space, number of users,... Too large to keep in registers inside CPU Idea: Keep page tables in the main memory Needs one reference to retrieve the page base address and another to access the data word doubles the number of memory references! (but we can fix this using something we already know about ) s in Memory Prog Virtual Space Prog Virtual Space PT Prog PT Prog Memory 4 4
5 Administrivia Project - due tonight Project 4 out now CompeNNon for glory + EC, awards during last lecture H6 Out VM, I/O, Parity, ECC Guerrilla SecNon on VM, I/O, ECC, on Thursday from 5-7pm, oz Sign up for tutoring on Piazza 5 Administrivia Upcoming Lecture Schedule 8/0: VM (today) 8/04: I/O: DMA, Disks, Networking 8/05: Dependability: Parity, ECC, RAID Last day of new material 8/06: Final Exam Review, Day (Formerly GPUs) 8/0: Final Exam Review, Day (Formerly tools) 8/: Summary, hat s Next? (+ HKN reviews) Project 4 CompeNNon inners Announced 8/: No Lecture, I ll have OH in this room 6 Administrivia Final Exam is next Thursday (8/) 9am- pm, 0 Evans More info soon CS6C In the News: Moore s Law s 50 th Anniversary this year! Gordon Moore s paper appeared in 9 April 965 issue of Electronics. ith unit cost falling as the number of components per circuit rises, by 975 economics may dictate squeezing as many as 65,000 components on a single silicon chip. Today: 8- core Intel Xeon Haswell- E billion transistors on a chip 7 8 Break Linear Entry (PTE) contains: bit to indicate if page exists And either or : (physical page number) for a memory- resident page (disk page number) for a page on the disk Status bits for protecnon and usage (read, write, exec) OS sets the Base Register whenever acnve user process changes PT Base Register VPN Virtual address 9 0 VPN Pages word 5
6 hat if the page isn t in DRAM? e get a page fault : IniNate transfer of the page we re requesnng from disk to DRAM, should place it into an unused page If no unused page is lem, a page currently in DRAM is selected to be replaced (based on usage) The replaced page is wrifen back to disk, page table entry that maps that VPN- > is marked as invalid Page table entry of the page we re requesnng is updated with a (now) valid Size of Linear ith - bit addresses, 4- KB pages & 4- byte PTEs: 0 PTEs, i.e, 4 MB page table per user 4 GB of swap needed to back up full virtual address space Larger pages? Internal fragmentanon (Not all memory in page is used) Larger page fault penalty (more Nme to read from disk) hat about 64- bit virtual address space??? Even MB pages would require byte PTEs (5 TB!) hat is the saving grace? Root of the Current Hierarchical Virtual p p offset 0-bit 0-bit L index L index (Processor Register) p Level page in primary memory page in secondary memory PTE of a nonexistent page 0 p Level s offset Pages Memory Two- Level s in Memory Virtual Spaces User User Level PT User Memory User/ User/ Level PT User Level PT User 4 TranslaNon & ProtecNon Kernel/User Mode Read/rite Exception? Virtual Virtual Page No. (VPN) Protection Check Translation Page No. () offset offset TranslaNon Lookaside Buffers () translation is very expensive! In a two-level page table, each reference becomes several memory accesses Solution: translations in hit Single-Cycle Translation miss Page-Table alk to refill virtual address VPN offset Every instruction and data access needs address translation and protection checks A good VM design needs to be fast (~ one cycle) and space efficient V R D tag (VPN = virtual page number) ( = physical page number) hit? physical address offset 5 6 6
7 Designs Typically - 8 entries, usually fully associanve Each entry maps a large page, hence less spanal locality across pages è more likely that two entries conflict SomeNmes larger s (56-5 entries) are 4-8 way set- associanve Larger systems somenmes have muln- level (L and L) s Random or FIFO replacement policy No process informanon in? Reach: Size of largest virtual address space that can be simultaneously mapped by Example: 64 entries, 4KB pages, one page per entry Reach =? 7 VM- related events in pipeline Inst miss? Page Fault? Protection violation? D Decode E + M miss? Page Fault? Protection violation? Handling a miss needs a hardware or somware mechanism to refill usually done in hardware now Handling a page fault (e.g., page is on disk) needs a precise trap so somware handler can easily resume amer retrieving page Handling protecnon violanon may abort process 8 Hierarchical alk: SPARC v8 Virtual Index Index Index 7 0 Context Context Table Table Register L Table Context root ptr Register L Table PTP L Table PTP PTE 0 MMU does this table walk in hardware on a miss 9 Page- Based Virtual- Memory Machine (Hardware Page- Table alk) Page Fault? Protec>on viola>on? Virtual Miss? D Decode E + M P Register Memory Controller Main Memory (DRAM) Page Fault? Protec>on viola>on? Virtual Miss? Hardware Page Table alker Assumes page tables held in untranslated physical memory 40 TranslaNon: pu]ng it all together Virtual alk Page Fault (OS loads page) miss Lookup Update Protection Check the page is memory memory denied permitted here? hit hardware hardware or software software Protection Fault SEGFAULT (to cache) 4 Modern Virtual Memory Systems Illusion of a large, private, uniform store Protection & Privacy several users, each with their private address space and one or more shared address spaces page table name space Demand Paging Provides the ability to run programs larger than the primary memory Hides differences in machine configurations The price is address translation on each memory reference OS user i Swapping Store (Disk) Primary Memory VA mapping PA 4 7
8 Clicker QuesNon Let s try to extrapolate from caches hich one is false? A. # offset bits in V.A. = log(page size) B. # offset bits in P.A. = log(page size) C. # VPN bits in V.A. = log(# of physical pages) D. # bits in P.A. = log(# of physical pages) E. A single- level page table contains a PTE for every possible VPN in the system Conclusion: VM features track historical uses Bare machine, only physical addresses One program owned ennre machine Batch- style mul5programming Several programs sharing CPU while wainng for I/O Base & bound: translanon and protecnon between programs (not virtual memory) Problem with external fragmentanon (holes in memory), needed occasional memory defragmentanon as new jobs arrived Time sharing More interacnve programs, wainng for user. Also, more jobs/second. MoNvated move to fixed- size page translanon and protecnon, no external fragmentanon (but now internal fragmentanon, wasted bytes in page) MoNvated adopnon of virtual memory to allow more jobs to share limited physical memory resources while holding working set in memory Virtual Machine Monitors Run mulnple operanng systems on one machine Idea from 970s IBM mainframes, now common on laptops e.g., run indows on top of Mac OS X Hardware support for two levels of translanon/protecnon Guest OS virtual - > Guest OS physical - > Host machine physical Also basis of Cloud CompuNng 4 Virtual machine instances on EC for Lab 44 8
CS 61C: Great Ideas in Computer Architecture Virtual Memory. Instructors: John Wawrzynek & Vladimir Stojanovic
CS 61C: Great Ideas in Computer Architecture Virtual Memory Instructors: John Wawrzynek & Vladimir Stojanovic http://inst.eecs.berkeley.edu/~cs61c/ 1 Review Programmed I/O Polling vs. Interrupts Booting
More informationJohn Wawrzynek & Nick Weaver
CS 61C: Great Ideas in Computer Architecture Lecture 23: Virtual Memory John Wawrzynek & Nick Weaver http://inst.eecs.berkeley.edu/~cs61c From Previous Lecture: Operating Systems Input / output (I/O) Memory
More informationCS 61C: Great Ideas in Computer Architecture Virtual Memory. Instructors: Krste Asanovic & Vladimir Stojanovic h>p://inst.eecs.berkeley.
CS 61C: Great Ideas in Computer Architecture Virtual Memory Instructors: Krste Asanovic & Vladimir Stojanovic h>p://inst.eecs.berkeley.edu/~cs61c/ 1 Programmed I/O Review Polling versus Interrupts Asynchronous
More informationCS 61C: Great Ideas in Computer Architecture. Lecture 23: Virtual Memory. Bernhard Boser & Randy Katz
CS 61C: Great Ideas in Computer Architecture Lecture 23: Virtual Memory Bernhard Boser & Randy Katz http://inst.eecs.berkeley.edu/~cs61c Agenda Virtual Memory Paged Physical Memory Swap Space Page Faults
More informationCS 61C: Great Ideas in Computer Architecture. Lecture 23: Virtual Memory
CS 61C: Great Ideas in Computer Architecture Lecture 23: Virtual Memory Krste Asanović & Randy H. Katz http://inst.eecs.berkeley.edu/~cs61c/fa17 1 Agenda Virtual Memory Paged Physical Memory Swap Space
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 informationecture 33 Virtual Memory Friedland and Weaver Computer Science 61C Spring 2017 April 12th, 2017
ecture 33 Computer Science 61C Spring 2017 April 12th, 2017 Virtual Memory 1 Multiprogramming The OS runs multiple applications at the same time. But not really: have many more processes/threads than available
More informationCS 61C: Great Ideas in Computer Architecture (Machine Structures) Intro to Virtual Memory
CS 61C: Great Ideas in Computer Architecture (Machine Structures) Intro to Virtual Memory Instructors: Vladimir Stojanovic and Nicholas Weaver http://inst.eecs.berkeley.edu/~cs61c/ 1 Agenda Multiprogramming/time-sharing
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 informationModern Virtual Memory Systems. Modern Virtual Memory Systems
6.823, L12--1 Modern Virtual Systems Asanovic Laboratory for Computer Science M.I.T. http://www.csg.lcs.mit.edu/6.823 6.823, L12--2 Modern Virtual Systems illusion of a large, private, uniform store Protection
More informationCS 61C: Great Ideas in Computer Architecture Excep&ons/Traps/Interrupts. Smart Phone. Core. FuncWonal Unit(s) Logic Gates
CS 6C: Great Ideas in Computer Architecture Excep&ons/Traps/Interrupts Instructors: Krste Asanovic, Randy H. Katz hcp://inst.eecs.berkeley.edu/~cs6c/fa Review Programmed I/O versus DMA Polling versus Interrupts
More informationCS 152 Computer Architecture and Engineering. Lecture 8 - Address Translation
CS 152 Computer Architecture and Engineering Lecture 8 - Translation Krste Asanovic Electrical Engineering and Computer Sciences University of California at Berkeley http://www.eecs.berkeley.edu/~krste!
More informationCS 152 Computer Architecture and Engineering. Lecture 8 - Address Translation
CS 152 Computer Architecture and Engineering Lecture 8 - Translation Krste Asanovic Electrical Engineering and Computer Sciences University of California at Berkeley http://www.eecs.berkeley.edu/~krste!
More informationCS 152 Computer Architecture and Engineering. Lecture 9 - Address Translation
CS 152 Computer Architecture and Engineering Lecture 9 - Address Translation Krste Asanovic Electrical Engineering and Computer Sciences University of California at Berkeley http://www.eecs.berkeley.edu/~krste!
More informationCS 152 Computer Architecture and Engineering. Lecture 11 - Virtual Memory and Caches
CS 152 Computer Architecture and Engineering Lecture 11 - Virtual Memory and Caches Krste Asanovic Electrical Engineering and Computer Sciences University of California at Berkeley http://www.eecs.berkeley.edu/~krste
More informationCS 152 Computer Architecture and Engineering. Lecture 9 - Virtual Memory
CS 152 Computer Architecture and Engineering Lecture 9 - Virtual Memory Krste Asanovic Electrical Engineering and Computer Sciences University of California at Berkeley http://www.eecs.berkeley.edu/~krste!
More informationCS 152 Computer Architecture and Engineering. Lecture 9 - Address Translation
CS 152 Computer Architecture and Engineering Lecture 9 - Address Translation Krste Asanovic Electrical Engineering and Computer Sciences University of California at Berkeley http://www.eecs.berkeley.edu/~krste
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 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 informationLecture 9 - Virtual Memory
CS 152 Computer Architecture and Engineering Lecture 9 - Virtual Memory Dr. George Michelogiannakis EECS, University of California at Berkeley CRD, Lawrence Berkeley National Laboratory http://inst.eecs.berkeley.edu/~cs152
More informationNew-School Machine Structures. Overarching Theme for Today. Agenda. Review: Memory Management. The Problem 8/1/2011
CS 61C: Great Ideas in Computer Architecture (Machine Structures) Virtual Instructor: Michael Greenbaum 1 New-School Machine Structures Software Parallel Requests Assigned to computer e.g., Search Katz
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 informationChapter 5B. Large and Fast: Exploiting Memory Hierarchy
Chapter 5B Large and Fast: Exploiting Memory Hierarchy One Transistor Dynamic RAM 1-T DRAM Cell word access transistor V REF TiN top electrode (V REF ) Ta 2 O 5 dielectric bit Storage capacitor (FET gate,
More informationLecture 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 informationCS 152 Computer Architecture and Engineering. Lecture 9 - Virtual Memory. Last?me in Lecture 9
CS 152 Computer Architecture and Engineering Lecture 9 - Krste Asanovic Electrical Engineering and Computer Sciences University of California at Berkeley http://www.eecs.berkeley.edu/~krste! http://inst.eecs.berkeley.edu/~cs152!
More informationLast =me in Lecture 7 3 C s of cache misses Compulsory, Capacity, Conflict
CS 152 Computer Architecture and Engineering Lecture 8 - Transla=on Krste Asanovic Electrical Engineering and Computer Sciences University of California at Berkeley http://www.eecs.berkeley.edu/~krste!
More informationAgenda. CS 61C: Great Ideas in Computer Architecture. Virtual Memory II. Goals of Virtual Memory. Memory Hierarchy Requirements
CS 61C: Great Ideas in Computer Architecture Virtual II Guest Lecturer: Justin Hsia Agenda Review of Last Lecture Goals of Virtual Page Tables Translation Lookaside Buffer (TLB) Administrivia VM Performance
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 informationCS 152 Computer Architecture and Engineering CS252 Graduate Computer Architecture. Lecture 8 Address Transla>on
CS 5 Computer Architecture and Engineering CS5 Graduate Computer Architecture Lecture 8 Transla>on Krste Asanovic Electrical Engineering and Computer Sciences University of California at Berkeley http://www.eecs.berkeley.edu/~krste
More informationCS 61C: Great Ideas in Computer Architecture. Virtual Memory
CS 61C: Great Ideas in Computer Architecture Virtual Memory Instructor: Justin Hsia 7/30/2012 Summer 2012 Lecture #24 1 Review of Last Lecture (1/2) Multiple instruction issue increases max speedup, but
More informationVirtual Memory. Motivations for VM Address translation Accelerating translation with TLBs
Virtual Memory Today Motivations for VM Address translation Accelerating translation with TLBs Fabián Chris E. Bustamante, Riesbeck, Fall Spring 2007 2007 A system with physical memory only Addresses generated
More informationCS 152 Computer Architecture and Engineering
CS 152 Computer Architecture and Engineering Lecture 12 -- Virtual Memory 2014-2-27 John Lazzaro (not a prof - John is always OK) TA: Eric Love www-inst.eecs.berkeley.edu/~cs152/ Play: CS 152 L12: Virtual
More informationCOSC3330 Computer Architecture Lecture 20. Virtual Memory
COSC3330 Computer Architecture Lecture 20. Virtual Memory Instructor: Weidong Shi (Larry), PhD Computer Science Department University of Houston Virtual Memory Topics Reducing Cache Miss Penalty (#2) Use
More informationCS252 Spring 2017 Graduate Computer Architecture. Lecture 17: Virtual Memory and Caches
CS252 Spring 2017 Graduate Computer Architecture Lecture 17: Virtual Memory and Caches Lisa Wu, Krste Asanovic http://inst.eecs.berkeley.edu/~cs252/sp17 WU UCB CS252 SP17 Last Time in Lecture 16 Memory
More information@2010 Badri Computer Architecture Assembly II. Virtual Memory. Topics (Chapter 9) Motivations for VM Address translation
Virtual Memory Topics (Chapter 9) Motivations for VM Address translation 1 Motivations for Virtual Memory Use Physical DRAM as a Cache for the Disk Address space of a process can exceed physical memory
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 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 informationCSE 560 Computer Systems Architecture
This Unit: CSE 560 Computer Systems Architecture App App App System software Mem I/O The operating system () A super-application Hardware support for an Page tables and address translation s and hierarchy
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 informationCSE 120 Principles of Operating Systems Spring 2017
CSE 120 Principles of Operating Systems Spring 2017 Lecture 12: Paging Lecture Overview Today we ll cover more paging mechanisms: Optimizations Managing page tables (space) Efficient translations (TLBs)
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 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 informationCS 61C: Great Ideas in Computer Architecture (Machine Structures) Caches Part 3
CS 61C: Great Ideas in Computer Architecture (Machine Structures) Caches Part 3 Instructors: Bernhard Boser & Randy H. Katz http://inst.eecs.berkeley.edu/~cs61c/ 10/24/16 Fall 2016 - Lecture #16 1 Software
More informationvirtual memory Page 1 CSE 361S Disk Disk
CSE 36S Motivations for Use DRAM a for the Address space of a process can exceed physical memory size Sum of address spaces of multiple processes can exceed physical memory Simplify Management 2 Multiple
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 information10/19/17. You Are Here! Review: Direct-Mapped Cache. Typical Memory Hierarchy
CS 6C: Great Ideas in Computer Architecture (Machine Structures) Caches Part 3 Instructors: Krste Asanović & Randy H Katz http://insteecsberkeleyedu/~cs6c/ Parallel Requests Assigned to computer eg, Search
More information14 May 2012 Virtual Memory. Definition: A process is an instance of a running program
Virtual Memory (VM) Overview and motivation VM as tool for caching VM as tool for memory management VM as tool for memory protection Address translation 4 May 22 Virtual Memory Processes Definition: A
More informationVirtual Memory Oct. 29, 2002
5-23 The course that gives CMU its Zip! Virtual Memory Oct. 29, 22 Topics Motivations for VM Address translation Accelerating translation with TLBs class9.ppt Motivations for Virtual Memory Use Physical
More informationCS 61C: Great Ideas in Computer Architecture. Lecture 22: Operating Systems. Krste Asanović & Randy H. Katz
CS 61C: Great Ideas in Computer Architecture Lecture 22: Operating Systems Krste Asanović & Randy H. Katz http://inst.eecs.berkeley.edu/~cs61c/fa17 1 CPU Project 2 CS61C so far MIPS Assembly.foo lw $t0,
More informationCS162 Operating Systems and Systems Programming Lecture 14. Caching (Finished), Demand Paging
CS162 Operating Systems and Systems Programming Lecture 14 Caching (Finished), Demand Paging October 11 th, 2017 Neeraja J. Yadwadkar http://cs162.eecs.berkeley.edu Recall: Caching Concept Cache: a repository
More informationRandom-Access Memory (RAM) Systemprogrammering 2007 Föreläsning 4 Virtual Memory. Locality. The CPU-Memory Gap. Topics
Systemprogrammering 27 Föreläsning 4 Topics The memory hierarchy Motivations for VM Address translation Accelerating translation with TLBs Random-Access (RAM) Key features RAM is packaged as a chip. Basic
More information11/13/17. CS61C so far. Adding I/O C Programs. So How is a Laptop Any Different? It s a Real Computer! Raspberry Pi (Less than $40 on Amazon in 2017)
11/14/17 CS61C so far CS 61C: Great Ideas in Computer Architecture C Programs #include MIPS Assembly Project 2 int fib(int n) { return fib(n-1) + fib(n-2); }.foo lw $t0, 4($r0) addi $t1, $t0,
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 informationRandom-Access Memory (RAM) Systemprogrammering 2009 Föreläsning 4 Virtual Memory. Locality. The CPU-Memory Gap. Topics! The memory hierarchy
Systemprogrammering 29 Föreläsning 4 Topics! The memory hierarchy! Motivations for VM! Address translation! Accelerating translation with TLBs Random-Access (RAM) Key features! RAM is packaged as a chip.!
More informationAnother View of the Memory Hierarchy. Lecture #25 Virtual Memory I Memory Hierarchy Requirements. Memory Hierarchy Requirements
CS61C L25 Virtual I (1) inst.eecs.berkeley.edu/~cs61c CS61C : Machine Structures Lecture #25 Virtual I 27-8-7 Scott Beamer, Instructor Another View of the Hierarchy Thus far{ Next: Virtual { Regs Instr.
More informationCS 61C: Great Ideas in Computer Architecture (Machine Structures) Caches Part 3
CS 61C: Great Ideas in Computer Architecture (Machine Structures) Caches Part 3 Instructors: Krste Asanović & Randy H. Katz http://inst.eecs.berkeley.edu/~cs61c/ 10/19/17 Fall 2017 - Lecture #16 1 Parallel
More information198:231 Intro to Computer Organization. 198:231 Introduction to Computer Organization Lecture 14
98:23 Intro to Computer Organization Lecture 4 Virtual Memory 98:23 Introduction to Computer Organization Lecture 4 Instructor: Nicole Hynes nicole.hynes@rutgers.edu Credits: Several slides courtesy of
More informationTopics: Memory Management (SGG, Chapter 08) 8.1, 8.2, 8.3, 8.5, 8.6 CS 3733 Operating Systems
Topics: Memory Management (SGG, Chapter 08) 8.1, 8.2, 8.3, 8.5, 8.6 CS 3733 Operating Systems Instructor: Dr. Turgay Korkmaz Department Computer Science The University of Texas at San Antonio Office: NPB
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 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 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 informationCSE 451: Operating Systems Winter Page Table Management, TLBs and Other Pragmatics. Gary Kimura
CSE 451: Operating Systems Winter 2013 Page Table Management, TLBs and Other Pragmatics Gary Kimura Moving now from Hardware to how the OS manages memory Two main areas to discuss Page table management,
More informationLast 2 Classes: Introduction to Operating Systems & C++ tutorial. Today: OS and Computer Architecture
Last 2 Classes: Introduction to Operating Systems & C++ tutorial User apps OS Virtual machine interface hardware physical machine interface An operating system is the interface between the user and the
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 informationGuerrilla 7: Virtual Memory, ECC, IO
Guerrilla 7:, August 4, 2016 Guerrilla 7:, Guerrilla 7:, Why do we need? Guerrilla 7:, Why do we need? Give each program the illusion that it has its own private address space. Provide protection between
More informationOperating Systems CMPSCI 377 Spring Mark Corner University of Massachusetts Amherst
Operating Systems CMPSCI 377 Spring 2017 Mark Corner University of Massachusetts Amherst Last Class: Intro to OS An operating system is the interface between the user and the architecture. User-level Applications
More informationMotivations for Virtual Memory Virtual Memory Oct. 29, Why VM Works? Motivation #1: DRAM a Cache for Disk
class8.ppt 5-23 The course that gives CMU its Zip! Virtual Oct. 29, 22 Topics Motivations for VM Address translation Accelerating translation with TLBs Motivations for Virtual Use Physical DRAM as a Cache
More informationMemory Hierarchy, Fully Associative Caches. Instructor: Nick Riasanovsky
Memory Hierarchy, Fully Associative Caches Instructor: Nick Riasanovsky Review Hazards reduce effectiveness of pipelining Cause stalls/bubbles Structural Hazards Conflict in use of datapath component Data
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 informationCISC 360. Virtual Memory Dec. 4, 2008
CISC 36 Virtual Dec. 4, 28 Topics Motivations for VM Address translation Accelerating translation with TLBs Motivations for Virtual Use Physical DRAM as a Cache for the Disk Address space of a process
More informationVirtual Memory II. CSE 351 Autumn Instructor: Justin Hsia
Virtual Memory II CSE 35 Autumn 26 Instructor: Justin Hsia Teaching Assistants: Chris Ma Hunter Zahn John Kaltenbach Kevin Bi Sachin Mehta Suraj Bhat Thomas Neuman Waylon Huang Xi Liu Yufang Sun https://xkcd.com/495/
More informationCOEN-4730 Computer Architecture Lecture 3 Review of Caches and Virtual Memory
1 COEN-4730 Computer Architecture Lecture 3 Review of Caches and Virtual Memory Cristinel Ababei Dept. of Electrical and Computer Engineering Marquette University Credits: Slides adapted from presentations
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 information18-447: Computer Architecture Lecture 16: Virtual Memory
18-447: Computer Architecture Lecture 16: Virtual Memory Justin Meza Carnegie Mellon University (with material from Onur Mutlu, Michael Papamichael, and Vivek Seshadri) 1 Notes HW 2 and Lab 2 grades will
More informationReview: Performance Latency vs. Throughput. Time (seconds/program) is performance measure Instructions Clock cycles Seconds.
Performance 980 98 982 983 984 985 986 987 988 989 990 99 992 993 994 995 996 997 998 999 2000 7/4/20 CS 6C: Great Ideas in Computer Architecture (Machine Structures) Caches Instructor: Michael Greenbaum
More informationComputer Architecture and Engineering. CS152 Quiz #3. March 18th, Professor Krste Asanovic. Name:
Computer Architecture and Engineering CS152 Quiz #3 March 18th, 2008 Professor Krste Asanovic Name: Notes: This is a closed book, closed notes exam. 80 Minutes 10 Pages Not all questions are of equal difficulty,
More informationCS 61C: Great Ideas in Computer Architecture (Machine Structures) Caches Part 3
CS 61C: Great Ideas in Computer Architecture (Machine Structures) Caches Part 3 Instructors: Krste Asanovic & Vladimir Stojanovic hfp://inst.eecs.berkeley.edu/~cs61c/ Parallel Requests Assigned to computer
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 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 informationCS 61C: Great Ideas in Computer Architecture Lecture 22: Opera&ng Systems, Interrupts, and Virtual Memory Part 1
CS 61C: Great Ideas in Computer Architecture Lecture 22: Opera&ng Systems, Interrupts, and Virtual Memory Part 1 Instructor: Sagar Karandikar sagark@eecs.berkeley.edu hbp://inst.eecs.berkeley.edu/~cs61c
More informationVirtual Memory Nov 9, 2009"
Virtual Memory Nov 9, 2009" Administrivia" 2! 3! Motivations for Virtual Memory" Motivation #1: DRAM a Cache for Disk" SRAM" DRAM" Disk" 4! Levels in Memory Hierarchy" cache! virtual memory! CPU" regs"
More informationPart I: You Are Here!
CS 61C: Great Ideas in Computer Architecture VM 2 : Virtual Memory and Machines Instructor: Randy H. Katz hbp://inst.eecs.berkeley.edu/~cs61c/fa13 1 Parallel Requests Assigned to computer e.g., Search
More informationCSE 351. Virtual Memory
CSE 351 Virtual Memory Virtual Memory Very powerful layer of indirection on top of physical memory addressing We never actually use physical addresses when writing programs Every address, pointer, etc
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 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 informationCS 153 Design of Operating Systems Winter 2016
CS 153 Design of Operating Systems Winter 2016 Lecture 16: Memory Management and Paging Announcement Homework 2 is out To be posted on ilearn today Due in a week (the end of Feb 19 th ). 2 Recap: Fixed
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 informationPOLITECNICO DI MILANO. Exception handling. Donatella Sciuto:
POLITECNICO DI MILANO Exception handling Donatella Sciuto: donatella.sciuto@polimi.it Interrupts: altering the normal flow of control I i-1 HI 1 program I i HI 2 interrupt handler I i+1 HI n An external
More informationShow Me the $... Performance And Caches
Show Me the $... Performance And Caches 1 CPU-Cache Interaction (5-stage pipeline) PCen 0x4 Add bubble PC addr inst hit? Primary Instruction Cache IR D To Memory Control Decode, Register Fetch E A B MD1
More informationPage 1. Review: Address Segmentation " Review: Address Segmentation " Review: Address Segmentation "
Review Address Segmentation " CS162 Operating Systems and Systems Programming Lecture 10 Caches and TLBs" February 23, 2011! Ion Stoica! http//inst.eecs.berkeley.edu/~cs162! 1111 0000" 1110 000" Seg #"
More informationChapter 8 Memory Management
Chapter 8 Memory Management Da-Wei Chang CSIE.NCKU Source: Abraham Silberschatz, Peter B. Galvin, and Greg Gagne, "Operating System Concepts", 9th Edition, Wiley. 1 Outline Background Swapping Contiguous
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 informationMo Money, No Problems: Caches #2...
Mo Money, No Problems: Caches #2... 1 Reminder: Cache Terms... Cache: A small and fast memory used to increase the performance of accessing a big and slow memory Uses temporal locality: The tendency to
More informationCS 61C: Great Ideas in Computer Architecture Direct- Mapped Caches. Increasing distance from processor, decreasing speed.
CS 6C: Great Ideas in Computer Architecture Direct- Mapped s 9/27/2 Instructors: Krste Asanovic, Randy H Katz hdp://insteecsberkeleyedu/~cs6c/fa2 Fall 2 - - Lecture #4 New- School Machine Structures (It
More informationCS 61C: Great Ideas in Computer Architecture (Machine Structures) Caches Part 3
CS 61C: Great Ideas in Computer Architecture (Machine Structures) Caches Part 3 Instructors: Krste Asanovic & Vladimir Stojanovic hcp://inst.eecs.berkeley.edu/~cs61c/ So$ware Parallel Requests Assigned
More informationCS162 Operating Systems and Systems Programming Lecture 14. Caching and Demand Paging
CS162 Operating Systems and Systems Programming Lecture 14 Caching and Demand Paging October 17, 2007 Prof. John Kubiatowicz http://inst.eecs.berkeley.edu/~cs162 Review: Hierarchy of a Modern Computer
More informationCS162 Operating Systems and Systems Programming Lecture 10 Caches and TLBs"
CS162 Operating Systems and Systems Programming Lecture 10 Caches and TLBs" October 1, 2012! Prashanth Mohan!! Slides from Anthony Joseph and Ion Stoica! http://inst.eecs.berkeley.edu/~cs162! Caching!
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 informationVirtual Memory II. CSE 351 Autumn Instructor: Justin Hsia
Virtual Memory II CSE 35 Autumn 27 Instructor: Justin Hsia Teaching Assistants: Lucas Wotton Michael Zhang Parker DeWilde Ryan Wong Sam Gehman Sam Wolfson Savanna Yee Vinny Palaniappan https://xkcd.com/495/
More informationRaspberry Pi ($40 on Amazon)
7/28/15 CS 61C: Great Ideas in Computer Architecture CS61C so far C Programs #include Instructor: Sagar Karandikar sagark@eecs.berkeley.edu hfp://inst.eecs.berkeley.edu/~cs61c Project 2 int
More information