一、现在先区分下ARM指令集与Thumb指令集
       Thumb 指令可以看作是 ARM 指令压缩形式的子集,是针对代码密度的问题而提出的,它具有 16 位的代码密度但是它不如ARM指令的效率高 .Thumb 不是一个完整的体系结构,不能指望处理只执行Thumb 指令而不支持 ARM 指令集.因此,Thumb 指令只需要支持通用功能,必要时可以借助于完善的 ARM 指令集,比如,所有异常自动进入 ARM 状态.在编写 Thumb 指令时,先要使用伪指令 CODE16 声明,而且在 ARM 指令中要使用 BX指令跳转到 Thumb 指令,以切换处理器状态.编写 ARM 指令时,则可使用伪指令 CODE32声明.

流水线处理:
不同于微编码的处理器,ARM (保持它的 RISC 性)是完全硬布线的。

为了加速 ARM 2 和 3 的执行使用 3 阶段流水线。第一阶段持有从内存中取回的指令。第二阶段开始解码,而第三阶段实际执行它。故此,程序计数器总是超出当前执行的指令两个指令。(在为分支指令计算偏移量时必须计算在内)。

因为有这个流水线,在分支时丢失 2 个指令周期(因为要重新添满流水线)。所以最好利用条件执行指令来避免浪费周期。例如:

...
CMP R0,#0
BEQ over
MOV R1,#1
MOV R2,#2
over
...

可以写为更有效的: 
...
CMP R0,#0
MOVNE R1,#1
MOVNE R2,#2

二、Thumb 指令集与 ARM 指令集的区别
Thumb 指令集没有协处理器指令,信号量指令以及访问 CPSR 或 SPSR 的指令,没有乘加指令及 64 位乘法指令等,且指令的第二操作数受到限制;除了跳转指令 B 有条件执行功能外,其它指令均为无条件执行;大多数 Thumb 数据处理指令采用 2 地址格式.Thumb指令集与 ARM 指令的区别一般有如下几点:
      跳转指令
程序相对转移,特别是条件跳转与 ARM 代码下的跳转相比,在范围上有更多的限制,转向子程序是无条件的转移.
      数据处理指令
数据处理指令是对通用寄存器进行操作,在大多数情况下,操作的结果须放入其中一个操作数寄存器中,而不是第 3 个寄存器中.数据处理操作比 ARM 状态的更少,访问寄存器 R8~R15 受到一定限制.除 MOV 和 ADD 指令访问器 R8~R15 外,其它数据处理指令总是更新 CPSR 中的 ALU 状态标志.访问寄存器 R8~R15 的 Thumb 数据处理指令不能更新 CPSR 中的 ALU 状态标志.
      单寄存器加载和存储指令
在 Thumb 状态下,单寄存器加载和存储指令只能访问寄存器 R0~R7
      批量寄存器加载和存储指令
LDM 和 STM 指令可以将任何范围为 R0~R7 的寄存器子集加载或存储. PUSH 和 POP 指令使用堆栈指令 R13 作为基址实现满递减堆栈.除 R0~R7 外,PUSH 指令还可以存储链接寄存器 R14,并且 POP 指令可以加载程序指令PC

ARM指令分为以下几种:

一、ARM 存储器访问指令
助记符                       说明                                        操作                                                  条件码位置
LDR    Rd,addressing      加载字数据                            Rd←[addressing],addressing 索引 LDR{cond}
LDRB   Rd,addressing    加载无符字节数据                  Rd←[addressing],addressing 索引 LDR{cond}B
LDRT   Rd,addressing    以用户模式加载字数据        Rd←[addressing],addressing 索引 LDR{cond}T
LDRBT Rd,addressing    以用户模式加载无符号字数据 Rd←[addressing],addressing 索引 LDR{cond}BT
LDRH   Rd,addressing    加载无符半字数据              Rd←[addressing],addressing 索引 LDR{cond}H
LDRSB Rd,addressing    加载有符字节数据        Rd←[addressing],addressing 索引 LDR{cond}SB
LDRSH Rd,addressing    加载有符半字数据     Rd←[addressing],addressing 索引 LDR{cond}SH
STR    Rd,addressing    存储字数据                        [addressing]←Rd,addressing 索引 STR{cond}
STRB   Rd,addressing    存储字节数据       [addressing]←Rd,addressing 索引 STR{cond}B
STRT   Rd,addressing    以用户模式存储字数据    [addressing]←Rd,addressing 索引 STR{cond}T
SRTBT Rd,addressing    以用户模式存储字节数据   [addressing]←Rd,addressing 索引 STR{cond}BT
STRH   Rd,addressing    存储半字数据          [addressing]←Rd,addressing 索引 STR{cond}H
LDM{mode} Rn{!},reglist   批量(寄存器)加载       reglist←[Rn…],Rn 回存等          LDM{cond}{more}
STM{mode} Rn{!},rtglist   批量(寄存器)存储           [Rn…]← reglist,Rn 回存等         STM{cond}{more}
SWP     Rd,Rm,Rn          寄存器和存储器字数据交换 Rd←[Rd],[Rn]←[Rm](Rn≠Rd 或 Rm) SWP{cond}
SWPB    Rd,Rm,Rn        寄存器和存储器字节数据交换 Rd←[Rd],[Rn]←[Rm](Rn≠Rd 或 Rm) SWP{cond}B

