ARM指令
语法格式
<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指令的更多相关文章
- iOS逆向工程之Hopper中的ARM指令
虽然前段时间ARM被日本软银收购了,但是科技是无国界的,所以呢ARM相关知识该学的学.现在看ARM指令集还是倍感亲切的,毕竟大学里开了ARM这门课,并且做了不少的实验,当时自我感觉ARM这门课学的还是 ...
- ARM指令教程
ARM指令教程 ARM汇编程序特点: l 所有运算处理都是发生通用寄存器(一般是R0~R14)的之中.所有存储器空间(如C语言变量的本质就是一个存储器空间上的几个BYTE).的值的处理 ...
- ARM指令分类及其寻址方式
ARM指令分类及其寻址方式 一:ARM指令的分类 ARM指令集可以分为以下6类: •跳转指令: •数据处理指令: •程序状态寄存器(PSR)传输指令: •load/store指令: •协处理器指令: ...
- ARM指令学习,王明学learn
ARM指令学习 一.算数和逻辑指令 1— MOV 数据传送指令 2.— MVN 数据取反传送指令 3.— CMP 比较指令 4.— CMN 反值比较指令 5.— TST 位测试 ...
- 头文件定义和ARM指令
2015.2.2星期一,阴天 内存管理:内存的分配和释放等静态和动态内存:主要是在释放方式上的区别 静态变量:编译时就已经确定,定义在函数外面自动变量:在程序运行时才能在栈中确定只读数据节:存放常量的 ...
- [置顶] ARM指令集和常用寄存器
1) ARM指令集 32位的 ARM指令和 16位 的Thumb指令 1,寄存器寻址 MOV R1, R2 //将寄存器R2的值传给寄存器R1 2,立即寻址 MOV R0, #0XFF00 //数据 ...
- ARM指令和Thumb指令区别
Thumb指令集 ]的问题而提出的,它具有16为的代码密度.Thumb不是一个完整的体系结构,不能指望处理程序只执行Thumb指令而不支持ARM指令集.因此,Thumb指令只需要支持通用功能,必要时, ...
- arm指令bne.w改成b,即无条件跳转
近期逆向一个程序,需要把bne.w改成b,无条件跳转.由于ios逆向不像pc上,可以在od里直接改汇编指令,这篇文章给了我很大的帮助.通过memory write 修改后,验证可行后,再用ultrae ...
- arm指令1
.section .text.writeFUNCTION(write) ldr r12, =__NR_write swi #0 bx lr LDR: LDR 的两种用法 1)LDR pc, =MyHa ...
随机推荐
- MUI(2)
本篇博文是继续MUI(1)博文. 上一篇博文小编写了两个页面,一个页面只写了一个头部导航栏,另一个页面写了一个按钮,然后这两个页面进行合并显示,即在头部导航栏页面加载显示另一个页面的按钮.仔细观察上一 ...
- jquery常见知识点 总结
1. jquery特点 2. jquery中css选择器用法 jQuery使用了一套css选择器,共有5种,即标签选择器,ID选择器,类选择器,通用选择器和群组选择器,现分述如下: 标签选择器 用 ...
- [小北De编程手记] : Lesson 04 玩转 xUnit.Net 之 Fixture(下)
上一篇文章<[小北De编程手记] : Lesson 03 玩转 xUnit.Net 之 Fixture(上)>向大家介绍了xUnit.Net 共享数据的方式.Test Case的构造函数 ...
- 浅谈spring security 403机制
403就是access denied ,就是请求拒绝,因为权限不足 三种权限级别 一.无权限访问 <security:http security="none" pattern ...
- ArcGIS server开发之API for js 本地部署
ArcGIS Server for javascript 本地部署 第一次使用arcgis server for js开发,在经验方面还有很多的不足,所以将自己在开发过程中遇到的问题写出来与大家共享. ...
- Weinre调试移动端页面
Weinre是什么 如果我们做的是Cordova(phonegap)或其他hybird应用,当使用到原生功能时候(类似原生请求数据或页面切换时),没办法在PC chrome浏览器调试页面,一旦页面在手 ...
- JavaScript 开发者经常忽略或误用的七个基础知识点(转)
JavaScript 本身可以算是一门简单的语言,但我们也不断用智慧和灵活的模式来改进它.昨天我们将这些模式应用到了 JavaScript 框架中,今天这些框架又驱动了我们的 Web 应用程序.很多新 ...
- Win10中安装ArcObject帮助
问题 环境:Win10+VS2010+ArcGIS10.0,未能成功安装其AO帮助文档:使用help library manager手动安装也报错. 选择msha文件: 解决 查看系统事件,发现组件注 ...
- sharepoint2010如何本地化WebPart的Category、WebDisplayName 和 WebDescription 属性
在项目中经常需要实现多语言其中包括webpart的属性也需要.那么如何实现呢? 首先需要资源文件,利用资源文件实现语言的翻译,如下图: 创建好资源后,下面我们来实现webpart属性的多语言.方法代码 ...
- Android 查看手机中所有进程
真机测试的时候发现DDMS对进程的显示很不给力,一些进程管理工具又不显示包名. 所以就自己写了一个小程序,查看自己手机中的进程,显示当前时间和进程的包名: 程序运行截图: 布局: <Linear ...