全局描述符表GDT、局部描述符表LDT和中断描述符表IDT等都是保护模式下非常重要的特殊段。 他们包含有对段机制所用的重要表格。 为了方便定位这些段,处理器采用一些特殊的寄存器保存这些段的基地址和段界限。 这些特殊的寄存器就是系统地址寄存器。
①全局描述符表寄存器GDTR
全局描述符表寄存器长48位,其中高32位含基地址,低16位含段界限。由于GDT不能由其本身之内的描述符进行描述定义,所以处理器采用GDTR为GDT这一特殊的系统段提供一个伪描述符。利用结构类型定义伪描述符如下:
PDESC STRUC
LIMIT DW 0
BASE DD 0
PDESC ENDS
GDTR中的段界限以字节为单位。 由于段选择子中只有13位作为描述符索引,而每个描述符长8个字节, 所以用16位表示GDT的界限就足够了。通常对于含有N个描述符的描述符表的段界限赢设置为8*N-1
②局部描述符表寄存器LDTR
局部描述符寄存器LDTR规定当前任务使用的局部描述符表LDT。LDTR类似段寄存器,由可见的16位寄存器和不可见的告诉缓冲寄存器组成。 实际上,每个任务的局部描述符表LDT作为系统的一个特殊段, 由一个描述符描述,而用于描述LDT的描述符存放在GDT中。 在初始化或者任务切换中,把指示描述对应任务LDT的描述符的选择子装入LDTR,处理器根据装入LDTR可见部分的选择子,从GDT中取出对应的描述符,并把LDT的基地址和段界限等信息保存到LDTR的高速缓冲寄存器中。 随后对LDT的访问,就根据保存在高速缓冲寄存器中的相关信息进行合法性检查。
LDTR寄存器包含当前任务的LDT的选择子。 所以, 装入到LDTR的选择子必须确定一个位于GDT的类型为LDT的系统段描述符, 也即选择子中的TI必须是0,而且描述符中的类型字段所表示的类型必须是LDT。
可以用一个空选择子装入LDTR,这表示当前任务没有LDT。 在这种情况下,所有装入到段寄存器的选择子都必须指示GDT中的描述符,也即当前任务涉及的段都由GDT中的描述符来描述, 如果再把一个TI=1的选择子装入段寄存器,将引起异常。
③中断描述符寄存器IDTR
中断描述符表寄存器IDTR指向中断描述符表IDT。IDTR长48位,其中32位规定的基地址规定IDT的基地址,16位的界限规定IDT的段界限。由于80386只支持256个中断/异常,所以IDT表最大长度2K,以字节为单位的段界限为7FFH。IDTR指示IDT表的方式与GDTR指示GDT的方式相同。
④任务状态段寄存器TR
任务状态寄存器TR包含指示描述当前任务的任务状态段的描述符选择子,从而规定了当前任务的状态段。TR也分为可见的和不可见两部分。当把任务状态段的选择子装入TR可见部分时,处理器自动把选择子所索引的描述符中的段基地址等信息保存在不可见的高速缓冲寄存器中。 装入到TR的选择子不能为空,必须索引位于GDT中的描述符,切描述符类型必须是TSS。
- [somniumchase] 我一运行就说没有数字 01/01 11:44
- [游客] 为什么啊 08/07 15:36
- [游客] 如果想快一些 就改下面这里 dx值改成1H delay: push ax 04/19 02:53
- [lshhjx] 注释在程序中很重要,楼主不知道吗? 12/08 13:40
- [biaggi] 看不明白,在下還須學習 11/06 08:11
- [游客] 我运行的时候直接显示Unkown filename跳出了- -请问怎么改 06/16 21:44
- [游客] 勿庸置疑,注释是好习惯。与人方便自己方便。 04/12 10:33
- [游客] 老实说,看着真心累呀! 04/07 18:37
- [游客] 很无语,初学者就多看书,不要动不动要别人注释,基础打好了,再自己注释,这样比别人帮你注释好得多 12/17 19:43
- [dgkepu] 初学者:不懂,希望有多点注释带着学习学习! 12/07 20:52
- [游客] windows 7是一个64Bit操作系统,它不兼容DOS,无法识别16Bit系统。重装系统wind 02/28 21:05
- [游客] windows 7是一个64Bit操作系统,它不兼容DOS,无法识别16Bit系统。重装系统wind 02/28 21:05
- [466987333] 你好,高手,我想请教一个问题。 我用的是win7操作系统,32位的,里面没有找masm目录,是不是 12/12 17:30
- [lanfioncc] 那个太高级了。。。我还有点看不懂。。不过谢谢!!! 11/27 11:23
- [yc2010] 实验16中的 table: dw sub1,sub2,sub3,sub4 可不可以改成呢? 09/11 09:08
- [yc2010] mov bl,ah mov bh,0 add bx,bx ----------->这里为 09/07 21:03
- [yc2010] 为什么要add bx,bx呢? 09/07 20:55
- [yc2010] 那是不是像table[bx],ds[bx]....等(内存单元)都是表示一个字节呢? 09/06 21:10
- [masmaster] 杨季文的《80X86汇编语言程序设计教程》 09/01 12:52
- [游客] to masmaster shl左移4位,那al传进来的4,5,6位背景色不就没了. 为什 09/01 11:00