当前位置: 首页 > article >正文

ARM V8 A32常用指令集

文章目录

  • 1. 算术指令
    • 1.1 加法命令ADD\ADDS
    • 1.2 带进位加法命令ADC\ADCS
    • 1.3减法命令SUB\SUBC
    • 1.4带借位减法命令SBC\SBCS
  • 2.逻辑运算指令
    • 2.1逻辑与指令AND、ANDS
    • 2.2位清零指令BIC
    • 2.3逻辑或指令ORR\ORRS
    • 2.4逻辑异或指令
    • 2.5 逻辑左移LSL
    • 2.6逻辑右移LSR
  • 3.比较指令
    • 3.1直接比较指令CMP
    • 3.2负数比较指令CMN
  • 4.移动指令
    • 4.1MOV指令
    • 4.2MVN指令
  • 5.跳转指令
    • 5.1 B指令
    • 5.2 BL指令
    • 5.3 BX指令
    • 5.4 BLX指令
  • 6. 加载/存储指令
    • 6.1 LDR\LDRB\LDRH指令
    • 6.2 STR\STRB\STRH指令
  • 7. 批量数据加载/存储指令指令

记录ARM V8 A32常用指令集。

调试时常用的汇编命令:ADD\SUB\MOV\LDR\STR\BL\CMP等命令

具体可以参考官方文档:DUI0801C_armasm_user_guide

1. 算术指令

1.1 加法命令ADD\ADDS

在这里插入图片描述

1.2 带进位加法命令ADC\ADCS

在这里插入图片描述

1.3减法命令SUB\SUBC

在这里插入图片描述

1.4带借位减法命令SBC\SBCS

在这里插入图片描述

2.逻辑运算指令

2.1逻辑与指令AND、ANDS

在这里插入图片描述

2.2位清零指令BIC

在这里插入图片描述

2.3逻辑或指令ORR\ORRS

在这里插入图片描述

2.4逻辑异或指令

在这里插入图片描述

2.5 逻辑左移LSL

移位进来值补0
![在这里插入图片描述](https://i-blog.csdnimg.cn/direct/98d41fef2fb64cf09a74bef9b32b3e80.pn

2.6逻辑右移LSR

在这里插入图片描述

3.比较指令

3.1直接比较指令CMP

在这里插入图片描述

3.2负数比较指令CMN

在这里插入图片描述

4.移动指令

4.1MOV指令

在这里插入图片描述

4.2MVN指令

在这里插入图片描述

5.跳转指令

跳转指令用于实现程序流程的跳转,在ARM程序中有两种方法可以实现程序流程的跳转:
使用专门的跳转指令。
直接向程序计数器PC写入跳转地址值。
通过向程序计数器PC写入跳转地址值,可以实现在4GB的地址空间中的任意跳转,在跳转之前结合使用MOV LR,PC等类似指令,可以保存将来的返回地址值,从而实现在4GB连续的线性地址空间的子程序调用。
ARM指令集中的跳转指令可以完成从当前指令向前或向后的32MB的地址空间的跳转,包括以下4条指令:
B 跳转指令
BL 带返回的跳转指令
BLX 带返回和状态切换的跳转指令
BX 带状态切换的跳转指令

5.1 B指令

在这里插入图片描述

5.2 BL指令

在这里插入图片描述

5.3 BX指令

在这里插入图片描述

5.4 BLX指令

在这里插入图片描述

6. 加载/存储指令

6.1 LDR\LDRB\LDRH指令

在这里插入图片描述
备注:LDR R,label 和 LDR R,=label的区别
LDR 是ARM中的指令,也是伪指令。
当用 LDR r, =imd // r 为寄存器, imd为立即数
LDR 是一条伪指令。编译器会根据 立即数的大小,决定用 ldr 指令或者是mov或mvn指令。
当imd能用mov或者mvn操作时,就将它翻译成一条mov或mvn指令。当imd大于mov或mvn能够操作的数时,编译器会将imd存在一个内存单元中,然后再用一条ldr指令加载这个内存单元的的值到寄存器中。
LDR r, label 和 LDR r, =label的区别:
LDR r, =label 会把label表示的值加载到寄存器中,而LDR r, label会把label当做地址,把label指向的地址中的值加载到寄存器中。
例如label的值是 0x8000, LDR r, =label会将 0x8000加载到寄存器中,而LDR r, label则会将内存0x8000处的值加载到寄存器中。

6.2 STR\STRB\STRH指令

在这里插入图片描述

7. 批量数据加载/存储指令指令

LDM 批量数据加载指令
STM 批量数据存储指令
在这里插入图片描述


http://www.kler.cn/news/328687.html

相关文章:

  • 华为OD机试真题---找终点
  • excel 处理数据的常用场景之考勤表的制作
  • 递归函数设计技巧
  • 一次实践:给自己的手机摄像头进行相机标定
  • 【小沐学GIS】基于ubuntu+three.js的OSM建筑模型显示(node.js、Python)
  • 【论文阅读】基于真实数据感知的模型功能窃取攻击
  • 区块链可投会议CCF C--FC 2025 截止10.8 附录用率
  • 滚雪球学MySQL[1.2讲]:安装与配置
  • Qt界面编程01
  • python-patterns:Python 设计模式大全
  • 个人项目简单https服务配置
  • STL之list篇(上)初识list容器,了解其核心机制,实例化对象进行分析
  • Angular 2 用户输入
  • 安全的价值:构建现代企业的基础
  • k8s篇之数据挂载类型及区别
  • Python编码系列—Python命令模式:将请求封装为对象
  • 数据分析师之Excel学习
  • CI/CD详细流程
  • 传输层协议 --- UDP
  • C++ 线程
  • Linux 应用层自定义协议与序列化
  • 【Java数据结构】 ArrayList 顺序表
  • Android-Handle消息传递和线程通信
  • LeetCode 面试经典150题 66.加一
  • 【数据类型】C和C++的区别
  • 【C#生态园】探索地理信息系统软件套件与库:功能、API和应用
  • CSS | CSS中强大的margin负边距
  • 深度学习中的卷积神经网络
  • Ubuntu安装Docker和Docker Compose
  • 高性价比PCB分板机高速主轴SycoTec 4025 HY