LLVM 23.0.0git
ScalarEvolution.h
Go to the documentation of this file.
1//===- llvm/Analysis/ScalarEvolution.h - Scalar Evolution -------*- C++ -*-===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8//
9// The ScalarEvolution class is an LLVM pass which can be used to analyze and
10// categorize scalar expressions in loops. It specializes in recognizing
11// general induction variables, representing them with the abstract and opaque
12// SCEV class. Given this analysis, trip counts of loops and other important
13// properties can be obtained.
14//
15// This analysis is primarily useful for induction variable substitution and
16// strength reduction.
17//
18//===----------------------------------------------------------------------===//
19
20#ifndef LLVM_ANALYSIS_SCALAREVOLUTION_H
21#define LLVM_ANALYSIS_SCALAREVOLUTION_H
22
23#include "llvm/ADT/APInt.h"
24#include "llvm/ADT/ArrayRef.h"
26#include "llvm/ADT/DenseMap.h"
28#include "llvm/ADT/FoldingSet.h"
30#include "llvm/ADT/SetVector.h"
35#include "llvm/IR/PassManager.h"
36#include "llvm/IR/ValueHandle.h"
37#include "llvm/IR/ValueMap.h"
38#include "llvm/Pass.h"
40#include <cassert>
41#include <cstdint>
42#include <memory>
43#include <optional>
44#include <utility>
45
46namespace llvm {
47
49class AssumptionCache;
50class BasicBlock;
51class Constant;
52class ConstantInt;
53class DataLayout;
54class DominatorTree;
55class GEPOperator;
56class LLVMContext;
57class Loop;
58class LoopInfo;
59class raw_ostream;
60class ScalarEvolution;
61class SCEVAddRecExpr;
62class SCEVUnknown;
63class StructType;
65class Type;
66enum SCEVTypes : unsigned short;
67
68LLVM_ABI extern bool VerifySCEV;
69
70/// NoWrapFlags are bitfield indices into SCEV's SubclassData.
71///
72/// Add and Mul expressions may have no-unsigned-wrap <NUW> or
73/// no-signed-wrap <NSW> properties, which are derived from the IR
74/// operator. NSW is a misnomer that we use to mean no signed overflow or
75/// underflow. NUW and NSW must hold for all subsets and orders of
76/// Add/Mul operands. That is, in `(a + b + c)<nsw>`, all of `a + b`,
77/// `b + c`, `a + c` must be nsw as well.
78///
79/// AddRec expressions may have a no-self-wraparound <NW> property if, in
80/// the integer domain, abs(step) * max-iteration(loop) <=
81/// unsigned-max(bitwidth). This means that the recurrence will never reach
82/// its start value if the step is non-zero. Computing the same value on
83/// each iteration is not considered wrapping, and recurrences with step = 0
84/// are trivially <NW>. <NW> is independent of the sign of step and the
85/// value the add recurrence starts with.
86///
87/// Note that NUW and NSW are also valid properties of a recurrence, and
88/// either implies NW. For convenience, NW will be set for a recurrence
89/// whenever either NUW or NSW are set.
90///
91/// We require that the flag on a SCEV apply to the entire scope in which
92/// that SCEV is defined. A SCEV's scope is set of locations dominated by
93/// a defining location, which is in turn described by the following rules:
94/// * A SCEVUnknown is at the point of definition of the Value.
95/// * A SCEVConstant is defined at all points.
96/// * A SCEVAddRec is defined starting with the header of the associated
97/// loop.
98/// * All other SCEVs are defined at the earlest point all operands are
99/// defined.
100///
101/// The above rules describe a maximally hoisted form (without regards to
102/// potential control dependence). A SCEV is defined anywhere a
103/// corresponding instruction could be defined in said maximally hoisted
104/// form. Note that SCEVUDivExpr (currently the only expression type which
105/// can trap) can be defined per these rules in regions where it would trap
106/// at runtime. A SCEV being defined does not require the existence of any
107/// instruction within the defined scope.
108enum class SCEVNoWrapFlags {
109 FlagAnyWrap = 0, // No guarantee.
110 FlagNW = (1 << 0), // No self-wrap.
111 FlagNUW = (1 << 1), // No unsigned wrap.
112 FlagNSW = (1 << 2), // No signed wrap.
113 NoWrapMask = (1 << 3) - 1,
114 LLVM_MARK_AS_BITMASK_ENUM(/*LargestValue=*/NoWrapMask)
115};
116
117class SCEV;
118
119template <typename SCEVPtrT = const SCEV *>
120struct SCEVUseT : private PointerIntPair<SCEVPtrT, 2> {
123 using Base::getPointer;
124
125 SCEVUseT() : Base(nullptr, 0) {}
126 SCEVUseT(SCEVPtrT S) : Base(S, 0) {}
127 /// Construct with NoWrapFlags; only NUW/NSW are encoded, NW is dropped.
128 SCEVUseT(SCEVPtrT S, SCEVNoWrapFlags Flags)
129 : Base(S, static_cast<unsigned>(Flags) >> 1) {}
130 template <typename OtherPtrT, typename = std::enable_if_t<
131 std::is_convertible_v<OtherPtrT, SCEVPtrT>>>
134
135 operator SCEVPtrT() const { return getPointer(); }
136 SCEVPtrT operator->() const { return getPointer(); }
137
138 /// Returns true if the SCEVUse is canonical, i.e. no SCEVUse flags set in any
139 /// operands.
140 bool isCanonical() const { return getCanonical() == getOpaqueValue(); }
141
142 /// Return the canonical SCEV for this SCEVUse.
143 const SCEV *getCanonical() const;
144
145 /// Return the no-wrap flags for this SCEVUse, which is the union of the
146 /// use-specific flags and the underlying SCEV's flags, masked by \p Mask.
149
150 /// Return only the use-specific no-wrap flags (NUW/NSW) without the
151 /// underlying SCEV's flags.
153 SCEVNoWrapFlags UseFlags =
154 static_cast<SCEVNoWrapFlags>(Base::getInt() << 1);
156 UseFlags |= SCEVNoWrapFlags::FlagNW;
157 return UseFlags;
158 }
159
160 bool operator==(const SCEVUseT &RHS) const {
161 return getOpaqueValue() == RHS.getOpaqueValue();
162 }
163
164 bool operator!=(const SCEVUseT &RHS) const { return !(*this == RHS); }
165
166 bool operator>(const SCEVUseT &RHS) const { return Base::operator>(RHS); }
167
168 bool operator==(const SCEV *RHS) const { return getOpaqueValue() == RHS; }
169 bool operator!=(const SCEV *RHS) const { return getOpaqueValue() != RHS; }
170
171 /// Print out the internal representation of this scalar to the specified
172 /// stream. This should really only be used for debugging purposes.
173 void print(raw_ostream &OS) const;
174
175 /// This method is used for debugging.
176 void dump() const;
177
178private:
180 friend struct PointerLikeTypeTraits<SCEVUseT>;
181};
182
183/// Deduction guide for various SCEV subclass pointers.
184template <typename SCEVPtrT> SCEVUseT(SCEVPtrT) -> SCEVUseT<SCEVPtrT>;
185
187
188/// Provide PointerLikeTypeTraits for SCEVUse, so it can be used with
189/// SmallPtrSet, among others.
190template <> struct PointerLikeTypeTraits<SCEVUse> {
191 static inline void *getAsVoidPointer(SCEVUse U) { return U.getOpaqueValue(); }
192 static inline SCEVUse getFromVoidPointer(void *P) {
193 SCEVUse U;
194 U.setFromOpaqueValue(P);
195 return U;
196 }
197
198 /// The Low bits are used by the PointerIntPair.
199 static constexpr int NumLowBitsAvailable = 0;
200};
201
202template <> struct DenseMapInfo<SCEVUse> {
203 static inline SCEVUse getEmptyKey() {
204 uintptr_t Val = static_cast<uintptr_t>(-1);
206 }
207
208 static inline SCEVUse getTombstoneKey() {
209 uintptr_t Val = static_cast<uintptr_t>(-2);
211 }
212
213 static unsigned getHashValue(SCEVUse U) {
214 return hash_value(U.getOpaqueValue());
215 }
216
217 static bool isEqual(const SCEVUse LHS, const SCEVUse RHS) {
218 return LHS.getOpaqueValue() == RHS.getOpaqueValue();
219 }
220};
221
222template <> struct simplify_type<SCEVUse> {
223 using SimpleType = const SCEV *;
224
226 return Val.getPointer();
227 }
228};
229
230/// Provide CastInfo for SCEVUseT so that cast<SCEVUseT<const To *>>(use)
231/// returns SCEVUseT<const To *> with flags preserved.
232template <typename ToSCEVPtrT>
233struct CastInfo<SCEVUseT<ToSCEVPtrT>, SCEVUse,
234 std::enable_if_t<!is_simple_type<SCEVUse>::value>> {
235 using To = std::remove_cv_t<std::remove_pointer_t<ToSCEVPtrT>>;
237
238 static bool isPossible(const SCEVUse &U) { return isa<To>(U.getPointer()); }
239 static CastReturnType doCast(const SCEVUse &U) {
240 return CastReturnType(cast<To>(U.getPointer()), U.getUseNoWrapFlags());
241 }
242 static CastReturnType castFailed() { return CastReturnType(nullptr); }
244 if (!isPossible(U))
245 return castFailed();
246 return doCast(U);
247 }
248};
249
250template <typename ToSCEVPtrT>
251struct CastInfo<SCEVUseT<ToSCEVPtrT>, const SCEVUse,
252 std::enable_if_t<!is_simple_type<const SCEVUse>::value>>
253 : CastInfo<SCEVUseT<ToSCEVPtrT>, SCEVUse> {};
254
255/// This class represents an analyzed expression in the program. These are
256/// opaque objects that the client is not allowed to do much with directly.
257///
258class SCEV : public FoldingSetNode {
259 friend struct FoldingSetTrait<SCEV>;
260
261 /// A reference to an Interned FoldingSetNodeID for this node. The
262 /// ScalarEvolution's BumpPtrAllocator holds the data.
263 FoldingSetNodeIDRef FastID;
264
265 // The SCEV baseclass this node corresponds to
266 const SCEVTypes SCEVType;
267
268protected:
269 // Estimated complexity of this node's expression tree size.
270 const unsigned short ExpressionSize;
271
272 /// This field is initialized to zero and may be used in subclasses to store
273 /// miscellaneous information.
274 unsigned short SubclassData = 0;
275
276 /// Pointer to the canonical version of the SCEV, i.e. one where all operands
277 /// have no SCEVUse flags.
278 const SCEV *CanonicalSCEV = nullptr;
279
280public:
283 static constexpr auto FlagNW = SCEVNoWrapFlags::FlagNW;
284 static constexpr auto FlagNUW = SCEVNoWrapFlags::FlagNUW;
285 static constexpr auto FlagNSW = SCEVNoWrapFlags::FlagNSW;
287
288 explicit SCEV(const FoldingSetNodeIDRef ID, SCEVTypes SCEVTy,
289 unsigned short ExpressionSize)
290 : FastID(ID), SCEVType(SCEVTy), ExpressionSize(ExpressionSize) {}
291 SCEV(const SCEV &) = delete;
292 SCEV &operator=(const SCEV &) = delete;
293
294 SCEVTypes getSCEVType() const { return SCEVType; }
295
296 /// Return the LLVM type of this SCEV expression.
297 LLVM_ABI Type *getType() const;
298
299 /// Return operands of this SCEV expression.
301
302 /// Return true if the expression is a constant zero.
303 LLVM_ABI bool isZero() const;
304
305 /// Return true if the expression is a constant one.
306 LLVM_ABI bool isOne() const;
307
308 /// Return true if the expression is a constant all-ones value.
309 LLVM_ABI bool isAllOnesValue() const;
310
311 /// Return true if the specified scev is negated, but not a constant.
312 LLVM_ABI bool isNonConstantNegative() const;
313
314 // Returns estimated size of the mathematical expression represented by this
315 // SCEV. The rules of its calculation are following:
316 // 1) Size of a SCEV without operands (like constants and SCEVUnknown) is 1;
317 // 2) Size SCEV with operands Op1, Op2, ..., OpN is calculated by formula:
318 // (1 + Size(Op1) + ... + Size(OpN)).
319 // This value gives us an estimation of time we need to traverse through this
320 // SCEV and all its operands recursively. We may use it to avoid performing
321 // heavy transformations on SCEVs of excessive size for sake of saving the
322 // compilation time.
323 unsigned short getExpressionSize() const {
324 return ExpressionSize;
325 }
326
327 /// Print out the internal representation of this scalar to the specified
328 /// stream. This should really only be used for debugging purposes.
329 LLVM_ABI void print(raw_ostream &OS) const;
330
331 /// This method is used for debugging.
332 LLVM_ABI void dump() const;
333
334 /// Compute and set the canonical SCEV, by constructing a SCEV with the same
335 /// operands, but all SCEVUse flags dropped.
337
338 /// Return the canonical SCEV.
339 LLVM_ABI const SCEV *getCanonical() const {
340 assert(CanonicalSCEV && "canonical SCEV not yet computed");
341 return CanonicalSCEV;
342 }
343};
344
345// Specialize FoldingSetTrait for SCEV to avoid needing to compute
346// temporary FoldingSetNodeID values.
347template <> struct FoldingSetTrait<SCEV> : DefaultFoldingSetTrait<SCEV> {
348 static void Profile(const SCEV &X, FoldingSetNodeID &ID) { ID = X.FastID; }
349
350 static bool Equals(const SCEV &X, const FoldingSetNodeID &ID, unsigned IDHash,
351 FoldingSetNodeID &TempID) {
352 return ID == X.FastID;
353 }
354
355 static unsigned ComputeHash(const SCEV &X, FoldingSetNodeID &TempID) {
356 return X.FastID.ComputeHash();
357 }
358};
359
360inline raw_ostream &operator<<(raw_ostream &OS, const SCEV &S) {
361 S.print(OS);
362 return OS;
363}
364
366 U.print(OS);
367 return OS;
368}
369
370/// An object of this class is returned by queries that could not be answered.
371/// For example, if you ask for the number of iterations of a linked-list
372/// traversal loop, you will get one of these. None of the standard SCEV
373/// operations are valid on this class, it is just a marker.
374struct SCEVCouldNotCompute : public SCEV {
376
377 /// Methods for support type inquiry through isa, cast, and dyn_cast:
378 LLVM_ABI static bool classof(const SCEV *S);
379};
380
381/// This class represents an assumption made using SCEV expressions which can
382/// be checked at run-time.
384 friend struct FoldingSetTrait<SCEVPredicate>;
385
386 /// A reference to an Interned FoldingSetNodeID for this node. The
387 /// ScalarEvolution's BumpPtrAllocator holds the data.
388 FoldingSetNodeIDRef FastID;
389
390public:
392
393protected:
395 ~SCEVPredicate() = default;
396 SCEVPredicate(const SCEVPredicate &) = default;
398
399public:
401
402 SCEVPredicateKind getKind() const { return Kind; }
403
404 /// Returns the estimated complexity of this predicate. This is roughly
405 /// measured in the number of run-time checks required.
406 virtual unsigned getComplexity() const { return 1; }
407
408 /// Returns true if the predicate is always true. This means that no
409 /// assumptions were made and nothing needs to be checked at run-time.
410 virtual bool isAlwaysTrue() const = 0;
411
412 /// Returns true if this predicate implies \p N.
413 virtual bool implies(const SCEVPredicate *N, ScalarEvolution &SE) const = 0;
414
415 /// Prints a textual representation of this predicate with an indentation of
416 /// \p Depth.
417 virtual void print(raw_ostream &OS, unsigned Depth = 0) const = 0;
418};
419
421 P.print(OS);
422 return OS;
423}
424
425// Specialize FoldingSetTrait for SCEVPredicate to avoid needing to compute
426// temporary FoldingSetNodeID values.
427template <>
429 static void Profile(const SCEVPredicate &X, FoldingSetNodeID &ID) {
430 ID = X.FastID;
431 }
432
433 static bool Equals(const SCEVPredicate &X, const FoldingSetNodeID &ID,
434 unsigned IDHash, FoldingSetNodeID &TempID) {
435 return ID == X.FastID;
436 }
437
438 static unsigned ComputeHash(const SCEVPredicate &X,
439 FoldingSetNodeID &TempID) {
440 return X.FastID.ComputeHash();
441 }
442};
443
444/// This class represents an assumption that the expression LHS Pred RHS
445/// evaluates to true, and this can be checked at run-time.
447 /// We assume that LHS Pred RHS is true.
448 const ICmpInst::Predicate Pred;
449 const SCEV *LHS;
450 const SCEV *RHS;
451
452public:
454 const ICmpInst::Predicate Pred,
455 const SCEV *LHS, const SCEV *RHS);
456
457 /// Implementation of the SCEVPredicate interface
458 bool implies(const SCEVPredicate *N, ScalarEvolution &SE) const override;
459 void print(raw_ostream &OS, unsigned Depth = 0) const override;
460 bool isAlwaysTrue() const override;
461
462 ICmpInst::Predicate getPredicate() const { return Pred; }
463
464 /// Returns the left hand side of the predicate.
465 const SCEV *getLHS() const { return LHS; }
466
467 /// Returns the right hand side of the predicate.
468 const SCEV *getRHS() const { return RHS; }
469
470 /// Methods for support type inquiry through isa, cast, and dyn_cast:
471 static bool classof(const SCEVPredicate *P) {
472 return P->getKind() == P_Compare;
473 }
474};
475
476/// This class represents an assumption made on an AddRec expression. Given an
477/// affine AddRec expression {a,+,b}, we assume that it has the nssw or nusw
478/// flags (defined below) in the first X iterations of the loop, where X is a
479/// SCEV expression returned by getPredicatedBackedgeTakenCount).
480///
481/// Note that this does not imply that X is equal to the backedge taken
482/// count. This means that if we have a nusw predicate for i32 {0,+,1} with a
483/// predicated backedge taken count of X, we only guarantee that {0,+,1} has
484/// nusw in the first X iterations. {0,+,1} may still wrap in the loop if we
485/// have more than X iterations.
487public:
488 /// Similar to SCEV::NoWrapFlags, but with slightly different semantics
489 /// for FlagNUSW. The increment is considered to be signed, and a + b
490 /// (where b is the increment) is considered to wrap if:
491 /// zext(a + b) != zext(a) + sext(b)
492 ///
493 /// If Signed is a function that takes an n-bit tuple and maps to the
494 /// integer domain as the tuples value interpreted as twos complement,
495 /// and Unsigned a function that takes an n-bit tuple and maps to the
496 /// integer domain as the base two value of input tuple, then a + b
497 /// has IncrementNUSW iff:
498 ///
499 /// 0 <= Unsigned(a) + Signed(b) < 2^n
500 ///
501 /// The IncrementNSSW flag has identical semantics with SCEV::FlagNSW.
502 ///
503 /// Note that the IncrementNUSW flag is not commutative: if base + inc
504 /// has IncrementNUSW, then inc + base doesn't neccessarily have this
505 /// property. The reason for this is that this is used for sign/zero
506 /// extending affine AddRec SCEV expressions when a SCEVWrapPredicate is
507 /// assumed. A {base,+,inc} expression is already non-commutative with
508 /// regards to base and inc, since it is interpreted as:
509 /// (((base + inc) + inc) + inc) ...
511 IncrementAnyWrap = 0, // No guarantee.
512 IncrementNUSW = (1 << 0), // No unsigned with signed increment wrap.
513 IncrementNSSW = (1 << 1), // No signed with signed increment wrap
514 // (equivalent with SCEV::NSW)
515 IncrementNoWrapMask = (1 << 2) - 1
516 };
517
518 /// Convenient IncrementWrapFlags manipulation methods.
519 [[nodiscard]] static SCEVWrapPredicate::IncrementWrapFlags
522 assert((Flags & IncrementNoWrapMask) == Flags && "Invalid flags value!");
523 assert((OffFlags & IncrementNoWrapMask) == OffFlags &&
524 "Invalid flags value!");
525 return (SCEVWrapPredicate::IncrementWrapFlags)(Flags & ~OffFlags);
526 }
527
528 [[nodiscard]] static SCEVWrapPredicate::IncrementWrapFlags
530 assert((Flags & IncrementNoWrapMask) == Flags && "Invalid flags value!");
531 assert((Mask & IncrementNoWrapMask) == Mask && "Invalid mask value!");
532
533 return (SCEVWrapPredicate::IncrementWrapFlags)(Flags & Mask);
534 }
535
536 [[nodiscard]] static SCEVWrapPredicate::IncrementWrapFlags
539 assert((Flags & IncrementNoWrapMask) == Flags && "Invalid flags value!");
540 assert((OnFlags & IncrementNoWrapMask) == OnFlags &&
541 "Invalid flags value!");
542
543 return (SCEVWrapPredicate::IncrementWrapFlags)(Flags | OnFlags);
544 }
545
546 /// Returns the set of SCEVWrapPredicate no wrap flags implied by a
547 /// SCEVAddRecExpr.
548 [[nodiscard]] static SCEVWrapPredicate::IncrementWrapFlags
549 getImpliedFlags(const SCEVAddRecExpr *AR, ScalarEvolution &SE);
550
551private:
552 const SCEVAddRecExpr *AR;
553 IncrementWrapFlags Flags;
554
555public:
557 const SCEVAddRecExpr *AR,
558 IncrementWrapFlags Flags);
559
560 /// Returns the set assumed no overflow flags.
561 IncrementWrapFlags getFlags() const { return Flags; }
562
563 /// Implementation of the SCEVPredicate interface
564 const SCEVAddRecExpr *getExpr() const;
565 bool implies(const SCEVPredicate *N, ScalarEvolution &SE) const override;
566 void print(raw_ostream &OS, unsigned Depth = 0) const override;
567 bool isAlwaysTrue() const override;
568
569 /// Methods for support type inquiry through isa, cast, and dyn_cast:
570 static bool classof(const SCEVPredicate *P) {
571 return P->getKind() == P_Wrap;
572 }
573};
574
575/// This class represents a composition of other SCEV predicates, and is the
576/// class that most clients will interact with. This is equivalent to a
577/// logical "AND" of all the predicates in the union.
578///
579/// NB! Unlike other SCEVPredicate sub-classes this class does not live in the
580/// ScalarEvolution::Preds folding set. This is why the \c add function is sound.
582private:
583 using PredicateMap =
585
586 /// Vector with references to all predicates in this union.
588
589 /// Adds a predicate to this union.
590 void add(const SCEVPredicate *N, ScalarEvolution &SE);
591
592public:
594 ScalarEvolution &SE);
595
597
598 /// Returns a new SCEVUnionPredicate that is the union of this predicate
599 /// and the given predicate \p N.
601 ScalarEvolution &SE) const {
602 SCEVUnionPredicate Result(Preds, SE);
603 Result.add(N, SE);
604 return Result;
605 }
606
607 /// Implementation of the SCEVPredicate interface
608 bool isAlwaysTrue() const override;
609 bool implies(const SCEVPredicate *N, ScalarEvolution &SE) const override;
610 void print(raw_ostream &OS, unsigned Depth) const override;
611
612 /// We estimate the complexity of a union predicate as the size number of
613 /// predicates in the union.
614 unsigned getComplexity() const override { return Preds.size(); }
615
616 /// Methods for support type inquiry through isa, cast, and dyn_cast:
617 static bool classof(const SCEVPredicate *P) {
618 return P->getKind() == P_Union;
619 }
620};
621
622/// The main scalar evolution driver. Because client code (intentionally)
623/// can't do much with the SCEV objects directly, they must ask this class
624/// for services.
627
628public:
629 /// An enum describing the relationship between a SCEV and a loop.
631 LoopVariant, ///< The SCEV is loop-variant (unknown).
632 LoopInvariant, ///< The SCEV is loop-invariant.
633 LoopComputable ///< The SCEV varies predictably with the loop.
634 };
635
636 /// An enum describing the relationship between a SCEV and a basic block.
638 DoesNotDominateBlock, ///< The SCEV does not dominate the block.
639 DominatesBlock, ///< The SCEV dominates the block.
640 ProperlyDominatesBlock ///< The SCEV properly dominates the block.
641 };
642
643 /// Convenient NoWrapFlags manipulation. TODO: Replace with & operator of
644 /// enum class.
646 SCEV::NoWrapFlags Mask) {
647 return Flags & Mask;
648 }
649 [[nodiscard]] static SCEV::NoWrapFlags setFlags(SCEV::NoWrapFlags Flags,
650 SCEV::NoWrapFlags OnFlags) {
651 return Flags | OnFlags;
652 }
653 [[nodiscard]] static SCEV::NoWrapFlags
655 return Flags & ~OffFlags;
656 }
657 [[nodiscard]] static bool hasFlags(SCEV::NoWrapFlags Flags,
658 SCEV::NoWrapFlags TestFlags) {
659 return TestFlags == maskFlags(Flags, TestFlags);
660 };
661
664 LoopInfo &LI);
667
668 LLVMContext &getContext() const { return F.getContext(); }
669
670 /// Test if values of the given type are analyzable within the SCEV
671 /// framework. This primarily includes integer types, and it can optionally
672 /// include pointer types if the ScalarEvolution class has access to
673 /// target-specific information.
674 LLVM_ABI bool isSCEVable(Type *Ty) const;
675
676 /// Return the size in bits of the specified type, for which isSCEVable must
677 /// return true.
679
680 /// Return a type with the same bitwidth as the given type and which
681 /// represents how SCEV will treat the given type, for which isSCEVable must
682 /// return true. For pointer types, this is the pointer-sized integer type.
684
685 // Returns a wider type among {Ty1, Ty2}.
686 LLVM_ABI Type *getWiderType(Type *Ty1, Type *Ty2) const;
687
688 /// Return true if there exists a point in the program at which both
689 /// A and B could be operands to the same instruction.
690 /// SCEV expressions are generally assumed to correspond to instructions
691 /// which could exists in IR. In general, this requires that there exists
692 /// a use point in the program where all operands dominate the use.
693 ///
694 /// Example:
695 /// loop {
696 /// if
697 /// loop { v1 = load @global1; }
698 /// else
699 /// loop { v2 = load @global2; }
700 /// }
701 /// No SCEV with operand V1, and v2 can exist in this program.
703
704 /// Return true if the SCEV is a scAddRecExpr or it contains
705 /// scAddRecExpr. The result will be cached in HasRecMap.
706 LLVM_ABI bool containsAddRecurrence(const SCEV *S);
707
708 /// Is operation \p BinOp between \p LHS and \p RHS provably does not have
709 /// a signed/unsigned overflow (\p Signed)? If \p CtxI is specified, the
710 /// no-overflow fact should be true in the context of this instruction.
712 const SCEV *LHS, const SCEV *RHS,
713 const Instruction *CtxI = nullptr);
714
715 /// Parse NSW/NUW flags from add/sub/mul IR binary operation \p Op into
716 /// SCEV no-wrap flags, and deduce flag[s] that aren't known yet.
717 /// Does not mutate the original instruction. Returns std::nullopt if it could
718 /// not deduce more precise flags than the instruction already has, otherwise
719 /// returns proven flags.
720 LLVM_ABI std::optional<SCEV::NoWrapFlags>
722
723 /// Notify this ScalarEvolution that \p User directly uses SCEVs in \p Ops.
726
727 /// Return true if the SCEV expression contains an undef value.
728 LLVM_ABI bool containsUndefs(const SCEV *S) const;
729
730 /// Return true if the SCEV expression contains a Value that has been
731 /// optimised out and is now a nullptr.
732 LLVM_ABI bool containsErasedValue(const SCEV *S) const;
733
734 /// Return a SCEV expression for the full generality of the specified
735 /// expression.
736 LLVM_ABI const SCEV *getSCEV(Value *V);
737
738 /// Return an existing SCEV for V if there is one, otherwise return nullptr.
740
742 LLVM_ABI const SCEV *getConstant(const APInt &Val);
743 LLVM_ABI const SCEV *getConstant(Type *Ty, uint64_t V, bool isSigned = false);
745
746 LLVM_ABI const SCEV *getPtrToAddrExpr(const SCEV *Op);
747 LLVM_ABI const SCEV *getPtrToIntExpr(const SCEV *Op, Type *Ty);
748 LLVM_ABI const SCEV *getTruncateExpr(const SCEV *Op, Type *Ty,
749 unsigned Depth = 0);
750 LLVM_ABI const SCEV *getVScale(Type *Ty);
751 LLVM_ABI const SCEV *
754 LLVM_ABI const SCEV *getZeroExtendExpr(const SCEV *Op, Type *Ty,
755 unsigned Depth = 0);
756 LLVM_ABI const SCEV *getZeroExtendExprImpl(const SCEV *Op, Type *Ty,
757 unsigned Depth = 0);
758 LLVM_ABI const SCEV *getSignExtendExpr(const SCEV *Op, Type *Ty,
759 unsigned Depth = 0);
760 LLVM_ABI const SCEV *getSignExtendExprImpl(const SCEV *Op, Type *Ty,
761 unsigned Depth = 0);
762 LLVM_ABI const SCEV *getCastExpr(SCEVTypes Kind, const SCEV *Op, Type *Ty);
763 LLVM_ABI const SCEV *getAnyExtendExpr(const SCEV *Op, Type *Ty);
764
767 unsigned Depth = 0);
770 unsigned Depth = 0) {
772 return getAddExpr(Ops, Flags, Depth);
773 }
774 const SCEV *getAddExpr(SCEVUse Op0, SCEVUse Op1, SCEVUse Op2,
776 unsigned Depth = 0) {
777 SmallVector<SCEVUse, 3> Ops = {Op0, Op1, Op2};
778 return getAddExpr(Ops, Flags, Depth);
779 }
782 unsigned Depth = 0);
785 unsigned Depth = 0) {
787 return getMulExpr(Ops, Flags, Depth);
788 }
789 const SCEV *getMulExpr(SCEVUse Op0, SCEVUse Op1, SCEVUse Op2,
791 unsigned Depth = 0) {
792 SmallVector<SCEVUse, 3> Ops = {Op0, Op1, Op2};
793 return getMulExpr(Ops, Flags, Depth);
794 }
798 LLVM_ABI const SCEV *getAddRecExpr(SCEVUse Start, SCEVUse Step, const Loop *L,
799 SCEV::NoWrapFlags Flags);
801 const Loop *L, SCEV::NoWrapFlags Flags);
803 const Loop *L, SCEV::NoWrapFlags Flags) {
804 SmallVector<SCEVUse, 4> NewOp(Operands.begin(), Operands.end());
805 return getAddRecExpr(NewOp, L, Flags);
806 }
807
808 /// Checks if \p SymbolicPHI can be rewritten as an AddRecExpr under some
809 /// Predicates. If successful return these <AddRecExpr, Predicates>;
810 /// The function is intended to be called from PSCEV (the caller will decide
811 /// whether to actually add the predicates and carry out the rewrites).
812 LLVM_ABI std::optional<
813 std::pair<const SCEV *, SmallVector<const SCEVPredicate *, 3>>>
814 createAddRecFromPHIWithCasts(const SCEVUnknown *SymbolicPHI);
815
816 /// Returns an expression for a GEP
817 ///
818 /// \p GEP The GEP. The indices contained in the GEP itself are ignored,
819 /// instead we use IndexExprs.
820 /// \p IndexExprs The expressions for the indices.
822 ArrayRef<SCEVUse> IndexExprs);
823 LLVM_ABI const SCEV *getGEPExpr(SCEVUse BaseExpr,
824 ArrayRef<SCEVUse> IndexExprs,
825 Type *SrcElementTy,
827 LLVM_ABI const SCEV *getAbsExpr(const SCEV *Op, bool IsNSW);
829 SmallVectorImpl<SCEVUse> &Operands);
830 LLVM_ABI const SCEV *
839 bool Sequential = false);
841 bool Sequential = false);
842 LLVM_ABI const SCEV *getUnknown(Value *V);
844
845 /// Return a SCEV for the constant 0 of a specific type.
846 const SCEV *getZero(Type *Ty) { return getConstant(Ty, 0); }
847
848 /// Return a SCEV for the constant 1 of a specific type.
849 const SCEV *getOne(Type *Ty) { return getConstant(Ty, 1); }
850
851 /// Return a SCEV for the constant \p Power of two.
852 const SCEV *getPowerOfTwo(Type *Ty, unsigned Power) {
853 assert(Power < getTypeSizeInBits(Ty) && "Power out of range");
855 }
856
857 /// Return a SCEV for the constant -1 of a specific type.
858 const SCEV *getMinusOne(Type *Ty) {
859 return getConstant(Ty, -1, /*isSigned=*/true);
860 }
861
862 /// Return an expression for a TypeSize.
864
865 /// Return an expression for the alloc size of AllocTy that is type IntTy
866 LLVM_ABI const SCEV *getSizeOfExpr(Type *IntTy, Type *AllocTy);
867
868 /// Return an expression for the store size of StoreTy that is type IntTy
869 LLVM_ABI const SCEV *getStoreSizeOfExpr(Type *IntTy, Type *StoreTy);
870
871 /// Return an expression for offsetof on the given field with type IntTy
872 LLVM_ABI const SCEV *getOffsetOfExpr(Type *IntTy, StructType *STy,
873 unsigned FieldNo);
874
875 /// Return the SCEV object corresponding to -V.
876 LLVM_ABI const SCEV *
878
879 /// Return the SCEV object corresponding to ~V.
880 LLVM_ABI const SCEV *getNotSCEV(const SCEV *V);
881
882 /// Return LHS-RHS. Minus is represented in SCEV as A+B*-1.
883 ///
884 /// If the LHS and RHS are pointers which don't share a common base
885 /// (according to getPointerBase()), this returns a SCEVCouldNotCompute.
886 /// To compute the difference between two unrelated pointers, you can
887 /// explicitly convert the arguments using getPtrToIntExpr(), for pointer
888 /// types that support it.
891 unsigned Depth = 0);
892
893 /// Compute ceil(N / D). N and D are treated as unsigned values.
894 ///
895 /// Since SCEV doesn't have native ceiling division, this generates a
896 /// SCEV expression of the following form:
897 ///
898 /// umin(N, 1) + floor((N - umin(N, 1)) / D)
899 ///
900 /// A denominator of zero or poison is handled the same way as getUDivExpr().
901 LLVM_ABI const SCEV *getUDivCeilSCEV(const SCEV *N, const SCEV *D);
902
903 /// Return a SCEV corresponding to a conversion of the input value to the
904 /// specified type. If the type must be extended, it is zero extended.
905 LLVM_ABI const SCEV *getTruncateOrZeroExtend(const SCEV *V, Type *Ty,
906 unsigned Depth = 0);
907
908 /// Return a SCEV corresponding to a conversion of the input value to the
909 /// specified type. If the type must be extended, it is sign extended.
910 LLVM_ABI const SCEV *getTruncateOrSignExtend(const SCEV *V, Type *Ty,
911 unsigned Depth = 0);
912
913 /// Return a SCEV corresponding to a conversion of the input value to the
914 /// specified type. If the type must be extended, it is zero extended. The
915 /// conversion must not be narrowing.
916 LLVM_ABI const SCEV *getNoopOrZeroExtend(const SCEV *V, Type *Ty);
917
918 /// Return a SCEV corresponding to a conversion of the input value to the
919 /// specified type. If the type must be extended, it is sign extended. The
920 /// conversion must not be narrowing.
921 LLVM_ABI const SCEV *getNoopOrSignExtend(const SCEV *V, Type *Ty);
922
923 /// Return a SCEV corresponding to a conversion of the input value to the
924 /// specified type. If the type must be extended, it is extended with
925 /// unspecified bits. The conversion must not be narrowing.
926 LLVM_ABI const SCEV *getNoopOrAnyExtend(const SCEV *V, Type *Ty);
927
928 /// Return a SCEV corresponding to a conversion of the input value to the
929 /// specified type. The conversion must not be widening.
930 LLVM_ABI const SCEV *getTruncateOrNoop(const SCEV *V, Type *Ty);
931
932 /// Promote the operands to the wider of the types using zero-extension, and
933 /// then perform a umax operation with them.
935 const SCEV *RHS);
936
937 /// Promote the operands to the wider of the types using zero-extension, and
938 /// then perform a umin operation with them.
940 const SCEV *RHS,
941 bool Sequential = false);
942
943 /// Promote the operands to the wider of the types using zero-extension, and
944 /// then perform a umin operation with them. N-ary function.
946 bool Sequential = false);
947
948 /// Transitively follow the chain of pointer-type operands until reaching a
949 /// SCEV that does not have a single pointer operand. This returns a
950 /// SCEVUnknown pointer for well-formed pointer-type expressions, but corner
951 /// cases do exist.
952 LLVM_ABI const SCEV *getPointerBase(const SCEV *V);
953
954 /// Compute an expression equivalent to S - getPointerBase(S).
955 LLVM_ABI const SCEV *removePointerBase(const SCEV *S);
956
957 /// Return a SCEV expression for the specified value at the specified scope
958 /// in the program. The L value specifies a loop nest to evaluate the
959 /// expression at, where null is the top-level or a specified loop is
960 /// immediately inside of the loop.
961 ///
962 /// This method can be used to compute the exit value for a variable defined
963 /// in a loop by querying what the value will hold in the parent loop.
964 ///
965 /// In the case that a relevant loop exit value cannot be computed, the
966 /// original value V is returned.
967 LLVM_ABI const SCEV *getSCEVAtScope(const SCEV *S, const Loop *L);
968
969 /// This is a convenience function which does getSCEVAtScope(getSCEV(V), L).
970 LLVM_ABI const SCEV *getSCEVAtScope(Value *V, const Loop *L);
971
972 /// Test whether entry to the loop is protected by a conditional between LHS
973 /// and RHS. This is used to help avoid max expressions in loop trip
974 /// counts, and to eliminate casts.
976 const SCEV *LHS, const SCEV *RHS);
977
978 /// Test whether entry to the basic block is protected by a conditional
979 /// between LHS and RHS.
981 CmpPredicate Pred,
982 const SCEV *LHS,
983 const SCEV *RHS);
984
985 /// Test whether the backedge of the loop is protected by a conditional
986 /// between LHS and RHS. This is used to eliminate casts.
988 const SCEV *LHS, const SCEV *RHS);
989
990 /// A version of getTripCountFromExitCount below which always picks an
991 /// evaluation type which can not result in overflow.
992 LLVM_ABI const SCEV *getTripCountFromExitCount(const SCEV *ExitCount);
993
994 /// Convert from an "exit count" (i.e. "backedge taken count") to a "trip
995 /// count". A "trip count" is the number of times the header of the loop
996 /// will execute if an exit is taken after the specified number of backedges
997 /// have been taken. (e.g. TripCount = ExitCount + 1). Note that the
998 /// expression can overflow if ExitCount = UINT_MAX. If EvalTy is not wide
999 /// enough to hold the result without overflow, result unsigned wraps with
1000 /// 2s-complement semantics. ex: EC = 255 (i8), TC = 0 (i8)
1001 LLVM_ABI const SCEV *getTripCountFromExitCount(const SCEV *ExitCount,
1002 Type *EvalTy, const Loop *L);
1003
1004 /// Returns the exact trip count of the loop if we can compute it, and
1005 /// the result is a small constant. '0' is used to represent an unknown
1006 /// or non-constant trip count. Note that a trip count is simply one more
1007 /// than the backedge taken count for the loop.
1008 LLVM_ABI unsigned getSmallConstantTripCount(const Loop *L);
1009
1010 /// Return the exact trip count for this loop if we exit through ExitingBlock.
1011 /// '0' is used to represent an unknown or non-constant trip count. Note
1012 /// that a trip count is simply one more than the backedge taken count for
1013 /// the same exit.
1014 /// This "trip count" assumes that control exits via ExitingBlock. More
1015 /// precisely, it is the number of times that control will reach ExitingBlock
1016 /// before taking the branch. For loops with multiple exits, it may not be
1017 /// the number times that the loop header executes if the loop exits
1018 /// prematurely via another branch.
1019 LLVM_ABI unsigned getSmallConstantTripCount(const Loop *L,
1020 const BasicBlock *ExitingBlock);
1021
1022 /// Returns the upper bound of the loop trip count as a normal unsigned
1023 /// value.
1024 /// Returns 0 if the trip count is unknown, not constant or requires
1025 /// SCEV predicates and \p Predicates is nullptr.
1027 const Loop *L,
1028 SmallVectorImpl<const SCEVPredicate *> *Predicates = nullptr);
1029
1030 /// Returns the largest constant divisor of the trip count as a normal
1031 /// unsigned value, if possible. This means that the actual trip count is
1032 /// always a multiple of the returned value. Returns 1 if the trip count is
1033 /// unknown or not guaranteed to be the multiple of a constant., Will also
1034 /// return 1 if the trip count is very large (>= 2^32).
1035 /// Note that the argument is an exit count for loop L, NOT a trip count.
1036 LLVM_ABI unsigned getSmallConstantTripMultiple(const Loop *L,
1037 const SCEV *ExitCount);
1038
1039 /// Returns the largest constant divisor of the trip count of the
1040 /// loop. Will return 1 if no trip count could be computed, or if a
1041 /// divisor could not be found.
1042 LLVM_ABI unsigned getSmallConstantTripMultiple(const Loop *L);
1043
1044 /// Returns the largest constant divisor of the trip count of this loop as a
1045 /// normal unsigned value, if possible. This means that the actual trip
1046 /// count is always a multiple of the returned value (don't forget the trip
1047 /// count could very well be zero as well!). As explained in the comments
1048 /// for getSmallConstantTripCount, this assumes that control exits the loop
1049 /// via ExitingBlock.
1050 LLVM_ABI unsigned
1051 getSmallConstantTripMultiple(const Loop *L, const BasicBlock *ExitingBlock);
1052
1053 /// The terms "backedge taken count" and "exit count" are used
1054 /// interchangeably to refer to the number of times the backedge of a loop
1055 /// has executed before the loop is exited.
1057 /// An expression exactly describing the number of times the backedge has
1058 /// executed when a loop is exited.
1060 /// A constant which provides an upper bound on the exact trip count.
1062 /// An expression which provides an upper bound on the exact trip count.
1064 };
1065
1066 /// Return the number of times the backedge executes before the given exit
1067 /// would be taken; if not exactly computable, return SCEVCouldNotCompute.
1068 /// For a single exit loop, this value is equivelent to the result of
1069 /// getBackedgeTakenCount. The loop is guaranteed to exit (via *some* exit)
1070 /// before the backedge is executed (ExitCount + 1) times. Note that there
1071 /// is no guarantee about *which* exit is taken on the exiting iteration.
1072 LLVM_ABI const SCEV *getExitCount(const Loop *L,
1073 const BasicBlock *ExitingBlock,
1074 ExitCountKind Kind = Exact);
1075
1076 /// Same as above except this uses the predicated backedge taken info and
1077 /// may require predicates.
1078 LLVM_ABI const SCEV *
1079 getPredicatedExitCount(const Loop *L, const BasicBlock *ExitingBlock,
1081 ExitCountKind Kind = Exact);
1082
1083 /// If the specified loop has a predictable backedge-taken count, return it,
1084 /// otherwise return a SCEVCouldNotCompute object. The backedge-taken count is
1085 /// the number of times the loop header will be branched to from within the
1086 /// loop, assuming there are no abnormal exists like exception throws. This is
1087 /// one less than the trip count of the loop, since it doesn't count the first
1088 /// iteration, when the header is branched to from outside the loop.
1089 ///
1090 /// Note that it is not valid to call this method on a loop without a
1091 /// loop-invariant backedge-taken count (see
1092 /// hasLoopInvariantBackedgeTakenCount).
1093 LLVM_ABI const SCEV *getBackedgeTakenCount(const Loop *L,
1094 ExitCountKind Kind = Exact);
1095
1096 /// Similar to getBackedgeTakenCount, except it will add a set of
1097 /// SCEV predicates to Predicates that are required to be true in order for
1098 /// the answer to be correct. Predicates can be checked with run-time
1099 /// checks and can be used to perform loop versioning.
1101 const Loop *L, SmallVectorImpl<const SCEVPredicate *> &Predicates);
1102
1103 /// When successful, this returns a SCEVConstant that is greater than or equal
1104 /// to (i.e. a "conservative over-approximation") of the value returend by
1105 /// getBackedgeTakenCount. If such a value cannot be computed, it returns the
1106 /// SCEVCouldNotCompute object.
1110
1111 /// Similar to getConstantMaxBackedgeTakenCount, except it will add a set of
1112 /// SCEV predicates to Predicates that are required to be true in order for
1113 /// the answer to be correct. Predicates can be checked with run-time
1114 /// checks and can be used to perform loop versioning.
1116 const Loop *L, SmallVectorImpl<const SCEVPredicate *> &Predicates);
1117
1118 /// When successful, this returns a SCEV that is greater than or equal
1119 /// to (i.e. a "conservative over-approximation") of the value returend by
1120 /// getBackedgeTakenCount. If such a value cannot be computed, it returns the
1121 /// SCEVCouldNotCompute object.
1125
1126 /// Similar to getSymbolicMaxBackedgeTakenCount, except it will add a set of
1127 /// SCEV predicates to Predicates that are required to be true in order for
1128 /// the answer to be correct. Predicates can be checked with run-time
1129 /// checks and can be used to perform loop versioning.
1131 const Loop *L, SmallVectorImpl<const SCEVPredicate *> &Predicates);
1132
1133 /// Return true if the backedge taken count is either the value returned by
1134 /// getConstantMaxBackedgeTakenCount or zero.
1136
1137 /// Return true if the specified loop has an analyzable loop-invariant
1138 /// backedge-taken count.
1140
1141 // This method should be called by the client when it made any change that
1142 // would invalidate SCEV's answers, and the client wants to remove all loop
1143 // information held internally by ScalarEvolution. This is intended to be used
1144 // when the alternative to forget a loop is too expensive (i.e. large loop
1145 // bodies).
1146 LLVM_ABI void forgetAllLoops();
1147
1148 /// This method should be called by the client when it has changed a loop in
1149 /// a way that may effect ScalarEvolution's ability to compute a trip count,
1150 /// or if the loop is deleted. This call is potentially expensive for large
1151 /// loop bodies.
1152 LLVM_ABI void forgetLoop(const Loop *L);
1153
1154 // This method invokes forgetLoop for the outermost loop of the given loop
1155 // \p L, making ScalarEvolution forget about all this subtree. This needs to
1156 // be done whenever we make a transform that may affect the parameters of the
1157 // outer loop, such as exit counts for branches.
1158 LLVM_ABI void forgetTopmostLoop(const Loop *L);
1159
1160 /// This method should be called by the client when it has changed a value
1161 /// in a way that may effect its value, or which may disconnect it from a
1162 /// def-use chain linking it to a loop.
1163 LLVM_ABI void forgetValue(Value *V);
1164
1165 /// Forget LCSSA phi node V of loop L to which a new predecessor was added,
1166 /// such that it may no longer be trivial.
1168
1169 /// Called when the client has changed the disposition of values in
1170 /// this loop.
1171 ///
1172 /// We don't have a way to invalidate per-loop dispositions. Clear and
1173 /// recompute is simpler.
1175
1176 /// Called when the client has changed the disposition of values in
1177 /// a loop or block.
1178 ///
1179 /// We don't have a way to invalidate per-loop/per-block dispositions. Clear
1180 /// and recompute is simpler.
1182
1183 /// Determine the minimum number of zero bits that S is guaranteed to end in
1184 /// (at every loop iteration). It is, at the same time, the minimum number
1185 /// of times S is divisible by 2. For example, given {4,+,8} it returns 2.
1186 /// If S is guaranteed to be 0, it returns the bitwidth of S.
1187 /// If \p CtxI is not nullptr, return a constant multiple valid at \p CtxI.
1189 const Instruction *CtxI = nullptr);
1190
1191 /// Returns the max constant multiple of S. If \p CtxI is not nullptr, return
1192 /// a constant multiple valid at \p CtxI.
1194 const Instruction *CtxI = nullptr);
1195
1196 // Returns the max constant multiple of S. If S is exactly 0, return 1.
1198
1199 /// Determine the unsigned range for a particular SCEV.
1200 /// NOTE: This returns a copy of the reference returned by getRangeRef.
1202 return getRangeRef(S, HINT_RANGE_UNSIGNED);
1203 }
1204
1205 /// Determine the min of the unsigned range for a particular SCEV.
1207 return getRangeRef(S, HINT_RANGE_UNSIGNED).getUnsignedMin();
1208 }
1209
1210 /// Determine the max of the unsigned range for a particular SCEV.
1212 return getRangeRef(S, HINT_RANGE_UNSIGNED).getUnsignedMax();
1213 }
1214
1215 /// Determine the signed range for a particular SCEV.
1216 /// NOTE: This returns a copy of the reference returned by getRangeRef.
1218 return getRangeRef(S, HINT_RANGE_SIGNED);
1219 }
1220
1221 /// Determine the min of the signed range for a particular SCEV.
1223 return getRangeRef(S, HINT_RANGE_SIGNED).getSignedMin();
1224 }
1225
1226 /// Determine the max of the signed range for a particular SCEV.
1228 return getRangeRef(S, HINT_RANGE_SIGNED).getSignedMax();
1229 }
1230
1231 /// Test if the given expression is known to be negative.
1232 LLVM_ABI bool isKnownNegative(const SCEV *S);
1233
1234 /// Test if the given expression is known to be positive.
1235 LLVM_ABI bool isKnownPositive(const SCEV *S);
1236
1237 /// Test if the given expression is known to be non-negative.
1238 LLVM_ABI bool isKnownNonNegative(const SCEV *S);
1239
1240 /// Test if the given expression is known to be non-positive.
1241 LLVM_ABI bool isKnownNonPositive(const SCEV *S);
1242
1243 /// Test if the given expression is known to be non-zero.
1244 LLVM_ABI bool isKnownNonZero(const SCEV *S);
1245
1246 /// Test if the given expression is known to be a power of 2. OrNegative
1247 /// allows matching negative power of 2s, and OrZero allows matching 0.
1248 LLVM_ABI bool isKnownToBeAPowerOfTwo(const SCEV *S, bool OrZero = false,
1249 bool OrNegative = false);
1250
1251 /// Check that \p S is a multiple of \p M. When \p S is an AddRecExpr, \p S is
1252 /// a multiple of \p M if \p S starts with a multiple of \p M and at every
1253 /// iteration step \p S only adds multiples of \p M. \p Assumptions records
1254 /// the runtime predicates under which \p S is a multiple of \p M.
1255 LLVM_ABI bool
1256 isKnownMultipleOf(const SCEV *S, uint64_t M,
1258
1259 /// Return true if we know that S1 and S2 must have the same sign.
1260 LLVM_ABI bool haveSameSign(const SCEV *S1, const SCEV *S2);
1261
1262 /// Splits SCEV expression \p S into two SCEVs. One of them is obtained from
1263 /// \p S by substitution of all AddRec sub-expression related to loop \p L
1264 /// with initial value of that SCEV. The second is obtained from \p S by
1265 /// substitution of all AddRec sub-expressions related to loop \p L with post
1266 /// increment of this AddRec in the loop \p L. In both cases all other AddRec
1267 /// sub-expressions (not related to \p L) remain the same.
1268 /// If the \p S contains non-invariant unknown SCEV the function returns
1269 /// CouldNotCompute SCEV in both values of std::pair.
1270 /// For example, for SCEV S={0, +, 1}<L1> + {0, +, 1}<L2> and loop L=L1
1271 /// the function returns pair:
1272 /// first = {0, +, 1}<L2>
1273 /// second = {1, +, 1}<L1> + {0, +, 1}<L2>
1274 /// We can see that for the first AddRec sub-expression it was replaced with
1275 /// 0 (initial value) for the first element and to {1, +, 1}<L1> (post
1276 /// increment value) for the second one. In both cases AddRec expression
1277 /// related to L2 remains the same.
1278 LLVM_ABI std::pair<const SCEV *, const SCEV *>
1279 SplitIntoInitAndPostInc(const Loop *L, const SCEV *S);
1280
1281 /// We'd like to check the predicate on every iteration of the most dominated
1282 /// loop between loops used in LHS and RHS.
1283 /// To do this we use the following list of steps:
1284 /// 1. Collect set S all loops on which either LHS or RHS depend.
1285 /// 2. If S is non-empty
1286 /// a. Let PD be the element of S which is dominated by all other elements.
1287 /// b. Let E(LHS) be value of LHS on entry of PD.
1288 /// To get E(LHS), we should just take LHS and replace all AddRecs that are
1289 /// attached to PD on with their entry values.
1290 /// Define E(RHS) in the same way.
1291 /// c. Let B(LHS) be value of L on backedge of PD.
1292 /// To get B(LHS), we should just take LHS and replace all AddRecs that are
1293 /// attached to PD on with their backedge values.
1294 /// Define B(RHS) in the same way.
1295 /// d. Note that E(LHS) and E(RHS) are automatically available on entry of PD,
1296 /// so we can assert on that.
1297 /// e. Return true if isLoopEntryGuardedByCond(Pred, E(LHS), E(RHS)) &&
1298 /// isLoopBackedgeGuardedByCond(Pred, B(LHS), B(RHS))
1300 SCEVUse RHS);
1301
1302 /// Test if the given expression is known to satisfy the condition described
1303 /// by Pred, LHS, and RHS.
1305
1306 /// Check whether the condition described by Pred, LHS, and RHS is true or
1307 /// false. If we know it, return the evaluation of this condition. If neither
1308 /// is proved, return std::nullopt.
1309 LLVM_ABI std::optional<bool>
1310 evaluatePredicate(CmpPredicate Pred, const SCEV *LHS, const SCEV *RHS);
1311
1312 /// Test if the given expression is known to satisfy the condition described
1313 /// by Pred, LHS, and RHS in the given Context.
1315 const SCEV *RHS, const Instruction *CtxI);
1316
1317 /// Check whether the condition described by Pred, LHS, and RHS is true or
1318 /// false in the given \p Context. If we know it, return the evaluation of
1319 /// this condition. If neither is proved, return std::nullopt.
1320 LLVM_ABI std::optional<bool> evaluatePredicateAt(CmpPredicate Pred,
1321 const SCEV *LHS,
1322 const SCEV *RHS,
1323 const Instruction *CtxI);
1324
1325 /// Test if the condition described by Pred, LHS, RHS is known to be true on
1326 /// every iteration of the loop of the recurrency LHS.
1328 const SCEVAddRecExpr *LHS,
1329 const SCEV *RHS);
1330
1331 /// Information about the number of loop iterations for which a loop exit's
1332 /// branch condition evaluates to the not-taken path. This is a temporary
1333 /// pair of exact and max expressions that are eventually summarized in
1334 /// ExitNotTakenInfo and BackedgeTakenInfo.
1335 struct ExitLimit {
1336 const SCEV *ExactNotTaken; // The exit is not taken exactly this many times
1337 const SCEV *ConstantMaxNotTaken; // The exit is not taken at most this many
1338 // times
1340
1341 // Not taken either exactly ConstantMaxNotTaken or zero times
1342 bool MaxOrZero = false;
1343
1344 /// A vector of predicate guards for this ExitLimit. The result is only
1345 /// valid if all of the predicates in \c Predicates evaluate to 'true' at
1346 /// run-time.
1348
1349 /// Construct either an exact exit limit from a constant, or an unknown
1350 /// one from a SCEVCouldNotCompute. No other types of SCEVs are allowed
1351 /// as arguments and asserts enforce that internally.
1352 /*implicit*/ LLVM_ABI ExitLimit(const SCEV *E);
1353 /*implicit*/ ExitLimit(SCEVUse E) : ExitLimit((const SCEV *)E) {}
1354
1355 LLVM_ABI
1356 ExitLimit(const SCEV *E, const SCEV *ConstantMaxNotTaken,
1357 const SCEV *SymbolicMaxNotTaken, bool MaxOrZero,
1359
1361 const SCEV *SymbolicMaxNotTaken, bool MaxOrZero,
1363
1364 /// Test whether this ExitLimit contains any computed information, or
1365 /// whether it's all SCEVCouldNotCompute values.
1370
1371 /// Test whether this ExitLimit contains all information.
1372 bool hasFullInfo() const {
1374 }
1375 };
1376
1377 /// Compute the number of times the backedge of the specified loop will
1378 /// execute if its exit condition were a conditional branch of ExitCond.
1379 ///
1380 /// \p ControlsOnlyExit is true if ExitCond directly controls the only exit
1381 /// branch. In this case, we can assume that the loop exits only if the
1382 /// condition is true and can infer that failing to meet the condition prior
1383 /// to integer wraparound results in undefined behavior.
1384 ///
1385 /// If \p AllowPredicates is set, this call will try to use a minimal set of
1386 /// SCEV predicates in order to return an exact answer.
1387 LLVM_ABI ExitLimit computeExitLimitFromCond(const Loop *L, Value *ExitCond,
1388 bool ExitIfTrue,
1389 bool ControlsOnlyExit,
1390 bool AllowPredicates = false);
1391
1392 /// A predicate is said to be monotonically increasing if may go from being
1393 /// false to being true as the loop iterates, but never the other way
1394 /// around. A predicate is said to be monotonically decreasing if may go
1395 /// from being true to being false as the loop iterates, but never the other
1396 /// way around.
1401
1402 /// If, for all loop invariant X, the predicate "LHS `Pred` X" is
1403 /// monotonically increasing or decreasing, returns
1404 /// Some(MonotonicallyIncreasing) and Some(MonotonicallyDecreasing)
1405 /// respectively. If we could not prove either of these facts, returns
1406 /// std::nullopt.
1407 LLVM_ABI std::optional<MonotonicPredicateType>
1409 ICmpInst::Predicate Pred);
1410
1419 /// If the result of the predicate LHS `Pred` RHS is loop invariant with
1420 /// respect to L, return a LoopInvariantPredicate with LHS and RHS being
1421 /// invariants, available at L's entry. Otherwise, return std::nullopt.
1422 LLVM_ABI std::optional<LoopInvariantPredicate>
1424 const Loop *L, const Instruction *CtxI = nullptr);
1425
1426 /// If the result of the predicate LHS `Pred` RHS is loop invariant with
1427 /// respect to L at given Context during at least first MaxIter iterations,
1428 /// return a LoopInvariantPredicate with LHS and RHS being invariants,
1429 /// available at L's entry. Otherwise, return std::nullopt. The predicate
1430 /// should be the loop's exit condition.
1431 LLVM_ABI std::optional<LoopInvariantPredicate>
1433 const SCEV *LHS,
1434 const SCEV *RHS, const Loop *L,
1435 const Instruction *CtxI,
1436 const SCEV *MaxIter);
1437
1438 LLVM_ABI std::optional<LoopInvariantPredicate>
1440 CmpPredicate Pred, const SCEV *LHS, const SCEV *RHS, const Loop *L,
1441 const Instruction *CtxI, const SCEV *MaxIter);
1442
1443 /// Simplify LHS and RHS in a comparison with predicate Pred. Return true
1444 /// iff any changes were made. If the operands are provably equal or
1445 /// unequal, LHS and RHS are set to the same value and Pred is set to either
1446 /// ICMP_EQ or ICMP_NE.
1448 SCEVUse &RHS, unsigned Depth = 0);
1449
1450 /// Return the "disposition" of the given SCEV with respect to the given
1451 /// loop.
1453
1454 /// Return true if the value of the given SCEV is unchanging in the
1455 /// specified loop.
1456 LLVM_ABI bool isLoopInvariant(const SCEV *S, const Loop *L);
1457
1458 /// Determine if the SCEV can be evaluated at loop's entry. It is true if it
1459 /// doesn't depend on a SCEVUnknown of an instruction which is dominated by
1460 /// the header of loop L.
1461 LLVM_ABI bool isAvailableAtLoopEntry(const SCEV *S, const Loop *L);
1462
1463 /// Return true if the given SCEV changes value in a known way in the
1464 /// specified loop. This property being true implies that the value is
1465 /// variant in the loop AND that we can emit an expression to compute the
1466 /// value of the expression at any particular loop iteration.
1467 LLVM_ABI bool hasComputableLoopEvolution(const SCEV *S, const Loop *L);
1468
1469 /// Return the "disposition" of the given SCEV with respect to the given
1470 /// block.
1472 const BasicBlock *BB);
1473
1474 /// Return true if elements that makes up the given SCEV dominate the
1475 /// specified basic block.
1476 LLVM_ABI bool dominates(const SCEV *S, const BasicBlock *BB);
1477
1478 /// Return true if elements that makes up the given SCEV properly dominate
1479 /// the specified basic block.
1480 LLVM_ABI bool properlyDominates(const SCEV *S, const BasicBlock *BB);
1481
1482 /// Test whether the given SCEV has Op as a direct or indirect operand.
1483 LLVM_ABI bool hasOperand(const SCEV *S, const SCEV *Op) const;
1484
1485 /// Return the size of an element read or written by Inst.
1487
1488 LLVM_ABI void print(raw_ostream &OS) const;
1489 LLVM_ABI void verify() const;
1491 FunctionAnalysisManager::Invalidator &Inv);
1492
1493 /// Return the DataLayout associated with the module this SCEV instance is
1494 /// operating on.
1495 const DataLayout &getDataLayout() const { return DL; }
1496
1498 const SCEV *RHS);
1500 const SCEV *LHS,
1501 const SCEV *RHS);
1502
1503 LLVM_ABI const SCEVPredicate *
1506
1507 /// Re-writes the SCEV according to the Predicates in \p A.
1508 LLVM_ABI const SCEV *rewriteUsingPredicate(const SCEV *S, const Loop *L,
1509 const SCEVPredicate &A);
1510 /// Tries to convert the \p S expression to an AddRec expression,
1511 /// adding additional predicates to \p Preds as required.
1513 const SCEV *S, const Loop *L,
1515
1516 /// Compute \p LHS - \p RHS and returns the result as an APInt if it is a
1517 /// constant, and std::nullopt if it isn't.
1518 ///
1519 /// This is intended to be a cheaper version of getMinusSCEV. We can be
1520 /// frugal here since we just bail out of actually constructing and
1521 /// canonicalizing an expression in the cases where the result isn't going
1522 /// to be a constant.
1523 LLVM_ABI std::optional<APInt> computeConstantDifference(const SCEV *LHS,
1524 const SCEV *RHS);
1525
1526 /// Update no-wrap flags of an AddRec. This may drop the cached info about
1527 /// this AddRec (such as range info) in case if new flags may potentially
1528 /// sharpen it.
1530
1531 class LoopGuards {
1534 bool PreserveNUW = false;
1535 bool PreserveNSW = false;
1536 ScalarEvolution &SE;
1537
1538 LoopGuards(ScalarEvolution &SE) : SE(SE) {}
1539
1540 /// Recursively collect loop guards in \p Guards, starting from
1541 /// block \p Block with predecessor \p Pred. The intended starting point
1542 /// is to collect from a loop header and its predecessor.
1543 static void
1544 collectFromBlock(ScalarEvolution &SE, ScalarEvolution::LoopGuards &Guards,
1545 const BasicBlock *Block, const BasicBlock *Pred,
1547 unsigned Depth = 0);
1548
1549 /// Collect loop guards in \p Guards, starting from PHINode \p
1550 /// Phi, by calling \p collectFromBlock on the incoming blocks of
1551 /// \Phi and trying to merge the found constraints into a single
1552 /// combined one for \p Phi.
1553 static void collectFromPHI(
1557 unsigned Depth);
1558
1559 public:
1560 /// Collect rewrite map for loop guards for loop \p L, together with flags
1561 /// indicating if NUW and NSW can be preserved during rewriting.
1562 LLVM_ABI static LoopGuards collect(const Loop *L, ScalarEvolution &SE);
1563
1564 /// Try to apply the collected loop guards to \p Expr.
1565 LLVM_ABI const SCEV *rewrite(const SCEV *Expr) const;
1566 };
1567
1568 /// Try to apply information from loop guards for \p L to \p Expr.
1569 LLVM_ABI const SCEV *applyLoopGuards(const SCEV *Expr, const Loop *L);
1570 LLVM_ABI const SCEV *applyLoopGuards(const SCEV *Expr,
1571 const LoopGuards &Guards);
1572
1573 /// Return true if the loop has no abnormal exits. That is, if the loop
1574 /// is not infinite, it must exit through an explicit edge in the CFG.
1575 /// (As opposed to either a) throwing out of the function or b) entering a
1576 /// well defined infinite loop in some callee.)
1578 return getLoopProperties(L).HasNoAbnormalExits;
1579 }
1580
1581 /// Return true if this loop is finite by assumption. That is,
1582 /// to be infinite, it must also be undefined.
1583 LLVM_ABI bool loopIsFiniteByAssumption(const Loop *L);
1584
1585 /// Return the set of Values that, if poison, will definitively result in S
1586 /// being poison as well. The returned set may be incomplete, i.e. there can
1587 /// be additional Values that also result in S being poison.
1588 LLVM_ABI void
1590 const SCEV *S);
1591
1592 /// Check whether it is poison-safe to represent the expression S using the
1593 /// instruction I. If such a replacement is performed, the poison flags of
1594 /// instructions in DropPoisonGeneratingInsts must be dropped.
1596 const SCEV *S, Instruction *I,
1597 SmallVectorImpl<Instruction *> &DropPoisonGeneratingInsts);
1598
1599 class FoldID {
1600 const SCEV *Op = nullptr;
1601 const Type *Ty = nullptr;
1602 unsigned short C;
1603
1604 public:
1605 FoldID(SCEVTypes C, const SCEV *Op, const Type *Ty) : Op(Op), Ty(Ty), C(C) {
1606 assert(Op);
1607 assert(Ty);
1608 }
1609
1610 FoldID(unsigned short C) : C(C) {}
1611
1612 unsigned computeHash() const {
1614 C, detail::combineHashValue(reinterpret_cast<uintptr_t>(Op),
1615 reinterpret_cast<uintptr_t>(Ty)));
1616 }
1617
1618 bool operator==(const FoldID &RHS) const {
1619 return std::tie(Op, Ty, C) == std::tie(RHS.Op, RHS.Ty, RHS.C);
1620 }
1621 };
1622
1623private:
1624 /// A CallbackVH to arrange for ScalarEvolution to be notified whenever a
1625 /// Value is deleted.
1626 class LLVM_ABI SCEVCallbackVH final : public CallbackVH {
1627 ScalarEvolution *SE;
1628
1629 void deleted() override;
1630 void allUsesReplacedWith(Value *New) override;
1631
1632 public:
1633 SCEVCallbackVH(Value *V, ScalarEvolution *SE = nullptr);
1634 };
1635
1636 friend class SCEVCallbackVH;
1637 friend class SCEVExpander;
1638 friend class SCEVUnknown;
1639
1640 /// The function we are analyzing.
1641 Function &F;
1642
1643 /// Data layout of the module.
1644 const DataLayout &DL;
1645
1646 /// Does the module have any calls to the llvm.experimental.guard intrinsic
1647 /// at all? If this is false, we avoid doing work that will only help if
1648 /// thare are guards present in the IR.
1649 bool HasGuards;
1650
1651 /// The target library information for the target we are targeting.
1652 TargetLibraryInfo &TLI;
1653
1654 /// The tracker for \@llvm.assume intrinsics in this function.
1655 AssumptionCache &AC;
1656
1657 /// The dominator tree.
1658 DominatorTree &DT;
1659
1660 /// The loop information for the function we are currently analyzing.
1661 LoopInfo &LI;
1662
1663 /// This SCEV is used to represent unknown trip counts and things.
1664 std::unique_ptr<SCEVCouldNotCompute> CouldNotCompute;
1665
1666 /// The type for HasRecMap.
1667 using HasRecMapType = DenseMap<const SCEV *, bool>;
1668
1669 /// This is a cache to record whether a SCEV contains any scAddRecExpr.
1670 HasRecMapType HasRecMap;
1671
1672 /// The type for ExprValueMap.
1673 using ValueSetVector = SmallSetVector<Value *, 4>;
1674 using ExprValueMapType = DenseMap<const SCEV *, ValueSetVector>;
1675
1676 /// ExprValueMap -- This map records the original values from which
1677 /// the SCEV expr is generated from.
1678 ExprValueMapType ExprValueMap;
1679
1680 /// The type for ValueExprMap.
1681 using ValueExprMapType =
1683
1684 /// This is a cache of the values we have analyzed so far.
1685 ValueExprMapType ValueExprMap;
1686
1687 /// This is a cache for expressions that got folded to a different existing
1688 /// SCEV.
1691
1692 /// Mark predicate values currently being processed by isImpliedCond.
1693 SmallPtrSet<const Value *, 6> PendingLoopPredicates;
1694
1695 // Mark SCEVUnknown Phis currently being processed by isImpliedViaMerge.
1696 SmallPtrSet<const PHINode *, 6> PendingMerges;
1697
1698 /// Set to true by isLoopBackedgeGuardedByCond when we're walking the set of
1699 /// conditions dominating the backedge of a loop.
1700 bool WalkingBEDominatingConds = false;
1701
1702 /// Set to true by isKnownPredicateViaSplitting when we're trying to prove a
1703 /// predicate by splitting it into a set of independent predicates.
1704 bool ProvingSplitPredicate = false;
1705
1706 /// Memoized values for the getConstantMultiple
1707 DenseMap<const SCEV *, APInt> ConstantMultipleCache;
1708
1709 /// Return the Value set from which the SCEV expr is generated.
1710 ArrayRef<Value *> getSCEVValues(const SCEV *S);
1711
1712 /// Private helper method for the getConstantMultiple method. If \p CtxI is
1713 /// not nullptr, return a constant multiple valid at \p CtxI.
1714 APInt getConstantMultipleImpl(const SCEV *S,
1715 const Instruction *Ctx = nullptr);
1716
1717 /// Information about the number of times a particular loop exit may be
1718 /// reached before exiting the loop.
1719 struct ExitNotTakenInfo {
1720 PoisoningVH<BasicBlock> ExitingBlock;
1721 const SCEV *ExactNotTaken;
1722 const SCEV *ConstantMaxNotTaken;
1723 const SCEV *SymbolicMaxNotTaken;
1725
1726 explicit ExitNotTakenInfo(PoisoningVH<BasicBlock> ExitingBlock,
1727 const SCEV *ExactNotTaken,
1728 const SCEV *ConstantMaxNotTaken,
1729 const SCEV *SymbolicMaxNotTaken,
1731 : ExitingBlock(ExitingBlock), ExactNotTaken(ExactNotTaken),
1732 ConstantMaxNotTaken(ConstantMaxNotTaken),
1733 SymbolicMaxNotTaken(SymbolicMaxNotTaken), Predicates(Predicates) {}
1734
1735 bool hasAlwaysTruePredicate() const {
1736 return Predicates.empty();
1737 }
1738 };
1739
1740 /// Information about the backedge-taken count of a loop. This currently
1741 /// includes an exact count and a maximum count.
1742 ///
1743 class BackedgeTakenInfo {
1744 friend class ScalarEvolution;
1745
1746 /// A list of computable exits and their not-taken counts. Loops almost
1747 /// never have more than one computable exit.
1748 SmallVector<ExitNotTakenInfo, 1> ExitNotTaken;
1749
1750 /// Expression indicating the least constant maximum backedge-taken count of
1751 /// the loop that is known, or a SCEVCouldNotCompute. This expression is
1752 /// only valid if the predicates associated with all loop exits are true.
1753 const SCEV *ConstantMax = nullptr;
1754
1755 /// Indicating if \c ExitNotTaken has an element for every exiting block in
1756 /// the loop.
1757 bool IsComplete = false;
1758
1759 /// Expression indicating the least maximum backedge-taken count of the loop
1760 /// that is known, or a SCEVCouldNotCompute. Lazily computed on first query.
1761 const SCEV *SymbolicMax = nullptr;
1762
1763 /// True iff the backedge is taken either exactly Max or zero times.
1764 bool MaxOrZero = false;
1765
1766 bool isComplete() const { return IsComplete; }
1767 const SCEV *getConstantMax() const { return ConstantMax; }
1768
1769 LLVM_ABI const ExitNotTakenInfo *getExitNotTaken(
1770 const BasicBlock *ExitingBlock,
1771 SmallVectorImpl<const SCEVPredicate *> *Predicates = nullptr) const;
1772
1773 public:
1774 BackedgeTakenInfo() = default;
1775 BackedgeTakenInfo(BackedgeTakenInfo &&) = default;
1776 BackedgeTakenInfo &operator=(BackedgeTakenInfo &&) = default;
1777
1778 using EdgeExitInfo = std::pair<BasicBlock *, ExitLimit>;
1779
1780 /// Initialize BackedgeTakenInfo from a list of exact exit counts.
1781 LLVM_ABI BackedgeTakenInfo(ArrayRef<EdgeExitInfo> ExitCounts,
1782 bool IsComplete, const SCEV *ConstantMax,
1783 bool MaxOrZero);
1784
1785 /// Test whether this BackedgeTakenInfo contains any computed information,
1786 /// or whether it's all SCEVCouldNotCompute values.
1787 bool hasAnyInfo() const {
1788 return !ExitNotTaken.empty() ||
1789 !isa<SCEVCouldNotCompute>(getConstantMax());
1790 }
1791
1792 /// Test whether this BackedgeTakenInfo contains complete information.
1793 bool hasFullInfo() const { return isComplete(); }
1794
1795 /// Return an expression indicating the exact *backedge-taken*
1796 /// count of the loop if it is known or SCEVCouldNotCompute
1797 /// otherwise. If execution makes it to the backedge on every
1798 /// iteration (i.e. there are no abnormal exists like exception
1799 /// throws and thread exits) then this is the number of times the
1800 /// loop header will execute minus one.
1801 ///
1802 /// If the SCEV predicate associated with the answer can be different
1803 /// from AlwaysTrue, we must add a (non null) Predicates argument.
1804 /// The SCEV predicate associated with the answer will be added to
1805 /// Predicates. A run-time check needs to be emitted for the SCEV
1806 /// predicate in order for the answer to be valid.
1807 ///
1808 /// Note that we should always know if we need to pass a predicate
1809 /// argument or not from the way the ExitCounts vector was computed.
1810 /// If we allowed SCEV predicates to be generated when populating this
1811 /// vector, this information can contain them and therefore a
1812 /// SCEVPredicate argument should be added to getExact.
1813 LLVM_ABI const SCEV *getExact(
1814 const Loop *L, ScalarEvolution *SE,
1815 SmallVectorImpl<const SCEVPredicate *> *Predicates = nullptr) const;
1816
1817 /// Return the number of times this loop exit may fall through to the back
1818 /// edge, or SCEVCouldNotCompute. The loop is guaranteed not to exit via
1819 /// this block before this number of iterations, but may exit via another
1820 /// block. If \p Predicates is null the function returns CouldNotCompute if
1821 /// predicates are required, otherwise it fills in the required predicates.
1822 const SCEV *getExact(
1823 const BasicBlock *ExitingBlock, ScalarEvolution *SE,
1824 SmallVectorImpl<const SCEVPredicate *> *Predicates = nullptr) const {
1825 if (auto *ENT = getExitNotTaken(ExitingBlock, Predicates))
1826 return ENT->ExactNotTaken;
1827 else
1828 return SE->getCouldNotCompute();
1829 }
1830
1831 /// Get the constant max backedge taken count for the loop.
1832 LLVM_ABI const SCEV *getConstantMax(
1833 ScalarEvolution *SE,
1834 SmallVectorImpl<const SCEVPredicate *> *Predicates = nullptr) const;
1835
1836 /// Get the constant max backedge taken count for the particular loop exit.
1837 const SCEV *getConstantMax(
1838 const BasicBlock *ExitingBlock, ScalarEvolution *SE,
1839 SmallVectorImpl<const SCEVPredicate *> *Predicates = nullptr) const {
1840 if (auto *ENT = getExitNotTaken(ExitingBlock, Predicates))
1841 return ENT->ConstantMaxNotTaken;
1842 else
1843 return SE->getCouldNotCompute();
1844 }
1845
1846 /// Get the symbolic max backedge taken count for the loop.
1847 LLVM_ABI const SCEV *getSymbolicMax(
1848 const Loop *L, ScalarEvolution *SE,
1849 SmallVectorImpl<const SCEVPredicate *> *Predicates = nullptr);
1850
1851 /// Get the symbolic max backedge taken count for the particular loop exit.
1852 const SCEV *getSymbolicMax(
1853 const BasicBlock *ExitingBlock, ScalarEvolution *SE,
1854 SmallVectorImpl<const SCEVPredicate *> *Predicates = nullptr) const {
1855 if (auto *ENT = getExitNotTaken(ExitingBlock, Predicates))
1856 return ENT->SymbolicMaxNotTaken;
1857 else
1858 return SE->getCouldNotCompute();
1859 }
1860
1861 /// Return true if the number of times this backedge is taken is either the
1862 /// value returned by getConstantMax or zero.
1863 LLVM_ABI bool isConstantMaxOrZero(ScalarEvolution *SE) const;
1864 };
1865
1866 /// Cache the backedge-taken count of the loops for this function as they
1867 /// are computed.
1868 DenseMap<const Loop *, BackedgeTakenInfo> BackedgeTakenCounts;
1869
1870 /// Cache the predicated backedge-taken count of the loops for this
1871 /// function as they are computed.
1872 DenseMap<const Loop *, BackedgeTakenInfo> PredicatedBackedgeTakenCounts;
1873
1874 /// Loops whose backedge taken counts directly use this non-constant SCEV.
1875 DenseMap<const SCEV *, SmallPtrSet<PointerIntPair<const Loop *, 1, bool>, 4>>
1876 BECountUsers;
1877
1878 /// This map contains entries for all of the PHI instructions that we
1879 /// attempt to compute constant evolutions for. This allows us to avoid
1880 /// potentially expensive recomputation of these properties. An instruction
1881 /// maps to null if we are unable to compute its exit value.
1882 DenseMap<PHINode *, Constant *> ConstantEvolutionLoopExitValue;
1883
1884 /// This map contains entries for all the expressions that we attempt to
1885 /// compute getSCEVAtScope information for, which can be expensive in
1886 /// extreme cases.
1887 DenseMap<const SCEV *, SmallVector<std::pair<const Loop *, const SCEV *>, 2>>
1888 ValuesAtScopes;
1889
1890 /// Reverse map for invalidation purposes: Stores of which SCEV and which
1891 /// loop this is the value-at-scope of.
1892 DenseMap<const SCEV *, SmallVector<std::pair<const Loop *, const SCEV *>, 2>>
1893 ValuesAtScopesUsers;
1894
1895 /// Memoized computeLoopDisposition results.
1896 DenseMap<const SCEV *,
1898 LoopDispositions;
1899
1900 struct LoopProperties {
1901 /// Set to true if the loop contains no instruction that can abnormally exit
1902 /// the loop (i.e. via throwing an exception, by terminating the thread
1903 /// cleanly or by infinite looping in a called function). Strictly
1904 /// speaking, the last one is not leaving the loop, but is identical to
1905 /// leaving the loop for reasoning about undefined behavior.
1906 bool HasNoAbnormalExits;
1907
1908 /// Set to true if the loop contains no instruction that can have side
1909 /// effects (i.e. via throwing an exception, volatile or atomic access).
1910 bool HasNoSideEffects;
1911 };
1912
1913 /// Cache for \c getLoopProperties.
1914 DenseMap<const Loop *, LoopProperties> LoopPropertiesCache;
1915
1916 /// Return a \c LoopProperties instance for \p L, creating one if necessary.
1917 LLVM_ABI LoopProperties getLoopProperties(const Loop *L);
1918
1919 bool loopHasNoSideEffects(const Loop *L) {
1920 return getLoopProperties(L).HasNoSideEffects;
1921 }
1922
1923 /// Compute a LoopDisposition value.
1924 LoopDisposition computeLoopDisposition(const SCEV *S, const Loop *L);
1925
1926 /// Memoized computeBlockDisposition results.
1927 DenseMap<
1928 const SCEV *,
1930 BlockDispositions;
1931
1932 /// Compute a BlockDisposition value.
1933 BlockDisposition computeBlockDisposition(const SCEV *S, const BasicBlock *BB);
1934
1935 /// Stores all SCEV that use a given SCEV as its direct operand.
1936 DenseMap<const SCEV *, SmallPtrSet<const SCEV *, 8> > SCEVUsers;
1937
1938 /// Memoized results from getRange
1939 DenseMap<const SCEV *, ConstantRange> UnsignedRanges;
1940
1941 /// Memoized results from getRange
1942 DenseMap<const SCEV *, ConstantRange> SignedRanges;
1943
1944 /// Used to parameterize getRange
1945 enum RangeSignHint { HINT_RANGE_UNSIGNED, HINT_RANGE_SIGNED };
1946
1947 /// Set the memoized range for the given SCEV.
1948 const ConstantRange &setRange(const SCEV *S, RangeSignHint Hint,
1949 ConstantRange CR) {
1950 DenseMap<const SCEV *, ConstantRange> &Cache =
1951 Hint == HINT_RANGE_UNSIGNED ? UnsignedRanges : SignedRanges;
1952
1953 auto Pair = Cache.insert_or_assign(S, std::move(CR));
1954 return Pair.first->second;
1955 }
1956
1957 /// Determine the range for a particular SCEV.
1958 /// NOTE: This returns a reference to an entry in a cache. It must be
1959 /// copied if its needed for longer.
1960 LLVM_ABI const ConstantRange &getRangeRef(const SCEV *S, RangeSignHint Hint,
1961 unsigned Depth = 0);
1962
1963 /// Determine the range for a particular SCEV, but evaluates ranges for
1964 /// operands iteratively first.
1965 const ConstantRange &getRangeRefIter(const SCEV *S, RangeSignHint Hint);
1966
1967 /// Determines the range for the affine SCEVAddRecExpr {\p Start,+,\p Step}.
1968 /// Helper for \c getRange.
1969 ConstantRange getRangeForAffineAR(const SCEV *Start, const SCEV *Step,
1970 const APInt &MaxBECount);
1971
1972 /// Determines the range for the affine non-self-wrapping SCEVAddRecExpr {\p
1973 /// Start,+,\p Step}<nw>.
1974 ConstantRange getRangeForAffineNoSelfWrappingAR(const SCEVAddRecExpr *AddRec,
1975 const SCEV *MaxBECount,
1976 unsigned BitWidth,
1977 RangeSignHint SignHint);
1978
1979 /// Try to compute a range for the affine SCEVAddRecExpr {\p Start,+,\p
1980 /// Step} by "factoring out" a ternary expression from the add recurrence.
1981 /// Helper called by \c getRange.
1982 ConstantRange getRangeViaFactoring(const SCEV *Start, const SCEV *Step,
1983 const APInt &MaxBECount);
1984
1985 /// If the unknown expression U corresponds to a simple recurrence, return
1986 /// a constant range which represents the entire recurrence. Note that
1987 /// *add* recurrences with loop invariant steps aren't represented by
1988 /// SCEVUnknowns and thus don't use this mechanism.
1989 ConstantRange getRangeForUnknownRecurrence(const SCEVUnknown *U);
1990
1991 /// We know that there is no SCEV for the specified value. Analyze the
1992 /// expression recursively.
1993 const SCEV *createSCEV(Value *V);
1994
1995 /// We know that there is no SCEV for the specified value. Create a new SCEV
1996 /// for \p V iteratively.
1997 const SCEV *createSCEVIter(Value *V);
1998 /// Collect operands of \p V for which SCEV expressions should be constructed
1999 /// first. Returns a SCEV directly if it can be constructed trivially for \p
2000 /// V.
2001 const SCEV *getOperandsToCreate(Value *V, SmallVectorImpl<Value *> &Ops);
2002
2003 /// Returns SCEV for the first operand of a phi if all phi operands have
2004 /// identical opcodes and operands.
2005 const SCEV *createNodeForPHIWithIdenticalOperands(PHINode *PN);
2006
2007 /// Provide the special handling we need to analyze PHI SCEVs.
2008 const SCEV *createNodeForPHI(PHINode *PN);
2009
2010 /// Helper function called from createNodeForPHI.
2011 const SCEV *createAddRecFromPHI(PHINode *PN);
2012
2013 /// A helper function for createAddRecFromPHI to handle simple cases.
2014 const SCEV *createSimpleAffineAddRec(PHINode *PN, Value *BEValueV,
2015 Value *StartValueV);
2016
2017 /// Helper function called from createNodeForPHI.
2018 const SCEV *createNodeFromSelectLikePHI(PHINode *PN);
2019
2020 /// Provide special handling for a select-like instruction (currently this
2021 /// is either a select instruction or a phi node). \p Ty is the type of the
2022 /// instruction being processed, that is assumed equivalent to
2023 /// "Cond ? TrueVal : FalseVal".
2024 std::optional<const SCEV *>
2025 createNodeForSelectOrPHIInstWithICmpInstCond(Type *Ty, ICmpInst *Cond,
2026 Value *TrueVal, Value *FalseVal);
2027
2028 /// See if we can model this select-like instruction via umin_seq expression.
2029 const SCEV *createNodeForSelectOrPHIViaUMinSeq(Value *I, Value *Cond,
2030 Value *TrueVal,
2031 Value *FalseVal);
2032
2033 /// Given a value \p V, which is a select-like instruction (currently this is
2034 /// either a select instruction or a phi node), which is assumed equivalent to
2035 /// Cond ? TrueVal : FalseVal
2036 /// see if we can model it as a SCEV expression.
2037 const SCEV *createNodeForSelectOrPHI(Value *V, Value *Cond, Value *TrueVal,
2038 Value *FalseVal);
2039
2040 /// Provide the special handling we need to analyze GEP SCEVs.
2041 const SCEV *createNodeForGEP(GEPOperator *GEP);
2042
2043 /// Implementation code for getSCEVAtScope; called at most once for each
2044 /// SCEV+Loop pair.
2045 const SCEV *computeSCEVAtScope(const SCEV *S, const Loop *L);
2046
2047 /// Return the BackedgeTakenInfo for the given loop, lazily computing new
2048 /// values if the loop hasn't been analyzed yet. The returned result is
2049 /// guaranteed not to be predicated.
2050 BackedgeTakenInfo &getBackedgeTakenInfo(const Loop *L);
2051
2052 /// Similar to getBackedgeTakenInfo, but will add predicates as required
2053 /// with the purpose of returning complete information.
2054 BackedgeTakenInfo &getPredicatedBackedgeTakenInfo(const Loop *L);
2055
2056 /// Compute the number of times the specified loop will iterate.
2057 /// If AllowPredicates is set, we will create new SCEV predicates as
2058 /// necessary in order to return an exact answer.
2059 BackedgeTakenInfo computeBackedgeTakenCount(const Loop *L,
2060 bool AllowPredicates = false);
2061
2062 /// Compute the number of times the backedge of the specified loop will
2063 /// execute if it exits via the specified block. If AllowPredicates is set,
2064 /// this call will try to use a minimal set of SCEV predicates in order to
2065 /// return an exact answer.
2066 ExitLimit computeExitLimit(const Loop *L, BasicBlock *ExitingBlock,
2067 bool IsOnlyExit, bool AllowPredicates = false);
2068
2069 // Helper functions for computeExitLimitFromCond to avoid exponential time
2070 // complexity.
2071
2072 class ExitLimitCache {
2073 // It may look like we need key on the whole (L, ExitIfTrue,
2074 // ControlsOnlyExit, AllowPredicates) tuple, but recursive calls to
2075 // computeExitLimitFromCondCached from computeExitLimitFromCondImpl only
2076 // vary the in \c ExitCond and \c ControlsOnlyExit parameters. We remember
2077 // the initial values of the other values to assert our assumption.
2078 SmallDenseMap<PointerIntPair<Value *, 1>, ExitLimit> TripCountMap;
2079
2080 const Loop *L;
2081 bool ExitIfTrue;
2082 bool AllowPredicates;
2083
2084 public:
2085 ExitLimitCache(const Loop *L, bool ExitIfTrue, bool AllowPredicates)
2086 : L(L), ExitIfTrue(ExitIfTrue), AllowPredicates(AllowPredicates) {}
2087
2088 LLVM_ABI std::optional<ExitLimit> find(const Loop *L, Value *ExitCond,
2089 bool ExitIfTrue,
2090 bool ControlsOnlyExit,
2091 bool AllowPredicates);
2092
2093 LLVM_ABI void insert(const Loop *L, Value *ExitCond, bool ExitIfTrue,
2094 bool ControlsOnlyExit, bool AllowPredicates,
2095 const ExitLimit &EL);
2096 };
2097
2098 using ExitLimitCacheTy = ExitLimitCache;
2099
2100 ExitLimit computeExitLimitFromCondCached(ExitLimitCacheTy &Cache,
2101 const Loop *L, Value *ExitCond,
2102 bool ExitIfTrue,
2103 bool ControlsOnlyExit,
2104 bool AllowPredicates);
2105 ExitLimit computeExitLimitFromCondImpl(ExitLimitCacheTy &Cache, const Loop *L,
2106 Value *ExitCond, bool ExitIfTrue,
2107 bool ControlsOnlyExit,
2108 bool AllowPredicates);
2109 std::optional<ScalarEvolution::ExitLimit> computeExitLimitFromCondFromBinOp(
2110 ExitLimitCacheTy &Cache, const Loop *L, Value *ExitCond, bool ExitIfTrue,
2111 bool ControlsOnlyExit, bool AllowPredicates);
2112
2113 /// Compute the number of times the backedge of the specified loop will
2114 /// execute if its exit condition were a conditional branch of the ICmpInst
2115 /// ExitCond and ExitIfTrue. If AllowPredicates is set, this call will try
2116 /// to use a minimal set of SCEV predicates in order to return an exact
2117 /// answer.
2118 ExitLimit computeExitLimitFromICmp(const Loop *L, ICmpInst *ExitCond,
2119 bool ExitIfTrue,
2120 bool IsSubExpr,
2121 bool AllowPredicates = false);
2122
2123 /// Variant of previous which takes the components representing an ICmp
2124 /// as opposed to the ICmpInst itself. Note that the prior version can
2125 /// return more precise results in some cases and is preferred when caller
2126 /// has a materialized ICmp.
2127 ExitLimit computeExitLimitFromICmp(const Loop *L, CmpPredicate Pred,
2128 SCEVUse LHS, SCEVUse RHS, bool IsSubExpr,
2129 bool AllowPredicates = false);
2130
2131 /// Compute the number of times the backedge of the specified loop will
2132 /// execute if its exit condition were a switch with a single exiting case
2133 /// to ExitingBB.
2134 ExitLimit computeExitLimitFromSingleExitSwitch(const Loop *L,
2135 SwitchInst *Switch,
2136 BasicBlock *ExitingBB,
2137 bool IsSubExpr);
2138
2139 /// Compute the exit limit of a loop that is controlled by a
2140 /// "(IV >> 1) != 0" type comparison. We cannot compute the exact trip
2141 /// count in these cases (since SCEV has no way of expressing them), but we
2142 /// can still sometimes compute an upper bound.
2143 ///
2144 /// Return an ExitLimit for a loop whose backedge is guarded by `LHS Pred
2145 /// RHS`.
2146 ExitLimit computeShiftCompareExitLimit(Value *LHS, Value *RHS, const Loop *L,
2147 ICmpInst::Predicate Pred);
2148
2149 /// If the loop is known to execute a constant number of times (the
2150 /// condition evolves only from constants), try to evaluate a few iterations
2151 /// of the loop until we get the exit condition gets a value of ExitWhen
2152 /// (true or false). If we cannot evaluate the exit count of the loop,
2153 /// return CouldNotCompute.
2154 const SCEV *computeExitCountExhaustively(const Loop *L, Value *Cond,
2155 bool ExitWhen);
2156
2157 /// Return the number of times an exit condition comparing the specified
2158 /// value to zero will execute. If not computable, return CouldNotCompute.
2159 /// If AllowPredicates is set, this call will try to use a minimal set of
2160 /// SCEV predicates in order to return an exact answer.
2161 ExitLimit howFarToZero(const SCEV *V, const Loop *L, bool IsSubExpr,
2162 bool AllowPredicates = false);
2163
2164 /// Return the number of times an exit condition checking the specified
2165 /// value for nonzero will execute. If not computable, return
2166 /// CouldNotCompute.
2167 ExitLimit howFarToNonZero(const SCEV *V, const Loop *L);
2168
2169 /// Return the number of times an exit condition containing the specified
2170 /// less-than comparison will execute. If not computable, return
2171 /// CouldNotCompute.
2172 ///
2173 /// \p isSigned specifies whether the less-than is signed.
2174 ///
2175 /// \p ControlsOnlyExit is true when the LHS < RHS condition directly controls
2176 /// the branch (loops exits only if condition is true). In this case, we can
2177 /// use NoWrapFlags to skip overflow checks.
2178 ///
2179 /// If \p AllowPredicates is set, this call will try to use a minimal set of
2180 /// SCEV predicates in order to return an exact answer.
2181 ExitLimit howManyLessThans(const SCEV *LHS, const SCEV *RHS, const Loop *L,
2182 bool isSigned, bool ControlsOnlyExit,
2183 bool AllowPredicates = false);
2184
2185 ExitLimit howManyGreaterThans(const SCEV *LHS, const SCEV *RHS, const Loop *L,
2186 bool isSigned, bool IsSubExpr,
2187 bool AllowPredicates = false);
2188
2189 /// Return a predecessor of BB (which may not be an immediate predecessor)
2190 /// which has exactly one successor from which BB is reachable, or null if
2191 /// no such block is found.
2192 std::pair<const BasicBlock *, const BasicBlock *>
2193 getPredecessorWithUniqueSuccessorForBB(const BasicBlock *BB) const;
2194
2195 /// Test whether the condition described by Pred, LHS, and RHS is true
2196 /// whenever the given FoundCondValue value evaluates to true in given
2197 /// Context. If Context is nullptr, then the found predicate is true
2198 /// everywhere. LHS and FoundLHS may have different type width.
2199 LLVM_ABI bool isImpliedCond(CmpPredicate Pred, const SCEV *LHS,
2200 const SCEV *RHS, const Value *FoundCondValue,
2201 bool Inverse,
2202 const Instruction *Context = nullptr);
2203
2204 /// Test whether the condition described by Pred, LHS, and RHS is true
2205 /// whenever the given FoundCondValue value evaluates to true in given
2206 /// Context. If Context is nullptr, then the found predicate is true
2207 /// everywhere. LHS and FoundLHS must have same type width.
2208 LLVM_ABI bool isImpliedCondBalancedTypes(CmpPredicate Pred, SCEVUse LHS,
2209 SCEVUse RHS, CmpPredicate FoundPred,
2210 SCEVUse FoundLHS, SCEVUse FoundRHS,
2211 const Instruction *CtxI);
2212
2213 /// Test whether the condition described by Pred, LHS, and RHS is true
2214 /// whenever the condition described by FoundPred, FoundLHS, FoundRHS is
2215 /// true in given Context. If Context is nullptr, then the found predicate is
2216 /// true everywhere.
2217 LLVM_ABI bool isImpliedCond(CmpPredicate Pred, const SCEV *LHS,
2218 const SCEV *RHS, CmpPredicate FoundPred,
2219 const SCEV *FoundLHS, const SCEV *FoundRHS,
2220 const Instruction *Context = nullptr);
2221
2222 /// Test whether the condition described by Pred, LHS, and RHS is true
2223 /// whenever the condition described by Pred, FoundLHS, and FoundRHS is
2224 /// true in given Context. If Context is nullptr, then the found predicate is
2225 /// true everywhere.
2226 bool isImpliedCondOperands(CmpPredicate Pred, const SCEV *LHS,
2227 const SCEV *RHS, const SCEV *FoundLHS,
2228 const SCEV *FoundRHS,
2229 const Instruction *Context = nullptr);
2230
2231 /// Test whether the condition described by Pred, LHS, and RHS is true
2232 /// whenever the condition described by Pred, FoundLHS, and FoundRHS is
2233 /// true. Here LHS is an operation that includes FoundLHS as one of its
2234 /// arguments.
2235 bool isImpliedViaOperations(CmpPredicate Pred, const SCEV *LHS,
2236 const SCEV *RHS, const SCEV *FoundLHS,
2237 const SCEV *FoundRHS, unsigned Depth = 0);
2238
2239 /// Test whether the condition described by Pred, LHS, and RHS is true.
2240 /// Use only simple non-recursive types of checks, such as range analysis etc.
2241 bool isKnownViaNonRecursiveReasoning(CmpPredicate Pred, SCEVUse LHS,
2242 SCEVUse RHS);
2243
2244 /// Test whether the condition described by Pred, LHS, and RHS is true
2245 /// whenever the condition described by Pred, FoundLHS, and FoundRHS is
2246 /// true.
2247 bool isImpliedCondOperandsHelper(CmpPredicate Pred, const SCEV *LHS,
2248 const SCEV *RHS, const SCEV *FoundLHS,
2249 const SCEV *FoundRHS);
2250
2251 /// Test whether the condition described by Pred, LHS, and RHS is true
2252 /// whenever the condition described by Pred, FoundLHS, and FoundRHS is
2253 /// true. Utility function used by isImpliedCondOperands. Tries to get
2254 /// cases like "X `sgt` 0 => X - 1 `sgt` -1".
2255 bool isImpliedCondOperandsViaRanges(CmpPredicate Pred, const SCEV *LHS,
2256 const SCEV *RHS, CmpPredicate FoundPred,
2257 const SCEV *FoundLHS,
2258 const SCEV *FoundRHS);
2259
2260 /// Return true if the condition denoted by \p LHS \p Pred \p RHS is implied
2261 /// by a call to @llvm.experimental.guard in \p BB.
2262 bool isImpliedViaGuard(const BasicBlock *BB, CmpPredicate Pred,
2263 const SCEV *LHS, const SCEV *RHS);
2264
2265 /// Test whether the condition described by Pred, LHS, and RHS is true
2266 /// whenever the condition described by Pred, FoundLHS, and FoundRHS is
2267 /// true.
2268 ///
2269 /// This routine tries to rule out certain kinds of integer overflow, and
2270 /// then tries to reason about arithmetic properties of the predicates.
2271 bool isImpliedCondOperandsViaNoOverflow(CmpPredicate Pred, const SCEV *LHS,
2272 const SCEV *RHS, const SCEV *FoundLHS,
2273 const SCEV *FoundRHS);
2274
2275 /// Test whether the condition described by Pred, LHS, and RHS is true
2276 /// whenever the condition described by Pred, FoundLHS, and FoundRHS is
2277 /// true.
2278 ///
2279 /// This routine tries to weaken the known condition basing on fact that
2280 /// FoundLHS is an AddRec.
2281 bool isImpliedCondOperandsViaAddRecStart(CmpPredicate Pred, const SCEV *LHS,
2282 const SCEV *RHS,
2283 const SCEV *FoundLHS,
2284 const SCEV *FoundRHS,
2285 const Instruction *CtxI);
2286
2287 /// Test whether the condition described by Pred, LHS, and RHS is true
2288 /// whenever the condition described by Pred, FoundLHS, and FoundRHS is
2289 /// true.
2290 ///
2291 /// This routine tries to figure out predicate for Phis which are SCEVUnknown
2292 /// if it is true for every possible incoming value from their respective
2293 /// basic blocks.
2294 bool isImpliedViaMerge(CmpPredicate Pred, const SCEV *LHS, const SCEV *RHS,
2295 const SCEV *FoundLHS, const SCEV *FoundRHS,
2296 unsigned Depth);
2297
2298 /// Test whether the condition described by Pred, LHS, and RHS is true
2299 /// whenever the condition described by Pred, FoundLHS, and FoundRHS is
2300 /// true.
2301 ///
2302 /// This routine tries to reason about shifts.
2303 bool isImpliedCondOperandsViaShift(CmpPredicate Pred, const SCEV *LHS,
2304 const SCEV *RHS, const SCEV *FoundLHS,
2305 const SCEV *FoundRHS);
2306
2307 /// If we know that the specified Phi is in the header of its containing
2308 /// loop, we know the loop executes a constant number of times, and the PHI
2309 /// node is just a recurrence involving constants, fold it.
2310 Constant *getConstantEvolutionLoopExitValue(PHINode *PN, const APInt &BEs,
2311 const Loop *L);
2312
2313 /// Test if the given expression is known to satisfy the condition described
2314 /// by Pred and the known constant ranges of LHS and RHS.
2315 bool isKnownPredicateViaConstantRanges(CmpPredicate Pred, SCEVUse LHS,
2316 SCEVUse RHS);
2317
2318 /// Try to prove the condition described by "LHS Pred RHS" by ruling out
2319 /// integer overflow.
2320 ///
2321 /// For instance, this will return true for "A s< (A + C)<nsw>" if C is
2322 /// positive.
2323 bool isKnownPredicateViaNoOverflow(CmpPredicate Pred, SCEVUse LHS,
2324 SCEVUse RHS);
2325
2326 /// Try to split Pred LHS RHS into logical conjunctions (and's) and try to
2327 /// prove them individually.
2328 bool isKnownPredicateViaSplitting(CmpPredicate Pred, SCEVUse LHS,
2329 SCEVUse RHS);
2330
2331 /// Try to match the Expr as "(L + R)<Flags>".
2332 bool splitBinaryAdd(SCEVUse Expr, SCEVUse &L, SCEVUse &R,
2333 SCEV::NoWrapFlags &Flags);
2334
2335 /// Forget predicated/non-predicated backedge taken counts for the given loop.
2336 void forgetBackedgeTakenCounts(const Loop *L, bool Predicated);
2337
2338 /// Drop memoized information for all \p SCEVs.
2339 void forgetMemoizedResults(ArrayRef<SCEVUse> SCEVs);
2340
2341 /// Helper for forgetMemoizedResults.
2342 void forgetMemoizedResultsImpl(const SCEV *S);
2343
2344 /// Iterate over instructions in \p Worklist and their users. Erase entries
2345 /// from ValueExprMap and collect SCEV expressions in \p ToForget
2346 void visitAndClearUsers(SmallVectorImpl<Instruction *> &Worklist,
2347 SmallPtrSetImpl<Instruction *> &Visited,
2348 SmallVectorImpl<SCEVUse> &ToForget);
2349
2350 /// Erase Value from ValueExprMap and ExprValueMap.
2351 void eraseValueFromMap(Value *V);
2352
2353 /// Insert V to S mapping into ValueExprMap and ExprValueMap.
2354 void insertValueToMap(Value *V, const SCEV *S);
2355
2356 /// Return false iff given SCEV contains a SCEVUnknown with NULL value-
2357 /// pointer.
2358 bool checkValidity(const SCEV *S) const;
2359
2360 /// Return true if `ExtendOpTy`({`Start`,+,`Step`}) can be proved to be
2361 /// equal to {`ExtendOpTy`(`Start`),+,`ExtendOpTy`(`Step`)}. This is
2362 /// equivalent to proving no signed (resp. unsigned) wrap in
2363 /// {`Start`,+,`Step`} if `ExtendOpTy` is `SCEVSignExtendExpr`
2364 /// (resp. `SCEVZeroExtendExpr`).
2365 template <typename ExtendOpTy>
2366 bool proveNoWrapByVaryingStart(const SCEV *Start, const SCEV *Step,
2367 const Loop *L);
2368
2369 /// Try to prove NSW or NUW on \p AR relying on ConstantRange manipulation.
2370 SCEV::NoWrapFlags proveNoWrapViaConstantRanges(const SCEVAddRecExpr *AR);
2371
2372 /// Try to prove NSW on \p AR by proving facts about conditions known on
2373 /// entry and backedge.
2374 SCEV::NoWrapFlags proveNoSignedWrapViaInduction(const SCEVAddRecExpr *AR);
2375
2376 /// Try to prove NUW on \p AR by proving facts about conditions known on
2377 /// entry and backedge.
2378 SCEV::NoWrapFlags proveNoUnsignedWrapViaInduction(const SCEVAddRecExpr *AR);
2379
2380 std::optional<MonotonicPredicateType>
2381 getMonotonicPredicateTypeImpl(const SCEVAddRecExpr *LHS,
2382 ICmpInst::Predicate Pred);
2383
2384 /// Return SCEV no-wrap flags that can be proven based on reasoning about
2385 /// how poison produced from no-wrap flags on this value (e.g. a nuw add)
2386 /// would trigger undefined behavior on overflow.
2387 SCEV::NoWrapFlags getNoWrapFlagsFromUB(const Value *V);
2388
2389 /// Return a scope which provides an upper bound on the defining scope of
2390 /// 'S'. Specifically, return the first instruction in said bounding scope.
2391 /// Return nullptr if the scope is trivial (function entry).
2392 /// (See scope definition rules associated with flag discussion above)
2393 const Instruction *getNonTrivialDefiningScopeBound(const SCEV *S);
2394
2395 /// Return a scope which provides an upper bound on the defining scope for
2396 /// a SCEV with the operands in Ops. The outparam Precise is set if the
2397 /// bound found is a precise bound (i.e. must be the defining scope.)
2398 const Instruction *getDefiningScopeBound(ArrayRef<SCEVUse> Ops,
2399 bool &Precise);
2400
2401 /// Wrapper around the above for cases which don't care if the bound
2402 /// is precise.
2403 const Instruction *getDefiningScopeBound(ArrayRef<SCEVUse> Ops);
2404
2405 /// Given two instructions in the same function, return true if we can
2406 /// prove B must execute given A executes.
2407 bool isGuaranteedToTransferExecutionTo(const Instruction *A,
2408 const Instruction *B);
2409
2410 /// Returns true if \p Op is guaranteed not to cause immediate UB.
2411 bool isGuaranteedNotToCauseUB(const SCEV *Op);
2412
2413 /// Returns true if \p Op is guaranteed to not be poison.
2414 static bool isGuaranteedNotToBePoison(const SCEV *Op);
2415
2416 /// Return true if the SCEV corresponding to \p I is never poison. Proving
2417 /// this is more complex than proving that just \p I is never poison, since
2418 /// SCEV commons expressions across control flow, and you can have cases
2419 /// like:
2420 ///
2421 /// idx0 = a + b;
2422 /// ptr[idx0] = 100;
2423 /// if (<condition>) {
2424 /// idx1 = a +nsw b;
2425 /// ptr[idx1] = 200;
2426 /// }
2427 ///
2428 /// where the SCEV expression (+ a b) is guaranteed to not be poison (and
2429 /// hence not sign-overflow) only if "<condition>" is true. Since both
2430 /// `idx0` and `idx1` will be mapped to the same SCEV expression, (+ a b),
2431 /// it is not okay to annotate (+ a b) with <nsw> in the above example.
2432 bool isSCEVExprNeverPoison(const Instruction *I);
2433
2434 /// This is like \c isSCEVExprNeverPoison but it specifically works for
2435 /// instructions that will get mapped to SCEV add recurrences. Return true
2436 /// if \p I will never generate poison under the assumption that \p I is an
2437 /// add recurrence on the loop \p L.
2438 bool isAddRecNeverPoison(const Instruction *I, const Loop *L);
2439
2440 /// Similar to createAddRecFromPHI, but with the additional flexibility of
2441 /// suggesting runtime overflow checks in case casts are encountered.
2442 /// If successful, the analysis records that for this loop, \p SymbolicPHI,
2443 /// which is the UnknownSCEV currently representing the PHI, can be rewritten
2444 /// into an AddRec, assuming some predicates; The function then returns the
2445 /// AddRec and the predicates as a pair, and caches this pair in
2446 /// PredicatedSCEVRewrites.
2447 /// If the analysis is not successful, a mapping from the \p SymbolicPHI to
2448 /// itself (with no predicates) is recorded, and a nullptr with an empty
2449 /// predicates vector is returned as a pair.
2450 std::optional<std::pair<const SCEV *, SmallVector<const SCEVPredicate *, 3>>>
2451 createAddRecFromPHIWithCastsImpl(const SCEVUnknown *SymbolicPHI);
2452
2453 /// Compute the maximum backedge count based on the range of values
2454 /// permitted by Start, End, and Stride. This is for loops of the form
2455 /// {Start, +, Stride} LT End.
2456 ///
2457 /// Preconditions:
2458 /// * the induction variable is known to be positive.
2459 /// * the induction variable is assumed not to overflow (i.e. either it
2460 /// actually doesn't, or we'd have to immediately execute UB)
2461 /// We *don't* assert these preconditions so please be careful.
2462 const SCEV *computeMaxBECountForLT(const SCEV *Start, const SCEV *Stride,
2463 const SCEV *End, unsigned BitWidth,
2464 bool IsSigned);
2465
2466 /// Verify if an linear IV with positive stride can overflow when in a
2467 /// less-than comparison, knowing the invariant term of the comparison,
2468 /// the stride.
2469 bool canIVOverflowOnLT(const SCEV *RHS, const SCEV *Stride, bool IsSigned);
2470
2471 /// Verify if an linear IV with negative stride can overflow when in a
2472 /// greater-than comparison, knowing the invariant term of the comparison,
2473 /// the stride.
2474 bool canIVOverflowOnGT(const SCEV *RHS, const SCEV *Stride, bool IsSigned);
2475
2476 /// Get add expr already created or create a new one.
2477 const SCEV *getOrCreateAddExpr(ArrayRef<SCEVUse> Ops,
2478 SCEV::NoWrapFlags Flags);
2479
2480 /// Get mul expr already created or create a new one.
2481 const SCEV *getOrCreateMulExpr(ArrayRef<SCEVUse> Ops,
2482 SCEV::NoWrapFlags Flags);
2483
2484 // Get addrec expr already created or create a new one.
2485 const SCEV *getOrCreateAddRecExpr(ArrayRef<SCEVUse> Ops, const Loop *L,
2486 SCEV::NoWrapFlags Flags);
2487
2488 /// Return x if \p Val is f(x) where f is a 1-1 function.
2489 const SCEV *stripInjectiveFunctions(const SCEV *Val) const;
2490
2491 /// Find all of the loops transitively used in \p S, and fill \p LoopsUsed.
2492 /// A loop is considered "used" by an expression if it contains
2493 /// an add rec on said loop.
2494 void getUsedLoops(const SCEV *S, SmallPtrSetImpl<const Loop *> &LoopsUsed);
2495
2496 /// Look for a SCEV expression with type `SCEVType` and operands `Ops` in
2497 /// `UniqueSCEVs`. Return if found, else nullptr.
2498 SCEV *findExistingSCEVInCache(SCEVTypes SCEVType, ArrayRef<const SCEV *> Ops);
2499 SCEV *findExistingSCEVInCache(SCEVTypes SCEVType, ArrayRef<SCEVUse> Ops);
2500
2501 /// Get reachable blocks in this function, making limited use of SCEV
2502 /// reasoning about conditions.
2503 void getReachableBlocks(SmallPtrSetImpl<BasicBlock *> &Reachable,
2504 Function &F);
2505
2506 /// Return the given SCEV expression with a new set of operands.
2507 /// This preserves the origial nowrap flags.
2508 const SCEV *getWithOperands(const SCEV *S, SmallVectorImpl<SCEVUse> &NewOps);
2509
2510 FoldingSet<SCEV> UniqueSCEVs;
2511 FoldingSet<SCEVPredicate> UniquePreds;
2512 BumpPtrAllocator SCEVAllocator;
2513
2514 /// This maps loops to a list of addrecs that directly use said loop.
2515 DenseMap<const Loop *, SmallVector<const SCEVAddRecExpr *, 4>> LoopUsers;
2516
2517 /// Cache tentative mappings from UnknownSCEVs in a Loop, to a SCEV expression
2518 /// they can be rewritten into under certain predicates.
2519 DenseMap<std::pair<const SCEVUnknown *, const Loop *>,
2520 std::pair<const SCEV *, SmallVector<const SCEVPredicate *, 3>>>
2521 PredicatedSCEVRewrites;
2522
2523 /// Set of AddRecs for which proving NUW via an induction has already been
2524 /// tried.
2525 SmallPtrSet<const SCEVAddRecExpr *, 16> UnsignedWrapViaInductionTried;
2526
2527 /// Set of AddRecs for which proving NSW via an induction has already been
2528 /// tried.
2529 SmallPtrSet<const SCEVAddRecExpr *, 16> SignedWrapViaInductionTried;
2530
2531 /// The head of a linked list of all SCEVUnknown values that have been
2532 /// allocated. This is used by releaseMemory to locate them all and call
2533 /// their destructors.
2534 SCEVUnknown *FirstUnknown = nullptr;
2535};
2536
2537/// Analysis pass that exposes the \c ScalarEvolution for a function.
2539 : public AnalysisInfoMixin<ScalarEvolutionAnalysis> {
2541
2542 LLVM_ABI static AnalysisKey Key;
2543
2544public:
2546
2548};
2549
2550/// Verifier pass for the \c ScalarEvolutionAnalysis results.
2552 : public RequiredPassInfoMixin<ScalarEvolutionVerifierPass> {
2553public:
2555};
2556
2557/// Printer pass for the \c ScalarEvolutionAnalysis results.
2559 : public RequiredPassInfoMixin<ScalarEvolutionPrinterPass> {
2560 raw_ostream &OS;
2561
2562public:
2563 explicit ScalarEvolutionPrinterPass(raw_ostream &OS) : OS(OS) {}
2564
2566};
2567
2569 std::unique_ptr<ScalarEvolution> SE;
2570
2571public:
2572 static char ID;
2573
2575
2576 ScalarEvolution &getSE() { return *SE; }
2577 const ScalarEvolution &getSE() const { return *SE; }
2578
2579 bool runOnFunction(Function &F) override;
2580 void releaseMemory() override;
2581 void getAnalysisUsage(AnalysisUsage &AU) const override;
2582 void print(raw_ostream &OS, const Module * = nullptr) const override;
2583 void verifyAnalysis() const override;
2584};
2585
2586/// An interface layer with SCEV used to manage how we see SCEV expressions
2587/// for values in the context of existing predicates. We can add new
2588/// predicates, but we cannot remove them.
2589///
2590/// This layer has multiple purposes:
2591/// - provides a simple interface for SCEV versioning.
2592/// - guarantees that the order of transformations applied on a SCEV
2593/// expression for a single Value is consistent across two different
2594/// getSCEV calls. This means that, for example, once we've obtained
2595/// an AddRec expression for a certain value through expression
2596/// rewriting, we will continue to get an AddRec expression for that
2597/// Value.
2598/// - lowers the number of expression rewrites.
2600public:
2602
2603 LLVM_ABI const SCEVPredicate &getPredicate() const;
2604
2605 /// Returns the SCEV expression of V, in the context of the current SCEV
2606 /// predicate. The order of transformations applied on the expression of V
2607 /// returned by ScalarEvolution is guaranteed to be preserved, even when
2608 /// adding new predicates.
2609 LLVM_ABI const SCEV *getSCEV(Value *V);
2610
2611 /// Returns the rewritten SCEV for \p Expr in the context of the current SCEV
2612 /// predicate. The order of transformations applied on the expression of \p
2613 /// Expr returned by ScalarEvolution is guaranteed to be preserved, even when
2614 /// adding new predicates.
2615 LLVM_ABI const SCEV *getPredicatedSCEV(const SCEV *Expr);
2616
2617 /// Get the (predicated) backedge count for the analyzed loop.
2619
2620 /// Get the (predicated) symbolic max backedge count for the analyzed loop.
2622
2623 /// Returns the upper bound of the loop trip count as a normal unsigned
2624 /// value, or 0 if the trip count is unknown.
2626
2627 /// Adds a new predicate.
2628 LLVM_ABI void addPredicate(const SCEVPredicate &Pred);
2629
2630 /// Attempts to produce an AddRecExpr for V by adding additional SCEV
2631 /// predicates. If we can't transform the expression into an AddRecExpr we
2632 /// return nullptr and not add additional SCEV predicates to the current
2633 /// context.
2635
2636 /// Proves that V doesn't overflow by adding SCEV predicate.
2639
2640 /// Returns true if we've proved that V doesn't wrap by means of a SCEV
2641 /// predicate.
2644
2645 /// Returns the ScalarEvolution analysis used.
2646 ScalarEvolution *getSE() const { return &SE; }
2647
2648 /// We need to explicitly define the copy constructor because of FlagsMap.
2650
2651 /// Print the SCEV mappings done by the Predicated Scalar Evolution.
2652 /// The printed text is indented by \p Depth.
2653 LLVM_ABI void print(raw_ostream &OS, unsigned Depth) const;
2654
2655 /// Check if \p AR1 and \p AR2 are equal, while taking into account
2656 /// Equal predicates in Preds.
2658 const SCEVAddRecExpr *AR2) const;
2659
2660private:
2661 /// Increments the version number of the predicate. This needs to be called
2662 /// every time the SCEV predicate changes.
2663 void updateGeneration();
2664
2665 /// Holds a SCEV and the version number of the SCEV predicate used to
2666 /// perform the rewrite of the expression.
2667 using RewriteEntry = std::pair<unsigned, const SCEV *>;
2668
2669 /// Maps a SCEV to the rewrite result of that SCEV at a certain version
2670 /// number. If this number doesn't match the current Generation, we will
2671 /// need to do a rewrite. To preserve the transformation order of previous
2672 /// rewrites, we will rewrite the previous result instead of the original
2673 /// SCEV.
2675
2676 /// Records what NoWrap flags we've added to a Value *.
2678
2679 /// The ScalarEvolution analysis.
2680 ScalarEvolution &SE;
2681
2682 /// The analyzed Loop.
2683 const Loop &L;
2684
2685 /// The SCEVPredicate that forms our context. We will rewrite all
2686 /// expressions assuming that this predicate true.
2687 std::unique_ptr<SCEVUnionPredicate> Preds;
2688
2689 /// Marks the version of the SCEV predicate used. When rewriting a SCEV
2690 /// expression we mark it with the version of the predicate. We use this to
2691 /// figure out if the predicate has changed from the last rewrite of the
2692 /// SCEV. If so, we need to perform a new rewrite.
2693 unsigned Generation = 0;
2694
2695 /// The backedge taken count.
2696 const SCEV *BackedgeCount = nullptr;
2697
2698 /// The symbolic backedge taken count.
2699 const SCEV *SymbolicMaxBackedgeCount = nullptr;
2700
2701 /// The constant max trip count for the loop.
2702 std::optional<unsigned> SmallConstantMaxTripCount;
2703};
2704
2705template <> struct DenseMapInfo<ScalarEvolution::FoldID> {
2708 return ID;
2709 }
2712 return ID;
2713 }
2714
2715 static unsigned getHashValue(const ScalarEvolution::FoldID &Val) {
2716 return Val.computeHash();
2717 }
2718
2721 return LHS == RHS;
2722 }
2723};
2724
2725template <> inline const SCEV *SCEVUseT<const SCEV *>::getCanonical() const {
2726 return getPointer()->getCanonical();
2727}
2728
2729template <typename SCEVPtrT>
2731 getPointer()->print(OS);
2733 if (any(Flags & SCEV::FlagNUW))
2734 OS << "(u nuw)";
2735 if (any(Flags & SCEV::FlagNSW))
2736 OS << "(u nsw)";
2737}
2738
2739#if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP)
2740template <typename SCEVPtrT>
2742 print(dbgs());
2743 dbgs() << '\n';
2744}
2745#endif
2746
2747} // end namespace llvm
2748
2749#endif // LLVM_ANALYSIS_SCALAREVOLUTION_H
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
aarch64 promote const
constexpr LLT S1
This file implements a class to represent arbitrary precision integral constant values and operations...
static void print(raw_ostream &Out, object::Archive::Kind Kind, T Val)
#define X(NUM, ENUM, NAME)
Definition ELF.h:853
static GCRegistry::Add< ErlangGC > A("erlang", "erlang-compatible garbage collector")
static GCRegistry::Add< StatepointGC > D("statepoint-example", "an example strategy for statepoint")
static GCRegistry::Add< CoreCLRGC > E("coreclr", "CoreCLR-compatible GC")
static GCRegistry::Add< OcamlGC > B("ocaml", "ocaml 3.10-compatible GC")
#define LLVM_ABI
Definition Compiler.h:213
#define LLVM_DUMP_METHOD
Mark debug helper function definitions like dump() that should not be stripped from debug builds.
Definition Compiler.h:661
SmallPtrSet< const BasicBlock *, 8 > VisitedBlocks
This file defines DenseMapInfo traits for DenseMap.
This file defines the DenseMap class.
static bool runOnFunction(Function &F, bool PostInlining)
static bool isSigned(unsigned Opcode)
This file defines a hash set that can be used to remove duplication of nodes in a graph.
Hexagon Common GEP
Value * getPointer(Value *Ptr)
This header defines various interfaces for pass management in LLVM.
const AbstractManglingParser< Derived, Alloc >::OperatorInfo AbstractManglingParser< Derived, Alloc >::Ops[]
#define F(x, y, z)
Definition MD5.cpp:54
#define I(x, y, z)
Definition MD5.cpp:57
#define P(N)
This file defines the PointerIntPair class.
const SmallVectorImpl< MachineOperand > & Cond
This file implements a set that has insertion order iteration characteristics.
This file defines the SmallPtrSet class.
This file defines the SmallVector class.
Value * RHS
Value * LHS
Class for arbitrary precision integers.
Definition APInt.h:78
static APInt getOneBitSet(unsigned numBits, unsigned BitNo)
Return an APInt with exactly one bit set in the result.
Definition APInt.h:240
Represent the analysis usage information of a pass.
Represent a constant reference to an array (0 or more elements consecutively in memory),...
Definition ArrayRef.h:40
A cache of @llvm.assume calls within a function.
LLVM Basic Block Representation.
Definition BasicBlock.h:62
Value handle with callbacks on RAUW and destruction.
Predicate
This enumeration lists the possible predicates for CmpInst subclasses.
Definition InstrTypes.h:676
An abstraction over a floating-point predicate, and a pack of an integer predicate with samesign info...
This is the shared class of boolean and integer constants.
Definition Constants.h:87
This class represents a range of values.
This is an important base class in LLVM.
Definition Constant.h:43
A parsed version of the target data layout string in and methods for querying it.
Definition DataLayout.h:64
Concrete subclass of DominatorTreeBase that is used to compute a normal dominator tree.
Definition Dominators.h:159
This class describes a reference to an interned FoldingSetNodeID, which can be a useful to store node...
Definition FoldingSet.h:171
This class is used to gather all the unique data bits of a node.
Definition FoldingSet.h:208
FunctionPass(char &pid)
Definition Pass.h:316
Represents flags for the getelementptr instruction/expression.
static GEPNoWrapFlags none()
This is an important class for using LLVM in a threaded context.
Definition LLVMContext.h:68
Represents a single loop in the control flow graph.
Definition LoopInfo.h:40
A Module instance is used to store all the information related to an LLVM module.
Definition Module.h:67
Utility class for integer operators which may exhibit overflow - Add, Sub, Mul, and Shl.
Definition Operator.h:78
bool operator>(const PointerIntPair &RHS) const
Value handle that poisons itself if the Value is deleted.
An interface layer with SCEV used to manage how we see SCEV expressions for values in the context of ...
LLVM_ABI void addPredicate(const SCEVPredicate &Pred)
Adds a new predicate.
ScalarEvolution * getSE() const
Returns the ScalarEvolution analysis used.
LLVM_ABI const SCEVPredicate & getPredicate() const
LLVM_ABI const SCEV * getPredicatedSCEV(const SCEV *Expr)
Returns the rewritten SCEV for Expr in the context of the current SCEV predicate.
LLVM_ABI bool hasNoOverflow(Value *V, SCEVWrapPredicate::IncrementWrapFlags Flags)
Returns true if we've proved that V doesn't wrap by means of a SCEV predicate.
LLVM_ABI void setNoOverflow(Value *V, SCEVWrapPredicate::IncrementWrapFlags Flags)
Proves that V doesn't overflow by adding SCEV predicate.
LLVM_ABI void print(raw_ostream &OS, unsigned Depth) const
Print the SCEV mappings done by the Predicated Scalar Evolution.
LLVM_ABI bool areAddRecsEqualWithPreds(const SCEVAddRecExpr *AR1, const SCEVAddRecExpr *AR2) const
Check if AR1 and AR2 are equal, while taking into account Equal predicates in Preds.
LLVM_ABI PredicatedScalarEvolution(ScalarEvolution &SE, Loop &L)
LLVM_ABI const SCEVAddRecExpr * getAsAddRec(Value *V)
Attempts to produce an AddRecExpr for V by adding additional SCEV predicates.
LLVM_ABI unsigned getSmallConstantMaxTripCount()
Returns the upper bound of the loop trip count as a normal unsigned value, or 0 if the trip count is ...
LLVM_ABI const SCEV * getBackedgeTakenCount()
Get the (predicated) backedge count for the analyzed loop.
LLVM_ABI const SCEV * getSymbolicMaxBackedgeTakenCount()
Get the (predicated) symbolic max backedge count for the analyzed loop.
LLVM_ABI const SCEV * getSCEV(Value *V)
Returns the SCEV expression of V, in the context of the current SCEV predicate.
A set of analyses that are preserved following a run of a transformation pass.
Definition Analysis.h:112
This node represents a polynomial recurrence on the trip count of the specified loop.
SCEVComparePredicate(const FoldingSetNodeIDRef ID, const ICmpInst::Predicate Pred, const SCEV *LHS, const SCEV *RHS)
const SCEV * getRHS() const
Returns the right hand side of the predicate.
ICmpInst::Predicate getPredicate() const
bool isAlwaysTrue() const override
Returns true if the predicate is always true.
const SCEV * getLHS() const
Returns the left hand side of the predicate.
static bool classof(const SCEVPredicate *P)
Methods for support type inquiry through isa, cast, and dyn_cast:
bool implies(const SCEVPredicate *N, ScalarEvolution &SE) const override
Implementation of the SCEVPredicate interface.
This class represents an assumption made using SCEV expressions which can be checked at run-time.
SCEVPredicateKind getKind() const
virtual unsigned getComplexity() const
Returns the estimated complexity of this predicate.
SCEVPredicate & operator=(const SCEVPredicate &)=default
SCEVPredicate(const SCEVPredicate &)=default
virtual bool implies(const SCEVPredicate *N, ScalarEvolution &SE) 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.
~SCEVPredicate()=default
virtual bool isAlwaysTrue() const =0
Returns true if the predicate is always true.
SCEVPredicateKind Kind
unsigned getComplexity() const override
We estimate the complexity of a union predicate as the size number of predicates in the union.
SCEVUnionPredicate(ArrayRef< const SCEVPredicate * > Preds, ScalarEvolution &SE)
Union predicates don't get cached so create a dummy set ID for it.
SCEVUnionPredicate getUnionWith(const SCEVPredicate *N, ScalarEvolution &SE) const
Returns a new SCEVUnionPredicate that is the union of this predicate and the given predicate N.
ArrayRef< const SCEVPredicate * > getPredicates() const
static bool classof(const SCEVPredicate *P)
Methods for support type inquiry through isa, cast, and dyn_cast:
This means that we are dealing with an entirely unknown SCEV value, and only represent it as its LLVM...
This class represents an assumption made on an AddRec expression.
IncrementWrapFlags
Similar to SCEV::NoWrapFlags, but with slightly different semantics for FlagNUSW.
SCEVWrapPredicate(const FoldingSetNodeIDRef ID, const SCEVAddRecExpr *AR, IncrementWrapFlags Flags)
static SCEVWrapPredicate::IncrementWrapFlags setFlags(SCEVWrapPredicate::IncrementWrapFlags Flags, SCEVWrapPredicate::IncrementWrapFlags OnFlags)
static SCEVWrapPredicate::IncrementWrapFlags clearFlags(SCEVWrapPredicate::IncrementWrapFlags Flags, SCEVWrapPredicate::IncrementWrapFlags OffFlags)
Convenient IncrementWrapFlags manipulation methods.
static bool classof(const SCEVPredicate *P)
Methods for support type inquiry through isa, cast, and dyn_cast:
IncrementWrapFlags getFlags() const
Returns the set assumed no overflow flags.
static SCEVWrapPredicate::IncrementWrapFlags maskFlags(SCEVWrapPredicate::IncrementWrapFlags Flags, int Mask)
This class represents an analyzed expression in the program.
LLVM_ABI const SCEV * getCanonical() const
Return the canonical SCEV.
static constexpr auto NoWrapMask
unsigned short getExpressionSize() const
SCEV & operator=(const SCEV &)=delete
SCEVNoWrapFlags NoWrapFlags
LLVM_ABI bool isOne() const
Return true if the expression is a constant one.
static constexpr auto FlagNUW
LLVM_ABI void computeAndSetCanonical(ScalarEvolution &SE)
Compute and set the canonical SCEV, by constructing a SCEV with the same operands,...
LLVM_ABI bool isZero() const
Return true if the expression is a constant zero.
SCEV(const SCEV &)=delete
const SCEV * CanonicalSCEV
Pointer to the canonical version of the SCEV, i.e.
static constexpr auto FlagAnyWrap
LLVM_ABI void dump() const
This method is used for debugging.
LLVM_ABI bool isAllOnesValue() const
Return true if the expression is a constant all-ones value.
LLVM_ABI bool isNonConstantNegative() const
Return true if the specified scev is negated, but not a constant.
static constexpr auto FlagNSW
LLVM_ABI ArrayRef< SCEVUse > operands() const
Return operands of this SCEV expression.
const unsigned short ExpressionSize
LLVM_ABI void print(raw_ostream &OS) const
Print out the internal representation of this scalar to the specified stream.
SCEV(const FoldingSetNodeIDRef ID, SCEVTypes SCEVTy, unsigned short ExpressionSize)
SCEVTypes getSCEVType() const
unsigned short SubclassData
This field is initialized to zero and may be used in subclasses to store miscellaneous information.
static constexpr auto FlagNW
LLVM_ABI Type * getType() const
Return the LLVM type of this SCEV expression.
Analysis pass that exposes the ScalarEvolution for a function.
LLVM_ABI ScalarEvolution run(Function &F, FunctionAnalysisManager &AM)
LLVM_ABI PreservedAnalyses run(Function &F, FunctionAnalysisManager &AM)
Verifier pass for the ScalarEvolutionAnalysis results.
LLVM_ABI PreservedAnalyses run(Function &F, FunctionAnalysisManager &AM)
const ScalarEvolution & getSE() const
bool operator==(const FoldID &RHS) const
FoldID(SCEVTypes C, const SCEV *Op, const Type *Ty)
static LLVM_ABI LoopGuards collect(const Loop *L, ScalarEvolution &SE)
Collect rewrite map for loop guards for loop L, together with flags indicating if NUW and NSW can be ...
LLVM_ABI const SCEV * rewrite(const SCEV *Expr) const
Try to apply the collected loop guards to Expr.
The main scalar evolution driver.
LLVM_ABI const SCEV * getUDivExpr(SCEVUse LHS, SCEVUse RHS)
Get a canonical unsigned division expression, or something simpler if possible.
const SCEV * getConstantMaxBackedgeTakenCount(const Loop *L)
When successful, this returns a SCEVConstant that is greater than or equal to (i.e.
static bool hasFlags(SCEV::NoWrapFlags Flags, SCEV::NoWrapFlags TestFlags)
const DataLayout & getDataLayout() const
Return the DataLayout associated with the module this SCEV instance is operating on.
LLVM_ABI bool isKnownNonNegative(const SCEV *S)
Test if the given expression is known to be non-negative.
LLVM_ABI bool isKnownOnEveryIteration(CmpPredicate Pred, const SCEVAddRecExpr *LHS, const SCEV *RHS)
Test if the condition described by Pred, LHS, RHS is known to be true on every iteration of the loop ...
LLVM_ABI const SCEV * getNegativeSCEV(const SCEV *V, SCEV::NoWrapFlags Flags=SCEV::FlagAnyWrap)
Return the SCEV object corresponding to -V.
LLVM_ABI std::optional< LoopInvariantPredicate > getLoopInvariantExitCondDuringFirstIterationsImpl(CmpPredicate Pred, const SCEV *LHS, const SCEV *RHS, const Loop *L, const Instruction *CtxI, const SCEV *MaxIter)
LLVM_ABI const SCEV * getUDivCeilSCEV(const SCEV *N, const SCEV *D)
Compute ceil(N / D).
LLVM_ABI std::optional< LoopInvariantPredicate > getLoopInvariantExitCondDuringFirstIterations(CmpPredicate Pred, const SCEV *LHS, const SCEV *RHS, const Loop *L, const Instruction *CtxI, const SCEV *MaxIter)
If the result of the predicate LHS Pred RHS is loop invariant with respect to L at given Context duri...
LLVM_ABI Type * getWiderType(Type *Ty1, Type *Ty2) const
LLVM_ABI const SCEV * getAbsExpr(const SCEV *Op, bool IsNSW)
LLVM_ABI bool isKnownNonPositive(const SCEV *S)
Test if the given expression is known to be non-positive.
LLVM_ABI bool isKnownNegative(const SCEV *S)
Test if the given expression is known to be negative.
LLVM_ABI const SCEV * getPredicatedConstantMaxBackedgeTakenCount(const Loop *L, SmallVectorImpl< const SCEVPredicate * > &Predicates)
Similar to getConstantMaxBackedgeTakenCount, except it will add a set of SCEV predicates to Predicate...
LLVM_ABI const SCEV * removePointerBase(const SCEV *S)
Compute an expression equivalent to S - getPointerBase(S).
LLVM_ABI bool isLoopEntryGuardedByCond(const Loop *L, CmpPredicate Pred, const SCEV *LHS, const SCEV *RHS)
Test whether entry to the loop is protected by a conditional between LHS and RHS.
LLVM_ABI bool isKnownNonZero(const SCEV *S)
Test if the given expression is known to be non-zero.
LLVM_ABI const SCEV * getURemExpr(SCEVUse LHS, SCEVUse RHS)
Represents an unsigned remainder expression based on unsigned division.
LLVM_ABI const SCEV * getSCEVAtScope(const SCEV *S, const Loop *L)
Return a SCEV expression for the specified value at the specified scope in the program.
LLVM_ABI const SCEV * getBackedgeTakenCount(const Loop *L, ExitCountKind Kind=Exact)
If the specified loop has a predictable backedge-taken count, return it, otherwise return a SCEVCould...
LLVM_ABI const SCEV * getSMinExpr(SCEVUse LHS, SCEVUse RHS)
LLVM_ABI void setNoWrapFlags(SCEVAddRecExpr *AddRec, SCEV::NoWrapFlags Flags)
Update no-wrap flags of an AddRec.
LLVM_ABI const SCEV * getUMaxFromMismatchedTypes(const SCEV *LHS, const SCEV *RHS)
Promote the operands to the wider of the types using zero-extension, and then perform a umax operatio...
const SCEV * getZero(Type *Ty)
Return a SCEV for the constant 0 of a specific type.
LLVM_ABI bool willNotOverflow(Instruction::BinaryOps BinOp, bool Signed, const SCEV *LHS, const SCEV *RHS, const Instruction *CtxI=nullptr)
Is operation BinOp between LHS and RHS provably does not have a signed/unsigned overflow (Signed)?
LLVM_ABI ExitLimit computeExitLimitFromCond(const Loop *L, Value *ExitCond, bool ExitIfTrue, bool ControlsOnlyExit, bool AllowPredicates=false)
Compute the number of times the backedge of the specified loop will execute if its exit condition wer...
LLVM_ABI const SCEV * getZeroExtendExprImpl(const SCEV *Op, Type *Ty, unsigned Depth=0)
LLVM_ABI const SCEV * getMinMaxExpr(SCEVTypes Kind, SmallVectorImpl< SCEVUse > &Operands)
LLVM_ABI const SCEVPredicate * getEqualPredicate(const SCEV *LHS, const SCEV *RHS)
LLVM_ABI unsigned getSmallConstantTripMultiple(const Loop *L, const SCEV *ExitCount)
Returns the largest constant divisor of the trip count as a normal unsigned value,...
LLVM_ABI uint64_t getTypeSizeInBits(Type *Ty) const
Return the size in bits of the specified type, for which isSCEVable must return true.
LLVM_ABI const SCEV * getConstant(ConstantInt *V)
LLVM_ABI const SCEV * getPredicatedBackedgeTakenCount(const Loop *L, SmallVectorImpl< const SCEVPredicate * > &Predicates)
Similar to getBackedgeTakenCount, except it will add a set of SCEV predicates to Predicates that are ...
LLVM_ABI const SCEV * getSCEV(Value *V)
Return a SCEV expression for the full generality of the specified expression.
LLVM_ABI const SCEV * getMinusSCEV(SCEVUse LHS, SCEVUse RHS, SCEV::NoWrapFlags Flags=SCEV::FlagAnyWrap, unsigned Depth=0)
Return LHS-RHS.
ConstantRange getSignedRange(const SCEV *S)
Determine the signed range for a particular SCEV.
LLVM_ABI const SCEV * getAddRecExpr(SCEVUse Start, SCEVUse Step, const Loop *L, SCEV::NoWrapFlags Flags)
Get an add recurrence expression for the specified loop.
LLVM_ABI const SCEV * getNoopOrSignExtend(const SCEV *V, Type *Ty)
Return a SCEV corresponding to a conversion of the input value to the specified type.
bool loopHasNoAbnormalExits(const Loop *L)
Return true if the loop has no abnormal exits.
LLVM_ABI const SCEV * getTripCountFromExitCount(const SCEV *ExitCount)
A version of getTripCountFromExitCount below which always picks an evaluation type which can not resu...
LLVM_ABI ScalarEvolution(Function &F, TargetLibraryInfo &TLI, AssumptionCache &AC, DominatorTree &DT, LoopInfo &LI)
const SCEV * getOne(Type *Ty)
Return a SCEV for the constant 1 of a specific type.
LLVM_ABI const SCEV * getTruncateOrNoop(const SCEV *V, Type *Ty)
Return a SCEV corresponding to a conversion of the input value to the specified type.
LLVM_ABI const SCEV * getLosslessPtrToIntExpr(const SCEV *Op)
const SCEV * getMulExpr(SCEVUse Op0, SCEVUse Op1, SCEVUse Op2, SCEV::NoWrapFlags Flags=SCEV::FlagAnyWrap, unsigned Depth=0)
LLVM_ABI const SCEV * getCastExpr(SCEVTypes Kind, const SCEV *Op, Type *Ty)
LLVM_ABI const SCEV * getSequentialMinMaxExpr(SCEVTypes Kind, SmallVectorImpl< SCEVUse > &Operands)
LLVM_ABI std::optional< bool > evaluatePredicateAt(CmpPredicate Pred, const SCEV *LHS, const SCEV *RHS, const Instruction *CtxI)
Check whether the condition described by Pred, LHS, and RHS is true or false in the given Context.
LLVM_ABI unsigned getSmallConstantMaxTripCount(const Loop *L, SmallVectorImpl< const SCEVPredicate * > *Predicates=nullptr)
Returns the upper bound of the loop trip count as a normal unsigned value.
LLVM_ABI const SCEV * getPtrToIntExpr(const SCEV *Op, Type *Ty)
LLVM_ABI bool isBackedgeTakenCountMaxOrZero(const Loop *L)
Return true if the backedge taken count is either the value returned by getConstantMaxBackedgeTakenCo...
LLVM_ABI void forgetLoop(const Loop *L)
This method should be called by the client when it has changed a loop in a way that may effect Scalar...
LLVM_ABI bool isLoopInvariant(const SCEV *S, const Loop *L)
Return true if the value of the given SCEV is unchanging in the specified loop.
LLVM_ABI bool isKnownPositive(const SCEV *S)
Test if the given expression is known to be positive.
LLVM_ABI bool SimplifyICmpOperands(CmpPredicate &Pred, SCEVUse &LHS, SCEVUse &RHS, unsigned Depth=0)
Simplify LHS and RHS in a comparison with predicate Pred.
APInt getUnsignedRangeMin(const SCEV *S)
Determine the min of the unsigned range for a particular SCEV.
LLVM_ABI const SCEV * getOffsetOfExpr(Type *IntTy, StructType *STy, unsigned FieldNo)
Return an expression for offsetof on the given field with type IntTy.
LLVM_ABI LoopDisposition getLoopDisposition(const SCEV *S, const Loop *L)
Return the "disposition" of the given SCEV with respect to the given loop.
LLVM_ABI bool containsAddRecurrence(const SCEV *S)
Return true if the SCEV is a scAddRecExpr or it contains scAddRecExpr.
LLVM_ABI const SCEV * getSignExtendExprImpl(const SCEV *Op, Type *Ty, unsigned Depth=0)
LLVM_ABI bool hasOperand(const SCEV *S, const SCEV *Op) const
Test whether the given SCEV has Op as a direct or indirect operand.
LLVM_ABI const SCEV * getZeroExtendExpr(const SCEV *Op, Type *Ty, unsigned Depth=0)
LLVM_ABI bool isSCEVable(Type *Ty) const
Test if values of the given type are analyzable within the SCEV framework.
LLVM_ABI Type * getEffectiveSCEVType(Type *Ty) const
Return a type with the same bitwidth as the given type and which represents how SCEV will treat the g...
LLVM_ABI const SCEVPredicate * getComparePredicate(ICmpInst::Predicate Pred, const SCEV *LHS, const SCEV *RHS)
LLVM_ABI bool haveSameSign(const SCEV *S1, const SCEV *S2)
Return true if we know that S1 and S2 must have the same sign.
LLVM_ABI const SCEV * getNotSCEV(const SCEV *V)
Return the SCEV object corresponding to ~V.
LLVM_ABI const SCEV * getElementCount(Type *Ty, ElementCount EC, SCEV::NoWrapFlags Flags=SCEV::FlagAnyWrap)
LLVM_ABI bool instructionCouldExistWithOperands(const SCEV *A, const SCEV *B)
Return true if there exists a point in the program at which both A and B could be operands to the sam...
ConstantRange getUnsignedRange(const SCEV *S)
Determine the unsigned range for a particular SCEV.
LLVM_ABI void print(raw_ostream &OS) const
LLVM_ABI const SCEV * getPredicatedExitCount(const Loop *L, const BasicBlock *ExitingBlock, SmallVectorImpl< const SCEVPredicate * > *Predicates, ExitCountKind Kind=Exact)
Same as above except this uses the predicated backedge taken info and may require predicates.
static SCEV::NoWrapFlags clearFlags(SCEV::NoWrapFlags Flags, SCEV::NoWrapFlags OffFlags)
LLVM_ABI void forgetTopmostLoop(const Loop *L)
friend class ScalarEvolutionsTest
LLVM_ABI void forgetValue(Value *V)
This method should be called by the client when it has changed a value in a way that may effect its v...
APInt getSignedRangeMin(const SCEV *S)
Determine the min of the signed range for a particular SCEV.
LLVM_ABI const SCEV * getNoopOrAnyExtend(const SCEV *V, Type *Ty)
Return a SCEV corresponding to a conversion of the input value to the specified type.
LLVM_ABI void forgetBlockAndLoopDispositions(Value *V=nullptr)
Called when the client has changed the disposition of values in a loop or block.
LLVM_ABI const SCEV * getTruncateExpr(const SCEV *Op, Type *Ty, unsigned Depth=0)
LLVM_ABI const SCEV * getUMaxExpr(SCEVUse LHS, SCEVUse RHS)
static SCEV::NoWrapFlags maskFlags(SCEV::NoWrapFlags Flags, SCEV::NoWrapFlags Mask)
Convenient NoWrapFlags manipulation.
MonotonicPredicateType
A predicate is said to be monotonically increasing if may go from being false to being true as the lo...
LLVM_ABI std::optional< LoopInvariantPredicate > getLoopInvariantPredicate(CmpPredicate Pred, const SCEV *LHS, const SCEV *RHS, const Loop *L, const Instruction *CtxI=nullptr)
If the result of the predicate LHS Pred RHS is loop invariant with respect to L, return a LoopInvaria...
LLVM_ABI const SCEV * getStoreSizeOfExpr(Type *IntTy, Type *StoreTy)
Return an expression for the store size of StoreTy that is type IntTy.
LLVM_ABI const SCEVPredicate * getWrapPredicate(const SCEVAddRecExpr *AR, SCEVWrapPredicate::IncrementWrapFlags AddedFlags)
LLVM_ABI bool isLoopBackedgeGuardedByCond(const Loop *L, CmpPredicate Pred, const SCEV *LHS, const SCEV *RHS)
Test whether the backedge of the loop is protected by a conditional between LHS and RHS.
LLVM_ABI APInt getNonZeroConstantMultiple(const SCEV *S)
const SCEV * getMinusOne(Type *Ty)
Return a SCEV for the constant -1 of a specific type.
static SCEV::NoWrapFlags setFlags(SCEV::NoWrapFlags Flags, SCEV::NoWrapFlags OnFlags)
LLVM_ABI bool hasLoopInvariantBackedgeTakenCount(const Loop *L)
Return true if the specified loop has an analyzable loop-invariant backedge-taken count.
LLVM_ABI BlockDisposition getBlockDisposition(const SCEV *S, const BasicBlock *BB)
Return the "disposition" of the given SCEV with respect to the given block.
LLVM_ABI const SCEV * getNoopOrZeroExtend(const SCEV *V, Type *Ty)
Return a SCEV corresponding to a conversion of the input value to the specified type.
LLVM_ABI bool invalidate(Function &F, const PreservedAnalyses &PA, FunctionAnalysisManager::Invalidator &Inv)
LLVM_ABI const SCEV * getUMinFromMismatchedTypes(const SCEV *LHS, const SCEV *RHS, bool Sequential=false)
Promote the operands to the wider of the types using zero-extension, and then perform a umin operatio...
LLVM_ABI bool loopIsFiniteByAssumption(const Loop *L)
Return true if this loop is finite by assumption.
LLVM_ABI const SCEV * getExistingSCEV(Value *V)
Return an existing SCEV for V if there is one, otherwise return nullptr.
LLVM_ABI APInt getConstantMultiple(const SCEV *S, const Instruction *CtxI=nullptr)
Returns the max constant multiple of S.
LoopDisposition
An enum describing the relationship between a SCEV and a loop.
@ LoopComputable
The SCEV varies predictably with the loop.
@ LoopVariant
The SCEV is loop-variant (unknown).
@ LoopInvariant
The SCEV is loop-invariant.
LLVM_ABI bool isKnownMultipleOf(const SCEV *S, uint64_t M, SmallVectorImpl< const SCEVPredicate * > &Assumptions)
Check that S is a multiple of M.
LLVM_ABI const SCEV * getAnyExtendExpr(const SCEV *Op, Type *Ty)
getAnyExtendExpr - Return a SCEV for the given operand extended with unspecified bits out to the give...
const SCEV * getAddRecExpr(const SmallVectorImpl< SCEVUse > &Operands, const Loop *L, SCEV::NoWrapFlags Flags)
LLVM_ABI bool isKnownToBeAPowerOfTwo(const SCEV *S, bool OrZero=false, bool OrNegative=false)
Test if the given expression is known to be a power of 2.
LLVM_ABI std::optional< SCEV::NoWrapFlags > getStrengthenedNoWrapFlagsFromBinOp(const OverflowingBinaryOperator *OBO)
Parse NSW/NUW flags from add/sub/mul IR binary operation Op into SCEV no-wrap flags,...
LLVM_ABI void forgetLcssaPhiWithNewPredecessor(Loop *L, PHINode *V)
Forget LCSSA phi node V of loop L to which a new predecessor was added, such that it may no longer be...
LLVM_ABI bool containsUndefs(const SCEV *S) const
Return true if the SCEV expression contains an undef value.
LLVM_ABI std::optional< MonotonicPredicateType > getMonotonicPredicateType(const SCEVAddRecExpr *LHS, ICmpInst::Predicate Pred)
If, for all loop invariant X, the predicate "LHS `Pred` X" is monotonically increasing or decreasing,...
LLVM_ABI const SCEV * getCouldNotCompute()
LLVM_ABI const SCEV * getMulExpr(SmallVectorImpl< SCEVUse > &Ops, SCEV::NoWrapFlags Flags=SCEV::FlagAnyWrap, unsigned Depth=0)
Get a canonical multiply expression, or something simpler if possible.
LLVM_ABI bool isAvailableAtLoopEntry(const SCEV *S, const Loop *L)
Determine if the SCEV can be evaluated at loop's entry.
LLVM_ABI uint32_t getMinTrailingZeros(const SCEV *S, const Instruction *CtxI=nullptr)
Determine the minimum number of zero bits that S is guaranteed to end in (at every loop iteration).
BlockDisposition
An enum describing the relationship between a SCEV and a basic block.
@ DominatesBlock
The SCEV dominates the block.
@ ProperlyDominatesBlock
The SCEV properly dominates the block.
@ DoesNotDominateBlock
The SCEV does not dominate the block.
LLVM_ABI const SCEV * getExitCount(const Loop *L, const BasicBlock *ExitingBlock, ExitCountKind Kind=Exact)
Return the number of times the backedge executes before the given exit would be taken; if not exactly...
LLVM_ABI const SCEV * getSignExtendExpr(const SCEV *Op, Type *Ty, unsigned Depth=0)
LLVM_ABI void getPoisonGeneratingValues(SmallPtrSetImpl< const Value * > &Result, const SCEV *S)
Return the set of Values that, if poison, will definitively result in S being poison as well.
LLVM_ABI void forgetLoopDispositions()
Called when the client has changed the disposition of values in this loop.
LLVM_ABI const SCEV * getVScale(Type *Ty)
LLVM_ABI unsigned getSmallConstantTripCount(const Loop *L)
Returns the exact trip count of the loop if we can compute it, and the result is a small constant.
LLVM_ABI bool hasComputableLoopEvolution(const SCEV *S, const Loop *L)
Return true if the given SCEV changes value in a known way in the specified loop.
LLVM_ABI const SCEV * getPointerBase(const SCEV *V)
Transitively follow the chain of pointer-type operands until reaching a SCEV that does not have a sin...
const SCEV * getPowerOfTwo(Type *Ty, unsigned Power)
Return a SCEV for the constant Power of two.
LLVM_ABI void forgetAllLoops()
LLVM_ABI bool dominates(const SCEV *S, const BasicBlock *BB)
Return true if elements that makes up the given SCEV dominate the specified basic block.
const SCEV * getAddExpr(SCEVUse Op0, SCEVUse Op1, SCEVUse Op2, SCEV::NoWrapFlags Flags=SCEV::FlagAnyWrap, unsigned Depth=0)
APInt getUnsignedRangeMax(const SCEV *S)
Determine the max of the unsigned range for a particular SCEV.
LLVM_ABI const SCEV * getAddExpr(SmallVectorImpl< SCEVUse > &Ops, SCEV::NoWrapFlags Flags=SCEV::FlagAnyWrap, unsigned Depth=0)
Get a canonical add expression, or something simpler if possible.
ExitCountKind
The terms "backedge taken count" and "exit count" are used interchangeably to refer to the number of ...
@ SymbolicMaximum
An expression which provides an upper bound on the exact trip count.
@ ConstantMaximum
A constant which provides an upper bound on the exact trip count.
@ Exact
An expression exactly describing the number of times the backedge has executed when a loop is exited.
LLVM_ABI bool isKnownPredicate(CmpPredicate Pred, SCEVUse LHS, SCEVUse RHS)
Test if the given expression is known to satisfy the condition described by Pred, LHS,...
LLVM_ABI const SCEV * applyLoopGuards(const SCEV *Expr, const Loop *L)
Try to apply information from loop guards for L to Expr.
LLVM_ABI const SCEV * getPtrToAddrExpr(const SCEV *Op)
LLVM_ABI const SCEVAddRecExpr * convertSCEVToAddRecWithPredicates(const SCEV *S, const Loop *L, SmallVectorImpl< const SCEVPredicate * > &Preds)
Tries to convert the S expression to an AddRec expression, adding additional predicates to Preds as r...
LLVM_ABI const SCEV * getSMaxExpr(SCEVUse LHS, SCEVUse RHS)
LLVM_ABI const SCEV * getElementSize(Instruction *Inst)
Return the size of an element read or written by Inst.
LLVM_ABI const SCEV * getSizeOfExpr(Type *IntTy, TypeSize Size)
Return an expression for a TypeSize.
LLVM_ABI std::optional< bool > evaluatePredicate(CmpPredicate Pred, const SCEV *LHS, const SCEV *RHS)
Check whether the condition described by Pred, LHS, and RHS is true or false.
LLVM_ABI const SCEV * getUnknown(Value *V)
const SCEV * getAddExpr(SCEVUse LHS, SCEVUse RHS, SCEV::NoWrapFlags Flags=SCEV::FlagAnyWrap, unsigned Depth=0)
LLVM_ABI std::optional< std::pair< const SCEV *, SmallVector< const SCEVPredicate *, 3 > > > createAddRecFromPHIWithCasts(const SCEVUnknown *SymbolicPHI)
Checks if SymbolicPHI can be rewritten as an AddRecExpr under some Predicates.
LLVM_ABI const SCEV * getTruncateOrZeroExtend(const SCEV *V, Type *Ty, unsigned Depth=0)
Return a SCEV corresponding to a conversion of the input value to the specified type.
LLVM_ABI bool isKnownViaInduction(CmpPredicate Pred, SCEVUse LHS, SCEVUse RHS)
We'd like to check the predicate on every iteration of the most dominated loop between loops used in ...
LLVM_ABI std::optional< APInt > computeConstantDifference(const SCEV *LHS, const SCEV *RHS)
Compute LHS - RHS and returns the result as an APInt if it is a constant, and std::nullopt if it isn'...
LLVM_ABI bool properlyDominates(const SCEV *S, const BasicBlock *BB)
Return true if elements that makes up the given SCEV properly dominate the specified basic block.
LLVM_ABI const SCEV * getUDivExactExpr(SCEVUse LHS, SCEVUse RHS)
Get a canonical unsigned division expression, or something simpler if possible.
LLVM_ABI const SCEV * rewriteUsingPredicate(const SCEV *S, const Loop *L, const SCEVPredicate &A)
Re-writes the SCEV according to the Predicates in A.
LLVM_ABI std::pair< const SCEV *, const SCEV * > SplitIntoInitAndPostInc(const Loop *L, const SCEV *S)
Splits SCEV expression S into two SCEVs.
LLVM_ABI bool canReuseInstruction(const SCEV *S, Instruction *I, SmallVectorImpl< Instruction * > &DropPoisonGeneratingInsts)
Check whether it is poison-safe to represent the expression S using the instruction I.
LLVM_ABI bool isKnownPredicateAt(CmpPredicate Pred, const SCEV *LHS, const SCEV *RHS, const Instruction *CtxI)
Test if the given expression is known to satisfy the condition described by Pred, LHS,...
LLVM_ABI const SCEV * getPredicatedSymbolicMaxBackedgeTakenCount(const Loop *L, SmallVectorImpl< const SCEVPredicate * > &Predicates)
Similar to getSymbolicMaxBackedgeTakenCount, except it will add a set of SCEV predicates to Predicate...
LLVM_ABI const SCEV * getGEPExpr(GEPOperator *GEP, ArrayRef< SCEVUse > IndexExprs)
Returns an expression for a GEP.
LLVM_ABI const SCEV * getUMinExpr(SCEVUse LHS, SCEVUse RHS, bool Sequential=false)
LLVM_ABI void registerUser(const SCEV *User, ArrayRef< const SCEV * > Ops)
Notify this ScalarEvolution that User directly uses SCEVs in Ops.
LLVM_ABI bool isBasicBlockEntryGuardedByCond(const BasicBlock *BB, CmpPredicate Pred, const SCEV *LHS, const SCEV *RHS)
Test whether entry to the basic block is protected by a conditional between LHS and RHS.
LLVM_ABI const SCEV * getTruncateOrSignExtend(const SCEV *V, Type *Ty, unsigned Depth=0)
Return a SCEV corresponding to a conversion of the input value to the specified type.
LLVM_ABI bool containsErasedValue(const SCEV *S) const
Return true if the SCEV expression contains a Value that has been optimised out and is now a nullptr.
const SCEV * getSymbolicMaxBackedgeTakenCount(const Loop *L)
When successful, this returns a SCEV that is greater than or equal to (i.e.
const SCEV * getMulExpr(SCEVUse LHS, SCEVUse RHS, SCEV::NoWrapFlags Flags=SCEV::FlagAnyWrap, unsigned Depth=0)
APInt getSignedRangeMax(const SCEV *S)
Determine the max of the signed range for a particular SCEV.
LLVM_ABI void verify() const
LLVMContext & getContext() const
Implements a dense probed hash-table based set with some number of buckets stored inline.
Definition DenseSet.h:291
A templated base class for SmallPtrSet which provides the typesafe interface that is common across al...
SmallPtrSet - This class implements a set which is optimized for holding SmallSize or less elements.
A SetVector that performs no allocations if smaller than a certain size.
Definition SetVector.h:339
This class consists of common code factored out of the SmallVector class to reduce code duplication b...
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
Class to represent struct types.
Provides information about what library functions are available for the current target.
The instances of the Type class are immutable: once they are created, they are never changed.
Definition Type.h:46
See the file comment.
Definition ValueMap.h:84
LLVM Value Representation.
Definition Value.h:75
LLVM_ABI void print(raw_ostream &O, bool IsForDebug=false) const
Implement operator<< on Value.
This class implements an extremely fast bulk output stream that can only output to a stream.
Definition raw_ostream.h:53
unsigned ID
LLVM IR allows to use arbitrary numbers as calling convention identifiers.
Definition CallingConv.h:24
unsigned combineHashValue(unsigned a, unsigned b)
Simplistic combination of 32-bit hash values into 32-bit hash values.
friend class Instruction
Iterator for Instructions in a `BasicBlock.
Definition BasicBlock.h:73
This is an optimization pass for GlobalISel generic memory operations.
FunctionAddr VTableAddr Value
Definition InstrProf.h:137
hash_code hash_value(const FixedPointSemantics &Val)
Printable print(const GCNRegPressure &RP, const GCNSubtarget *ST=nullptr, unsigned DynamicVGPRBlockSize=0)
FoldingSetBase::Node FoldingSetNode
Definition FoldingSet.h:404
LLVM_ABI bool VerifySCEV
SCEVUseT(SCEVPtrT) -> SCEVUseT< SCEVPtrT >
Deduction guide for various SCEV subclass pointers.
SCEVNoWrapFlags
NoWrapFlags are bitfield indices into SCEV's SubclassData.
LLVM_ABI raw_ostream & dbgs()
dbgs() - This returns a reference to a raw_ostream for debugging messages.
Definition Debug.cpp:209
class LLVM_GSL_OWNER SmallVector
Forward declaration of SmallVector so that calculateSmallVectorDefaultInlinedElements can reference s...
bool isa(const From &Val)
isa<X> - Return true if the parameter to the template is an instance of one of the template type argu...
Definition Casting.h:547
@ Other
Any other memory.
Definition ModRef.h:68
DWARFExpression::Operation Op
raw_ostream & operator<<(raw_ostream &OS, const APFixedPoint &FX)
ArrayRef(const T &OneElt) -> ArrayRef< T >
constexpr unsigned BitWidth
decltype(auto) cast(const From &Val)
cast<X> - Return the argument parameter cast to the specified type.
Definition Casting.h:559
AnalysisManager< Function > FunctionAnalysisManager
Convenience typedef for the Function analysis manager.
BumpPtrAllocatorImpl<> BumpPtrAllocator
The standard BumpPtrAllocator which just uses the default template parameters.
Definition Allocator.h:383
SCEVUseT< const SCEV * > SCEVUse
Implement std::hash so that hash_code can be used in STL containers.
Definition BitVector.h:874
#define N
A CRTP mix-in that provides informational APIs needed for analysis passes.
A special type used by analysis passes to provide an address that identifies that particular analysis...
Definition Analysis.h:29
This struct provides a method for customizing the way a cast is performed.
Definition Casting.h:476
static CastReturnType castFailed()
Definition Casting.h:490
static CastReturnType doCast(const From &f)
Definition Casting.h:481
typename cast_retty< To, From >::ret_type CastReturnType
Definition Casting.h:479
static bool isPossible(const From &f)
Definition Casting.h:254
This class provides default implementations for FoldingSetTrait implementations.
Definition FoldingSet.h:116
static bool isEqual(const SCEVUse LHS, const SCEVUse RHS)
static unsigned getHashValue(SCEVUse U)
static unsigned getHashValue(const ScalarEvolution::FoldID &Val)
static ScalarEvolution::FoldID getTombstoneKey()
static ScalarEvolution::FoldID getEmptyKey()
static bool isEqual(const ScalarEvolution::FoldID &LHS, const ScalarEvolution::FoldID &RHS)
An information struct used to provide DenseMap with the various necessary components for a given valu...
static void Profile(const SCEVPredicate &X, FoldingSetNodeID &ID)
static bool Equals(const SCEVPredicate &X, const FoldingSetNodeID &ID, unsigned IDHash, FoldingSetNodeID &TempID)
static unsigned ComputeHash(const SCEVPredicate &X, FoldingSetNodeID &TempID)
static bool Equals(const SCEV &X, const FoldingSetNodeID &ID, unsigned IDHash, FoldingSetNodeID &TempID)
static unsigned ComputeHash(const SCEV &X, FoldingSetNodeID &TempID)
static void Profile(const SCEV &X, FoldingSetNodeID &ID)
This trait class is used to define behavior of how to "profile" (in the FoldingSet parlance) an objec...
Definition FoldingSet.h:146
static constexpr int NumLowBitsAvailable
The Low bits are used by the PointerIntPair.
static void * getAsVoidPointer(SCEVUse U)
static SCEVUse getFromVoidPointer(void *P)
A traits type that is used to handle pointer types and things that are just wrappers for pointers as ...
A CRTP mix-in for passes that should not be skipped.
static LLVM_ABI bool classof(const SCEV *S)
Methods for support type inquiry through isa, cast, and dyn_cast:
bool operator==(const SCEVUseT &RHS) const
const SCEV * getCanonical() const
Return the canonical SCEV for this SCEVUse.
bool operator!=(const SCEVUseT &RHS) const
SCEVPtrT operator->() const
SCEVUseT(const SCEVUseT< OtherPtrT > &Other)
void * getOpaqueValue() const
bool isCanonical() const
Returns true if the SCEVUse is canonical, i.e.
SCEVNoWrapFlags getUseNoWrapFlags() const
const SCEV * getPointer() const
bool operator==(const SCEV *RHS) const
void dump() const
This method is used for debugging.
SCEVUseT(SCEVPtrT S, SCEVNoWrapFlags Flags)
Construct with NoWrapFlags; only NUW/NSW are encoded, NW is dropped.
SCEVNoWrapFlags getNoWrapFlags(SCEVNoWrapFlags Mask=SCEVNoWrapFlags::NoWrapMask) const
Return the no-wrap flags for this SCEVUse, which is the union of the use-specific flags and the under...
bool operator>(const SCEVUseT &RHS) const
PointerIntPair< SCEVPtrT, 2 > Base
bool operator!=(const SCEV *RHS) const
void print(raw_ostream &OS) const
Print out the internal representation of this scalar to the specified stream.
SCEVUseT(SCEVPtrT S)
Information about the number of loop iterations for which a loop exit's branch condition evaluates to...
LLVM_ABI ExitLimit(const SCEV *E)
Construct either an exact exit limit from a constant, or an unknown one from a SCEVCouldNotCompute.
bool hasAnyInfo() const
Test whether this ExitLimit contains any computed information, or whether it's all SCEVCouldNotComput...
SmallVector< const SCEVPredicate *, 4 > Predicates
A vector of predicate guards for this ExitLimit.
bool hasFullInfo() const
Test whether this ExitLimit contains all information.
LoopInvariantPredicate(CmpPredicate Pred, const SCEV *LHS, const SCEV *RHS)
static SimpleType getSimplifiedValue(SCEVUse &Val)
Define a template that can be specialized by smart pointers to reflect the fact that they are automat...
Definition Casting.h:34