[PATCH] D106083: [unittest] Exercise SCEV's udiv and udiv ceiling routines
Philip Reames via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Thu Jul 15 11:59:39 PDT 2021
This revision was landed with ongoing or failed builds.
This revision was automatically updated to reflect the committed changes.
Closed by commit rGb980d2f54bb6: [unittest] Exercise SCEV's udiv and udiv ceiling routines (authored by reames).
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D106083/new/
https://reviews.llvm.org/D106083
Files:
llvm/include/llvm/Analysis/ScalarEvolution.h
llvm/unittests/Analysis/ScalarEvolutionTest.cpp
Index: llvm/unittests/Analysis/ScalarEvolutionTest.cpp
===================================================================
--- llvm/unittests/Analysis/ScalarEvolutionTest.cpp
+++ llvm/unittests/Analysis/ScalarEvolutionTest.cpp
@@ -1507,4 +1507,35 @@
});
}
+TEST_F(ScalarEvolutionsTest, SCEVUDivFloorCeiling) {
+ LLVMContext C;
+ SMDiagnostic Err;
+ std::unique_ptr<Module> M = parseAssemblyString("define void @foo() { "
+ " ret void "
+ "} ",
+ Err, C);
+
+ ASSERT_TRUE(M && "Could not parse module?");
+ ASSERT_TRUE(!verifyModule(*M) && "Must have been well formed!");
+
+ runWithSE(*M, "foo", [](Function &F, LoopInfo &LI, ScalarEvolution &SE) {
+ // Check that SCEV's udiv and uceil handling produce the correct results
+ // for all 8 bit options. Div-by-zero is deliberately excluded.
+ for (unsigned N = 0; N < 256; N++)
+ for (unsigned D = 1; D < 256; D++) {
+ APInt NInt(8, N);
+ APInt DInt(8, D);
+ using namespace llvm::APIntOps;
+ APInt FloorInt = RoundingUDiv(NInt, DInt, APInt::Rounding::DOWN);
+ APInt CeilingInt = RoundingUDiv(NInt, DInt, APInt::Rounding::UP);
+ auto *NS = SE.getConstant(NInt);
+ auto *DS = SE.getConstant(DInt);
+ auto *FloorS = cast<SCEVConstant>(SE.getUDivExpr(NS, DS));
+ auto *CeilingS = cast<SCEVConstant>(SE.getUDivCeilSCEV(NS, DS));
+ ASSERT_TRUE(FloorS->getAPInt() == FloorInt);
+ ASSERT_TRUE(CeilingS->getAPInt() == CeilingInt);
+ }
+ });
+}
+
} // end namespace llvm
Index: llvm/include/llvm/Analysis/ScalarEvolution.h
===================================================================
--- llvm/include/llvm/Analysis/ScalarEvolution.h
+++ llvm/include/llvm/Analysis/ScalarEvolution.h
@@ -643,6 +643,16 @@
SCEV::NoWrapFlags Flags = SCEV::FlagAnyWrap,
unsigned Depth = 0);
+ /// Compute ceil(N / D). N and D are treated as unsigned values.
+ ///
+ /// Since SCEV doesn't have native ceiling division, this generates a
+ /// SCEV expression of the following form:
+ ///
+ /// umin(N, 1) + floor((N - umin(N, 1)) / D)
+ ///
+ /// A denominator of zero or poison is handled the same way as getUDivExpr().
+ const SCEV *getUDivCeilSCEV(const SCEV *N, const SCEV *D);
+
/// Return a SCEV corresponding to a conversion of the input value to the
/// specified type. If the type must be extended, it is zero extended.
const SCEV *getTruncateOrZeroExtend(const SCEV *V, Type *Ty,
@@ -2029,16 +2039,6 @@
/// that the result is undefined if it does.
const SCEV *computeBECount(const SCEV *Delta, const SCEV *Stride);
- /// Compute ceil(N / D). N and D are treated as unsigned values.
- ///
- /// Since SCEV doesn't have native ceiling division, this generates a
- /// SCEV expression of the following form:
- ///
- /// umin(N, 1) + floor((N - umin(N, 1)) / D)
- ///
- /// A denominator of zero or poison is handled the same way as getUDivExpr().
- const SCEV *getUDivCeilSCEV(const SCEV *N, const SCEV *D);
-
/// Compute the maximum backedge count based on the range of values
/// permitted by Start, End, and Stride. This is for loops of the form
/// {Start, +, Stride} LT End.
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D106083.359081.patch
Type: text/x-patch
Size: 3373 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20210715/aae0f70d/attachment.bin>
More information about the llvm-commits
mailing list