ARM指令集----杂项指令
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
转载请注明链接地址:http://www.cnblogs.com/fengdashen/p/3728564.html
ARM指令集----杂项指令的更多相关文章
- ARM指令集—SWP指令
ARM指令集-SWP指令 SWP和SWPB是ARM指令集中对存储单元的原子操作.即对存储单元的一次读和一次不可被切割. SWP和SWPB分别完毕存储器和寄存器之间 一个字(32bit)和一个字节(8b ...
- ARM指令集——数据处理指令
ARM汇编指令集 ARM汇编文件的组成 指令:编译完成后作为一条指令(机器码)存储在内存单元中,CPU执行时能够完成处理的操作 伪指令:在编译时替换成能被识别的ARM指令 伪操作:知道编译器进行编译, ...
- ARM指令集——条件执行、内存操作指令、跳转指令
ARM 汇编指令条件执行 在ARM模式下,任何一条数据处理指令可以选择是否根据操作的结果来更新CPSR寄存器中的ALU状态标志位.在数据处理指令中使用S后缀来实现该功能. 不要在CMP,CMN,TST ...
- ARM_Instruction_Set_Encoding_hacking(ARM指令集编码格式解读)
ARM指令集编码格式解读 说明: 1.本文参考的书籍<ARM Architecture Reference Manual ARMv7-A and ARMv7-R edition>中的Cha ...
- 常用 ARM 指令集及汇编
ARM7TDMI(-S)指令集及汇编 ARM 处理器是基于精简指令集计算机(RISC)原理设计的,指令集和相关译码机制 较为简单,ARM7TDMI(-S)具有 32 位 ARM 指令集和 16 位 T ...
- ARM指令集详解--汇编
1. 汇编 1.1. 通用寄存器 通用寄存器 37个寄存器,31个通用寄存器,6个状态寄存器,R13堆栈指针sp,R14返回指针,R15为PC指针, cpsr_c代表的是这32位中的 ...
- ARM的栈指令
ARM的指令系统中关于栈指令的内容比较容易引起迷惑,这是因为准确描述一个栈的特点需要两个参数: 栈地址的增长方向:ARM将向高地址增长的栈称为递增栈(Descendent Stack),将向低地址增长 ...
- ARM指令集(下)
A.2.5 ARM 协处理器指令 ARM 支持协处理器操作,协处理器的控制要通过协处理器命令实现.表A-7给出全部的ARM协处理器指令. 表A-7 ARM 协处理器指令 CDP ...
- ARM指令集(上)
ADuC702x可以用两套指令集:ARM指令集和Thumb指令集.本小节介绍ARM指令集.在介绍ARM指令集之前,先介绍指令的格式. A.2.1 指令格式 (1)基本格式 ...
随机推荐
- lintcode:Fibonacci 斐波纳契数列
题目: 斐波纳契数列 查找斐波纳契数列中第 N 个数. 所谓的斐波纳契数列是指: 前2个数是 0 和 1 . 第 i 个数是第 i-1 个数和第i-2 个数的和. 斐波纳契数列的前10个数字是: 0, ...
- Arc Engiene读取文档的属性
设计界面 创建类 代码如下 using System; using System.Collections.Generic; using System.Linq; using System.Text; ...
- YASKAWA电机控制(2)---调试
2015 5 23 基础调试—点动 上次接线由于没有接地,导致外壳带电,非常危险. 由于上次接线端子被弄坏,这次自己重做.由于没有压线钳,只用尖嘴钳把线压近端子,有可能会松动. 接线的时候Lc1.Lc ...
- Django admin的一些有用定制
Model实例,myapp/models.py: from django.db import models class Blog(models.Model): name = models.CharFi ...
- 如何写科技文章的讨论discussion部分
众所周知,讨论部分是在结合自己的研究结果基础上,对整个文章的结论的提炼和升华.这一部分是整个论文的精,往往点睛作用. 同时,很多杂志要求结果和讨论分开,这也就更突出了写好讨论的重要性. 那么,我们应该 ...
- C#版二维码生成器
前言 本文所使用的二维码生成代码是谷歌开源的条形码图像处理库完成的,c#版的代码可去 这里 -- 下载压缩包. 截止目前为止最新版本为2.2,提供以下编码格式的支持: UPC-A and UPC ...
- (sql server)数据分页的实现
谈谈自己了解的几种数据库分页的方法,下面來分享下,有什么好的方法可以指导一下哦.. 方法一:利用ROW_NUMBER()方法 利用ROW_NUMBER 产生序列后直接取出 /*如要查詢的表為Test ...
- 学习Hadoop不错的系列文章
1)Hadoop学习总结 (1)HDFS简介 (2)HDFS读写过程解析 (3)Map-Reduce入门 (4)Map-Reduce的过程解析 (5)Hadoop的运行痕迹 (6)Apache Had ...
- UITableViewCell上的按钮点击事件处理
转自: http://www.aichengxu.com/view/42871 UITableViewCell上的按钮点击事件处理,有需要的朋友可以参考下. 今天突然做项目的时候,又遇到处理自定义的 ...
- CentOS 5.6 netInstall可以的在线安装方式。
之前百度google了一把, 发现原来的地址都失效了. 只找到一个能用的. 下载9M多的CentOS Net Install ISO文件, 选择安装方式时选HTTP. 然后在后面的 服务器位置处输入 ...