作者:郭嘉

邮箱: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指令集详解

指令集是处理器的核心。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指令集的更多相关文章

  1. 【基于Android的ARM汇编语言系列】之三:ARM汇编语言程序结构

    作者:郭嘉 邮箱:allenwells@163.com 博客:http://blog.csdn.net/allenwells github:https://github.com/AllenWell [ ...

  2. ARM指令集、Thumb指令集、Thumb-2指令集

    MCU使用什么指令集主要由内核决定的,比如Cortex-M3使用的是Thumb-2指令集 ARM指令集: 编代码全部是 32bits 的,每条指令能承载更多的信息,因此使用最少的指令完成功能, 所以在 ...

  3. 13 ARM指令集与Thumb指令集

    指令格式 ARM基本格式 <opcode>{<cond>}{S}{.W|.N}<Rd>,<Rn>{,<operand2>} opecode: ...

  4. Android ARM汇编语言

    简介 ARM是Advanced RISC Machine的首字母缩写,它可以称之为一家嵌入式处理器的提供商,也可以理解为一种处理器的架构,还可以将它作为一套完整的处理器指令集. 原生程序与ARM汇编语 ...

  5. ARM版本系列及家族成员梳理

    ARM公司简介 ARM是Advanced RISC Machines的缩写,它是一家微处理器行业的知名企业,该企业设计了大量高性能.廉价.耗能低的RISC (精简指令集)处理器. 1985年第一个AR ...

  6. ARM的体系结构与编程系列博客——ARM处理器系列介绍

    ARM处理器系列介绍 现在到了3月,过年过得过于舒服了.系列博客也停更了近半月,我果然是个慢(lan)性(gui)子,那么趁着到校的第一天晚上,就写一篇博客来继续我的系列博客了!众所周知,ARM处理器 ...

  7. ARM v8-A 系列CPU的MMU隐射分析

    ARM v8-A 系列CPU的MMU隐射分析 摘要:V8-A系列CPU有ELX,X为0~3等4个异常级别,又有AArch64和AArch32两种执行状态,异常级别可以决定执行状态,而对应着执行状态,M ...

  8. 一点理解之 CmBacktrace: ARM Cortex-M 系列 MCU 错误追踪库

    @2019-02-14 [小记] CmBacktrace: ARM Cortex-M 系列 MCU 错误追踪库,用来将单片机故障状态寄存器值翻译出来输出至终端上以便排错 CmBacktrace: AR ...

  9. ARM汇编语言

    ---恢复内容开始--- arm汇编语言 汇编语言是一种程序设计语言,arm处理器是一种16/32位的嵌入式RISC微处理器.一开始我把这混为一谈了.ARM汇编的特点:汇编语言,又叫助记符语言. 1) ...

随机推荐

  1. bzoj3957

    数学+模拟 细节很多 首先我们发现,如果两个区间已经包含,那么可以输出empty,一个数能通过变换得到另一个区间的数,这个区间的大小必须小于等于终点区间的大小.加法不会改变区间大小,只有乘法会改变,而 ...

  2. LBS(定位)的使用

    一.LBS(定位)的使用 1.使用框架Core Location 2.CLLocationManager (1)CoreLocation中使用CLLocationManager对象来做用户定位 (2) ...

  3. 98.Ext.form.Label组件的基本用法

    转自:https://www.cnblogs.com/kelly/archive/2009/06/05/1496897.html 本篇介绍Ext.form.Label组件的基本用法: 这里通过上一篇介 ...

  4. java 格式化日期

      SimpleDateFormat simpleDateFormat=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); simpleDat ...

  5. BKDRHash 算法 php 版本( 可用于 字符串 hash 为int 转)

    <?php function BKDRHash($str) { $seed = 131; // 31 131 1313 13131 131313 etc.. $hash = 0; $cnt = ...

  6. 混个脸熟 -- go

    一.第一个项目:hello world src/day1/example1/main.go package main import "fmt" func main(){ fmt.P ...

  7. JS排序之快速排序

    JS排序之快速排序 一个数组中的数据,选择索引为(2/数组长度)的那个数据作为基数,数组中的其他数据与它对比,比它数值小的放在做数组,比它数值大的放在右数组,最后组合 左数组+基数+右数组,其中,左数 ...

  8. less 安装和webstorm的使用

    1.less 的安装 npm install -g less 2.less安装成功 3.less安装成功后,在webstorm中进行配置.file——>settings:弹出settings框, ...

  9. jQuery中容易让人困惑的东西

    前言:jqueryt很灵活,太灵活了,可以说是他一个优点,也是他一个缺点,达到一种效果,十个人也许会用十种不同的方法来实现这个过程,结果一样,过程不一样,这到底是好,还是坏呢. 一,什么是jquery ...

  10. Java Web_过滤器

    过滤器分类: Servlet2.5: request:用户直接访问页面时,Web容器将会调用过滤器. forward:目标资源是通过RequestDispatcher的forward访问时,该过滤器将 ...