LLVM 20.0.0git
Constants.h
Go to the documentation of this file.
1//===-- llvm/Constants.h - Constant class subclass definitions --*- 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/// @file
10/// This file contains the declarations for the subclasses of Constant,
11/// which represent the different flavors of constant values that live in LLVM.
12/// Note that Constants are immutable (once created they never change) and are
13/// fully shared by structural equivalence. This means that two structurally
14/// equivalent constants will always have the same address. Constants are
15/// created on demand as needed and never deleted: thus clients don't have to
16/// worry about the lifetime of the objects.
17//
18//===----------------------------------------------------------------------===//
19
20#ifndef LLVM_IR_CONSTANTS_H
21#define LLVM_IR_CONSTANTS_H
22
23#include "llvm/ADT/APFloat.h"
24#include "llvm/ADT/APInt.h"
25#include "llvm/ADT/ArrayRef.h"
26#include "llvm/ADT/STLExtras.h"
27#include "llvm/ADT/StringRef.h"
28#include "llvm/IR/Constant.h"
32#include "llvm/IR/Intrinsics.h"
34#include "llvm/IR/User.h"
35#include "llvm/IR/Value.h"
39#include <cassert>
40#include <cstddef>
41#include <cstdint>
42#include <optional>
43
44namespace llvm {
45
46template <class ConstantClass> struct ConstantAggrKeyType;
47
48/// Base class for constants with no operands.
49///
50/// These constants have no operands; they represent their data directly.
51/// Since they can be in use by unrelated modules (and are never based on
52/// GlobalValues), it never makes sense to RAUW them.
53class ConstantData : public Constant {
54 friend class Constant;
55
56 Value *handleOperandChangeImpl(Value *From, Value *To) {
57 llvm_unreachable("Constant data does not have operands!");
58 }
59
60protected:
61 explicit ConstantData(Type *Ty, ValueTy VT) : Constant(Ty, VT, nullptr, 0) {}
62
63 void *operator new(size_t S) { return User::operator new(S, 0); }
64
65public:
66 void operator delete(void *Ptr) { User::operator delete(Ptr); }
67
68 ConstantData(const ConstantData &) = delete;
69
70 /// Methods to support type inquiry through isa, cast, and dyn_cast.
71 static bool classof(const Value *V) {
72 return V->getValueID() >= ConstantDataFirstVal &&
73 V->getValueID() <= ConstantDataLastVal;
74 }
75};
76
77//===----------------------------------------------------------------------===//
78/// This is the shared class of boolean and integer constants. This class
79/// represents both boolean and integral constants.
80/// Class for constant integers.
81class ConstantInt final : public ConstantData {
82 friend class Constant;
83 friend class ConstantVector;
84
85 APInt Val;
86
87 ConstantInt(Type *Ty, const APInt &V);
88
89 void destroyConstantImpl();
90
91 /// Return a ConstantInt with the specified value and an implied Type. The
92 /// type is the vector type whose integer element type corresponds to the bit
93 /// width of the value.
94 static ConstantInt *get(LLVMContext &Context, ElementCount EC,
95 const APInt &V);
96
97public:
98 ConstantInt(const ConstantInt &) = delete;
99
100 static ConstantInt *getTrue(LLVMContext &Context);
101 static ConstantInt *getFalse(LLVMContext &Context);
102 static ConstantInt *getBool(LLVMContext &Context, bool V);
103 static Constant *getTrue(Type *Ty);
104 static Constant *getFalse(Type *Ty);
105 static Constant *getBool(Type *Ty, bool V);
106
107 /// If Ty is a vector type, return a Constant with a splat of the given
108 /// value. Otherwise return a ConstantInt for the given value.
109 static Constant *get(Type *Ty, uint64_t V, bool IsSigned = false);
110
111 /// Return a ConstantInt with the specified integer value for the specified
112 /// type. If the type is wider than 64 bits, the value will be zero-extended
113 /// to fit the type, unless IsSigned is true, in which case the value will
114 /// be interpreted as a 64-bit signed integer and sign-extended to fit
115 /// the type.
116 /// Get a ConstantInt for a specific value.
117 static ConstantInt *get(IntegerType *Ty, uint64_t V, bool IsSigned = false);
118
119 /// Return a ConstantInt with the specified value for the specified type. The
120 /// value V will be canonicalized to a an unsigned APInt. Accessing it with
121 /// either getSExtValue() or getZExtValue() will yield a correctly sized and
122 /// signed value for the type Ty.
123 /// Get a ConstantInt for a specific signed value.
124 static ConstantInt *getSigned(IntegerType *Ty, int64_t V) {
125 return get(Ty, V, true);
126 }
127 static Constant *getSigned(Type *Ty, int64_t V) {
128 return get(Ty, V, true);
129 }
130
131 /// Return a ConstantInt with the specified value and an implied Type. The
132 /// type is the integer type that corresponds to the bit width of the value.
133 static ConstantInt *get(LLVMContext &Context, const APInt &V);
134
135 /// Return a ConstantInt constructed from the string strStart with the given
136 /// radix.
137 static ConstantInt *get(IntegerType *Ty, StringRef Str, uint8_t Radix);
138
139 /// If Ty is a vector type, return a Constant with a splat of the given
140 /// value. Otherwise return a ConstantInt for the given value.
141 static Constant *get(Type *Ty, const APInt &V);
142
143 /// Return the constant as an APInt value reference. This allows clients to
144 /// obtain a full-precision copy of the value.
145 /// Return the constant's value.
146 inline const APInt &getValue() const { return Val; }
147
148 /// getBitWidth - Return the scalar bitwidth of this constant.
149 unsigned getBitWidth() const { return Val.getBitWidth(); }
150
151 /// Return the constant as a 64-bit unsigned integer value after it
152 /// has been zero extended as appropriate for the type of this constant. Note
153 /// that this method can assert if the value does not fit in 64 bits.
154 /// Return the zero extended value.
155 inline uint64_t getZExtValue() const { return Val.getZExtValue(); }
156
157 /// Return the constant as a 64-bit integer value after it has been sign
158 /// extended as appropriate for the type of this constant. Note that
159 /// this method can assert if the value does not fit in 64 bits.
160 /// Return the sign extended value.
161 inline int64_t getSExtValue() const { return Val.getSExtValue(); }
162
163 /// Return the constant as an llvm::MaybeAlign.
164 /// Note that this method can assert if the value does not fit in 64 bits or
165 /// is not a power of two.
167 return MaybeAlign(getZExtValue());
168 }
169
170 /// Return the constant as an llvm::Align, interpreting `0` as `Align(1)`.
171 /// Note that this method can assert if the value does not fit in 64 bits or
172 /// is not a power of two.
173 inline Align getAlignValue() const {
175 }
176
177 /// A helper method that can be used to determine if the constant contained
178 /// within is equal to a constant. This only works for very small values,
179 /// because this is all that can be represented with all types.
180 /// Determine if this constant's value is same as an unsigned char.
181 bool equalsInt(uint64_t V) const { return Val == V; }
182
183 /// Variant of the getType() method to always return an IntegerType, which
184 /// reduces the amount of casting needed in parts of the compiler.
185 inline IntegerType *getIntegerType() const {
186 return cast<IntegerType>(Value::getType());
187 }
188
189 /// This static method returns true if the type Ty is big enough to
190 /// represent the value V. This can be used to avoid having the get method
191 /// assert when V is larger than Ty can represent. Note that there are two
192 /// versions of this method, one for unsigned and one for signed integers.
193 /// Although ConstantInt canonicalizes everything to an unsigned integer,
194 /// the signed version avoids callers having to convert a signed quantity
195 /// to the appropriate unsigned type before calling the method.
196 /// @returns true if V is a valid value for type Ty
197 /// Determine if the value is in range for the given type.
198 static bool isValueValidForType(Type *Ty, uint64_t V);
199 static bool isValueValidForType(Type *Ty, int64_t V);
200
201 bool isNegative() const { return Val.isNegative(); }
202
203 /// This is just a convenience method to make client code smaller for a
204 /// common code. It also correctly performs the comparison without the
205 /// potential for an assertion from getZExtValue().
206 bool isZero() const { return Val.isZero(); }
207
208 /// This is just a convenience method to make client code smaller for a
209 /// common case. It also correctly performs the comparison without the
210 /// potential for an assertion from getZExtValue().
211 /// Determine if the value is one.
212 bool isOne() const { return Val.isOne(); }
213
214 /// This function will return true iff every bit in this constant is set
215 /// to true.
216 /// @returns true iff this constant's bits are all set to true.
217 /// Determine if the value is all ones.
218 bool isMinusOne() const { return Val.isAllOnes(); }
219
220 /// This function will return true iff this constant represents the largest
221 /// value that may be represented by the constant's type.
222 /// @returns true iff this is the largest value that may be represented
223 /// by this type.
224 /// Determine if the value is maximal.
225 bool isMaxValue(bool IsSigned) const {
226 if (IsSigned)
227 return Val.isMaxSignedValue();
228 else
229 return Val.isMaxValue();
230 }
231
232 /// This function will return true iff this constant represents the smallest
233 /// value that may be represented by this constant's type.
234 /// @returns true if this is the smallest value that may be represented by
235 /// this type.
236 /// Determine if the value is minimal.
237 bool isMinValue(bool IsSigned) const {
238 if (IsSigned)
239 return Val.isMinSignedValue();
240 else
241 return Val.isMinValue();
242 }
243
244 /// This function will return true iff this constant represents a value with
245 /// active bits bigger than 64 bits or a value greater than the given uint64_t
246 /// value.
247 /// @returns true iff this constant is greater or equal to the given number.
248 /// Determine if the value is greater or equal to the given number.
249 bool uge(uint64_t Num) const { return Val.uge(Num); }
250
251 /// getLimitedValue - If the value is smaller than the specified limit,
252 /// return it, otherwise return the limit value. This causes the value
253 /// to saturate to the limit.
254 /// @returns the min of the value of the constant and the specified value
255 /// Get the constant's value with a saturation limit
256 uint64_t getLimitedValue(uint64_t Limit = ~0ULL) const {
257 return Val.getLimitedValue(Limit);
258 }
259
260 /// Methods to support type inquiry through isa, cast, and dyn_cast.
261 static bool classof(const Value *V) {
262 return V->getValueID() == ConstantIntVal;
263 }
264};
265
266//===----------------------------------------------------------------------===//
267/// ConstantFP - Floating Point Values [float, double]
268///
269class ConstantFP final : public ConstantData {
270 friend class Constant;
271 friend class ConstantVector;
272
273 APFloat Val;
274
275 ConstantFP(Type *Ty, const APFloat &V);
276
277 void destroyConstantImpl();
278
279 /// Return a ConstantFP with the specified value and an implied Type. The
280 /// type is the vector type whose element type has the same floating point
281 /// semantics as the value.
282 static ConstantFP *get(LLVMContext &Context, ElementCount EC,
283 const APFloat &V);
284
285public:
286 ConstantFP(const ConstantFP &) = delete;
287
288 /// This returns a ConstantFP, or a vector containing a splat of a ConstantFP,
289 /// for the specified value in the specified type. This should only be used
290 /// for simple constant values like 2.0/1.0 etc, that are known-valid both as
291 /// host double and as the target format.
292 static Constant *get(Type *Ty, double V);
293
294 /// If Ty is a vector type, return a Constant with a splat of the given
295 /// value. Otherwise return a ConstantFP for the given value.
296 static Constant *get(Type *Ty, const APFloat &V);
297
298 static Constant *get(Type *Ty, StringRef Str);
299 static ConstantFP *get(LLVMContext &Context, const APFloat &V);
300 static Constant *getNaN(Type *Ty, bool Negative = false,
301 uint64_t Payload = 0);
302 static Constant *getQNaN(Type *Ty, bool Negative = false,
303 APInt *Payload = nullptr);
304 static Constant *getSNaN(Type *Ty, bool Negative = false,
305 APInt *Payload = nullptr);
306 static Constant *getZero(Type *Ty, bool Negative = false);
307 static Constant *getNegativeZero(Type *Ty) { return getZero(Ty, true); }
308 static Constant *getInfinity(Type *Ty, bool Negative = false);
309
310 /// Return true if Ty is big enough to represent V.
311 static bool isValueValidForType(Type *Ty, const APFloat &V);
312 inline const APFloat &getValueAPF() const { return Val; }
313 inline const APFloat &getValue() const { return Val; }
314
315 /// Return true if the value is positive or negative zero.
316 bool isZero() const { return Val.isZero(); }
317
318 /// Return true if the sign bit is set.
319 bool isNegative() const { return Val.isNegative(); }
320
321 /// Return true if the value is infinity
322 bool isInfinity() const { return Val.isInfinity(); }
323
324 /// Return true if the value is a NaN.
325 bool isNaN() const { return Val.isNaN(); }
326
327 /// We don't rely on operator== working on double values, as it returns true
328 /// for things that are clearly not equal, like -0.0 and 0.0.
329 /// As such, this method can be used to do an exact bit-for-bit comparison of
330 /// two floating point values. The version with a double operand is retained
331 /// because it's so convenient to write isExactlyValue(2.0), but please use
332 /// it only for simple constants.
333 bool isExactlyValue(const APFloat &V) const;
334
335 bool isExactlyValue(double V) const {
336 bool ignored;
337 APFloat FV(V);
339 return isExactlyValue(FV);
340 }
341
342 /// Methods for support type inquiry through isa, cast, and dyn_cast:
343 static bool classof(const Value *V) {
344 return V->getValueID() == ConstantFPVal;
345 }
346};
347
348//===----------------------------------------------------------------------===//
349/// All zero aggregate value
350///
352 friend class Constant;
353
354 explicit ConstantAggregateZero(Type *Ty)
355 : ConstantData(Ty, ConstantAggregateZeroVal) {}
356
357 void destroyConstantImpl();
358
359public:
361
362 static ConstantAggregateZero *get(Type *Ty);
363
364 /// If this CAZ has array or vector type, return a zero with the right element
365 /// type.
367
368 /// If this CAZ has struct type, return a zero with the right element type for
369 /// the specified element.
370 Constant *getStructElement(unsigned Elt) const;
371
372 /// Return a zero of the right value for the specified GEP index if we can,
373 /// otherwise return null (e.g. if C is a ConstantExpr).
375
376 /// Return a zero of the right value for the specified GEP index.
377 Constant *getElementValue(unsigned Idx) const;
378
379 /// Return the number of elements in the array, vector, or struct.
381
382 /// Methods for support type inquiry through isa, cast, and dyn_cast:
383 ///
384 static bool classof(const Value *V) {
385 return V->getValueID() == ConstantAggregateZeroVal;
386 }
387};
388
389/// Base class for aggregate constants (with operands).
390///
391/// These constants are aggregates of other constants, which are stored as
392/// operands.
393///
394/// Subclasses are \a ConstantStruct, \a ConstantArray, and \a
395/// ConstantVector.
396///
397/// \note Some subclasses of \a ConstantData are semantically aggregates --
398/// such as \a ConstantDataArray -- but are not subclasses of this because they
399/// use operands.
401protected:
403
404public:
405 /// Transparently provide more efficient getOperand methods.
407
408 /// Methods for support type inquiry through isa, cast, and dyn_cast:
409 static bool classof(const Value *V) {
410 return V->getValueID() >= ConstantAggregateFirstVal &&
411 V->getValueID() <= ConstantAggregateLastVal;
412 }
413};
414
415template <>
417 : public VariadicOperandTraits<ConstantAggregate> {};
418
420
421//===----------------------------------------------------------------------===//
422/// ConstantArray - Constant Array Declarations
423///
424class ConstantArray final : public ConstantAggregate {
425 friend struct ConstantAggrKeyType<ConstantArray>;
426 friend class Constant;
427
429
430 void destroyConstantImpl();
431 Value *handleOperandChangeImpl(Value *From, Value *To);
432
433public:
434 // ConstantArray accessors
436
437private:
438 static Constant *getImpl(ArrayType *T, ArrayRef<Constant *> V);
439
440public:
441 /// Specialize the getType() method to always return an ArrayType,
442 /// which reduces the amount of casting needed in parts of the compiler.
443 inline ArrayType *getType() const {
444 return cast<ArrayType>(Value::getType());
445 }
446
447 /// Methods for support type inquiry through isa, cast, and dyn_cast:
448 static bool classof(const Value *V) {
449 return V->getValueID() == ConstantArrayVal;
450 }
451};
452
453//===----------------------------------------------------------------------===//
454// Constant Struct Declarations
455//
456class ConstantStruct final : public ConstantAggregate {
457 friend struct ConstantAggrKeyType<ConstantStruct>;
458 friend class Constant;
459
461
462 void destroyConstantImpl();
463 Value *handleOperandChangeImpl(Value *From, Value *To);
464
465public:
466 // ConstantStruct accessors
468
469 template <typename... Csts>
470 static std::enable_if_t<are_base_of<Constant, Csts...>::value, Constant *>
471 get(StructType *T, Csts *...Vs) {
472 return get(T, ArrayRef<Constant *>({Vs...}));
473 }
474
475 /// Return an anonymous struct that has the specified elements.
476 /// If the struct is possibly empty, then you must specify a context.
477 static Constant *getAnon(ArrayRef<Constant *> V, bool Packed = false) {
478 return get(getTypeForElements(V, Packed), V);
479 }
481 bool Packed = false) {
482 return get(getTypeForElements(Ctx, V, Packed), V);
483 }
484
485 /// Return an anonymous struct type to use for a constant with the specified
486 /// set of elements. The list must not be empty.
488 bool Packed = false);
489 /// This version of the method allows an empty list.
492 bool Packed = false);
493
494 /// Specialization - reduce amount of casting.
495 inline StructType *getType() const {
496 return cast<StructType>(Value::getType());
497 }
498
499 /// Methods for support type inquiry through isa, cast, and dyn_cast:
500 static bool classof(const Value *V) {
501 return V->getValueID() == ConstantStructVal;
502 }
503};
504
505//===----------------------------------------------------------------------===//
506/// Constant Vector Declarations
507///
508class ConstantVector final : public ConstantAggregate {
509 friend struct ConstantAggrKeyType<ConstantVector>;
510 friend class Constant;
511
513
514 void destroyConstantImpl();
515 Value *handleOperandChangeImpl(Value *From, Value *To);
516
517public:
518 // ConstantVector accessors
520
521private:
522 static Constant *getImpl(ArrayRef<Constant *> V);
523
524public:
525 /// Return a ConstantVector with the specified constant in each element.
526 /// Note that this might not return an instance of ConstantVector
527 static Constant *getSplat(ElementCount EC, Constant *Elt);
528
529 /// Specialize the getType() method to always return a FixedVectorType,
530 /// which reduces the amount of casting needed in parts of the compiler.
531 inline FixedVectorType *getType() const {
532 return cast<FixedVectorType>(Value::getType());
533 }
534
535 /// If all elements of the vector constant have the same value, return that
536 /// value. Otherwise, return nullptr. Ignore poison elements by setting
537 /// AllowPoison to true.
538 Constant *getSplatValue(bool AllowPoison = false) const;
539
540 /// Methods for support type inquiry through isa, cast, and dyn_cast:
541 static bool classof(const Value *V) {
542 return V->getValueID() == ConstantVectorVal;
543 }
544};
545
546//===----------------------------------------------------------------------===//
547/// A constant pointer value that points to null
548///
549class ConstantPointerNull final : public ConstantData {
550 friend class Constant;
551
553 : ConstantData(T, Value::ConstantPointerNullVal) {}
554
555 void destroyConstantImpl();
556
557public:
559
560 /// Static factory methods - Return objects of the specified value
562
563 /// Specialize the getType() method to always return an PointerType,
564 /// which reduces the amount of casting needed in parts of the compiler.
565 inline PointerType *getType() const {
566 return cast<PointerType>(Value::getType());
567 }
568
569 /// Methods for support type inquiry through isa, cast, and dyn_cast:
570 static bool classof(const Value *V) {
571 return V->getValueID() == ConstantPointerNullVal;
572 }
573};
574
575//===----------------------------------------------------------------------===//
576/// ConstantDataSequential - A vector or array constant whose element type is a
577/// simple 1/2/4/8-byte integer or half/bfloat/float/double, and whose elements
578/// are just simple data values (i.e. ConstantInt/ConstantFP). This Constant
579/// node has no operands because it stores all of the elements of the constant
580/// as densely packed data, instead of as Value*'s.
581///
582/// This is the common base class of ConstantDataArray and ConstantDataVector.
583///
585 friend class LLVMContextImpl;
586 friend class Constant;
587
588 /// A pointer to the bytes underlying this constant (which is owned by the
589 /// uniquing StringMap).
590 const char *DataElements;
591
592 /// This forms a link list of ConstantDataSequential nodes that have
593 /// the same value but different type. For example, 0,0,0,1 could be a 4
594 /// element array of i8, or a 1-element array of i32. They'll both end up in
595 /// the same StringMap bucket, linked up.
596 std::unique_ptr<ConstantDataSequential> Next;
597
598 void destroyConstantImpl();
599
600protected:
601 explicit ConstantDataSequential(Type *ty, ValueTy VT, const char *Data)
602 : ConstantData(ty, VT), DataElements(Data) {}
603
604 static Constant *getImpl(StringRef Bytes, Type *Ty);
605
606public:
608
609 /// Return true if a ConstantDataSequential can be formed with a vector or
610 /// array of the specified element type.
611 /// ConstantDataArray only works with normal float and int types that are
612 /// stored densely in memory, not with things like i42 or x86_f80.
613 static bool isElementTypeCompatible(Type *Ty);
614
615 /// If this is a sequential container of integers (of any size), return the
616 /// specified element in the low bits of a uint64_t.
617 uint64_t getElementAsInteger(unsigned i) const;
618
619 /// If this is a sequential container of integers (of any size), return the
620 /// specified element as an APInt.
621 APInt getElementAsAPInt(unsigned i) const;
622
623 /// If this is a sequential container of floating point type, return the
624 /// specified element as an APFloat.
625 APFloat getElementAsAPFloat(unsigned i) const;
626
627 /// If this is an sequential container of floats, return the specified element
628 /// as a float.
629 float getElementAsFloat(unsigned i) const;
630
631 /// If this is an sequential container of doubles, return the specified
632 /// element as a double.
633 double getElementAsDouble(unsigned i) const;
634
635 /// Return a Constant for a specified index's element.
636 /// Note that this has to compute a new constant to return, so it isn't as
637 /// efficient as getElementAsInteger/Float/Double.
638 Constant *getElementAsConstant(unsigned i) const;
639
640 /// Return the element type of the array/vector.
641 Type *getElementType() const;
642
643 /// Return the number of elements in the array or vector.
644 unsigned getNumElements() const;
645
646 /// Return the size (in bytes) of each element in the array/vector.
647 /// The size of the elements is known to be a multiple of one byte.
649
650 /// This method returns true if this is an array of \p CharSize integers.
651 bool isString(unsigned CharSize = 8) const;
652
653 /// This method returns true if the array "isString", ends with a null byte,
654 /// and does not contains any other null bytes.
655 bool isCString() const;
656
657 /// If this array is isString(), then this method returns the array as a
658 /// StringRef. Otherwise, it asserts out.
660 assert(isString() && "Not a string");
661 return getRawDataValues();
662 }
663
664 /// If this array is isCString(), then this method returns the array (without
665 /// the trailing null byte) as a StringRef. Otherwise, it asserts out.
667 assert(isCString() && "Isn't a C string");
668 StringRef Str = getAsString();
669 return Str.substr(0, Str.size() - 1);
670 }
671
672 /// Return the raw, underlying, bytes of this data. Note that this is an
673 /// extremely tricky thing to work with, as it exposes the host endianness of
674 /// the data elements.
676
677 /// Methods for support type inquiry through isa, cast, and dyn_cast:
678 static bool classof(const Value *V) {
679 return V->getValueID() == ConstantDataArrayVal ||
680 V->getValueID() == ConstantDataVectorVal;
681 }
682
683private:
684 const char *getElementPointer(unsigned Elt) const;
685};
686
687//===----------------------------------------------------------------------===//
688/// An array constant whose element type is a simple 1/2/4/8-byte integer or
689/// float/double, and whose elements are just simple data values
690/// (i.e. ConstantInt/ConstantFP). This Constant node has no operands because it
691/// stores all of the elements of the constant as densely packed data, instead
692/// of as Value*'s.
695
696 explicit ConstantDataArray(Type *ty, const char *Data)
697 : ConstantDataSequential(ty, ConstantDataArrayVal, Data) {}
698
699public:
701
702 /// get() constructor - Return a constant with array type with an element
703 /// count and element type matching the ArrayRef passed in. Note that this
704 /// can return a ConstantAggregateZero object.
705 template <typename ElementTy>
706 static Constant *get(LLVMContext &Context, ArrayRef<ElementTy> Elts) {
707 const char *Data = reinterpret_cast<const char *>(Elts.data());
708 return getRaw(StringRef(Data, Elts.size() * sizeof(ElementTy)), Elts.size(),
709 Type::getScalarTy<ElementTy>(Context));
710 }
711
712 /// get() constructor - ArrayTy needs to be compatible with
713 /// ArrayRef<ElementTy>. Calls get(LLVMContext, ArrayRef<ElementTy>).
714 template <typename ArrayTy>
715 static Constant *get(LLVMContext &Context, ArrayTy &Elts) {
716 return ConstantDataArray::get(Context, ArrayRef(Elts));
717 }
718
719 /// getRaw() constructor - Return a constant with array type with an element
720 /// count and element type matching the NumElements and ElementTy parameters
721 /// passed in. Note that this can return a ConstantAggregateZero object.
722 /// ElementTy must be one of i8/i16/i32/i64/half/bfloat/float/double. Data is
723 /// the buffer containing the elements. Be careful to make sure Data uses the
724 /// right endianness, the buffer will be used as-is.
725 static Constant *getRaw(StringRef Data, uint64_t NumElements,
726 Type *ElementTy) {
727 Type *Ty = ArrayType::get(ElementTy, NumElements);
728 return getImpl(Data, Ty);
729 }
730
731 /// getFP() constructors - Return a constant of array type with a float
732 /// element type taken from argument `ElementType', and count taken from
733 /// argument `Elts'. The amount of bits of the contained type must match the
734 /// number of bits of the type contained in the passed in ArrayRef.
735 /// (i.e. half or bfloat for 16bits, float for 32bits, double for 64bits) Note
736 /// that this can return a ConstantAggregateZero object.
737 static Constant *getFP(Type *ElementType, ArrayRef<uint16_t> Elts);
738 static Constant *getFP(Type *ElementType, ArrayRef<uint32_t> Elts);
739 static Constant *getFP(Type *ElementType, ArrayRef<uint64_t> Elts);
740
741 /// This method constructs a CDS and initializes it with a text string.
742 /// The default behavior (AddNull==true) causes a null terminator to
743 /// be placed at the end of the array (increasing the length of the string by
744 /// one more than the StringRef would normally indicate. Pass AddNull=false
745 /// to disable this behavior.
746 static Constant *getString(LLVMContext &Context, StringRef Initializer,
747 bool AddNull = true);
748
749 /// Specialize the getType() method to always return an ArrayType,
750 /// which reduces the amount of casting needed in parts of the compiler.
751 inline ArrayType *getType() const {
752 return cast<ArrayType>(Value::getType());
753 }
754
755 /// Methods for support type inquiry through isa, cast, and dyn_cast:
756 static bool classof(const Value *V) {
757 return V->getValueID() == ConstantDataArrayVal;
758 }
759};
760
761//===----------------------------------------------------------------------===//
762/// A vector constant whose element type is a simple 1/2/4/8-byte integer or
763/// float/double, and whose elements are just simple data values
764/// (i.e. ConstantInt/ConstantFP). This Constant node has no operands because it
765/// stores all of the elements of the constant as densely packed data, instead
766/// of as Value*'s.
769
770 explicit ConstantDataVector(Type *ty, const char *Data)
771 : ConstantDataSequential(ty, ConstantDataVectorVal, Data),
772 IsSplatSet(false) {}
773 // Cache whether or not the constant is a splat.
774 mutable bool IsSplatSet : 1;
775 mutable bool IsSplat : 1;
776 bool isSplatData() const;
777
778public:
780
781 /// get() constructors - Return a constant with vector type with an element
782 /// count and element type matching the ArrayRef passed in. Note that this
783 /// can return a ConstantAggregateZero object.
784 static Constant *get(LLVMContext &Context, ArrayRef<uint8_t> Elts);
785 static Constant *get(LLVMContext &Context, ArrayRef<uint16_t> Elts);
786 static Constant *get(LLVMContext &Context, ArrayRef<uint32_t> Elts);
787 static Constant *get(LLVMContext &Context, ArrayRef<uint64_t> Elts);
788 static Constant *get(LLVMContext &Context, ArrayRef<float> Elts);
789 static Constant *get(LLVMContext &Context, ArrayRef<double> Elts);
790
791 /// getRaw() constructor - Return a constant with vector type with an element
792 /// count and element type matching the NumElements and ElementTy parameters
793 /// passed in. Note that this can return a ConstantAggregateZero object.
794 /// ElementTy must be one of i8/i16/i32/i64/half/bfloat/float/double. Data is
795 /// the buffer containing the elements. Be careful to make sure Data uses the
796 /// right endianness, the buffer will be used as-is.
797 static Constant *getRaw(StringRef Data, uint64_t NumElements,
798 Type *ElementTy) {
799 Type *Ty = VectorType::get(ElementTy, ElementCount::getFixed(NumElements));
800 return getImpl(Data, Ty);
801 }
802
803 /// getFP() constructors - Return a constant of vector type with a float
804 /// element type taken from argument `ElementType', and count taken from
805 /// argument `Elts'. The amount of bits of the contained type must match the
806 /// number of bits of the type contained in the passed in ArrayRef.
807 /// (i.e. half or bfloat for 16bits, float for 32bits, double for 64bits) Note
808 /// that this can return a ConstantAggregateZero object.
809 static Constant *getFP(Type *ElementType, ArrayRef<uint16_t> Elts);
810 static Constant *getFP(Type *ElementType, ArrayRef<uint32_t> Elts);
811 static Constant *getFP(Type *ElementType, ArrayRef<uint64_t> Elts);
812
813 /// Return a ConstantVector with the specified constant in each element.
814 /// The specified constant has to be a of a compatible type (i8/i16/
815 /// i32/i64/half/bfloat/float/double) and must be a ConstantFP or ConstantInt.
816 static Constant *getSplat(unsigned NumElts, Constant *Elt);
817
818 /// Returns true if this is a splat constant, meaning that all elements have
819 /// the same value.
820 bool isSplat() const;
821
822 /// If this is a splat constant, meaning that all of the elements have the
823 /// same value, return that value. Otherwise return NULL.
824 Constant *getSplatValue() const;
825
826 /// Specialize the getType() method to always return a FixedVectorType,
827 /// which reduces the amount of casting needed in parts of the compiler.
828 inline FixedVectorType *getType() const {
829 return cast<FixedVectorType>(Value::getType());
830 }
831
832 /// Methods for support type inquiry through isa, cast, and dyn_cast:
833 static bool classof(const Value *V) {
834 return V->getValueID() == ConstantDataVectorVal;
835 }
836};
837
838//===----------------------------------------------------------------------===//
839/// A constant token which is empty
840///
841class ConstantTokenNone final : public ConstantData {
842 friend class Constant;
843
844 explicit ConstantTokenNone(LLVMContext &Context)
845 : ConstantData(Type::getTokenTy(Context), ConstantTokenNoneVal) {}
846
847 void destroyConstantImpl();
848
849public:
851
852 /// Return the ConstantTokenNone.
853 static ConstantTokenNone *get(LLVMContext &Context);
854
855 /// Methods to support type inquiry through isa, cast, and dyn_cast.
856 static bool classof(const Value *V) {
857 return V->getValueID() == ConstantTokenNoneVal;
858 }
859};
860
861/// A constant target extension type default initializer
862class ConstantTargetNone final : public ConstantData {
863 friend class Constant;
864
866 : ConstantData(T, Value::ConstantTargetNoneVal) {}
867
868 void destroyConstantImpl();
869
870public:
872
873 /// Static factory methods - Return objects of the specified value.
875
876 /// Specialize the getType() method to always return an TargetExtType,
877 /// which reduces the amount of casting needed in parts of the compiler.
878 inline TargetExtType *getType() const {
879 return cast<TargetExtType>(Value::getType());
880 }
881
882 /// Methods for support type inquiry through isa, cast, and dyn_cast.
883 static bool classof(const Value *V) {
884 return V->getValueID() == ConstantTargetNoneVal;
885 }
886};
887
888/// The address of a basic block.
889///
890class BlockAddress final : public Constant {
891 friend class Constant;
892
894
895 void *operator new(size_t S) { return User::operator new(S, 2); }
896
897 void destroyConstantImpl();
898 Value *handleOperandChangeImpl(Value *From, Value *To);
899
900public:
901 void operator delete(void *Ptr) { User::operator delete(Ptr); }
902
903 /// Return a BlockAddress for the specified function and basic block.
904 static BlockAddress *get(Function *F, BasicBlock *BB);
905
906 /// Return a BlockAddress for the specified basic block. The basic
907 /// block must be embedded into a function.
908 static BlockAddress *get(BasicBlock *BB);
909
910 /// Lookup an existing \c BlockAddress constant for the given BasicBlock.
911 ///
912 /// \returns 0 if \c !BB->hasAddressTaken(), otherwise the \c BlockAddress.
913 static BlockAddress *lookup(const BasicBlock *BB);
914
915 /// Transparently provide more efficient getOperand methods.
917
918 Function *getFunction() const { return (Function *)Op<0>().get(); }
919 BasicBlock *getBasicBlock() const { return (BasicBlock *)Op<1>().get(); }
920
921 /// Methods for support type inquiry through isa, cast, and dyn_cast:
922 static bool classof(const Value *V) {
923 return V->getValueID() == BlockAddressVal;
924 }
925};
926
927template <>
929 : public FixedNumOperandTraits<BlockAddress, 2> {};
930
932
933/// Wrapper for a function that represents a value that
934/// functionally represents the original function. This can be a function,
935/// global alias to a function, or an ifunc.
936class DSOLocalEquivalent final : public Constant {
937 friend class Constant;
938
940
941 void *operator new(size_t S) { return User::operator new(S, 1); }
942
943 void destroyConstantImpl();
944 Value *handleOperandChangeImpl(Value *From, Value *To);
945
946public:
947 void operator delete(void *Ptr) { User::operator delete(Ptr); }
948
949 /// Return a DSOLocalEquivalent for the specified global value.
951
952 /// Transparently provide more efficient getOperand methods.
954
956 return cast<GlobalValue>(Op<0>().get());
957 }
958
959 /// Methods for support type inquiry through isa, cast, and dyn_cast:
960 static bool classof(const Value *V) {
961 return V->getValueID() == DSOLocalEquivalentVal;
962 }
963};
964
965template <>
967 : public FixedNumOperandTraits<DSOLocalEquivalent, 1> {};
968
970
971/// Wrapper for a value that won't be replaced with a CFI jump table
972/// pointer in LowerTypeTestsModule.
973class NoCFIValue final : public Constant {
974 friend class Constant;
975
977
978 void *operator new(size_t S) { return User::operator new(S, 1); }
979
980 void destroyConstantImpl();
981 Value *handleOperandChangeImpl(Value *From, Value *To);
982
983public:
984 /// Return a NoCFIValue for the specified function.
985 static NoCFIValue *get(GlobalValue *GV);
986
987 /// Transparently provide more efficient getOperand methods.
989
991 return cast<GlobalValue>(Op<0>().get());
992 }
993
994 /// NoCFIValue is always a pointer.
996 return cast<PointerType>(Value::getType());
997 }
998
999 /// Methods for support type inquiry through isa, cast, and dyn_cast:
1000 static bool classof(const Value *V) {
1001 return V->getValueID() == NoCFIValueVal;
1002 }
1003};
1004
1005template <>
1006struct OperandTraits<NoCFIValue> : public FixedNumOperandTraits<NoCFIValue, 1> {
1007};
1008
1010
1011/// A signed pointer, in the ptrauth sense.
1012class ConstantPtrAuth final : public Constant {
1014 friend class Constant;
1015
1017 Constant *AddrDisc);
1018
1019 void *operator new(size_t s) { return User::operator new(s, 4); }
1020
1021 void destroyConstantImpl();
1022 Value *handleOperandChangeImpl(Value *From, Value *To);
1023
1024public:
1025 /// Return a pointer signed with the specified parameters.
1027 ConstantInt *Disc, Constant *AddrDisc);
1028
1029 /// Produce a new ptrauth expression signing the given value using
1030 /// the same schema as is stored in one.
1031 ConstantPtrAuth *getWithSameSchema(Constant *Pointer) const;
1032
1033 /// Transparently provide more efficient getOperand methods.
1035
1036 /// The pointer that is signed in this ptrauth signed pointer.
1037 Constant *getPointer() const { return cast<Constant>(Op<0>().get()); }
1038
1039 /// The Key ID, an i32 constant.
1040 ConstantInt *getKey() const { return cast<ConstantInt>(Op<1>().get()); }
1041
1042 /// The integer discriminator, an i64 constant, or 0.
1044 return cast<ConstantInt>(Op<2>().get());
1045 }
1046
1047 /// The address discriminator if any, or the null constant.
1048 /// If present, this must be a value equivalent to the storage location of
1049 /// the only global-initializer user of the ptrauth signed pointer.
1051 return cast<Constant>(Op<3>().get());
1052 }
1053
1054 /// Whether there is any non-null address discriminator.
1056 return !getAddrDiscriminator()->isNullValue();
1057 }
1058
1059 /// A constant value for the address discriminator which has special
1060 /// significance to ctors/dtors lowering. Regular address discrimination can't
1061 /// be applied for them since uses of llvm.global_{c|d}tors are disallowed
1062 /// (see Verifier::visitGlobalVariable) and we can't emit getelementptr
1063 /// expressions referencing these special arrays.
1064 enum { AddrDiscriminator_CtorsDtors = 1 };
1065
1066 /// Whether the address uses a special address discriminator.
1067 /// These discriminators can't be used in real pointer-auth values; they
1068 /// can only be used in "prototype" values that indicate how some real
1069 /// schema is supposed to be produced.
1070 bool hasSpecialAddressDiscriminator(uint64_t Value) const;
1071
1072 /// Check whether an authentication operation with key \p Key and (possibly
1073 /// blended) discriminator \p Discriminator is known to be compatible with
1074 /// this ptrauth signed pointer.
1075 bool isKnownCompatibleWith(const Value *Key, const Value *Discriminator,
1076 const DataLayout &DL) const;
1077
1078 /// Methods for support type inquiry through isa, cast, and dyn_cast:
1079 static bool classof(const Value *V) {
1080 return V->getValueID() == ConstantPtrAuthVal;
1081 }
1082};
1083
1084template <>
1086 : public FixedNumOperandTraits<ConstantPtrAuth, 4> {};
1087
1089
1090//===----------------------------------------------------------------------===//
1091/// A constant value that is initialized with an expression using
1092/// other constant values.
1093///
1094/// This class uses the standard Instruction opcodes to define the various
1095/// constant expressions. The Opcode field for the ConstantExpr class is
1096/// maintained in the Value::SubclassData field.
1097class ConstantExpr : public Constant {
1098 friend struct ConstantExprKeyType;
1099 friend class Constant;
1100
1101 void destroyConstantImpl();
1102 Value *handleOperandChangeImpl(Value *From, Value *To);
1103
1104protected:
1105 ConstantExpr(Type *ty, unsigned Opcode, Use *Ops, unsigned NumOps)
1106 : Constant(ty, ConstantExprVal, Ops, NumOps) {
1107 // Operation type (an Instruction opcode) is stored as the SubclassData.
1108 setValueSubclassData(Opcode);
1109 }
1110
1111 ~ConstantExpr() = default;
1112
1113public:
1114 // Static methods to construct a ConstantExpr of different kinds. Note that
1115 // these methods may return a object that is not an instance of the
1116 // ConstantExpr class, because they will attempt to fold the constant
1117 // expression into something simpler if possible.
1118
1119 /// getAlignOf constant expr - computes the alignment of a type in a target
1120 /// independent way (Note: the return type is an i64).
1121 static Constant *getAlignOf(Type *Ty);
1122
1123 /// getSizeOf constant expr - computes the (alloc) size of a type (in
1124 /// address-units, not bits) in a target independent way (Note: the return
1125 /// type is an i64).
1126 ///
1127 static Constant *getSizeOf(Type *Ty);
1128
1129 static Constant *getNeg(Constant *C, bool HasNSW = false);
1130 static Constant *getNot(Constant *C);
1131 static Constant *getAdd(Constant *C1, Constant *C2, bool HasNUW = false,
1132 bool HasNSW = false);
1133 static Constant *getSub(Constant *C1, Constant *C2, bool HasNUW = false,
1134 bool HasNSW = false);
1135 static Constant *getMul(Constant *C1, Constant *C2, bool HasNUW = false,
1136 bool HasNSW = false);
1137 static Constant *getXor(Constant *C1, Constant *C2);
1138 static Constant *getTrunc(Constant *C, Type *Ty, bool OnlyIfReduced = false);
1139 static Constant *getPtrToInt(Constant *C, Type *Ty,
1140 bool OnlyIfReduced = false);
1141 static Constant *getIntToPtr(Constant *C, Type *Ty,
1142 bool OnlyIfReduced = false);
1143 static Constant *getBitCast(Constant *C, Type *Ty,
1144 bool OnlyIfReduced = false);
1145 static Constant *getAddrSpaceCast(Constant *C, Type *Ty,
1146 bool OnlyIfReduced = false);
1147
1148 static Constant *getNSWNeg(Constant *C) { return getNeg(C, /*HasNSW=*/true); }
1149
1151 return getAdd(C1, C2, false, true);
1152 }
1153
1155 return getAdd(C1, C2, true, false);
1156 }
1157
1159 return getSub(C1, C2, false, true);
1160 }
1161
1163 return getSub(C1, C2, true, false);
1164 }
1165
1167 return getMul(C1, C2, false, true);
1168 }
1169
1171 return getMul(C1, C2, true, false);
1172 }
1173
1174 /// If C is a scalar/fixed width vector of known powers of 2, then this
1175 /// function returns a new scalar/fixed width vector obtained from logBase2
1176 /// of C. Undef vector elements are set to zero.
1177 /// Return a null pointer otherwise.
1178 static Constant *getExactLogBase2(Constant *C);
1179
1180 /// Return the identity constant for a binary opcode.
1181 /// If the binop is not commutative, callers can acquire the operand 1
1182 /// identity constant by setting AllowRHSConstant to true. For example, any
1183 /// shift has a zero identity constant for operand 1: X shift 0 = X. If this
1184 /// is a fadd/fsub operation and we don't care about signed zeros, then
1185 /// setting NSZ to true returns the identity +0.0 instead of -0.0. Return
1186 /// nullptr if the operator does not have an identity constant.
1187 static Constant *getBinOpIdentity(unsigned Opcode, Type *Ty,
1188 bool AllowRHSConstant = false,
1189 bool NSZ = false);
1190
1191 static Constant *getIntrinsicIdentity(Intrinsic::ID, Type *Ty);
1192
1193 /// Return the identity constant for a binary or intrinsic Instruction.
1194 /// The identity constant C is defined as X op C = X and C op X = X where C
1195 /// and X are the first two operands, and the operation is commutative.
1196 static Constant *getIdentity(Instruction *I, Type *Ty,
1197 bool AllowRHSConstant = false, bool NSZ = false);
1198
1199 /// Return the absorbing element for the given binary
1200 /// operation, i.e. a constant C such that X op C = C and C op X = C for
1201 /// every X. For example, this returns zero for integer multiplication.
1202 /// It returns null if the operator doesn't have an absorbing element.
1203 static Constant *getBinOpAbsorber(unsigned Opcode, Type *Ty);
1204
1205 /// Transparently provide more efficient getOperand methods.
1207
1208 /// Convenience function for getting a Cast operation.
1209 ///
1210 /// \param ops The opcode for the conversion
1211 /// \param C The constant to be converted
1212 /// \param Ty The type to which the constant is converted
1213 /// \param OnlyIfReduced see \a getWithOperands() docs.
1214 static Constant *getCast(unsigned ops, Constant *C, Type *Ty,
1215 bool OnlyIfReduced = false);
1216
1217 // Create a Trunc or BitCast cast constant expression
1218 static Constant *
1219 getTruncOrBitCast(Constant *C, ///< The constant to trunc or bitcast
1220 Type *Ty ///< The type to trunc or bitcast C to
1221 );
1222
1223 /// Create a BitCast, AddrSpaceCast, or a PtrToInt cast constant
1224 /// expression.
1225 static Constant *
1226 getPointerCast(Constant *C, ///< The pointer value to be casted (operand 0)
1227 Type *Ty ///< The type to which cast should be made
1228 );
1229
1230 /// Create a BitCast or AddrSpaceCast for a pointer type depending on
1231 /// the address space.
1232 static Constant *getPointerBitCastOrAddrSpaceCast(
1233 Constant *C, ///< The constant to addrspacecast or bitcast
1234 Type *Ty ///< The type to bitcast or addrspacecast C to
1235 );
1236
1237 /// Return true if this is a convert constant expression
1238 bool isCast() const;
1239
1240 /// get - Return a binary or shift operator constant expression,
1241 /// folding if possible.
1242 ///
1243 /// \param OnlyIfReducedTy see \a getWithOperands() docs.
1244 static Constant *get(unsigned Opcode, Constant *C1, Constant *C2,
1245 unsigned Flags = 0, Type *OnlyIfReducedTy = nullptr);
1246
1247 /// Getelementptr form. Value* is only accepted for convenience;
1248 /// all elements must be Constants.
1249 ///
1250 /// \param InRange the inrange range if present or std::nullopt.
1251 /// \param OnlyIfReducedTy see \a getWithOperands() docs.
1252 static Constant *
1255 std::optional<ConstantRange> InRange = std::nullopt,
1256 Type *OnlyIfReducedTy = nullptr) {
1257 return getGetElementPtr(
1258 Ty, C, ArrayRef((Value *const *)IdxList.data(), IdxList.size()), NW,
1259 InRange, OnlyIfReducedTy);
1260 }
1261 static Constant *
1264 std::optional<ConstantRange> InRange = std::nullopt,
1265 Type *OnlyIfReducedTy = nullptr) {
1266 // This form of the function only exists to avoid ambiguous overload
1267 // warnings about whether to convert Idx to ArrayRef<Constant *> or
1268 // ArrayRef<Value *>.
1269 return getGetElementPtr(Ty, C, cast<Value>(Idx), NW, InRange,
1270 OnlyIfReducedTy);
1271 }
1272 static Constant *
1273 getGetElementPtr(Type *Ty, Constant *C, ArrayRef<Value *> IdxList,
1275 std::optional<ConstantRange> InRange = std::nullopt,
1276 Type *OnlyIfReducedTy = nullptr);
1277
1278 /// Create an "inbounds" getelementptr. See the documentation for the
1279 /// "inbounds" flag in LangRef.html for details.
1281 ArrayRef<Constant *> IdxList) {
1282 return getGetElementPtr(Ty, C, IdxList, GEPNoWrapFlags::inBounds());
1283 }
1285 Constant *Idx) {
1286 // This form of the function only exists to avoid ambiguous overload
1287 // warnings about whether to convert Idx to ArrayRef<Constant *> or
1288 // ArrayRef<Value *>.
1289 return getGetElementPtr(Ty, C, Idx, GEPNoWrapFlags::inBounds());
1290 }
1292 ArrayRef<Value *> IdxList) {
1293 return getGetElementPtr(Ty, C, IdxList, GEPNoWrapFlags::inBounds());
1294 }
1295
1296 static Constant *getExtractElement(Constant *Vec, Constant *Idx,
1297 Type *OnlyIfReducedTy = nullptr);
1298 static Constant *getInsertElement(Constant *Vec, Constant *Elt, Constant *Idx,
1299 Type *OnlyIfReducedTy = nullptr);
1300 static Constant *getShuffleVector(Constant *V1, Constant *V2,
1301 ArrayRef<int> Mask,
1302 Type *OnlyIfReducedTy = nullptr);
1303
1304 /// Return the opcode at the root of this constant expression
1305 unsigned getOpcode() const { return getSubclassDataFromValue(); }
1306
1307 /// Assert that this is a shufflevector and return the mask. See class
1308 /// ShuffleVectorInst for a description of the mask representation.
1309 ArrayRef<int> getShuffleMask() const;
1310
1311 /// Assert that this is a shufflevector and return the mask.
1312 ///
1313 /// TODO: This is a temporary hack until we update the bitcode format for
1314 /// shufflevector.
1315 Constant *getShuffleMaskForBitcode() const;
1316
1317 /// Return a string representation for an opcode.
1318 const char *getOpcodeName() const;
1319
1320 /// This returns the current constant expression with the operands replaced
1321 /// with the specified values. The specified array must have the same number
1322 /// of operands as our current one.
1324 return getWithOperands(Ops, getType());
1325 }
1326
1327 /// Get the current expression with the operands replaced.
1328 ///
1329 /// Return the current constant expression with the operands replaced with \c
1330 /// Ops and the type with \c Ty. The new operands must have the same number
1331 /// as the current ones.
1332 ///
1333 /// If \c OnlyIfReduced is \c true, nullptr will be returned unless something
1334 /// gets constant-folded, the type changes, or the expression is otherwise
1335 /// canonicalized. This parameter should almost always be \c false.
1336 Constant *getWithOperands(ArrayRef<Constant *> Ops, Type *Ty,
1337 bool OnlyIfReduced = false,
1338 Type *SrcTy = nullptr) const;
1339
1340 /// Returns an Instruction which implements the same operation as this
1341 /// ConstantExpr. It is not inserted into any basic block.
1342 ///
1343 /// A better approach to this could be to have a constructor for Instruction
1344 /// which would take a ConstantExpr parameter, but that would have spread
1345 /// implementation details of ConstantExpr outside of Constants.cpp, which
1346 /// would make it harder to remove ConstantExprs altogether.
1347 Instruction *getAsInstruction() const;
1348
1349 /// Whether creating a constant expression for this binary operator is
1350 /// desirable.
1351 static bool isDesirableBinOp(unsigned Opcode);
1352
1353 /// Whether creating a constant expression for this binary operator is
1354 /// supported.
1355 static bool isSupportedBinOp(unsigned Opcode);
1356
1357 /// Whether creating a constant expression for this cast is desirable.
1358 static bool isDesirableCastOp(unsigned Opcode);
1359
1360 /// Whether creating a constant expression for this cast is supported.
1361 static bool isSupportedCastOp(unsigned Opcode);
1362
1363 /// Whether creating a constant expression for this getelementptr type is
1364 /// supported.
1365 static bool isSupportedGetElementPtr(const Type *SrcElemTy) {
1366 return !SrcElemTy->isScalableTy();
1367 }
1368
1369 /// Methods for support type inquiry through isa, cast, and dyn_cast:
1370 static bool classof(const Value *V) {
1371 return V->getValueID() == ConstantExprVal;
1372 }
1373
1374private:
1375 // Shadow Value::setValueSubclassData with a private forwarding method so that
1376 // subclasses cannot accidentally use it.
1377 void setValueSubclassData(unsigned short D) {
1379 }
1380};
1381
1382template <>
1384 : public VariadicOperandTraits<ConstantExpr, 1> {};
1385
1387
1388//===----------------------------------------------------------------------===//
1389/// 'undef' values are things that do not have specified contents.
1390/// These are used for a variety of purposes, including global variable
1391/// initializers and operands to instructions. 'undef' values can occur with
1392/// any first-class type.
1393///
1394/// Undef values aren't exactly constants; if they have multiple uses, they
1395/// can appear to have different bit patterns at each use. See
1396/// LangRef.html#undefvalues for details.
1397///
1398class UndefValue : public ConstantData {
1399 friend class Constant;
1400
1401 explicit UndefValue(Type *T) : ConstantData(T, UndefValueVal) {}
1402
1403 void destroyConstantImpl();
1404
1405protected:
1406 explicit UndefValue(Type *T, ValueTy vty) : ConstantData(T, vty) {}
1407
1408public:
1409 UndefValue(const UndefValue &) = delete;
1410
1411 /// Static factory methods - Return an 'undef' object of the specified type.
1412 static UndefValue *get(Type *T);
1413
1414 /// If this Undef has array or vector type, return a undef with the right
1415 /// element type.
1416 UndefValue *getSequentialElement() const;
1417
1418 /// If this undef has struct type, return a undef with the right element type
1419 /// for the specified element.
1420 UndefValue *getStructElement(unsigned Elt) const;
1421
1422 /// Return an undef of the right value for the specified GEP index if we can,
1423 /// otherwise return null (e.g. if C is a ConstantExpr).
1424 UndefValue *getElementValue(Constant *C) const;
1425
1426 /// Return an undef of the right value for the specified GEP index.
1427 UndefValue *getElementValue(unsigned Idx) const;
1428
1429 /// Return the number of elements in the array, vector, or struct.
1430 unsigned getNumElements() const;
1431
1432 /// Methods for support type inquiry through isa, cast, and dyn_cast:
1433 static bool classof(const Value *V) {
1434 return V->getValueID() == UndefValueVal ||
1435 V->getValueID() == PoisonValueVal;
1436 }
1437};
1438
1439//===----------------------------------------------------------------------===//
1440/// In order to facilitate speculative execution, many instructions do not
1441/// invoke immediate undefined behavior when provided with illegal operands,
1442/// and return a poison value instead.
1443///
1444/// see LangRef.html#poisonvalues for details.
1445///
1446class PoisonValue final : public UndefValue {
1447 friend class Constant;
1448
1449 explicit PoisonValue(Type *T) : UndefValue(T, PoisonValueVal) {}
1450
1451 void destroyConstantImpl();
1452
1453public:
1454 PoisonValue(const PoisonValue &) = delete;
1455
1456 /// Static factory methods - Return an 'poison' object of the specified type.
1457 static PoisonValue *get(Type *T);
1458
1459 /// If this poison has array or vector type, return a poison with the right
1460 /// element type.
1462
1463 /// If this poison has struct type, return a poison with the right element
1464 /// type for the specified element.
1465 PoisonValue *getStructElement(unsigned Elt) const;
1466
1467 /// Return an poison of the right value for the specified GEP index if we can,
1468 /// otherwise return null (e.g. if C is a ConstantExpr).
1470
1471 /// Return an poison of the right value for the specified GEP index.
1472 PoisonValue *getElementValue(unsigned Idx) const;
1473
1474 /// Methods for support type inquiry through isa, cast, and dyn_cast:
1475 static bool classof(const Value *V) {
1476 return V->getValueID() == PoisonValueVal;
1477 }
1478};
1479
1480} // end namespace llvm
1481
1482#endif // LLVM_IR_CONSTANTS_H
This file declares a class to represent arbitrary precision floating point values and provide a varie...
This file implements a class to represent arbitrary precision integral constant values and operations...
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
BlockVerifier::State From
static GCRegistry::Add< StatepointGC > D("statepoint-example", "an example strategy for statepoint")
static StringRef getOpcodeName(uint8_t Opcode, uint8_t OpcodeBase)
Returns the sub type a function will return at a given Idx Should correspond to the result type of an ExtractValue instruction executed with just that one unsigned Idx
Looks at all the uses of the given value Returns the Liveness deduced from the uses of this value Adds all uses that cause the result to be MaybeLive to MaybeLiveRetUses If the result is MaybeLiveUses might be modified but its content should be ignored(since it might not be complete). DeadArgumentEliminationPass
Given that RA is a live value
#define F(x, y, z)
Definition: MD5.cpp:55
#define I(x, y, z)
Definition: MD5.cpp:58
static bool InRange(int64_t Value, unsigned short Shift, int LBound, int HBound)
#define DEFINE_TRANSPARENT_OPERAND_ACCESSORS(CLASS, VALUECLASS)
Macro for generating out-of-class operand accessor definitions.
assert(ImpDefSCC.getReg()==AMDGPU::SCC &&ImpDefSCC.isDef())
static unsigned getNumElements(Type *Ty)
This file contains some templates that are useful if you are working with the STL at all.
static SymbolRef::Type getType(const Symbol *Sym)
Definition: TapiFile.cpp:40
xray Insert XRay ops
opStatus convert(const fltSemantics &ToSemantics, roundingMode RM, bool *losesInfo)
Definition: APFloat.cpp:5337
bool isNegative() const
Definition: APFloat.h:1360
const fltSemantics & getSemantics() const
Definition: APFloat.h:1368
bool isNaN() const
Definition: APFloat.h:1358
bool isZero() const
Definition: APFloat.h:1356
bool isInfinity() const
Definition: APFloat.h:1357
Class for arbitrary precision integers.
Definition: APInt.h:78
bool isMinSignedValue() const
Determine if this is the smallest signed value.
Definition: APInt.h:403
uint64_t getZExtValue() const
Get zero extended value.
Definition: APInt.h:1500
bool isAllOnes() const
Determine if all bits are set. This is true for zero-width values.
Definition: APInt.h:351
bool isZero() const
Determine if this value is zero, i.e. all bits are clear.
Definition: APInt.h:360
unsigned getBitWidth() const
Return the number of bits in the APInt.
Definition: APInt.h:1448
bool isMinValue() const
Determine if this is the smallest unsigned value.
Definition: APInt.h:397
bool isNegative() const
Determine sign of this APInt.
Definition: APInt.h:309
uint64_t getLimitedValue(uint64_t Limit=UINT64_MAX) const
If this value is smaller than the specified limit, return it, otherwise return the limit value.
Definition: APInt.h:455
bool isMaxSignedValue() const
Determine if this is the largest signed value.
Definition: APInt.h:385
bool isOne() const
Determine if this is a value of 1.
Definition: APInt.h:369
int64_t getSExtValue() const
Get sign extended value.
Definition: APInt.h:1522
bool uge(const APInt &RHS) const
Unsigned greater or equal comparison.
Definition: APInt.h:1201
bool isMaxValue() const
Determine if this is the largest unsigned value.
Definition: APInt.h:379
ArrayRef - Represent a constant reference to an array (0 or more elements consecutively in memory),...
Definition: ArrayRef.h:41
size_t size() const
size - Get the array size.
Definition: ArrayRef.h:165
const T * data() const
Definition: ArrayRef.h:162
Class to represent array types.
Definition: DerivedTypes.h:371
static ArrayType * get(Type *ElementType, uint64_t NumElements)
This static method is the primary way to construct an ArrayType.
Definition: Type.cpp:635
LLVM Basic Block Representation.
Definition: BasicBlock.h:61
The address of a basic block.
Definition: Constants.h:890
DECLARE_TRANSPARENT_OPERAND_ACCESSORS(Value)
Transparently provide more efficient getOperand methods.
static BlockAddress * lookup(const BasicBlock *BB)
Lookup an existing BlockAddress constant for the given BasicBlock.
Definition: Constants.cpp:1889
static bool classof(const Value *V)
Methods for support type inquiry through isa, cast, and dyn_cast:
Definition: Constants.h:922
Function * getFunction() const
Definition: Constants.h:918
BasicBlock * getBasicBlock() const
Definition: Constants.h:919
static BlockAddress * get(Function *F, BasicBlock *BB)
Return a BlockAddress for the specified function and basic block.
Definition: Constants.cpp:1871
All zero aggregate value.
Definition: Constants.h:351
ElementCount getElementCount() const
Return the number of elements in the array, vector, or struct.
Definition: Constants.cpp:1135
ConstantAggregateZero(const ConstantAggregateZero &)=delete
static bool classof(const Value *V)
Methods for support type inquiry through isa, cast, and dyn_cast:
Definition: Constants.h:384
Constant * getSequentialElement() const
If this CAZ has array or vector type, return a zero with the right element type.
Definition: Constants.cpp:1113
Constant * getElementValue(Constant *C) const
Return a zero of the right value for the specified GEP index if we can, otherwise return null (e....
Definition: Constants.cpp:1123
Constant * getStructElement(unsigned Elt) const
If this CAZ has struct type, return a zero with the right element type for the specified element.
Definition: Constants.cpp:1119
static ConstantAggregateZero * get(Type *Ty)
Definition: Constants.cpp:1650
Base class for aggregate constants (with operands).
Definition: Constants.h:400
DECLARE_TRANSPARENT_OPERAND_ACCESSORS(Constant)
Transparently provide more efficient getOperand methods.
static bool classof(const Value *V)
Methods for support type inquiry through isa, cast, and dyn_cast:
Definition: Constants.h:409
ConstantArray - Constant Array Declarations.
Definition: Constants.h:424
static bool classof(const Value *V)
Methods for support type inquiry through isa, cast, and dyn_cast:
Definition: Constants.h:448
ArrayType * getType() const
Specialize the getType() method to always return an ArrayType, which reduces the amount of casting ne...
Definition: Constants.h:443
An array constant whose element type is a simple 1/2/4/8-byte integer or float/double,...
Definition: Constants.h:693
static bool classof(const Value *V)
Methods for support type inquiry through isa, cast, and dyn_cast:
Definition: Constants.h:756
static Constant * getString(LLVMContext &Context, StringRef Initializer, bool AddNull=true)
This method constructs a CDS and initializes it with a text string.
Definition: Constants.cpp:2950
static Constant * get(LLVMContext &Context, ArrayRef< ElementTy > Elts)
get() constructor - Return a constant with array type with an element count and element type matching...
Definition: Constants.h:706
static Constant * getFP(Type *ElementType, ArrayRef< uint16_t > Elts)
getFP() constructors - Return a constant of array type with a float element type taken from argument ...
Definition: Constants.cpp:2929
static Constant * get(LLVMContext &Context, ArrayTy &Elts)
get() constructor - ArrayTy needs to be compatible with ArrayRef<ElementTy>.
Definition: Constants.h:715
ConstantDataArray(const ConstantDataArray &)=delete
static Constant * getRaw(StringRef Data, uint64_t NumElements, Type *ElementTy)
getRaw() constructor - Return a constant with array type with an element count and element type match...
Definition: Constants.h:725
ArrayType * getType() const
Specialize the getType() method to always return an ArrayType, which reduces the amount of casting ne...
Definition: Constants.h:751
ConstantDataSequential - A vector or array constant whose element type is a simple 1/2/4/8-byte integ...
Definition: Constants.h:584
APInt getElementAsAPInt(unsigned i) const
If this is a sequential container of integers (of any size), return the specified element as an APInt...
Definition: Constants.cpp:3094
double getElementAsDouble(unsigned i) const
If this is an sequential container of doubles, return the specified element as a double.
Definition: Constants.cpp:3153
StringRef getAsString() const
If this array is isString(), then this method returns the array as a StringRef.
Definition: Constants.h:659
uint64_t getElementByteSize() const
Return the size (in bytes) of each element in the array/vector.
Definition: Constants.cpp:2824
ConstantDataSequential(const ConstantDataSequential &)=delete
float getElementAsFloat(unsigned i) const
If this is an sequential container of floats, return the specified element as a float.
Definition: Constants.cpp:3147
bool isString(unsigned CharSize=8) const
This method returns true if this is an array of CharSize integers.
Definition: Constants.cpp:3167
StringRef getAsCString() const
If this array is isCString(), then this method returns the array (without the trailing null byte) as ...
Definition: Constants.h:666
uint64_t getElementAsInteger(unsigned i) const
If this is a sequential container of integers (of any size), return the specified element in the low ...
Definition: Constants.cpp:3074
static Constant * getImpl(StringRef Bytes, Type *Ty)
This is the underlying implementation of all of the ConstantDataSequential::get methods.
Definition: Constants.cpp:2847
unsigned getNumElements() const
Return the number of elements in the array or vector.
Definition: Constants.cpp:2817
Constant * getElementAsConstant(unsigned i) const
Return a Constant for a specified index's element.
Definition: Constants.cpp:3159
Type * getElementType() const
Return the element type of the array/vector.
Definition: Constants.cpp:2791
bool isCString() const
This method returns true if the array "isString", ends with a null byte, and does not contains any ot...
Definition: Constants.cpp:3171
APFloat getElementAsAPFloat(unsigned i) const
If this is a sequential container of floating point type, return the specified element as an APFloat.
Definition: Constants.cpp:3122
static bool classof(const Value *V)
Methods for support type inquiry through isa, cast, and dyn_cast:
Definition: Constants.h:678
StringRef getRawDataValues() const
Return the raw, underlying, bytes of this data.
Definition: Constants.cpp:2797
static bool isElementTypeCompatible(Type *Ty)
Return true if a ConstantDataSequential can be formed with a vector or array of the specified element...
Definition: Constants.cpp:2801
ConstantDataSequential(Type *ty, ValueTy VT, const char *Data)
Definition: Constants.h:601
A vector constant whose element type is a simple 1/2/4/8-byte integer or float/double,...
Definition: Constants.h:767
static Constant * getRaw(StringRef Data, uint64_t NumElements, Type *ElementTy)
getRaw() constructor - Return a constant with vector type with an element count and element type matc...
Definition: Constants.h:797
Constant * getSplatValue() const
If this is a splat constant, meaning that all of the elements have the same value,...
Definition: Constants.cpp:3204
static Constant * getSplat(unsigned NumElts, Constant *Elt)
Return a ConstantVector with the specified constant in each element.
Definition: Constants.cpp:3027
static bool classof(const Value *V)
Methods for support type inquiry through isa, cast, and dyn_cast:
Definition: Constants.h:833
bool isSplat() const
Returns true if this is a splat constant, meaning that all elements have the same value.
Definition: Constants.cpp:3196
FixedVectorType * getType() const
Specialize the getType() method to always return a FixedVectorType, which reduces the amount of casti...
Definition: Constants.h:828
ConstantDataVector(const ConstantDataVector &)=delete
static Constant * get(LLVMContext &Context, ArrayRef< uint8_t > Elts)
get() constructors - Return a constant with vector type with an element count and element type matchi...
Definition: Constants.cpp:2966
static Constant * getFP(Type *ElementType, ArrayRef< uint16_t > Elts)
getFP() constructors - Return a constant of vector type with a float element type taken from argument...
Definition: Constants.cpp:3003
Base class for constants with no operands.
Definition: Constants.h:53
static bool classof(const Value *V)
Methods to support type inquiry through isa, cast, and dyn_cast.
Definition: Constants.h:71
ConstantData(const ConstantData &)=delete
ConstantData(Type *Ty, ValueTy VT)
Definition: Constants.h:61
A constant value that is initialized with an expression using other constant values.
Definition: Constants.h:1097
static bool classof(const Value *V)
Methods for support type inquiry through isa, cast, and dyn_cast:
Definition: Constants.h:1370
static Constant * getNUWSub(Constant *C1, Constant *C2)
Definition: Constants.h:1162
static Constant * getInBoundsGetElementPtr(Type *Ty, Constant *C, ArrayRef< Constant * > IdxList)
Create an "inbounds" getelementptr.
Definition: Constants.h:1280
static Constant * getNSWAdd(Constant *C1, Constant *C2)
Definition: Constants.h:1150
DECLARE_TRANSPARENT_OPERAND_ACCESSORS(Constant)
Transparently provide more efficient getOperand methods.
ConstantExpr(Type *ty, unsigned Opcode, Use *Ops, unsigned NumOps)
Definition: Constants.h:1105
static bool isSupportedGetElementPtr(const Type *SrcElemTy)
Whether creating a constant expression for this getelementptr type is supported.
Definition: Constants.h:1365
static Constant * getGetElementPtr(Type *Ty, Constant *C, Constant *Idx, GEPNoWrapFlags NW=GEPNoWrapFlags::none(), std::optional< ConstantRange > InRange=std::nullopt, Type *OnlyIfReducedTy=nullptr)
Definition: Constants.h:1262
static Constant * getInBoundsGetElementPtr(Type *Ty, Constant *C, ArrayRef< Value * > IdxList)
Definition: Constants.h:1291
static Constant * getNSWNeg(Constant *C)
Definition: Constants.h:1148
static Constant * getNSWSub(Constant *C1, Constant *C2)
Definition: Constants.h:1158
static Constant * getInBoundsGetElementPtr(Type *Ty, Constant *C, Constant *Idx)
Definition: Constants.h:1284
static Constant * getNUWAdd(Constant *C1, Constant *C2)
Definition: Constants.h:1154
~ConstantExpr()=default
unsigned getOpcode() const
Return the opcode at the root of this constant expression.
Definition: Constants.h:1305
static Constant * getGetElementPtr(Type *Ty, Constant *C, ArrayRef< Constant * > IdxList, GEPNoWrapFlags NW=GEPNoWrapFlags::none(), std::optional< ConstantRange > InRange=std::nullopt, Type *OnlyIfReducedTy=nullptr)
Getelementptr form.
Definition: Constants.h:1253
static Constant * getNSWMul(Constant *C1, Constant *C2)
Definition: Constants.h:1166
static Constant * getNUWMul(Constant *C1, Constant *C2)
Definition: Constants.h:1170
Constant * getWithOperands(ArrayRef< Constant * > Ops) const
This returns the current constant expression with the operands replaced with the specified values.
Definition: Constants.h:1323
ConstantFP - Floating Point Values [float, double].
Definition: Constants.h:269
ConstantFP(const ConstantFP &)=delete
const APFloat & getValue() const
Definition: Constants.h:313
static Constant * getSNaN(Type *Ty, bool Negative=false, APInt *Payload=nullptr)
Definition: Constants.cpp:1027
const APFloat & getValueAPF() const
Definition: Constants.h:312
static bool classof(const Value *V)
Methods for support type inquiry through isa, cast, and dyn_cast:
Definition: Constants.h:343
bool isInfinity() const
Return true if the value is infinity.
Definition: Constants.h:322
bool isNegative() const
Return true if the sign bit is set.
Definition: Constants.h:319
bool isExactlyValue(double V) const
Definition: Constants.h:335
static Constant * getInfinity(Type *Ty, bool Negative=false)
Definition: Constants.cpp:1084
static Constant * getZero(Type *Ty, bool Negative=false)
Definition: Constants.cpp:1038
static Constant * getNegativeZero(Type *Ty)
Definition: Constants.h:307
static Constant * getNaN(Type *Ty, bool Negative=false, uint64_t Payload=0)
Definition: Constants.cpp:1005
bool isNaN() const
Return true if the value is a NaN.
Definition: Constants.h:325
bool isExactlyValue(const APFloat &V) const
We don't rely on operator== working on double values, as it returns true for things that are clearly ...
Definition: Constants.cpp:1100
static bool isValueValidForType(Type *Ty, const APFloat &V)
Return true if Ty is big enough to represent V.
Definition: Constants.cpp:1589
static Constant * getQNaN(Type *Ty, bool Negative=false, APInt *Payload=nullptr)
Definition: Constants.cpp:1016
bool isZero() const
Return true if the value is positive or negative zero.
Definition: Constants.h:316
This is the shared class of boolean and integer constants.
Definition: Constants.h:81
static Constant * getSigned(Type *Ty, int64_t V)
Definition: Constants.h:127
bool isMinusOne() const
This function will return true iff every bit in this constant is set to true.
Definition: Constants.h:218
bool isOne() const
This is just a convenience method to make client code smaller for a common case.
Definition: Constants.h:212
bool isNegative() const
Definition: Constants.h:201
uint64_t getLimitedValue(uint64_t Limit=~0ULL) const
getLimitedValue - If the value is smaller than the specified limit, return it, otherwise return the l...
Definition: Constants.h:256
IntegerType * getIntegerType() const
Variant of the getType() method to always return an IntegerType, which reduces the amount of casting ...
Definition: Constants.h:185
static bool isValueValidForType(Type *Ty, uint64_t V)
This static method returns true if the type Ty is big enough to represent the value V.
Definition: Constants.cpp:1575
static bool classof(const Value *V)
Methods to support type inquiry through isa, cast, and dyn_cast.
Definition: Constants.h:261
static ConstantInt * getTrue(LLVMContext &Context)
Definition: Constants.cpp:850
ConstantInt(const ConstantInt &)=delete
bool isZero() const
This is just a convenience method to make client code smaller for a common code.
Definition: Constants.h:206
MaybeAlign getMaybeAlignValue() const
Return the constant as an llvm::MaybeAlign.
Definition: Constants.h:166
static ConstantInt * getSigned(IntegerType *Ty, int64_t V)
Return a ConstantInt with the specified value for the specified type.
Definition: Constants.h:124
bool isMinValue(bool IsSigned) const
This function will return true iff this constant represents the smallest value that may be represente...
Definition: Constants.h:237
static ConstantInt * getFalse(LLVMContext &Context)
Definition: Constants.cpp:857
int64_t getSExtValue() const
Return the constant as a 64-bit integer value after it has been sign extended as appropriate for the ...
Definition: Constants.h:161
bool isMaxValue(bool IsSigned) const
This function will return true iff this constant represents the largest value that may be represented...
Definition: Constants.h:225
unsigned getBitWidth() const
getBitWidth - Return the scalar bitwidth of this constant.
Definition: Constants.h:149
uint64_t getZExtValue() const
Return the constant as a 64-bit unsigned integer value after it has been zero extended as appropriate...
Definition: Constants.h:155
Align getAlignValue() const
Return the constant as an llvm::Align, interpreting 0 as Align(1).
Definition: Constants.h:173
bool equalsInt(uint64_t V) const
A helper method that can be used to determine if the constant contained within is equal to a constant...
Definition: Constants.h:181
const APInt & getValue() const
Return the constant as an APInt value reference.
Definition: Constants.h:146
bool uge(uint64_t Num) const
This function will return true iff this constant represents a value with active bits bigger than 64 b...
Definition: Constants.h:249
static ConstantInt * getBool(LLVMContext &Context, bool V)
Definition: Constants.cpp:864
A constant pointer value that points to null.
Definition: Constants.h:549
static bool classof(const Value *V)
Methods for support type inquiry through isa, cast, and dyn_cast:
Definition: Constants.h:570
static ConstantPointerNull * get(PointerType *T)
Static factory methods - Return objects of the specified value.
Definition: Constants.cpp:1800
PointerType * getType() const
Specialize the getType() method to always return an PointerType, which reduces the amount of casting ...
Definition: Constants.h:565
ConstantPointerNull(const ConstantPointerNull &)=delete
A signed pointer, in the ptrauth sense.
Definition: Constants.h:1012
Constant * getAddrDiscriminator() const
The address discriminator if any, or the null constant.
Definition: Constants.h:1050
DECLARE_TRANSPARENT_OPERAND_ACCESSORS(Constant)
Transparently provide more efficient getOperand methods.
Constant * getPointer() const
The pointer that is signed in this ptrauth signed pointer.
Definition: Constants.h:1037
ConstantInt * getKey() const
The Key ID, an i32 constant.
Definition: Constants.h:1040
bool hasAddressDiscriminator() const
Whether there is any non-null address discriminator.
Definition: Constants.h:1055
ConstantInt * getDiscriminator() const
The integer discriminator, an i64 constant, or 0.
Definition: Constants.h:1043
static bool classof(const Value *V)
Methods for support type inquiry through isa, cast, and dyn_cast:
Definition: Constants.h:1079
static Constant * getAnon(LLVMContext &Ctx, ArrayRef< Constant * > V, bool Packed=false)
Definition: Constants.h:480
static bool classof(const Value *V)
Methods for support type inquiry through isa, cast, and dyn_cast:
Definition: Constants.h:500
static Constant * get(StructType *T, ArrayRef< Constant * > V)
Definition: Constants.cpp:1357
friend class Constant
Definition: Constants.h:458
static StructType * getTypeForElements(ArrayRef< Constant * > V, bool Packed=false)
Return an anonymous struct type to use for a constant with the specified set of elements.
Definition: Constants.cpp:1343
static std::enable_if_t< are_base_of< Constant, Csts... >::value, Constant * > get(StructType *T, Csts *...Vs)
Definition: Constants.h:471
StructType * getType() const
Specialization - reduce amount of casting.
Definition: Constants.h:495
static Constant * getAnon(ArrayRef< Constant * > V, bool Packed=false)
Return an anonymous struct that has the specified elements.
Definition: Constants.h:477
A constant target extension type default initializer.
Definition: Constants.h:862
static ConstantTargetNone * get(TargetExtType *T)
Static factory methods - Return objects of the specified value.
Definition: Constants.cpp:1817
TargetExtType * getType() const
Specialize the getType() method to always return an TargetExtType, which reduces the amount of castin...
Definition: Constants.h:878
static bool classof(const Value *V)
Methods for support type inquiry through isa, cast, and dyn_cast.
Definition: Constants.h:883
ConstantTargetNone(const ConstantTargetNone &)=delete
A constant token which is empty.
Definition: Constants.h:841
ConstantTokenNone(const ConstantTokenNone &)=delete
static ConstantTokenNone * get(LLVMContext &Context)
Return the ConstantTokenNone.
Definition: Constants.cpp:1500
static bool classof(const Value *V)
Methods to support type inquiry through isa, cast, and dyn_cast.
Definition: Constants.h:856
Constant Vector Declarations.
Definition: Constants.h:508
static bool classof(const Value *V)
Methods for support type inquiry through isa, cast, and dyn_cast:
Definition: Constants.h:541
FixedVectorType * getType() const
Specialize the getType() method to always return a FixedVectorType, which reduces the amount of casti...
Definition: Constants.h:531
Constant * getSplatValue(bool AllowPoison=false) const
If all elements of the vector constant have the same value, return that value.
Definition: Constants.cpp:1718
static Constant * getSplat(ElementCount EC, Constant *Elt)
Return a ConstantVector with the specified constant in each element.
Definition: Constants.cpp:1450
static Constant * get(ArrayRef< Constant * > V)
Definition: Constants.cpp:1399
This is an important base class in LLVM.
Definition: Constant.h:42
Wrapper for a function that represents a value that functionally represents the original function.
Definition: Constants.h:936
static bool classof(const Value *V)
Methods for support type inquiry through isa, cast, and dyn_cast:
Definition: Constants.h:960
GlobalValue * getGlobalValue() const
Definition: Constants.h:955
DECLARE_TRANSPARENT_OPERAND_ACCESSORS(Value)
Transparently provide more efficient getOperand methods.
This class represents an Operation in the Expression.
A parsed version of the target data layout string in and methods for querying it.
Definition: DataLayout.h:110
static constexpr ElementCount getFixed(ScalarTy MinVal)
Definition: TypeSize.h:311
Class to represent fixed width SIMD vectors.
Definition: DerivedTypes.h:539
Represents flags for the getelementptr instruction/expression.
static GEPNoWrapFlags inBounds()
static GEPNoWrapFlags none()
Class to represent integer types.
Definition: DerivedTypes.h:40
This is an important class for using LLVM in a threaded context.
Definition: LLVMContext.h:67
Wrapper for a value that won't be replaced with a CFI jump table pointer in LowerTypeTestsModule.
Definition: Constants.h:973
static bool classof(const Value *V)
Methods for support type inquiry through isa, cast, and dyn_cast:
Definition: Constants.h:1000
PointerType * getType() const
NoCFIValue is always a pointer.
Definition: Constants.h:995
DECLARE_TRANSPARENT_OPERAND_ACCESSORS(Value)
Transparently provide more efficient getOperand methods.
GlobalValue * getGlobalValue() const
Definition: Constants.h:990
Class to represent pointers.
Definition: DerivedTypes.h:646
In order to facilitate speculative execution, many instructions do not invoke immediate undefined beh...
Definition: Constants.h:1446
static PoisonValue * get(Type *T)
Static factory methods - Return an 'poison' object of the specified type.
Definition: Constants.cpp:1852
PoisonValue(const PoisonValue &)=delete
static bool classof(const Value *V)
Methods for support type inquiry through isa, cast, and dyn_cast:
Definition: Constants.h:1475
PoisonValue * getStructElement(unsigned Elt) const
If this poison has struct type, return a poison with the right element type for the specified element...
Definition: Constants.cpp:1189
PoisonValue * getSequentialElement() const
If this poison has array or vector type, return a poison with the right element type.
Definition: Constants.cpp:1183
PoisonValue * getElementValue(Constant *C) const
Return an poison of the right value for the specified GEP index if we can, otherwise return null (e....
Definition: Constants.cpp:1193
StringRef - Represent a constant reference to a string, i.e.
Definition: StringRef.h:50
Class to represent struct types.
Definition: DerivedTypes.h:216
Class to represent target extensions types, which are generally unintrospectable from target-independ...
Definition: DerivedTypes.h:720
The instances of the Type class are immutable: once they are created, they are never changed.
Definition: Type.h:45
bool isScalableTy() const
Return true if this is a type whose size is a known multiple of vscale.
'undef' values are things that do not have specified contents.
Definition: Constants.h:1398
UndefValue(const UndefValue &)=delete
static bool classof(const Value *V)
Methods for support type inquiry through isa, cast, and dyn_cast:
Definition: Constants.h:1433
UndefValue(Type *T, ValueTy vty)
Definition: Constants.h:1406
A Use represents the edge between a Value definition and its users.
Definition: Use.h:43
LLVM Value Representation.
Definition: Value.h:74
Type * getType() const
All values are typed, get the type of this value.
Definition: Value.h:255
void setValueSubclassData(unsigned short D)
Definition: Value.h:867
ValueTy
Concrete subclass of this.
Definition: Value.h:513
Base class of all SIMD vector types.
Definition: DerivedTypes.h:403
static VectorType * get(Type *ElementType, ElementCount EC)
This static method is the primary way to construct an VectorType.
Definition: Type.cpp:664
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
@ C
The default llvm calling convention, compatible with C.
Definition: CallingConv.h:34
This is an optimization pass for GlobalISel generic memory operations.
Definition: AddressRanges.h:18
std::conjunction< std::is_base_of< T, Ts >... > are_base_of
traits class for checking whether type T is a base class for all the given types in the variadic list...
Definition: STLExtras.h:134
decltype(auto) get(const PointerIntPair< PointerTy, IntBits, IntType, PtrTraits, Info > &Pair)
static constexpr roundingMode rmNearestTiesToEven
Definition: APFloat.h:254
This struct is a compact representation of a valid (non-zero power of two) alignment.
Definition: Alignment.h:39
FixedNumOperandTraits - determine the allocation regime of the Use array when it is a prefix to the U...
Definition: OperandTraits.h:30
This struct is a compact representation of a valid (power of two) or undefined (0) alignment.
Definition: Alignment.h:117
Align valueOrOne() const
For convenience, returns a valid alignment or 1 if undefined.
Definition: Alignment.h:141
Compile-time customization of User operands.
Definition: User.h:42
VariadicOperandTraits - determine the allocation regime of the Use array when it is a prefix to the U...
Definition: OperandTraits.h:68