二、ARM 数据处理指令
助记符号                                   说明                                   操作               条件码位置
MOV Rd ,operand2   数据转送                           Rd←operand2               MOV {cond}{S}
MVN Rd ,operand2   数据非转送                        Rd←(operand2)             MVN {cond}{S}
ADD Rd,Rn operand2 加法运算指令                  Rd←Rn+operand2            ADD {cond}{S}
SUB Rd,Rn operand2 减法运算指令                  Rd←Rn-operand2            SUB {cond}{S}
RSB Rd,Rn operand2 逆向减法指令                  Rd←operand2-Rn            RSB {cond}{S}
ADC Rd,Rn operand2 带进位加法                     Rd←Rn+operand2+carry      ADC {cond}{S}
SBC Rd,Rn operand2 带进位减法指令            Rd←Rn-operand2-(NOT)Carry SBC {cond}{S}
RSC Rd,Rn operand2 带进位逆向减法指令       Rd←operand2-Rn-(NOT)Carry RSC {cond}{S}
AND Rd,Rn operand2 逻辑与操作指令              Rd←Rn&operand2            AND {cond}{S}
ORR Rd,Rn operand2 逻辑或操作指令             Rd←Rn|operand2            ORR {cond}{S}
EOR Rd,Rn operand2 逻辑异或操作指令          Rd←Rn^operand2            EOR {cond}{S}
BIC Rd,Rn operand2 位清除指令                      Rd←Rn&(~operand2)         BIC {cond}{S}
CMP Rn,operand2    比较指令                       标志 N、Z、C、V←Rn-operand2 CMP {cond}
CMN Rn,operand2    负数比较指令               标志 N、Z、C、V←Rn+operand2 CMN {cond}
TST Rn,operand2    位测试指令                    标志 N、Z、C、V←Rn&operand2 TST {cond}
TEQ Rn,operand2    相等测试指令                标志 N、Z、C、V←Rn^operand2 TEQ {cond}

三、乘法指令
      具有 32×32 乘法指令,32×32 乘加指令,32×32 结果为 64 位的乘/乘法指令.
助记符                                               说明                        操作              条件码位置
MUL   Rd,Rm,Rs        32 位乘法指令    Rd←Rm*Rs           (Rd≠Rm)    MUL{cond}{S}
MLA   Rd,Rm,Rs,Rn     32 位乘加指令    Rd←Rm*Rs+Rn        (Rd≠Rm)    MLA{cond}{S}
UMULL RdLo,RdHi,Rm,Rs 64 位无符号乘法指令 (RdLo,RdHi)←Rm*Rs             UMULL{cond}{S}
UMLAL RdLo,RdHi,Rm,Rs 64 位无符号乘加指令 (RdLo,RdHi)←Rm*Rs+(RdLo,RdHi) UMLAL{cond}{S}
SMULL RdLo,RdHi,Rm,Rs 64 位有符号乘法指令 (RdLo,RdHi)←Rm*Rs             SMULL{cond}{S}
SMLAL RdLo,RdHi,Rm,Rs 64 位有符号乘加指令 (RdLo,RdHi)←Rm*Rs+(RdLo,RdHi) SMLAL{cond}{S}

四、跳转指令
在 ARM 中有两种方式可以实现程序的跳转,一种是使用跳转指令直接跳转,另一种则是直接向 PC 寄存器赋值实现跳转.
           
助记符           说明                            操作                    条件码位置
B label 跳转指令                             Pc←label                 B{cond}
BL label 带链接的跳转指令             LR←PC-4, PC←label BL{cond}
BX Rm    带状态切换的跳转指令    PC←label,切换处理状态 BX{cond}

五、ARM协处理器指令
ARM 支持协处理器操作,协处理器的控制要通过协处理器命令实现.
助记符                                                            说明                           操作             条件码位置
CDP
coproc,opcodel,CRd,CRn,CRm{,opcode2}     协处理器数据操作指令       取决于协处理器   CDP{cond}
LDC{L} coproc,CRd〈地址〉                  协处理器数据读取指令      取决于协处理器   LDC{cond}{L}
STC{L} coproc,CRd,〈地址〉                 协处理器数据写入指令      取决于协处理器   STC{cond}{L}
                                                                    ARM 寄存器到协处理器
MCR coproc, opcodel,Rd,CRn,{,opcode2}   寄存器的数据传送指令       取决于协处理器 MCR{cond}
                                                                     协处理器寄存器到 ARM
MRC coproc, opcodel,Rd,CRn,{,opcode2}   寄存器到数据传送指令        取决于协处理器MCR{cond}

五、ARM 杂项指令
助记符                                                说明                            操作                               条件码位置
SWI immed_24                软中断指令               产生软中断,处理器进入管理模式       SWI{cond}
MRS Rd,psr                  读状态寄存器指令 Rd←psr,psr 为 CPSR 或 SPSR                  MRS{cond}

