. : : Assembly Language : : .  |  首页  |  我提出的问题  |  我参与的问题  |  我的收藏  |  消息中心   |  游客  登录  | 
刷新 | 提问 | 未解决 | 已解决 | 精华区 | 搜索 |
  《汇编语言》论坛 ->外中断
  管理员: assembly   [回复本贴] [收藏本贴] [管理本贴] [关闭窗口]
主题 : :  15.5 新int9 中断例程中数据进出栈的疑问  [待解决] 回复[ 1次 ]   点击[ 333次 ]  
wping
[帖 主]   [ 发表时间:2009-03-14 16:07 ]   [引用]   [回复]   [ top ] 
荣誉值:0
信誉值:0
注册日期:2009-01-15 17:32
书中这样写:
int9:push ax
     push bx
     push cx
     push es

     in al,60h
     pushf
     ......
这是进栈,
出栈的顺序则是:
int9ret:
pop es
pop cx
pop bx
pop ax
iret

最后入栈的应该是标志寄存器(pushf),理应第一个出栈才对.
请高手帮忙解答一下
younggay
[第1楼]   [ 回复时间:2009-03-16 11:06 ]   [引用]   [回复]   [ top ] 
荣誉值:273
信誉值:0
注册日期:2008-01-23 20:23
楼主对于前面的中断过程,以及我们实现自己的int9中断例程时候做的一些重要处理,比如说键盘输入处理(调用以前的int 9中断例程)还是没有彻底理解。
这里的
pushf
call word ptr cs:[200]
是在调用以前的键盘处理中断,我们在修改中断向量表之前,把以前的int 9中断放到了这个地址处,由于我们只是去模拟实现int 9中断的一些功能,对于键盘处理,我们还需要调用之前的int 9中断例程的。但是,我们直接
call word ptr cs:[200]只是字节进行了子程序的调用,我们知道,中断最后都是iret,所以,中断例程调用前都必须pushf。以前pushf都是硬件根据中断响应自动作出的,但是,现在,我们以call来调用的时候,必须我们来实现了,因为不是通过中断机制去调用的,是没有pushf的,只能我们在call之前自己加上。所以,这个pushf对应的是call的子程序中的iret而不是你的中断程序中的iret或pop。

楼主不妨重新温习和研究一下本章的内容和知识点。这里一定要搞清楚的。
需要登录后才能回帖 -->> 请单击此处登录
    Copyright © 2006-2024   ASMEDU.NET  All Rights Reserved