【ARM64 常见汇编指令学习 19.3 -- ARMv8 三目运算指令 csel 详细介绍】

文章目录

三目运算指令 csel

本篇文章以下面汇编代码介绍三目运算指令csel

c 复制代码
adr     x0, pass_message
                adr     x1, fail_message
                csel    x1, x0, x1, pl

下面是对这几行代码的详解:

地址获取

assembly 复制代码
adr x0, pass_message
adr x1, fail_message
  • adr x0, pass_message:该指令用于获取相对当前指令地址(PC)的偏移位置上的 pass_message 标签的地址,并将其放入寄存器 x0 中。adr 指令通常用于获取小范围内的标签或变量地址。
  • adr x1, fail_message:同样地,这条指令获取 fail_message 标签的地址,并将其放入寄存器 x1 中。

条件选择

assembly 复制代码
csel x1, x0, x1, pl
  • csel x1, x0, x1, pl:这是一个条件选择(Conditional SELect)指令。它根据最后一个参数 pl(表示 Plus 或 Positive,N flag 未设置时满足)来选择 x0x1 的值,并将所选值存入第一个参数指定的寄存器中,这里是 x1
    • 如果条件 pl 成立(即,之前的操作导致状态寄存器的 N(Negative)标志位未被设置,表示结果为正数或零),则 x1 被赋值为 x0 的值,即 pass_message 的地址。
    • 如果条件 pl 不成立(即,N 标志位被设置,表示结果为负数),x1 保持不变,即仍为 fail_message 的地址。

用途

这组指令的用途通常是在基于某个条件(通常是之前的计算结果)来决定程序的下一步行动,比如输出不同的消息。在这个场景中,根据某个条件的结果,选择 pass_messagefail_message 的地址,最终可能用于后续的打印或日志记录操作。

例如,在执行了某些操作后,程序通过检查标志位来决定是显示"通过"消息还是"失败"消息。这种模式是低级编程中常见的条件逻辑处理方式,能有效地利用 ARM 架构提供的条件执行特性,以实现更紧凑和高效的代码。

相关推荐
@小博的博客11 分钟前
C++初阶学习第十弹——深入讲解vector的迭代器失效
数据结构·c++·学习
南宫生1 小时前
贪心算法习题其四【力扣】【算法学习day.21】
学习·算法·leetcode·链表·贪心算法
懒惰才能让科技进步2 小时前
从零学习大模型(十二)-----基于梯度的重要性剪枝(Gradient-based Pruning)
人工智能·深度学习·学习·算法·chatgpt·transformer·剪枝
love_and_hope2 小时前
Pytorch学习--神经网络--搭建小实战(手撕CIFAR 10 model structure)和 Sequential 的使用
人工智能·pytorch·python·深度学习·学习
Chef_Chen2 小时前
从0开始学习机器学习--Day14--如何优化神经网络的代价函数
神经网络·学习·机器学习
芊寻(嵌入式)2 小时前
C转C++学习笔记--基础知识摘录总结
开发语言·c++·笔记·学习
hong1616883 小时前
跨模态对齐与跨领域学习
学习
阿伟来咯~3 小时前
记录学习react的一些内容
javascript·学习·react.js
Suckerbin4 小时前
Hms?: 1渗透测试
学习·安全·网络安全
水豚AI课代表4 小时前
分析报告、调研报告、工作方案等的提示词
大数据·人工智能·学习·chatgpt·aigc