指令分类:

1、算数和逻辑指令

2、比较指令

3、跳转指令

4、移位指令

5、程序状态字访问指令

6、存储器访问指令

++++++++++++++++++++++++++++++++++++++++++++++++++

学习指令的资料《arm汇编手册(中文版).chm》 ,注:这个资料是 ARM汇编手册,我们用的是GNU的汇编,所以语法 大小写上是有差别的。

使用上一篇文章中的汇编程序来,学习使用每个指令的用法。

一、算数和逻辑指令

1、mov指令

作用、格式、例子

从另一个寄存器、被移位的寄存器、或一个立即值装载一个值到目的寄存器。

MOV{条件}{S}  <dest>, <op 1>   。其中<dest>必须是通用寄存器。<op 1> 可以是通用寄存器,也可以是立即数。
汇编程序中使用@来添加注释。
JLink 连接好板子,PC机。板子nandflash启动。开启JLinkGDBServer,启动eclipse。
打开上一篇文章中的汇编程序工程。
直接在eclipse的工程项目中编辑start.s文件,
.text
.global _start
_start:
@mov指令释放
mov r1,#3
@ #3表示立即数,十进制3
mov r2,r1
mov r3,#10 clean,编译,调试。
查看寄存器的值,寄存器的值可以使用16进制来展示,右键菜单选项进行设置。

2、MVN : 传送取反的值

  MVN{条件}{S}  <dest>, <op 1>

 ( 使用C语言的表示方法:dest = !op_1)将 <op 1> 按位取反之后,赋值给<dest>
例子:
mvn r1,#ob10
@ #ob10 表示二进制数 10
mvn r2,#5
mvn r3,r1
------------------
r1的值应该是 二进制 10 按位取反之后的值: 11111111111111111111111111111101 r3的值应该是r1取反的值 即二进制 10

3、SUB : 减法

  SUB{条件}{S}  <dest>, <op 1>, <op 2>

                dest = op_1 - op_2

SUB 用操作数 one 减去操作数 two,把结果放置到目的寄存器中。操作数 1 是一个寄存器,操作数 2 可以是一个寄存器,被移位的寄存器,或一个立即值

4、ADD : 加法

5、AND : 逻辑与

  AND{条件}{S}  <dest>, <op 1>, <op 2>

                dest = op_1 AND op_2

----------------------------------
  Op_1   Op_2   结果

  0      0      0
0 1 0
1 0 0
1 1 1

.text
.global _start
_start:
mov r0,#0
mov r1,#1
mov r2,#3
and r3,r0,r1
@r3的值是0
and r4,r1,r2
@r4的值是1

6、BIC : 位清除

BIC{条件}{S}  <dest>, <op 1>, <op 2>
BIC 是在一个字中清除位的一种方法。操作数 2 是一个 32 位位掩码(mask)。如果如果在掩码中设置了某一位,则清除这一位。未设置的掩码位指示此位保持不变。 例子:
r0 的值是二进制 10111111
掩码是 101
则结果是 10111010
掩码是1 则清楚对应位,置为0
掩码是0,则不做操作。
.text
.global _start
_start:
mov r1,#0b101011
bic r2,r1,#0b101
@r2的值应该是 0b101010
二、比较指令

1、cmp : 比较(Compare)

比较的结果保存在程序状态寄存器,CPSR的 N ,Z 位

N: 0  操作数 one大于操作数two

1 操作数 one小于操作数two

Z:  1 表示比较的结果是两个数相等


.text
.global _start
_start:
mov r1,#1
cmp r1,#3
2、TST : 测试位
操作数one跟操作数two按位与操作,结果影响CPSR的Z位
Status = op_1 AND op_2
Status 0  CPSR Z位 是1
Status 1  CPSR Z位 是0
 


四、跳转指令(分支指令)

C语言中 if else分支,在汇编中是如何实现的?

1、b

b{条件}  <地址>
{条件}的相关知识在:

GT : 大于(有符号)如果一次比较之后...
设置了 N 标志设置了 V 标志
或者...
清除了 N 标志清除了 V
标志
并且...
清除了 Z 标志。 
示例:
mov r1,#7
mov r2,#3
cmp r1,r2
bgt branch
add r3,r1,r2
b end
branch:
sub r3,r1,r2
end:
nop
bgt branch: 满足条件跳转到 branch标号处。
b end: 无条件跳转到end标号处。

2、bl  带连接的分支

bl会把下一条指令的地址保存到lr寄存器当中。以便函数能够正常返回到调用的地方。

在汇编中实现函数的调用,返回

mov r3,#1

bl func1 @调用函数 func1

mov r1,#6

func1:

mov r1,#2

mov r2,#3

mov pc,lr

@注意lr寄存器,bl指令能够把跳转地址的下一条指令保存到lr中,可以通过反汇编来看到lr的地址是哪个指令操作的地址。

mov r3,#3


五、移位指令

1、LSL 逻辑左移

mov r1, #0b1

mov r1, r1, lsl#1

@r1的值最终为 0b10

2、ROR 循环右移

mov r1, #0b11

mov r1, r1, ror#1

@r1 的最终结果  1........1

六、程序状态字访问指令

需要特殊的指令来访问,修改CPSR寄存器

