80386的分段机制、分页机制和物理地址的形成


注:本分类下文章大多整理自《深入分析linux内核源代码》一书,另有参考其他一些资料如《linux内核完全剖析》、《linux c 编程一站式学习》等,只是为了更好地理清系统编程和网络编程中的一些概念性问题,并没有深入地阅读分析源码,我也是草草翻过这本书,请有兴趣的朋友自己参考相关资料。此书出版较早,分析的版本为2.4.16,故出现的一些概念可能跟最新版本内核不同。

此书已经开源,阅读地址 http://www.kerneltravel.net


MOVE REG,ADDR ;  它把地址为ADDR(假设为10000)的内存单元的内容复制到REG 中

在8086 的实模式下,把某一段寄存器(段基址)左移4 位,然后与地址ADDR 相加后被直接送到内 存总线上,这个相加后的地址(20位)就是内存单元的物理地址,而程序中的这个地址ADDR就叫逻辑地址 (或叫虚地址)。

在80386 的段机制中,逻辑地址由两部分组成,即 段部分(选择符) 及偏移部分。
段是形成逻辑地址到线性地址转换的基础。如果我们把段看成一个对象的话,那么对它 的描述如下。
(1)段的基地址(Base Address):在线性地址空间中段的起始地址。
(2)段的界限(Limit):表示在逻辑地址中,段内可以使用的最大偏移量。
(3)段的属性(Attribute): 表示段的特性。例如,该段是否可被读出或写入,或者 该段是否作为一个程序来执行,以及段的特权级等。

1、逻辑地址、线性地址和物理地址




所谓 描述符(Descriptor) ,就是描述段的属性的一个8 字节存储单元。

2、用户段描述符(Descriptor)



一个段描述符指出了段的32 位基地址和20 位段界限(即段大小)。 第6 个字节的G 位是粒度位,当G=0 时,段长表示段格式的字节长度,即一个段最长可 达1M 字节。当G=1 时,段长表示段的以4K 字节为一页的页的数目,即一个段最长可达 1M×4K=4G 字节。D 位表示缺省操作数的大小,如果D=0,操作数为16 位,如果D=1,操作数 为32 位。

第7 位P 位(Present) 是存在位,表示段描述符描述的这个段是否在内存中,如果在 内存中。P=1;如果不在内存中,P=0。

DPL(Descriptor Privilege Level) ,就是描述符特权级,它占两位,其值为0~3, 用来确定这个段的特权级即保护等级。0为内核级别,3为用户级别。

S 位(System)表示这个段是系统段还是用户段。如果S=0,则为系统段,如果S=1,则 为用户程序的代码段、数据段或堆栈段。

类型占3 位,第3 位为E 位,表示段是否可执行。当E=0 时,为数据段描述符,这时的 第2 位ED 表示地址增长方向。 第1 位(W)是可写位 当段为代码段时,第3 位E=1,这时第2 位为一致位(C)。当C=1 时,如果当前特权级 低于描述符特权级,并且当前特权级保持不变,那么代码段只能执行。所谓当前特权级
  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值