[llvm] c632ac3 - [SLP][NFC]Add a test with the gather operand in phi node in gathered loads
Alexey Bataev via llvm-commits
llvm-commits at lists.llvm.org
Wed May 14 08:18:33 PDT 2025
Author: Alexey Bataev
Date: 2025-05-14T08:18:23-07:00
New Revision: c632ac3506731e394dd7e3ac3f3320f5442250b4
URL: https://github.com/llvm/llvm-project/commit/c632ac3506731e394dd7e3ac3f3320f5442250b4
DIFF: https://github.com/llvm/llvm-project/commit/c632ac3506731e394dd7e3ac3f3320f5442250b4.diff
LOG: [SLP][NFC]Add a test with the gather operand in phi node in gathered loads
Added:
llvm/test/Transforms/SLPVectorizer/X86/phi-operand-gathered-loads.ll
Modified:
Removed:
################################################################################
diff --git a/llvm/test/Transforms/SLPVectorizer/X86/phi-operand-gathered-loads.ll b/llvm/test/Transforms/SLPVectorizer/X86/phi-operand-gathered-loads.ll
new file mode 100644
index 0000000000000..57eb1e7173618
--- /dev/null
+++ b/llvm/test/Transforms/SLPVectorizer/X86/phi-operand-gathered-loads.ll
@@ -0,0 +1,53 @@
+; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 5
+; RUN: opt -S --passes=slp-vectorizer -mtriple=x86_64-unknown-linux-gnu -mcpu=cascadelake < %s | FileCheck %s
+
+%class.btManifoldPoint = type <{ %class.btVector3, %class.btVector3, %class.btVector3, %class.btVector3, %class.btVector3, float, float, float, i32, i32, i32, i32, [4 x i8], ptr, float, i8, [3 x i8], float, float, i32, %class.btVector3, %class.btVector3, [4 x i8] }>
+%class.btVector3 = type { [4 x float] }
+
+define void @test(ptr %this, i1 %cmp4.not) {
+; CHECK-LABEL: define void @test(
+; CHECK-SAME: ptr [[THIS:%.*]], i1 [[CMP4_NOT:%.*]]) #[[ATTR0:[0-9]+]] {
+; CHECK-NEXT: [[ENTRY:.*]]:
+; CHECK-NEXT: [[NEWPT:%.*]] = alloca [[CLASS_BTMANIFOLDPOINT:%.*]], align 8
+; CHECK-NEXT: [[CALL25:%.*]] = load volatile i32, ptr [[NEWPT]], align 4
+; CHECK-NEXT: br i1 [[CMP4_NOT]], label %[[IF_ELSE37:.*]], label %[[IF_END46:.*]]
+; CHECK: [[IF_ELSE37]]:
+; CHECK-NEXT: br label %[[IF_END46]]
+; CHECK: [[IF_END46]]:
+; CHECK-NEXT: [[TMP0:%.*]] = phi <4 x i64> [ <i64 160, i64 1, i64 0, i64 1>, %[[IF_ELSE37]] ], [ <i64 0, i64 0, i64 1, i64 0>, %[[ENTRY]] ]
+; CHECK-NEXT: [[TMP1:%.*]] = insertelement <4 x ptr> poison, ptr [[THIS]], i32 0
+; CHECK-NEXT: [[TMP2:%.*]] = shufflevector <4 x ptr> [[TMP1]], <4 x ptr> poison, <4 x i32> zeroinitializer
+; CHECK-NEXT: [[TMP3:%.*]] = getelementptr i8, <4 x ptr> [[TMP2]], <4 x i64> [[TMP0]]
+; CHECK-NEXT: [[TMP4:%.*]] = getelementptr i8, ptr [[NEWPT]], i64 92
+; CHECK-NEXT: [[TMP5:%.*]] = call <4 x i32> @llvm.masked.gather.v4i32.v4p0(<4 x ptr> [[TMP3]], i32 4, <4 x i1> splat (i1 true), <4 x i32> poison)
+; CHECK-NEXT: store <4 x i32> [[TMP5]], ptr [[TMP4]], align 4
+; CHECK-NEXT: ret void
+;
+entry:
+ %newPt = alloca %class.btManifoldPoint, align 8
+ %call25 = load volatile i32, ptr %newPt, align 4
+ br i1 %cmp4.not, label %if.else37, label %if.end46
+
+if.else37: ; preds = %entry
+ br label %if.end46
+
+if.end46: ; preds = %if.else37, %entry
+ %.sink264 = phi i64 [ 160, %if.else37 ], [ 0, %entry ]
+ %.sink262 = phi i64 [ 0, %if.else37 ], [ 1, %entry ]
+ %.sink261 = phi i64 [ 1, %if.else37 ], [ 0, %entry ]
+ %m_partId038 = getelementptr i8, ptr %this, i64 %.sink264
+ %m_index042 = getelementptr i8, ptr %this, i64 %.sink262
+ %m_index144 = getelementptr i8, ptr %this, i64 %.sink261
+ %.sink = load i32, ptr %m_index144, align 4
+ %.sink186 = load i32, ptr %m_index042, align 4
+ %.sink188 = load i32, ptr %m_partId038, align 4
+ %0 = getelementptr i8, ptr %newPt, i64 92
+ store i32 %.sink188, ptr %0, align 4
+ %1 = getelementptr i8, ptr %newPt, i64 96
+ store i32 %.sink, ptr %1, align 8
+ %2 = getelementptr i8, ptr %newPt, i64 100
+ store i32 %.sink186, ptr %2, align 4
+ %3 = getelementptr i8, ptr %newPt, i64 104
+ store i32 %.sink, ptr %3, align 8
+ ret void
+}
More information about the llvm-commits
mailing list