Lecture 21 Last lecture Today’s lecture Cache Memory Virtual memory

Slides:



Advertisements
Similar presentations
Memory.
Advertisements

Chapter 6 Memory.
Virtual Memory Adapted from lecture notes of Dr. Patterson and Dr. Kubiatowicz of UC Berkeley.
Modified from Silberschatz, Galvin and Gagne Lecture 16 Chapter 8: Main Memory.
Memory Management (II)
1  1998 Morgan Kaufmann Publishers Chapter Seven Large and Fast: Exploiting Memory Hierarchy.
Memory Management and Paging CSCI 3753 Operating Systems Spring 2005 Prof. Rick Han.
Memory Management.
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.
Chapter 7: Main Memory CS 170, Fall Memory Management Background Swapping Contiguous Memory Allocation Paging Structure of the Page Table Segmentation.
03/22/2004CSCI 315 Operating Systems Design1 Virtual Memory Notice: The slides for this lecture have been largely based on those accompanying the textbook.
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.
Chapter 8: Main Memory.
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. 
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.
SOCSAMS e-learning Dept. of Computer Applications, MES College Marampally MEMORYMANAGEMNT.
Operating Systems Chapter 8
Chapter 8 Memory Management Dr. Yingwu Zhu. Outline Background Basic Concepts Memory Allocation.
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.
Computer Architecture Lecture 28 Fasih ur Rehman.
Lecture 19: Virtual Memory
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.
Silberschatz, Galvin and Gagne  2002 Modified for CSCI 399, Royden, Operating System Concepts Operating Systems Lecture 34 Paging Implementation.
IT253: Computer Organization
Fall 2000M.B. Ibáñez Lecture 17 Paging Hardware Support.
CE Operating Systems Lecture 14 Memory management.
CS 149: Operating Systems March 3 Class Meeting Department of Computer Science San Jose State University Spring 2015 Instructor: Ron Mak
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.
1 Chapter Seven CACHE MEMORY AND VIRTUAL MEMORY. 2 SRAM: –value is stored on a pair of inverting gates –very fast but takes up more space than DRAM (4.
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.
Memory Management Continued Questions answered in this lecture: What is paging? How can segmentation and paging be combined? How can one speed up address.
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.
8.1 Silberschatz, Galvin and Gagne ©2009 Operating System Concepts – 8 th Edition Fragmentation External Fragmentation – total memory space exists to satisfy.
Operating Systems Session 7: – Virtual Memory organization Operating Systems.
Chapter 7: Main Memory CS 170, Fall Program Execution & Memory Management Program execution Swapping Contiguous Memory Allocation Paging Structure.
Virtual Memory. Cache memory enhances performance by providing faster memory access speed. Virtual memory enhances performance by providing greater memory.
Silberschatz, Galvin and Gagne  2002 Modified for CSCI 399, Royden, Operating System Concepts Operating Systems Lecture 33 Paging Read Ch. 9.4.
CS161 – Design and Architecture of Computer
Memory Hierarchy Ideal memory is fast, large, and inexpensive
Virtual Memory Chapter 7.4.
Chapter 2 Memory and process management
Memory COMPUTER ARCHITECTURE
CS161 – Design and Architecture of Computer
CS703 - Advanced Operating Systems
Memory Management Lectures notes from the text supplement by Siberschatz and Galvin Modified by B.Ramamurthy Chapter 8 11/24/2018.
Computer Architecture
Memory Management Lectures notes from the text supplement by Siberschatz and Galvin Modified by B.Ramamurthy Chapter 9 12/1/2018.
Main Memory Background Swapping Contiguous Allocation Paging
Memory Management Lectures notes from the text supplement by Siberschatz and Galvin Modified by B.Ramamurthy Chapter 9 4/5/2019.
CS703 - Advanced Operating Systems
Virtual Memory 1 1.
Presentation transcript:

Lecture 21 Last lecture Today’s lecture Cache Memory Virtual memory Direct mapping Fully associative Set associative Today’s lecture Virtual memory Why virtual memory? Virtual address and physical address Page table: virtual address to physical address translation Paging Segmentation Translation look-aside buffer

Exercise Suppose we have a computer that uses a memory address word size of 8 bits. This computer has a 16-byte cache with 4 bytes per block. The computer accesses a number of memory locations throughout the course of running a program. Suppose this computer uses direct-mapped cache. The format of a memory address as seen by the cache is shown below: The system accesses memory addresses in this exact order: 0x6E, 0xB9, 0x17, 0xE0, 0x4E, 0x4F, 0x50, 0x91, 0xA8, 0xA9, 0xAB, 0xAD, 0x93, and 0x94. What is the hit ratio for the entire memory reference sequence given above, assuming we count the first four accesses as misses? What memory blocks will be in the cache after the last address has been accessed?

Exercise

Why Virtual Memory? Today computers run multiple processes, each with its own address space Too expensive to dedicate a full-address-space worth of memory for each process Principle of Locality allows caches to offer speed of cache memory with size of DRAM memory DRAM can act as a “cache” for secondary storage (disk)  Virtual Memory Virtual memory – divides physical memory into blocks and allocate them to different processes

Virtual Memory Cache memory Virtual memory Providing faster memory access speed. Virtual memory Providing greater memory capacity, without the expense of adding main memory. Extending main memory with a portion of a disk drive.

Virtual Memory Terminology Virtual addresses: the logical or program address that the process uses. CPU generates an address in terms of virtual address space. Physical address – the real address in physical memory. Mapping: the mechanism by which virtual addresses are translated into physical ones. Page frames: the equal-size chunks or blocks into which main memory (physical memory) is divided. Pages: the chunks or blocks into which virtual memory (the logical address space) is divided, each equal in size to a page frame. Virtual pages are stored on disk until needed. Paging: the process of copying a virtual page from disk to a page frame in main memory. Fragmentation: memory that becomes unusable. Page fault: an event that occurs when a requested page is not in main memory and must be copied into memory from disk.

Page Table Maintaining the Information concerning the location of each page, whether on disk or in memory. There is one page table for each active process.

Virtual Address & Physical Address Two fields: A page field, and an offset field. Page field: determines the page location of the virtual address Offset field: indicates the location of the address within the page. Physical address Two fields: a page frame field, and an offset field. Page frame field: determines the page frame location in main memory The logical page number is translated into a physical page frame through a lookup in the page table.

Virtual Address Translation - 1 Extract the page number from the virtual address. Extract the offset from the virtual address Translate the page number into a physical page frame number using the page table. Look up the page number in the page table (using the virtual page number as an index)

Virtual Address Translation - 2 Check the valid bit for that page Valid bit is 1 Virtual page number is replaced by physical frame number. Access the data at offset in the physical page frame. Valid bit is 0: Page fault: meaning that the page is not in memory and must be fetched from disk. Locate the desired the page on disk. 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. Update the page table and resume execution.

Exercise As an example, suppose a system has a virtual address space of 8KB and a physical address space of 4KB, and the system uses byte addressing. The page size is 1KB. A virtual address has 13 bits (8K = 213) 213/210 = 23 virtual pages 3 bits for the page field and 10 for the offset. A physical memory address requires 12 bits, the first two bits for the page frame and the trailing 10 bits the offset.

Exercise Suppose we have the page table shown below. What happens when CPU generates address 545910 = 10101010100112 = 0x1553?

Exercise The address 10101010100112 is converted to physical address 0101010100112 = 0x1363 because the page field 101 is replaced by frame number 01 through a lookup in the page table. The high-order 3 bits of the virtual address, 101 (510), provide the page number in the page table.

Exercise What happens when the CPU generates address 10000000001002?

Effective Access Time 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. EAT = (1 – page fault rate) x 2 x main memory access time + page fault rate x page fault penalty 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, 396 ns. 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 access the page from memory.

Translation Look-aside Buffer (TLB) 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.

TLB lookup process 1. Extract the page number from the virtual address. 2. Extract the offset from the virtual address. 3. Search for the virtual page number in the TLB. 4. If the (virtual page #, page frame #) pair is found in the TLB, add the offset to the physical frame number and access the memory location. 5. If there is a TLB miss, go to the page table to get the necessary frame number. If the page is in memory, use the corresponding frame number and add the offset to yield the physical address. 6. If the page is not in main memory, generate a page fault and restart the access when the page fault is complete.

Putting it all together: The TLB, Page Table, and Main Memory

Segmentation Paging: dividing memory into equal-sized pages, Segmentation: virtual address space is divided into variable-length segments. 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.

Fragmentation 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. The next slides illustrate internal and external fragmentation.

Paging: Internal Fragmentation Consider a small computer having 32K of memory. 32K memory is divided into 8 page frames of 4K each. A schematic of this configuration is shown at the right. The numbers at the right are memory frame addresses. Suppose there are four processes waiting to be loaded into the system with memory requirements as shown in the table. These processes require 31K of memory.

Paging: Internal Fragmentation When the first three processes are loaded, memory looks like this: All of the frames are occupied by three of the processes. Despite the fact that there are enough free bytes in memory to load the fourth process, P4 has to wait for one of the other three to terminate, because there are no unallocated frames. This is an example of internal fragmentation.

Segmentation: External Fragmentation Suppose that instead of frames, our 32K system uses segmentation. The memory segments of two processes is shown in the table at the right. The segments can be allocated anywhere in memory.

Segmentation: External Fragmentation All of the segments of P1 and one of the segments of P2 are loaded as shown at the right. Segment S2 of process P2 requires 11K of memory, and there is only 1K free, so it waits.

Segmentation: External Fragmentation Eventually, Segment 2 of Process 1 is no longer needed, so it is unloaded giving 11K of free memory. But Segment 2 of Process 2 cannot be loaded because the free memory is not contiguous.

Segmentation: External Fragmentation Over time, the problem gets worse, resulting in small unusable blocks scattered throughout physical memory. This is an example of external fragmentation. Eventually, this memory is recovered through compaction, and the process starts over.