Virtual Memory. Cache memory enhances performance by providing faster memory access speed. Virtual memory enhances performance by providing greater memory.

Slides:



Advertisements
Similar presentations
OS Fall’02 Virtual Memory Operating Systems Fall 2002.
Advertisements

Segmentation and Paging Considerations
Lecture 34: Chapter 5 Today’s topic –Virtual Memories 1.
Chapter 6 Memory.
Cs 325 virtualmemory.1 Accessing Caches in Virtual Memory Environment.
Memory/Storage Architecture Lab Computer Architecture Virtual Memory.
Memory Management Norman White Stern School of Business.
Operating System Support Focus on Architecture
Memory Management and Paging CSCI 3753 Operating Systems Spring 2005 Prof. Rick Han.
Paging and Virtual Memory. Memory management: Review  Fixed partitioning, dynamic partitioning  Problems Internal/external fragmentation A process can.
Memory Management 2010.
Memory Organization.
Chapter 3.2 : Virtual Memory
1 Chapter 8 Virtual Memory Virtual memory is a storage allocation scheme in which secondary memory can be addressed as though it were part of main memory.
Chapter 9 Virtual Memory Produced by Lemlem Kebede Monday, July 16, 2001.
Computer Organization Cs 147 Prof. Lee Azita Keshmiri.
©UCB CS 162 Ch 7: Virtual Memory LECTURE 13 Instructor: L.N. Bhuyan
Computer Organization and Architecture
Virtual Memory I Chapter 8.
A. Frank - P. Weisberg Operating Systems Simple/Basic Paging.
03/17/2008CSCI 315 Operating Systems Design1 Virtual Memory Notice: The slides for this lecture have been largely based on those accompanying the textbook.
VIRTUAL MEMORY. Virtual memory technique is used to extents the size of physical memory When a program does not completely fit into the main memory, it.
Chapter 6 Memory.
Chapter 6 Memory.
Virtual Memory Chantha Thoeun. Overview  Purpose:  Use the hard disk as an extension of RAM.  Increase the available address space of a process. 
Memory Systems Architecture and Hierarchical Memory Systems
Rensselaer Polytechnic Institute CSC 432 – Operating Systems David Goldschmidt, Ph.D.
Silberschatz, Galvin and Gagne  2002 Modified for CSCI 346, Royden, Operating System Concepts Operating Systems Lecture 24 Paging.
Lecture 21 Last lecture Today’s lecture Cache Memory Virtual memory
Memory. 2 Objectives Master the concepts of hierarchical memory organization. Understand how each level of memory contributes to system performance, and.
Topics covered: Memory subsystem CSE243: Introduction to Computer Architecture and Hardware/Software Interface.
Lecture 19: Virtual Memory
8.4 paging Paging is a memory-management scheme that permits the physical address space of a process to be non-contiguous. The basic method for implementation.
Cosc 2150: Computer Organization Chapter 6, Part 2 Virtual Memory.
1 Chapter 3.2 : Virtual Memory What is virtual memory? What is virtual memory? Virtual memory management schemes Virtual memory management schemes Paging.
IT253: Computer Organization
Memory Management – Page 1 of 49CSCI 4717 – Computer Architecture Memory Management Uni-program – memory split into two parts –One for Operating System.
By Teacher Asma Aleisa Year 1433 H.   Goals of memory management  To provide a convenient abstraction for programming  To allocate scarce memory resources.
Fall 2000M.B. Ibáñez Lecture 17 Paging Hardware Support.
Chapter 6 Memory Introduction Memory lies at the heart of the stored-program computer In previous chapters, we studied the components from which.
1 Virtual Memory Main memory can act as a cache for the secondary storage (disk) Advantages: –illusion of having more physical memory –program relocation.
Chapter 6 Memory. 2 Chapter 6 Objectives Master the concepts of hierarchical memory organization. Understand how each level of memory contributes to system.
Virtual Memory. Virtual Memory: Topics Why virtual memory? Virtual to physical address translation Page Table Translation Lookaside Buffer (TLB)
By Teacher Asma Aleisa Year 1433 H.   Goals of memory management  To provide a convenient abstraction for programming.  To allocate scarce memory.
Virtual Memory 1 1.
Multilevel Caches Microprocessors are getting faster and including a small high speed cache on the same chip.
Paging Paging is a memory-management scheme that permits the physical-address space of a process to be noncontiguous. Paging avoids the considerable problem.
1  2004 Morgan Kaufmann Publishers Chapter Seven Memory Hierarchy-3 by Patterson.
Informationsteknologi Wednesday, October 3, 2007Computer Systems/Operating Systems - Class 121 Today’s class Memory management Virtual memory.
Lectures 8 & 9 Virtual Memory - Paging & Segmentation System Design.
Virtual Memory Pranav Shah CS147 - Sin Min Lee. Concept of Virtual Memory Purpose of Virtual Memory - to use hard disk as an extension of RAM. Personal.
Chapter 7 Memory Management Eighth Edition William Stallings Operating Systems: Internals and Design Principles.
CS203 – Advanced Computer Architecture Virtual Memory.
Virtual Memory By CS147 Maheshpriya Venkata. Agenda Review Cache Memory Virtual Memory Paging Segmentation Configuration Of Virtual Memory Cache Memory.
Memory management The main purpose of a computer system is to execute programs. These programs, together with the data they access, must be in main memory.
CDA 3101 Spring 2016 Introduction to Computer Organization Physical Memory, Virtual Memory and Cache 22, 29 March 2016.
CS161 – Design and Architecture of Computer
Memory Hierarchy Ideal memory is fast, large, and inexpensive
Computer Organization
Virtual Memory Chapter 7.4.
ECE232: Hardware Organization and Design
Memory COMPUTER ARCHITECTURE
CS161 – Design and Architecture of Computer
Virtual Memory Chapter 8.
Computer Architecture
IS 139 Lecture 7 Memory.
Chapter 6 Memory.
Computer Architecture
Operating Systems: Internals and Design Principles, 6/E
Virtual Memory 1 1.
Presentation transcript:

