LLVM 22.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/// If the specified value can be set by repeating the same byte in memory,
333/// return the i8 value that it is represented with. This is true for all i8
334/// values obviously, but is also true for i32 0, i32 -1, i16 0xF0F0, double
335/// 0.0 etc. If the value can't be handled with a repeated byte store (e.g.
336/// i16 0x1234), return null. If the value is entirely undef and padding,
337/// return undef.
339
340/// Given an aggregate and an sequence of indices, see if the scalar value
341/// indexed is already around as a register, for example if it were inserted
342/// directly into the aggregate.
343///
344/// If InsertBefore is not empty, this function will duplicate (modified)
345/// insertvalues when a part of a nested struct is extracted.
347 Value *V, ArrayRef<unsigned> idx_range,
348 std::optional<BasicBlock::iterator> InsertBefore = std::nullopt);
349
350/// Analyze the specified pointer to see if it can be expressed as a base
351/// pointer plus a constant offset. Return the base and offset to the caller.
352///
353/// This is a wrapper around Value::stripAndAccumulateConstantOffsets that
354/// creates and later unpacks the required APInt.
356 const DataLayout &DL,
357 bool AllowNonInbounds = true) {
358 APInt OffsetAPInt(DL.getIndexTypeSizeInBits(Ptr->getType()), 0);
359 Value *Base =
360 Ptr->stripAndAccumulateConstantOffsets(DL, OffsetAPInt, AllowNonInbounds);
361
362 Offset = OffsetAPInt.getSExtValue();
363 return Base;
364}
365inline const Value *
367 const DataLayout &DL,
368 bool AllowNonInbounds = true) {
369 return GetPointerBaseWithConstantOffset(const_cast<Value *>(Ptr), Offset, DL,
370 AllowNonInbounds);
371}
372
373/// Represents offset+length into a ConstantDataArray.
375 /// ConstantDataArray pointer. nullptr indicates a zeroinitializer (a valid
376 /// initializer, it just doesn't fit the ConstantDataArray interface).
378
379 /// Slice starts at this Offset.
381
382 /// Length of the slice.
384
385 /// Moves the Offset and adjusts Length accordingly.
386 void move(uint64_t Delta) {
387 assert(Delta < Length);
388 Offset += Delta;
389 Length -= Delta;
390 }
391
392 /// Convenience accessor for elements in the slice.
393 uint64_t operator[](unsigned I) const {
394 return Array == nullptr ? 0 : Array->getElementAsInteger(I + Offset);
395 }
396};
397
398/// Returns true if the value \p V is a pointer into a ConstantDataArray.
399/// If successful \p Slice will point to a ConstantDataArray info object
400/// with an appropriate offset.
401LLVM_ABI bool getConstantDataArrayInfo(const Value *V,
402 ConstantDataArraySlice &Slice,
403 unsigned ElementSize,
404 uint64_t Offset = 0);
405
406/// This function computes the length of a null-terminated C string pointed to
407/// by V. If successful, it returns true and returns the string in Str. If
408/// unsuccessful, it returns false. This does not include the trailing null
409/// character by default. If TrimAtNul is set to false, then this returns any
410/// trailing null characters as well as any other characters that come after
411/// it.
412LLVM_ABI bool getConstantStringInfo(const Value *V, StringRef &Str,
413 bool TrimAtNul = true);
414
415/// If we can compute the length of the string pointed to by the specified
416/// pointer, return 'len+1'. If we can't, return 0.
417LLVM_ABI uint64_t GetStringLength(const Value *V, unsigned CharSize = 8);
418
419/// This function returns call pointer argument that is considered the same by
420/// aliasing rules. You CAN'T use it to replace one value with another. If
421/// \p MustPreserveNullness is true, the call must preserve the nullness of
422/// the pointer.
423LLVM_ABI const Value *
425 bool MustPreserveNullness);
427 bool MustPreserveNullness) {
428 return const_cast<Value *>(getArgumentAliasingToReturnedPointer(
429 const_cast<const CallBase *>(Call), MustPreserveNullness));
430}
431
432/// {launder,strip}.invariant.group returns pointer that aliases its argument,
433/// and it only captures pointer by returning it.
434/// These intrinsics are not marked as nocapture, because returning is
435/// considered as capture. The arguments are not marked as returned neither,
436/// because it would make it useless. If \p MustPreserveNullness is true,
437/// the intrinsic must preserve the nullness of the pointer.
439 const CallBase *Call, bool MustPreserveNullness);
440
441/// This method strips off any GEP address adjustments, pointer casts
442/// or `llvm.threadlocal.address` from the specified value \p V, returning the
443/// original object being addressed. Note that the returned value has pointer
444/// type if the specified value does. If the \p MaxLookup value is non-zero, it
445/// limits the number of instructions to be stripped off.
446LLVM_ABI const Value *
447getUnderlyingObject(const Value *V, unsigned MaxLookup = MaxLookupSearchDepth);
449 unsigned MaxLookup = MaxLookupSearchDepth) {
450 // Force const to avoid infinite recursion.
451 const Value *VConst = V;
452 return const_cast<Value *>(getUnderlyingObject(VConst, MaxLookup));
453}
454
455/// Like getUnderlyingObject(), but will try harder to find a single underlying
456/// object. In particular, this function also looks through selects and phis.
457LLVM_ABI const Value *getUnderlyingObjectAggressive(const Value *V);
458
459/// This method is similar to getUnderlyingObject except that it can
460/// look through phi and select instructions and return multiple objects.
461///
462/// If LoopInfo is passed, loop phis are further analyzed. If a pointer
463/// accesses different objects in each iteration, we don't look through the
464/// phi node. E.g. consider this loop nest:
465///
466/// int **A;
467/// for (i)
468/// for (j) {
469/// A[i][j] = A[i-1][j] * B[j]
470/// }
471///
472/// This is transformed by Load-PRE to stash away A[i] for the next iteration
473/// of the outer loop:
474///
475/// Curr = A[0]; // Prev_0
476/// for (i: 1..N) {
477/// Prev = Curr; // Prev = PHI (Prev_0, Curr)
478/// Curr = A[i];
479/// for (j: 0..N) {
480/// Curr[j] = Prev[j] * B[j]
481/// }
482/// }
483///
484/// Since A[i] and A[i-1] are independent pointers, getUnderlyingObjects
485/// should not assume that Curr and Prev share the same underlying object thus
486/// it shouldn't look through the phi above.
487LLVM_ABI void getUnderlyingObjects(const Value *V,
488 SmallVectorImpl<const Value *> &Objects,
489 const LoopInfo *LI = nullptr,
490 unsigned MaxLookup = MaxLookupSearchDepth);
491
492/// This is a wrapper around getUnderlyingObjects and adds support for basic
493/// ptrtoint+arithmetic+inttoptr sequences.
494LLVM_ABI bool getUnderlyingObjectsForCodeGen(const Value *V,
495 SmallVectorImpl<Value *> &Objects);
496
497/// Returns unique alloca where the value comes from, or nullptr.
498/// If OffsetZero is true check that V points to the begining of the alloca.
499LLVM_ABI AllocaInst *findAllocaForValue(Value *V, bool OffsetZero = false);
500inline const AllocaInst *findAllocaForValue(const Value *V,
501 bool OffsetZero = false) {
502 return findAllocaForValue(const_cast<Value *>(V), OffsetZero);
503}
504
505/// Return true if the only users of this pointer are lifetime markers.
506LLVM_ABI bool onlyUsedByLifetimeMarkers(const Value *V);
507
508/// Return true if the only users of this pointer are lifetime markers or
509/// droppable instructions.
511
512/// Return true if the instruction doesn't potentially cross vector lanes. This
513/// condition is weaker than checking that the instruction is lanewise: lanewise
514/// means that the same operation is splatted across all lanes, but we also
515/// include the case where there is a different operation on each lane, as long
516/// as the operation only uses data from that lane. An example of an operation
517/// that is not lanewise, but doesn't cross vector lanes is insertelement.
518LLVM_ABI bool isNotCrossLaneOperation(const Instruction *I);
519
520/// Return true if the instruction does not have any effects besides
521/// calculating the result and does not have undefined behavior.
522///
523/// This method never returns true for an instruction that returns true for
524/// mayHaveSideEffects; however, this method also does some other checks in
525/// addition. It checks for undefined behavior, like dividing by zero or
526/// loading from an invalid pointer (but not for undefined results, like a
527/// shift with a shift amount larger than the width of the result). It checks
528/// for malloc and alloca because speculatively executing them might cause a
529/// memory leak. It also returns false for instructions related to control
530/// flow, specifically terminators and PHI nodes.
531///
532/// If the CtxI is specified this method performs context-sensitive analysis
533/// and returns true if it is safe to execute the instruction immediately
534/// before the CtxI. If the instruction has (transitive) operands that don't
535/// dominate CtxI, the analysis is performed under the assumption that these
536/// operands will also be speculated to a point before CxtI.
537///
538/// If the CtxI is NOT specified this method only looks at the instruction
539/// itself and its operands, so if this method returns true, it is safe to
540/// move the instruction as long as the correct dominance relationships for
541/// the operands and users hold.
542///
543/// If \p UseVariableInfo is true, the information from non-constant operands
544/// will be taken into account.
545///
546/// If \p IgnoreUBImplyingAttrs is true, UB-implying attributes will be ignored.
547/// The caller is responsible for correctly propagating them after hoisting.
548///
549/// This method can return true for instructions that read memory;
550/// for such instructions, moving them may change the resulting value.
552 const Instruction *I, const Instruction *CtxI = nullptr,
553 AssumptionCache *AC = nullptr, const DominatorTree *DT = nullptr,
554 const TargetLibraryInfo *TLI = nullptr, bool UseVariableInfo = true,
555 bool IgnoreUBImplyingAttrs = true);
556
559 AssumptionCache *AC = nullptr,
560 const DominatorTree *DT = nullptr,
561 const TargetLibraryInfo *TLI = nullptr,
562 bool UseVariableInfo = true,
563 bool IgnoreUBImplyingAttrs = true) {
564 // Take an iterator, and unwrap it into an Instruction *.
565 return isSafeToSpeculativelyExecute(I, &*CtxI, AC, DT, TLI, UseVariableInfo,
566 IgnoreUBImplyingAttrs);
567}
568
569/// Don't use information from its non-constant operands. This helper is used
570/// when its operands are going to be replaced.
572 const Instruction *I, bool IgnoreUBImplyingAttrs = true) {
573 return isSafeToSpeculativelyExecute(I, nullptr, nullptr, nullptr, nullptr,
574 /*UseVariableInfo=*/false,
575 IgnoreUBImplyingAttrs);
576}
577
578/// This returns the same result as isSafeToSpeculativelyExecute if Opcode is
579/// the actual opcode of Inst. If the provided and actual opcode differ, the
580/// function (virtually) overrides the opcode of Inst with the provided
581/// Opcode. There are come constraints in this case:
582/// * If Opcode has a fixed number of operands (eg, as binary operators do),
583/// then Inst has to have at least as many leading operands. The function
584/// will ignore all trailing operands beyond that number.
585/// * If Opcode allows for an arbitrary number of operands (eg, as CallInsts
586/// do), then all operands are considered.
587/// * The virtual instruction has to satisfy all typing rules of the provided
588/// Opcode.
589/// * This function is pessimistic in the following sense: If one actually
590/// materialized the virtual instruction, then isSafeToSpeculativelyExecute
591/// may say that the materialized instruction is speculatable whereas this
592/// function may have said that the instruction wouldn't be speculatable.
593/// This behavior is a shortcoming in the current implementation and not
594/// intentional.
596 unsigned Opcode, const Instruction *Inst, const Instruction *CtxI = nullptr,
597 AssumptionCache *AC = nullptr, const DominatorTree *DT = nullptr,
598 const TargetLibraryInfo *TLI = nullptr, bool UseVariableInfo = true,
599 bool IgnoreUBImplyingAttrs = true);
600
601/// Returns true if the result or effects of the given instructions \p I
602/// depend values not reachable through the def use graph.
603/// * Memory dependence arises for example if the instruction reads from
604/// memory or may produce effects or undefined behaviour. Memory dependent
605/// instructions generally cannot be reorderd with respect to other memory
606/// dependent instructions.
607/// * Control dependence arises for example if the instruction may fault
608/// if lifted above a throwing call or infinite loop.
609LLVM_ABI bool mayHaveNonDefUseDependency(const Instruction &I);
610
611/// Return true if it is an intrinsic that cannot be speculated but also
612/// cannot trap.
613LLVM_ABI bool isAssumeLikeIntrinsic(const Instruction *I);
614
615/// Return true if it is valid to use the assumptions provided by an
616/// assume intrinsic, I, at the point in the control-flow identified by the
617/// context instruction, CxtI. By default, ephemeral values of the assumption
618/// are treated as an invalid context, to prevent the assumption from being used
619/// to optimize away its argument. If the caller can ensure that this won't
620/// happen, it can call with AllowEphemerals set to true to get more valid
621/// assumptions.
622LLVM_ABI bool isValidAssumeForContext(const Instruction *I,
623 const Instruction *CxtI,
624 const DominatorTree *DT = nullptr,
625 bool AllowEphemerals = false);
626
627/// Returns true, if no instruction between \p Assume and \p CtxI may free
628/// memory and the function is marked as NoSync. The latter ensures the current
629/// function cannot arrange for another thread to free on its behalf.
630LLVM_ABI bool willNotFreeBetween(const Instruction *Assume,
631 const Instruction *CtxI);
632
633enum class OverflowResult {
634 /// Always overflows in the direction of signed/unsigned min value.
636 /// Always overflows in the direction of signed/unsigned max value.
638 /// May or may not overflow.
640 /// Never overflows.
642};
643
645 const Value *RHS,
646 const SimplifyQuery &SQ,
647 bool IsNSW = false);
649 const Value *RHS,
650 const SimplifyQuery &SQ);
652 const WithCache<const Value *> &LHS, const WithCache<const Value *> &RHS,
653 const SimplifyQuery &SQ);
655 const WithCache<const Value *> &LHS, const WithCache<const Value *> &RHS,
656 const SimplifyQuery &SQ);
657/// This version also leverages the sign bit of Add if known.
659 const SimplifyQuery &SQ);
661 const Value *RHS,
662 const SimplifyQuery &SQ);
664 const Value *RHS,
665 const SimplifyQuery &SQ);
666
667/// Returns true if the arithmetic part of the \p WO 's result is
668/// used only along the paths control dependent on the computation
669/// not overflowing, \p WO being an <op>.with.overflow intrinsic.
670LLVM_ABI bool isOverflowIntrinsicNoWrap(const WithOverflowInst *WO,
671 const DominatorTree &DT);
672
673/// Determine the possible constant range of vscale with the given bit width,
674/// based on the vscale_range function attribute.
675LLVM_ABI ConstantRange getVScaleRange(const Function *F, unsigned BitWidth);
676
677/// Determine the possible constant range of an integer or vector of integer
678/// value. This is intended as a cheap, non-recursive check.
679LLVM_ABI ConstantRange computeConstantRange(const Value *V, bool ForSigned,
680 bool UseInstrInfo = true,
681 AssumptionCache *AC = nullptr,
682 const Instruction *CtxI = nullptr,
683 const DominatorTree *DT = nullptr,
684 unsigned Depth = 0);
685
686/// Combine constant ranges from computeConstantRange() and computeKnownBits().
688 const WithCache<const Value *> &V, bool ForSigned, const SimplifyQuery &SQ);
689
690/// Return true if this function can prove that the instruction I will
691/// always transfer execution to one of its successors (including the next
692/// instruction that follows within a basic block). E.g. this is not
693/// guaranteed for function calls that could loop infinitely.
694///
695/// In other words, this function returns false for instructions that may
696/// transfer execution or fail to transfer execution in a way that is not
697/// captured in the CFG nor in the sequence of instructions within a basic
698/// block.
699///
700/// Undefined behavior is assumed not to happen, so e.g. division is
701/// guaranteed to transfer execution to the following instruction even
702/// though division by zero might cause undefined behavior.
704
705/// Returns true if this block does not contain a potential implicit exit.
706/// This is equivelent to saying that all instructions within the basic block
707/// are guaranteed to transfer execution to their successor within the basic
708/// block. This has the same assumptions w.r.t. undefined behavior as the
709/// instruction variant of this function.
711
712/// Return true if every instruction in the range (Begin, End) is
713/// guaranteed to transfer execution to its static successor. \p ScanLimit
714/// bounds the search to avoid scanning huge blocks.
715LLVM_ABI bool
718 unsigned ScanLimit = 32);
719
720/// Same as previous, but with range expressed via iterator_range.
722 iterator_range<BasicBlock::const_iterator> Range, unsigned ScanLimit = 32);
723
724/// Return true if this function can prove that the instruction I
725/// is executed for every iteration of the loop L.
726///
727/// Note that this currently only considers the loop header.
729 const Loop *L);
730
731/// Return true if \p PoisonOp's user yields poison or raises UB if its
732/// operand \p PoisonOp is poison.
733///
734/// If \p PoisonOp is a vector or an aggregate and the operation's result is a
735/// single value, any poison element in /p PoisonOp should make the result
736/// poison or raise UB.
737///
738/// To filter out operands that raise UB on poison, you can use
739/// getGuaranteedNonPoisonOp.
740LLVM_ABI bool propagatesPoison(const Use &PoisonOp);
741
742/// Return whether this intrinsic propagates poison for all operands.
744
745/// Return true if the given instruction must trigger undefined behavior
746/// when I is executed with any operands which appear in KnownPoison holding
747/// a poison value at the point of execution.
748LLVM_ABI bool mustTriggerUB(const Instruction *I,
749 const SmallPtrSetImpl<const Value *> &KnownPoison);
750
751/// Return true if this function can prove that if Inst is executed
752/// and yields a poison value or undef bits, then that will trigger
753/// undefined behavior.
754///
755/// Note that this currently only considers the basic block that is
756/// the parent of Inst.
757LLVM_ABI bool programUndefinedIfUndefOrPoison(const Instruction *Inst);
758LLVM_ABI bool programUndefinedIfPoison(const Instruction *Inst);
759
760/// canCreateUndefOrPoison returns true if Op can create undef or poison from
761/// non-undef & non-poison operands.
762/// For vectors, canCreateUndefOrPoison returns true if there is potential
763/// poison or undef in any element of the result when vectors without
764/// undef/poison poison are given as operands.
765/// For example, given `Op = shl <2 x i32> %x, <0, 32>`, this function returns
766/// true. If Op raises immediate UB but never creates poison or undef
767/// (e.g. sdiv I, 0), canCreatePoison returns false.
768///
769/// \p ConsiderFlagsAndMetadata controls whether poison producing flags and
770/// metadata on the instruction are considered. This can be used to see if the
771/// instruction could still introduce undef or poison even without poison
772/// generating flags and metadata which might be on the instruction.
773/// (i.e. could the result of Op->dropPoisonGeneratingFlags() still create
774/// poison or undef)
775///
776/// canCreatePoison returns true if Op can create poison from non-poison
777/// operands.
778LLVM_ABI bool canCreateUndefOrPoison(const Operator *Op,
779 bool ConsiderFlagsAndMetadata = true);
780LLVM_ABI bool canCreatePoison(const Operator *Op,
781 bool ConsiderFlagsAndMetadata = true);
782
783/// Return true if V is poison given that ValAssumedPoison is already poison.
784/// For example, if ValAssumedPoison is `icmp X, 10` and V is `icmp X, 5`,
785/// impliesPoison returns true.
786LLVM_ABI bool impliesPoison(const Value *ValAssumedPoison, const Value *V);
787
788/// Return true if this function can prove that V does not have undef bits
789/// and is never poison. If V is an aggregate value or vector, check whether
790/// all elements (except padding) are not undef or poison.
791/// Note that this is different from canCreateUndefOrPoison because the
792/// function assumes Op's operands are not poison/undef.
793///
794/// If CtxI and DT are specified this method performs flow-sensitive analysis
795/// and returns true if it is guaranteed to be never undef or poison
796/// immediately before the CtxI.
797LLVM_ABI bool
798isGuaranteedNotToBeUndefOrPoison(const Value *V, AssumptionCache *AC = nullptr,
799 const Instruction *CtxI = nullptr,
800 const DominatorTree *DT = nullptr,
801 unsigned Depth = 0);
802
803/// Returns true if V cannot be poison, but may be undef.
804LLVM_ABI bool isGuaranteedNotToBePoison(const Value *V,
805 AssumptionCache *AC = nullptr,
806 const Instruction *CtxI = nullptr,
807 const DominatorTree *DT = nullptr,
808 unsigned Depth = 0);
809
812 const DominatorTree *DT = nullptr,
813 unsigned Depth = 0) {
814 // Takes an iterator as a position, passes down to Instruction *
815 // implementation.
816 return isGuaranteedNotToBePoison(V, AC, &*CtxI, DT, Depth);
817}
818
819/// Returns true if V cannot be undef, but may be poison.
820LLVM_ABI bool isGuaranteedNotToBeUndef(const Value *V,
821 AssumptionCache *AC = nullptr,
822 const Instruction *CtxI = nullptr,
823 const DominatorTree *DT = nullptr,
824 unsigned Depth = 0);
825
826/// Return true if undefined behavior would provable be executed on the path to
827/// OnPathTo if Root produced a posion result. Note that this doesn't say
828/// anything about whether OnPathTo is actually executed or whether Root is
829/// actually poison. This can be used to assess whether a new use of Root can
830/// be added at a location which is control equivalent with OnPathTo (such as
831/// immediately before it) without introducing UB which didn't previously
832/// exist. Note that a false result conveys no information.
833LLVM_ABI bool mustExecuteUBIfPoisonOnPathTo(Instruction *Root,
834 Instruction *OnPathTo,
835 DominatorTree *DT);
836
837/// Convert an integer comparison with a constant RHS into an equivalent
838/// form with the strictness flipped predicate. Return the new predicate and
839/// corresponding constant RHS if possible. Otherwise return std::nullopt.
840/// E.g., (icmp sgt X, 0) -> (icmp sle X, 1).
841LLVM_ABI std::optional<std::pair<CmpPredicate, Constant *>>
842getFlippedStrictnessPredicateAndConstant(CmpPredicate Pred, Constant *C);
843
844/// Specific patterns of select instructions we can match.
847 SPF_SMIN, /// Signed minimum
848 SPF_UMIN, /// Unsigned minimum
849 SPF_SMAX, /// Signed maximum
850 SPF_UMAX, /// Unsigned maximum
851 SPF_FMINNUM, /// Floating point minnum
852 SPF_FMAXNUM, /// Floating point maxnum
853 SPF_ABS, /// Absolute value
854 SPF_NABS /// Negated absolute value
855};
856
857/// Behavior when a floating point min/max is given one NaN and one
858/// non-NaN as input.
860 SPNB_NA = 0, /// NaN behavior not applicable.
861 SPNB_RETURNS_NAN, /// Given one NaN input, returns the NaN.
862 SPNB_RETURNS_OTHER, /// Given one NaN input, returns the non-NaN.
863 SPNB_RETURNS_ANY /// Given one NaN input, can return either (or
864 /// it has been determined that no operands can
865 /// be NaN).
866};
867
870 SelectPatternNaNBehavior NaNBehavior; /// Only applicable if Flavor is
871 /// SPF_FMINNUM or SPF_FMAXNUM.
872 bool Ordered; /// When implementing this min/max pattern as
873 /// fcmp; select, does the fcmp have to be
874 /// ordered?
875
876 /// Return true if \p SPF is a min or a max pattern.
878 return SPF != SPF_UNKNOWN && SPF != SPF_ABS && SPF != SPF_NABS;
879 }
880};
881
882/// Pattern match integer [SU]MIN, [SU]MAX and ABS idioms, returning the kind
883/// and providing the out parameter results if we successfully match.
884///
885/// For ABS/NABS, LHS will be set to the input to the abs idiom. RHS will be
886/// the negation instruction from the idiom.
887///
888/// If CastOp is not nullptr, also match MIN/MAX idioms where the type does
889/// not match that of the original select. If this is the case, the cast
890/// operation (one of Trunc,SExt,Zext) that must be done to transform the
891/// type of LHS and RHS into the type of V is returned in CastOp.
892///
893/// For example:
894/// %1 = icmp slt i32 %a, i32 4
895/// %2 = sext i32 %a to i64
896/// %3 = select i1 %1, i64 %2, i64 4
897///
898/// -> LHS = %a, RHS = i32 4, *CastOp = Instruction::SExt
899///
900LLVM_ABI SelectPatternResult
901matchSelectPattern(Value *V, Value *&LHS, Value *&RHS,
902 Instruction::CastOps *CastOp = nullptr, unsigned Depth = 0);
903
905 const Value *&RHS) {
906 Value *L = const_cast<Value *>(LHS);
907 Value *R = const_cast<Value *>(RHS);
908 auto Result = matchSelectPattern(const_cast<Value *>(V), L, R);
909 LHS = L;
910 RHS = R;
911 return Result;
912}
913
914/// Determine the pattern that a select with the given compare as its
915/// predicate and given values as its true/false operands would match.
916LLVM_ABI SelectPatternResult matchDecomposedSelectPattern(
917 CmpInst *CmpI, Value *TrueVal, Value *FalseVal, Value *&LHS, Value *&RHS,
918 FastMathFlags FMF = FastMathFlags(), Instruction::CastOps *CastOp = nullptr,
919 unsigned Depth = 0);
920
921/// Determine the pattern for predicate `X Pred Y ? X : Y`.
922LLVM_ABI SelectPatternResult getSelectPattern(
923 CmpInst::Predicate Pred, SelectPatternNaNBehavior NaNBehavior = SPNB_NA,
924 bool Ordered = false);
925
926/// Return the canonical comparison predicate for the specified
927/// minimum/maximum flavor.
928LLVM_ABI CmpInst::Predicate getMinMaxPred(SelectPatternFlavor SPF,
929 bool Ordered = false);
930
931/// Convert given `SPF` to equivalent min/max intrinsic.
932/// Caller must ensure `SPF` is an integer min or max pattern.
933LLVM_ABI Intrinsic::ID getMinMaxIntrinsic(SelectPatternFlavor SPF);
934
935/// Return the inverse minimum/maximum flavor of the specified flavor.
936/// For example, signed minimum is the inverse of signed maximum.
937LLVM_ABI SelectPatternFlavor getInverseMinMaxFlavor(SelectPatternFlavor SPF);
938
940
941/// Return the minimum or maximum constant value for the specified integer
942/// min/max flavor and type.
943LLVM_ABI APInt getMinMaxLimit(SelectPatternFlavor SPF, unsigned BitWidth);
944
945/// Check if the values in \p VL are select instructions that can be converted
946/// to a min or max (vector) intrinsic. Returns the intrinsic ID, if such a
947/// conversion is possible, together with a bool indicating whether all select
948/// conditions are only used by the selects. Otherwise return
949/// Intrinsic::not_intrinsic.
950LLVM_ABI std::pair<Intrinsic::ID, bool>
952
953/// Attempt to match a simple first order recurrence cycle of the form:
954/// %iv = phi Ty [%Start, %Entry], [%Inc, %backedge]
955/// %inc = binop %iv, %step
956/// OR
957/// %iv = phi Ty [%Start, %Entry], [%Inc, %backedge]
958/// %inc = binop %step, %iv
959///
960/// A first order recurrence is a formula with the form: X_n = f(X_(n-1))
961///
962/// A couple of notes on subtleties in that definition:
963/// * The Step does not have to be loop invariant. In math terms, it can
964/// be a free variable. We allow recurrences with both constant and
965/// variable coefficients. Callers may wish to filter cases where Step
966/// does not dominate P.
967/// * For non-commutative operators, we will match both forms. This
968/// results in some odd recurrence structures. Callers may wish to filter
969/// out recurrences where the phi is not the LHS of the returned operator.
970/// * Because of the structure matched, the caller can assume as a post
971/// condition of the match the presence of a Loop with P's parent as it's
972/// header *except* in unreachable code. (Dominance decays in unreachable
973/// code.)
974///
975/// NOTE: This is intentional simple. If you want the ability to analyze
976/// non-trivial loop conditons, see ScalarEvolution instead.
977LLVM_ABI bool matchSimpleRecurrence(const PHINode *P, BinaryOperator *&BO,
978 Value *&Start, Value *&Step);
979
980/// Analogous to the above, but starting from the binary operator
981LLVM_ABI bool matchSimpleRecurrence(const BinaryOperator *I, PHINode *&P,
982 Value *&Start, Value *&Step);
983
984/// Attempt to match a simple value-accumulating recurrence of the form:
985/// %llvm.intrinsic.acc = phi Ty [%Init, %Entry], [%llvm.intrinsic, %backedge]
986/// %llvm.intrinsic = call Ty @llvm.intrinsic(%OtherOp, %llvm.intrinsic.acc)
987/// OR
988/// %llvm.intrinsic.acc = phi Ty [%Init, %Entry], [%llvm.intrinsic, %backedge]
989/// %llvm.intrinsic = call Ty @llvm.intrinsic(%llvm.intrinsic.acc, %OtherOp)
990///
991/// The recurrence relation is of kind:
992/// X_0 = %a (initial value),
993/// X_i = call @llvm.binary.intrinsic(X_i-1, %b)
994/// Where %b is not required to be loop-invariant.
995LLVM_ABI bool matchSimpleBinaryIntrinsicRecurrence(const IntrinsicInst *I,
996 PHINode *&P, Value *&Init,
997 Value *&OtherOp);
998
999/// Return true if RHS is known to be implied true by LHS. Return false if
1000/// RHS is known to be implied false by LHS. Otherwise, return std::nullopt if
1001/// no implication can be made. A & B must be i1 (boolean) values or a vector of
1002/// such values. Note that the truth table for implication is the same as <=u on
1003/// i1 values (but not
1004/// <=s!). The truth table for both is:
1005/// | T | F (B)
1006/// T | T | F
1007/// F | T | T
1008/// (A)
1009LLVM_ABI std::optional<bool>
1010isImpliedCondition(const Value *LHS, const Value *RHS, const DataLayout &DL,
1011 bool LHSIsTrue = true, unsigned Depth = 0);
1012LLVM_ABI std::optional<bool>
1013isImpliedCondition(const Value *LHS, CmpPredicate RHSPred, const Value *RHSOp0,
1014 const Value *RHSOp1, const DataLayout &DL,
1015 bool LHSIsTrue = true, unsigned Depth = 0);
1016
1017/// Return the boolean condition value in the context of the given instruction
1018/// if it is known based on dominating conditions.
1019LLVM_ABI std::optional<bool>
1020isImpliedByDomCondition(const Value *Cond, const Instruction *ContextI,
1021 const DataLayout &DL);
1022LLVM_ABI std::optional<bool>
1023isImpliedByDomCondition(CmpPredicate Pred, const Value *LHS, const Value *RHS,
1024 const Instruction *ContextI, const DataLayout &DL);
1025
1026/// Call \p InsertAffected on all Values whose known bits / value may be
1027/// affected by the condition \p Cond. Used by AssumptionCache and
1028/// DomConditionCache.
1029LLVM_ABI void
1030findValuesAffectedByCondition(Value *Cond, bool IsAssume,
1031 function_ref<void(Value *)> InsertAffected);
1032
1033/// Returns the inner value X if the expression has the form f(X)
1034/// where f(X) == 0 if and only if X == 0, otherwise returns nullptr.
1035LLVM_ABI Value *stripNullTest(Value *V);
1036LLVM_ABI const Value *stripNullTest(const Value *V);
1037
1038/// Enumerates all possible immediate values of V and inserts them into the set
1039/// \p Constants. If \p AllowUndefOrPoison is false, it fails when V may contain
1040/// undef/poison elements. Returns true if the result is complete. Otherwise,
1041/// the result is incomplete (more than MaxCount values).
1042/// NOTE: The constant values are not distinct.
1043LLVM_ABI bool
1044collectPossibleValues(const Value *V,
1045 SmallPtrSetImpl<const Constant *> &Constants,
1046 unsigned MaxCount, bool AllowUndefOrPoison = true);
1047
1048} // end namespace llvm
1049
1050#endif // LLVM_ANALYSIS_VALUETRACKING_H
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
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")
static TableGen::Emitter::OptClass< SkeletonEmitter > X("gen-skeleton-class", "Generate example skeleton class")
Value * RHS
Value * LHS
Class for arbitrary precision integers.
Definition APInt.h:78
int64_t getSExtValue() const
Get sign extended value.
Definition APInt.h:1563
an instruction to allocate memory on the stack
ArrayRef - 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 or float/double,...
Definition Constants.h:707
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:164
Convenience struct for specifying and reasoning about fast-math flags.
Definition FMF.h:22
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:1078
This is a utility class that provides an abstraction for the common functionality between Instruction...
Definition Operator.h:33
StringRef - Represent a constant reference to a string, i.e.
Definition StringRef.h:55
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:256
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.
Definition Types.h:26
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:532
@ 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 const Value * getArgumentAliasingToReturnedPointer(const CallBase *Call, bool MustPreserveNullness)
This function returns call pointer argument that is considered the same by aliasing rules.
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 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 ConstantRange computeConstantRange(const Value *V, bool ForSigned, bool UseInstrInfo=true, AssumptionCache *AC=nullptr, const Instruction *CtxI=nullptr, const DominatorTree *DT=nullptr, unsigned Depth=0)
Determine the possible constant range of an integer or vector of integer value.
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 isIntrinsicReturningPointerAliasingArgumentWithoutCapturing(const CallBase *Call, bool MustPreserveNullness)
{launder,strip}.invariant.group returns pointer that aliases its argument, and it only captures point...
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 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 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 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