码迷,mamicode.com
首页 > 系统相关 > 详细

Linux进程3——虚拟地址访问

时间:2017-08-06 20:45:05      阅读:192      评论:0      收藏:0      [点我收藏+]

标签:结果   linux   适应   通道   x86   内核   bit   导致   实现   

1.虚拟地址到物理地址

  X86芯片访问内存,需要使用MMU功能,实现虚拟地址到线性地址,再到物理地址的访问。

X86的分段机制是强制的,分页机制是可选的。

技术分享

2.分段机制

  X86的虚拟地址,由选择符:偏移值决定。段选择符由CS,SS,DS等组成。CS为代码段选择符,SS为堆栈段选择符,

DS为数据段选择符。

技术分享

  Index为段描述符在全局段描述符表或局部段描述符表的索引,因为段描述符为8字节,所以从bit3开始。

  TI表示是GDT或者LDT

  RPL表示段访问权限,内核态为0,用户态为3.

  段描述符结果如下:

  技术分享

  通道段描述符和偏置计算线性地址。

技术分享

3.Linux分段机制

  Linux主要使用分页机制,为了适应X86芯片,简化了分段机制。为用户态程序和内核态程序分别建立CS和DS

段描述符,使基地址为0,长度为4GB。

  技术分享

4.Linux段分页机制

  X86的32位地址分成3个区域,包括目录、页表和偏移量。如果采用2级模式,会导致每个进程需要4MB(4B * (2^20))空间

保存页表项。采用这种3级页表安排方式,可以保证程序只保存使用的页表项,并且在实际访问地址时才加载缺省的页面。

技术分享

  目录项和页表项具有相同的数据结构,每个进程可以有1024个目录项,每个目录项可以有1024个页表项,

每个页表项指向一个4KB的目录内存页。

  技术分享 

 

Linux进程3——虚拟地址访问

标签:结果   linux   适应   通道   x86   内核   bit   导致   实现   

原文地址:http://www.cnblogs.com/TheImportanceOfLiving/p/7294083.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!