12.11单步中断
如果CPU在执行完一条指令后,检测到TF=1,则产生单步中断。
单步中断过程如下:
(1)取得中断类型码。
(2)标志寄存器入栈,TF,IF=0
(3)CS,IP入栈
(4)(IP)=(1*4),(CS)=(1*4+2)
所以,如果TF=1,那么他执行完一条指令后就要单步中断,就是显示每个寄存器的状态,看上去没有问题,但是我们要知道,中断程序也是一个程序,也是一条条代码,如果这个时候TF还=1,他每执行一条指令后,都会进行单步中断,而单步中断又是单步中断,好像进入了无尽的深渊。
所以我们CPU就设置了TF=0.(自己理解的,若有不对欢迎指正)
12.12 响应中断的特殊情况
一般的中断CPU都会去理会的,但是凡事无绝对,有的中断CPU是不会管的。比如向SS寄存器中传送数据的指令。即便他之后的指令中断了,也不会去理会,而是一口气执行完因为ss是改变栈的,如果下一条指令有中断,就会push flag CS IP啥的,这样栈顶就不太对了。所以就不去理会。
所以我们通常连续设置栈顶(SS:SP)
mov ax,1000h
mov ss,ax
mov sp,0
会发现直接执行了mov sp,0