第十章:Call指令和Ret指令讲解02
让编程改变世界
Change the world by program
转移的目的地址在指令中的call指令
前面讲解的call指令,其对应的机器指令中并没有转移的目的地址 ,而是相对于当前IP的转移位移。 指令“call far ptr 标号”实现的是段间转移。CPU执行“call far ptr 标号”这种格式的call指令时的操作:
(1)(sp) = (sp) – 2
((ss) ×16+(sp)) = (CS)
(sp) = (sp) – 2
((ss) ×16+(sp)) = (IP)
(2)(CS) = 标号所在的段地址
(IP) = 标号所在的偏移地址
从上面的描述中可以看出,如果我们用汇编语法来解释此种格式的 call 指令,则: CPU 执行指令 “call far ptr 标号” 时,相当于进行:push CS
push IP
jmp far ptr 标号
检测点10.3
转移地址在寄存器中的call指令
格式:call 16位寄存器 功能:(sp) = (sp) – 2
((ss)*16+(sp)) = (IP)
(IP) = (16位寄存器)
汇编语法解释此种格式的 call 指令,CPU执行call 16位reg时,相当于进行:push IP
jmp 16位寄存器
检测点10.4
转移地址在内存中的call指令
转移地址在内存中的call指令有两种格式:(1) call word ptr 内存单元地址
(2) call dword ptr 内存单元地址
(1) call word ptr 内存单元地址
汇编语法解释:push IP
jmp word ptr 内存单元地址
比如下面的指令:mov sp,10h
mov ax,0123h
mov ds:[0],ax
call word ptr ds:[0]
执行后,(IP)=0123H,(sp)=0EH(2) call dword ptr 内存单元地址
汇编语法解释:push CS
push IP
jmp dword ptr 内存单元地址
比如,下面的指令:mov sp,10h
mov ax,0123h
mov ds:[0],ax
mov word ptr ds:[2],0
call dword ptr ds:[0]
执行后,(CS)=0,(IP)=0123H,(sp)=0CH检测点10.5
call指令和ret指令的配合使用
前面,我们已经分别学习了 ret 和call指令的原理。现在我们看一下,如何将它们配合使用来实现子程序的机制。问题10.1
右面程序返回前,bx中的值是多少? 思考后看分析。 [codesyntax lang="asm"]assume cs:code code segment start: mov ax,1 mov cx,3 call s mov bx,ax ;(bx) = ? mov ax,4c00h int 21h s: add ax,ax loop s ret code ends end start[/codesyntax]