[llvm] [SCEV] Improve code around constant TC (NFC) (PR #133261)
via llvm-commits
llvm-commits at lists.llvm.org
Thu Mar 27 07:49:14 PDT 2025
llvmbot wrote:
<!--LLVM PR SUMMARY COMMENT-->
@llvm/pr-subscribers-llvm-analysis
Author: Ramkumar Ramachandra (artagnon)
<details>
<summary>Changes</summary>
---
Full diff: https://github.com/llvm/llvm-project/pull/133261.diff
1 Files Affected:
- (modified) llvm/lib/Analysis/ScalarEvolution.cpp (+5-5)
``````````diff
diff --git a/llvm/lib/Analysis/ScalarEvolution.cpp b/llvm/lib/Analysis/ScalarEvolution.cpp
index 314baa7c7aee1..fc12128f73146 100644
--- a/llvm/lib/Analysis/ScalarEvolution.cpp
+++ b/llvm/lib/Analysis/ScalarEvolution.cpp
@@ -8225,7 +8225,7 @@ static unsigned getConstantTripCount(const SCEVConstant *ExitCount) {
ConstantInt *ExitConst = ExitCount->getValue();
// Guard against huge trip counts.
- if (ExitConst->getValue().getActiveBits() > 32)
+ if (ExitConst->getValue().getActiveBits() > CHAR_BIT * sizeof(unsigned))
return 0;
// In case of integer overflow, this returns 0, which is correct.
@@ -8266,14 +8266,14 @@ unsigned ScalarEvolution::getSmallConstantTripMultiple(const Loop *L) {
unsigned Multiple = getSmallConstantTripMultiple(L, ExitingBB);
if (!Res)
Res = Multiple;
- Res = (unsigned)std::gcd(*Res, Multiple);
+ Res = std::gcd(*Res, Multiple);
}
return Res.value_or(1);
}
unsigned ScalarEvolution::getSmallConstantTripMultiple(const Loop *L,
const SCEV *ExitCount) {
- if (ExitCount == getCouldNotCompute())
+ if (isa<SCEVCouldNotCompute>(ExitCount))
return 1;
// Get the trip count
@@ -8283,8 +8283,8 @@ unsigned ScalarEvolution::getSmallConstantTripMultiple(const Loop *L,
// If a trip multiple is huge (>=2^32), the trip count is still divisible by
// the greatest power of 2 divisor less than 2^32.
return Multiple.getActiveBits() > 32
- ? 1U << std::min((unsigned)31, Multiple.countTrailingZeros())
- : (unsigned)Multiple.zextOrTrunc(32).getZExtValue();
+ ? 1U << std::min(31U, Multiple.countTrailingZeros())
+ : (unsigned)Multiple.getZExtValue();
}
/// Returns the largest constant divisor of the trip count of this loop as a
``````````
</details>
https://github.com/llvm/llvm-project/pull/133261
More information about the llvm-commits
mailing list