欢迎来到天天文库
浏览记录
ID:39601715
大小:442.10 KB
页数:77页
时间:2019-07-07
《《汇编语言》讲》PPT课件(I)》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、第10章call和ret指令章节分布10.1ret和retf10.2call指令10.3依据位移进行转移的call指令10.4转移的目的地址在指令中的call指令10.5转移地址在寄存器中的call指令10.6转移地址在内存中的call指令10.7call和ret的配合使用10.8mul指令10.9模块化程序设计10.10参数和结果传递的问题10.11批量数据的传递10.12寄存器冲突的问题引言call和ret指令都是转移指令,它们都修改IP,或同时修改CS和IP。它们经常被共同用来实现自程序的设计。这一章,我们将学
2、习call和ret指令的原理。10.1ret和retfret指令用栈中的数据,修改IP的内容,从而实现近转移;操作retf指令用栈中的数据,修改CS和IP的内容,从而实现远转移;操作10.1ret和retfCPU执行ret指令时,进行下面两步操作:(1)(IP)=((ss)*16+(sp))(2)(sp)=(sp)+210.1ret和retfCPU执行retf指令时,进行下面两步操作:(1)(IP)=((ss)*16+(sp))(2)(sp)=(sp)+2(3)(CS)=((ss)*16+(sp))(4)(sp)=(
3、sp)+210.1ret和retf可以看出,如果我们用汇编语法来解释ret和retf指令,则:CPU执行ret指令时,相当于进行:popIPCPU执行retf指令时,相当于进行:popIPpopCS10.1ret和retf示例程序ret指令程序中ret指令执行后,(IP)=0,CS:IP指向代码段的第一条指令。retf指令程序中retf指令执行后,CS:IP指向代码段的第一条指令。特别提示检测点10.1(p191)没有完成此检测点,请不要向下进行。10.2call指令CPU执行call指令,进行两步操作:(1)将当前
4、的IP或CS和IP压入栈中;(2)转移。call指令不能实现短转移,除此之外,call指令实现转移的方法和jmp指令的原理相同,下面的几个小节中,我们以给出转移目的地址的不同方法为主线,讲解call指令的主要应用格式。10.3依据位移进行转移的call指令call标号(将当前的IP压栈后,转到标号处执行指令)CPU执行此种格式的call指令时,进行如下的操作:(1)(sp)=(sp)–2((ss)*16+(sp))=(IP)(2)(IP)=(IP)+16位位移10.3依据位移进行转移的call指令call标号16位位
5、移=“标号”处的地址-call指令后的第一个字节的地址;16位位移的范围为-32768~32767,用补码表示;16位位移由编译程序在编译时算出。演示10.3依据位移进行转移的call指令从上面的描述中,可以看出,如果用汇编语法来解释此种格式的call指令,则:CPU执行指令“call标号”时,相当于进行:pushIPjmpnearptr标号特别提示检测点10.2(p192)没有完成此检测点,请不要向下进行。10.4转移目的地址在指令中的call指令前面讲解的call指令,其对应的机器指令中并没有转移的目的地址,而是
6、相对于当前IP的转移位移。指令“callfarptr标号”实现的是段间转移。操作10.4转移目的地址在指令中的call指令CPU执行“callfarptr标号”这种格式的call指令时的操作:(1)(sp)=(sp)–2((ss)×16+(sp))=(CS)(sp)=(sp)–2((ss)×16+(sp))=(IP)(2)(CS)=标号所在的段地址(IP)=标号所在的偏移地址10.4转移目的地址在指令中的call指令从上面的描述中可以看出,如果我们用汇编语法来解释此种格式的call指令,则:CPU执行指令“callf
7、arptr标号”时,相当于进行:pushCSpushIPjmpfarptr标号特别提示检测点10.3(p193)没有完成此检测点,请不要向下进行。10.5转移地址在寄存器中的call指令指令格式:call16位寄存器功能:(sp)=(sp)–2((ss)*16+(sp))=(IP)(IP)=(16位寄存器)10.5转移地址在寄存器中的call指令指令格式:call16位寄存器汇编语法解释此种格式的call指令,CPU执行call16位reg时,相当于进行:pushIPjmp16位寄存器特别提示检测点10.4(p194
8、)没有完成此检测点,请不要向下进行。10.6转移地址在内存中的call指令转移地址在内存中的call指令有两种格式:(1)callwordptr内存单元地址(2)calldwordptr内存单元地址10.6转移地址在内存中的call指令(1)callwordptr内存单元地址汇编语法解释:pushIPjmpwordptr内存单元地址示例10.6
此文档下载收益归作者所有