微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 嵌入式设计 > arm汇编指令整理

arm汇编指令整理

时间:11-09 来源:互联网 点击:

并将结果写回寄存器)。

而R15(PC)总是指向“正在取指”的指令,而不是指向“正在执行”的指令或正在“译码”的指令。一般来说,人们习惯性约定将“正在执行的指令作为参考点”,称之为当前第一条指令,因此PC总是指向第三条指令。当ARM状态时,每条指令为4字节长,所以PC始终指向该指令地址加8字节的地址,即:PC值=当前程序执行位置+8;

周期1 周期2 周期3 周期4 周期5 周期6

PC-8取指 译码 执行

PC-4 取指 译码 执行

PC 取指 译码执行

14.cmp

CMP比较指令,用于把一个寄存器的内容和另一个寄存器的内容或一个立即数进行比较,同时更新CPSR中条件标志位的值。指令将第一操作数减去第二操作数,但不存储结果,只更改条件标志位。

CMP R1, R0 ;做R1-R0的操作。

CMP R1,#10 ;做R1-10的操作。

15.txt

TST位测试指令,用于把一个寄存器的内容和另一个寄存器的内容或立即数进行按位的与运算,并根据运算结果更新CPSR中条件标志位的值。操作数1是要测试的数,而操作数2 是一个位掩码,该指令一般用来检测是否设置了特定的位。

TST {条件} 操作数1, 操作数2

例:TST R0, #0X0000 0040 ; 指令用来测试R0的位3是否为1。

TST指令通常和EQ、NE条件码配合使用,当所有测试位为0时,EQ有效,而只要有一个测试位不为0,则NE有效。

16.teq

TEQ相等测试指令,用于把一个寄存器的内容和另一个寄存器的内容或立即数进行按位的异或运算,并根据运算结果更新CPSR中的条件标志位。指令用于比较两个操作数是否相等。如果相等,则 Z = 1,否则Z = 0。指令通常和EQ、NE条件码配合使用

例:TEQ R1, R2

TST R1,#%1;测试R1中是否设置了最低位(%表示二进制数

17.cmn

CMN -- 比较取负的值

CMN{条件}{P} ,

status = op1 - (-op2)

CMN R0, #1 @把R0与-1进行比较

18.bic

BIC指令用于清除操作数1的某些位,并把结果放置到目的寄存器中,如果在掩码中设置了某一位,则清除这一位。未设置的掩码位保持不变。

例:BIC R1, R1, #0X0F ;将R1的低四位清零,其他位不变。

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top