【CSAPP】虚拟内存 | 地址空间 | 页表内存保护 | 页错误引发异常逐出 (evicted)

简介: 【CSAPP】虚拟内存 | 地址空间 | 页表内存保护 | 页错误引发异常逐出 (evicted)

💭 写在前面:本文将学习《深入理解计算机系统》虚拟内存部分,CSAPP 是计算机科学经典教材《Computer Systems: A Programmer's Perspective》的缩写,该教材由Randal E. Bryant和David R. O'Hallaron 合著。



0x00 回顾:进程的概念(Processes)

"Definition: A process is an instance of a running program"

📚 定义:进程是正在运行的程序的实例。

可以这么说:当可执行文件被加载到内存中时,该程序就成为了一个进程。

  • 进程可谓是计算机科学中最成功的想法之一。
  • 不同于 "程序" 或 "处理器"。
  • 进程具有程序执行的上下文(状态)的能力。

进程为每个程序提供了两个关键抽象:

逻辑控制流 (Logical control flow):

  • 每个进程 "似乎" 都有自己的 CPU。
  • 由称为上下文切换 (virtual memory) 的内核机制提供。

私有地址空间 (Private address space)

  • 每个进程 "似乎" 都独占内存 (memory)。
  • 由称为虚拟内存 (virtual memory) 的内核机制提供。

0x01 私有地址空间的错觉

使用物理地址的系统:用于 "简单 "系统,如汽车、电梯等的嵌入式微控制器。

使用虚拟地址的系统:在所有现代服务器、笔记本电脑和智能手机中使用,计算算机科学中的一个伟大想法。

0x02 地址空间(Address Spaces)

线性地址空间:连续的非负整数地址的有序集合:

虚拟地址空间:个虚拟地址的集合:

物理地址空间: 个物理地址的集合:

0x03 虚拟机作为内存管理的工具

关键思想是让每个进程都有自己的虚拟地址空间,每个进程都可以把内存看作是一个简单的线性阵列,地址转换在物理内存中映射这些地址。

页是地址管理的基本单位(通常为4KB):每个虚拟页将被映射到一个物理页。

允许进程之间共享代码和数据:通过将虚拟页映射到同一物理页。

0x04 启用数据结构:页表

页表 (page table),是一个页表项(PTE)阵列,将虚拟页映射到物理页。

  • 物理内存(DRAM)中的每进程内核数据结构
  • 特殊寄存器(PTBR)告诉CPU页表的地址

0x05 虚拟内存和硬盘

并非所有的虚拟页都能被映射到物理页上,因此,我们实际上将所有的虚拟页都存储在硬盘中(其大小相对较大)。而部分虚拟页被加载到物理内存中,这类似于 "缓存 "的概念

页命中 (page hit):对物理内存中的虚拟地址的访问。

页错误 (page fault)

如果访问到了一个不在物理内存中的虚拟地址,就会发生页错误 (page fault),扑了个空。

页错误的处理:页面错误导致 CPU 异常

页错误在 CPU 中引起异常,页错误处理程序会选择一个 "受害者" 将其 逐出 (evicted) 。

下图例子中,VP4 被逐出:

错误指令重新启动:页面命中 (page hit) !

0x06 页表的内存保护

用权限位扩展PTE,"SUP " 位表示监督者(内核)模式。

你的硬件在每次访问时都会检查这些位。

📌 [ 笔者 ]   王亦优
📃 [ 更新 ]   2023.5.22
❌ [ 勘误 ]   /* 暂无 */
📜 [ 声明 ]   由于作者水平有限,本文有错误和不准确之处在所难免,
              本人也很想知道这些错误,恳望读者批评指正!

📜 参考资料 

Bryant and O’Hallaron, Computer Systems: A Programmer’s Perspective, Third Edition

Microsoft. MSDN(Microsoft Developer Network)[EB/OL]. []. .

百度百科[EB/OL]. []. https://baike.baidu.com/.

相关文章
|
3月前
|
存储 开发框架 .NET
"揭秘.NET内存奥秘:从CIL深处窥探值类型与引用类型的生死较量,一场关于速度与空间的激情大戏!"
【8月更文挑战第16天】在.NET框架中,通过CIL(公共中间语言)可以深入了解值类型与引用类型的内存分配机制。值类型如`int`和`double`直接在方法调用堆栈上分配,访问迅速,生命周期随栈帧销毁而结束。引用类型如`string`在托管堆上分配,堆栈上仅存储引用,CLR负责垃圾回收,确保高效且自动化的内存管理。
55 6
|
15天前
|
存储 关系型数据库 MySQL
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
187 1
|
1月前
|
C++
析构造函数就是为了释放内存,就是在局部指针消失前释放内存,拷贝构造函数就是以构造函数为模块,在堆里面新开一块,同一个变量在堆里面的地址
本文讨论了C++中构造函数和析构函数的作用,特别是它们在管理动态内存分配和释放中的重要性,以及如何正确地实现拷贝构造函数以避免内存泄漏。
36 2
|
1月前
|
存储 安全 NoSQL
driftingblues9 - 溢出ASLR(内存地址随机化机制)
driftingblues9 - 溢出ASLR(内存地址随机化机制)
35 1
|
2月前
|
存储 关系型数据库 MySQL
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
125 5
|
3月前
|
算法 安全 UED
探索操作系统的内核空间:虚拟内存管理
【7月更文挑战第50天】 在现代操作系统中,虚拟内存管理是核心功能之一,它允许操作系统高效地使用物理内存,并为应用程序提供独立的地址空间。本文将深入探讨操作系统虚拟内存管理的机制,包括分页、分段以及内存交换等关键技术,并分析它们如何共同作用以实现内存的有效管理和保护。通过理解这些原理,读者可以更好地把握操作系统的内部工作原理及其对应用程序性能的影响。
|
2月前
|
Java C++
Java内存区域于内存溢出异常
这篇文章详细解释了Java虚拟机的内存区域划分、各区域的作用以及可能遇到的内存溢出异常情况。
45 0
|
3月前
|
存储 编译器 C语言
【C语言篇】数据在内存中的存储(超详细)
浮点数就采⽤下⾯的规则表⽰,即指数E的真实值加上127(或1023),再将有效数字M去掉整数部分的1。
357 0
|
19天前
|
存储 C语言
数据在内存中的存储方式
本文介绍了计算机中整数和浮点数的存储方式,包括整数的原码、反码、补码,以及浮点数的IEEE754标准存储格式。同时,探讨了大小端字节序的概念及其判断方法,通过实例代码展示了这些概念的实际应用。
41 1