ARM 汇编指令:STM

ARM 汇编指令:STM

ARM 汇编指令:STM

本文来自于我关于 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
12、ARM 汇编指令:STP\LDP
13、ARM 汇编指令:UBFX
14、ARM 汇编指令:STM

STMARM 汇编指令中的存储多个寄存器指令,全称是Store Multiple

基本功能

多个寄存器的值存入连续的内存地址中。它是LDM(加载多个寄存器)的逆操作。

基本语法

STM{条件}{寻址模式} Rn{!}, {寄存器列表}{^}

关键组成部分

1.寻址模式(Addressing Mode)

决定地址的增长方向和起始/结束位置:

  • IA(Increment After):操作后地址增加(默认)
  • IB(Increment Before):操作前地址增加
  • DA(Decrement After):操作后地址减少
  • DB(Decrement Before):操作前地址减少

2.寄存器列表

用花括号{}包含要存储的寄存器,用逗号分隔:

STMIA R0!, {R1-R4, R7} ; 将 R1,R2,R3,R4,R7 存入内存

3.写回选项!

Rn!表示操作后更新基址寄存器 Rn 的值。

4.特权模式选项^

在特权模式下使用,用于恢复用户模式的寄存器。

常见用法示例

示例 1:基本存储

STMIA R0!, {R1-R5} ; 将 R1~R5 存入 R0 指向的地址,R0 每次增加

示例 2:栈操作(向下满栈)

STMDB SP!, {R0-R3, LR} ; 将寄存器压栈(相当于 PUSH)

示例 3:批量数据保存

; 保存工作寄存器到内存缓冲区 STMIA R8, {R0-R7} ; 将 R0~R7 保存到 R8 指向的位置

与栈操作的关系

ARM 中常用STM/LDM配合寻址模式实现栈操作:

指令组合等效指令描述
STMDB SP!, {...}PUSH压栈
LDMIA SP!, {...}POP出栈

重要特性

  1. 存储顺序:总是从低编号寄存器到高编号寄存器存储
  2. 内存地址:连续递增或递减
  3. 原子性:在中断上下文中需注意,可能被中断打断
  4. 效率:比多条单寄存器存储指令更高效

实际应用场景

  • 函数调用时的上下文保存
  • 任务切换时的寄存器保存
  • 批量数据搬移
  • 中断处理程序入口

STM是 ARM 汇编中非常重要的批量内存操作指令,特别在函数调用和上下文保存中广泛应用。