【学习笔记】汇编:关于内中断的规则

内中断 是发生了需要CPU立即去处理的信息

有以下情况

1、除法溢出

2、单步执行

3、执行INTO指令

4、执行INT指令

这里以INT指令为例,当发生内中断时,CS:IP会指向所需执行的程序的入口

若使用INT X那么会遵循(中断向量表)

IP = (word ptr 0:X*4) CS =(word ptr 0:X*4+2) 规则

注意这里并非获取的地址,而是获取的指向地址的值

如使用INT 0H

那么就会让CS:IP指向 (word ptr 0:2):(word ptr 0:0)

同时程序入口的地址不固定,每个CPU都不一样(仅一次验证,同一个不变)


同时会出现这么一个问题:

当执行

MOV SS,AX

MOV SP,128;或者别的什么指令的时候

会出现跳过MOV SS,AX的中断(DEBUG)直接跳到下一条指令处

这是由于此处栈移位,单步执行会将之前的CS:IP还有标志寄存器压入栈

在执行完MOV SS,AX之后,栈顶将不正确,无法将中断时的指令取出,所以这里单步中断程序(DEBUG)程序默认跳到下一个指令处再开始中断(即MOV SS,AX时会将TF与IF设置为0,以屏蔽中断,知道下一个指令处再执行中断)

猜你喜欢

转载自blog.csdn.net/h2809871142/article/details/79381736