汇编ret指令怎么用?

 我来答
太平洋科技
优质机构答主

2023-01-06 · 百度认证:广东太平洋互联网信息服务有限公司官方账号,优质数码...
太平洋科技
太平洋电脑网通过分析、评测生活及工作中各类消费品,让消费者客观了解产品性能及安全状况,帮助用户做出理性购买选择。同时科普各领域产品知识,解答用户选购及使用中所遇问题。
向TA提问
展开全部

ret用栈的数据修改IP的内容,实现近转移。

ret执行步骤:

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

(2):(SP)=(SP)+2

执行过程

ret指令用栈中的数据,修改IP的值,从而实现近转移。

CPU执行ret指令时,进行下面两步操作:

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

(SP)=(SP)+2;

另一种用法ret n(n为整数)

等效于

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

(SP)=(SP)+2;

(SP)=(SP)+n;

例如ret 4

pop ip

add sp,4

返回调用处

例:

push eax

call msg;call标号是把eip压入堆栈,然后再跳到标号msg处;[标记1]

;继续代码....

msg:

push 0

push 0

push eax

push 0

call dword ptr[MessageBoxA]

ret;这是取出EIP,返回到调用处,继续执行[标记1]

扩展资料:

功能:

从堆栈中退出pc的高8位和低8位字节,把堆栈指针减2,从pc值处开始继续执行程序。不影响任何标志。

例子

;主程序

MAIN:SETB P1.0;(1)开始主程序,P1.0口置1(P1.0口输出为高,可以控制LED点亮)

LCALL DELAY;(2)此时当前堆栈指针加2,调用(6)DELAY延时子程序

CLR P1.0;(3)P1.0口清零(P1.0口输出为低,可以控制LED熄灭)

LCALL DELAY;(4)此时当前堆栈指针加2,调用(6)DELAY延时子程序

LJMP MAIN;(5)跳转到主程序,这样LED实现循环点亮

;子程序

DELAY:MOV R7,#250;(6)250-->R7

D1:MOV R6,#250;(7)250--->R6

D2:DJNZ R6,D2;(8)(R6-1),等于零执行下一条,不等于零,则跳转到D2

DJNZ R7,D1;(9)(R7-1),等于零执行下一条,不等于零,则跳转到D1

RET;(10)当前堆栈指针减2,返回到(3)CLR P1.0继续执行MAIN主程序。

END.(11)程序结束(伪指令)

参考资料:

百度百科——RET指令

百度百科——ret

意法半导体(中国)投资有限公司
2023-06-12 广告
STM32F103是一款高性能的嵌入式芯片,由意法半导体(STMicroelectronics)公司生产。它是STM32系列芯片之一,具有紧凑、低功耗、高性能等特点,被广泛应用于嵌入式系统中。STM32F103的主要特点包括:1. 集成了A... 点击进入详情页
本回答由意法半导体(中国)投资有限公司提供
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式