保护模式下的编程<四>

王朝other·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

保护模式下的编程<四>

这段代码,我们可以用前面的图来表示.要用LDT,我们需要用到mov ax,gdtseg ,lldt ax这两个命令是把全局描述表送入局部描述表寄存器.在执行完这两个命令后,我就可以使用

局部描述符中的描述表中的各个段了.呵呵.

下面这段代码演示了任务内特权级的变换,在这个程序中我演示了怎样通过调用门和RETF实现任务内特权级的变换。每一个特权级都有自己对应的堆栈。在我的这个程序中我使用了0级和3级,在不通的特权级的变换中,我使用了堆栈来实现变换的。首先建立0级的堆栈,然后将3级堆栈的指针压入这个0级堆栈。理论上还要将3级段使用的参数压入0级堆栈。这样便于0级的函数直接调用这些参数,但是我的这个程序没有这样做,因为该程序没有参数可以压入。然后使用retf使得CS指向vcode_sel描述符所描述的段,eip指向编译vstart,这样段的转移就实现了。

接着用写屏技术将我想显示的东西显示出来,就使用调用门来实现从0级回到3级。我将介绍调用门。

门也是描述符的一种。他的结构如下:

gate struc

offsetl dw 0 ;32位偏移的低16位

selector dw 0 ;选择子

dcount db 0 ;双字计算字段

gtype db 0 ;类型

offseth dw 0 ;32位偏移的高16位

gate ends

如tovbuf gate <tojump,codek_sel,0,at386cgate+dpl3,0>,tojump表示32位偏移的低16位,最后的0是32位偏移的高16位,codek_sel是目标的选择子,就是目标段的描述符。门的DPL描述了能够访问该段的最外层的段。可以利用段间调用指令CALL,通过调用门可实现任务内从外层特权变换到内层特权级。

由于文件加代码很长,所以代码请看保护模式编程五

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航