汇编语言学习笔记 联系客服

发布时间 : 星期六 文章汇编语言学习笔记更新完毕开始阅读edcacefcc8d376eeafaa3105

第十章 call和ret指令

ret和retf

ret指令:用栈中的数据修改IP的内容,从而实现近转移 执行的操作: (ip)= ((ss)*16+ (sp)) (sp)= (sp) +2

retf指令:用栈中的数据修改CS和IP的内容,从而实现远转移 执行的操作: (ip)= ((ss)*16+ (sp)) (sp)= (sp) +2 (cs)= ((ss)*16+ (sp)) (sp)= (sp) +2

call指令 格式: call 标号 call far ptr 标号 call reg

call word ptr mem call dword ptr mem

格式: call标号

功能:将当前的IP压栈后,转到标号处执行指令 操作: (sp)=(sp)-2 ((ss)*16+(sp))=(IP) (IP)=(IP)+16位位移

相当于 push IP jmp near ptr 标号 说明:

1) 16位位移=“标号”处的地址-call指令后第一个字节的地址 2) 16位位移的范围是转移到段内的任意位置 3) 16位位移是由编译程序在编译时算出

格式:call far ptr 标号

转移的目的地址在指令中的call指令

功能:将当前的CS和IP压栈后,转到标号处执行指令 操作: (sp)= (sp)-2

((ss)*16+ (sp))= (CS) (sp)= (sp)-2 ((ss)*16+ (sp))= (IP) (CS)=标号所在段的段地址 (IP)=标号在段中的偏移地址 相当于 push cs pushIP

jmp far ptr 标号

格式:call reg

转移地址在寄存器中的call指令

功能:将当前的IP压栈后,转到寄存器中所存放的偏移地址处执行指令 操作: (sp)=(sp)-2 ((ss)*16+(sp))=(IP) (IP)=(16位寄存器)

转移地址在内存中的call指令

格式1:call word ptr mem 操作:push IP jmp word ptr mem

例:mov sp,10h mov ax,0123h mov ds:[0],ax call word ptr ds:[0]

格式2:call dword ptr mem 操作:push cs push IP

jmp dword ptr mem

例:mov sp,10h mov ax,0123h mov ds:[9],ax mov word ptr ds:[2],0

call dword ptr ds:[0]