windows操作系统描述符结构说明

; 高地址………………………………………………………………………低地址

; |   7   |   6   |   5   |   4   |   3   |   2   |   1   |   0    |
; |7654321076543210765432107654321076543210765432107654321076543210| <- 共 8 字节
; |--------========--------========--------========--------========|
; ┏━━━┳━━━━━━━┳━━━━━━━━━━━┳━━━━━━━┓
; ┃31..24┃   (见下图)   ┃     段基址(23..0)    ┃ 段界限(15..0)┃
; ┃      ┃              ┃                      ┃              ┃
; ┃ 基址2┃③│②│    ①┃基址1b│   基址1a     ┃    段界限1   ┃
; ┣━━━╋━━━┳━━━╋━━━━━━━━━━━╋━━━━━━━┫
; ┃   %6 ┃  %5  ┃  %4  ┃  %3  ┃     %2       ┃       %1     ┃
; ┗━━━┻━━━┻━━━┻━━━┻━━━━━━━┻━━━━━━━┛
;         │                \_________
;         │                          \__________________
;         │                                             \________________________________________________
;         │                                                                                              \
;         ┏━━┳━━┳━━┳━━┳━━┳━━┳━━┳━━┳━━┳━━┳━━┳━━┳━━┳━━┳━━┳━━┓
;         ┃ 7  ┃ 6  ┃ 5  ┃ 4  ┃ 3  ┃ 2  ┃ 1  ┃ 0  ┃ 7  ┃ 6  ┃ 5  ┃ 4  ┃ 3  ┃ 2  ┃ 1  ┃ 0  ┃
;         ┣━━╋━━╋━━╋━━╋━━┻━━┻━━┻━━╋━━╋━━┻━━╋━━╋━━┻━━┻━━┻━━┫
;         ┃ G  ┃ D  ┃ 0  ┃ AVL┃   段界限 2 (19..16)  ┃  P ┃   DPL    ┃ S  ┃       TYPE           ┃
;         ┣━━┻━━┻━━┻━━╋━━━━━━━━━━━╋━━┻━━━━━┻━━┻━━━━━━━━━━━┫
;         ┃      ③: 属性 2      ┃    ②: 段界限 2      ┃                   ①: 属性1                  ┃
;         ┗━━━━━━━━━━━┻━━━━━━━━━━━┻━━━━━━━━━━━━━━━━━━━━━━━┛
;       高地址                                                                                          低地址
;
;

; 说明:
;
; (1) P:    存在(Present)位。
;  P=1 表示描述符所描述的段存在内存中;
;  P=0 表示描述符所描述的段不在内存中。使用该描述符进行内存访问时会引起异常。
;
; (2) DPL:  表示描述符特权级,共2位。特权检查时决定对该段能否访问。
;
; (3) S:   说明描述符的类型。
; S=1表示存储段描述符,S=0表示系统段描述符或门描述符。
;
; (4) TYPE: 表示描述符所描述存储段的具体属性。
;
;  
; 数据段类型 类型值  说明
;   ----------------------------------
;   0  只读
;   1  只读、已访问
;   2  读/写
;   3  读/写、已访问
;   4  只读、向下扩展
;   5  只读、向下扩展、已访问
;   6  读/写、向下扩展
;   7  读/写、向下扩展、已访问
;
;  
;   类型值  说明
; 代码段类型 ----------------------------------
;   8  只执行
;   9  只执行、已访问
;   A  执行/读
;   B  执行/读、已访问
;   C  只执行、一致码段
;   D  只执行、一致码段、已访问
;   E  执行/读、一致码段
;   F  执行/读、一致码段、已访问
;
;  
; 系统段类型 类型编码 说明
;   ----------------------------------
;   0  <未定义>
;   1  可用286TSS
;   2  LDT
;   3  忙的286TSS
;   4  286调用门
;   5  任务门
;   6  286中断门
;   7  286陷阱门
;   8  未定义
;   9  可用386TSS
;   A  <未定义>
;   B  忙的386TSS
;   C  386调用门
;   D  <未定义>
;   E  386中断门
;   F  386陷阱门
;
; (5) G:    段界限粒度(Granularity)位。
;  G=0 表示界限粒度为字节;
;  G=1 表示界限粒度为4K 字节。
;
; (6) D:    ‌D位在描述符中具有特殊意义,其作用根据所描述的段类型不同而有所差异‌。具体而言:

在描述可执行段时‌:D位决定了指令使用的地址及操作数的默认大小。若D=1,则默认情况下指令使用32位地址及32位或8位操作数,此类代码段被称为32位代码段;若D=0,则默认情况下使用16位地址及16位或8位操作数,此类代码段被称为16位代码段,与80286兼容。同时,可以通过地址大小前缀和操作数大小前缀来改变默认的地址或操作数大小‌1。;        

在描述向下扩展的数据段时,D位用于确定段的上部边界‌。具体来说:

当D=1时,表示该段的上部界限扩展至4G;

当D=0时,表示该段的上部界限为64K,这样做是为了保持与80286的兼容性。

在描述由SS寄存器寻址的段描述符中,SS寄存器寻址的段描述符中D位作用‌:

  • D位决定堆栈访问指令的寄存器‌:在描述由SS寄存器寻址的段描述符中,D位用于决定隐式的堆栈访问指令(例如PUSH和POP)使用哪种堆栈指针寄存器。
    • D=1时,使用32位堆栈指针寄存器ESP;
    • D=0时,使用16位堆栈指针寄存器SP,这样做是为了与80286兼容。

AVL位‌:

  • 软件可利用位‌:AVL位是软件可利用位,80386及之后与80386兼容的处理器都未对该位的使用做任何定义或规定。

;----------------------------------------------------------------------------
; 描述符类型值说明
; 其中:
;       DA_  : Descriptor Attribute
;       D    : 数据段
;       C    : 代码段
;       S    : 系统段
;       R    : 只读
;       RW   : 读写
;       A    : 已访问
;       其它 : 可按照字面意思理解


; 选择子图示:
;         ┏━━┳━━┳━━┳━━┳━━┳━━┳━━┳━━┳━━┳━━┳━━┳━━┳━━┳━━┳━━┳━━┓
;         ┃ 15 ┃ 14 ┃ 13 ┃ 12 ┃ 11 ┃ 10 ┃ 9  ┃ 8  ┃ 7  ┃ 6  ┃ 5  ┃ 4  ┃ 3  ┃ 2  ┃ 1  ┃ 0  ┃
;         ┣━━┻━━┻━━┻━━┻━━┻━━┻━━┻━━┻━━┻━━┻━━┻━━┻━━╋━━╋━━┻━━┫
;         ┃                                 描述符索引                                 ┃ TI ┃   RPL    ┃
;         ┗━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┻━━┻━━━━━┛
;
; RPL(Requested Privilege Level): 请求特权级,用于特权检查。
;
; TI(Table Indicator): 引用描述符表指示位
; TI=0 指示从全局描述符表GDT中读取描述符;
; TI=1 指示从局部描述符表LDT中读取描述符。
;

  • 16
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值