From 65f86cd8b09b15e6ba531309325750d1a3f4af7c Mon Sep 17 00:00:00 2001 From: Johannes Doerfert Date: Tue, 12 Apr 2016 09:33:47 +0000 Subject: [PATCH] Simplify SCEVAffinator code [NFC] llvm-svn: 266051 --- polly/lib/Support/SCEVAffinator.cpp | 23 ++++++++--------------- 1 file changed, 8 insertions(+), 15 deletions(-) diff --git a/polly/lib/Support/SCEVAffinator.cpp b/polly/lib/Support/SCEVAffinator.cpp index e1520c8..f2db2dd 100644 --- a/polly/lib/Support/SCEVAffinator.cpp +++ b/polly/lib/Support/SCEVAffinator.cpp @@ -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(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::getWrappingContext() const { for (const auto &CachedPair : CachedExpressions) { const SCEV *Expr = CachedPair.first.first; - SCEV::NoWrapFlags Flags; - - switch (Expr->getSCEVType()) { - case scAddExpr: - Flags = cast(Expr)->getNoWrapFlags(); - break; - case scMulExpr: - Flags = cast(Expr)->getNoWrapFlags(); - break; - case scAddRecExpr: - Flags = cast(Expr)->getNoWrapFlags(); - break; - default: - continue; - } + SCEV::NoWrapFlags Flags = getNoWrapFlags(Expr); isl_pw_aff *PWA = CachedPair.second; BasicBlock *BB = CachedPair.first.second; -- 2.7.4