内中断 是发生了需要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,以屏蔽中断,知道下一个指令处再执行中断)