汇编语言 第十章 CALL和RET指令

本文详细介绍了汇编语言中CALL和RET指令的使用,包括它们在不同情况下的执行过程,如ret和retf的区别,以及call指令的各种形式,如依据位移、寄存器和内存中的转移。此外,还探讨了call与ret的配合使用,mul指令,以及模块化程序设计中的参数和结果传递问题。

10.1 ret和retf

ret指令用栈中的数据更改IP的内容,从而实现近转移

进行的过程:pop IP

(IP) = ((SS * 16) + (SP))

(SP) = (SP) + 2

retf指令用栈中的数据更改CS和IP的内容,从而实现远转移

执行过程:1.pop IP,2.pop CS

(IP) = ((SS)  * 16 + (SP))

(SP) = (SP) + 2

(CS) = ((SS) * 16 + (SP))

(SP)  = (SP) + 2

书中程序ret前面有一个mov bx,0感觉没实际作用

检测点10.1

补全程序,实现从内存1000:0000处来世执行指令。

assume cs:code 

stack segment 

    db 16 dup(0)

stack ends

code segment

start:
    mov ax,stack
    mov ss,ax
    mov sp,16
    mov ax,1000H
    push ax
    mov ax,0
    push ax
    retf

code ends

end start

### 汇编语言王爽第四版第十章实验内容及指导 #### 实验目标 通过编写并调试简单的汇编程序,理解子程序调用机制以及堆栈的工作原理。掌握 `CALL` `RET` 指令的作用及其对寄存器的影响。 #### 实验环境设置 为了确保能够顺利运行测试代码,在开始之前需配置好开发环境: - 使用 MASM 或 TASM 编译工具; - 准备 DOSBox 或其他兼容 MS-DOS 的虚拟机来模拟真实的硬件平台; #### 关键知识点解析 当执行 `call s` 指令时会先保存当前指令指针(IP),即将其压入堆栈中以便稍后返回继续执行原位置后的代码[^1]。之后跳转至指定标签处执行新流程。而当遇到 `ret` 返回指令时,则自动弹出先前存储于栈内的地址值重新加载回 IP 寄存器从而实现函数间的来回切换功能[^2]。 #### 示例代码分析 下面给出一段用于演示上述理论概念的小例子,并附带详细说明每一步骤的具体作用: ```assembly assume cs:code, ss:stack ; 定义段描述符 stack segment ; 堆栈段定义 db 16 dup(0) ; 初始化16字节大小的空间作为工作区 stack ends ; code segment ; 代码段开始标记 start: mov ax, stack ; 将堆栈段基址送入AX暂存器内 mov ss, ax ; 设置SS为新的堆栈段选择子 mov sp, 16 ; SP指向最顶端位置准备接收后续数据项 mov ax, 1000h ; AX=CS初始设定值 push ax ; CS的值被推送到堆栈顶部 mov ax, 0 ; 清零AX用来表示IP应置位成0 push ax ; 把清空后的AX也一并加入其中代表起始偏移量 retf ; 远程返回操作码触发远距离跳跃动作 ; 此刻CPU将会依次取出两个双字分别赋予IP/CS完成跨段转移 code ends ; 结束整个源文件编辑过程 end start ; 明确指出入口点位于哪里 ``` 这段程序展示了如何利用堆栈管理控制流转向不同部分的方法。特别值得注意的是最后那条远程返回命令(`retf`)它不仅改变了下一条待处理语句的位置还同时更改了正在使用的代码段编号实现了真正的模块化编程风格。 #### 调试技巧提示 建议读者尝试借助 DEBUG 工具逐步单步追踪以上实例中的各项变动状况,尤其是关注各个通用目的寄存器的状态改变趋势。这有助于加深对于底层架构运作细节的理解程度[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值