msr  把通用寄存器写入到CSPR寄存器中

mrs 把程序状态字搬移到通用寄存器

mrs r0, cpsr  @把cpsr的值赋值给 r0

orr r0, #0b100  @把r0 的第三位置为1

msr cpsr, r0 @把r0的值赋值给cpsr


七、存储器访问指令

内存的值到寄存器 ldr

寄存器的值到内存 str

mov r0, 0xff

str r0,  [r1]  @把r0的值赋值给,以r1的值为地址的内存中。

@在调试时,认为的修改 r1的值为 0x30001000 ,(2440的开发板)

@调试界面打开Memory窗口,观察 内存地址为 0x30001000 的数据是否是  0xff

ldr r2,  [r1]

@以r1的值作为内存的地址,把该内存地址上的值赋值给r2 ,应该是 0xff

												

ARM指令分类学习的更多相关文章

  1. 3.2 ARM指令分类学习

    1 算术移位寄存器和逻辑指令 1.1 mov 传送(Move) Mov {条件} {S} <dest>, <op_1> MOV从另一个寄存器.被移位的寄存器.或者一个立即数装载 ...

  2. [国嵌笔记][025][ARM指令分类学习]

    算术和逻辑指令 1.mov 格式:mov {条件}{s} <dest>, <op> 作用:把一个值从一个地方移动到另一个地方,<dest>必须是寄存器 示例: @m ...

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

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

  4. Part3_lesson2---ARM指令分类学习

    1.算术和逻辑指令 mov.mvn.cmp.tst.sub.add.and.bic 2.比较指令 cmp和tst 3.跳转指令 b和bl 4.移位指令 lsl和ror 5.程序状态字访问指令 msr与 ...

  5. 【嵌入式开发】 ARM 汇编 (指令分类 | 伪指令 | 协处理器访问指令)

    作者 : 韩曙亮 博客地址 : http://blog.csdn.net/shulianghan/article/details/42408137 转载请著名出处 本博客相关文档下载 :  -- AR ...

  6. ARM指令解析

    今天我来总结一下arm指令的学习,今天我不会对所有的arm指令进行一一的解析,在这里希望大家去看arm汇编手册,这个手册的中文版我放在了http://download.csdn.net/detail/ ...

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

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

  8. Android ARM指令学习

    在逆向分析Android APK的时候,往往需要分析它的.so文件.这个.so文件就是Linux的动态链接库,只不过是在ARM-cpu下编译的.所以学习Android下的ARM指令很重要.目前,市面上 ...

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

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

随机推荐

  1. IMG图片和文字同行显示

    只要设定img标签的vertical-align CSS属性就好了,代码如下: <img src="images/untitled.png" style="widt ...

  2. Github上PHP资源汇总大全,php学习的好资料

    Github上PHP资源汇总大全,php学习的好资料 国外程序员ziadoz 在Github上收集整理了PHP的各种资源,内容包括模板.框架.数据库.安全等方面的库和工具.汇总了各种PHP资源,供各位 ...

  3. linux源码Makefile详解(完整)【转】

    转自:http://www.cnblogs.com/Daniel-G/p/3286614.html 随着 Linux 操作系统的广泛应用,特别是 Linux 在嵌入式领域的发展,越来越多的人开始投身到 ...

  4. java继承关系中成员变量,构造方法,成员方法的关系

    Java继承中的成员关系 A:成员变量 a:子类的成员变量名称和父类中的成员变量名称不一样,这个太简单写那个名字就访问那个名字! b:子类的成员变量名称和父类中的成员变量名称一样,这个怎么访问呢? 子 ...

  5. C# 探索c#之Async、Await剖析

    探索c#之Async.Await剖析 作者:蘑菇先生 出处:http://mushroom.cnblogs.com/

  6. Maven之Nexus构建企业级Maven仓库

    什么是Nexus? Nexus是Maven仓库管理器,用来搭建一个本地仓库服务器,这样做的好处是便于管理,节省网络资源,速度快,还有一个非常有用的功能就是可以通过项目的SNAPSHOT版本管理,来进行 ...

  7. 对于改善 MySQL 数据装载操作有效率的方法是怎样

    多时候关心的是优化SELECT 查询,因为它们是最常用的查询,而且确定怎样优化它们并不总是直截了当.相对来说,将数据装入数据库是直截了当的.然而,也存在可用来改善数据装载操作效率的策略,其基本原理如下 ...

  8. 关于sql server 2008过期导致 MSSQLSERVER服务就无法启动,手动启动就报告错误代码17051。

    1.基本现象:MSSQLSERVER服务就无法启动,手动启动就报告17051错误. 2.解决办法: 第一步:进入SQL2008配置工具中的安装中心, 第二步:再进入维护界面,选择版本升级, 第三步:进 ...

  9. postgresql压力测试工具用法以及参数解读

    pgbench是PostgreSQL自带的一个数据库压力测试工具, 支持TPC-B测试模型, 或自定义测试模型. 自定义测试模型支持元命令, 调用shell脚本, 设置随机数, 变量等等. 支持3种异 ...

  10. SlickGrid example 6:Ajax加载

    Ajax加载.   代码:   <!DOCTYPE HTML> <html> <head> <meta http-equiv="Content-Ty ...