ARM 常用汇编指令
ARM 汇编程序的框架结构
.section .data
<初始化的数据>
.section.bss
<未初始化的数据>
.section .text
.global _start
_start:
<汇编代码>
注意: 一般是将上面结构进行简化
.text
.global _start
_start:
<汇编代码>
寄存器操作指令:
算术和逻辑指令:
MOV :用于将一个寄存器或被移位寄存器或一个立即数移动到目的寄存器
MOV r1 ,#8 (注意:#+数,表示一个十进制数,#+0b数,表示一个二进制数,#+0x数,表示一个十六进制数)
MVN :对源操作数取反再赋值给目的寄存器
MOV R1,#8
SUB : 将一个数减去另外一个数再存放如寄存器
SUB R1,#8,#6(8-6)
ADD:将一个数加上另外一个数后将其存放如寄存器中
ADD R1,R2,R3
AND :逻辑与
AND R1,R2,#0
BIC:位清除
BIC R1,R2,#0B1101
将R2中所与#b1101中1所对应的位清零后的结果保存在R1中
比较指令:
CMP:顾名思义,用于比较两个数的大小,比较的结果不过会放在哪个通用寄存器中而是改在程序状态寄存器中的一个标志状态位
CMP R1,#0B111010
TST:测试位,将两个数按位与
TST R1,R2
分枝指令:
B:条件跳转指令
B [条件] 标号 (注意 :中括号在编写程序时不需要写出)
BL :带连接的返回(类似于C语言中的子函数调用,调用子函数后返回主函数)
移位指令:
LSL:算术左移位
MOV R1,R1,LSL#2(将R1中的数据左移两位存入R1)
ROR:循环右移
MOV R1,R1,#ROR 2(将R1中的数据循环右移后存入R1中)
程序状态字访问指令:
上面所学指令都不能对计算机中的程序状态字中的指令进行访问和读写,所以需要专用计算机指令来将程序状态字中的数据读写到通用寄存器中,在进行修改后写入
MRS :将程序状态字中的数据搬出来
MRS R0,CPRS
MSR:将数据搬回程序状态字中
MSR CPRS, R0
存储器操作指令:
LDR :将内存中的值导出到通用寄存器中
LDR R0 ,#0XFF ‘
STR:将同用寄存器中的数据写回到内存中
STR R0 ,#0XFF
伪指令:
定义类伪指令:(1:编译时起作用2:起作用但是转化为其他机器指令)
.global 表明一个全局的符号 (注意GNU伪指令的特点在前面加上一个“.”)
.data 定义一个数据段
.ascii 定义字符串的数据
.byte 定义一个字节的数据
.word 定义一个字的数据
.data
.equ (类似于C语言中定义宏)
.align 用于字节对齐
操作类伪指令:
nop:空操作指令 \
具体实现:mov r0 ,r0
ldr:用于将一个大于八位的数据装入寄存器
注意:ldr r0 ,=0x1ff
这里后面是用的等号这里和其他地方有些不一样
协处理指令:(最重要是就是CP15)
作用:系统控制
mcr:
mrc:
mrc p15,0, r0 ,c0,c0,0
注意:蓝色部分是由芯片手册的cp15寄存器访问列表给出的以访问不同寄存器 。红色部分是内核内部通用寄存器
ARM 常用汇编指令的更多相关文章
- ARM常用汇编指令介绍
b 跳转指令(跳转范围为32Mb) bl 带返回地址的跳转,指令自动将下一条指令的地址复制到R14寄存器,然后跳转到指定地址去执行,执行完后返回到下一条指令处执行 pc 寄存器R1 ...
- 浅析VS2010反汇编 VS 反汇编方法及常用汇编指令介绍 VS2015使用技巧 调试-反汇编 查看C语言代码对应的汇编代码
浅析VS2010反汇编 2015年07月25日 21:53:11 阅读数:4374 第一篇 1. 如何进行反汇编 在调试的环境下,我们可以很方便地通过反汇编窗口查看程序生成的反汇编信息.如下图所示. ...
- ARM 内核 汇编指令 的 8种 寻址方式
str: store register ->指令将寄存器内容存到内存空间中, ldr: load register 将内存内容加载到通用寄存器, ldr/str 组合来实现ARM CPU 和内 ...
- 【安卓逆向】ARM常见汇编指令总结
跳转指令 B 无条件跳转 BL 带链接的无条件跳转 BX 带状态切换的无条件跳转 BLX 带链接和状态的无条件跳转 存储器与寄存器交互数据指令(核心) 存储器:主存和内存 寄存器中放的数据:可以是字符 ...
- ARM常用汇编指令列表 --- 转自百度文库
- 从零开始的程序逆向之路 第一章——认识OD(Ollydbg)以及常用汇编扫盲
作者:Crazyman_Army 原文来自:https://bbs.ichunqiu.com/thread-43041-1-1.html 0×00 序言: 1.自从上次笔者调戏完盗取文件密码大黑客后, ...
- 常用ARM汇编指令
常用ARM汇编指令 [日期:2012-07-14] 来源:Linux社区 作者:xuyuanfan77 [字体:大 中 小] 在嵌入式开发中,汇编程序常常用于非常关键的地方,比如系统启动时初 ...
- ARM汇编指令调试方法
学习ARM汇编时,少不了对ARM汇编指令的调试.作为支持多语言的调试器,gdb自然是较好的选择.调试器工作时,一般通过修改代码段的内容构造trap软中断指令,实现程序的暂停和程序执行状态的监控.为了在 ...
- ARM 汇编指令
ARM汇编程序特点: l 所有运算处理都是发生通用寄存器(一般是R0~R14)的之中.所有存储器空间(如C语言变量的本质就是一个存储器空间上的几个BYTE).的值的处理,都是要传送到通 ...
随机推荐
- weblogic 反序列化补丁绕过漏洞的一个批量检测shell脚本(CVE-2017-3248 )
~ 以下内容,仅供学习参考 ~ weblogic 反序列化补丁绕过漏洞已经出了两个月了,balabala ~~~ 废话不说,拿到该漏洞的利用工具weblogic.jar,但只能一个个检测ip和端口,效 ...
- HDU 1686 Oulipo (KMP 可重叠)
题目链接 Problem Description The French author Georges Perec (1936–1982) once wrote a book, La dispariti ...
- win7.wifi热点
使用本地连接上网,将网卡设为wifi热点 cmd 管理员身份运行 netsh wlan set hostednetwork mode=allow ssid=4Gtest key=12345678 网络 ...
- 利用反射型XSS二次注入绕过CSP form-action限制
利用反射型XSS二次注入绕过CSP form-action限制 翻译:SecurityToolkit 0x01 简单介绍 CSP(Content-Security-Policy)是为了缓解XSS而存在 ...
- Spiral Matrix I & II
Spiral Matrix I Given an integer n, generate a square matrix filled with elements from 1 to n^2 in s ...
- 【Linux】Linux基本命令扫盲【转】
转自:http://www.cnblogs.com/lcw/p/3762927.html [VI使用] 1.在命令行模式 :在vi编辑器中将光标放在函数上,shift + k 可直接man手册 ...
- 【驱动】USB驱动实例·串口驱动·键盘驱动【转】
转自:http://www.cnblogs.com/lcw/p/3159370.html Preface USB体系支持多种类型的设备. 在 Linux内核,所有的USB设备都使用 usb_drive ...
- Python 使用 Redis 操作
1.redis简介 redis是一款开源免费的高性能key-value数据库,redis特点: 支持更多的数据类型:字符串(String).列表(List).哈希(Map).数字(Int).集合(Se ...
- linux bash shell之declare
一. #Set the right GC options based on the what we are runningdeclare -a server_cmds=("master&qu ...
- Access中替代case when的方法 .
最近在做一个用Access的东东,其中用到了case when的方式,但是Access是不支持这种语法的,查询知道IIf和Swith可以作为替代,总结如下: IIf(expr, truepart, f ...