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

异常处理

相关推荐
逐步前行21 小时前
STM32_TIM_寄存器操作
stm32·单片机·嵌入式硬件
0南城逆流01 天前
【STM32】知识点介绍七:PWM功能
stm32·单片机·嵌入式硬件
dashizhi20151 天前
服务器共享禁止保存到本地磁盘、共享文件禁止另存为本地磁盘、移动硬盘等
运维·网络·stm32·安全·电脑
三佛科技-187366133971 天前
FT32F030F6AP7高性能32位RISC内核MCU解析(兼容STM32F030K6TP7)
stm32·单片机·嵌入式硬件
LCMICRO-133108477461 天前
长芯微LDC90810完全P2P替代ADC128D818,是一款八通道系统监控器,专为监控复杂系统状态而设计。
stm32·单片机·嵌入式硬件·fpga开发·硬件工程·模数转换芯片adc
csaaa20051 天前
STM32F103 开发USB设备端点超过ENDP4以上时崩溃问题的解决
stm32·单片机·嵌入式硬件
LCG元1 天前
故障预测与健康管理:STM32G4监控自身参数,早期预警
stm32·单片机·嵌入式硬件
ipod7411 天前
STM32 GPIO控制器及其应用
stm32·单片机·嵌入式硬件
逐步前行1 天前
STM32_USART_串口通信
stm32·单片机·嵌入式硬件
我不是程序猿儿1 天前
【嵌入式】趣味理解“volatile”
stm32·单片机·嵌入式硬件·学习