【ARM64 常见汇编指令学习 21 -- ARM RET 与 ERET】

请阅读【嵌入式开发学习必备专栏 】


文章目录

    • [ARM RET 与 ERET](#ARM RET 与 ERET)
      • [ARMv8 ERET 指令](#ARMv8 ERET 指令)
      • [RET 与 ERET 的区别](#RET 与 ERET 的区别)

ARM RET 与 ERET

在 ARMv8 架构中,RET 指令用于从函数或者过程返回。它主要负责从当前过程跳转回调用者,并恢复调用者的程序计数器 (PC) 的值。

语法:

assembly 复制代码
RET {Xn} 

Xn 是一个可选的寄存器,通常为 X30(也称为 LR,链接寄存器),其中包含返回地址。如果没有指定寄存器,则默认为 X30

工作原理:

  1. Xn(通常是 LR)寄存器中的值加载到程序计数器 PC 中,从而跳回到调用过程之后的地址。
  2. 根据需要更新程序状态,如堆栈指针 SP 和其他调用约定相关的寄存器。

示例:

assembly 复制代码
func: 
	// 函数内容 
	RET // 返回到调用者,等同于 RET X30 

another_func: 
	// 另一个函数内容 
	RET X29 // 如果X29寄存器中存放了返回地址,则使用它返回 

ARMv8 ERET 指令

ERET 指令用于从异常返回,特别是从中断或陷阱处理程序返回到之前的执行上下文。ERET 还原 Exception Level (EL) 发生变化前的程序状态,它通常在处理操作系统级别的代码中使用。
语法:

assembly 复制代码
ERET 

ERET 指令没有操作数。

工作原理:

  1. ELR_ELx(Exception Link Register)恢复程序计数器 PC
  2. SPSR_ELx(Saved Program Status Register)恢复程序状态寄存器 CPSR(Current Program Status Register),包括标志位和执行状态(例如 ARM 或 Thumb 模式)。

示例:

assembly 复制代码
// 假设处于异常处理程序内部 
// 执行 ERET 会返回到触发异常的指令之后的程序地址 
	ERET 

RET 与 ERET 的区别

  • RET 用于标准的函数返回,而 ERET 用于从异常或中断处理程序返回。
  • RET 只是简单地将链接寄存器 LR 的值加载到程序计数器 PC 中,不会改变当前的执行级别或恢复程序状态。
  • ERET 会加载 ELR_ELx 中的值到 PC,并从 SPSR_ELx 恢复状态寄存器。它会改变处理器的执行级别,通常是从更高的异常级别(EL1, EL2, EL3)返回到较低的应用级别(EL0)。
  • ERET 是一个更复杂的指令,它用于在更严格和受控的环境中切换上下文,如操作系统的中断处理。
相关推荐
lingggggaaaa11 分钟前
安全工具篇&动态绕过&DumpLsass凭据&Certutil下载&变异替换&打乱源头特征
学习·安全·web安全·免杀对抗
PP东21 分钟前
Flowable学习(二)——Flowable概念学习
java·后端·学习·flowable
学电子她就能回来吗24 分钟前
深度学习速成:损失函数与反向传播
人工智能·深度学习·学习·计算机视觉·github
AI视觉网奇2 小时前
ue 角色驱动衣服 绑定衣服
笔记·学习·ue5
wdfk_prog4 小时前
[Linux]学习笔记系列 -- [drivers][input]serio
linux·笔记·学习
ZH15455891315 小时前
Flutter for OpenHarmony Python学习助手实战:GUI桌面应用开发的实现
python·学习·flutter
编程小白20266 小时前
从 C++ 基础到效率翻倍:Qt 开发环境搭建与Windows 神级快捷键指南
开发语言·c++·windows·qt·学习
万法若空6 小时前
8086/8088实模式的内存布局
汇编
学历真的很重要6 小时前
【系统架构师】第二章 操作系统知识 - 第二部分:进程与线程(补充版)
学习·职场和发展·系统架构·系统架构师
深蓝海拓6 小时前
PySide6,QCoreApplication::aboutToQuit与QtQore.qAddPostRoutine:退出前后的清理工作
笔记·python·qt·学习·pyqt