通俗易懂:ARM指令的寻址方式(三)

一、为什么所有的ARM指令都是条件执行?

ARM处理器在拿到一条指令的时候,它首先要看条件码给出的条件和CPSR条件码标志位里现存的这个状况匹配不匹配,如果匹配,条件符合,它才执行。如果不匹配,这行ARM指令它就不执行。

二、对于立即数0xF132,能不能把它放在ARM当中?

不能。在ARM指令机器编码基本格式中,操作数2为立即数,且只占12位。

注:操作数2包括寄存器里的数据在ARM的CPU的算数逻辑单元和其他处理系统乘法器。这些东西在计算的过程当中,数据都要转换成32位数据。

三、12位数据转换成32位数据

12位编码包括8位常数和4位循环右移值,由8位常数循环右移4位值的2倍,得到最后的32位立即数。

例:

复制代码
MOV R0,#0x0000F200     ;R0<------#0x0000F200

机器代码:E3A00CF2


//MOV : [1]、[2];R0 : E ;

解析:13A:指令码------MOV是指令助记符,3A是MOV的机器编码

2E:1110------指令助记符:AL。无条件执行,相当于MOV AL。

300:原指令中只有目的寄存器,没有操作数1寄存器

4C:4位循环右移值位C(十进制为120

50xF2:8位常数

##3A如何译为"搬移",CPU(硬件)里有存有相应的译码机制,来完成·相应的译码和执行。

##12位数据转换位32位数据方法如图:

注:移位操作:以4位二进制数为1组,只需让这组循环右移6次(4*6=24)。

四、ARM指令的指令机器编码格式和指令一般格式(程序员书写格式)

1、ARM指令机器编码格式

注:目的寄存器和操作数1寄存器必须是寄存器(16位寄存器)。操作数2可以是:立即数或寄存器

2、指令一般格式(程序员书写格式)

相关推荐
鹏大师运维7 小时前
为什么信创电脑装软件总提示“软件包架构不匹配”?
linux·运维·架构·国产化·麒麟·deb·统信uos
007张三丰7 小时前
软件测试专栏(11/20):测试框架开发:pytest深度解析与插件体系
运维·服务器·自动化测试·pytest·测试框架
weixin_604236678 小时前
华三 路由器 极简核心配置
运维·服务器·网络·h3c·h3c路由器
鹤落晴春9 小时前
【Linux复习】管理SELinux安全性
linux·运维·服务器
AI智图坊9 小时前
多件装组合SKU图的批量生产效率分析:从PS手工到AI自动化的工作流改造
大数据·运维·人工智能·gpt·ai作画·自动化·aigc
想要成为糕糕手13 小时前
前端必修课:JavaScript 数组与数据结构底层逻辑全解析
javascript·数据结构·面试
云计算磊哥@14 小时前
运维开发宝典026-MySQL02数据库表操作
运维·数据库·运维开发
天天进步201514 小时前
Tunnelto 源码解析 #9:控制服务器设计:Warp、WebSocket、Ping/Pong 与连接保活
运维·服务器·websocket
极客先躯15 小时前
高级java每日一道面试题-2026年02月01日-实战篇[Docker]-Docker Volume 的生命周期管理是怎样的?
java·运维·docker·容器·持久化·架构图·容器卷
tyung15 小时前
Go 手写 Wait-Free SPSC 无界队列:无 CAS、无锁、泛型节点池
数据结构·后端·go