<< Chapter < Page | Chapter >> Page > |
Partitioning of memory is as a job that is brought into memory, it must be allocated a portion of the memory, this is its partition. Partitions can be fixed size of variable sized
– Fixed size:
This is a rigid size divisions of memory
Process is assigned to smallest available partition it fits into
Process can be very wasteful of memory
– Variable size
Allocate a process to only as much memory as it needs
Other memory can be used for other processes
Efficient use of memory but, over time, can lead to large numbers of little left over pieces of free memory -- too small to use
Must consider use of memory compaction
Since a process can be swapped in and out of memory and end up in different partitions, addressing within the process must not be tied to specific physical memory addresses
– Program/process addresses are logical ones with respect to the starting address of the
program itself
– Processor hardware must convert the logical address reference of the program into a physical address that the machine can operate on
– In effect this is a form of index addressing -- base addressing -- where the base address is the first address of the program.
Figure 15.1 Effect of partitioning
– Each program has a page table associated with it that maps each program page to a memory page frame
– Thus, logical addresses in a program are interpreted as a physical address -- page frame number and an offset within the page
Figure 15.2 Allocation of free pages
The more sophistiated way of mapping address from the address space onto the actual memory address is possible. Principle of address mapping in a paging system is shown in Figure 15.3 .
The address that the program can refer is called the virtual address space, the actual hardwired (pgysical) memory address is called the physical address space.
Figure 15.3 Address mapping in a paging system
– Only the program pages that are required for the execution of the program are actually loaded -- hence the “demanded” concept
– Only a few (of the many potential) pages of any one program might be in memory at a time
– Many “active” programs can have pages -- increasing the degree of multiprogramming
– This is presents a virtual memory system that seems unlimited in size to the programmer
– Significantly simplifies program development
secondary storage. Only a small portion will be kept in main memory
– Using a 2-level page table:
Entry in first level point to a table at the second level
First level is small -- in many cases the size of a single page
– Use an inverted table structure: A hashing function maps a page request
into an inverted table that is used by all processes. One structure is usec for all processes and virtual pages
– An access to get to the page table
– An access to get the actual data page
– Trying to find frame reference in TLB
– If not there, go to page table in memory
– With frame identified, check the cache to see if it is there,
– If not there, get from main memory or retrieve from disk
Figure 15.3 Operation of paging and TLB
Figure 15.4. TLB and cache operation
- If there is an unused page frame, it can be loaded into it
- If all page frames are in use, one must be selected for replacement
- If it has been altered, the page to be replaced must be copied back to secondary
storage
Similar to the ones discussed in caching, the following algorithms have been used
LRU
FIFO
Random, etc.
In addition to partitioning and paging, segmentation can be used to subdivide
memory
– Programmer subdivides the program into logical units called segments
Programs subdivided by function
Data array items grouped together as a unit
– Advantages
Simplifies data structure handling
Supports code modification and maintenance
Supports sharing code segments
Provides a degree of protection
– Memory reference is in the form of a segment ID and an offset
– Segmentation can be combined with paging in a segment ID, page number, page offset scheme
Resume of Virtual Memory management
– Partitioning
– Paging
– Segmentation
– Segmentation and paging
Notification Switch
Would you like to follow the 'Computer architecture' conversation and receive update notifications?