LLVM 20.0.0git
|
This class represents an assumption made on an AddRec expression. More...
#include "llvm/Analysis/ScalarEvolution.h"
Public Types | |
enum | IncrementWrapFlags { IncrementAnyWrap = 0 , IncrementNUSW = (1 << 0) , IncrementNSSW = (1 << 1) , IncrementNoWrapMask = (1 << 2) - 1 } |
Similar to SCEV::NoWrapFlags, but with slightly different semantics for FlagNUSW. More... | |
Public Types inherited from llvm::SCEVPredicate | |
enum | SCEVPredicateKind { P_Union , P_Compare , P_Wrap } |
Public Member Functions | |
SCEVWrapPredicate (const FoldingSetNodeIDRef ID, const SCEVAddRecExpr *AR, IncrementWrapFlags Flags) | |
IncrementWrapFlags | getFlags () const |
Returns the set assumed no overflow flags. | |
const SCEVAddRecExpr * | getExpr () const |
Implementation of the SCEVPredicate interface. | |
bool | implies (const SCEVPredicate *N) const override |
Returns true if this predicate implies N . | |
void | print (raw_ostream &OS, unsigned Depth=0) const override |
Prints a textual representation of this predicate with an indentation of Depth . | |
bool | isAlwaysTrue () const override |
Returns true if the predicate is always true. | |
Public Member Functions inherited from llvm::SCEVPredicate | |
SCEVPredicate (const FoldingSetNodeIDRef ID, SCEVPredicateKind Kind) | |
SCEV predicates. | |
SCEVPredicateKind | getKind () const |
virtual unsigned | getComplexity () const |
Returns the estimated complexity of this predicate. | |
virtual bool | isAlwaysTrue () const =0 |
Returns true if the predicate is always true. | |
virtual bool | implies (const SCEVPredicate *N) const =0 |
Returns true if this predicate implies N . | |
virtual void | print (raw_ostream &OS, unsigned Depth=0) const =0 |
Prints a textual representation of this predicate with an indentation of Depth . | |
Public Member Functions inherited from llvm::FoldingSetBase::Node | |
Node ()=default | |
void * | getNextInBucket () const |
void | SetNextInBucket (void *N) |
Static Public Member Functions | |
static SCEVWrapPredicate::IncrementWrapFlags | clearFlags (SCEVWrapPredicate::IncrementWrapFlags Flags, SCEVWrapPredicate::IncrementWrapFlags OffFlags) |
Convenient IncrementWrapFlags manipulation methods. | |
static SCEVWrapPredicate::IncrementWrapFlags | maskFlags (SCEVWrapPredicate::IncrementWrapFlags Flags, int Mask) |
static SCEVWrapPredicate::IncrementWrapFlags | setFlags (SCEVWrapPredicate::IncrementWrapFlags Flags, SCEVWrapPredicate::IncrementWrapFlags OnFlags) |
static SCEVWrapPredicate::IncrementWrapFlags | getImpliedFlags (const SCEVAddRecExpr *AR, ScalarEvolution &SE) |
Returns the set of SCEVWrapPredicate no wrap flags implied by a SCEVAddRecExpr. | |
static bool | classof (const SCEVPredicate *P) |
Methods for support type inquiry through isa, cast, and dyn_cast: | |
Additional Inherited Members | |
Protected Member Functions inherited from llvm::SCEVPredicate | |
~SCEVPredicate ()=default | |
SCEVPredicate (const SCEVPredicate &)=default | |
SCEVPredicate & | operator= (const SCEVPredicate &)=default |
Protected Attributes inherited from llvm::SCEVPredicate | |
SCEVPredicateKind | Kind |
This class represents an assumption made on an AddRec expression.
Given an affine AddRec expression {a,+,b}, we assume that it has the nssw or nusw flags (defined below) in the first X iterations of the loop, where X is a SCEV expression returned by getPredicatedBackedgeTakenCount).
Note that this does not imply that X is equal to the backedge taken count. This means that if we have a nusw predicate for i32 {0,+,1} with a predicated backedge taken count of X, we only guarantee that {0,+,1} has nusw in the first X iterations. {0,+,1} may still wrap in the loop if we have more than X iterations.
Definition at line 317 of file ScalarEvolution.h.
Similar to SCEV::NoWrapFlags, but with slightly different semantics for FlagNUSW.
The increment is considered to be signed, and a + b (where b is the increment) is considered to wrap if: zext(a + b) != zext(a) + sext(b)
If Signed is a function that takes an n-bit tuple and maps to the integer domain as the tuples value interpreted as twos complement, and Unsigned a function that takes an n-bit tuple and maps to the integer domain as the base two value of input tuple, then a + b has IncrementNUSW iff:
0 <= Unsigned(a) + Signed(b) < 2^n
The IncrementNSSW flag has identical semantics with SCEV::FlagNSW.
Note that the IncrementNUSW flag is not commutative: if base + inc has IncrementNUSW, then inc + base doesn't neccessarily have this property. The reason for this is that this is used for sign/zero extending affine AddRec SCEV expressions when a SCEVWrapPredicate is assumed. A {base,+,inc} expression is already non-commutative with regards to base and inc, since it is interpreted as: (((base + inc) + inc) + inc) ...
Enumerator | |
---|---|
IncrementAnyWrap | |
IncrementNUSW | |
IncrementNSSW | |
IncrementNoWrapMask |
Definition at line 341 of file ScalarEvolution.h.
|
explicit |
Definition at line 14802 of file ScalarEvolution.cpp.
|
inlinestatic |
Methods for support type inquiry through isa, cast, and dyn_cast:
Definition at line 401 of file ScalarEvolution.h.
References P, and llvm::SCEVPredicate::P_Wrap.
|
inlinestatic |
Convenient IncrementWrapFlags manipulation methods.
Definition at line 351 of file ScalarEvolution.h.
References assert(), and IncrementNoWrapMask.
Referenced by llvm::PredicatedScalarEvolution::hasNoOverflow(), isAlwaysTrue(), and llvm::PredicatedScalarEvolution::setNoOverflow().
const SCEVAddRecExpr * SCEVWrapPredicate::getExpr | ( | ) | const |
Implementation of the SCEVPredicate interface.
Definition at line 14807 of file ScalarEvolution.cpp.
Referenced by llvm::SCEVExpander::expandWrapPredicate(), and print().
|
inline |
Returns the set assumed no overflow flags.
Definition at line 392 of file ScalarEvolution.h.
Referenced by llvm::SCEVExpander::expandWrapPredicate(), and print().
|
static |
Returns the set of SCEVWrapPredicate no wrap flags implied by a SCEVAddRecExpr.
Definition at line 14835 of file ScalarEvolution.cpp.
References llvm::SCEV::FlagNSW, llvm::SCEV::FlagNUW, llvm::SCEVNAryExpr::getNoWrapFlags(), llvm::SCEVAddRecExpr::getStepRecurrence(), IncrementAnyWrap, IncrementNSSW, IncrementNUSW, llvm::ScalarEvolution::setFlags(), and setFlags().
Referenced by llvm::PredicatedScalarEvolution::hasNoOverflow(), and llvm::PredicatedScalarEvolution::setNoOverflow().
|
overridevirtual |
Returns true if this predicate implies N
.
Implements llvm::SCEVPredicate.
Definition at line 14809 of file ScalarEvolution.cpp.
References N, and setFlags().
|
overridevirtual |
Returns true if the predicate is always true.
This means that no assumptions were made and nothing needs to be checked at run-time.
Implements llvm::SCEVPredicate.
Definition at line 14815 of file ScalarEvolution.cpp.
References clearFlags(), llvm::SCEV::FlagNSW, llvm::SCEVNAryExpr::getNoWrapFlags(), IncrementAnyWrap, IncrementNSSW, and llvm::ScalarEvolution::setFlags().
|
inlinestatic |
Definition at line 360 of file ScalarEvolution.h.
References assert(), and IncrementNoWrapMask.
|
overridevirtual |
Prints a textual representation of this predicate with an indentation of Depth
.
Implements llvm::SCEVPredicate.
Definition at line 14825 of file ScalarEvolution.cpp.
References llvm::Depth, getExpr(), getFlags(), IncrementNSSW, IncrementNUSW, llvm::raw_ostream::indent(), and OS.
|
inlinestatic |
Definition at line 368 of file ScalarEvolution.h.
References assert(), and IncrementNoWrapMask.
Referenced by getImpliedFlags(), implies(), and llvm::PredicatedScalarEvolution::setNoOverflow().