Virtual Memory

Cache memory enhances performance by providing faster memory access speed. Virtual memory enhances performance by providing greater memory capacity, without the expense of adding main memory. Instead, a portion of a disk drive serves as an extension of main memory. If a system uses paging, virtual memory partitions main memory into individually managed page frames, that are written (or paged) to disk when they are not immediately needed. 2

Virtual Memory A physical address is the actual memory address of physical memory. Programs create virtual addresses that are mapped to physical addresses by the memory manager. Page faults occur when a logical address requires that a page be brought in from disk. Memory fragmentation occurs when the paging process results in the creation of small, unusable clusters of memory addresses. 3

Virtual Memory Main memory and virtual memory are divided into equal sized pages. The entire address space required by a process need not be in memory at once. Some parts can be on disk, while others are in main memory. Further, the pages allocated to a process do not need to be stored contiguously-- either on disk or in memory. In this way, only the needed pages are in memory at any time, the unnecessary pages are in slower disk storage. 4

Virtual Memory Information concerning the location of each page, whether on disk or in memory, is maintained in a data structure called a page table (shown below). There is one page table for each active process. 5

Virtual Memory When a process generates a virtual address, the operating system translates it into a physical memory address. To accomplish this, the virtual address is divided into two fields: A page field, and an offset field. The page field determines the page location of the address, and the offset indicates the location of the address within the page. The logical page number is translated into a physical page frame through a lookup in the page table. 6

Virtual Memory If the valid bit is zero in the page table entry for the logical address, this means that the page is not in memory and must be fetched from disk. – This is a page fault. – If necessary, a page is evicted from memory and is replaced by the page retrieved from disk, and the valid bit is set to 1. If the valid bit is 1, the virtual page number is replaced by the physical frame number. The data is then accessed by adding the offset to the physical frame number. 7

Virtual Memory As an example, suppose a system has a virtual address space of 8K and a physical address space of 4K, and the system uses byte addressing. – We have 2 13 /2 10 = 2 3 virtual pages. A virtual address has 13 bits (8K = 2 13 ) with 3 bits for the page field and 10 for the offset, because the page size is A physical memory address requires 12 bits, the first two bits for the page frame and the trailing 10 bits the offset. 8

Virtual Memory Suppose we have the page table shown below. What happens when CPU generates address = ? 9

Virtual Memory The address is converted to physical address because the page field 101 is replaced by frame number 01 through a lookup in the page table. 10

Virtual Memory What happens when the CPU generates address ? 11

Virtual Memory Effective access time (EAT) takes all levels of memory into consideration. Thus, virtual memory is also a factor in the calculation, and we also have to consider page table access time. Suppose a main memory access takes 200ns, the page fault rate is 1%, and it takes 10ms to load a page from disk. We have: EAT = 0.99(200ns + 200ns) 0.01(10ms) = 100, 396ns. 12

Virtual Memory Even if we had no page faults, the EAT would be 400ns because memory is always read twice: First to access the page table, and second to load the page from memory. Because page tables are read constantly, it makes sense to keep them in a special cache called a translation look-aside buffer (TLB). TLBs are a special associative cache that stores the mapping of virtual pages to physical pages. 13 The next slide shows how all the pieces fit together.

Virtual Memory 14