MSR psr_fields,Rd/#immed_8r 写状态寄存器指令 psr_fields←Rd/#immed_8r,psr 为 CPSR 或 SPSR MSR{cond}

转载于:http://blog.csdn.net/itismine/article/details/4753701

ARM指令和Thumb指令的区别相关推荐

  1. ARM指令集与Thumb指令集--区别关联--汇编指令 BX LR ; 跳转回LR地址处,既可以是ARM模式也可以是Thumb模式

    BX        LR    ; 跳转回LR地址处,既可以是ARM模式也可以是Thumb模式 A 一.现在先区分下ARM指令集与Thumb指令集        Thumb 指令可以看作是 ARM 指 ...

  2. thumb指令和arm指令

    参考https://www.embedded.com/introduction-to-arm-thumb/ 一.为什么一个芯片需要thumb和arm两套指令集 许多复杂的功能在复杂指令集(CISC)处 ...

  3. arm和thumb指令模式

    目录:frameworks/native/opengl/libagl 文件:Androi.mk light.cpp 默认情况下,arm目标二进制会以thumb的形式生成(16位),你可以通过设置这个变 ...

  4. S5PV210体系结构与接口02:ARM编程模型 汇编指令

    目录 1. ARM的基本设定 1.1 ARM数据类型 1.1.1 基本数据类型 1.1.2 浮点数据类型 1.1.3 存储器大小端 1.2 支持的指令集 2. Cortex-A8编程模型 2.1 处理 ...

  5. 逆向知识内存ARM常用的汇编指令合集

    ARM   处理器的指令集可以分为 跳转指令.数据处理指令.程序状态寄存器(PSR)处理指令.加载/存储指令.协处理器指令和异常产生指令  六大指令,这里把其它几个指令一起发了出来,可以查看具体的目录 ...

  6. ARM 指令集 和 Thumb 指令集

    From:https://gitee.com/lsliushuang/ASM/blob/master/arm汇编.txt ARM 汇编指令集汇总:https://blog.csdn.net/qq_40 ...

  7. 自己归纳整理的ARM THUMB指令机器码表

    有个项目需要分析ARM THUMB指令的机器码,网上没有搜索到整理好的机器码表,只好自己把相关指令的机器码归纳整理出来,这里分享给大家.THUMB指令并不多,只有六十多条,这个数字真的是非常了不起,5 ...

  8. IDA Pro ARM指令集和Thumb指令集的切换

    在动态调试android的ndk程序的时候,发现很多程序都会反汇编错误,原来是ARM反汇编的模式没搞对.因为在动态调试的时候,ida Pro并没有去解析elf模块中的一些信息,造成了模块信息丢失,有时 ...

  9. ARM中的ldr指令与adr、ldr伪指令之间的区别

    ARM汇编语言中有ldr指令和ldr.adr伪指令,他们都可以将标号表达式作为操作数.区别如下: ldr指令和adr.ldr伪指令的区别:ldr指令属于load-store指令,用于读取标号地址中的值 ...

最新文章

  1. 网络营销激烈竞争下,网站被黑了怎么办?
  2. CSS布局--head区的其他设置
  3. What is corresponding Cron expression to fire in every X seconds, where X 60? --转载
  4. ZOJ3370. Radio Waves(2-sat)
  5. List VS Set
  6. 2018.3.13 浮动 定位
  7. 报错信息:NoReverseMatch at / 'blog' is not a registered namespace
  8. 计算机编程的 20 年变迁!
  9. OxA6可以作为C语言常量吗,淮阴师范学院期末考试c语言题库
  10. jsp与servlet的区别与联系
  11. jQuery实现省市二级联动
  12. Oracle:view 添加主键
  13. mysql 空值处理
  14. 计算机er在本科如何争取发论文?
  15. 同时投掷两个不同面的骰子
  16. python数据分析实战 fabio nelli百度云_Python数据分析实战 内利(Fabio Nelli),杜春晓 9787115432209...
  17. 中国AI觉醒 阿里王坚:云智能将成为大趋势
  18. 美国国土安全部部长约翰逊就Dyn网络攻击事件发表声明
  19. 如何制作SOLIDWORKS材料明细表模板
  20. 2021安道拓企业研究数据报告_爱普搜汽车

热门文章

  1. 美国休斯敦警察调查涉毒案件时遭枪击 5人受伤
  2. arm linux 指纹识别,基于ARM—Linux指纹识别系统的设计.pdf
  3. ubuntu装机指南
  4. 中文自然语言处理入门之Hanlp介绍
  5. SVN远程改密码的超简单的java实现
  6. centos查询 硬盘序列号查询_centos下查看网卡型号,如何查看主板型号,CPU显卡信息,硬盘型号等硬件信息...
  7. python用PyQt5实现一个简单的表白软件(代码实现+py文件打包成exe文件)
  8. 大数据培训机构,主要都学习哪些课程?
  9. 快速理解简单的短链接生成原理
  10. 云计算中Region、AZ、POD的三角关系