语法格式

<opcode>{<cond>}{S} <Rd>, <Rn>,<shifter_operand>

{}表示是可选的部分,<>表示是必要的部分

条件码

大部分ARM指令都支持条件执行,即满足某些条件的时候执行当前指令,同时,还配合有S位用来指示当前指令是否会映像CPSR相应的位。

EQ Equal 相等 Z=1
NE Noequal 不相等 Z=0
CS/HS CarrySet/HighorSame 无符号数>= C=1
CC/LO CarryClear/LOwer 无符号数< C=0
MI MInus 负数 N=1
PL Plus 非负数 N=0
VS oVerflowSet 上溢出 V=1
VC oVerflowClear 没有上溢出 V=0
HI HIgh 无符号> C=1&&Z=0
LS LowerorSame 无符号数<= C=0
GE GreaterorEqual 带符号数>= N=1&&V=1或 N=0&&V=0
LT LessThan 带符号数< N=1&&V=0或 N=0&&V=1
GT GreaterThan 带符号数> Z=0&&N=V
LE LessEqual 带符号数<= Z=1&&N!=V
AL 无条件执行

跳转

B指令跳转的范围是PC+-32M,因为ARM一条指令32bit,操作码B占了6bit,还有24bit装数据,考虑到ARM的地址是4byte对齐的,所以最后的两位都会是0,所以就可以用24bit数据表达26bit的地址空间,2^26=64M,即+-32M。如果需要跳转的地址距离PC超过了32M,可以将目标地址压栈,通过内存将地址传递给PC实现长跳转

B{<cond>}		<target_addr>
BL{<cond>} <target_addr>
BX{<cond>}, <Rm>
BLX <target_address>
BLX{<cond>} <Rm>

数据处理

  • 注意立即数的合法性问题
  • 立即数=(8bit数据) ROR 偶数位,如果不能通过这种方式得到,就会报错
  • {S}用于表示当前指令的操作结果是否影响CPSR中的相应位
MOV{<cond>}{S}	<Rd>,	<shifter_operand>			;数据传送
MVN{<cond>}{S} <Rd>, <shifter_operand> ;数据求反传送
ADD{<cond>}{S} <Rd>, <Rn>, <shifter_operand> ;加法
ADC{<cond>}{S} <Rd>, <Rn>, <shifter_operand> ;带位加法
SUB{<cond>}{S} <Rd>, <Rn>, <shifter_operand> ;减法
SBC{<cond>}{S} <Rd>, <Rn>, <shifter_operand> ;带位减法
RSB{<cond>}{S} <Rd>, <Rn>, <shifter_operand> ;逆向减法
RSC{<cond>}{S} <Rd>, <Rn>, <shifter_operand> ;带位逆向减法
AND{<cond>}{S} <Rd>, <Rn>, <shifter_operand> ;逻辑与
ORR{<cond>}{S} <Rd>, <Rn>, <shifter_operand> ;逻辑或
EOR{<cond>}{S} <Rd>, <Rn>, <shifter_operand> ;逻辑异或
BIC{<cond>}{S} <Rd>, <Rn>, <shifter_operand> ;位清除
CMP{<cond>}{S} <Rd>, <Rn>, <shifter_operand> ;比较
CMN{<cond>}{S} <Rd>, <Rn>, <shifter_operand> ;基于相反数的比较
TST{<cond>}{S} <Rd>, <Rn>, <shifter_operand> ;位测试
TEQ{<cond>} <Rn>, <shifter_operand> ;相等测试

数据处理指令的操作数寻址方式(shifter_operand)

<opcode>{<cond>}{S}	<Rd>,	<Rn>,	<shifter_operand>
#<immediate> ;立即数寻址
<Rm> ;寄存器寻址
<Rm>,LSL #<shift_imm> ;立即数逻辑左移
<Rm>,LSL <Rs> ;寄存器逻辑左移 <Rm>,LSR #<shift_imm> ;立即数逻辑右移
<Rm>,LSR <Rs> ;寄存器逻辑右移 <Rm>,ASR #<shift_imm> ;立即数算术右移
<Rm>,ASR <Rs> ;立即数算术右移 <Rm>,ROR #<shift_imm> ;立即数循环右移
<Rm>,ROR <Rs> ;寄存器循环右移 <Rm>,RRX ;寄存器扩展循环右移

