- Mastering Linux Kernel Development
- Raghu Bharadwaj
- 229字
- 2021-07-08 09:47:12
The illusion called address space
Modern-day computing platforms are expected to handle a plethora of processes efficiently. Operating systems thus must deal with allocating unique memory to all contending processes within the physical memory (often finite) and also ensure their reliable execution. With multiple processes contending and executing simultaneously (multi-tasking), the operating system must ensure that the memory allocation of every process is protected from accidental access by another process.
To address this issue, the kernel provides a level of abstraction between the process and the physical memory called virtual address space. Virtual address space is the process' view of memory; it is how the running program views the memory.
Virtual address space creates an illusion that every process exclusively owns the whole memory while executing. This abstracted view of memory is called virtual memory and is achieved by the kernel's memory manager in coordination with the CPU's MMU. Each process is given a contiguous 32 or 64-bit address space, bound by the architecture and unique to that process. With each process caged into its virtual address space by the MMU, any attempt by a process to access an address region outside its boundaries will trigger a hardware fault, making it possible for the memory manger to detect and terminate violating processes, thus ensuring protection.
The following figure depicts the illusion of address space created for every contending process:

- 軟件架構設計:大型網站技術架構與業務架構融合之道
- 動手玩轉Scratch3.0編程:人工智能科創教育指南
- INSTANT Sencha Touch
- Monitoring Elasticsearch
- Getting Started with NativeScript
- Android底層接口與驅動開發技術詳解
- 網站構建技術
- Getting Started with LLVM Core Libraries
- Unity&VR游戲美術設計實戰
- Python全棧開發:基礎入門
- Selenium WebDriver Practical Guide
- Learning Cocos2d-JS Game Development
- 軟硬件綜合系統軟件需求建模及可靠性綜合試驗、分析、評價技術
- 產品架構評估原理與方法
- ASP.NET本質論