再理解retf和特权等级跳转

        retf 指令:retf指远返回,就是执行指令时,将[ESP]送EIP,[ESP+4]送CS,同时进行保护检查,违反则GP,不然就执行新地址处指令,一般我们在RING0返回RING3时使用,一般不用因为我们在FLAT模式下。

今天对特权等级的转移又有了一些新的认识。
        翻看前面的内容,发现有下面一段解释:“一致”的意思是这样的,当转移的目标是一个特权级更高的一致代码段时,当前的特权级(CPL)会被延续下去,而向特权级更高的非一致代码段的转移会引起常规保护错误,除非使用调用门或者任务门。如果代码不访问受保护的资源和某些类型的异常(比如,除法错误或者溢出错误),它可以被放在一致代码段(这样,受保护的资源的控制权就完全掌握在了应用程序不能访问的核心代码的手中。……个人理解)。为避免低特权等级的程序访问而被保护起来的系统代码应放在非一致代码段中。

        今天看了门,建桥门,酒瓶门,调用门。。。。。。无语。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
以下是用8253和8259实现500ms中断的汇编语言程序: ``` ;设置8253计时器 mov al, 00110110b ;选择计数器0,工作模式3,二进制计数 out 43h, al ;向控制字寄存器发送命令字节 mov ax, 1193 ;设置计数器0初值为1193,为500ms的计数值 out 40h, al ;向计数器0发送低字节 mov al, ah out 40h, al ;向计数器0发送高字节 ;初始化8259中断控制器 mov al, 11110000b ;设置主片IRQ0~3连接从片,开启中断 out 20h, al ;向主片发送ICW1 mov al, 00000100b ;设置主片IRQ2连接从片 out 21h, al ;向主片发送ICW2 mov al, 00000100b ;设置从片连接主片IRQ2 out 0A0h, al ;向从片发送ICW2 mov al, 00000001b ;设置主片和从片均为8086模式 out 21h, al ;向主片发送ICW4 out 0A1h, al ;向从片发送ICW4 ;开启中断 sti ;等待中断发生 wait: jmp wait ;中断服务程序 interrupt: ;处理中断 ;清除中断标志 in al, 20h ;读取主片中断服务结束寄存器 or al, 00000001b ;设置EOI位 out 20h, al ;向主片发送中断服务结束信号 in al, 0A0h ;读取从片中断服务结束寄存器 or al, 00000001b ;设置EOI位 out 0A0h, al ;向从片发送中断服务结束信号 retf ;中断返回 ``` 在上面的程序中,我们首先设置8253计时器的工作模式和初值,使其每次计数到1193时触发一次中断,即500ms。然后初始化8259中断控制器,并开启中断。在程序的主循环中,我们使用一个无限循环来等待中断的发生。中断服务程序中,我们首先处理中断,然后清除中断标志,并使用`retf`指令返回到中断前的状态。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值