Linux内存地址映射.PDF
Linux内存地址映射
Linux内存地址映射
Linux内存地址映射
目 录
1 概述3
2 IA-32体系结构内存地址映射 4
2.1 CPU相关寄存器 4
2.1.1 系统寄存器5
2.1.2 内存管理寄存器5
2.2 保护模式的内存管理 7
2.3 32位时页面机制地址映射 9
2.3.1 逻辑地址到线性地址的映射9
2.3.2 线性地址到物理地址的映射11
2.4 PAE页面机制地址映射过程12
2.4.1 PDPTE寄存器12
2.4.2 逻辑地址到线性地址的映射13
2.4.3 线性地址到物理地址的映射13
3 Linux 内核的地址映射过程15
3.1 段式映射过程 15
3.2 页式映射过程 17
4 Linux地址映射实验 19
4.1 gdtr和cr3寄存器值的获取20
4.2 读取物理内存上的数据 21
4.3 地址映射过程实验 21
4.3.1 段式映射过程23
4.3.2 页式映射过程24
4.4 PAE机制下地址映射过程实验26
4.4.1 段式映射过程26
4.4.2 页式映射过程27
5 常见问题及解答28
Linux内存地址映射
1 概述
在分析Linux内存地址映射前,先来看一段简单的C程序代码在32位和64位系统上运行
结果:
#include
int main()
{
unsigned long tmp;
tmp = 0
printf("tmp variable address:0x%08lX\n", &tmp);
return 0;
}
[root@RHEL6 C]# ./addr
tmp variable address:0xBFF42DEC
[root@RHEL6 C]#
[root@RHEL6-x64-1 C]# ./addr
tmp variable address:0x7FFF138E0888
上面的程序功能非常简单,就是打印出临时变量tmp 的地址。程序运行后在32位系统中
tmp地址为0xBFF42DEC,在64位系统中打印地址为0x7FFF138E0888 (注意:每次运
行的结果都可能不同)。那么这个地址对是逻辑地址,还是线性地址?物理地址?临时变量
tmp到底存放在物理内存的哪个位置上?
在Intel体系结构的CPU中,现代操作系统如Linux都采用内存保护模式来管理内存。我
们看Linux内核中的内存管理相关内容时,会遇到一个基本问题:普通用户程序中的地址是
如何转换到内存上的物理地址的?IA-32架构的CPU规定地址映射过程是逻辑地址
线性地址 物理地址。Linux既然能在Intel架构的CPU上运行,就要遵守这个规定,那
么Linux又是如何进行地址映射的?
本