arm64汇编学习-(2)算术与移位指令
创始人
2025-06-01 05:28:00
0

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

  • 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 , , {, {#}}
  • (result, nzcv) = AddWithCarry(operand1, operand2, ‘0’);
  • PSTATE. = 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 测试之后的状态值
在这里插入图片描述

相关内容

热门资讯

迷你退出安卓系统了吗,转型新篇... 最近有没有发现你的手机上那个可爱的迷你退出图标突然不见了?别急,让我来给你揭秘迷你退出安卓系统了吗的...
华为优先使用安卓系统,打造自主... 你知道吗?最近科技圈里有个大动作,那就是华为宣布优先使用安卓系统。这可不是一个简单的决定,它背后可是...
安卓系统隐藏了设置,隐藏设置功... 你知道吗?安卓系统这个大宝藏里,竟然隐藏着一些不为人知的设置!是不是听起来就有点小激动呢?别急,今天...
反渣恋爱系统安卓,收获真爱 你有没有听说过那个神奇的“反渣恋爱系统安卓”呢?最近,这款应用在网络上可是火得一塌糊涂,不少单身狗都...
安卓出厂系统能升级,探索无限可... 你知道吗?现在这个时代,手机更新换代的速度简直就像坐上了火箭!而说到手机,安卓系统可是占据了半壁江山...
老安卓刷机系统,从入门到精通 你有没有想过,你的老安卓手机其实还有大大的潜力呢?没错,就是那个陪伴你多年的老安卓,它可不是只能用来...
安卓粉ios系统app,兼容性... 你有没有发现,身边的朋友圈里,安卓粉和iOS系统粉总是争论不休?今天,咱们就来聊聊这个话题,看看安卓...
安卓系统语言下载,探索安卓系统... 你有没有想过,你的安卓手机是不是该换换口味了?没错,就是语言!想象如果你能轻松切换到自己喜欢的语言,...
安卓共有多少种系统,究竟有多少... 你有没有想过,安卓这个我们每天不离手的操作系统,竟然有那么多不同的版本呢?没错,安卓系统就像一个大家...
安卓系统怎么播放swf,And... 你有没有遇到过这种情况:手里拿着一部安卓手机,想看一个SWF格式的动画,结果发现怎么也打不开?别急,...
pos机安卓系统跟win系统,... 你有没有想过,那些在我们生活中默默无闻的POS机,竟然也有自己的操作系统呢?没错,就是安卓系统和Wi...
俄罗斯封禁安卓系统,本土化替代... 俄罗斯封禁安卓系统的背后:技术、经济与社会的影响在数字化浪潮席卷全球的今天,智能手机已成为我们生活中...
安卓系统总是弹出权限,安卓系统... 手机里的安卓系统是不是总爱和你玩捉迷藏?每次打开一个应用,它就跳出来问你要不要给它开权限,真是让人又...
安卓系统测血氧,便捷健康生活新... 你知道吗?现在科技的发展真是让人惊叹不已!手机,这个我们日常生活中不可或缺的小玩意儿,竟然也能变身成...
蓝光助手安卓系统的,深度解析与... 你有没有发现,现在手机屏幕越来越大,看视频、刷抖音,简直爽到飞起!但是,你知道吗?长时间盯着屏幕,尤...
安卓系统如何隐藏提示,Andr... 你是不是也和我一样,在使用安卓手机的时候,总是被那些弹出来的提示信息打扰到?别急,今天就来教你怎么巧...
安卓6.0系统如何分区,And... 你有没有想过,你的安卓手机里那些神秘的分区到底是怎么来的?别急,今天就来给你揭秘安卓6.0系统如何分...
安卓系统图片怎么涂鸦,指尖上的... 你有没有想过,在安卓系统的手机上,那些单调的图片也能变得生动有趣呢?没错,就是涂鸦!今天,就让我来带...
安卓系统40g,40GB存储空... 你有没有发现,最近你的安卓手机突然变得有点“胖”了呢?没错,就是那个传说中的40G!别急,别慌,今天...
安卓5.0系统怎么重置,轻松实... 手机用久了是不是感觉卡得要命?别急,今天就来教你怎么给安卓5.0系统来个彻底的重置,让它焕发新生!一...