历史上的今天
今天是:2025年02月17日(星期一)
2020年02月17日 | ARM指令集----杂项指令
2020-02-17 来源:eefocus
ARM指令集可以分为6类,即是跳转指令,数据处理指令,程序状态传输指令,Load、Store指令,协处理器指令和异常中断指令
跳转指令:
在ARM中有两种方式可以实现程序的跳转,一种是跳转指令,另一种是直接向PC寄存器写入目标地址的值
通过直接向PC寄存器写入目标寄存器的数字可以实现在4GB 地址空间的任意跳转,这种跳转又称为长跳转,如果在残肢令前面使用MOV LR,PC等指令,可以保存返回来的地址值,这样就实现了在4GB空间中的子程序调用
ARM的跳转指令可以从当前指令向前或者是向后的32位的地址进行空间跳转,这类跳转指令有一下4种
B 跳转指令
BL带换回的跳转指令
BLX 带返回的跳转和切换指令
BX 带状态切换的跳转指令
B和BL的区别在于,L决定是否将PC寄存器的数字保存到LR寄存器中,
BL指令用于实现子程序的调用,子程序的返回地址可以将LR寄存器的值复制到PC寄存器来实现
数据处理指令
数据处理指令包括如下指令
MOV 数据传送指令
MVN 数据求反传送指令:MVN指令有以下用途:先寄存器传递一个负数,生成位的掩码,求一个数的反码
CMP 比较指令:
CMN 基于相反数的比较指令
TST 位测试指令 :TST指令通常是用于测试寄存器中某些位是1还是0
TEQ 测试相等指令:TEQ用来比较两个数是否相等ORR指令
ADD 加法指令 :典型应用ADD RX,RX,#1 // RX = RX+1
ADD RD,RX,lSL#n //RX= RX+RX*(2*n)
ADD RS,PC,#oFFSET //生成基于PC的跳转指令
SUB 减法指令 典型用法:SUB RX,RX,#1 // Rx= Rx-1
RSB 逆向减法指令 :逆向减法指令,RSB RD,RX,#0, //RD = -Rx
ADC 带进位加法指令 :带进位的加法指令,用于实现64位+64位的加法操作
SBC 带进位减法指令 :带进位的加法指令,用于实现64位+64位的减法操作
RSC 带逆向减法指令 :带进位的逆向相减指令
AND 逻辑与操作 :AND指令可以用于提取寄存器的某些位的值,具体做法是设置一个掩码值,将该值中的对应寄存器欲提取的位设置为1,其余的设置成0,将该寄存器与上该掩码值就可以得到提取的位操作
BIC 位清除指令:BIC指令可以用于寄存器的某些位的值设置为0,将某些与1做BIC操作,该位被轻微0,将某些位与 0 操作,该位置不变
EOR 逻辑异或指令:某位与0做异或操作,该位不变,某位与1做异或操作,该位取反
ORR 逻辑或操作指令:ORR指令主要是用于将寄存器的某些位设置成1,具体做法是设置一个掩码值,将该寄存器中与提取的位设置为1,其他的位设置为0,将该寄存器的值与该掩码值做逻辑或操作即可
乘法指令:
ARM有两类乘法指令,1类为32位的乘法指令,即是乘法操作的结果为32位,另一类是64位的乘法指令,即是操作结果位64位,两类指令共有以下6条
MUL 32位乘法指令
MLA 32位带加法的的乘法指令
SMULL 64位有符号乘法指令
SMLAL 64位有符号带加法的乘法指令
UMULL 64位无符号乘法指令
UMLAL 64位无符号带加法乘法指令
示例代码:
MUL:
MUL R0,R1,R2 ;R0 = R1*R2
MULS R0,R1,R2; R0=R1*R2,同时设置CPSR中的N位和Z位
MLA:
MLA R0,R1,R2,R3 R0=R1*R2+R3
SMULL:
SMULL R1,R2,R3,R4 ;R1 = R3*R4 的低32位
R2= R3*R4的高32位
UMULL
UMULL R1,R2,R3,R4 ;R1 = R3*R4 的低32位
R2= R3*R4的高32位 也就是说R2R1 = R3*R4
UMLAL R1,R2,R3,R4 ;R2R1 = R3*R4+R2R1
杂项算术指令
CLZ 用于计算操作数最高端0的个数,这条指令主要用于一下两个场合
计算操作数规范化(使其最高位为1)时需要左移的位数
确定一个优先级掩码中最高优先级
CLZ指令用于计算寄存器中操作数的最高位0的个数,如果操作数的bit[31]为1,则返回0,如果操作数为0 ,则指令返回32
上一篇:arm的bin二进制代码分析
史海拾趣
|
从8位/16位单片机发展到以ARM CPU核为代表的32位嵌入式处理器,嵌入式操作系统将替代传统的由手工编制的监控程序或调度程序,成为重要的基础组件。更重要的是嵌入式操作系统对应用程序可以起到屏蔽的作用,使应用程序员面向操作系统级开发应用软件 ...… 查看全部问答> |
|
一、 前言 随着计算机软硬件技术的发展,人机界面的重要性与日俱增。一些专家指出:对于用户,人机界面就是系统本身。在计算机发展的早期,受计算速度、存储容量等条件的限制,用户一味追求运行速度与所占空间,致使程序员在开发软件时不得不绞尽 ...… 查看全部问答> |
|
摘要针对经典多维定标的MDS—MAP算法在定位精度与矩阵计算复杂度方面的不足,提出一种基于 MDS的分布式定位算法。改进后的分布式定位算法加入了分簇的思想,把网络中的节点分成不同的簇来进行局 部定位,局部定位时引入Euclidean算法估算距离矩阵 ...… 查看全部问答> |
|
对应DeviceIOControl函数写了如下的流驱动代码: BOOL TES_IOControl (DWORD dwCtx, DWORD dwCode, PBYTE pInpBuf, DWORD dwInpLen, & ...… 查看全部问答> |
|
急问!!!如何在windows和linux下获取所有硬盘physicaldriveX???请大虾不惜赐教!!! windows下硬盘的编号为physicaldrive0表示第一个硬盘,physicaldrive1表示第二个硬盘...(考虑远程映射的硬盘,可能有很多)。 现在我需要通过程序得到连接我电脑的所有的physicaldrive,比如physicaldrive0,physicaldrive1,physicaldrive2全部 ...… 查看全部问答> |




