diff options
Diffstat (limited to 'llvm/test/CodeGen/X86/mulo-pow2.ll')
-rw-r--r-- | llvm/test/CodeGen/X86/mulo-pow2.ll | 13 |
1 files changed, 4 insertions, 9 deletions
diff --git a/llvm/test/CodeGen/X86/mulo-pow2.ll b/llvm/test/CodeGen/X86/mulo-pow2.ll index f5be144ff8e..de7dc567327 100644 --- a/llvm/test/CodeGen/X86/mulo-pow2.ll +++ b/llvm/test/CodeGen/X86/mulo-pow2.ll @@ -98,15 +98,10 @@ define <4 x i32> @smul_v4i32_1(<4 x i32> %a, <4 x i32> %b) nounwind { define <4 x i32> @smul_v4i32_2(<4 x i32> %a, <4 x i32> %b) nounwind { ; AVX-LABEL: smul_v4i32_2: ; AVX: # %bb.0: -; AVX-NEXT: vpxor %xmm2, %xmm2, %xmm2 -; AVX-NEXT: vpcmpgtd %xmm0, %xmm2, %xmm3 -; AVX-NEXT: vpcmpeqd %xmm4, %xmm4, %xmm4 -; AVX-NEXT: vpxor %xmm4, %xmm3, %xmm3 -; AVX-NEXT: vpaddd %xmm0, %xmm0, %xmm0 -; AVX-NEXT: vpcmpgtd %xmm0, %xmm2, %xmm2 -; AVX-NEXT: vpxor %xmm4, %xmm2, %xmm2 -; AVX-NEXT: vpcmpeqd %xmm2, %xmm3, %xmm2 -; AVX-NEXT: vblendvps %xmm2, %xmm0, %xmm1, %xmm0 +; AVX-NEXT: vpaddd %xmm0, %xmm0, %xmm2 +; AVX-NEXT: vpcmpgtd %xmm2, %xmm0, %xmm3 +; AVX-NEXT: vpxor %xmm3, %xmm0, %xmm0 +; AVX-NEXT: vblendvps %xmm0, %xmm1, %xmm2, %xmm0 ; AVX-NEXT: retq %x = call { <4 x i32>, <4 x i1> } @llvm.smul.with.overflow.v4i32(<4 x i32> %a, <4 x i32> <i32 2, i32 2, i32 2, i32 2>) %y = extractvalue { <4 x i32>, <4 x i1> } %x, 0 |