【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 架构提供的条件执行特性,以实现更紧凑和高效的代码。

相关推荐
lingggggaaaa1 天前
小迪安全v2023学习笔记(一百四十五讲)—— Webshell篇&魔改冰蝎&打乱特征指纹&新增加密协议&过后门查杀&过流量识别
笔记·学习·安全·魔改冰蝎·免杀对抗·免杀技术
落羽的落羽1 天前
【C++】现代C++的新特性constexpr,及其在C++14、C++17、C++20中的进化
linux·c++·人工智能·学习·机器学习·c++20·c++40周年
小苏兮1 天前
【把Linux“聊”明白】编译器gcc/g++与调试器gdb/cgdb:从编译原理到高效调试
java·linux·运维·学习·1024程序员节
im_AMBER1 天前
React 11 登录页项目框架搭建
前端·学习·react.js·前端框架
py有趣1 天前
LeetCode算法学习之两数之和 II - 输入有序数组
学习·算法·leetcode
BreezeJuvenile1 天前
外设模块学习(15)——MQ-2烟雾气体传感器(STM32)
stm32·单片机·学习·mq-2·烟雾气体传感器
XH1.1 天前
学习RT-thread(RT-thread定时器)
stm32·单片机·学习
2301_796512521 天前
Rust编程学习 - 为什么说Cow 代表的是Copy-On-Write, 即“写时复制技术”,它是一种高效的 资源管理手段
java·学习·rust
故里21301 天前
学习前端记录(二)21-40
学习
ThreeYear_s1 天前
电力电子技术学习路径与FPGA/DSP技术结合方向(gemini生成)
学习·fpga开发