ARM 汇编比较指令-条件执行指令

比较指令用来比较两个数大小,或者是否相等,比较指令的运算结果会影响CPSR寄存器的N\Z\C、V标识位,具体的标志位可以参考前面的CPSR寄存器介绍,比较指令的格式如下/

CMP {cond} Rn, operand2 比较两个数大小

CMN {cond}Rn, operand2 取负比较

比较指令的使用示例及说明如下。

CMP R1, #10

CMP R1,R2

CMP R0, #1

比较指令的运行结果Z=1时,表示运算结果为0,两个数相乘,N=1表示运算结果为负,N=0 表示运算结果为非负,即运算结果为正或者为零。

3.2.6 条件执行指令

为了提高代码密度,减少ARM指令的数量, 几乎所有的ARM指令都可以根据CPSR寄存器中的标识为,通过指令组合实现条件执行,如无条件跳转指令B,我们呢可以在后面加上条件码组成BEQ,BNE组合指令,BEQ指令表示两个数比较,结果相等时跳转;BNE指令则表示结果不想等时跳转,CPSR寄存器中的标识位根据需要可以任意搭配成不同的条件码,和ARM指令一起组合使用,ARM指令的条件码如表3-3所示。

表 3-3 ARM指令的条件码

|-------|----------|-----------|-----|----------|-----------|
| 条件码 | CPSR 标识位 | 说明 | 条件码 | CPSR标志位 | 说明 |
| EQ | Z=1 | 相等 | HI | C置位,Z清零 | 无符号数大于 |
| NE | Z=0 | 不相等 | LS | C清零,Z置位 | 有符号数小于或等于 |
| CS/HS | C=1 | 无符号数大于或等于 | GE | N=V | 有符号数大于或等于 |
| CC/LO | C=0 | 无符号数小于 | LT | N!=V | 有符号数小于 |
| MI | N置位 | 负数 | GT | Z清零,N=V | 有符号数大于 |
| PL | N清零 | 整数或零 | LE | Z置位,N!=V | 有符号数小于或等于 |
| VS | V置位 | 溢出 | AL | 忽略 | 无条件执行 |
| VC | V清零 | 未溢出 | NV | 忽略 | 从不执行 |

条件执行经常出现在跳转或循环的程序结构中。如下面的汇编程序,通过循环结构,我们可以实现数据块搬运功能,我们可以将无条件跳转指令B和条件码NE组合在一起使用。构成一个循环程序结构。

AREA COPY,CODE,READONLY

Entry

START

LDR R0, =SRC

LDR R1, =DST

MOV R2, #10

LOOP

LDR R3,[R0] #4

STR R3, [R1], #4

SUBS R2, R2, #1

BNE LOOP

AREA COPYDATA, DATA, READWRITE

SRC DCD 1,2,3,4,5,6,7,8,9,0

DST DCD 0,0,0,0,0,0,0,,0,0,0,0

END

相关推荐
CinzWS11 分钟前
DMA控制器 - 沉默的加速器:驾驭通道仲裁、传输握手与内存一致性的双刃剑
arm开发·dma·嵌入式
CinzWS42 分钟前
GIPC(处理器间通信) - 多核的桥梁:剖析硬件队列、门铃中断与共享内存的数据一致性困局
arm开发·嵌入式·gipc
szxinmai主板定制专家1 天前
基于RK3588超小体积,轻巧,长续航的无人机AI模块,支持视频跟踪
arm开发·人工智能·嵌入式硬件·fpga开发·无人机
AI服务老曹1 天前
【架构深度解析】从异构计算到微服务:构建支持 X86/ARM 与 GPU/NPU 协同的 GB28181 视频 AI 平台
arm开发·微服务·架构
ai产品老杨1 天前
【架构解析】高并发 AI 视频流管理平台:实现 X86/ARM 异构部署与 GB28181 全链路源码交付
arm开发·人工智能·架构
进击的小头2 天前
第18篇:嵌入式电机控制专用外设:正交编码脉冲模块原理与闭环控制应用
arm开发·单片机·嵌入式硬件
ai产品老杨2 天前
【架构深析】打破硬件壁垒:支持 X86/ARM 异构计算与源码交付的 GB28181 视频 AI 平台设计实践
arm开发·架构·音视频
AI服务老曹2 天前
深度架构解析:如何构建兼容 X86/ARM 及异构计算(GPU/NPU)的级联级 AI 视频管理平台
arm开发·人工智能·架构
ai产品老杨2 天前
架构深度解析:支持X86/ARM与GPU/NPU异构部署的AI视频管理平台实践(附源码交付与GB28181方案)
arm开发·人工智能·架构
iCxhust2 天前
8088汇编测试程序 (MASM/TASM) — 显示 “HELLO 8088!“ + “LCD1602 OK“
汇编·单片机·嵌入式硬件·51单片机·微机原理