除了存储段描述符和系统段描述符外,还有一类门描述符。
门描述符并不描述某种内存段,而是描述控制转移的入口点。 这种描述符好比一个通向另一个代码段的门。 通过这种门,可实现任务特权级的变换和任务间的切换。因此,这种门描述符也称为控制门。
①门描述符的一般格式
门描述符只有位于描述符内偏移5的类型字节与系统段描述符保持一致,也由该字节标识门描述符和系统段描述符。 该字节内的P位和DPL位的含义与其他描述符中的意义相同。其他字节主要用于存放一个48位的全指针(16位的选择子和32位的偏移量)
其数据结构如下:
GATE STRUC
OFFSETL DW 0 ;32位偏移的低16位
SELECTOR DW 0 ;选择子
DCOUNT DB 0 ;计数字段
GTYPE DW 0 ;类型
OFFSETH DW 0 ;32位偏移的高16位
GATE ENDS
门描述符还可分为:任务门、调用门、中断门和陷阱门,并且除了任务门之外,其他的门描述符又各分为286和386两种。
②调用门
调用门描述某个子程序的入口。 调用门内的选择子必须指向代码段描述符,调用门内的偏移是对应代码段内的偏移。 利用段间调用指令CALL,通过调用门可实现任务内从外层特权级变化到内层特权级。
②任务门
任务门指示任务。 任务门内的选择子必须指向GDT中的任务状态段TSS描述符, 门内的偏移无意义。 任务的入口点保存在TSS中。 利用段间转移指令JMP和段间调用指令CALL,通过任务门可实现任务切换。
③中断门和陷阱门
中断门和陷阱门描述中断/异常处理程序的入口点。 中断门和陷阱门内的选择子必须指向代码段描述符,门内的偏移就是对应代码段的入口点偏移。中断门和陷阱门只有在中断描述符表IDT中才有效。
- [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