[polly] r266051 - Simplify SCEVAffinator code [NFC]
Johannes Doerfert via llvm-commits
llvm-commits at lists.llvm.org
Tue Apr 12 02:33:47 PDT 2016
Author: jdoerfert
Date: Tue Apr 12 04:33:47 2016
New Revision: 266051
URL: http://llvm.org/viewvc/llvm-project?rev=266051&view=rev
Log:
Simplify SCEVAffinator code [NFC]
Modified:
polly/trunk/lib/Support/SCEVAffinator.cpp
Modified: polly/trunk/lib/Support/SCEVAffinator.cpp
URL: http://llvm.org/viewvc/llvm-project/polly/trunk/lib/Support/SCEVAffinator.cpp?rev=266051&r1=266050&r2=266051&view=diff
==============================================================================
--- polly/trunk/lib/Support/SCEVAffinator.cpp (original)
+++ polly/trunk/lib/Support/SCEVAffinator.cpp Tue Apr 12 04:33:47 2016
@@ -51,6 +51,13 @@ static bool isToComplex(isl_pw_aff *PWA)
return true;
}
+/// @brief Return the flag describing the possible wrapping of @p Expr.
+static SCEV::NoWrapFlags getNoWrapFlags(const SCEV *Expr) {
+ if (auto *NAry = dyn_cast<SCEVNAryExpr>(Expr))
+ return NAry->getNoWrapFlags();
+ return SCEV::NoWrapMask;
+}
+
SCEVAffinator::SCEVAffinator(Scop *S, LoopInfo &LI)
: S(S), Ctx(S->getIslCtx()), R(S->getRegion()), SE(*S->getSE()), LI(LI),
TD(R.getEntry()->getParent()->getParent()->getDataLayout()) {}
@@ -112,21 +119,7 @@ __isl_give isl_set *SCEVAffinator::getWr
for (const auto &CachedPair : CachedExpressions) {
const SCEV *Expr = CachedPair.first.first;
- SCEV::NoWrapFlags Flags;
-
- switch (Expr->getSCEVType()) {
- case scAddExpr:
- Flags = cast<SCEVAddExpr>(Expr)->getNoWrapFlags();
- break;
- case scMulExpr:
- Flags = cast<SCEVMulExpr>(Expr)->getNoWrapFlags();
- break;
- case scAddRecExpr:
- Flags = cast<SCEVAddRecExpr>(Expr)->getNoWrapFlags();
- break;
- default:
- continue;
- }
+ SCEV::NoWrapFlags Flags = getNoWrapFlags(Expr);
isl_pw_aff *PWA = CachedPair.second;
BasicBlock *BB = CachedPair.first.second;
More information about the llvm-commits
mailing list