arm64汇编学习-(3)算术与移位指令

2023-12-22 23:59

本文主要是介绍arm64汇编学习-(3)算术与移位指令,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

arm64汇编学习-(3)算术与移位指令

  • 1 数据处理指令
    • 1.1 check the C condition of adds, adc,cmp
      • 1.1.1 测试示例程序
      • 1.1.2 执行之前
      • 1.1.3 执行之后
        • 1.1.3.1 ldr和mov指令之后
        • 1.1.3.2 ads和adc指令之后
        • 1.1.3.3 cmp和adc指令之后
    • 1.2 cmp和sbc指令的综合运用
      • 1.2.1 示例代码
      • 1.2.2 compare_and_return(10, 9)测试之前
      • 1.2.3 compare_and_return(10, 9)测试之后
      • 1.2.4 compare_and_return(9, 10)测试之前
      • 1.2.5 compare_and_return(9, 10)测试之后
    • 1.3 测试ands指令对Z标志位的影响
      • 1.3.2 测试之前
      • 1.3.3 测试之后
    • 1.4 测试位段bitfield指令
      • 1.4.1 示例代码
      • 1.4.2 测试之前
      • 1.4.3 bfi x0, x1, 8, 4之后
      • 1.4.4 ubfx and sbfx之后
    • 1.5 读取寄存器的域
      • 1.5.1 示例代码

本篇博客是基于对苯叔的第三季视频的学习整理而得,大家如果想深入学习可以购买《arm64体系结构编程与实践》以及购买苯叔出品的第三季视频。

1 数据处理指令

1.1 check the C condition of adds, adc,cmp

1.1.1 测试示例程序

/*测试adds, cmp以及adc指令的条件标志位
*/
.global add_inst_test
add_inst_test:mov x0, #0ldr x1, =0xffffffffffffffffmov x2, #3/*测试adds的进位功能,当有溢出发生时,C=1*/adds x0, x1, x1adc x3, xzr, xzr/*测试cmp的条件标志位,当x1 > x2时,C=1当x1 < x2是, C=0*/cmp x1, x2adc x4, xzr, xzrret

1.1.2 执行之前

在这里插入图片描述

1.1.3 执行之后

1.1.3.1 ldr和mov指令之后

在这里插入图片描述

1.1.3.2 ads和adc指令之后

