保护模式下的编程<四>

博客介绍保护模式下的编程,涉及使用mov和lldt命令将全局描述表送入局部描述表寄存器以使用局部描述符各段。还演示了通过调用门和RETF实现任务内特权级变换,利用堆栈完成不同特权级切换,介绍了调用门结构及通过它实现特权变换的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

                          保护模式下的编程<四>

        这段代码,我们可以用前面的图来表示.要用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位,最后的032位偏移的高16位,codek_sel是目标的选择子,就是目标段的描述符。门的DPL描述了能够访问该段的最外层的段。可以利用段间调用指令CALL,通过调用门可实现任务内从外层特权变换到内层特权级。

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值