CPU

Process context

The CPU and memory resources allocated by the operating system to the process are the context for the process


Memory address

Virtual memory address: the memory address used by the process

2. Physical memory address: the actual space address in the hardware

Virtual addresses held by processes are converted into physical addresses by mapping memory management units (MMUs) in the CPU chip, and then physical addresses are used to access memory

How does the OPERATING system manage the relationship between virtual and physical addresses?

There are two main methods, namely memory segmentation and memory paging


Memory management

One, memory paging storage: in page storage management, the logical address of the program is divided into fixed size pages (page), while the physical memory is divided into frames of the same size. When the program is loaded, any page can be put into any frame in memory, and these frames do not have to be continuous, so as to achieve discrete separation

(1) page is the physical unit of information, pagination is to realize discrete distribution;

(2) to reduce the external memory, improve the utilization of memory; But there will be inside change;

(3) The page size is fixed and determined by the system

Under Linux, each page is 4KB in size. Virtual addresses and physical addresses are mapped through a page table

If the virtual address accessed by a process cannot be found in the page table, the system generates a page missing exception. The system accesses the kernel space to allocate physical memory, updates the process page table, and finally returns to the user space to restore the process

For a memory translation, there are three steps:

  1. Divide the virtual memory address into page numbers and offsets.
  2. Query the corresponding physical page number from the page table according to the page number.
  3. Just take the physical page number and add the preceding offset to get the physical memory address.

2. Segmented memory storage: In segment storage management, the program address space is divided into several segments, such as code segment, data segment, stack segment; Thus each process has a two-dimensional address space, independent of each other

(1) Without internal oddment, there will be external oddment

Distinguish between:

  1. Different purposes: paging is due to the needs of system management rather than the needs of users, it is the physical unit of information; The purpose of segmentation is to better meet the needs of users, it is the logical unit of information, it contains a group of its meaning relatively complete information;
  2. Different sizes: the size of a page is fixed and determined by the system, while the length of a section is not fixed and determined by the function it performs;
  3. Different address Spaces: segments provide users with two-dimensional address Spaces. Pages provide users with a one-dimensional address space;
  4. Information sharing: a section is a logical unit of information, which facilitates storage protection and information sharing, while page protection and information sharing are restricted.
  5. Memory fragmentation: Page storage management has the advantage of no external fragmentation (because the page size is fixed), but internal fragmentation (a page may not be filled); The advantage of segment management is that there is no internal fragmentation (because the segment size is variable, change the segment size to eliminate internal fragmentation). However, when a segment is swapped in and out, external fragments will be generated (for example, when a 4k segment is swapped for a 5K segment, 1K external fragments will be generated).

Section page type memory management (each program a section table, each section to establish a page table)

  1. First, the program is divided into multiple logical sections, which is the previously mentioned segmentation mechanism;
  2. Then each segment is divided into multiple pages, that is, the continuous space divided by segments, and then divided into fixed size pages

Steps:

  1. Access the segment table for the first time, get the start address of the page table;
  2. Access the page table a second time to get the physical page number;
  3. For the third time, combine the physical page number with the in-page displacement to get the physical address.


Memory Swap space (Swap in Linux)

Solve external internal fragmentation: Write memory occupied by a process to the hard disk and then read back to the hard disk, but read back immediately after the memory already occupied, freeing up more memory

Memory fragmentation: On a multi-process system, memory fragmentation is very easy to generate. If memory fragmentation is generated, the memory area has to be re-swap. This process can cause performance bottlenecks. Because hard disk access is much slower than memory, each memory swap requires a large contiguous chunk of memory data to be written to the hard disk. So, if you swap memory, and you swap a program that takes up a lot of memory, the whole machine will be stuck.

Paging: If you run Out of memory, the operating system will Swap Out “recently unused” memory pages from other running processes. When it is needed, it is loaded In again, called a Swap In. Therefore, only a few pages or pages are written to disk at a time, which does not take too much time, and memory swapping is relatively efficient


Fraction of memory

  1. External oddment: There are areas of memory that are not owned by any process and are too small to meet the size requested by other processes.
  2. Internal spare: The portion of memory allocated to a process that is not being used.