ADDS: Add (extended register), setting flags, adds a register value and a sign or zero-extended register value, followed by an optional left shift amount, and writes the result to the destination register. The argument that is extended from the register can be a byte, halfword, word, or doubleword. It updates the condition flags based on the result.

  • ADDS , <Xn|SP>, {, {#}}
  • (result, nzcv) = AddWithCarry(operand1, operand2, ‘0’);
  • PSTATE.<N,Z,C,V> = nzcv;
  • X[d] = result;
    ADC:Add with Carry adds two register values and the Carry flag value, and writes the result to the destination register.
  • (result, -) = AddWithCarry(operand1, operand2, PSTATE.C);
  • X[d] = result;
    在这里插入图片描述
1.1.3.3 cmp和adc指令之后

CMP:This instruction is an alias of the SUBS (shifted register) instruction.

  • The encodings in this description are named to match the encodings of SUBS (shifted register).
  • The description of SUBS (shifted register) gives the operational pseudocode for this instruction.
    在这里插入图片描述

1.2 cmp和sbc指令的综合运用

1.2.1 示例代码

ret = compare_and_return(10, 9);
val = compare_and_return(9, 10);/*当arg1 >= arg2 时, 返回 0当arg1 < arg2 时,返回0xffffffffffffffff
*/
.global compare_and_return
compare_and_return:cmp x0, x1sbc x0, xzr, xzrret

1.2.2 compare_and_return(10, 9)测试之前

在这里插入图片描述

1.2.3 compare_and_return(10, 9)测试之后

在这里插入图片描述

1.2.4 compare_and_return(9, 10)测试之前

在这里插入图片描述

1.2.5 compare_and_return(9, 10)测试之后

在这里插入图片描述

1.3 测试ands指令对Z标志位的影响

2.1.3.1 示例代码

/*data_process_instr lab3: 测试ands指令对Z标志位的影响
*/
.global ands_test
ands_test:mov x1, #0x3mov x2, #0//mov x2, #2ands x3, x1, x2/*读取NZCV寄存器,查看Z标志位是否为1, 见armv8.6手册第C5.2.9章*/mrs x0, nzcvret

1.3.2 测试之前

在这里插入图片描述

1.3.3 测试之后

在这里插入图片描述

1.4 测试位段bitfield指令

1.4.1 示例代码

/*data_process_instr lab4: 测试位段bitfield指令*/
.global bitfield_test
bitfield_test:/* 位段插入*/mov x1, 0x345mov x0, 0bfi x0, x1, 8, 4/*无符号数的bitfield提取,提取x2,从第4个bit开始,提取8位,x3其他位都是0,最终:0xbc*/ldr x2, =0x5678abcdubfx x3, x2, #4, #8/*有符号数的bitfield提取,提取x2,从第4个bit开始,提取8bit。x4的其他比特位都是f, 最终:0xffffffffffffffbc*/sbfx x4, x2, #4, #8ret

1.4.2 测试之前

在这里插入图片描述

1.4.3 bfi x0, x1, 8, 4之后

BFI :Bitfield Insert copies a bitfield of bits from the least significant bits of the source register to bit position of the destination register, leaving the other destination bits unchanged.
在这里插入图片描述

  • bfi x0, x1, 8, 4 该汇编指令的含义为:将x1寄存器的最低4位拷贝到x0寄存器的bit 8开始的4位上去,x0寄存器的其他位不变,所以最终x0寄存器的值被设置为0x500
    在这里插入图片描述

1.4.4 ubfx and sbfx之后

UBFX :Unsigned Bitfield Extract copies a bitfield of bits starting from bit position in the source register to the least significant bits of the destination register, and sets destination bits above the bitfield to zero.

  • UBFX , , #, #
    SBFX :Signed Bitfield Extract copies a bitfield of bits starting from bit position in the source register to the least significant bits of the destination register, and sets destination bits above the bitfield to a copy of the most significant bit of the bitfield.
  • SBFX , , #, #
    This content is only supported in a Docs.
    在这里插入图片描述
    在这里插入图片描述

1.5 读取寄存器的域

1.5.1 示例代码

/*data_process_instr lab4: 测试位段bitfield指令*/
.global bitfield_test
bitfield_test:/* 位段插入*/mov x1, 0x345mov x0, 0bfi x0, x1, 8, 4/*无符号数的bitfield提取,提取x2,从第4个bit开始,提取8位,x3其他位都是0,最终:0xbc*/ldr x2, =0x5678abcdubfx x3, x2, #4, #8/*有符号数的bitfield提取,提取x2,从第4个bit开始,提取8bit。x4的其他比特位都是f, 最终:0xffffffffffffffbc*/sbfx x4, x2, #4, #8/*lab5: 使用ubfx指令来读取 寄存器的位域*/mrs x1, ID_AA64ISAR0_EL1/*读取atomic域的值:判断是否支持LSE指令*/ubfx x0, x1, #20, #4/*读取AES域的值:判断是否支持AES指令*/ubfx x2, x1, #4, #4ret

2.5.1.2 测试之前的状态
在这里插入图片描述

2.5.1.3 测试之后的状态值
在这里插入图片描述

这篇关于arm64汇编学习-(3)算术与移位指令的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/525966

相关文章

Java进阶学习之如何开启远程调式

《Java进阶学习之如何开启远程调式》Java开发中的远程调试是一项至关重要的技能,特别是在处理生产环境的问题或者协作开发时,:本文主要介绍Java进阶学习之如何开启远程调式的相关资料,需要的朋友... 目录概述Java远程调试的开启与底层原理开启Java远程调试底层原理JVM参数总结&nbsMbKKXJx

Java深度学习库DJL实现Python的NumPy方式

《Java深度学习库DJL实现Python的NumPy方式》本文介绍了DJL库的背景和基本功能,包括NDArray的创建、数学运算、数据获取和设置等,同时,还展示了如何使用NDArray进行数据预处理... 目录1 NDArray 的背景介绍1.1 架构2 JavaDJL使用2.1 安装DJL2.2 基本操

Java汇编源码如何查看环境搭建

《Java汇编源码如何查看环境搭建》:本文主要介绍如何在IntelliJIDEA开发环境中搭建字节码和汇编环境,以便更好地进行代码调优和JVM学习,首先,介绍了如何配置IntelliJIDEA以方... 目录一、简介二、在IDEA开发环境中搭建汇编环境2.1 在IDEA中搭建字节码查看环境2.1.1 搭建步

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学