[llvm] [profcheck] Add heuristical profile metadata for lowering table-based cttz. (PR #161898)
Aiden Grossman via llvm-commits
llvm-commits at lists.llvm.org
Mon Oct 6 14:27:56 PDT 2025
================
@@ -599,6 +607,19 @@ static bool tryToRecognizeTableBasedCttz(Instruction &I, const DataLayout &DL) {
auto Cmp = B.CreateICmpEQ(X1, ConstantInt::get(XType, 0));
auto Select = B.CreateSelect(Cmp, B.CreateZExt(ZeroTableElem, XType), Cttz);
+ // Attach heuristic branch weigths to the newly 'select' instruction that
+ // handles the cttz(0) edge case The assumpltion is tht the input to a cttz
+ // operation is rarely 0, so we add a strong 100-to-1 bias weights to the
+ // 'false' path.
----------------
boomanaiden154 wrote:
Can you add a comment mentioning that the 100-1 is arbitrary (or where it comes from if not)?
https://github.com/llvm/llvm-project/pull/161898
More information about the llvm-commits
mailing list