乘法指令

任何乘法指令都必须使用寄存器,不能使用立即数

MUL{<cond>}{S}	<Rd>,	<Rm>,	<Rs>				;32位乘法
MLA{<cond>}{S} <Rd>, <Rm>, <Rs>, <Rn> ;32位带加数的乘法
SMULL{<cond>}{S} <RdLo>, <RdHi>, <Rm>, <Rs> ;64位有符号数乘法
SMLAL{<cond>}{S} <RdLo>, <RdHi>, <Rm>, <Rs> ;64位带加数的有符号数乘法
UMULL{<cond>}{S} <RdLo>, <RdHi>, <Rm>, <Rs> ;64位无符号数乘法
UMLAL{<cond>}{S} <RdLo>, <RdHi>, <Rm>, <Rs> ;64位带加数的无符号数乘法

PSR指令

MRS{<cond>}	<Rd>,	CPSR							;将PSR的内容传送到通用寄存器中
MRS{<cond>} <Rd>, SPSR
MSR{<cond>} CPSR_<fields>, #<immediate> ;将通用寄存器的内容或一个立即数传送到PSR
MSR{<cond>} CPSR_<fields>, <Rm>
MSR{<cond>} SPSR_<fields>, #<immediate>
MSR{<cond>} SPSR_<fields>, <Rm>

内存访问

B字节,H半字,T用户模式,S由有符号

LDR{<cond>		<Rd>,	<addressing_mode>				;字数据读取
LDR{<cond>}B <Rd>, <addressing_mode> ;字节数据读取
LDR{<cond>}BT <Rd>, <addressing_mode> ;用户模式的字节数据读取
LDR{<cond>}H <Rd>, <addressing_mode> ;半字数据读取
LDR{<cond>}SB <Rd>, <addressing_mode> ;有符号的字节数据读取
LDR{<cond>}SH <Rd>, <addressing_mode> ;有符号的半字数据读取
LDR{<cond>}T <Rd>, <post_indexed_addressing_mode> ;用户模式的字数据读取
STR{<cond>} <Rd>, <addressing_mode> ;字数据写入
STR{<cond>}B <Rd>, <addressing_mode> ;字节数据写入
STR{<cond>}H <Rd>, <addressing_mode> ;半字数据写入
STR{<cond>}T <Rd>, < post_indexed_addressing_mode> ;用户模式字数据写入

批量内存访问

LDM{<cond>}<addressing_mode>	<Rn>{!},		<registers>			;批量内存字数据读取
LDM{<cond>}<addressing_mode> <Rn>{!}, <registers_without_pc> ;用户模式的批量内存字数据读取
LDM{<cond>}<addressing_mode> <Rn>{!}, <registers_and_pc> ;带PSR的批量内存字数据读取
STM{<cond>}<addressing_mode> <Rn>{!}, <registers> ;批量内存字数据写入
STM{<cond>}<addressing_mode> <Rn>, <registers> ;用户模式的批量内存字数据写入

异常发生指令

SWI{<cond>}	<immed_24>		;软中断
BKPT <immediate> ;断点中断

ARM指令的更多相关文章

  1. iOS逆向工程之Hopper中的ARM指令

    虽然前段时间ARM被日本软银收购了,但是科技是无国界的,所以呢ARM相关知识该学的学.现在看ARM指令集还是倍感亲切的,毕竟大学里开了ARM这门课,并且做了不少的实验,当时自我感觉ARM这门课学的还是 ...

  2. ARM指令教程

    ARM指令教程 ARM汇编程序特点: l         所有运算处理都是发生通用寄存器(一般是R0~R14)的之中.所有存储器空间(如C语言变量的本质就是一个存储器空间上的几个BYTE).的值的处理 ...

  3. ARM指令分类及其寻址方式

    ARM指令分类及其寻址方式 一:ARM指令的分类 ARM指令集可以分为以下6类: •跳转指令: •数据处理指令: •程序状态寄存器(PSR)传输指令: •load/store指令: •协处理器指令: ...

  4. ARM指令学习,王明学learn

    ARM指令学习 一.算数和逻辑指令 1— MOV 数据传送指令    2.— MVN 数据取反传送指令    3.— CMP 比较指令    4.— CMN 反值比较指令    5.— TST 位测试 ...

  5. 头文件定义和ARM指令

    2015.2.2星期一,阴天 内存管理:内存的分配和释放等静态和动态内存:主要是在释放方式上的区别 静态变量:编译时就已经确定,定义在函数外面自动变量:在程序运行时才能在栈中确定只读数据节:存放常量的 ...

  6. [置顶] ARM指令集和常用寄存器

    1) ARM指令集 32位的 ARM指令和 16位 的Thumb指令 1,寄存器寻址 MOV R1, R2  //将寄存器R2的值传给寄存器R1 2,立即寻址 MOV R0, #0XFF00 //数据 ...

  7. ARM指令和Thumb指令区别

    Thumb指令集 ]的问题而提出的,它具有16为的代码密度.Thumb不是一个完整的体系结构,不能指望处理程序只执行Thumb指令而不支持ARM指令集.因此,Thumb指令只需要支持通用功能,必要时, ...

  8. arm指令bne.w改成b,即无条件跳转

    近期逆向一个程序,需要把bne.w改成b,无条件跳转.由于ios逆向不像pc上,可以在od里直接改汇编指令,这篇文章给了我很大的帮助.通过memory write 修改后,验证可行后,再用ultrae ...

  9. arm指令1

    .section .text.writeFUNCTION(write) ldr r12, =__NR_write swi #0 bx lr LDR: LDR 的两种用法 1)LDR pc, =MyHa ...

