ARM编程:零比较、UAL汇编与异常处理详解
1. 零比较操作
在ARM编程中,零比较是一个常见的操作。不同状态下实现零比较的方式有所不同,具体如下表所示:
| 状态 | 助记符 | 长度 |
| ---- | ---- | ---- |
| ARM | CMP R0, #0; BEQ
从表中可以看出,在T16状态下,CBZ指令取代了ARM和Thumb状态下的CMP + BEQ组合,将其浓缩为一条两字节长的指令,提高了代码的效率。
2. 统一汇编语言(UAL)
ARM处理器只能工作在ARM状态或Thumb状态,即使是支持UAL之前的处理器也是如此。不能混合使用A32和T32代码。若要在同一程序中使用A32和T32代码,必须分块使用,并在适当的点进行状态切换。
使用UAL时,需要在源文件顶部添加 .syntax unified 指令来调用UAL。编译时,还需指定编译的架构,例如 march=armv8 - a 。
对于T32指令,有些指令可以有16位或32位编码。如果不指定指令大小,默认规则如下:
- 对于前向引用的LDR、ADR和B指令,编译器应生成16位指令,即使这可能导致使用32位指令才能到达的目标失败。
- 对于外部引用的LDR和B指令,编译器应生成32位指
超级会员免费看
订阅专栏 解锁全文

被折叠的 条评论
为什么被折叠?



