LLVM 23.0.0git
ValueTracking.h
Go to the documentation of this file.
1//===- llvm/Analysis/ValueTracking.h - Walk computations --------*- 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// This file contains routines that help analyze properties that chains of
10// computations have.
11//
12//===----------------------------------------------------------------------===//
13
14#ifndef LLVM_ANALYSIS_VALUETRACKING_H
15#define LLVM_ANALYSIS_VALUETRACKING_H
16
19#include "llvm/IR/Constants.h"
20#include "llvm/IR/DataLayout.h"
21#include "llvm/IR/FMF.h"
22#include "llvm/IR/InstrTypes.h"
24#include "llvm/IR/Intrinsics.h"
26#include <cassert>
27#include <cstdint>
28
29namespace llvm {
30
31class Operator;
32class AddOperator;
33class AssumptionCache;
34class DominatorTree;
35class GEPOperator;
37struct KnownBits;
38struct KnownFPClass;
39class Loop;
40class LoopInfo;
41class MDNode;
42class StringRef;
44class IntrinsicInst;
45template <typename T> class ArrayRef;
46
47constexpr unsigned MaxAnalysisRecursionDepth = 6;
48
49/// The max limit of the search depth in DecomposeGEPExpression() and
50/// getUnderlyingObject().
51constexpr unsigned MaxLookupSearchDepth = 10;
52
53/// Determine which bits of V are known to be either zero or one and return
54/// them in the KnownZero/KnownOne bit sets.
55///
56/// This function is defined on values with integer type, values with pointer
57/// type, and vectors of integers. In the case
58/// where V is a vector, the known zero and known one values are the
59/// same width as the vector element, and the bit is set only if it is true
60/// for all of the elements in the vector.
61LLVM_ABI void computeKnownBits(const Value *V, KnownBits &Known,
62 const DataLayout &DL,
63 AssumptionCache *AC = nullptr,
64 const Instruction *CxtI = nullptr,
65 const DominatorTree *DT = nullptr,
66 bool UseInstrInfo = true, unsigned Depth = 0);
67
68/// Returns the known bits rather than passing by reference.
70 AssumptionCache *AC = nullptr,
71 const Instruction *CxtI = nullptr,
72 const DominatorTree *DT = nullptr,
73 bool UseInstrInfo = true,
74 unsigned Depth = 0);
75
76/// Returns the known bits rather than passing by reference.
77LLVM_ABI KnownBits computeKnownBits(const Value *V, const APInt &DemandedElts,
78 const DataLayout &DL,
79 AssumptionCache *AC = nullptr,
80 const Instruction *CxtI = nullptr,
81 const DominatorTree *DT = nullptr,
82 bool UseInstrInfo = true,
83 unsigned Depth = 0);
84
85LLVM_ABI KnownBits computeKnownBits(const Value *V, const APInt &DemandedElts,
86 const SimplifyQuery &Q, unsigned Depth = 0);
87
89 unsigned Depth = 0);
90
91LLVM_ABI void computeKnownBits(const Value *V, KnownBits &Known,
92 const SimplifyQuery &Q, unsigned Depth = 0);
93
94/// Compute known bits from the range metadata.
95/// \p KnownZero the set of bits that are known to be zero
96/// \p KnownOne the set of bits that are known to be one
98 KnownBits &Known);
99
100/// Merge bits known from context-dependent facts into Known.
102 const SimplifyQuery &Q,
103 unsigned Depth = 0);
104
105/// Using KnownBits LHS/RHS produce the known bits for logic op (and/xor/or).
107 const KnownBits &KnownLHS,
108 const KnownBits &KnownRHS,
109 const SimplifyQuery &SQ,
110 unsigned Depth = 0);
111
112/// Adjust \p Known for the given select \p Arm to include information from the
113/// select \p Cond.
115 Value *Arm, bool Invert,
116 const SimplifyQuery &Q,
117 unsigned Depth = 0);
118
119/// Adjust \p Known for the given select \p Arm to include information from the
120/// select \p Cond.
122 Value *Arm, bool Invert,
123 const SimplifyQuery &Q,
124 unsigned Depth = 0);
125
126/// Return true if LHS and RHS have no common bits set.
128 const WithCache<const Value *> &RHSCache,
129 const SimplifyQuery &SQ);
130
131/// Return true if the given value is known to have exactly one bit set when
132/// defined. For vectors return true if every element is known to be a power
133/// of two when defined. Supports values with integer or pointer type and
134/// vectors of integers. If 'OrZero' is set, then return true if the given
135/// value is either a power of two or zero.
137 bool OrZero = false,
138 AssumptionCache *AC = nullptr,
139 const Instruction *CxtI = nullptr,
140 const DominatorTree *DT = nullptr,
141 bool UseInstrInfo = true,
142 unsigned Depth = 0);
143
144LLVM_ABI bool isKnownToBeAPowerOfTwo(const Value *V, bool OrZero,
145 const SimplifyQuery &Q,
146 unsigned Depth = 0);
147
149
151
152/// Return true if the given value is known to be non-zero when defined. For
153/// vectors, return true if every element is known to be non-zero when
154/// defined. For pointers, if the context instruction and dominator tree are
155/// specified, perform context-sensitive analysis and return true if the
156/// pointer couldn't possibly be null at the specified instruction.
157/// Supports values with integer or pointer type and vectors of integers.
158LLVM_ABI bool isKnownNonZero(const Value *V, const SimplifyQuery &Q,
159 unsigned Depth = 0);
160
161/// Return true if the two given values are negation.
162/// Currently can recoginze Value pair:
163/// 1: <X, Y> if X = sub (0, Y) or Y = sub (0, X)
164/// 2: <X, Y> if X = sub (A, B) and Y = sub (B, A)
165LLVM_ABI bool isKnownNegation(const Value *X, const Value *Y,
166 bool NeedNSW = false, bool AllowPoison = true);
167
168/// Return true iff:
169/// 1. X is poison implies Y is poison.
170/// 2. X is true implies Y is false.
171/// 3. X is false implies Y is true.
172/// Otherwise, return false.
173LLVM_ABI bool isKnownInversion(const Value *X, const Value *Y);
174
175/// Returns true if the give value is known to be non-negative.
176LLVM_ABI bool isKnownNonNegative(const Value *V, const SimplifyQuery &SQ,
177 unsigned Depth = 0);
178
179/// Returns true if the given value is known be positive (i.e. non-negative
180/// and non-zero).
181LLVM_ABI bool isKnownPositive(const Value *V, const SimplifyQuery &SQ,
182 unsigned Depth = 0);
183
184/// Returns true if the given value is known be negative (i.e. non-positive
185/// and non-zero).
186LLVM_ABI bool isKnownNegative(const Value *V, const SimplifyQuery &SQ,
187 unsigned Depth = 0);
188
189/// Return true if the given values are known to be non-equal when defined.
190/// Supports scalar integer types only.
191LLVM_ABI bool isKnownNonEqual(const Value *V1, const Value *V2,
192 const SimplifyQuery &SQ, unsigned Depth = 0);
193
194/// Return true if 'V & Mask' is known to be zero. We use this predicate to
195/// simplify operations downstream. Mask is known to be zero for bits that V
196/// cannot have.
197///
198/// This function is defined on values with integer type, values with pointer
199/// type, and vectors of integers. In the case
200/// where V is a vector, the mask, known zero, and known one values are the
201/// same width as the vector element, and the bit is set only if it is true
202/// for all of the elements in the vector.
203LLVM_ABI bool MaskedValueIsZero(const Value *V, const APInt &Mask,
204 const SimplifyQuery &SQ, unsigned Depth = 0);
205
206/// Return the number of times the sign bit of the register is replicated into
207/// the other bits. We know that at least 1 bit is always equal to the sign
208/// bit (itself), but other cases can give us information. For example,
209/// immediately after an "ashr X, 2", we know that the top 3 bits are all
210/// equal to each other, so we return 3. For vectors, return the number of
211/// sign bits for the vector element with the mininum number of known sign
212/// bits.
213LLVM_ABI unsigned ComputeNumSignBits(const Value *Op, const DataLayout &DL,
214 AssumptionCache *AC = nullptr,
215 const Instruction *CxtI = nullptr,
216 const DominatorTree *DT = nullptr,
217 bool UseInstrInfo = true,
218 unsigned Depth = 0);
219
220/// Get the upper bound on bit size for this Value \p Op as a signed integer.
221/// i.e. x == sext(trunc(x to MaxSignificantBits) to bitwidth(x)).
222/// Similar to the APInt::getSignificantBits function.
224 const DataLayout &DL,
225 AssumptionCache *AC = nullptr,
226 const Instruction *CxtI = nullptr,
227 const DominatorTree *DT = nullptr,
228 unsigned Depth = 0);
229
230/// Map a call instruction to an intrinsic ID. Libcalls which have equivalent
231/// intrinsics are treated as-if they were intrinsics.
233 const TargetLibraryInfo *TLI);
234
235/// Given an exploded icmp instruction, return true if the comparison only
236/// checks the sign bit. If it only checks the sign bit, set TrueIfSigned if
237/// the result of the comparison is true when the input value is signed.
239 bool &TrueIfSigned);
240
242 const Instruction *I, const KnownFPClass &KnownLHS,
243 const KnownFPClass &KnownRHS, const SimplifyQuery &SQ, unsigned Depth = 0);
244
245/// Determine which floating-point classes are valid for \p V, and return them
246/// in KnownFPClass bit sets.
247///
248/// This function is defined on values with floating-point type, values vectors
249/// of floating-point type, and arrays of floating-point type.
250
251/// \p InterestedClasses is a compile time optimization hint for which floating
252/// point classes should be queried. Queries not specified in \p
253/// InterestedClasses should be reliable if they are determined during the
254/// query.
256 const APInt &DemandedElts,
257 FPClassTest InterestedClasses,
258 const SimplifyQuery &SQ,
259 unsigned Depth = 0);
260
262 FPClassTest InterestedClasses,
263 const SimplifyQuery &SQ,
264 unsigned Depth = 0);
265
267 const Value *V, const DataLayout &DL,
268 FPClassTest InterestedClasses = fcAllFlags,
269 const TargetLibraryInfo *TLI = nullptr, AssumptionCache *AC = nullptr,
270 const Instruction *CxtI = nullptr, const DominatorTree *DT = nullptr,
271 bool UseInstrInfo = true, unsigned Depth = 0);
272
273/// Wrapper to account for known fast math flags at the use instruction.
275 const Value *V, const APInt &DemandedElts, FastMathFlags FMF,
276 FPClassTest InterestedClasses, const SimplifyQuery &SQ, unsigned Depth = 0);
277
279 FPClassTest InterestedClasses,
280 const SimplifyQuery &SQ,
281 unsigned Depth = 0);
282
283/// Return true if we can prove that the specified FP value is never equal to
284/// -0.0. Users should use caution when considering PreserveSign
285/// denormal-fp-math.
286LLVM_ABI bool cannotBeNegativeZero(const Value *V, const SimplifyQuery &SQ,
287 unsigned Depth = 0);
288
289/// Return true if we can prove that the specified FP value is either NaN or
290/// never less than -0.0.
291///
292/// NaN --> true
293/// +0 --> true
294/// -0 --> true
295/// x > +0 --> true
296/// x < -0 --> false
298 const SimplifyQuery &SQ,
299 unsigned Depth = 0);
300
301/// Return true if the floating-point scalar value is not an infinity or if
302/// the floating-point vector value has no infinities. Return false if a value
303/// could ever be infinity.
304LLVM_ABI bool isKnownNeverInfinity(const Value *V, const SimplifyQuery &SQ,
305 unsigned Depth = 0);
306
307/// Return true if the floating-point value can never contain a NaN or infinity.
308LLVM_ABI bool isKnownNeverInfOrNaN(const Value *V, const SimplifyQuery &SQ,
309 unsigned Depth = 0);
310
311/// Return true if the floating-point scalar value is not a NaN or if the
312/// floating-point vector value has no NaN elements. Return false if a value
313/// could ever be NaN.
314LLVM_ABI bool isKnownNeverNaN(const Value *V, const SimplifyQuery &SQ,
315 unsigned Depth = 0);
316
317/// Return false if we can prove that the specified FP value's sign bit is 0.
318/// Return true if we can prove that the specified FP value's sign bit is 1.
319/// Otherwise return std::nullopt.
320LLVM_ABI std::optional<bool> computeKnownFPSignBit(const Value *V,
321 const SimplifyQuery &SQ,
322 unsigned Depth = 0);
323
324/// Return true if the sign bit of the FP value can be ignored by the user when
325/// the value is zero.
326LLVM_ABI bool canIgnoreSignBitOfZero(const Use &U);
327
328/// Return true if the sign bit of the FP value can be ignored by the user when
329/// the value is NaN.
330LLVM_ABI bool canIgnoreSignBitOfNaN(const Use &U);
331
332/// Return true if the floating-point value \p V is known to be an integer
333/// value.
334LLVM_ABI bool isKnownIntegral(const Value *V, const SimplifyQuery &SQ,
335 FastMathFlags FMF);
336
337/// If the specified value can be set by repeating the same byte in memory,
338/// return the i8 value that it is represented with. This is true for all i8
339/// values obviously, but is also true for i32 0, i32 -1, i16 0xF0F0, double
340/// 0.0 etc. If the value can't be handled with a repeated byte store (e.g.
341/// i16 0x1234), return null. If the value is entirely undef and padding,
342/// return undef.
344
345/// Given an aggregate and an sequence of indices, see if the scalar value
346/// indexed is already around as a register, for example if it were inserted
347/// directly into the aggregate.
348///
349/// If InsertBefore is not empty, this function will duplicate (modified)
350/// insertvalues when a part of a nested struct is extracted.
352 Value *V, ArrayRef<unsigned> idx_range,
353 std::optional<BasicBlock::iterator> InsertBefore = std::nullopt);
354
355/// Analyze the specified pointer to see if it can be expressed as a base
356/// pointer plus a constant offset. Return the base and offset to the caller.
357///
358/// This is a wrapper around Value::stripAndAccumulateConstantOffsets that
359/// creates and later unpacks the required APInt.
361 const DataLayout &DL,
362 bool AllowNonInbounds = true) {
363 APInt OffsetAPInt(DL.getIndexTypeSizeInBits(Ptr->getType()), 0);
364 Value *Base =
365 Ptr->stripAndAccumulateConstantOffsets(DL, OffsetAPInt, AllowNonInbounds);
366
367 Offset = OffsetAPInt.getSExtValue();
368 return Base;
369}
370inline const Value *
372 const DataLayout &DL,
373 bool AllowNonInbounds = true) {
374 return GetPointerBaseWithConstantOffset(const_cast<Value *>(Ptr), Offset, DL,
375 AllowNonInbounds);
376}
377
378/// Represents offset+length into a ConstantDataArray.
380 /// ConstantDataArray pointer. nullptr indicates a zeroinitializer (a valid
381 /// initializer, it just doesn't fit the ConstantDataArray interface).
383
384 /// Slice starts at this Offset.
386
387 /// Length of the slice.
389
390 /// Moves the Offset and adjusts Length accordingly.
391 void move(uint64_t Delta) {
392 assert(Delta < Length);
393 Offset += Delta;
394 Length -= Delta;
395 }
396
397 /// Convenience accessor for elements in the slice.
398 uint64_t operator[](unsigned I) const {
399 return Array == nullptr ? 0 : Array->getElementAsInteger(I + Offset);
400 }
401};
402
403/// Returns true if the value \p V is a pointer into a ConstantDataArray.
404/// If successful \p Slice will point to a ConstantDataArray info object
405/// with an appropriate offset.
406LLVM_ABI bool getConstantDataArrayInfo(const Value *V,
407 ConstantDataArraySlice &Slice,
408 unsigned ElementSize,
409 uint64_t Offset = 0);
410
411/// This function computes the length of a null-terminated C string pointed to
412/// by V. If successful, it returns true and returns the string in Str. If
413/// unsuccessful, it returns false. This does not include the trailing null
414/// character by default. If TrimAtNul is set to false, then this returns any
415/// trailing null characters as well as any other characters that come after
416/// it.
417LLVM_ABI bool getConstantStringInfo(const Value *V, StringRef &Str,
418 bool TrimAtNul = true);
419
420/// If we can compute the length of the string pointed to by the specified
421/// pointer, return 'len+1'. If we can't, return 0.
422LLVM_ABI uint64_t GetStringLength(const Value *V, unsigned CharSize = 8);
423
424/// This function returns call pointer argument that is considered the same by
425/// aliasing rules. You CAN'T use it to replace one value with another. If
426/// \p MustPreserveOffset is true, the call must preserve the byte offset of
427/// the pointer within its underlying object. Offset preservation implies
428/// nullness preservation; pass true when callers reason about either offset or
429/// null equality (e.g. GEP decomposition, dereferenceability, isKnownNonZero).
430LLVM_ABI const Value *
432 bool MustPreserveOffset);
434 bool MustPreserveOffset) {
435 return const_cast<Value *>(getArgumentAliasingToReturnedPointer(
436 const_cast<const CallBase *>(Call), MustPreserveOffset));
437}
438
439/// {launder,strip}.invariant.group returns pointer that aliases its argument,
440/// and it only captures pointer by returning it.
441/// These intrinsics are not marked as nocapture, because returning is
442/// considered as capture. The arguments are not marked as returned neither,
443/// because it would make it useless. If \p MustPreserveOffset is true, the
444/// intrinsic must preserve the byte offset of the pointer within its
445/// underlying object (which excludes `llvm.ptrmask`, since masking off low
446/// bits changes the byte offset while still aliasing the same object).
448 const CallBase *Call, bool MustPreserveOffset);
449
450/// This method strips off any GEP address adjustments, pointer casts
451/// or `llvm.threadlocal.address` from the specified value \p V, returning the
452/// original object being addressed. Note that the returned value has pointer
453/// type if the specified value does. If the \p MaxLookup value is non-zero, it
454/// limits the number of instructions to be stripped off.
455LLVM_ABI const Value *
456getUnderlyingObject(const Value *V, unsigned MaxLookup = MaxLookupSearchDepth);
458 unsigned MaxLookup = MaxLookupSearchDepth) {
459 // Force const to avoid infinite recursion.
460 const Value *VConst = V;
461 return const_cast<Value *>(getUnderlyingObject(VConst, MaxLookup));
462}
463
464/// Like getUnderlyingObject(), but will try harder to find a single underlying
465/// object. In particular, this function also looks through selects and phis.
466LLVM_ABI const Value *getUnderlyingObjectAggressive(const Value *V);
467
468/// This method is similar to getUnderlyingObject except that it can
469/// look through phi and select instructions and return multiple objects.
470///
471/// If LoopInfo is passed, loop phis are further analyzed. If a pointer
472/// accesses different objects in each iteration, we don't look through the
473/// phi node. E.g. consider this loop nest:
474///
475/// int **A;
476/// for (i)
477/// for (j) {
478/// A[i][j] = A[i-1][j] * B[j]
479/// }
480///
481/// This is transformed by Load-PRE to stash away A[i] for the next iteration
482/// of the outer loop:
483///
484/// Curr = A[0]; // Prev_0
485/// for (i: 1..N) {
486/// Prev = Curr; // Prev = PHI (Prev_0, Curr)
487/// Curr = A[i];
488/// for (j: 0..N) {
489/// Curr[j] = Prev[j] * B[j]
490/// }
491/// }
492///
493/// Since A[i] and A[i-1] are independent pointers, getUnderlyingObjects
494/// should not assume that Curr and Prev share the same underlying object thus
495/// it shouldn't look through the phi above.
496LLVM_ABI void getUnderlyingObjects(const Value *V,
497 SmallVectorImpl<const Value *> &Objects,
498 const LoopInfo *LI = nullptr,
499 unsigned MaxLookup = MaxLookupSearchDepth);
500
501/// This is a wrapper around getUnderlyingObjects and adds support for basic
502/// ptrtoint+arithmetic+inttoptr sequences.
503LLVM_ABI bool getUnderlyingObjectsForCodeGen(const Value *V,
504 SmallVectorImpl<Value *> &Objects);
505
506/// Returns unique alloca where the value comes from, or nullptr.
507/// If OffsetZero is true check that V points to the begining of the alloca.
508LLVM_ABI AllocaInst *findAllocaForValue(Value *V, bool OffsetZero = false);
509inline const AllocaInst *findAllocaForValue(const Value *V,
510 bool OffsetZero = false) {
511 return findAllocaForValue(const_cast<Value *>(V), OffsetZero);
512}
513
514/// Return true if the only users of this pointer are lifetime markers.
515LLVM_ABI bool onlyUsedByLifetimeMarkers(const Value *V);
516
517/// Return true if the only users of this pointer are lifetime markers or
518/// droppable instructions.
520
521/// Return true if the instruction doesn't potentially cross vector lanes. This
522/// condition is weaker than checking that the instruction is lanewise: lanewise
523/// means that the same operation is splatted across all lanes, but we also
524/// include the case where there is a different operation on each lane, as long
525/// as the operation only uses data from that lane. An example of an operation
526/// that is not lanewise, but doesn't cross vector lanes is insertelement.
527LLVM_ABI bool isNotCrossLaneOperation(const Instruction *I);
528
529/// Return true if the instruction does not have any effects besides
530/// calculating the result and does not have undefined behavior.
531///
532/// This method never returns true for an instruction that returns true for
533/// mayHaveSideEffects; however, this method also does some other checks in
534/// addition. It checks for undefined behavior, like dividing by zero or
535/// loading from an invalid pointer (but not for undefined results, like a
536/// shift with a shift amount larger than the width of the result). It checks
537/// for malloc and alloca because speculatively executing them might cause a
538/// memory leak. It also returns false for instructions related to control
539/// flow, specifically terminators and PHI nodes.
540///
541/// If the CtxI is specified this method performs context-sensitive analysis
542/// and returns true if it is safe to execute the instruction immediately
543/// before the CtxI. If the instruction has (transitive) operands that don't
544/// dominate CtxI, the analysis is performed under the assumption that these
545/// operands will also be speculated to a point before CxtI.
546///
547/// If the CtxI is NOT specified this method only looks at the instruction
548/// itself and its operands, so if this method returns true, it is safe to
549/// move the instruction as long as the correct dominance relationships for
550/// the operands and users hold.
551///
552/// If \p UseVariableInfo is true, the information from non-constant operands
553/// will be taken into account.
554///
555/// If \p IgnoreUBImplyingAttrs is true, UB-implying attributes will be ignored.
556/// The caller is responsible for correctly propagating them after hoisting.
557///
558/// This method can return true for instructions that read memory;
559/// for such instructions, moving them may change the resulting value.
561 const Instruction *I, const Instruction *CtxI = nullptr,
562 AssumptionCache *AC = nullptr, const DominatorTree *DT = nullptr,
563 const TargetLibraryInfo *TLI = nullptr, bool UseVariableInfo = true,
564 bool IgnoreUBImplyingAttrs = true);
565
568 AssumptionCache *AC = nullptr,
569 const DominatorTree *DT = nullptr,
570 const TargetLibraryInfo *TLI = nullptr,
571 bool UseVariableInfo = true,
572 bool IgnoreUBImplyingAttrs = true) {
573 // Take an iterator, and unwrap it into an Instruction *.
574 return isSafeToSpeculativelyExecute(I, &*CtxI, AC, DT, TLI, UseVariableInfo,
575 IgnoreUBImplyingAttrs);
576}
577
578/// Don't use information from its non-constant operands. This helper is used
579/// when its operands are going to be replaced.
581 const Instruction *I, bool IgnoreUBImplyingAttrs = true) {
582 return isSafeToSpeculativelyExecute(I, nullptr, nullptr, nullptr, nullptr,
583 /*UseVariableInfo=*/false,
584 IgnoreUBImplyingAttrs);
585}
586
587/// This returns the same result as isSafeToSpeculativelyExecute if Opcode is
588/// the actual opcode of Inst. If the provided and actual opcode differ, the
589/// function (virtually) overrides the opcode of Inst with the provided
590/// Opcode. There are come constraints in this case:
591/// * If Opcode has a fixed number of operands (eg, as binary operators do),
592/// then Inst has to have at least as many leading operands. The function
593/// will ignore all trailing operands beyond that number.
594/// * If Opcode allows for an arbitrary number of operands (eg, as CallInsts
595/// do), then all operands are considered.
596/// * The virtual instruction has to satisfy all typing rules of the provided
597/// Opcode.
598/// * This function is pessimistic in the following sense: If one actually
599/// materialized the virtual instruction, then isSafeToSpeculativelyExecute
600/// may say that the materialized instruction is speculatable whereas this
601/// function may have said that the instruction wouldn't be speculatable.
602/// This behavior is a shortcoming in the current implementation and not
603/// intentional.
605 unsigned Opcode, const Instruction *Inst, const Instruction *CtxI = nullptr,
606 AssumptionCache *AC = nullptr, const DominatorTree *DT = nullptr,
607 const TargetLibraryInfo *TLI = nullptr, bool UseVariableInfo = true,
608 bool IgnoreUBImplyingAttrs = true);
609
610/// Returns true if the result or effects of the given instructions \p I
611/// depend values not reachable through the def use graph.
612/// * Memory dependence arises for example if the instruction reads from
613/// memory or may produce effects or undefined behaviour. Memory dependent
614/// instructions generally cannot be reorderd with respect to other memory
615/// dependent instructions.
616/// * Control dependence arises for example if the instruction may fault
617/// if lifted above a throwing call or infinite loop.
618LLVM_ABI bool mayHaveNonDefUseDependency(const Instruction &I);
619
620/// Return true if it is an intrinsic that cannot be speculated but also
621/// cannot trap.
622LLVM_ABI bool isAssumeLikeIntrinsic(const Instruction *I);
623
624/// Return true if it is valid to use the assumptions provided by an
625/// assume intrinsic, I, at the point in the control-flow identified by the
626/// context instruction, CxtI. By default, ephemeral values of the assumption
627/// are treated as an invalid context, to prevent the assumption from being used
628/// to optimize away its argument. If the caller can ensure that this won't
629/// happen, it can call with AllowEphemerals set to true to get more valid
630/// assumptions.
631LLVM_ABI bool isValidAssumeForContext(const Instruction *I,
632 const Instruction *CxtI,
633 const DominatorTree *DT = nullptr,
634 bool AllowEphemerals = false);
635
637 const SimplifyQuery &Q) {
639}
640
641/// Returns true, if no instruction between \p Assume and \p CtxI may free
642/// memory and the function is marked as NoSync. The latter ensures the current
643/// function cannot arrange for another thread to free on its behalf.
644LLVM_ABI bool willNotFreeBetween(const Instruction *Assume,
645 const Instruction *CtxI);
646
647enum class OverflowResult {
648 /// Always overflows in the direction of signed/unsigned min value.
650 /// Always overflows in the direction of signed/unsigned max value.
652 /// May or may not overflow.
654 /// Never overflows.
656};
657
659 const Value *RHS,
660 const SimplifyQuery &SQ,
661 bool IsNSW = false);
663 const Value *RHS,
664 const SimplifyQuery &SQ);
666 const WithCache<const Value *> &LHS, const WithCache<const Value *> &RHS,
667 const SimplifyQuery &SQ);
669 const WithCache<const Value *> &LHS, const WithCache<const Value *> &RHS,
670 const SimplifyQuery &SQ);
671/// This version also leverages the sign bit of Add if known.
673 const SimplifyQuery &SQ);
675 const Value *RHS,
676 const SimplifyQuery &SQ);
678 const Value *RHS,
679 const SimplifyQuery &SQ);
680
681/// Returns true if the arithmetic part of the \p WO 's result is
682/// used only along the paths control dependent on the computation
683/// not overflowing, \p WO being an <op>.with.overflow intrinsic.
684LLVM_ABI bool isOverflowIntrinsicNoWrap(const WithOverflowInst *WO,
685 const DominatorTree &DT);
686
687/// Determine the possible constant range of vscale with the given bit width,
688/// based on the vscale_range function attribute.
689LLVM_ABI ConstantRange getVScaleRange(const Function *F, unsigned BitWidth);
690
691/// Determine the possible constant range of an integer or vector of integer
692/// value. This is intended as a cheap, non-recursive check.
693LLVM_ABI ConstantRange computeConstantRange(const Value *V, bool ForSigned,
694 const SimplifyQuery &SQ,
695 unsigned Depth = 0);
696
697/// Combine constant ranges from computeConstantRange() and computeKnownBits().
699 const WithCache<const Value *> &V, bool ForSigned, const SimplifyQuery &SQ);
700
701/// Return true if this function can prove that the instruction I will
702/// always transfer execution to one of its successors (including the next
703/// instruction that follows within a basic block). E.g. this is not
704/// guaranteed for function calls that could loop infinitely.
705///
706/// In other words, this function returns false for instructions that may
707/// transfer execution or fail to transfer execution in a way that is not
708/// captured in the CFG nor in the sequence of instructions within a basic
709/// block.
710///
711/// Undefined behavior is assumed not to happen, so e.g. division is
712/// guaranteed to transfer execution to the following instruction even
713/// though division by zero might cause undefined behavior.
715
716/// Returns true if this block does not contain a potential implicit exit.
717/// This is equivelent to saying that all instructions within the basic block
718/// are guaranteed to transfer execution to their successor within the basic
719/// block. This has the same assumptions w.r.t. undefined behavior as the
720/// instruction variant of this function.
722
723/// Return true if every instruction in the range (Begin, End) is
724/// guaranteed to transfer execution to its static successor. \p ScanLimit
725/// bounds the search to avoid scanning huge blocks.
726LLVM_ABI bool
729 unsigned ScanLimit = 32);
730
731/// Same as previous, but with range expressed via iterator_range.
733 iterator_range<BasicBlock::const_iterator> Range, unsigned ScanLimit = 32);
734
735/// Return true if this function can prove that the instruction I
736/// is executed for every iteration of the loop L.
737///
738/// Note that this currently only considers the loop header.
740 const Loop *L);
741
742/// Return true if \p PoisonOp's user yields poison or raises UB if its
743/// operand \p PoisonOp is poison.
744///
745/// If \p PoisonOp is a vector or an aggregate and the operation's result is a
746/// single value, any poison element in /p PoisonOp should make the result
747/// poison or raise UB.
748///
749/// To filter out operands that raise UB on poison, you can use
750/// getGuaranteedNonPoisonOp.
751LLVM_ABI bool propagatesPoison(const Use &PoisonOp);
752
753/// Return whether this intrinsic propagates poison for all operands.
755
756/// Return true if the given instruction must trigger undefined behavior
757/// when I is executed with any operands which appear in KnownPoison holding
758/// a poison value at the point of execution.
759LLVM_ABI bool mustTriggerUB(const Instruction *I,
760 const SmallPtrSetImpl<const Value *> &KnownPoison);
761
762/// Return true if this function can prove that if Inst is executed
763/// and yields a poison value or undef bits, then that will trigger
764/// undefined behavior.
765///
766/// Note that this currently only considers the basic block that is
767/// the parent of Inst.
768LLVM_ABI bool programUndefinedIfUndefOrPoison(const Instruction *Inst);
769LLVM_ABI bool programUndefinedIfPoison(const Instruction *Inst);
770
771/// canCreateUndefOrPoison returns true if Op can create undef or poison from
772/// non-undef & non-poison operands.
773/// For vectors, canCreateUndefOrPoison returns true if there is potential
774/// poison or undef in any element of the result when vectors without
775/// undef/poison poison are given as operands.
776/// For example, given `Op = shl <2 x i32> %x, <0, 32>`, this function returns
777/// true. If Op raises immediate UB but never creates poison or undef
778/// (e.g. sdiv I, 0), canCreatePoison returns false.
779///
780/// \p ConsiderFlagsAndMetadata controls whether poison producing flags and
781/// metadata on the instruction are considered. This can be used to see if the
782/// instruction could still introduce undef or poison even without poison
783/// generating flags and metadata which might be on the instruction.
784/// (i.e. could the result of Op->dropPoisonGeneratingFlags() still create
785/// poison or undef)
786///
787/// canCreatePoison returns true if Op can create poison from non-poison
788/// operands.
789LLVM_ABI bool canCreateUndefOrPoison(const Operator *Op,
790 bool ConsiderFlagsAndMetadata = true);
791LLVM_ABI bool canCreatePoison(const Operator *Op,
792 bool ConsiderFlagsAndMetadata = true);
793
794/// Return true if V is poison given that ValAssumedPoison is already poison.
795/// For example, if ValAssumedPoison is `icmp X, 10` and V is `icmp X, 5`,
796/// impliesPoison returns true.
797LLVM_ABI bool impliesPoison(const Value *ValAssumedPoison, const Value *V);
798
799/// Return true if this function can prove that V does not have undef bits
800/// and is never poison. If V is an aggregate value or vector, check whether
801/// all elements (except padding) are not undef or poison.
802/// Note that this is different from canCreateUndefOrPoison because the
803/// function assumes Op's operands are not poison/undef.
804///
805/// If CtxI and DT are specified this method performs flow-sensitive analysis
806/// and returns true if it is guaranteed to be never undef or poison
807/// immediately before the CtxI.
808LLVM_ABI bool
809isGuaranteedNotToBeUndefOrPoison(const Value *V, AssumptionCache *AC = nullptr,
810 const Instruction *CtxI = nullptr,
811 const DominatorTree *DT = nullptr,
812 unsigned Depth = 0);
813
814/// Returns true if V cannot be poison, but may be undef.
815LLVM_ABI bool isGuaranteedNotToBePoison(const Value *V,
816 AssumptionCache *AC = nullptr,
817 const Instruction *CtxI = nullptr,
818 const DominatorTree *DT = nullptr,
819 unsigned Depth = 0);
820
823 const DominatorTree *DT = nullptr,
824 unsigned Depth = 0) {
825 // Takes an iterator as a position, passes down to Instruction *
826 // implementation.
827 return isGuaranteedNotToBePoison(V, AC, &*CtxI, DT, Depth);
828}
829
830/// Returns true if V cannot be undef, but may be poison.
831LLVM_ABI bool isGuaranteedNotToBeUndef(const Value *V,
832 AssumptionCache *AC = nullptr,
833 const Instruction *CtxI = nullptr,
834 const DominatorTree *DT = nullptr,
835 unsigned Depth = 0);
836
837/// Return true if undefined behavior would provable be executed on the path to
838/// OnPathTo if Root produced a posion result. Note that this doesn't say
839/// anything about whether OnPathTo is actually executed or whether Root is
840/// actually poison. This can be used to assess whether a new use of Root can
841/// be added at a location which is control equivalent with OnPathTo (such as
842/// immediately before it) without introducing UB which didn't previously
843/// exist. Note that a false result conveys no information.
844LLVM_ABI bool mustExecuteUBIfPoisonOnPathTo(Instruction *Root,
845 Instruction *OnPathTo,
846 DominatorTree *DT);
847
848/// Convert an integer comparison with a constant RHS into an equivalent
849/// form with the strictness flipped predicate. Return the new predicate and
850/// corresponding constant RHS if possible. Otherwise return std::nullopt.
851/// E.g., (icmp sgt X, 0) -> (icmp sle X, 1).
852LLVM_ABI std::optional<std::pair<CmpPredicate, Constant *>>
853getFlippedStrictnessPredicateAndConstant(CmpPredicate Pred, Constant *C);
854
855/// Specific patterns of select instructions we can match.
858 SPF_SMIN, /// Signed minimum
859 SPF_UMIN, /// Unsigned minimum
860 SPF_SMAX, /// Signed maximum
861 SPF_UMAX, /// Unsigned maximum
862 SPF_FMINNUM, /// Floating point minnum
863 SPF_FMAXNUM, /// Floating point maxnum
864 SPF_ABS, /// Absolute value
865 SPF_NABS /// Negated absolute value
866};
867
868/// Behavior when a floating point min/max is given one NaN and one
869/// non-NaN as input.
871 SPNB_NA = 0, /// NaN behavior not applicable.
872 SPNB_RETURNS_NAN, /// Given one NaN input, returns the NaN.
873 SPNB_RETURNS_OTHER, /// Given one NaN input, returns the non-NaN.
874 SPNB_RETURNS_ANY /// Given one NaN input, can return either (or
875 /// it has been determined that no operands can
876 /// be NaN).
877};
878
881 SelectPatternNaNBehavior NaNBehavior; /// Only applicable if Flavor is
882 /// SPF_FMINNUM or SPF_FMAXNUM.
883 bool Ordered; /// When implementing this min/max pattern as
884 /// fcmp; select, does the fcmp have to be
885 /// ordered?
886
887 /// Return true if \p SPF is a min or a max pattern.
889 return SPF != SPF_UNKNOWN && SPF != SPF_ABS && SPF != SPF_NABS;
890 }
891};
892
893/// Pattern match integer [SU]MIN, [SU]MAX and ABS idioms, returning the kind
894/// and providing the out parameter results if we successfully match.
895///
896/// For ABS/NABS, LHS will be set to the input to the abs idiom. RHS will be
897/// the negation instruction from the idiom.
898///
899/// If CastOp is not nullptr, also match MIN/MAX idioms where the type does
900/// not match that of the original select. If this is the case, the cast
901/// operation (one of Trunc,SExt,Zext) that must be done to transform the
902/// type of LHS and RHS into the type of V is returned in CastOp.
903///
904/// For example:
905/// %1 = icmp slt i32 %a, i32 4
906/// %2 = sext i32 %a to i64
907/// %3 = select i1 %1, i64 %2, i64 4
908///
909/// -> LHS = %a, RHS = i32 4, *CastOp = Instruction::SExt
910///
911LLVM_ABI SelectPatternResult
912matchSelectPattern(Value *V, Value *&LHS, Value *&RHS,
913 Instruction::CastOps *CastOp = nullptr, unsigned Depth = 0);
914
916 const Value *&RHS) {
917 Value *L = const_cast<Value *>(LHS);
918 Value *R = const_cast<Value *>(RHS);
919 auto Result = matchSelectPattern(const_cast<Value *>(V), L, R);
920 LHS = L;
921 RHS = R;
922 return Result;
923}
924
925/// Determine the pattern that a select with the given compare as its
926/// predicate and given values as its true/false operands would match.
927LLVM_ABI SelectPatternResult matchDecomposedSelectPattern(
928 CmpInst *CmpI, Value *TrueVal, Value *FalseVal, Value *&LHS, Value *&RHS,
929 FastMathFlags FMF = FastMathFlags(), Instruction::CastOps *CastOp = nullptr,
930 unsigned Depth = 0);
931
932/// Determine the pattern for predicate `X Pred Y ? X : Y`.
933LLVM_ABI SelectPatternResult getSelectPattern(
934 CmpInst::Predicate Pred, SelectPatternNaNBehavior NaNBehavior = SPNB_NA,
935 bool Ordered = false);
936
937/// Return the canonical comparison predicate for the specified
938/// minimum/maximum flavor.
939LLVM_ABI CmpInst::Predicate getMinMaxPred(SelectPatternFlavor SPF,
940 bool Ordered = false);
941
942/// Convert given `SPF` to equivalent min/max intrinsic.
943/// Caller must ensure `SPF` is an integer min or max pattern.
944LLVM_ABI Intrinsic::ID getMinMaxIntrinsic(SelectPatternFlavor SPF);
945
946/// Return the inverse minimum/maximum flavor of the specified flavor.
947/// For example, signed minimum is the inverse of signed maximum.
948LLVM_ABI SelectPatternFlavor getInverseMinMaxFlavor(SelectPatternFlavor SPF);
949
951
952/// Return the minimum or maximum constant value for the specified integer
953/// min/max flavor and type.
954LLVM_ABI APInt getMinMaxLimit(SelectPatternFlavor SPF, unsigned BitWidth);
955
956/// Check if the values in \p VL are select instructions that can be converted
957/// to a min or max (vector) intrinsic. Returns the intrinsic ID, if such a
958/// conversion is possible, together with a bool indicating whether all select
959/// conditions are only used by the selects. Otherwise return
960/// Intrinsic::not_intrinsic.
961LLVM_ABI std::pair<Intrinsic::ID, bool>
963
964/// Attempt to match a simple first order recurrence cycle of the form:
965/// %iv = phi Ty [%Start, %Entry], [%Inc, %backedge]
966/// %inc = binop %iv, %step
967/// OR
968/// %iv = phi Ty [%Start, %Entry], [%Inc, %backedge]
969/// %inc = binop %step, %iv
970///
971/// A first order recurrence is a formula with the form: X_n = f(X_(n-1))
972///
973/// A couple of notes on subtleties in that definition:
974/// * The Step does not have to be loop invariant. In math terms, it can
975/// be a free variable. We allow recurrences with both constant and
976/// variable coefficients. Callers may wish to filter cases where Step
977/// does not dominate P.
978/// * For non-commutative operators, we will match both forms. This
979/// results in some odd recurrence structures. Callers may wish to filter
980/// out recurrences where the phi is not the LHS of the returned operator.
981/// * Because of the structure matched, the caller can assume as a post
982/// condition of the match the presence of a Loop with P's parent as it's
983/// header *except* in unreachable code. (Dominance decays in unreachable
984/// code.)
985///
986/// NOTE: This is intentional simple. If you want the ability to analyze
987/// non-trivial loop conditons, see ScalarEvolution instead.
988LLVM_ABI bool matchSimpleRecurrence(const PHINode *P, BinaryOperator *&BO,
989 Value *&Start, Value *&Step);
990
991/// Analogous to the above, but starting from the binary operator
992LLVM_ABI bool matchSimpleRecurrence(const BinaryOperator *I, PHINode *&P,
993 Value *&Start, Value *&Step);
994
995/// Attempt to match a simple value-accumulating recurrence of the form:
996/// %llvm.intrinsic.acc = phi Ty [%Init, %Entry], [%llvm.intrinsic, %backedge]
997/// %llvm.intrinsic = call Ty @llvm.intrinsic(%OtherOp, %llvm.intrinsic.acc)
998/// OR
999/// %llvm.intrinsic.acc = phi Ty [%Init, %Entry], [%llvm.intrinsic, %backedge]
1000/// %llvm.intrinsic = call Ty @llvm.intrinsic(%llvm.intrinsic.acc, %OtherOp)
1001///
1002/// The recurrence relation is of kind:
1003/// X_0 = %a (initial value),
1004/// X_i = call @llvm.binary.intrinsic(X_i-1, %b)
1005/// Where %b is not required to be loop-invariant.
1006LLVM_ABI bool matchSimpleBinaryIntrinsicRecurrence(const IntrinsicInst *I,
1007 PHINode *&P, Value *&Init,
1008 Value *&OtherOp);
1009
1010/// Attempt to match a simple value-accumulating recurrence of the form:
1011/// %llvm.intrinsic.acc = phi Ty [%Init, %Entry], [%llvm.intrinsic, %backedge]
1012/// %llvm.intrinsic = call Ty @llvm.intrinsic(%OtherOp0, %OtherOp1,
1013/// %llvm.intrinsic.acc)
1014/// OR
1015/// %llvm.intrinsic.acc = phi Ty [%Init, %Entry], [%llvm.intrinsic, %backedge]
1016/// %llvm.intrinsic = call Ty @llvm.intrinsic(%llvm.intrinsic.acc, %OtherOp0,
1017/// %OtherOp1)
1018///
1019/// The recurrence relation is of kind:
1020/// X_0 = %a (initial value),
1021/// X_i = call @llvm.ternary.intrinsic(X_i-1, %b, %c)
1022/// Where %b, %c are not required to be loop-invariant.
1023LLVM_ABI bool matchSimpleTernaryIntrinsicRecurrence(const IntrinsicInst *I,
1024 PHINode *&P, Value *&Init,
1025 Value *&OtherOp0,
1026 Value *&OtherOp1);
1027
1028/// Return true if RHS is known to be implied true by LHS. Return false if
1029/// RHS is known to be implied false by LHS. Otherwise, return std::nullopt if
1030/// no implication can be made. A & B must be i1 (boolean) values or a vector of
1031/// such values. Note that the truth table for implication is the same as <=u on
1032/// i1 values (but not
1033/// <=s!). The truth table for both is:
1034/// | T | F (B)
1035/// T | T | F
1036/// F | T | T
1037/// (A)
1038LLVM_ABI std::optional<bool>
1039isImpliedCondition(const Value *LHS, const Value *RHS, const DataLayout &DL,
1040 bool LHSIsTrue = true, unsigned Depth = 0);
1041LLVM_ABI std::optional<bool>
1042isImpliedCondition(const Value *LHS, CmpPredicate RHSPred, const Value *RHSOp0,
1043 const Value *RHSOp1, const DataLayout &DL,
1044 bool LHSIsTrue = true, unsigned Depth = 0);
1045
1046/// Return the boolean condition value in the context of the given instruction
1047/// if it is known based on dominating conditions.
1048LLVM_ABI std::optional<bool>
1049isImpliedByDomCondition(const Value *Cond, const Instruction *ContextI,
1050 const DataLayout &DL);
1051LLVM_ABI std::optional<bool>
1052isImpliedByDomCondition(CmpPredicate Pred, const Value *LHS, const Value *RHS,
1053 const Instruction *ContextI, const DataLayout &DL);
1054
1055/// Call \p InsertAffected on all Values whose known bits / value may be
1056/// affected by the condition \p Cond. Used by AssumptionCache and
1057/// DomConditionCache.
1058LLVM_ABI void
1059findValuesAffectedByCondition(Value *Cond, bool IsAssume,
1060 function_ref<void(Value *)> InsertAffected);
1061
1062/// Returns the inner value X if the expression has the form f(X)
1063/// where f(X) == 0 if and only if X == 0, otherwise returns nullptr.
1064LLVM_ABI Value *stripNullTest(Value *V);
1065LLVM_ABI const Value *stripNullTest(const Value *V);
1066
1067/// Enumerates all possible immediate values of V and inserts them into the set
1068/// \p Constants. If \p AllowUndefOrPoison is false, it fails when V may contain
1069/// undef/poison elements. Returns true if the result is complete. Otherwise,
1070/// the result is incomplete (more than MaxCount values).
1071/// NOTE: The constant values are not distinct.
1072LLVM_ABI bool
1073collectPossibleValues(const Value *V,
1074 SmallPtrSetImpl<const Constant *> &Constants,
1075 unsigned MaxCount, bool AllowUndefOrPoison = true);
1076
1077} // end namespace llvm
1078
1079#endif // LLVM_ANALYSIS_VALUETRACKING_H
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
#define X(NUM, ENUM, NAME)
Definition ELF.h:853
static GCRegistry::Add< ShadowStackGC > C("shadow-stack", "Very portable GC for uncooperative code generators")
#define LLVM_ABI
Definition Compiler.h:213
This file contains the declarations for the subclasses of Constant, which represent the different fla...
#define F(x, y, z)
Definition MD5.cpp:54
#define I(x, y, z)
Definition MD5.cpp:57
const uint64_t BitWidth
ConstantRange Range(APInt(BitWidth, Low), APInt(BitWidth, High))
#define P(N)
const SmallVectorImpl< MachineOperand > & Cond
static TableGen::Emitter::Opt Y("gen-skeleton-entry", EmitSkeleton, "Generate example skeleton entry")
Value * RHS
Value * LHS
Class for arbitrary precision integers.
Definition APInt.h:78
int64_t getSExtValue() const
Get sign extended value.
Definition APInt.h:1585
an instruction to allocate memory on the stack
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.
InstListType::const_iterator const_iterator
Definition BasicBlock.h:171
InstListType::iterator iterator
Instruction iterators...
Definition BasicBlock.h:170
Base class for all callable instructions (InvokeInst and CallInst) Holds everything related to callin...
Predicate
This enumeration lists the possible predicates for CmpInst subclasses.
Definition InstrTypes.h:676
An array constant whose element type is a simple 1/2/4/8-byte integer, bytes or float/double,...
Definition Constants.h:852
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
Convenience struct for specifying and reasoning about fast-math flags.
Definition FMF.h:23
A wrapper class for inspecting calls to intrinsic functions.
Represents a single loop in the control flow graph.
Definition LoopInfo.h:40
Metadata node.
Definition Metadata.h:1080
This is a utility class that provides an abstraction for the common functionality between Instruction...
Definition Operator.h:33
Represent a constant reference to a string, i.e.
Definition StringRef.h:56
Provides information about what library functions are available for the current target.
A Use represents the edge between a Value definition and its users.
Definition Use.h:35
LLVM Value Representation.
Definition Value.h:75
Type * getType() const
All values are typed, get the type of this value.
Definition Value.h:255
LLVM_ABI const Value * stripAndAccumulateConstantOffsets(const DataLayout &DL, APInt &Offset, bool AllowNonInbounds, bool AllowInvariantGroup=false, function_ref< bool(Value &Value, APInt &Offset)> ExternalAnalysis=nullptr, bool LookThroughIntToPtr=false) const
Accumulate the constant offset this value has compared to a base pointer.
Represents an op.with.overflow intrinsic.
CallInst * Call
This is an optimization pass for GlobalISel generic memory operations.
LLVM_ABI bool haveNoCommonBitsSet(const WithCache< const Value * > &LHSCache, const WithCache< const Value * > &RHSCache, const SimplifyQuery &SQ)
Return true if LHS and RHS have no common bits set.
LLVM_ABI bool mustExecuteUBIfPoisonOnPathTo(Instruction *Root, Instruction *OnPathTo, DominatorTree *DT)
Return true if undefined behavior would provable be executed on the path to OnPathTo if Root produced...
LLVM_ABI Intrinsic::ID getInverseMinMaxIntrinsic(Intrinsic::ID MinMaxID)
LLVM_ABI bool willNotFreeBetween(const Instruction *Assume, const Instruction *CtxI)
Returns true, if no instruction between Assume and CtxI may free memory and the function is marked as...
@ Offset
Definition DWP.cpp:557
@ NeverOverflows
Never overflows.
@ AlwaysOverflowsHigh
Always overflows in the direction of signed/unsigned max value.
@ AlwaysOverflowsLow
Always overflows in the direction of signed/unsigned min value.
@ MayOverflow
May or may not overflow.
LLVM_ABI KnownFPClass computeKnownFPClass(const Value *V, const APInt &DemandedElts, FPClassTest InterestedClasses, const SimplifyQuery &SQ, unsigned Depth=0)
Determine which floating-point classes are valid for V, and return them in KnownFPClass bit sets.
LLVM_ABI KnownFPClass analyzeKnownFPClassFromSelect(const Instruction *I, const KnownFPClass &KnownLHS, const KnownFPClass &KnownRHS, const SimplifyQuery &SQ, unsigned Depth=0)
LLVM_ABI bool isValidAssumeForContext(const Instruction *I, const Instruction *CxtI, const DominatorTree *DT=nullptr, bool AllowEphemerals=false)
Return true if it is valid to use the assumptions provided by an assume intrinsic,...
LLVM_ABI bool canCreatePoison(const Operator *Op, bool ConsiderFlagsAndMetadata=true)
LLVM_ABI bool mustTriggerUB(const Instruction *I, const SmallPtrSetImpl< const Value * > &KnownPoison)
Return true if the given instruction must trigger undefined behavior when I is executed with any oper...
LLVM_ABI bool isKnownNeverInfinity(const Value *V, const SimplifyQuery &SQ, unsigned Depth=0)
Return true if the floating-point scalar value is not an infinity or if the floating-point vector val...
LLVM_ABI void computeKnownBitsFromContext(const Value *V, KnownBits &Known, const SimplifyQuery &Q, unsigned Depth=0)
Merge bits known from context-dependent facts into Known.
LLVM_ABI bool isOnlyUsedInZeroEqualityComparison(const Instruction *CxtI)
LLVM_ABI bool isSignBitCheck(ICmpInst::Predicate Pred, const APInt &RHS, bool &TrueIfSigned)
Given an exploded icmp instruction, return true if the comparison only checks the sign bit.
LLVM_ABI bool isAssumeLikeIntrinsic(const Instruction *I)
Return true if it is an intrinsic that cannot be speculated but also cannot trap.
LLVM_ABI AllocaInst * findAllocaForValue(Value *V, bool OffsetZero=false)
Returns unique alloca where the value comes from, or nullptr.
LLVM_ABI APInt getMinMaxLimit(SelectPatternFlavor SPF, unsigned BitWidth)
Return the minimum or maximum constant value for the specified integer min/max flavor and type.
LLVM_ABI bool isOnlyUsedInZeroComparison(const Instruction *CxtI)
LLVM_ABI bool getConstantStringInfo(const Value *V, StringRef &Str, bool TrimAtNul=true)
This function computes the length of a null-terminated C string pointed to by V.
LLVM_ABI bool onlyUsedByLifetimeMarkersOrDroppableInsts(const Value *V)
Return true if the only users of this pointer are lifetime markers or droppable instructions.
LLVM_ABI Value * stripNullTest(Value *V)
Returns the inner value X if the expression has the form f(X) where f(X) == 0 if and only if X == 0,...
LLVM_ABI bool getUnderlyingObjectsForCodeGen(const Value *V, SmallVectorImpl< Value * > &Objects)
This is a wrapper around getUnderlyingObjects and adds support for basic ptrtoint+arithmetic+inttoptr...
LLVM_ABI std::pair< Intrinsic::ID, bool > canConvertToMinOrMaxIntrinsic(ArrayRef< Value * > VL)
Check if the values in VL are select instructions that can be converted to a min or max (vector) intr...
LLVM_ABI bool getConstantDataArrayInfo(const Value *V, ConstantDataArraySlice &Slice, unsigned ElementSize, uint64_t Offset=0)
Returns true if the value V is a pointer into a ConstantDataArray.
LLVM_ABI bool isGuaranteedToExecuteForEveryIteration(const Instruction *I, const Loop *L)
Return true if this function can prove that the instruction I is executed for every iteration of the ...
Value * GetPointerBaseWithConstantOffset(Value *Ptr, int64_t &Offset, const DataLayout &DL, bool AllowNonInbounds=true)
Analyze the specified pointer to see if it can be expressed as a base pointer plus a constant offset.
LLVM_ABI bool isIntrinsicReturningPointerAliasingArgumentWithoutCapturing(const CallBase *Call, bool MustPreserveOffset)
{launder,strip}.invariant.group returns pointer that aliases its argument, and it only captures point...
LLVM_ABI const Value * getArgumentAliasingToReturnedPointer(const CallBase *Call, bool MustPreserveOffset)
This function returns call pointer argument that is considered the same by aliasing rules.
LLVM_ABI bool isSafeToSpeculativelyExecute(const Instruction *I, const Instruction *CtxI=nullptr, AssumptionCache *AC=nullptr, const DominatorTree *DT=nullptr, const TargetLibraryInfo *TLI=nullptr, bool UseVariableInfo=true, bool IgnoreUBImplyingAttrs=true)
Return true if the instruction does not have any effects besides calculating the result and does not ...
LLVM_ABI CmpInst::Predicate getMinMaxPred(SelectPatternFlavor SPF, bool Ordered=false)
Return the canonical comparison predicate for the specified minimum/maximum flavor.
LLVM_ABI bool canIgnoreSignBitOfZero(const Use &U)
Return true if the sign bit of the FP value can be ignored by the user when the value is zero.
LLVM_ABI bool isGuaranteedNotToBeUndef(const Value *V, AssumptionCache *AC=nullptr, const Instruction *CtxI=nullptr, const DominatorTree *DT=nullptr, unsigned Depth=0)
Returns true if V cannot be undef, but may be poison.
LLVM_ABI bool MaskedValueIsZero(const Value *V, const APInt &Mask, const SimplifyQuery &SQ, unsigned Depth=0)
Return true if 'V & Mask' is known to be zero.
LLVM_ABI bool isOverflowIntrinsicNoWrap(const WithOverflowInst *WO, const DominatorTree &DT)
Returns true if the arithmetic part of the WO 's result is used only along the paths control dependen...
LLVM_ABI bool matchSimpleRecurrence(const PHINode *P, BinaryOperator *&BO, Value *&Start, Value *&Step)
Attempt to match a simple first order recurrence cycle of the form: iv = phi Ty [Start,...
LLVM_ABI OverflowResult computeOverflowForUnsignedMul(const Value *LHS, const Value *RHS, const SimplifyQuery &SQ, bool IsNSW=false)
LLVM_ABI SelectPatternFlavor getInverseMinMaxFlavor(SelectPatternFlavor SPF)
Return the inverse minimum/maximum flavor of the specified flavor.
constexpr unsigned MaxAnalysisRecursionDepth
LLVM_ABI void adjustKnownBitsForSelectArm(KnownBits &Known, Value *Cond, Value *Arm, bool Invert, const SimplifyQuery &Q, unsigned Depth=0)
Adjust Known for the given select Arm to include information from the select Cond.
LLVM_ABI bool isKnownNegative(const Value *V, const SimplifyQuery &SQ, unsigned Depth=0)
Returns true if the given value is known be negative (i.e.
LLVM_ABI OverflowResult computeOverflowForSignedSub(const Value *LHS, const Value *RHS, const SimplifyQuery &SQ)
SelectPatternFlavor
Specific patterns of select instructions we can match.
@ SPF_ABS
Floating point maxnum.
@ SPF_NABS
Absolute value.
@ SPF_FMAXNUM
Floating point minnum.
@ SPF_UMIN
Signed minimum.
@ SPF_UMAX
Signed maximum.
@ SPF_SMAX
Unsigned minimum.
@ SPF_UNKNOWN
@ SPF_FMINNUM
Unsigned maximum.
LLVM_ABI bool impliesPoison(const Value *ValAssumedPoison, const Value *V)
Return true if V is poison given that ValAssumedPoison is already poison.
LLVM_ABI SelectPatternResult getSelectPattern(CmpInst::Predicate Pred, SelectPatternNaNBehavior NaNBehavior=SPNB_NA, bool Ordered=false)
Determine the pattern for predicate X Pred Y ? X : Y.
FPClassTest
Floating-point class tests, supported by 'is_fpclass' intrinsic.
LLVM_ABI void computeKnownBits(const Value *V, KnownBits &Known, const DataLayout &DL, AssumptionCache *AC=nullptr, const Instruction *CxtI=nullptr, const DominatorTree *DT=nullptr, bool UseInstrInfo=true, unsigned Depth=0)
Determine which bits of V are known to be either zero or one and return them in the KnownZero/KnownOn...
LLVM_ABI bool programUndefinedIfPoison(const Instruction *Inst)
LLVM_ABI SelectPatternResult matchSelectPattern(Value *V, Value *&LHS, Value *&RHS, Instruction::CastOps *CastOp=nullptr, unsigned Depth=0)
Pattern match integer [SU]MIN, [SU]MAX and ABS idioms, returning the kind and providing the out param...
LLVM_ABI bool matchSimpleBinaryIntrinsicRecurrence(const IntrinsicInst *I, PHINode *&P, Value *&Init, Value *&OtherOp)
Attempt to match a simple value-accumulating recurrence of the form: llvm.intrinsic....
LLVM_ABI bool cannotBeNegativeZero(const Value *V, const SimplifyQuery &SQ, unsigned Depth=0)
Return true if we can prove that the specified FP value is never equal to -0.0.
LLVM_ABI bool programUndefinedIfUndefOrPoison(const Instruction *Inst)
Return true if this function can prove that if Inst is executed and yields a poison value or undef bi...
LLVM_ABI void adjustKnownFPClassForSelectArm(KnownFPClass &Known, Value *Cond, Value *Arm, bool Invert, const SimplifyQuery &Q, unsigned Depth=0)
Adjust Known for the given select Arm to include information from the select Cond.
LLVM_ABI bool collectPossibleValues(const Value *V, SmallPtrSetImpl< const Constant * > &Constants, unsigned MaxCount, bool AllowUndefOrPoison=true)
Enumerates all possible immediate values of V and inserts them into the set Constants.
constexpr unsigned MaxLookupSearchDepth
The max limit of the search depth in DecomposeGEPExpression() and getUnderlyingObject().
LLVM_ABI uint64_t GetStringLength(const Value *V, unsigned CharSize=8)
If we can compute the length of the string pointed to by the specified pointer, return 'len+1'.
LLVM_ABI OverflowResult computeOverflowForSignedMul(const Value *LHS, const Value *RHS, const SimplifyQuery &SQ)
LLVM_ABI ConstantRange getVScaleRange(const Function *F, unsigned BitWidth)
Determine the possible constant range of vscale with the given bit width, based on the vscale_range f...
LLVM_ABI bool canCreateUndefOrPoison(const Operator *Op, bool ConsiderFlagsAndMetadata=true)
canCreateUndefOrPoison returns true if Op can create undef or poison from non-undef & non-poison oper...
LLVM_ABI bool matchSimpleTernaryIntrinsicRecurrence(const IntrinsicInst *I, PHINode *&P, Value *&Init, Value *&OtherOp0, Value *&OtherOp1)
Attempt to match a simple value-accumulating recurrence of the form: llvm.intrinsic....
LLVM_ABI bool isKnownInversion(const Value *X, const Value *Y)
Return true iff:
LLVM_ABI bool intrinsicPropagatesPoison(Intrinsic::ID IID)
Return whether this intrinsic propagates poison for all operands.
LLVM_ABI bool isNotCrossLaneOperation(const Instruction *I)
Return true if the instruction doesn't potentially cross vector lanes.
LLVM_ABI bool isKnownNonZero(const Value *V, const SimplifyQuery &Q, unsigned Depth=0)
Return true if the given value is known to be non-zero when defined.
iterator_range(Container &&) -> iterator_range< llvm::detail::IterOfRange< Container > >
LLVM_ABI bool isSafeToSpeculativelyExecuteWithOpcode(unsigned Opcode, const Instruction *Inst, const Instruction *CtxI=nullptr, AssumptionCache *AC=nullptr, const DominatorTree *DT=nullptr, const TargetLibraryInfo *TLI=nullptr, bool UseVariableInfo=true, bool IgnoreUBImplyingAttrs=true)
This returns the same result as isSafeToSpeculativelyExecute if Opcode is the actual opcode of Inst.
LLVM_ABI bool onlyUsedByLifetimeMarkers(const Value *V)
Return true if the only users of this pointer are lifetime markers.
LLVM_ABI Intrinsic::ID getIntrinsicForCallSite(const CallBase &CB, const TargetLibraryInfo *TLI)
Map a call instruction to an intrinsic ID.
LLVM_ABI const Value * getUnderlyingObjectAggressive(const Value *V)
Like getUnderlyingObject(), but will try harder to find a single underlying object.
LLVM_ABI Intrinsic::ID getMinMaxIntrinsic(SelectPatternFlavor SPF)
Convert given SPF to equivalent min/max intrinsic.
LLVM_ABI SelectPatternResult matchDecomposedSelectPattern(CmpInst *CmpI, Value *TrueVal, Value *FalseVal, Value *&LHS, Value *&RHS, FastMathFlags FMF=FastMathFlags(), Instruction::CastOps *CastOp=nullptr, unsigned Depth=0)
Determine the pattern that a select with the given compare as its predicate and given values as its t...
LLVM_ABI OverflowResult computeOverflowForSignedAdd(const WithCache< const Value * > &LHS, const WithCache< const Value * > &RHS, const SimplifyQuery &SQ)
LLVM_ABI bool propagatesPoison(const Use &PoisonOp)
Return true if PoisonOp's user yields poison or raises UB if its operand PoisonOp is poison.
@ Add
Sum of integers.
LLVM_ABI ConstantRange computeConstantRangeIncludingKnownBits(const WithCache< const Value * > &V, bool ForSigned, const SimplifyQuery &SQ)
Combine constant ranges from computeConstantRange() and computeKnownBits().
SelectPatternNaNBehavior
Behavior when a floating point min/max is given one NaN and one non-NaN as input.
@ SPNB_RETURNS_NAN
NaN behavior not applicable.
@ SPNB_RETURNS_OTHER
Given one NaN input, returns the NaN.
@ SPNB_RETURNS_ANY
Given one NaN input, returns the non-NaN.
LLVM_ABI bool isKnownNonEqual(const Value *V1, const Value *V2, const SimplifyQuery &SQ, unsigned Depth=0)
Return true if the given values are known to be non-equal when defined.
DWARFExpression::Operation Op
bool isSafeToSpeculativelyExecuteWithVariableReplaced(const Instruction *I, bool IgnoreUBImplyingAttrs=true)
Don't use information from its non-constant operands.
LLVM_ABI bool isGuaranteedNotToBeUndefOrPoison(const Value *V, AssumptionCache *AC=nullptr, const Instruction *CtxI=nullptr, const DominatorTree *DT=nullptr, unsigned Depth=0)
Return true if this function can prove that V does not have undef bits and is never poison.
ArrayRef(const T &OneElt) -> ArrayRef< T >
LLVM_ABI unsigned ComputeNumSignBits(const Value *Op, const DataLayout &DL, AssumptionCache *AC=nullptr, const Instruction *CxtI=nullptr, const DominatorTree *DT=nullptr, bool UseInstrInfo=true, unsigned Depth=0)
Return the number of times the sign bit of the register is replicated into the other bits.
LLVM_ABI KnownBits analyzeKnownBitsFromAndXorOr(const Operator *I, const KnownBits &KnownLHS, const KnownBits &KnownRHS, const SimplifyQuery &SQ, unsigned Depth=0)
Using KnownBits LHS/RHS produce the known bits for logic op (and/xor/or).
LLVM_ABI OverflowResult computeOverflowForUnsignedSub(const Value *LHS, const Value *RHS, const SimplifyQuery &SQ)
LLVM_ABI bool isGuaranteedToTransferExecutionToSuccessor(const Instruction *I)
Return true if this function can prove that the instruction I will always transfer execution to one o...
LLVM_ABI bool isKnownNeverInfOrNaN(const Value *V, const SimplifyQuery &SQ, unsigned Depth=0)
Return true if the floating-point value can never contain a NaN or infinity.
LLVM_ABI bool isKnownNeverNaN(const Value *V, const SimplifyQuery &SQ, unsigned Depth=0)
Return true if the floating-point scalar value is not a NaN or if the floating-point vector value has...
LLVM_ABI Value * isBytewiseValue(Value *V, const DataLayout &DL)
If the specified value can be set by repeating the same byte in memory, return the i8 value that it i...
LLVM_ABI std::optional< std::pair< CmpPredicate, Constant * > > getFlippedStrictnessPredicateAndConstant(CmpPredicate Pred, Constant *C)
Convert an integer comparison with a constant RHS into an equivalent form with the strictness flipped...
LLVM_ABI unsigned ComputeMaxSignificantBits(const Value *Op, const DataLayout &DL, AssumptionCache *AC=nullptr, const Instruction *CxtI=nullptr, const DominatorTree *DT=nullptr, unsigned Depth=0)
Get the upper bound on bit size for this Value Op as a signed integer.
LLVM_ABI bool isKnownIntegral(const Value *V, const SimplifyQuery &SQ, FastMathFlags FMF)
Return true if the floating-point value V is known to be an integer value.
LLVM_ABI OverflowResult computeOverflowForUnsignedAdd(const WithCache< const Value * > &LHS, const WithCache< const Value * > &RHS, const SimplifyQuery &SQ)
LLVM_ABI bool isKnownToBeAPowerOfTwo(const Value *V, const DataLayout &DL, bool OrZero=false, AssumptionCache *AC=nullptr, const Instruction *CxtI=nullptr, const DominatorTree *DT=nullptr, bool UseInstrInfo=true, unsigned Depth=0)
Return true if the given value is known to have exactly one bit set when defined.
LLVM_ABI std::optional< bool > isImpliedByDomCondition(const Value *Cond, const Instruction *ContextI, const DataLayout &DL)
Return the boolean condition value in the context of the given instruction if it is known based on do...
LLVM_ABI bool isGuaranteedNotToBePoison(const Value *V, AssumptionCache *AC=nullptr, const Instruction *CtxI=nullptr, const DominatorTree *DT=nullptr, unsigned Depth=0)
Returns true if V cannot be poison, but may be undef.
LLVM_ABI void computeKnownBitsFromRangeMetadata(const MDNode &Ranges, KnownBits &Known)
Compute known bits from the range metadata.
LLVM_ABI Value * FindInsertedValue(Value *V, ArrayRef< unsigned > idx_range, std::optional< BasicBlock::iterator > InsertBefore=std::nullopt)
Given an aggregate and an sequence of indices, see if the scalar value indexed is already around as a...
LLVM_ABI bool isKnownNegation(const Value *X, const Value *Y, bool NeedNSW=false, bool AllowPoison=true)
Return true if the two given values are negation.
LLVM_ABI const Value * getUnderlyingObject(const Value *V, unsigned MaxLookup=MaxLookupSearchDepth)
This method strips off any GEP address adjustments, pointer casts or llvm.threadlocal....
LLVM_ABI bool isKnownPositive(const Value *V, const SimplifyQuery &SQ, unsigned Depth=0)
Returns true if the given value is known be positive (i.e.
LLVM_ABI bool isKnownNonNegative(const Value *V, const SimplifyQuery &SQ, unsigned Depth=0)
Returns true if the give value is known to be non-negative.
LLVM_ABI bool cannotBeOrderedLessThanZero(const Value *V, const SimplifyQuery &SQ, unsigned Depth=0)
Return true if we can prove that the specified FP value is either NaN or never less than -0....
LLVM_ABI void getUnderlyingObjects(const Value *V, SmallVectorImpl< const Value * > &Objects, const LoopInfo *LI=nullptr, unsigned MaxLookup=MaxLookupSearchDepth)
This method is similar to getUnderlyingObject except that it can look through phi and select instruct...
LLVM_ABI bool mayHaveNonDefUseDependency(const Instruction &I)
Returns true if the result or effects of the given instructions I depend values not reachable through...
LLVM_ABI std::optional< bool > isImpliedCondition(const Value *LHS, const Value *RHS, const DataLayout &DL, bool LHSIsTrue=true, unsigned Depth=0)
Return true if RHS is known to be implied true by LHS.
LLVM_ABI std::optional< bool > computeKnownFPSignBit(const Value *V, const SimplifyQuery &SQ, unsigned Depth=0)
Return false if we can prove that the specified FP value's sign bit is 0.
LLVM_ABI bool canIgnoreSignBitOfNaN(const Use &U)
Return true if the sign bit of the FP value can be ignored by the user when the value is NaN.
LLVM_ABI ConstantRange computeConstantRange(const Value *V, bool ForSigned, const SimplifyQuery &SQ, unsigned Depth=0)
Determine the possible constant range of an integer or vector of integer value.
LLVM_ABI void findValuesAffectedByCondition(Value *Cond, bool IsAssume, function_ref< void(Value *)> InsertAffected)
Call InsertAffected on all Values whose known bits / value may be affected by the condition Cond.
Represents offset+length into a ConstantDataArray.
uint64_t Length
Length of the slice.
uint64_t Offset
Slice starts at this Offset.
uint64_t operator[](unsigned I) const
Convenience accessor for elements in the slice.
void move(uint64_t Delta)
Moves the Offset and adjusts Length accordingly.
const ConstantDataArray * Array
ConstantDataArray pointer.
SelectPatternFlavor Flavor
bool Ordered
Only applicable if Flavor is SPF_FMINNUM or SPF_FMAXNUM.
static bool isMinOrMax(SelectPatternFlavor SPF)
When implementing this min/max pattern as fcmp; select, does the fcmp have to be ordered?
SelectPatternNaNBehavior NaNBehavior
const Instruction * CxtI
const DominatorTree * DT