ARM指令集比较简单,本文介绍ARM指令集中需要注意和不易理解的地方。
一、ARM指令集是32位的,程序的启动都是从ARM指令集开始,包括所有异常中断都是自动转化为ARM状态,并且所有的指令都可以是有条件执行的。
二、ARM指令集是Load/Store型的,只能通过Load/Store指令实现对系统存储器的访问,而其他的指令都是基于处理器内部的寄存器操作完成的,这和INTEL汇编是不同的,初学者很不易理解。
三、指令的后缀:
"S" 可选后缀,若指定S,则根据指令执行的结果更新CPSR中的条件码。很多初学着不知道怎么更新,若这条指令执行完以后,对ARM程序状态寄存器的条件码标志(N,Z,C,V)的影响。
"! " 表示在完成数据操作以后,将更新基址寄存器,并且不消耗额外的时间。
如:LDR R0, [R1, #4] 他相当于 R0 <- mem32[R1+4]
R1 = R1+4;
"^" LDMFD R13!, (R0-R3, PC)^ //"^"表示一条特殊形式的指令。(在从存储器中装入PC的同时,CPSR也得到恢复)。
四、#号后面加0x或&表示十六进制:#0xFF, #&FF
#号后面加0b表示二进制。
#号后面加0d表示十进制。
*******************************************************************************
五、立即数寻址
每个立即数都是采用一个8位的常数循环右移偶数位间接得到。
初学者不易理解:一个32位的指令不可能全部用来保存32位的立即数,所以从指令的编码格式上分析,在指令编码中只分配了12位来存储立即数,其中4位用来保存右循环值,8位用来保存一个常数,所以并不是每一个32位的立即数都是合法的。
六、寄存器寻址
ADD R3,R2,R1,LSR #2 //寄存器R1的内容右移了两位,但是注意本指令执行完毕以后R1的内容并不改变。
七、前变址、自动变址和后变址
1、前变址:LDR R0,[R1,#4] //R1寄存器的内容先加4,然后执行操作,但操作完毕以后,R1的内容不变。
2、自动变址:上面总结指令后缀时提到"!",表示自动变址(参考上面 三 )。
3、后变址:LDR R0,[R1],#4 //先进行操作然后R1+4->R1,操作完毕后,R1 = R1+4。不需要"!"号。
八、堆栈寻址
一定要注意:堆栈操作总是要指定自动变址的,否则会覆盖以前保存的内容。
********************************************************************************
九、乘法指令
1、乘法指令不支持第二操作数为立即数。
2、结果寄存器不能同时作为第一源寄存器。
32位:MUL Rd,Rm,Rs
MUL Rd,Rm,Rs //Rd和Rm不能为同一寄存器
64位:MUL RdHi,RdLo,Rm,Rs //RdHi、RdLo和Rm不能为同一寄存器,RdHi和RdLo不能为同一寄存器。
十、跳转指令
1、BL和BLX跳转是硬件自动将下一条指令地址保存到LR(R14)中,不需要自己写指令。
2、当指令跳转到32MB地址空间以外时,将产生不可预料的结果。
ARM的指令集比较简单,肯定还有其他需要注意的地方,欢迎网友们积极参与补充。
专栏文章内容及配图由作者撰写发布,仅供工程师学习之用,如有侵权或者其他违规问题,请联系本站处理。 联系我们
相关推荐
联发科天玑9500:旨在超越Snapdragon 8 Gen 3和苹果A17
GCC手册(下)
Gartner发布推动自主业务发展的主要新兴技术
GCC手册(中)
招聘老板,网内电话(零话费)=白打,网外长途(比市话还便宜)=白送
可扩展验证平台新技术帮助弥合验证鸿沟
pppOEServiceNameAdd 失败?
TDA7057Q功放电路
松翰科技2010新品发布暨方案应用研讨会
MAX11200 微功耗(<1mW)、24位ADC
S3C2410紧急求助
Microchip推出面向工业应用的灵活新型千兆以太网交换机系列支持TSN/AVB与冗余功能
GDB调试实用手册2
GCC手册(上)
2025迎人形机器人量产拐点 兆易创新全栈芯片已就位
2025 LoRa创新论坛圆满落幕,物联网新时代正式开启
人工智能革命:它会拯救人类还是毁灭人类?
低噪声、高电压 DC/DC 转换器
TDA7056A功放电路
耳目无所不在:嵌入式设备的联网技术
TDA7230A功放电路
GDB调试工具指南
NS便携式超声波系统完整解决方案
TDA7231功放电路
首届国际 IC 电子商务信用论坛暨 TBF 世界会员交流会深圳站视频
摩尔斯微电子完成8800万澳元(5900万美元)C轮融资,引领下一代物联网新纪元
华为发布《ISP一张网白皮书》,助力ISP掘金2B新蓝海
TDA7056功放电路
新的 MediaTek 天玑9500 手机芯片带来低功耗 AI 和相机升级
联发科据报道正在考虑在美国生产芯片