[llvm] [SLP]Represent SLP graph as a tree (PR #126771)
via llvm-commits
llvm-commits at lists.llvm.org
Tue Feb 11 10:02:09 PST 2025
github-actions[bot] wrote:
<!--LLVM CODE FORMAT COMMENT: {clang-format}-->
:warning: C/C++ code formatter, clang-format found issues in your code. :warning:
<details>
<summary>
You can test this locally with the following command:
</summary>
``````````bash
git-clang-format --diff 55ae118db7c36fb88994e072e424cb66d1f34e74 f2e3a1f7c4d481ed935eaec1e05d08ce8b140bc8 --extensions cpp -- llvm/lib/Transforms/Vectorize/SLPVectorizer.cpp
``````````
</details>
<details>
<summary>
View the diff from clang-format here.
</summary>
``````````diff
diff --git a/llvm/lib/Transforms/Vectorize/SLPVectorizer.cpp b/llvm/lib/Transforms/Vectorize/SLPVectorizer.cpp
index 6f9c62c621..82cc009d4d 100644
--- a/llvm/lib/Transforms/Vectorize/SLPVectorizer.cpp
+++ b/llvm/lib/Transforms/Vectorize/SLPVectorizer.cpp
@@ -6372,8 +6372,8 @@ void BoUpSLP::reorderBottomToTop(bool IgnoreReorder) {
if (TE->State != TreeEntry::Vectorize &&
TE->State != TreeEntry::StridedVectorize)
NonVectorized.push_back(TE.get());
- if (std::optional<OrdersType> CurrentOrder = getReorderingData(
- *TE, /*TopToBottom=*/false, IgnoreReorder)) {
+ if (std::optional<OrdersType> CurrentOrder =
+ getReorderingData(*TE, /*TopToBottom=*/false, IgnoreReorder)) {
OrderedEntries.insert(TE.get());
if (!(TE->State == TreeEntry::Vectorize ||
TE->State == TreeEntry::StridedVectorize) ||
@@ -13825,8 +13825,7 @@ BoUpSLP::isGatherShuffledEntry(
if (TE->hasNonWholeRegisterOrNonPowerOf2Vec(*TTI))
return {};
Mask.assign(VL.size(), PoisonMaskElem);
- assert((TE->UserTreeIndex ||
- TE == VectorizableTree.front().get()) &&
+ assert((TE->UserTreeIndex || TE == VectorizableTree.front().get()) &&
"Expected only single user of the gather node.");
assert(VL.size() % NumParts == 0 &&
"Number of scalars must be divisible by NumParts.");
@@ -18617,15 +18616,16 @@ void BoUpSLP::computeMinimumValueSizes() {
VectorizableTree[NodeIdx]->UserTreeIndex.UserTE->hasState() &&
VectorizableTree[NodeIdx]->UserTreeIndex.UserTE->getOpcode() ==
Instruction::ICmp &&
- any_of(VectorizableTree[NodeIdx]->UserTreeIndex.UserTE->Scalars,
- [&](Value *V) {
- auto *IC = dyn_cast<ICmpInst>(V);
- return IC && (IC->isSigned() ||
- !isKnownNonNegative(IC->getOperand(0),
- SimplifyQuery(*DL)) ||
- !isKnownNonNegative(IC->getOperand(1),
- SimplifyQuery(*DL)));
- });
+ any_of(
+ VectorizableTree[NodeIdx]->UserTreeIndex.UserTE->Scalars,
+ [&](Value *V) {
+ auto *IC = dyn_cast<ICmpInst>(V);
+ return IC && (IC->isSigned() ||
+ !isKnownNonNegative(IC->getOperand(0),
+ SimplifyQuery(*DL)) ||
+ !isKnownNonNegative(IC->getOperand(1),
+ SimplifyQuery(*DL)));
+ });
}
// If the maximum bit width we compute is less than the width of the roots'
``````````
</details>
https://github.com/llvm/llvm-project/pull/126771
More information about the llvm-commits
mailing list