ARM-汇编指令集(总结)】的更多相关文章

一.什么是ARM汇编? 运行在ARM处理器上的汇编语言就叫ARM汇编. C程序运行在X86平台,底层就是X86汇编:运行在ARM平台,底层就是ARM汇编.ARM汇编与X86汇编有显著区别. X86属于CISC(复杂指令集);ARM属于RISC(精简指令集). 二.CISC存在的问题: 指令系统庞大,指令功能复杂,指令格式.寻址方式多:执行速度慢:功耗大:难以优化编译:编译程序复杂:80%的指令在20%的运行时间使用:无法兼容等. 三.RISC特点: 简单的指令集---RISC指令集只提供很有限的…
常用ARM指令1:数据处理指令 •数据传输指令  mov mvn       mov r1,  r0        @两个寄存器之间数据传递       mov       r1,  #0xff   @将立即数赋值给寄存器 mov 和mvn用法一样,区别是mov是原封不动的传递,而mvn是按位取反后传递   •算术指令  add sub rsb adc sbc rsc       and    逻辑与      orr     逻辑或      eor     逻辑异或   •逻辑指令  and…
(汇编)指令是CPU机器指令的助记符,经过编译过会得到一串0011组成的机器码,可以由CPU读取执行. (汇编)伪指令本质不是指令(只是和指令一起写在代码中),它是编译器环境提供的,目的是用来指导编译过程,经过编译后伪指令最终不会生成机器码. 两种不同风格的ARM指令 --ARM官方的ARM汇编风格:指令一般用大写,Windows中的IDE开发环境(如ADS.MDK)常用.如:LDR  R0,[R1] --GNU风格的ARM汇编:指令一般用小写字母.Linux中常用.如:ldr  r0,[r1]…
一.跳转指令.跳转指令用于实现程序流程的跳转,在ARM程序中有以下两种方法可以实现程序流程的跳转. Ⅰ.使用专门的跳转指令.Ⅱ.直接向程序计数器PC写入跳转地址值. 通过向程序计数器PC写入跳转地址值,可以实现在4GB的地址空间中的任意跳转,在跳转之前结合使用 MOV LR,PC等类似指令,可以保存将来的返回地址值,从而实现在4GB连续的线性地址空间的子程序调用.ARM指令集中的跳转指令可以完成从当前指令向前或向后的32MB的地址空间的跳转,包括以下4条指令: 1.B指令 B指令的格式为: B{…
1.为增加处理器指令流 的速度,ARM使用多级流水线. 就是举个例子: mov r1,#0 ,这条指令 分几个人做,一个人从存储器取指令,解码指令中用到的寄存器,寄存器运算. 这样三步 :如果一个人做,需要分三步,浪费时间,ARM 就是分开处理,这样就能节省时间,加快处理速度.S5PV210 就有13级流水线,STM32F103 就有3级流水线! 流水线:缺点 一旦被打断,就会影响处理速度! 流水线:中断处理,返回的时候,PC 需要+8 ,或者-8, 3级流水线是相差 8个字节!  详细请百度!…
协处理器cp15操作指令: mcr & mrc •mrc用于读取CP15中的寄存器 •mcr用于写入CP15中的寄存器   什么是协处理器? •SoC内部另一处理核心,协助主CPU实现某些功能,被主CPU调用执行一定任务. •ARM设计上支持多达16个协处理器,但是一般SoC只实现其中的CP15.(cp:coprocessor) •协处理器和MMU.cache.TLB等处理有关,功能上和操作系统的虚拟地址映射.cache管理等有关.   MRC & MCR的使用方法 •mcr{<co…
什么是协处理器: SoC内部另一处理核心,协助CPU实现某些功能,被主CPU调用执行一定任务. ARM设计上支持16个协处理器,但是一般SoC只实现其中的CP15(cp就是cooperation processor). 协处理器和MMU.cache.TLB等处理有关,功能上和操作系统的虚拟地址映射.cache管理有关. 协处理器cp15操作指令:mcr & mrc mrc用于读取cp15中的寄存器 mcr用于写入cp15中的寄存器 多寄存器访问指令: ldr/str每周期只能访问4字节的内存,如…
mov r0,r1; moveq r0,r1;//这句代码是否执行 取决于 上几句代码 的运行结果(最后一次CPSR 寄存器 的 高四位   NZCV 的标志位) 条件后缀执行特点:1.条件后缀执行是否成立,不是取决于本句代码,而是取决于这句代码之前的代码运行后的结果! 2.条件后缀只是决定本句代码是否执行,并不影响下一句代码. CPSR : 高四位 解释 N:在结果是有符号的二进制补码情况下,如果结果为负数,则N=1:如果结果为非负数,则N=0. Z:如果结果为0,则Z=1;如果结果为非零,则…
1.同一 指令 添加不同的后缀 就会有不同的功能! 例子: B (Byte)  功能不变,操作长度变为8位 H (Half Word) 功能不变,操作长度变为16位 S(Signed) 功能不变,操作数变为有符号 //ldr,ldrb,ldrh,ldrsb,ldrsh S 和上一个不同,在不同的指令下S代表的含义不同这里表示:影响CPSR标志位,MOV 和 MOVS…
为什么需要多寄存器访问指令? ldr/str每周期只能访问4字节内存,如果需要批量读取.写入内存时太慢,解决方案是stm/ld 举例(uboot start.S 537行)   stmia  sp, {r0 - r12} 将r0存入sp指向的内存处(假设为0x30001000):然后地址+4(即指向0x30001004),将r1存入该地址:然后地址再+4(指向                0x30001008),将       r2存入该地址······直到r12内容放入(0x3000130)…
ARM汇编 ISA ISA即指指令集架构(Instruction Set Architecture)是与程序设计有关的计算机架构的一部分,包括本地数据类型.指令.寄存器.地址模式.内存架构.中断和意外处理和外部 I/O 一个 ISA 包括一系列 opcodes(机器语言)的一个规格,本地命令由一个特定的 CPU 设计来实现. 寄存器 在ARM微系统中,所有的运算指令都借助寄存器来完成.某些需要对存储器或者I/O值进行操作的情况下,会把存储器或者I/O值先读到寄存器中,然后再对寄存器中的值进行操作…
汇编源程序一般用于系统最基本的初始化:初始化堆栈指针.设置页表.操作 ARM的协处理器等.这些初始化工作完成后就可以跳转到C代码main函数中执行. 1.  GNU汇编语言语句格式 任何Linux汇编行都是如下结构:[<label>:][<instruction or directive or pseudo-instruction>} @comment l         instruction为指令 l         directive为伪操作 l         pseudo…
常用ARM汇编指令 [日期:2012-07-14] 来源:Linux社区  作者:xuyuanfan77 [字体:大 中 小]     在嵌入式开发中,汇编程序常常用于非常关键的地方,比如系统启动时初始化,进出中断时的环境保护,恢复等对性能有要求的地方. ARM指令集可以分为六大类,分别为数据处理指令.Load/Store指令.跳转指令.程序状态寄存器处理指令.协处理器指令和异常产生指令.ARM指令使用的基本格式如下:〈opcode〉{〈cond〉}{S}     〈Rd〉,〈Rn〉{,〈ope…
A.5.1  文件格式        ARM 源程序文件(即源文件)为文件格式,可以使用任一文本编辑器编写程序代码.         在一个项目中,至少要有一个汇编源文件或C 程序文件,可以有多个汇编源文件或多个C 程序文件,或者C 程序文件和汇编文件两者的组合.A.5.2  ARM 汇编的一些规范 (1)汇编语句格式        ARM 汇编中,所有标号必须在一行的顶格书写,其后面不要添加“:”,而所有指令均不能顶格书写.ARM 汇编器对标识符大小写敏感,书写标号及指令时字母大小写要一致,在…
ARM汇编程序特点: l         所有运算处理都是发生通用寄存器(一般是R0~R14)的之中.所有存储器空间(如C语言变量的本质就是一个存储器空间上的几个BYTE).的值的处理,都是要传送到通用寄存器来完成.因此代码中大量看到LDR,STR指令来传送值. l         ARM汇编语句中.当前语句很多时候要隐含的使用上一句的执行结果.而且上一句的执行结果,是放在CPSR寄存器里,(比如说进位,为0,为负…) CMP R0,R1 BNE NoMatch 比如上一句,BNE隐含的使用的上…
最近对iOS逆向工程很感兴趣. 目前iOS逆向的书籍有: <Hacking and Securing IOS Applications>, <iOS Hacker's Handbook>中文书籍有<iOS应用逆向工程:分析与实战> 中文博客有: 程序员念茜的<iOS安全攻防系列> 英文博客有:Prateek Gianchandani的iOS 安全系列博客 这些资料中都涉及到有ARM汇编,但都只是很泛地用到,并没有对iOS上的ARM汇编进行比较详细的讲解.因此…
一面学习,一面总结,一面记录. 以下是整理在网上找到的一些资料,简单整理记录一下,方便以后查阅. ARM处理器的指令集能够分为跳转指令.数据处理指令.程序状态寄存器(PSR)处理指令.载入/存储指令.协处理器指令和异常产生指令6大指令. 一.跳转指令 跳转指令用于实现程序流程的跳转,在ARM程序中有下面两种方法能够实现程序流程的跳转. Ⅰ.使用专门的跳转指令. Ⅱ.直接向程序计数器PC写入跳转地址值.通过向程序计数器PC写入跳转地址值,能够实如今4GB的地址空间中的随意跳转,在跳转之前结合使用M…
ARM汇编指令的一些总结ARM汇编指令很多,但是真正常用的不是很多,而且需要认真琢磨的又更少了.比较有用的是MOV B BL LDR STR还是通过具体汇编代码来学习吧.@ disable watch dog timer mov r1, #0x53000000 //立即数寻址方式mov r2, #0x0str r2, [r1] MOV 没有什么好说的,只要掌握几个寻址方式就可以了,而且ARM的寻址方式比386的简单很多.立即数寻址方式,立即数要求以“#”作前缀,对于十六进制的 数,还要求在#后面…
一.ARM介绍 1) arm汇编中,程序下一步执行哪一条指令,是根据程序计数器(PC)的值来决定. 类比于8086的CS:IP的功能. 2) 8086属于CISC(复杂指令集),每条指令长度不等,arm是RISC(精简指令集),所有指令等长(例如都为32位). 3)ARM指令代码一般分为5个区域: 第1个域是4位[31-28]的条件码域 第2个域是[27-20],除了指令编码外,还包含几个很重要的指令特征和可选后缀的编码 第3个域是地址基址,是4位[19-16],为R0-R15共16个寄存器编码…
GCC编译器支持直接在C或者C++代码中,嵌入ARM汇编代码.其基本格式非常简单,大致如下: __asm__ [__volatile__] ( assembler template : [output operand list] /* optional */ : [input operand list] /* optional */ : [clobbered register list] /* optional */ ); 首先是关键字“__asm__”,其实也可以写成“asm”.但是“asm”…
i春秋作家:v4ever 近日,在研究一些开源native层hook方案的实现方式,并据此对ARM汇编层中容易出问题的一些地方做了整理,以便后来人能有从中有所收获并应用于现实问题中.当然,文中许多介绍参考了许多零散的文章,本文重点工作在于对相关概念的整理收集,并按相对合理顺序引出后文中对hook技术中的一些难点的解读. Android平台大多采用了ARM架构的CPU,而ARM属RISC,与X86架构的处理器有不同的特征,本文讲介绍ARM中不容易理解的PC寄存器各种问题,包括ARM流水线.PC寄存…
1.LDR R1, =COUNT 意思是将 COUNT 变量的地址放到 R1中LDR R1, COUNT 意思是将 COUNT 变量地址里面的内容赋给 R1 2. Load-Store 结构——这个应该是 RISC设计中比较有特点的一部分.在 RISC 中,CPU 并不会对内存中的数据进行操作, 所有的计算都要求在寄存器中完成. 而寄存器和内存的通信则由单独的指令来完成.而在 CSIC中,CPU是可以直接对内存进行操作的,这也是一个比较特别的地方.所以,在 ARM中,cpu只能通过寄存器来对内存…
. GNU汇编程序中的常数 <>十进制数以非0数字开头,如:123和9876: <>二进制数以0b开头,其中字母也可以为大写: <>八进制数以0开始,如:,: <>十六进制数以0x开头,如:0xabcd,0X123f: <>字符串常量需要用引号括起来,中间也可以使用转义字符,如: “You are welcome!\n”: <>当前地址以“.”表示,在GNU汇编程序中可以使用这个符号代表当前指令的地址: <>表达式:在汇编…
第一部分 Linux下ARM汇编语法尽管在Linux下使用C或C++编写程序很方便,但汇编源程序用于系统最基本的初始化,如初始化堆栈指针.设置页表.操作 ARM的协处理器等.初始化完成后就可以跳转到C代码执行.需要注意的是,GNU的汇编器遵循AT&T的汇编语法,可以从GNU的站点(www.gnu.org)上下载有关规范. 一. Linux汇编行结构 任何汇编行都是如下结构: [:] [} @ comment [:] [} @ 注释 Linux ARM 汇编中,任何以冒号结尾的标识符都被认为是一个…
ARM  RISC  (Reduced Instruction Set Computers) X86   CISC  (Complex Instruction Set Computers)      ARMv3--ARMv7支持32位, ARMv8-A 开始支持64位 32bit ARM汇编有16个32位寄存器: - r0-r3 主要用来传递函数调用第1到第4个参数(a0-a3),更多的参数须通过栈来传递. - r0-r1 也作为结果寄存器,保存函数返回结果:被调用的子程序在返回前无须恢复这些寄…
要学习一个东西首先要把概念搞清楚,以下仅仅是自己的一些关于汇编的理解. 可运行文件里的01码是机器码,机器码不等于汇编码,尽管机器码能够非常easy翻译成汇编码. 汇编码中包括非常多汇编指令.伪指令和宏指令等.这些是不能够直接在机器上执行的. 机器指令是ARM指令集和Thumb指令集这些arm硬件支持的指令集组成的. 汇编码中的伪指令和宏指令这些都是汇编语言这个级别的指令,在汇编文件编译的时候汇编编译器as会去处理这些指令.在编译期间也会对宏进行展开,类似于gcc编译的时候对C代码中的宏展开一样…
Android系统采用java作为平台软件基础开发语言,NDK使Android平台可以运行C/C++代码这些代码汇编成ARM的elf可执行文件. 原生程序生成过程 经历4步:1.预处理2.编译3.汇编4.链接 经过第2步编译后C代码变成ARM汇编代码,NDK支持直接使用ARM汇编编写的 .s文件 ARM使用寄存器保存值或内存地址,共有37个寄存器,31个为通用寄存器,6个为状态寄存器.ARM有7种运行模式: 1.用户模式(usr):ARM正常运行状态 2.快速中断模式(fiq):用于高速数据传输…
9.1 ARM 汇编与 C 的混合编程 9.1.1 内嵌汇编 __asm __asm("指令")例如关闭/打开总中断开关 CPSR __asm //使用 C 中变量名代替寄存器 { MOV var,x ADD y,var,x/y } 内联汇编语言中的寄存器名被编译器视为 C 或 C++语言中的变量,所以内联汇编中出现的寄存器名不一定和同名的物理寄存器相对应.这些寄存器名在使用前必须声明, 否则编译器将提示警告信息 9.1.2 汇编访问 C 中的全局变量 [1]用 IMPORT 声明全局…
ARM汇编(非虫笔记) 1.ARM汇编的目的: 分析elf文件的需要. 2.原生程序生成过程. (1)预处理,编译器处理c代码中的预处理指令. gcc -E hello.c -o hello.i (2)编译 gcc编译器首先要检查代码的规范性,以及是否有语法错误,在检查无误之后,gcc编译把代码翻译成ARM汇编语言的代码. gcc -S hello.i -o hello.s (3)汇编,gcc编译器会挑用汇编器将汇编代码汇编成二进制目标文件. gcc -c hello.s -o hello.o…
原文地址:http://zqwt.012.blog.163.com/blog/static/120446842010111482417545/ 6.GNU汇编程序中的常数 <1>    十进制数以非0数字开头,如:123和9876: <2>    二进制数以0b开头,其中字母也可以为大写: <3>    八进制数以0开始,如:0456,0123: <4>    十六进制数以0x开头,如:0xabcd,0X123f: <5>    字符串常量需要用…