Virtual Memory Another approach to virtual memory is the use of segmentation. Instead of dividing memory into equal-sized pages, virtual address space is divided into variable-length segments, often under the control of the programmer. A segment is located through its entry in a segment table, which contains the segment’s memory location and a bounds limit that indicates its size. After a page fault, the operating system searches for a location in memory large enough to hold the segment that is retrieved from disk. 15

Virtual Memory Both paging and segmentation can cause fragmentation. Paging is subject to internal fragmentation because a process may not need the entire range of addresses contained within the page. Thus, there may be many pages containing unused fragments of memory. Segmentation is subject to external fragmentation, which occurs when contiguous chunks of memory become broken up as segments are allocated and deallocated over time. 16

Virtual Memory Large page tables are cumbersome and slow, but with its uniform memory mapping, page operations are fast. Segmentation allows fast access to the segment table, but segment loading is labor-intensive. Paging and segmentation can be combined to take advantage of the best features of both by assigning fixed-size pages within variable-sized segments. Each segment has a page table. This means that a memory address will have three fields, one for the segment, another for the page, and a third for the offset. 17

A Real-World Example The Pentium architecture supports both paging and segmentation, and they can be used in various combinations including unpaged unsegmented, segmented unpaged, and unsegmented paged. The processor supports two levels of cache (L1 and L2), both having a block size of 32 bytes. The L1 cache is next to the processor, and the L2 cache sits between the processor and memory. The L1 cache is in two parts: and instruction cache (I- cache) and a data cache (D-cache). 18 The next slide shows this organization schematically.

A Real-World Example 19

Virtual Memory Virtual memory is stored in a hard disk image. The physical memory holds a small number of virtual pages in physical page frames. A mapping between a virtual and a physical memory:

Page Table The page table maps between virtual memory and physical memory.

Using the Page Table A virtual address is translated into a physical address: Typical page table entry

Translation Lookaside Buffer An example TLB holds 8 entries for a system with 32 virtual pages and 16 page frames.

Putting it All Together An example TLB holds 8 entries for a system with 32 virtual pages and 16 page frames.

Content Addressable Memory – Addressing Relationships between random access memory and content addressable memory:

Associative Memory in Routers A simple network with three routers. The use of associative memories in high-end routers reduces the lookup time by allowing a search to be performed in a single operation. The search is based on the destination address, rather than the physical memory address. Access methods for this memory have been standardized into an interface interoperability agreement by the Network Processing Forum.

Review

Physical vs. Virtual Memory Physical Memory – Installed in Computer: 512MB RAM in PC – Limited by size and power supply of processor – Potential extent limited by size of address space Virtual Memory – How to put 2 32 words in your PC? – Not as RAM – not enough space or power – Make the CPU believe it has 2 32 words – Have the Main Memory act as a long-term Cache – Page the main memory contents to/from disk – Paging table (address system) works with Memory Management Unit to control page storage/retrieval

Virtual Memory (VM) Observe: Cache is a cache for main memory *** Main Memory is a Cache for Disk Storage *** Justification: VM allows efficient and safe sharing of memory among multiple programs (multiprogramming support) VM removes the programming headaches of a small amount of physical memory VM simplifies loading the program by supporting relocation History: VM was developed first, then cache Cache is based on VM technology, not conversely

Virtual Memory Terms Page:A virtual memory block (cache = block, VM = page) Page Fault: A miss on MemRead (cache = miss, VM = page fault) Physical Address: Where data is stored in physical memory Virtual Address: Produced by CPU which sees a big address space, then translated by HW + SW to yield a physical address Memory Mapping or Address Translation: Process of transforming Virtual Address to Physical Address Translation Lookaside Buffer: Helps make memory mapping more efficient

Virtual Memory Process CPU Virtual Address:Virtual page numberPage offset Translation Physical Address:Physical Page NumberPage offset Physical Memory N bits K 0 M bits K 0 M is always less than N Otherwise, why have VM?

Virtual Memory Cost Page Fault: Re-fetch the data from disk  (millisecond latency) Reducing VM Cost: Make pages large enough to amortize high disk access time Allow fully associative page placement to reduce page fault rate Handle page faults in software, because you have a lot of time between disk accesses (versus cache, which is v. fast) Use clever software algorithms to place pages (we have the time) Random page replacement, versus Least Recently Used Use Write-back (faster) instead of write-through (too long)

Conclusions Caching improves memory efficiency by: – Restricting frequently-occurring read/write operations to fast memory – Buffering register-to-memory access, thereby leveling resource use – Keeping the I/O pipeline almost always full (occupied) to maximize hierarchical memory system throughput Virtual Memory is useful because: – Maps a big symbolic address space to a small physical address space – works almost the same as cache