在虚拟模式下(win Xp), 中断程序的奇怪现象。
仅个人经验而己,不正确之处请指正。实例:王爽书中(p240)有关除法错误0号中断程序:
Mov ax, 1000h
Mob bh, 1
Div bh
执行后会得到"divide overflow"除法溢出的错误信息。
这个divide overflow是从那里来的?根据0号中断向量表,它的程序入口地址在0:0~0:3, 在这里显示在00a7:1068地址.
然而,在那里并没有。进行搜索一下,
-s cs:0 1000 "Divide overflow", 这里cs=0, 发现在0000:0c7a。退出debug,再进入,用指令d 0000:0c7a再显示一下,你惊讶的发现那里是空的,再用同样的指令搜索,你发现它又在那里了,很奇怪,不是吗?!
我猜这是因为某些特定指令触动系统加载了这个代码。这也许是虚拟模式的特征吧。