注:本分类下文章大多整理自《深入分析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 时,如果当前特权级
低于描述符特权级,并且当前特权级保持不变,那么代码段只能执行。所谓当前特权级