[llvm] 72959f7 - [X86] Add test case for Issue #55158

Simon Pilgrim via llvm-commits llvm-commits at lists.llvm.org
Thu Apr 28 05:07:11 PDT 2022


Author: Simon Pilgrim
Date: 2022-04-28T13:06:58+01:00
New Revision: 72959f77146e6a8c82d228e61968f08c307afc7c

URL: https://github.com/llvm/llvm-project/commit/72959f77146e6a8c82d228e61968f08c307afc7c
DIFF: https://github.com/llvm/llvm-project/commit/72959f77146e6a8c82d228e61968f08c307afc7c.diff

LOG: [X86] Add test case for Issue #55158

Added: 
    llvm/test/CodeGen/X86/pr55158.ll

Modified: 
    

Removed: 
    


################################################################################
diff  --git a/llvm/test/CodeGen/X86/pr55158.ll b/llvm/test/CodeGen/X86/pr55158.ll
new file mode 100644
index 000000000000..b278812228c2
--- /dev/null
+++ b/llvm/test/CodeGen/X86/pr55158.ll
@@ -0,0 +1,55 @@
+; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
+; RUN: llc < %s -mtriple=x86_64-linux -opaque-pointers -mcpu=ivybridge -mattr=+avx2 | FileCheck %s --check-prefixes=IVB
+; RUN: llc < %s -mtriple=x86_64-linux -opaque-pointers -mcpu=haswell | FileCheck %s --check-prefixes=HSW
+
+define <2 x i64> @PR55158(ptr %0) {
+; IVB-LABEL: PR55158:
+; IVB:       # %bb.0:
+; IVB-NEXT:    vmovdqa 64(%rdi), %xmm0
+; IVB-NEXT:    vmovdqa 128(%rdi), %xmm1
+; IVB-NEXT:    vpmovsxbd (%rdi), %xmm2
+; IVB-NEXT:    vpcmpgtd %xmm2, %xmm1, %xmm1
+; IVB-NEXT:    vphsubw %xmm0, %xmm0, %xmm0
+; IVB-NEXT:    vpmovzxdq {{.*#+}} xmm1 = xmm1[0],zero,xmm1[1],zero
+; IVB-NEXT:    vpxor %xmm2, %xmm2, %xmm2
+; IVB-NEXT:    vpsrlvq %xmm1, %xmm2, %xmm1
+; IVB-NEXT:    vpunpckhqdq {{.*#+}} xmm0 = xmm1[1],xmm0[1]
+; IVB-NEXT:    retq
+;
+; HSW-LABEL: PR55158:
+; HSW:       # %bb.0:
+; HSW-NEXT:    vmovdqa 64(%rdi), %xmm0
+; HSW-NEXT:    vmovdqa 128(%rdi), %xmm1
+; HSW-NEXT:    vpmovsxbd (%rdi), %xmm2
+; HSW-NEXT:    vpcmpgtd %xmm2, %xmm1, %xmm1
+; HSW-NEXT:    vphsubw %xmm0, %xmm0, %xmm0
+; HSW-NEXT:    vpmovzxdq {{.*#+}} xmm1 = xmm1[0],zero,xmm1[1],zero
+; HSW-NEXT:    vpandn {{\.?LCPI[0-9]+_[0-9]+}}(%rip), %xmm0, %xmm2
+; HSW-NEXT:    vpsrlvq %xmm1, %xmm2, %xmm1
+; HSW-NEXT:    vpunpckhqdq {{.*#+}} xmm0 = xmm1[1],xmm0[1]
+; HSW-NEXT:    retq
+  %2 = load <16 x i8>, ptr %0, align 16
+  %3 = getelementptr inbounds i32, ptr %0, i64 16
+  %4 = load <8 x i16>, ptr %3, align 16
+  %5 = getelementptr inbounds i32, ptr %0, i64 32
+  %6 = load <4 x i32>, ptr %5, align 16
+  %7 = shufflevector <16 x i8> %2, <16 x i8> poison, <4 x i32> <i32 0, i32 1, i32 2, i32 3>
+  %8 = sext <4 x i8> %7 to <4 x i32>
+  %9 = icmp sgt <4 x i32> %6, %8
+  %10 = sext <4 x i1> %9 to <4 x i32>
+  %11 = tail call <8 x i16> @llvm.x86.ssse3.phsub.w.128(<8 x i16> %4, <8 x i16> %4)
+  %12 = bitcast <8 x i16> %11 to <2 x i64>
+  %13 = shufflevector <4 x i32> %10, <4 x i32> poison, <2 x i32> <i32 0, i32 1>
+  %14 = zext <2 x i32> %13 to <2 x i64>
+  %15 = bitcast <8 x i16> %11 to <16 x i8>
+  %16 = icmp ne <16 x i8> %15, zeroinitializer
+  %17 = sext <16 x i1> %16 to <16 x i8>
+  %18 = shufflevector <16 x i8> %17, <16 x i8> poison, <2 x i32> <i32 0, i32 1>
+  %19 = zext <2 x i8> %18 to <2 x i64>
+  %20 = insertelement <2 x i64> %19, i64 0, i64 1
+  %21 = tail call <2 x i64> @llvm.x86.avx2.psrlv.q(<2 x i64> %20, <2 x i64> %14)
+  %22 = shufflevector <2 x i64> %21, <2 x i64> %12, <2 x i32> <i32 1, i32 3>
+  ret <2 x i64> %22
+}
+declare <8 x i16> @llvm.x86.ssse3.phsub.w.128(<8 x i16>, <8 x i16>)
+declare <2 x i64> @llvm.x86.avx2.psrlv.q(<2 x i64>, <2 x i64>)


        


More information about the llvm-commits mailing list