【基于Android的ARM汇编语言系列】之五:ARM指令集与Thumb指令集
作者:郭嘉
邮箱:allenwells@163.com
博客:http://blog.csdn.net/allenwells
github:https://github.com/AllenWell
【基于Android的ARM汇编语言系列】章节列表
【基于Android的ARM汇编语言系列】之中的一个:ARM汇编语言开篇
【基于Android的ARM汇编语言系列】之二:C/C++程序生成ARM汇编程序的过程分析
【基于Android的ARM汇编语言系列】之三:ARM汇编语言程序结构
【基于Android的ARM汇编语言系列】之四:ARM处理器的寻址方式
【基于Android的ARM汇编语言系列】之五:ARM指令集与Thumb指令集
【基于Android的ARM汇编语言系列】之六:NEON指令集与VFP指令集
写在前面:本篇文章旨在大致介绍下ARM指令集的相关内容,这里也同一时候提供一个有详解和用例的待书签的PDF版本号,方便大家查阅。
指令集是处理器的核心。ARM指令的基本格式例如以下所看到的:
opcode {cond}{S}{.W\.N}Rd, Rn{.operand2}
- S:指定是否影响CPSR寄存器的值,如ADDS。SUBS等。
- .W.N:指令宽度说明符。
- Rd:目的寄存器。
- Rn:第一个操作数寄存器。
- operand2:第二个操作数,第二个操作数能够是马上数、寄存器或寄存器位操作。
- cond:运行条件。它的取值例如以下图所看到的:
一 跳转指令
1.1 B
跳转指令。
1.2 BL
带链接的跳转指令。
1.3 BX
带状态切换的跳转指令。
二 存储器訪问指令
2.1 LDR
从存储器中载入数据到寄存器。
2.2 STR
存储数据到指定的存储单元。
2.3 LDM
从指定的存储单元载入多个数据到一个寄存器列表。
2.4 STM
将一个寄存器列表的数据的数据存储到指定的存储单元。
2.5 PUSH
将寄存器推入满递减堆栈。
2.6 POP
从递减堆栈中弹出数据到寄存器。
2.7 SWP
用于寄存器和存储器之间的数据交换。
三 数据处理指令
3.1 MOV
将8位马上数或寄存器里的内容送到目标寄存器中。
3.2 MVN
将8位马上数或寄存器里的内容按位取反后送到目标寄存器中。
3.3 ADD
加法指令。
3.4 ADC
带进位的加法指令。
3.5 SUB
减法指令。
3.6 RSB
逆向减法指令。
3.7 SBC
带进位的减法指令。
3.8 RSC
带进位的逆向减法指令。
3.9 MUL
乘法指令。
3.10 MLS
3.11 MLA
3.12 UMULL
3.13 UMLAL
3.14 SMULL
3.15 SMLAL
3.16 SMLAD
3.17 SMLSD
3.18 SDIV
有符号数除法指令。
3.19 UDIV
无符号数除法指令。
3.20 ASR
算术右移指令。
3.21 AND
逻辑与指令。
3.22 ORR
逻辑或指令。
3.23 EOR
异或指令。
3.24 BIC
位清除指令。
3.25 LSL
逻辑左移指令。
3.26 LSR
逻辑右移指令。
3.27 ROR
循环右移指令。
3.28 RRX
带扩展的循环右移指令。
3.29 CMP
3.30 CMN
3.31 TST
位測试指令。
3.32 TEQ
四 其它指令
4.1 SWI
软中断指令。
4.2 NOP
空操作指令。
4.3 MRS
读状态寄存器指令。
4.4 MSR
写状态寄存器指令。
【基于Android的ARM汇编语言系列】之五:ARM指令集与Thumb指令集的更多相关文章
- 【基于Android的ARM汇编语言系列】之三:ARM汇编语言程序结构
作者:郭嘉 邮箱:allenwells@163.com 博客:http://blog.csdn.net/allenwells github:https://github.com/AllenWell [ ...
- ARM指令集、Thumb指令集、Thumb-2指令集
MCU使用什么指令集主要由内核决定的,比如Cortex-M3使用的是Thumb-2指令集 ARM指令集: 编代码全部是 32bits 的,每条指令能承载更多的信息,因此使用最少的指令完成功能, 所以在 ...
- 13 ARM指令集与Thumb指令集
指令格式 ARM基本格式 <opcode>{<cond>}{S}{.W|.N}<Rd>,<Rn>{,<operand2>} opecode: ...
- Android ARM汇编语言
简介 ARM是Advanced RISC Machine的首字母缩写,它可以称之为一家嵌入式处理器的提供商,也可以理解为一种处理器的架构,还可以将它作为一套完整的处理器指令集. 原生程序与ARM汇编语 ...
- ARM版本系列及家族成员梳理
ARM公司简介 ARM是Advanced RISC Machines的缩写,它是一家微处理器行业的知名企业,该企业设计了大量高性能.廉价.耗能低的RISC (精简指令集)处理器. 1985年第一个AR ...
- ARM的体系结构与编程系列博客——ARM处理器系列介绍
ARM处理器系列介绍 现在到了3月,过年过得过于舒服了.系列博客也停更了近半月,我果然是个慢(lan)性(gui)子,那么趁着到校的第一天晚上,就写一篇博客来继续我的系列博客了!众所周知,ARM处理器 ...
- ARM v8-A 系列CPU的MMU隐射分析
ARM v8-A 系列CPU的MMU隐射分析 摘要:V8-A系列CPU有ELX,X为0~3等4个异常级别,又有AArch64和AArch32两种执行状态,异常级别可以决定执行状态,而对应着执行状态,M ...
- 一点理解之 CmBacktrace: ARM Cortex-M 系列 MCU 错误追踪库
@2019-02-14 [小记] CmBacktrace: ARM Cortex-M 系列 MCU 错误追踪库,用来将单片机故障状态寄存器值翻译出来输出至终端上以便排错 CmBacktrace: AR ...
- ARM汇编语言
---恢复内容开始--- arm汇编语言 汇编语言是一种程序设计语言,arm处理器是一种16/32位的嵌入式RISC微处理器.一开始我把这混为一谈了.ARM汇编的特点:汇编语言,又叫助记符语言. 1) ...
随机推荐
- E20170906-mk
portrait n. 肖像,肖像画; 模型,标本; 半身雕塑像; 人物描写; orientation n. 方向,定位,取向,排列方向; 任职培训; (外交等的) 方针[态度]的确定; 环境判 ...
- Django day08 多表操作 (三) 基于对象的跨表查询 基于双下划线的多表查询
一: 基于对象的跨表查询 1. 一对一 正向: 反向: 2. 一对多 正向: 反向: 3.多对多 正向: 反向: 4.*****基于对象的多表查询 二: 基于双下划线的多表查询 1. 连表查询 一对一 ...
- vmware 14黑屏处理办法
从12升级到了14,但是发现所有的虚拟机都不能用了,黑屏.挂起的时候反而会显示界面,但是继续运行就是黑屏. 记录下解决办法. 修复LSP 以管理员身份运行CMD命令: netsh winsock re ...
- MyBatis动态条件、一对多、整合spring(二)
输入映射和输出映射 Mapper.xml映射文件定义了操作数据库的sql,每一个sql是一个statement,映射文件是mybatis的核心. parameterType输入类型 1.传递简单类型 ...
- Activity生命周期(待整理)
1. 定义 有一些方法共同定义生命周期,如下图示:(图片来自于官网文档) 2. onStart()——在Activity即将对用户可见之前调用 (1)Activity启动动画.二维动画在onStart ...
- 使用CMD建立指定格式的文件
一.建立空文件的几种方法1.cd.>a.txtcd.表示改变当前目录为当前目录,即等于没改变:而且此命令不会有输出.>表示把命令输出写入到文件.后面跟着a.txt,就表示写入到a.txt. ...
- AI:IPPR的模式生成-学习/训练方式(基本结构)
前言: 一个完备的模式识别系统,必然包含一个模式识别模型,此外还要附加一个评价模型,以及为了构建识别模型而构建的学习模型,并选择在学习模型中使用的学习方法. 否则 w=w 这样,)那样 ...
- Python学习①. 基础语法
Python 简介 Python 是一种解释型,面向对象的语言.特点是语法简单,可跨平台 Python 基础语法 交互式编程 交互式编程不需要创建脚本文件,是通过 Python 解释器的交互模式进来编 ...
- node mysql es6/es7改造
本文js代码采取了ES6/ES7的写法,而不是commonJs的写法.支持一波JS的新语法.node版本的mysql驱动,通过npm i mysql安装.官网地址:https://github.com ...
- Qt中采用多线程实现Socket编程
Socket通常也称作"套接字",应用程序通常通过"套接字"向网络发出请求或者应答网络请求. 本文介绍的是Qt中采用多线程Socket编程,由于工作的需要,开始 ...