ARM 汇编指令:PUSH 和 POP

ARM 汇编指令:PUSH 和 POP

本文来自于我关于 ARM 汇编指令系列文章。欢迎阅读、点评与交流~
1、汇编指令在不同架构中的联系与区别
2、ARM 汇编指令:MOV
3、ARM 汇编指令:LDR
4、ARM 汇编指令:STR
5、ARM 汇编指令:MRS 和 MSR
6、ARM 汇编指令:ORRS
7、ARM 汇编指令:BEQ
8、ARM 汇编指令:TST
9、ARM 汇编指令:B
10、ARM 汇编指令:BX
11、ARM 汇编指令:ERET

在 ARM 汇编中,PUSHPOP 是用于栈操作(堆栈操作)的指令,主要用于保存和恢复寄存器的值。它们是 STMDBLDMIA 的别名,与栈指针(通常是 SP)一起使用。


1. 栈的概念

  • ARM 中栈通常是 满递减栈(Full Descending, FD),即栈向低地址方向生长,栈指针指向最后一个入栈的元素。
  • PUSH 用于将寄存器值存入栈(压栈)。
  • POP 用于从栈中取出值到寄存器(出栈)。

2. PUSH 指令

语法

assembly 复制代码
PUSH {reg_list}

功能

  • reg_list 中的寄存器依次存入栈(从高寄存器到低寄存器顺序存入内存,但内存地址递减)。

  • SP 会先递减(因为是满栈),然后再存数据。

  • 等价于:

    assembly 复制代码
    STMDB SP!, {reg_list}

    STMDB 表示先递减(Decrease Before)存储。

示例

assembly 复制代码
PUSH {R0, R1, R4-R7}   ; 将 R0, R1, R4, R5, R6, R7 压栈

假设入栈前 SP = 0x1000,入栈 6 个寄存器(每个 4 字节)后 SP = 0x1000 - 0x18 = 0xFE8


3. POP 指令

语法

assembly 复制代码
POP {reg_list}

功能

  • 从栈中取出数据到 reg_list 中的寄存器(从低地址到高地址加载到寄存器,寄存器的编号顺序不影响加载的内存顺序,但通常按编号升序弹出到寄存器列表中的寄存器)。

  • SP 会在加载后递增(因为是满栈)。

  • 等价于:

    assembly 复制代码
    LDMIA SP!, {reg_list}

    LDMIA 表示先递增(Increase After)加载。

示例

assembly 复制代码
POP {R0, R1, R4-R7}   ; 恢复 R0, R1, R4, R5, R6, R7 的值

4. 使用场景

子程序调用时保存现场:

assembly 复制代码
subroutine:
    PUSH {R0-R3, LR}   ; 保存工作寄存器和返回地址
    ...                ; 子程序代码
    POP {R0-R3, PC}    ; 恢复寄存器并返回(将 LR 弹出到 PC)

注意:这里 POP {..., PC} 相当于同时恢复了寄存器并跳转回调用处。


5. 注意事项

  • 寄存器顺序 :在 PUSHPOP 的寄存器列表中,可以按任意顺序书写,但汇编器会按寄存器编号升序排序后再压栈(编号高的寄存器对应高内存地址)。出栈时,低内存地址的数据弹出到列表中编号最小的寄存器。
  • 栈对齐 :在 ARMv7/AArch32 中,通常要求 SP 对齐到 8 字节(特别是在调用公共接口时)。在 AArch64 中,PUSH/POP 指令形式不同,并且要求 16 字节对齐。
  • Thumb 模式 :在 Thumb 指令集中,PUSH/POP 的寄存器列表有限制(通常只能用于通用寄存器和 LR/PC)。

6. 示例:完整的函数调用与返回

assembly 复制代码
main:
    ...
    BL foo
    ...

foo:
    PUSH {R4-R7, LR}      ; 保存调用者保存的寄存器和返回地址
    ...                   ; 使用这些寄存器
    POP {R4-R7, PC}       ; 恢复寄存器并直接返回

7. 与 x86 的区别

  • x86 的 PUSH/POP 一次只能操作一个寄存器或内存地址,而 ARM 可以一次操作多个寄存器。
  • ARM 的栈操作更加灵活,可以通过 STM/LDM 实现多种栈模式(但 PUSH/POP 固定为满递减)。
相关推荐
鸽芷咕9 小时前
DOSBox 汇编环境搭建完整教程:安装配置 + MASM/LINK/DEBUG 工具链配置详解
汇编
Gofarlic_OMS21 小时前
UG/NX许可证管理高频技术问题解答汇编
java·大数据·运维·服务器·汇编·人工智能
iCxhust21 小时前
如何在汇编中修改CS:IP
汇编·单片机·嵌入式硬件·51单片机·微机原理
CinzWS21 小时前
A53 FPGA原型验证:从RTL到可运行系统的挑战
arm开发·嵌入式·芯片验证·原型验证·a53
AI服务老曹1 天前
深度解析:支持 GB28181/RTSP 及异构计算(X86/ARM+GPU/NPU)的 AI 视频管理平台架构方案(附源码交付与 Docker 部署)
arm开发·人工智能·音视频
2302_813806221 天前
基础环境篇 – 交叉编译环境搭建与NFS服务配置
arm开发
极创信息1 天前
信创领域五种主流CPU架构(X86 / ARM / RISC-V / MIPS / LoongArch)
java·arm开发·数据库·spring boot·mysql·软件工程·risc-v
AI服务老曹1 天前
节省95%开发成本:支持X86/ARM与GPU/NPU异构部署的AI视频云网关架构深度解析
arm开发·人工智能·音视频
徐某人..2 天前
基于i.MX6ULL平台的智能网关系统开发
arm开发·c++·单片机·qt·物联网·学习·arm
2035去旅行2 天前
嵌入式开发,如何选择C标准库
linux·arm开发