permalink |
---|
/W04/ |
# Top 10 List of Week 04
-
How the CPU can be shared by a set of processes
This video explained about introduction to CPU Scheduling. Why we need to know about CPU Scheduling? Because CPU Scheduling is the basis ofmultiprogrammed OS. By switching the CPU among processes, the operating system can make the computer more productive. As a result of CPU scheduling, we can improve both the utilization of the CPU and speed of the computer's response to its users. Please check that interesting explanation in the video! -
Memory Management in Linux
This video is an introduction to memory management in Linux included physical memory, virtual memory, memory management unit (MMU), lookaside buffer. It also shows the advantages of each memory management. Virtual addresses, logical address and physical address explanation also included here. -
The Memory Management Unit
Still from the same resources as number 2. The MMU is a hardware component which manages virtual address mappings. The MMU operated on basic units of memory called pages. A page is a unit of memory sized aligned at the page size. If you want to read a full version of continguous memory allocation please read OSC 10th edition part 9.2. -
Shared Memory System Shared memory is easily implemented with an MMU. Interprocess communication shared memory required communicating processes to establish a region os shared memory. Typically, a shared-memory region resides in the address space of the process creating the shared-memory segment. Normally, the OS tries to prevent one process from accessing another process'memory and the shared memory required two or more processes agree to remove restriction.
-
First-Fit, Best-Fit, and Worst-Fit Strategies for Memory Allocation
- First-fit explained there may be many holes in the memory, so that operating system, to reduce the amount of time it spends analyzing the available spaces, begins at the start of primary memory and allocates memory from the first hole it encounters large enough to satisfy the request.
- Best-Fit, the allocator places a process in the smallest block of unallocated memory in which it will fit. For example, suppose a process requests 12KB of memory and the memory manager currently has a list of unallocated blocks of 6KB, 14KB, 19KB, 11KB, and 13KB blocks. The best-fit strategy will allocate 12KB of the 13KB block to the process.
- Worst fit: The memory manager places a process in the largest block of unallocated memory available. The idea is that this placement will create the largest hold after the allocations, thus increasing the possibility that, compared to best fit, another process can use the remaining space. Using the same example as above, worst fit will allocate 12KB of the 19KB block to the process, leaving a 7KB block for future use.
-
Logical Address VS Physical Address
The basic difference between Logical and physical address is that Logical address is generated by CPU in perspective of a program whereas the physical address is a location that exists in the memory unit. Logical address and physical address still have the other difference, please check the webiste! -
Paging System
Paging is a storage mechanism that allows OS to retrieve processes from the secondary storage into the main memory in the form of pages.The paging process should be protected by using the concept of insertion of an additional bit called Valid/Invalid bit.The biggest advantage of paging is that it is easy to use memory management algorithm. -
Translation from Logical to Physical Addresses in Paging System
I guess we learned about logical address in Introduction to Computer Organization, the new one is physical address! This is a great website that explain about address and examples also provided, so I think this is a great website to help us recall about the subject and learn new things. -
Hierarchical Paging, Hashed Paging, and Inverted Page Tables
This is a 10 minutes video that explained about hierarchical paging, hashed paging, and inverted page tabled, clearly explained here. If you want the PDF, please click here. -
Swapping
Swapping is one of the several methods of memory management. In swapping an idle or a blocked process in the main memory is swapped out to the backing store (disk) and the process that is ready for execution in the disk, is swapped in main memory for execution.