[国嵌笔记][025][ARM指令分类学习]
算术和逻辑指令
1.mov
格式:mov {条件}{s} <dest>, <op>
作用:把一个值从一个地方移动到另一个地方,<dest>必须是寄存器
示例:
@mov指令范例 “@”表示注释
mov r1, #8
mov r2, r1
2.mvn
格式:mvn {条件}{s} <dest>, <op>
作用:把一个值取反后从一个地方移动到另一个地方,<dest>必须是寄存器
示例:
@“0b”表示二进制,”0x”表示十六进制,什么都不加表示十进制
mvn r1, #0b10
mvn r2, #5
mvn r3, r1
3.sub
格式:sub{条件}{s} <dest>, <op1>, <op2>
作用:减法,用<op1>-<op2>把结果放到<dest>寄存器中
示例:
@<dest>和<op1>不能为立即数
mov r0, #4
sub r1, r0, #2
4.add
格式:add{条件}{s} <dest>, <op1>, <op2>
作用:加法,<op1>加上<op2>的和放到<dest>寄存器中
示例:
@可以在调试中直接给寄存器赋值
mov r1, #1
add r2, r1, #1
5.and
格式:and{条件}{s} <dest>, <op1>, <op2>
作用:逻辑与,<op1>与<op2>相与结果放在<dest>寄存器中
示例:
mov r1, #5
and r2, r1, #0
and r3, r1, #1
6.bic
格式:bic{条件}{s} <dest>, <op1>, <op2>
作用:位清除,把<op1>中在<op2>中对应为1的位清零,结果放在<dest>中
示例:
mov r1, #0b1011
bic r2, r1, #0b0101
比较指令
1.cmp
格式:cmp{条件}{P} <op1>, <op2>
作用:比较,<op1>减去<op2>的大于、小于和等于三种情况保存在cprs中的N和Z位中
示例:
mov r1, #2
cmp r1, #1 @NZ 00
cmp r1, #2 @NZ 01
cmp r1, #3 @NZ 10
2.tst
格式:tst{条件}{P} <op1>, <op2>
作用:测试位,把<op1>与<op2>中对应位做按位与操作,结果保存在cprs中的Z位,用来测试<op1>在<op2>中对应位是否为1(条件是否为真)
示例:
mov r1, #0b101
tst r1, #0b010 @Z 1
tst r1, #0b110 @Z 0
跳转指令
1.b
格式:b{条件} <地址>
作用:根据条件跳转到地址处,常用条件有gt(大于)、ge(大于等于)、eq(等于)、ne(不等于)、lt(小于)、le(小于等于);也可以不跟条件,表示无条件跳转
示例:
mov r1, #2
mov r2, #1
cmp r1, r2
bgt branch @(if)如果满足条件跳转到分支,否则执行另一个分支
sub r3, r1, r2
b end @无条件跳转
branch:
add r3, r1, r2
end:
nop @空操作
2.bl
格式:
作用:带链接返回的跳转,在跳转之前保存返回后将要执行的下一条指令的地址到lr(链接寄存器)中,用于函数的返回
示例:
mov r1, #1
mov r2, #2
bl func
mov r0, r3
b end
func:
add r3, r1, r2
mov pc, lr
end:
nop
移位指令
1.lsl
格式:rx , lsl#n
作用:逻辑左移(logical or arithmetic shift left),把rx寄存器中的值左移n位,低位补0。类似的还有asl(算术左移,低位直接补0),lsr(逻辑右移,高位补0),asr(算术右移,高位补符号值)。逻辑移动直接补0,算术移动补符号值。
示例:
mov r1, #0b101
mov r2, r1, lsl#2
mov r2, r1, asl#2
mov r2, r1, lsr#2
mov r2, r1, asr#2
2.ror
格式:rx, ror#n
作用:循环右移(rotate right),把rx寄存器的最低位循环移动到最高位。
示例:
mov r1, #0b11
mov r2, r1, ror#1
3.rrx
格式:rx, rrx#n
作用:带扩展位的循环右移(rotate right with extend),把rx寄存器的值加上cprs中的S位一起循环右移。
示例:
mov r1, #0b11
mov r2, r1, rrx
4.循环指令汇总
LSL 逻辑左移,低位补0值
ASL 算术左移,低位补0值
LSR 逻辑右移,高位补0值
ASR 算术右移,高位补符号(S)值
ROR 循环右移,高位补低位值
RRX 带扩展的循环右移,符号位(S)补低位值
5.程序状态字访问指令
1.mrs和msr
格式:mrs rd, cpsr msr cpsr, rd
作用:程序状态字寄存器不能直接修改,需要用专用指令来修改程序状态寄存器中的值。
示例:
mrs r0, cpsr
orr r0, r0, #0b11111 @使处理器工作在sys(系统模式
msr cpsr, r0
6.存储器访问指令
1.ldr和str
格式:ldr{条件} rd, <地址> str{条件} rd, <地址>
作用:从<地址>中装载到rd中,或把rd的值保存到<地址中>
示例:
mov r1, #ff
ldr r0,=0x30001000 @mov指令不能直接超过8位的值,用伪指令用来把内存地址0x30001000值赋给r0寄存器
str r1, [r0] @把r1中的值保存到到r0指向的地址中
ldr r2, [r0] @把r0指向的地址中的值装载到r2中
.text
.global _start
_start:
@ldr str
ldr r0, =0x30001000
mov r1, #0xff
str r1, [r0]
ldr r2, [r0] @mrs msr
mrs r1, cpsr
orr r1, r1, #0b11111
msr cpsr, r1 @ror
mov r1, #0b11
mov r2, r1, ror#1
mov r3, r1, rrx @lsl
mov r1, #0b101
mov r2, r1, lsl#2
mov r2, r1, asl#2
mov r2, r1, lsr#2
mov r2, r1, asr#2 @bl
mov r1, #1
mov r2, #2
bl func
mov r0, r3
b end func:
add r3, r1, r2
mov pc, lr end2:
nop @b
mov r1, #2
mov r2, #1 cmp r1, r2
bgt branch
sub r3, r1, r2
b end
branch:
add r3, r1, r2 end1:
nop @tst
mov r1, #0b101
tst r1, #0b010
tst r1, #0b110 @cmp
mov r1, #2
cmp r1, #1
cmp r1, #2
cmp r1, #3 @bic
mov r1, #0b1011
bic r2, r1, #0b0101 @and
mov r1, #5
and r2, r1, #0
and r3, r1, #1 @add
mov r1, #1
add r2, r1, #1 @sub
mov r0, #4
sub r1, r0, #2 @mvn
mvn r1, #0b10
mvn r2, #5
mvn r3, r1 @mov
mov r1, #8
mov r2, r1
[国嵌笔记][025][ARM指令分类学习]的更多相关文章
- ARM指令分类学习
指令分类: 1.算数和逻辑指令 2.比较指令 3.跳转指令 4.移位指令 5.程序状态字访问指令 6.存储器访问指令 +++++++++++++++++++++++++++++++++++++++++ ...
- [国嵌笔记][024][ARM汇编编程概述]
汇编程序用途 1.在bootloader与内核初始化时,还没有建立C语言运行环境,需要用到汇编程序 2.在对访问效率要求很高的情况下,需要用到汇编程序 ARM汇编分类 1.ARM标准汇编:适合于Win ...
- [国嵌笔记][027][ARM协处理器访问指令]
协处理器作用 协处理器用于执行特定的处理任务,如数学协处理器可以执行控制数字处理,以减轻处理器的负担.ARM处理器最多可以支持16个协处理器,其中CP15是最重要的一个协处理器 CP15的作用 CP1 ...
- [国嵌笔记][021-022][ARM处理器工作模式]
[ARM处理器工作模式] 处理器工作模式 1.User(urs):用户模式,linux应用程序运行在用户模式 2.FIQ(fiq):快速中断模式 3.IRQ(irq):中断模式 4.Superviso ...
- [国嵌笔记][020][ARM家族大检阅]
ARM芯片:2440(arm9) 6410(arm11) 210(cortex-A8) ARM核:arm9(arm-v4) arm11(arm-v6) cortex-A8(arm-v7) 指令架构:a ...
- [国嵌笔记][026][ARM伪指令]
ARM机器码 1.汇编程序通过汇编器变成机器码,然后才能在ARM处理器上运行 2.ARM机器码是一个32位的数,被分成了多个段,每个段都有各自的含义 3.格式: cond:表示条件(4位) I:表示源 ...
- 3.2 ARM指令分类学习
1 算术移位寄存器和逻辑指令 1.1 mov 传送(Move) Mov {条件} {S} <dest>, <op_1> MOV从另一个寄存器.被移位的寄存器.或者一个立即数装载 ...
- [国嵌笔记][023][ARM寻址方式]
寻找方式 1.处理器根据指令中给出的信息来找到指令所需操作数的方式 2.立即数寻址 操作数本身在指令中给出,立即数前加”#”表示立即数寻址,操作数在指令中 3.寄存器寻址 利用寄存器中的数值作为操作数 ...
- [国嵌笔记][029][ARM处理器启动流程分析v2]
2440启动流程 启动方式:nor flash启动.nand flash启动 地址布局: 选择nor flash启动时,SROM(nor flash)地址为0x00000000 选择nand flas ...
随机推荐
- Wamp环境搭建常见错误问题解决
第一点.对于apache + php + mysql 的版本的正确选择 问题:网上有些教学视频已经很早了,然后很多人照着来,完全和视频里讲的一样,但是结果就是搭建不成功. 出现问题原因:三件套的版本选 ...
- Locust no-web 模式与参数详解
读前参考:<性能测试工具Locust > 熟悉 Apache ab 工具的同学都知道,它是没有界面的,通过命令行执行. Locust 同样也提供的命令行运行,好处就是更节省客户端资源. 命 ...
- Notepad++使用教程
Notepad++ 快捷键 大全 Ctrl+C 复制Ctrl+X 剪切Ctrl+V 粘贴Ctrl+Z 撤消Ctrl+Y 恢复Ctrl+A 全选Ctrl+F 键查找对话框启动Ctrl+H 查找/替换对话 ...
- Python配置文件实现
实现目标: 支持配置文件继承 支持本地配置文件 支持配置文件别名 简单的配置文件操作 最新的代码可以参考 https://github.com/blackmatrix7/matrix-toolkit/ ...
- 腾讯云负载均衡CLB的那些“独门利器”
欢迎大家前往云+社区,获取更多腾讯海量技术实践干货哦~ 作者:李想 腾讯人做产品一直是很贴近用户的需求的,腾讯云也不例外.负载均衡器作为公有云上的最基础的网络服务,几乎每家云厂商都会提供,虽然负载均衡 ...
- ASP.NET 基础多文件上传
////多图上传 [HttpPost] public string duo() { ///.net 多文件上传 获取文件的集合 HttpFileCollection files = HttpConte ...
- [转]Wing IDE 6.0 安装及算号器注册机代码
下载安装wing 选择第三个,运行算号器,输入license id 输入request id. Python 2 算号器注册机代码 import string import random import ...
- 8086cpu中的标志寄存器与比较指令
在8086CPU中有一个特殊的寄存器--标志寄存器,该寄存器不同于其他寄存器,普通寄存器是用来存放数据的读取整个寄存器具有一定的含义,但是标志寄存器是每一位都有固定的含义,记录在运算中产生的信息,标志 ...
- Linux进程关系(转载)
Linux的进程相互之间有一定的关系.比如说,在Linux进程基础中,我们看到,每个进程都有父进程,而所有的进程以init进程为根,形成一个树状结构.我们在这里讲解进程组和会话,以便以更加丰富的方式了 ...
- Chris Richardson微服务翻译:微服务之事件驱动的数据管理
Chris Richardson 微服务系列翻译全7篇链接: 微服务介绍 构建微服务之使用API网关 构建微服务之微服务架构的进程通讯 微服务架构中的服务发现 微服务之事件驱动的数据管理(本文) 微服 ...