【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。它不能用做其他用途。

异常处理

相关推荐
✎ ﹏梦醒͜ღ҉繁华落℘15 天前
单片机基础知识---stm32单片机的优先级
stm32·单片机·mongodb
牛根生同志15 天前
SPI数据收发的时候 TXE与RXNE标志位置位的时机
stm32·spi·transfer
goldenrolan15 天前
学习型红外控制系统稳定性挂测工装专项总结
软件测试·python·stm32·嵌入式·红外
CC城子15 天前
STM32H7_FDCAN 驱动笔记
stm32·can·canfd
意法半导体STM3215 天前
【官方原创】如何为STM32CubeMX2配置Visual Studio Code配置方案
vscode·stm32·单片机·嵌入式硬件·策略模式·stm32cubemx·嵌入式开发
雾削木15 天前
B语言经典教程现代化重构
java·前端·stm32·单片机·嵌入式硬件
Digitally15 天前
如何快速将文件从电脑传输到平板电脑
stm32·嵌入式硬件·电脑
项目題供诗15 天前
STM32-USART串口协议(二十二)
stm32·单片机·嵌入式硬件
欢乐熊嵌入式编程15 天前
选型避坑:ESP32 vs STM32+模组 vs NB-IoT,不同场景怎么选
stm32·单片机·嵌入式硬件·物联网·esp32·嵌入式iot
振南的单片机世界15 天前
ARM中断比51快在哪?硬件压栈+NVIC集中管理
arm开发·stm32·单片机·嵌入式硬件