[llvm] bc8abb4 - Revert "[SLP]Relax assertion to check if the input scalars were extended to"
Alexey Bataev via llvm-commits
llvm-commits at lists.llvm.org
Fri Jul 14 07:04:18 PDT 2023
Author: Alexey Bataev
Date: 2023-07-14T07:04:06-07:00
New Revision: bc8abb42bb6e75df217714a65dceebdeaeeeab2a
URL: https://github.com/llvm/llvm-project/commit/bc8abb42bb6e75df217714a65dceebdeaeeeab2a
DIFF: https://github.com/llvm/llvm-project/commit/bc8abb42bb6e75df217714a65dceebdeaeeeab2a.diff
LOG: Revert "[SLP]Relax assertion to check if the input scalars were extended to"
This reverts commit 6fdfc81287ecdc2a7f409d08538ec6ce2bd698da to fix the
check in the assert )need to use end, nod begin function).
Added:
Modified:
llvm/lib/Transforms/Vectorize/SLPVectorizer.cpp
Removed:
llvm/test/Transforms/SLPVectorizer/X86/pr63668.ll
################################################################################
diff --git a/llvm/lib/Transforms/Vectorize/SLPVectorizer.cpp b/llvm/lib/Transforms/Vectorize/SLPVectorizer.cpp
index 36a363f0214e9e..97b8737df83e4a 100644
--- a/llvm/lib/Transforms/Vectorize/SLPVectorizer.cpp
+++ b/llvm/lib/Transforms/Vectorize/SLPVectorizer.cpp
@@ -952,13 +952,8 @@ static void addMask(SmallVectorImpl<int> &Mask, ArrayRef<int> SubMask,
bool ExtendingManyInputs = false) {
if (SubMask.empty())
return;
- assert(
- (!ExtendingManyInputs || SubMask.size() > Mask.size() ||
- // Check if input scalars were extended to match the size of other node.
- (SubMask.size() == Mask.size() &&
- std::all_of(std::next(Mask.begin(), Mask.size() / 2), Mask.begin(),
- [](int Idx) { return Idx == PoisonMaskElem; }))) &&
- "SubMask with many inputs support must be larger than the mask.");
+ assert((!ExtendingManyInputs || SubMask.size() > Mask.size()) &&
+ "SubMask with many inputs support must be larger than the mask.");
if (Mask.empty()) {
Mask.append(SubMask.begin(), SubMask.end());
return;
diff --git a/llvm/test/Transforms/SLPVectorizer/X86/pr63668.ll b/llvm/test/Transforms/SLPVectorizer/X86/pr63668.ll
deleted file mode 100644
index 391771e06cab80..00000000000000
--- a/llvm/test/Transforms/SLPVectorizer/X86/pr63668.ll
+++ /dev/null
@@ -1,54 +0,0 @@
-; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 3
-; RUN: opt -passes=slp-vectorizer -mtriple=x86_64-unknown-linux-gnu -mcpu=znver4 -S < %s | FileCheck %s
-
-define internal i32 @testfunc() {
-; CHECK-LABEL: define internal i32 @testfunc
-; CHECK-SAME: () #[[ATTR0:[0-9]+]] {
-; CHECK-NEXT: br label [[TMP1:%.*]]
-; CHECK: 1:
-; CHECK-NEXT: [[TMP2:%.*]] = phi float [ 0.000000e+00, [[TMP0:%.*]] ], [ 0.000000e+00, [[TMP8:%.*]] ]
-; CHECK-NEXT: [[TMP3:%.*]] = phi float [ 0.000000e+00, [[TMP0]] ], [ 0.000000e+00, [[TMP8]] ]
-; CHECK-NEXT: [[TMP4:%.*]] = phi float [ 0.000000e+00, [[TMP0]] ], [ 0.000000e+00, [[TMP8]] ]
-; CHECK-NEXT: br i1 false, label [[TMP8]], label [[TMP5:%.*]]
-; CHECK: 5:
-; CHECK-NEXT: br i1 false, label [[TMP6:%.*]], label [[TMP8]]
-; CHECK: 6:
-; CHECK-NEXT: [[TMP7:%.*]] = extractelement <8 x float> zeroinitializer, i64 0
-; CHECK-NEXT: br label [[TMP8]]
-; CHECK: 8:
-; CHECK-NEXT: [[TMP9:%.*]] = phi float [ [[TMP7]], [[TMP6]] ], [ 0.000000e+00, [[TMP1]] ], [ 0.000000e+00, [[TMP5]] ]
-; CHECK-NEXT: [[TMP10:%.*]] = phi float [ [[TMP2]], [[TMP6]] ], [ 0.000000e+00, [[TMP1]] ], [ [[TMP2]], [[TMP5]] ]
-; CHECK-NEXT: [[TMP11:%.*]] = phi float [ [[TMP7]], [[TMP6]] ], [ 0.000000e+00, [[TMP1]] ], [ 0.000000e+00, [[TMP5]] ]
-; CHECK-NEXT: [[TMP12:%.*]] = phi float [ [[TMP7]], [[TMP6]] ], [ 0.000000e+00, [[TMP1]] ], [ 0.000000e+00, [[TMP5]] ]
-; CHECK-NEXT: [[TMP13:%.*]] = phi float [ [[TMP7]], [[TMP6]] ], [ 0.000000e+00, [[TMP1]] ], [ 0.000000e+00, [[TMP5]] ]
-; CHECK-NEXT: [[TMP14:%.*]] = phi float [ [[TMP3]], [[TMP6]] ], [ 0.000000e+00, [[TMP1]] ], [ 0.000000e+00, [[TMP5]] ]
-; CHECK-NEXT: [[TMP15:%.*]] = phi float [ [[TMP4]], [[TMP6]] ], [ 0.000000e+00, [[TMP1]] ], [ 0.000000e+00, [[TMP5]] ]
-; CHECK-NEXT: [[TMP16:%.*]] = phi float [ [[TMP4]], [[TMP6]] ], [ 0.000000e+00, [[TMP1]] ], [ [[TMP3]], [[TMP5]] ]
-; CHECK-NEXT: br label [[TMP1]]
-;
- br label %1
-
-1: ; preds = %8, %0
- %2 = phi float [ 0.000000e+00, %0 ], [ 0.000000e+00, %8 ]
- %3 = phi float [ 0.000000e+00, %0 ], [ 0.000000e+00, %8 ]
- %4 = phi float [ 0.000000e+00, %0 ], [ 0.000000e+00, %8 ]
- br i1 false, label %8, label %5
-
-5: ; preds = %1
- br i1 false, label %6, label %8
-
-6: ; preds = %5
- %7 = extractelement <8 x float> zeroinitializer, i64 0
- br label %8
-
-8: ; preds = %6, %5, %1
- %9 = phi float [ %7, %6 ], [ 0.000000e+00, %1 ], [ 0.000000e+00, %5 ]
- %10 = phi float [ %2, %6 ], [ 0.000000e+00, %1 ], [ %2, %5 ]
- %11 = phi float [ %7, %6 ], [ 0.000000e+00, %1 ], [ 0.000000e+00, %5 ]
- %12 = phi float [ %7, %6 ], [ 0.000000e+00, %1 ], [ 0.000000e+00, %5 ]
- %13 = phi float [ %7, %6 ], [ 0.000000e+00, %1 ], [ 0.000000e+00, %5 ]
- %14 = phi float [ %3, %6 ], [ 0.000000e+00, %1 ], [ 0.000000e+00, %5 ]
- %15 = phi float [ %4, %6 ], [ 0.000000e+00, %1 ], [ 0.000000e+00, %5 ]
- %16 = phi float [ %4, %6 ], [ 0.000000e+00, %1 ], [ %3, %5 ]
- br label %1
-}
More information about the llvm-commits
mailing list