Linux内核学习之内存寻址

Linux内核学习之内存寻址

0. 前言

本文是以x86为例,讲解Linux中的寻址方法,在读本文前,建议先了解x86硬件分段、分页的实现,详情可以参考我另一篇文章x86架构学习之操作模式、内存寻址、特权级

1. Linux中的分段

介绍过硬件分段的原理,接下来就是软件如何配置硬件,即如何设计全局描述符表(或局部描述符表),然后把描述符表的基地址给到gdtr(或ldtr)寄存器。
Linux最初设计目标是让它可以移植到大多数流行处理器上,然而,多数处理器,比如RISC体系结构对分段的支持非常有限,因此,Linux重点使用的分页,在x86上,它通过合适的设置,让逻辑地址通过分段单元后,得到的线性地址与逻辑地址相同,从而在宏观上绕过了分段单元。
Linux配置的四个段描述符(用户代码段、数据段,内核代码段、数据段),都映射到了线性地址0。四个段描述符放在全局描述符表中,其他的还有一些描述符

段选择符全局描述符表段选择符全局描述符表
0x0null0x80TSS
NU(not used)0x88LDT
NU0x90PNPBIOS 32-bit code
NU0x98PNPBIOS 16-bit code
NU0xa0PNPBIOS 16-bit data
NU0xa8PNPBIOS 16-bit data
TLS10xb0PNPBIOS 16-bit data
TLS20xb8APMBIOS 32-bit code
TLS30xc0APMBIOS 16-bit code
NU0xc8null
NUNU
NUNU
0x60kernel code0x0NU
0x68kernel data0x0NU
0x73user code0x0NU
0x7buser data0x0double fault TSS
  • 1个默认局部描述符段,由所有进程共享,内控提供modify_ldt系统调用,供进程创建自己的局部段描述符表。
  • 3个线程局部存储段(TLS,thread-local storage),由内核提供的系统调用set_thread_area()和get_thread_area(),共用户程序使用。
  • 与BIOS高级电源管理(APM)相关的3段
  • 与BIOS即插即用(PnP)相关的5个段
  • 处理硬件双重错误的特殊TSS段,双重错误,即在异常中再次触发了异常。

ps1:这里没看到栈段的描述符,因此个人推测,Linux将栈段选择符配置成了和数据段选择符一样,两者使用相同的段描述符。
ps2:每个CPU有自己独立的gdtr和MMU,因此多核的处理器,Linux会配置多个全局描述符表。

Linux的4个主要代码、数据段描述符配置如下

线性基地址大小DPL
用户代码段04GB3
用户数据段04GB3
内核代码段04GB0
内核数据段04GB0

2. Linux中的分页

和分段相同,Linux中的分页,其实也就是配置分页单元,即初始化各级页表的表项内容(以及后续更新表项),如页与页框的映射关系,页的权限等等,之后只需把最上级的页目录(二级页表中是页目录,三级页表中是页目录指针表,四级页表中是页全局目录)的基地址给到cr3寄存器即可。

表项1
表项2
表项m
表项1
表项2
表项m
表项1
表项2
表项m
表项1
表项2
表项m
第一级页表
第二级页表1
第二级页表2
第二级页表m
第n级页表1
第n级页表2
第n级页表m
第n级页表1
第n级页表2
第n级页表m
第n级页表1
第n级页表2
第n级页表m

ps:为了实现进程地址空间隔离,Linux为每个进程配备自己的页表集,当进程切换时,cr3被保存到前一个进程的进程描述符中,后一个进程的进程描述中的保存值则被加载到cr3。

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值