《汇编语言》讲稿10课件.ppt
《《汇编语言》讲稿10课件.ppt》由会员分享,可在线阅读,更多相关《《汇编语言》讲稿10课件.ppt(77页珍藏版)》请在三一办公上搜索。
1、第10章 call 和 ret 指令,第10章 call 和 ret 指令,章节分布,10.1 ret 和 retf10.2 call 指令10.3 依据位移进行转移的call指令10.4 转移的目的地址在指令中的call指令10.5 转移地址在寄存器中的call指令10.6 转移地址在内存中的call指令10.7 call 和 ret 的配合使用10.8 mul 指令10.9 模块化程序设计10.10 参数和结果传递的问题10.11 批量数据的传递10.12 寄存器冲突的问题,章节分布10.1 ret 和 retf,引言,call和ret 指令都是转移指令,它们都修改IP,或同时修改CS和I
2、P。它们经常被共同用来实现自程序的设计。这一章,我们将学习call和ret 指令的原理。,引言call和ret 指令都是转移指令,它们都修改IP,或同,10.1 ret 和 retf,ret指令用栈中的数据,修改IP的内容,从而实现近转移;操作retf指令用栈中的数据,修改CS和IP的内容,从而实现远转移;操作,10.1 ret 和 retfret指令用栈中的数据,修改I,10.1 ret 和 retf,CPU执行ret指令时,进行下面两步操作:(1)(IP)=(ss)*16+(sp)(2)(sp)=(sp)+2,10.1 ret 和 retfCPU执行ret指令时,进行下,10.1 ret
3、和 retf,CPU执行retf指令时,进行下面两步操作:(1)(IP)=(ss)*16+(sp)(2)(sp)=(sp)+2(3)(CS)=(ss)*16+(sp)(4)(sp)=(sp)+2,10.1 ret 和 retfCPU执行retf指令时,进行,10.1 ret 和 retf,可以看出,如果我们用汇编语法来解释ret和retf指令,则:CPU执行ret指令时,相当于进行: pop IPCPU执行retf指令时,相当于进行: pop IP pop CS,10.1 ret 和 retf可以看出,如果我们用汇编语法来,10.1 ret 和 retf,示例程序ret指令 程序中ret指令执
4、行后,(IP)=0,CS:IP指向代码段的第一条指令。retf指令 程序中retf指令执行后,CS:IP指向代码段的第一条指令。,10.1 ret 和 retf示例程序,特别提示,检测点10.1(p191)没有完成此检测点,请不要向下进行。,特别提示检测点10.1(p191),10.2 call 指令,CPU执行call指令,进行两步操作:(1)将当前的 IP 或 CS和IP 压入栈中;(2)转移。call 指令不能实现短转移,除此之外,call指令实现转移的方法和 jmp 指令的原理相同,下面的几个小节中 ,我们以给出转移目的地址的不同方法为主线,讲解call指令的主要应用格式。,10.2
5、call 指令CPU执行call指令,进行两步操作,10.3 依据位移进行转移的call指令,call 标号(将当前的 IP 压栈后,转到标号处执行指令)CPU执行此种格式的call指令时,进行如下的操作:(1) (sp) = (sp) 2 (ss)*16+(sp) = (IP)(2) (IP) = (IP) + 16位位移,10.3 依据位移进行转移的call指令call 标号(将当,10.3 依据位移进行转移的call指令,call 标号16位位移=“标号”处的地址call指令后的第一个字节的地址;16位位移的范围为 -3276832767,用补码表示;16位位移由编译程序在编译时算出。演
6、示,10.3 依据位移进行转移的call指令call 标号,汇编语言讲稿10课件,10.3 依据位移进行转移的call指令,从上面的描述中,可以看出,如果用汇编语法来解释此种格式的 call指令,则: CPU 执行指令“call 标号”时,相当于进行: push IP jmp near ptr 标号,10.3 依据位移进行转移的call指令从上面的描述中,可以,特别提示,检测点10.2(p192)没有完成此检测点,请不要向下进行。,特别提示检测点10.2(p192),10.4 转移目的地址在指令中的call指令,前面讲解的call指令,其对应的机器指令中并没有转移的目的地址 ,而是相对于当前I
7、P的转移位移。指令“call far ptr 标号”实现的是段间转移。操作,10.4 转移目的地址在指令中的call指令前面讲解的cal,10.4 转移目的地址在指令中的call指令,CPU执行“call far ptr 标号”这种格式的call指令时的操作:(1) (sp) = (sp) 2 (ss) 16+(sp) = (CS) (sp) = (sp) 2 (ss) 16+(sp) = (IP)(2) (CS) = 标号所在的段地址 (IP) = 标号所在的偏移地址,10.4 转移目的地址在指令中的call指令CPU执行“ca,10.4 转移目的地址在指令中的call指令,从上面的描述中可
8、以看出,如果我们用汇编语法来解释此种格式的 call 指令,则: CPU 执行指令 “call far ptr 标号” 时,相当于进行: push CS push IP jmp far ptr 标号,10.4 转移目的地址在指令中的call指令从上面的描述中可,特别提示,检测点10.3(p193)没有完成此检测点,请不要向下进行。,特别提示检测点10.3(p193),10.5 转移地址在寄存器中的call指令,指令格式:call 16位寄存器功能:(sp) = (sp) 2(ss)*16+(sp) = (IP)(IP) = (16位寄存器),10.5 转移地址在寄存器中的call指令指令格式:
9、call,10.5 转移地址在寄存器中的call指令,指令格式:call 16位寄存器汇编语法解释此种格式的 call 指令,CPU执行call 16位reg时,相当于进行: push IP jmp 16位寄存器,10.5 转移地址在寄存器中的call指令指令格式:call,特别提示,检测点10.4(p194)没有完成此检测点,请不要向下进行。,特别提示检测点10.4(p194),10.6 转移地址在内存中的call指令,转移地址在内存中的call指令有两种格式:(1) call word ptr 内存单元地址 (2) call dword ptr 内存单元地址,10.6 转移地址在内存中的c
10、all指令转移地址在内存中的c,10.6 转移地址在内存中的call指令,(1) call word ptr 内存单元地址汇编语法解释: push IP jmp word ptr 内存单元地址示例,10.6 转移地址在内存中的call指令(1) call w,10.6 转移地址在内存中的call指令,(1) call word ptr 内存单元地址(示例)比如下面的指令: mov sp,10h mov ax,0123h mov ds:0,ax call word ptr ds:0执行后,(IP)=0123H,(sp)=0EH,10.6 转移地址在内存中的call指令(1) call w,10.
11、6 转移地址在内存中的call指令,(2) call dword ptr 内存单元地址汇编语法解释: push CS push IP jmp dword ptr 内存单元地址示例,10.6 转移地址在内存中的call指令(2) call d,10.6 转移地址在内存中的call指令,(2) call 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.6 转移地址在内
12、存中的call指令(2) call d,特别提示,检测点10.5(p195)没有完成此检测点,请不要向下进行。,特别提示检测点10.5(p195),10.7 call 和 ret 的配合使用,前面,我们已经分别学习了 ret 和call指令的原理。现在我们看一下,如何将它们配合使用来实现子程序的机制。问题10.1,10.7 call 和 ret 的配合使用前面,我们已经分别,10.7 call 和 ret 的配合使用,assume cs:codecode segmentstart:mov ax,1 mov cx,3 call s mov bx,ax;(bx) = ? mov ax,4c00h
13、int 21h s: add ax,ax loop s retcode endsend start,问题10.1 右面程序返回前,bx中的值是多少? 思考后看分析。,10.7 call 和 ret 的配合使用assume cs,10.7 call 和 ret 的配合使用,问题10.1分析 我们来看一下 CPU 执行这个程序的主要过程:(1)CPU 将call s指令的机器码读入,IP指向了call s后的指令mov bx,ax,然后CPU执行call s指令,将当前的 IP值(指令mov bx,ax的偏移地址)压栈,并将 IP 的值改变为标号 s处的偏移地址;(2)CPU从标号 s 处开始执行
14、指令,loop循环完毕,(ax)=8;,10.7 call 和 ret 的配合使用问题10.1分析,10.7 call 和 ret 的配合使用,问题10.1分析(续) 我们来看一下CPU执行这个程序的主要过程:(3)CPU将ret指令的机器码读入,IP指向了ret 指令后的内存单元,然后CPU 执行 ret 指令 ,从栈中弹出一个值(即 call 先前压入的mov bx,ax 指令的偏移地址)送入 IP 中。则CS:IP指向指令mov bx,ax;(4)CPU从 mov bx,ax 开始执行指令,直至完成。,10.7 call 和 ret 的配合使用问题10.1分析(,10.7 call 和
15、ret 的配合使用,问题10.1分析(续) 程序返回前,(bx)=8 。我们可以看出,从标号s 到ret的程序段的作用是计算2的N次方,计算前,N的值由CX提供。我们再来看下面的程序,10.7 call 和 ret 的配合使用问题10.1分析(,10.7 call 和 ret 的配合使用,10.7 call 和 ret 的配合使用,10.7 call 和 ret 的配合使用,程序的主要执行过程:(1)前三条指令执行后,栈的情况如下:,10.7 call 和 ret 的配合使用程序的主要执行过程,10.7 call 和 ret 的配合使用,程序的主要执行过程:(2)call 指令读入后,(IP)
16、 =000EH,CPU指令缓冲器中的代码为 B8 05 00; CPU执行B8 05 00,首先,栈中的情况变为: 然后,(IP)=(IP)+0005=0013H。,10.7 call 和 ret 的配合使用程序的主要执行过程,10.7 call 和 ret 的配合使用,程序的主要执行过程:(3)CPU从cs:0013H处(即标号s处)开始执行。(4)ret指令读入后:(IP)=0016H,CPU指令缓冲器中的代码为 C3;CPU执行C3,相当于进行pop IP,执行后,栈中的情况为: (IP)=000EH;,10.7 call 和 ret 的配合使用程序的主要执行过程,10.7 call 和
17、 ret 的配合使用,程序的主要执行过程:(5)CPU回到 cs:000EH处(即call指令后面的指令处)继续执行。从上面的讨论中我们发现,可以写一个具有一定功能的程序段,我们称其为子程序,在需要的时候,用call指令转去执行。,10.7 call 和 ret 的配合使用程序的主要执行过程,10.7 call 和 ret 的配合使用,可是执行完子程序后,如何让CPU接着call指令向下执行?call指令转去执行子程序之前,call指令后面的指令的地址将存储在栈中,所以可以在子程序的后面使用 ret 指令,用栈中的数据设置IP的值,从而转到 call 指令后面的代码处继续执行。,10.7 ca
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 汇编语言 讲稿 10 课件
链接地址:https://www.31ppt.com/p-1292919.html