【基于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) ...
随机推荐
- Django day15 (一) cbv装饰器 , 中间件
一: 装饰器 二: 中间件
- Python 45 css三种引入方式以及优先级
一:css三种引入方式 三种方式为:行间式 | 内联式 | 外联式 行间式 1.在标签头部的style属性内 2.属性值满足的是css语法 3.属性值用key:value形式赋值,value具 ...
- Cracking the Coding Interview 8.7
Given a infinite number of quarters(25cents), dimens(10cents), nickels(5cents) and pennies(1cent), w ...
- C#之实体类
一.为什么要用实体类? | 使程序简洁易懂,便于维护. | 暗合接口不变原则. | 体现面向对象思想. 举例说明: 不用实体类的三层 假如程序有所变动,需要增加一个参数,学生年龄 ...
- scrollWidth clientWidth offsetWidth
scrollWidth:对象的实际内容的宽度,不包边线宽度,会随对象中内容超过可视区后而变大. 实际内容+padding 不包括滚动条 边框client ...
- Android点击跳转到淘宝的某一商品详情页或者某一店铺页面
最近项目的有个需求是点击购买资料按钮进入淘宝界面,简单分析一下,如果用户手机有淘宝就打开淘宝的页面,没有的话也可以选择使用webView进行展示,还是使用手机浏览器进行展示. 判断有无淘宝的代码就不贴 ...
- Qt无法用UTF-8编辑问题
原因: Windows默认编码格式是GBK. 而QT-各默认版本的编码格式是UTF-8. 解决方法": Windows环境下,Qt Creator,菜单->工具->选项-> ...
- 小功能__tab实录
作为一个没有js基础的人来说,写一个小功能确实麻烦,也很累,从一个demo中发现details标签完美的实现菜单折叠功能,而不用费劲写好多li.div.js.发现html也是好厉害的.看来以后回家要多 ...
- GET 请求控制器 返回绑定后HTML
//$.get("/Home/index/" + $("#S_BookName").val(), function (data) { //MVC控制器返回Vie ...
- CorelDRAW图片导出变色,如何解决?
很多小伙伴反映说CDR颜色导出不准确,特别是CorelDRAW X4以及之前的版本,那么CDR导出变色的问题是怎么导致的,如何解决呢,本文小编分享一些自己的心得. 一:出现问题. 比如下面这个问题,明 ...