ARM中的汇编指令
Arm指令,32位的指令集,一共有16条的基本指令,每条指令都可以按条件执行,
指令都是32bit的,高四位是条件码[31:28],

Thumb指令,16位的指令集,执行效率比arm指令集要低,但是节省了系统的存储空间,兼容了16位的数据总线宽度的应用体系。
thumb指令,相比较与arm代码,储存器的功耗也较低。
thumb指令,基本都是无条件的,一共有18条基本指令,全部指令都是16bit。
Thumb-2指令,由16bit、32bit的指令混合组成,一共有16条基本指令,
BIC:ARM指令,对某些位,清零。先取反再相与。
asm("BIC r2, r2, #0x1f"); ##对R2的低5位清零。
ORR:ARM指令,逻辑或
asm("ORR r2, r2, #0x10"); ##R2逻辑与0x10。
MRS:asm("MRS r2, CPSR"); ##将CPSR的值加载到R2中。
MSR:asm("MSR CPSR, r2"); ##将R2的值加载到CPSR中。
asm(" SWI 0x0"); ##跳转到软件中断函数,并转换为SVC模式。
LDR:{条件}目的寄存器 存储器寄存器。将存储地址所指的4个字节数据传送到寄存器,其中寻址方式会有很多种。
asm("ldr r0,=0xddeeaabb"); ##在这里ldr是一个伪指令,相当于move指令。
asm("ldr r0, [r1]"); ##将存储器地址为r1的一个字的数据加载到r0中。
MRC与MCR:在处理器寄存器与协处理器寄存器之间交换数据。
MRC {cond} coproc, opcode1, Rd, CRn, CRm {,opcode2}
asm("mrc p15,0,r0,c1,c1,0"); ##在CRn, CRm均为c1, opcode均为0时,表示SCR
(Secure Configuration Register),表示将c1的值赋值给r0.
asm("mcr p15,0,r0,c1,c1,0"); ##将r0的值赋值给c1.
asm("mcr p15,0,r0,c12,c0,0"); ##将r0的值赋值给c12,此时c12表示VBAR,
Vector Base Address Register,存放异常时的入口地址。
SMC:(Secure Monitor Call). asm(" SMC 0x0"); ##将ARM core切换到Trust Zone模式。
asm("mov r2, r2, lsr, #4"); ##r2左移4位后,加载到r2中。
asm("str r3, [sp, #-4]"); ##将r3中的数据加载到堆栈中,堆栈顶指针向前移4.
asm("ldmia r0!, {r3-r10}"); ##ldmia多寄存器加载指令,将r0地址中的数据加载到r3中,且每次r0增加4.
!表示,最终r0的值会改变。
asm("SVC 0x0"); ##arm core转为Supervisor模式。
asm(),告知编译器,该语句是汇编语句。
lea,load effective address,取有效的偏移地址;
gnu汇编中的一些符号:
@ 用来表示注释,可以在行首,也可以在代码之后,类似于//
# 做注释,一般放在行首
:以冒号结尾的,表示标号
. 点号在gnu汇编中表示当前指令的地址
# 立即数前要加#或者$,表示这个是个立即数
常用的gnu伪指令
.global _start @给_start外部链接属性。
.section .text @指定当前段是代码段。
.ascii,.byte,.short,.long,.word,.quad,.float,.string @表示当前数据的大小,定义数据
.align 4 @以16自己对齐
.balignl 16 0xabcdefgh @以16字节对齐填充
.end @表示文件结束
.include @头文件包含
.arm、.code32 @声明以下为arm指令
.thumb、.code16 @声明以下为thumb指令。
nop 空操作。
ldr 大范围的地址加载指令,与程序链接时给定的地址有关,
adr 小范围的地址加载指令,总是以PC的值作为基准来表示地址。
arm中异常向量表的初始化,放在汇编中。
.global _start
_start:
b reset; //复位为0x0000_0000
ldr pc, _undefined_instruction; //这时pc为0x0000_0004,其中的值变为label _undefined_instruction的值;
ldr pc, _software_interrupt;
ldr pc, _prefetch_abort;
ldr pc, _data_abort;
ldr pc, _not_used;
ldr pc, _irq;
ldr pc, _fiq;
中断向量表的入口程序地址,通过.word来拿到;
_undefined_instruction: .word undefined_instruction;
_software_interrupt: .word software_interrupt;
.word将这个_undefined_instruction的值,定为undefined_instruction的值;
undefined_instruction: //程序链接的时候,确定值
get_bad_stack
bad_save_user_flags
bI do_undefined_instruction //只是定义一个跳转函数
.align 5
ARM中的汇编指令的更多相关文章
- [zhuan]arm中的汇编指令
http://blog.csdn.net/qqliyunpeng/article/details/45116615 一. 带点的(一般都是ARM GNU伪汇编指令) 1. ".text& ...
- ARM中的---汇编指令
一. 带点的(一般都是ARM GNU伪汇编指令) 1. ".text".".data".".bss" 依次表示的是"以下是代码段& ...
- C表达式中的汇编指令
C 表达式中的汇编指令 asm 为 gcc 中的关键字,asm 表达式为在 C代码中嵌套汇编指令,该表达式只是单纯的替换出汇编代码,并不对汇编代码的含义进行解析. asm 表达式有两种形式,第二种 a ...
- C 表达式中的汇编指令
asm 为 gcc 中的关键字,asm 表达式为在 C代码中嵌套汇编指令,该表达式只是单纯的替换出汇编代码,并不对汇编代码的含义进行解析. asm 表达式有两种形式,第二种 asm-qualifier ...
- ARM体系结构和汇编指令
第一节 可编程器件的编程原理 1. 可编程器件的特点 1 . CPU在固定频率的时钟控制下节奏运行 2 . CPU可以通过总线读取外部存储设备中的二进制指令集,然后解码执行 3 . 这些可以被CPU解 ...
- C/C++中书写汇编指令
汇编语言的指令格式目前有两种不同的标准:Windows下的汇编语言基本上都遵循Intel风格的语法,比如:MASM.NASM,Unix/Linux下的汇编语言基本上都遵循AT&T风格的语法. ...
- arm中的ldr指令
label .equ 0x53000000 ldr r0, label : 将0x53000000地址处的值放入r0中 ldr r0, =label : 将0x53000000付值给r0.
- ARM中C和汇编混合编程及示例(转)
在嵌入式系统开发中,目前使用的主要编程语言是C和汇编,C++已经有相应的编译器,但是现在使用还是比较少的.在稍大规模的嵌入式软件中,例如含有OS,大部分的代码都是用C编写的,主要是因为C语言的结构比较 ...
- 常用ARM汇编指令
常用ARM汇编指令 [日期:2012-07-14] 来源:Linux社区 作者:xuyuanfan77 [字体:大 中 小] 在嵌入式开发中,汇编程序常常用于非常关键的地方,比如系统启动时初 ...
随机推荐
- 学习生活必须知道的网站或者App
转载自:https://www.douban.com/group/topic/89798480/ 学习方面: 1.网易公开课(http://v.163.com/special/test/alltest ...
- 【读书笔记】socket描述符选项[SOL_SOCKET]
#include <sys/socket.h> int setsockopt( int socket, int level, int option_name, ...
- 关于sizeof和strlen
已知 char *str1="absde"; char str2[]="absde"; char str3[8]={'a',}; char ss[] = &qu ...
- UEditor富文本WEB编辑器自定义默认值设置方法
1.在使用UEditor编辑器编写内容时你会发现,当输入的内容较多时,编辑框的边框高度也会自动增加,若希望输入内容较多时以拉框滚动的效果. 方法:找到Ueditor文件根目录下的ueditor.con ...
- 天梯赛 大区赛 L3-014.周游世界 (Dijkstra)
L3-014. 周游世界 时间限制 200 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 陈越 周游世界是件浪漫事,但规划旅行路线就不一定了-- 全世 ...
- ububtu下安装配置搜狗输入法
安装搜狗输入法 for linux参考教程: http://blog.csdn.net/u013894834/article/details/60357071 安装后会遇到无法切换英文的问题,可以参考 ...
- 3322.org
3322.org — Krebs on Security https://krebsonsecurity.com/tag/3322-org/
- Bitwise and Bit Shift Operators 位运算 取反 补码
Bitwise and Bit Shift Operators (The Java™ Tutorials > Learning the Java Language > Language B ...
- 多线程情况下HashMap死循环的问题
1.多线程put操作后,get操作导致死循环. 2.多线程put非null元素后,get操作得到null值. 3.多线程put操作,导致元素丢失. 死循环场景重现 下面我用一段简单的DEMO模拟Has ...
- Spring MVC静态资源处理:<mvc:resources />
优雅REST风格的资源URL不希望带 .html 或 .do 等后缀.由于早期的Spring MVC不能很好地处理静态资源,所以在web.xml中配置DispatcherServlet的请求映射,往往 ...