【Cortex-M4分支跳转指令、内存访问指令、ARM AAPCS规则、异常处理】

分支跳转指令

B跳转指令

BL跳转指令

BX跳转指令

BLX跳转指令

IT指令

内存访问指令

LDR/STR指令

LDM/STM指令

IB/DA为ARM指令集中的

PUSH/POP指令

ARM AAPCS规则

为了使不同编译器编译的程序之间能够相互调用,必须为子程序间的调用规定一定的规则。AAPCS就是这样一个标准。AAPCS中定义了ARM寄存器使用规则如下:

1.子程序间通过寄存器R0-R3传递参数。如果参数多于4个,则多出的部分用堆栈传递。被调用的子程序在返回前无须恢复寄存器R0-R3的内容。AAPCS 规定返回值存放在R0(如果是64位值,则用R0-R1)。

2.在子程序中,使用寄存器R4-R11保存局部变量。如果在子程序中使用到了寄存器R4-R11中的某些寄存器,子程序进入时必须保存这些寄存器的值,在返回前必须恢复这些寄存器的值;对于子程序中没有用到的寄存器则不必进行这些操作。在Thumb程序中,通常只能使用寄存器R4-R7来保存局部变量。

3.寄存器R12用做子程序间scratch寄存器(用于暂存临时值),记作IP。使用后无需恢复。

4.寄存器R13用做数据栈指针,记作SP。在子程序中寄存器R13不能用做其他用途。寄存器SP在进入子程序时的值和退出子程序时的值必须相等。

5.寄存器R14称为连接寄存器,记作LR。它用于保存子程序的返回地址。如果在子程序中保存了返回地址,寄存器R14则可以用做其他用途。

6.寄存器R15是程序计数器,记作PC。它不能用做其他用途。

异常处理

相关推荐
shansz202010 小时前
暂时无法解决的关于STM32F103的RTC日期更新问题
stm32·嵌入式硬件·实时音视频
独处东汉16 小时前
freertos开发空气检测仪之按键输入事件管理系统设计与实现
人工智能·stm32·单片机·嵌入式硬件·unity
小灰灰搞电子16 小时前
STM32/GD32 字节对齐详解
stm32·单片机·嵌入式硬件
良许Linux20 小时前
DSP的选型和应用
后端·stm32·单片机·程序员·嵌入式
混分巨兽龙某某20 小时前
基于STM32的嵌入式操作系统RT-Thread移植教学(HAL库版本)
stm32·嵌入式硬件·rt-thread·rtos
蓬荜生灰1 天前
STM32(12)-- GPIO输入,按键检测
stm32·单片机·嵌入式硬件
DLGXY1 天前
STM32——ADC、多通道转换(十三)
stm32·单片机·嵌入式硬件
__万波__1 天前
STM32L475看门狗
stm32·单片机·嵌入式硬件
Hello_Embed2 天前
libmodbus 移植 STM32(基础篇)
笔记·stm32·单片机·学习·modbus
qqssss121dfd2 天前
STM32H750XBH6的ETH模块移植LWIP
网络·stm32·嵌入式硬件