ARM 与 Thumb 寄存器对应关系

  • PC寄存器: ARM状态为R15,Thumb状态为PC
  • LR寄存器: ARM状态为R14,Thumb状态为LR
  • SP寄存器: ARM状态为R13,Thumb状态为SP
  • IP寄存器: ARM状态为R12,Thumb状态为IP
  • FP寄存器: ARM状态为R11,Thumb状态为FP

其他对应关系一一相同

ARM 与 Thumb 指令集

指令格式:

{}{S}{.W|.N} ,{,}

其中

  • opcode为助记符
  • cond为条件
  • S指定其是否影响CPSR寄存器的值(也就是程序状态字)
  • .W与.N指定指令宽带。(一个指定32,一个指定16)
  • Rd 目的寄存器
  • Rn 第一个操作数寄存器
  • operand2为第二个操作数

跳转指令

B 跳转指令

格式:B{cond} label

BL带链接的跳转指令

格式:BL{cond} label

当条件满足时,会将当前指令的下一条指令保存到R14(LR)寄存器中,然后跳转到label中。这通常用于调用子程序,在子程序的尾部,通过 MOV PC,LR 返回

BX 带状态切换的跳转指令

格式:BX{cond} Rm

当执行BX指令时,如果条件cond满足,则处理器会检查Rm的为[0]是否为1,如果为1,这将CSPR寄存器的T置1,并将目标代码解释为Thumb代码来执行。为0的话,复位 CSPR寄存器的T。并将目标代码解释为ARM代码来执行。

eg:

.code 32
ADR R0,thumbcode+1
BX R0 @跳转到thmbcode,并将处理器切换为thumb模式
thumbcode:
.code 16
...

BLX带链接与状态切换的跳转指令

格式:BLX{cond} Rm

存储器访问指令

LDR

格式:

LDR{type}{cond} Rd,label

LDRD{cond} Rd,Rd2,label

type指定了操作的数据大小

用于从存储器中加载数据到寄存器。

LDRD 一次加载双字的数据,将数据加载到Rd,Rd2中

STR

格式:

STR{type}{cond} Rd,label

STRD{cond} Rd,Rd2,label

用于储存数据到指定的存储单元

LDM

格式:

LDM{addr_mode}{cond} Rn{!},reglist

其中 ! 为可选,如果有,则将最终地址回写到Rn中

该指令从指定的存储单元,加载数据到寄存器列表中

eg:

LDMIA R0!,{R1-R3} @依次加载R0地址处的数据到R1,R2,R3寄存器中

STM

格式:

STM{addr_mode}{cond} Rn{!},reglist

其中 ! 为可选,如果有,则将最终地址回写到Rn中

将寄存器列表中的数据存储到指定存储单元

PUSH

POP

SWP

格式:

SWP{B}{cond} Rd,Rm,[Rn]

Rd:为要从存储器加载数据的寄存器

Rm:为写入数据到存储器的寄存器

Rn:为存储器地址

如果 Rd 与 Rm 相同,则可实现寄存器与存储器的交换

数据处理指令

ARM汇编语言基础的更多相关文章

  1. Android ARM汇编语言

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

  2. ARM汇编语言

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

  3. GNU ARM 汇编基础

    ARM GNU汇编基础 0 前言 全文补充提醒: 笔者在阅读ARM官方文档及查阅实际的u-boot源码中的汇编代码后,发现了一些不同于ARM官方文档中的汇编语法,查阅相关资料后,才发现主要由于汇编器的 ...

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

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

  5. 【基于Android的ARM汇编语言系列】之五:ARM指令集与Thumb指令集

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

  6. Intel汇编语言程序设计学习-第三章 汇编语言基础-上

    汇编语言基础 3.1  汇编语言的基本元素 有人说汇编难,有人说汇编简单,我个人不做评价,下面是一个简单的实例(部分代码): main PROC mov  eax,5  ;5送EAX寄存器 add   ...

  7. 1.ARM的基础知识

    ARM简述 ARM公司既不生产芯片也不销售芯片,它只出售芯片技术授权.ARM技术具有很高的性能和功效,因而容易被厂商接受.同时,合作伙伴的增多,可获得更多的第三方工具.制造和软件支持,这又会使整个系统 ...

  8. HLA高级汇编语言基础

    HLA高级汇编语言环境的搭建与设置 我的操作系统:WINDOWS7 需要下载的东西:MASM32:http://www.masm32.com/masmdl.htm  HLA:http://webste ...

  9. linux arm mmu基础【转】

    转自:http://blog.csdn.net/xiaojsj111/article/details/11065717 ARM MMU页表框架 先上一张arm mmu的页表结构的通用框图(以下的论述都 ...

随机推荐

  1. java基础之XML

    目录 java基础之XML 1. XML解析概述 2. DOM4J介绍 2.1 常用包 2.2 内置元素 2.2 Element类 2.3 Attribute类 2.4 常用操作 3. 代码演示 3. ...

  2. 转:drupal常用api

    drupal常用api   最短的函数 // 语言字串,除了可以获取对应语言外,还可以设置字串变量.可以是!var, @var或 %var,%var就添加元素外层.@var会过滤HTML,!var会原 ...

  3. Kotlin入门(12)类的概貌与构造

    上一篇文章提到泛型函数appendString是在类外面定义,这不免使人疑惑,类里面又该怎样定义成员函数呢?为解答这个疑问,接下来的几篇文章将好好描述一下Kotlin如何操作类及其对象,本篇文章先对类 ...

  4. mysql的高级特性-存储过程

    定义: 存储例程是存储在数据库服务器中的一组sql语句,通过在查询中调用一个指定的名称来执行这些sql语句命令. 语法: DELIMITER // 声明语句结束符,用于区分; CEATE PROCED ...

  5. flask中的url_for的使用

    有多个路由的程序需要连接不同的网页链接,例如导航条 模板中构建正确的动态url较为困难,如果重定义路由,模板中的链接失效 url_for()函数: 使用url映射中保存的信息生成url 用法: 用视图 ...

  6. 《R数据挖掘入门》彩色插图(第8章)

    图8.4 图8.5 图8.6 图8.7

  7. 简单整理关于C#和Java的区别

    相信每个程序猿都有自己最喜欢的编程语言,然而对于编程语言似乎形成一条独特的鄙视链,就如Java和C#常常两边的开发者都是相互鄙视,然后他们一起共同鄙视全世界最好的编程语言——PHP 哈哈,但是其实我想 ...

  8. iptable用法

    一:添加屏蔽IP #禁止此IP访问服务器iptables -I INPUT -s 1.2.3.4 -j DROP或iptables -A INPUT -s 1.2.3.4 -j DROP#禁止服务器访 ...

  9. 字符串通过在配置文件配置三个key来进行加密解密

    在这里和大家分享一个加密util,相对于md5加密相信大家都已经很熟悉了吧,md5是不可逆的一种加密方式,虽说不可逆但是网上已经有了破解的方法,我这边分享一个免费的破解 网址给大家:https://w ...

  10. 17秋 软件工程 团队第五次作业 Alpha 用户反馈

    用户反馈 Bug 测试对不同机型进行了测试,包括: 小米NOTE, MIUI 8.5 稳定版 [已修复]点登录按钮之后自动退出: [已修复]登录界面的背景图片没有显示. 小米4 [已修复]闪退,无法打 ...