Presentation is loading. Please wait.

Presentation is loading. Please wait.

CMPT 300: Final Review Chapters 8 – 12. 2 Memory Management: Ch. 8, 9 Address spaces Logical (virtual): generated by the CPU Physical: seen by the memory.

Similar presentations


Presentation on theme: "CMPT 300: Final Review Chapters 8 – 12. 2 Memory Management: Ch. 8, 9 Address spaces Logical (virtual): generated by the CPU Physical: seen by the memory."— Presentation transcript:

1 CMPT 300: Final Review Chapters 8 – 12

2 2 Memory Management: Ch. 8, 9 Address spaces Logical (virtual): generated by the CPU Physical: seen by the memory unit User program deals with logical addresses; never sees physical addresses Mapping from logical to physical addresses Static: done at compile-time Dynamic: done at load or execution time

3 3 Memory Allocation Memory is usually divided into two partitions for: Kernel: usually held in low memory User processes: usually held in high memory Typically, the two partitions are managed differently Memory allocation Contiguous  First-, Best-, Worst-fit  Fragmentation: external and internal Paging, segmentation, virtual memory

4 4 Paging

5 5 Segmentation 1 3 2 4 1 4 2 3 user spacephysical memory space

6 6 Segmentation Hardware

7 7 Paging and Segmentation Paging issues: Page size  Internal fragmentation and page table size Page table (one table for each process)  Access time: use cache (TLB)  Size: use two- or three-levels page tables use hashed or inverted page tables for > 32 bits architectures Segmentation: variable size External fragmentation Facilitates sharing of code and data (share the whole segment) Combined Segmentation + paging: Example Intel Pentium

8 8 Virtual Memory Logical address space can be much larger than physical address space Only the needed parts of the program are brought to memory for execution Allows address spaces to be shared by several processes Allows for more efficient process creation Virtual memory can be implemented via Demand paging Demand segmentation

9 9 Virtual Memory and Page Fault

10 10 Page Replacement When we need to bring a page from disk and there is no free frame: Find a victim page to evict from memory Objective: minimize number of page faults (they are very costly) Replacement algorithms FIFO, OPT, LRU, second-chance, …

11 11 Thrashing Thrashing  a process is busy swapping pages in and out more than executing (because OS allocated too few frames to it)

12 12 Locality Model As a process executes, it moves from locality to locality, where a locality is a set of pages that are actively used together Locality could be: function, module, segment of code, … Locality model helps us to estimate the working set of a process Working set: pages that are actively being used (within a window)

13 13 Allocating Kernel Memory Treated differently from user memory because Kernel requests memory for structures of varying sizes  Process descriptors (PCB), semaphores, file descriptors, …  Some of them are less than a page Some kernel memory needs to be contiguous  some hardware devices interact directly with physical memory without using virtual memory Virtual memory may just be too expensive for the kernel (cannot afford a page fault)

14 14 Kernel Memory: Buddy System

15 15 Kernel Memory: Slab Allocation

16 16 File Systems: Ch. 10, 11, 12  Interface: file and directory structure  Maintains pointers to logical block addresses Application Programs Logical File System File-organization Module Device Drivers Storage Devices  Implementation: device-specific instructions  Writes specific bit patterns to device controller  Implementation: block allocation, …  Maps logical into physical addresses

17 17 File System Interface Files The smallest storage unit from the user’s perspective A collection of blocks on the disk from OS’ perspective Directory structure Tree-structured with links (general graphs) Each file has an entry in the directory

18 18 File System Implementation To implement a file system, we need On-disk structures, e.g.,  directory structure, number of blocks, location of free blocks, boot information, …  (In addition to data blocks, of course) In-memory structures to:  improve performance (caching)  manage file system

19 19 On-disk Structures Boot block Superblock Directory structure Free block File control block Data block

20 20 Opening and Reading from a File

21 21 Block Allocation Allocate free blocks to files to achieve efficient disk space utilization, and fast file access Three common allocation methods Contiguous Linked Indexed OS keeps track of free blocks using Bitmaps Linked lists

22 22 Combined Scheme: UNIX inode

23 23 Disk Structure and Scheduling Disk structure cylinders, tracks, sectors, logical blocks Disk operation Move the head to desired track (seek time) Wait for desired sector to rotate under the head (rotational latency time) Transfer the block to a local buffer, then to main memory (transfer time) Disk scheduling To minimize seek time (head movements) Algorithms: FCFC, SSTF, SCAN, LOOK

24 24 Warp Up: What We Have Covered How to manage resources in a single computer

25 25 Warp Up: What We Have NOT Covered How to manage resources distributed over multiple computers CMPT 371: Computer Networks  Protocols and algorithms to make computers talk to each other CMPT 401: Operating Systems II  Distributed file systems, distributed synchronization, inter- process communications, consistency and reliability, security Special-purpose operating systems, e.g., Real-time OS OS on small devices (PDAs, sensors,…)

26 26 That is it with CMPT 300! Good Luck on Your Final


Download ppt "CMPT 300: Final Review Chapters 8 – 12. 2 Memory Management: Ch. 8, 9 Address spaces Logical (virtual): generated by the CPU Physical: seen by the memory."

Similar presentations


Ads by Google