王爽汇编第二版检测点15.1(整理)

 对于15.1的答案精简为
pushf
call dword ptr ds:[0]
我觉得似乎不用pushf了吧,因为这是中断例程,占用的是中断类型码9的中断向量,
那在中断发生时,中断过程中,标志寄存器入栈是cpu硬件完成的啊,而且IF和TF也都由硬件置0,干嘛还需要再次pushf呢?
不明白!

 

CALL原来的中断例程时有一个IRET,改写后的中断例程最后还有一个IRET。为了保证堆栈不乱,所以得加个PUSHF

 

这个是在你自己的中断处理程序里面,模拟CPU去执行BIOS提供的int 9h中断。
CPU在执行中断处理程序前,做了什么工作。你的中断处理程序,在调用int 9h中断就一样要做什么工作。CPU干了以下4件事:
1.取中断类型码,这个我们已经知道是9,所以不用搞。
2.标志寄存器入栈。所以我们的中断处理程序也要pushf。这是必须的。
3.TF,IF=0。因为已经在中断处理程序里了,所以保证了TF,IF为0.所以15.1(1)里面说这一步也可以忽略。
4.CS,IP依次入栈。CALL就干了这个事情。
CPU为什么要这样呢?
因为BIOS提供的INT 9H中断,最后有一个IRET。
IRET干了以下3件事,POP IP,POP CS,POPF.这样就恢复了中断以前的CPU现场。
在我们这个程序中,如果你把PUSHF省略了,你自己想想有何后果吧。

你可能感兴趣的:(工作,汇编)