随机推荐

  1. Java面试总结系列之Collections.sort()

    面试中被问到,集合类中的排序方法是怎么实现的?没有回答上来,故而总结如下:你知道么? 前提:在eclipse中对于自己的代码可以通过按住Ctrl的同时单击名称跳入相应源码中.但eclipse默认没有添 ...

  2. php ci 2.0框架 ORM

    很早知道ci出了2.0版本了.这几天正好有项目要用ci开发 虽然项目不大.不过也从开发项目的过程中熟悉了CI框架 因为是个电商项目 本来想用个YII2 的. 封装的虽然厉害不过功能强大 因为另个兄弟坚 ...

  3. MySQL的常规操作

    MySQL的常规知识 show 查看数据库 show databases; 查看表 存在的所有表 show tables; 创建表的命令 show create table table_name; 表 ...

  4. [deviceone开发]-HeaderView和FooterView的示例

    一.简介 这个是利用do_ListView组件实现下拉和上拉刷新功能的例子,除了do_ListView,其它比如do_Webview,do_ScrollView都有这个个功能.对应的BBS里的帖子详细 ...

  5. SharePoint 2013 VSS 编写器

    Windows Server 包含的 VSS 是提供内置卷影复制功能的基础结构.VSS 创建的卷影副本扩展了存储管理员的磁带备份存档解决方案,提供可轻松.有效创建和还原的高保真时间点副本,从而帮助简化 ...

  6. VS 2015打开项目闪退,新建项目提示未将对象引用到实例

    因为开发需要,要把开发工具换成visual studio2015,装完之后会有警告“js”安装的问题,打开VS也没有问题, 但是一打开项目就闪退,新建项目也不行,查看应用程序日志,报错提示如下: .N ...

  7. MyEclipse 2015免费在线公开课,2月5日开讲

    MyEclipse 2015免费在线公开课,2月5日开讲,由MyEclipse官方高级PM Brian Fernandes 主讲. 主讲内容: 更好地支持javascript和技术模块 全新的REST ...

  8. 在ArcGIS中如何进行POI点抽稀

    对POI点添加权重等级类型信息.例如添加短整形字段Weight,并根据业务逻辑设置不同种类的POI的权重值,如分5类,0代表重要性最低的POI,4代表重要性最高. 在ArcMap的标注管理栏中,设置使 ...

  9. Web自动化测试 Selenium 2/3

    TesNG和Selenium集成使用 TestNG 是一个设计用来简化广泛的测试需求的测试框架,从单元测试(隔 离测试一个类)到集成测试(测试由有多个类多个包甚至多个外部框架组成的整 个系统,例如运用 ...

  10. jQuery导航切换功能

    Css ------------------------------------------------------------------------------------------------ ...