保护模式下的编程<四>

类别:编程语言 点击:0 评论:0 推荐:

                          保护模式下的编程<四>

        这段代码,我们可以用前面的图来表示.要用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,通过调用门可实现任务内从外层特权变换到内层特权级。

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

本文地址:http://com.8s8s.com/it/it28838.htm