注册 登录
编程论坛 汇编论坛

关于cpu修改ip的疑惑

zzx198411 发布于 2008-08-24 19:34, 1638 次点击
下面三条指令执行后,cpu几次修改ip?都是在什么时候?最后ip中的值是多少?
mov ax,bx
sub ax,ax
jmp ax

在读入指令jmp ax后,ip要自动加上2,但下一步不是在这个新的物理地址上读取指令而是在偏移地址ip=ax组成的这个物理地址上读取,为什么?
还有为什么最后的ip值为0.
4 回复
#2
ONEPROBLEM2008-08-24 22:16
呵呵~~~似曾相识哦。
王爽的汇编语言练习题吧~~~
-a
0B08:0100 mov ax,bx
0B08:0102 sub ax,ax
0B08:0104 jmp ax
0B08:0106
-r
AX=0000  BX=0000  CX=0000  DX=0000  SP=FFEE  BP=0000  SI=0000  DI=0000
DS=0B08  ES=0B08  SS=0B08  CS=0B08  IP=0100   NV UP EI PL NZ NA PO NC
0B08:0100 89D8          MOV     AX,BX
-t

AX=0000  BX=0000  CX=0000  DX=0000  SP=FFEE  BP=0000  SI=0000  DI=0000
DS=0B08  ES=0B08  SS=0B08  CS=0B08  IP=0102   NV UP EI PL NZ NA PO NC
0B08:0102 29C0          SUB     AX,AX
-t

AX=0000  BX=0000  CX=0000  DX=0000  SP=FFEE  BP=0000  SI=0000  DI=0000
DS=0B08  ES=0B08  SS=0B08  CS=0B08  IP=0104   NV UP EI PL ZR NA PE NC
0B08:0104 FFE0          JMP     AX
-t

AX=0000  BX=0000  CX=0000  DX=0000  SP=FFEE  BP=0000  SI=0000  DI=0000
DS=0B08  ES=0B08  SS=0B08  CS=0B08  IP=0000   NV UP EI PL ZR NA PE NC
0B08:0000 CD20          INT     20
-
#3
ONEPROBLEM2008-08-24 22:25
LZ,我觉得有疑问的时候,你不妨打开DEBUG,容易明白得快哦~~
你观察一下吧:IP原先的值是0100,执行了这三条指令后,IP=0000,你说修改了几次?都是在什么时候修改的?最后IP为什么是0000 ?因为有sub ax,ax .
jmp ax 这条指令本来就是一条修改IP值的指令。当读取这条指令时,IP是打算要加2的,但jmp指令就开口说了:别加了,按我说的去做。于是,IP就乖乖地接受ax的值了。
个人理解而已~~~LZ可以再想想,不同意见是有的。
#4
ONEPROBLEM2008-08-24 22:32
不过,想想也是,当读取这条指令jmp ax进入指令缓冲器的时候,IP应该是先加2,指向jmp ax后面的下一条指令的,然后真正执行jmp ax 了才修改IP的。
但是,到底修改几次我一般是以DEBUG来检验的。至于到底有没有加2,充分的证据又在哪呢?
#5
zzx1984112008-08-25 08:30
^_^ 谢谢oneproblem的大力支持,我会以后注意debug的。
1