汇编 – vmovdqu在这做什么?
发布时间:2020-12-15 04:49:48 所属栏目:Java 来源:网络整理
导读:我有一个 Java循环,如下所示: public void testMethod() { int[] nums = new int[10]; for (int i = 0; i nums.length; i++) { nums[i] = 0x42; }} 我得到的组件是这样的: 0x00000001296ac845: cmp %r10d,%ebp0x00000001296ac848: jae 0x00000001296ac8b40
我有一个
Java循环,如下所示:
public void testMethod() { int[] nums = new int[10]; for (int i = 0; i < nums.length; i++) { nums[i] = 0x42; } } 我得到的组件是这样的: 0x00000001296ac845: cmp %r10d,%ebp 0x00000001296ac848: jae 0x00000001296ac8b4 0x00000001296ac84a: movl $0x42,0x10(%rbx,%rbp,4) 0x00000001296ac852: inc %ebp 0x00000001296ac854: cmp %r11d,%ebp 0x00000001296ac857: jl 0x00000001296ac845 0x00000001296ac859: mov %r10d,%r8d 0x00000001296ac85c: add $0xfffffffd,%r8d 0x00000001296ac860: mov $0x80000000,%r9d 0x00000001296ac866: cmp %r8d,%r10d 0x00000001296ac869: cmovl %r9d,%r8d 0x00000001296ac86d: cmp %r8d,%ebp 0x00000001296ac870: jge 0x00000001296ac88e 0x00000001296ac872: vmovq -0xda(%rip),%xmm0 0x00000001296ac87a: vpunpcklqdq %xmm0,%xmm0,%xmm0 0x00000001296ac87e: xchg %ax,%ax 0x00000001296ac880: vmovdqu %xmm0,4) 0x00000001296ac886: add $0x4,%ebp 0x00000001296ac889: cmp %r8d,%ebp 0x00000001296ac88c: jl 0x00000001296ac880 如果我的理解是正确的,那么第一个汇编块就是那个做nums [i] = 0x42;的块.在第三个区块中,有vmovdqu
但是,我仍然不完全理解vmovdqu在我的循环上下文中正在做什么. 第三块汇编代码到底是做什么的? 完整代码可在此处获取:https://pastebin.com/cT5cJcMS 解决方法
优化器选择对循环进行矢量化,每次“迭代”设置4个值. (vmovdqu之前的指令是相当不透明的,但可能是它将0x42映射到XMM0的所有通道.)“未对齐”变量是必要的,因为不保证数组在内存中是SIMD对齐的(毕竟,它存储int32s,不是int32x4s).
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |