aboutsummaryrefslogtreecommitdiff
path: root/llvm/lib/CodeGen/SelectOptimize.cpp
diff options
context:
space:
mode:
authorIgor Kirillov <igor.kirillov@arm.com>2024-12-25 12:58:21 +0000
committerGitHub <noreply@github.com>2024-12-25 12:58:21 +0000
commit3469996d0d057d99a33ec34ee3c80e5d4fa3afcb (patch)
tree2a5f57be350e2cec11e1ec6d174f298cad6c8472 /llvm/lib/CodeGen/SelectOptimize.cpp
parent4884b1b08a13af430620e7104aa58710a70f618c (diff)
downloadllvm-3469996d0d057d99a33ec34ee3c80e5d4fa3afcb.zip
llvm-3469996d0d057d99a33ec34ee3c80e5d4fa3afcb.tar.gz
llvm-3469996d0d057d99a33ec34ee3c80e5d4fa3afcb.tar.bz2
[SelectOpt] Optimise big select groups in the latch of a non-inner loop to branches (#119728)
Loop latches often have a loop-carried dependency, and if they have several SelectLike instructions in one select group, it is usually profitable to convert it to branches rather than keep selects.
Diffstat (limited to 'llvm/lib/CodeGen/SelectOptimize.cpp')
-rw-r--r--llvm/lib/CodeGen/SelectOptimize.cpp12
1 files changed, 12 insertions, 0 deletions
diff --git a/llvm/lib/CodeGen/SelectOptimize.cpp b/llvm/lib/CodeGen/SelectOptimize.cpp
index 7b927e6..bfc49dd 100644
--- a/llvm/lib/CodeGen/SelectOptimize.cpp
+++ b/llvm/lib/CodeGen/SelectOptimize.cpp
@@ -1044,6 +1044,18 @@ bool SelectOptimizeImpl::isConvertToBranchProfitableBase(
return true;
}
+ // If latch has a select group with several elements, it is usually profitable
+ // to convert it to branches. We let `optimizeSelectsInnerLoops` decide if
+ // conversion is profitable for innermost loops.
+ auto *BB = SI.getI()->getParent();
+ auto *L = LI->getLoopFor(BB);
+ if (L && !L->isInnermost() && L->getLoopLatch() == BB &&
+ ASI.Selects.size() >= 3) {
+ OR << "Converted to branch because select group in the latch block is big.";
+ EmitAndPrintRemark(ORE, OR);
+ return true;
+ }
+
ORmiss << "Not profitable to convert to branch (base heuristic).";
EmitAndPrintRemark(ORE, ORmiss);
return false;