LLVM 22.0.0git
Type.h
Go to the documentation of this file.
1//===- llvm/Type.h - Classes for handling data types ------------*- 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 the declaration of the Type class. For more "Type"
10// stuff, look in DerivedTypes.h.
11//
12//===----------------------------------------------------------------------===//
13
14#ifndef LLVM_IR_TYPE_H
15#define LLVM_IR_TYPE_H
16
17#include "llvm/ADT/ArrayRef.h"
23#include <cassert>
24#include <cstdint>
25#include <iterator>
26
27namespace llvm {
28
29class IntegerType;
30struct fltSemantics;
31class LLVMContext;
32class PointerType;
33class raw_ostream;
34class StringRef;
35template <typename PtrType> class SmallPtrSetImpl;
36
37/// The instances of the Type class are immutable: once they are created,
38/// they are never changed. Also note that only one instance of a particular
39/// type is ever created. Thus seeing if two types are equal is a matter of
40/// doing a trivial pointer comparison. To enforce that no two equal instances
41/// are created, Type instances can only be created via static factory methods
42/// in class Type and in derived classes. Once allocated, Types are never
43/// free'd.
44///
45class Type {
46public:
47 //===--------------------------------------------------------------------===//
48 /// Definitions of all of the base types for the Type system. Based on this
49 /// value, you can cast to a class defined in DerivedTypes.h.
50 /// Note: If you add an element to this, you need to add an element to the
51 /// Type::getPrimitiveType function, or else things will break!
52 /// Also update LLVMTypeKind and LLVMGetTypeKind () in the C binding.
53 ///
54 enum TypeID {
55 // PrimitiveTypes
56 HalfTyID = 0, ///< 16-bit floating point type
57 BFloatTyID, ///< 16-bit floating point type (7-bit significand)
58 FloatTyID, ///< 32-bit floating point type
59 DoubleTyID, ///< 64-bit floating point type
60 X86_FP80TyID, ///< 80-bit floating point type (X87)
61 FP128TyID, ///< 128-bit floating point type (112-bit significand)
62 PPC_FP128TyID, ///< 128-bit floating point type (two 64-bits, PowerPC)
63 VoidTyID, ///< type with no size
64 LabelTyID, ///< Labels
65 MetadataTyID, ///< Metadata
66 X86_AMXTyID, ///< AMX vectors (8192 bits, X86 specific)
67 TokenTyID, ///< Tokens
68
69 // Derived types... see DerivedTypes.h file.
70 IntegerTyID, ///< Arbitrary bit width integers
71 FunctionTyID, ///< Functions
72 PointerTyID, ///< Pointers
73 StructTyID, ///< Structures
74 ArrayTyID, ///< Arrays
75 FixedVectorTyID, ///< Fixed width SIMD vector type
76 ScalableVectorTyID, ///< Scalable SIMD vector type
77 TypedPointerTyID, ///< Typed pointer used by some GPU targets
78 TargetExtTyID, ///< Target extension type
79 };
80
81private:
82 /// This refers to the LLVMContext in which this type was uniqued.
83 LLVMContext &Context;
84
85 TypeID ID : 8; // The current base type of this type.
86 unsigned SubclassData : 24; // Space for subclasses to store data.
87 // Note that this should be synchronized with
88 // MAX_INT_BITS value in IntegerType class.
89
90protected:
91 friend class LLVMContextImpl;
92
93 explicit Type(LLVMContext &C, TypeID tid)
94 : Context(C), ID(tid), SubclassData(0) {}
95 ~Type() = default;
96
97 unsigned getSubclassData() const { return SubclassData; }
98
99 void setSubclassData(unsigned val) {
100 SubclassData = val;
101 // Ensure we don't have any accidental truncation.
102 assert(getSubclassData() == val && "Subclass data too large for field");
103 }
104
105 /// Keeps track of how many Type*'s there are in the ContainedTys list.
106 unsigned NumContainedTys = 0;
107
108 /// A pointer to the array of Types contained by this Type. For example, this
109 /// includes the arguments of a function type, the elements of a structure,
110 /// the pointee of a pointer, the element type of an array, etc. This pointer
111 /// may be 0 for types that don't contain other types (Integer, Double,
112 /// Float).
113 Type * const *ContainedTys = nullptr;
114
115public:
116 /// Print the current type.
117 /// Omit the type details if \p NoDetails == true.
118 /// E.g., let %st = type { i32, i16 }
119 /// When \p NoDetails is true, we only print %st.
120 /// Put differently, \p NoDetails prints the type as if
121 /// inlined with the operands when printing an instruction.
122 LLVM_ABI void print(raw_ostream &O, bool IsForDebug = false,
123 bool NoDetails = false) const;
124
125 LLVM_ABI void dump() const;
126
127 /// Return the LLVMContext in which this type was uniqued.
128 LLVMContext &getContext() const { return Context; }
129
130 //===--------------------------------------------------------------------===//
131 // Accessors for working with types.
132 //
133
134 /// Return the type id for the type. This will return one of the TypeID enum
135 /// elements defined above.
136 TypeID getTypeID() const { return ID; }
137
138 /// Return true if this is 'void'.
139 bool isVoidTy() const { return getTypeID() == VoidTyID; }
140
141 /// Return true if this is 'half', a 16-bit IEEE fp type.
142 bool isHalfTy() const { return getTypeID() == HalfTyID; }
143
144 /// Return true if this is 'bfloat', a 16-bit bfloat type.
145 bool isBFloatTy() const { return getTypeID() == BFloatTyID; }
146
147 /// Return true if this is a 16-bit float type.
148 bool is16bitFPTy() const {
149 return getTypeID() == BFloatTyID || getTypeID() == HalfTyID;
150 }
151
152 /// Return true if this is 'float', a 32-bit IEEE fp type.
153 bool isFloatTy() const { return getTypeID() == FloatTyID; }
154
155 /// Return true if this is 'double', a 64-bit IEEE fp type.
156 bool isDoubleTy() const { return getTypeID() == DoubleTyID; }
157
158 /// Return true if this is x86 long double.
159 bool isX86_FP80Ty() const { return getTypeID() == X86_FP80TyID; }
160
161 /// Return true if this is 'fp128'.
162 bool isFP128Ty() const { return getTypeID() == FP128TyID; }
163
164 /// Return true if this is powerpc long double.
165 bool isPPC_FP128Ty() const { return getTypeID() == PPC_FP128TyID; }
166
167 /// Return true if this is a well-behaved IEEE-like type, which has a IEEE
168 /// compatible layout, and does not have non-IEEE values, such as x86_fp80's
169 /// unnormal values.
170 bool isIEEELikeFPTy() const {
171 switch (getTypeID()) {
172 case DoubleTyID:
173 case FloatTyID:
174 case HalfTyID:
175 case BFloatTyID:
176 case FP128TyID:
177 return true;
178 default:
179 return false;
180 }
181 }
182
183 /// Return true if this is one of the floating-point types
184 bool isFloatingPointTy() const {
185 return isIEEELikeFPTy() || getTypeID() == X86_FP80TyID ||
187 }
188
189 /// Returns true if this is a floating-point type that is an unevaluated sum
190 /// of multiple floating-point units.
191 /// An example of such a type is ppc_fp128, also known as double-double, which
192 /// consists of two IEEE 754 doubles.
193 bool isMultiUnitFPType() const {
194 return getTypeID() == PPC_FP128TyID;
195 }
196
198
199 /// Return true if this is X86 AMX.
200 bool isX86_AMXTy() const { return getTypeID() == X86_AMXTyID; }
201
202 /// Return true if this is a target extension type.
203 bool isTargetExtTy() const { return getTypeID() == TargetExtTyID; }
204
205 /// Return true if this is a target extension type with a scalable layout.
207
208 /// Return true if this is a type whose size is a known multiple of vscale.
210 LLVM_ABI bool isScalableTy() const;
211
212 /// Return true if this type is or contains a target extension type that
213 /// disallows being used as a global.
214 LLVM_ABI bool
217
218 /// Return true if this type is or contains a target extension type that
219 /// disallows being used as a local.
220 LLVM_ABI bool
223
224 /// Return true if this is a FP type or a vector of FP.
226
227 /// Return true if this is 'label'.
228 bool isLabelTy() const { return getTypeID() == LabelTyID; }
229
230 /// Return true if this is 'metadata'.
231 bool isMetadataTy() const { return getTypeID() == MetadataTyID; }
232
233 /// Return true if this is 'token'.
234 bool isTokenTy() const { return getTypeID() == TokenTyID; }
235
236 /// Returns true if this is 'token' or a token-like target type.s
237 bool isTokenLikeTy() const;
238
239 /// True if this is an instance of IntegerType.
240 bool isIntegerTy() const { return getTypeID() == IntegerTyID; }
241
242 /// Return true if this is an IntegerType of the given width.
243 LLVM_ABI bool isIntegerTy(unsigned Bitwidth) const;
244
245 /// Return true if this is an integer type or a vector of integer types.
246 bool isIntOrIntVectorTy() const { return getScalarType()->isIntegerTy(); }
247
248 /// Return true if this is an integer type or a vector of integer types of
249 /// the given width.
250 bool isIntOrIntVectorTy(unsigned BitWidth) const {
252 }
253
254 /// Return true if this is an integer type or a pointer type.
255 bool isIntOrPtrTy() const { return isIntegerTy() || isPointerTy(); }
256
257 /// True if this is an instance of FunctionType.
258 bool isFunctionTy() const { return getTypeID() == FunctionTyID; }
259
260 /// True if this is an instance of StructType.
261 bool isStructTy() const { return getTypeID() == StructTyID; }
262
263 /// True if this is an instance of ArrayType.
264 bool isArrayTy() const { return getTypeID() == ArrayTyID; }
265
266 /// True if this is an instance of PointerType.
267 bool isPointerTy() const { return getTypeID() == PointerTyID; }
268
269 /// Return true if this is a pointer type or a vector of pointer types.
270 bool isPtrOrPtrVectorTy() const { return getScalarType()->isPointerTy(); }
271
272 /// True if this is an instance of VectorType.
273 inline bool isVectorTy() const {
275 }
276
277 // True if this is an instance of TargetExtType of RISC-V vector tuple.
279
280 /// Return true if this type could be converted with a lossless BitCast to
281 /// type 'Ty'. For example, i8* to i32*. BitCasts are valid for types of the
282 /// same size only where no re-interpretation of the bits is done.
283 /// Determine if this type could be losslessly bitcast to Ty
285
286 /// Return true if this type is empty, that is, it has no elements or all of
287 /// its elements are empty.
288 LLVM_ABI bool isEmptyTy() const;
289
290 /// Return true if the type is "first class", meaning it is a valid type for a
291 /// Value.
293
294 /// Return true if the type is a valid type for a register in codegen. This
295 /// includes all first-class types except struct and array types.
296 bool isSingleValueType() const {
297 return isFloatingPointTy() || isIntegerTy() || isPointerTy() ||
299 }
300
301 /// Return true if the type is an aggregate type. This means it is valid as
302 /// the first operand of an insertvalue or extractvalue instruction. This
303 /// includes struct and array types, but does not include vector types.
304 bool isAggregateType() const {
305 return getTypeID() == StructTyID || getTypeID() == ArrayTyID;
306 }
307
308 /// Return true if it makes sense to take the size of this type. To get the
309 /// actual size for a particular target, it is reasonable to use the
310 /// DataLayout subsystem to do this.
311 bool isSized(SmallPtrSetImpl<Type*> *Visited = nullptr) const {
312 // If it's a primitive, it is always sized.
315 return true;
316 // If it is not something that can have a size (e.g. a function or label),
317 // it doesn't have a size.
318 if (getTypeID() != StructTyID && getTypeID() != ArrayTyID &&
320 return false;
321 // Otherwise we have to try harder to decide.
322 return isSizedDerivedType(Visited);
323 }
324
325 /// Return the basic size of this type if it is a primitive type. These are
326 /// fixed by LLVM and are not target-dependent.
327 /// This will return zero if the type does not have a size or is not a
328 /// primitive type.
329 ///
330 /// If this is a scalable vector type, the scalable property will be set and
331 /// the runtime size will be a positive integer multiple of the base size.
332 ///
333 /// Note that this may not reflect the size of memory allocated for an
334 /// instance of the type or the number of bytes that are written when an
335 /// instance of the type is stored to memory. The DataLayout class provides
336 /// additional query functions to provide this information.
337 ///
339
340 /// If this is a vector type, return the getPrimitiveSizeInBits value for the
341 /// element type. Otherwise return the getPrimitiveSizeInBits value for this
342 /// type.
344
345 /// Return the width of the mantissa of this type. This is only valid on
346 /// floating-point types. If the FP type does not have a stable mantissa (e.g.
347 /// ppc long double), this method returns -1.
349
350 /// If this is a vector type, return the element type, otherwise return
351 /// 'this'.
353 if (isVectorTy())
354 return getContainedType(0);
355 return const_cast<Type *>(this);
356 }
357
358 //===--------------------------------------------------------------------===//
359 // Type Iteration support.
360 //
361 using subtype_iterator = Type * const *;
362
367 }
368
369 using subtype_reverse_iterator = std::reverse_iterator<subtype_iterator>;
370
373 }
376 }
377
378 /// This method is used to implement the type iterator (defined at the end of
379 /// the file). For derived types, this returns the types 'contained' in the
380 /// derived type.
381 Type *getContainedType(unsigned i) const {
382 assert(i < NumContainedTys && "Index out of range!");
383 return ContainedTys[i];
384 }
385
386 /// Return the number of types in the derived type.
387 unsigned getNumContainedTypes() const { return NumContainedTys; }
388
389 //===--------------------------------------------------------------------===//
390 // Helper methods corresponding to subclass methods. This forces a cast to
391 // the specified subclass and calls its accessor. "getArrayNumElements" (for
392 // example) is shorthand for cast<ArrayType>(Ty)->getNumElements(). This is
393 // only intended to cover the core methods that are frequently used, helper
394 // methods should not be added here.
395
396 LLVM_ABI inline unsigned getIntegerBitWidth() const;
397
398 LLVM_ABI inline Type *getFunctionParamType(unsigned i) const;
399 LLVM_ABI inline unsigned getFunctionNumParams() const;
400 LLVM_ABI inline bool isFunctionVarArg() const;
401
403 LLVM_ABI inline unsigned getStructNumElements() const;
404 LLVM_ABI inline Type *getStructElementType(unsigned N) const;
405
407
410 return ContainedTys[0];
411 }
412
414
415 /// Given vector type, change the element type,
416 /// whilst keeping the old number of elements.
417 /// For non-vectors simply returns \p EltTy.
418 LLVM_ABI inline Type *getWithNewType(Type *EltTy) const;
419
420 /// Given an integer or vector type, change the lane bitwidth to NewBitwidth,
421 /// whilst keeping the old number of lanes.
422 LLVM_ABI inline Type *getWithNewBitWidth(unsigned NewBitWidth) const;
423
424 /// Given scalar/vector integer type, returns a type with elements twice as
425 /// wide as in the original type. For vectors, preserves element count.
427
428 /// Get the address space of this pointer or pointer vector type.
429 LLVM_ABI inline unsigned getPointerAddressSpace() const;
430
431 //===--------------------------------------------------------------------===//
432 // Static members exported by the Type class itself. Useful for getting
433 // instances of Type.
434 //
435
436 /// Return a type based on an identifier.
438
439 //===--------------------------------------------------------------------===//
440 // These are the builtin types that are always available.
441 //
461 template <typename ScalarTy> static Type *getScalarTy(LLVMContext &C) {
462 int noOfBits = sizeof(ScalarTy) * CHAR_BIT;
463 if (std::is_integral<ScalarTy>::value) {
464 return (Type*) Type::getIntNTy(C, noOfBits);
465 } else if (std::is_floating_point<ScalarTy>::value) {
466 switch (noOfBits) {
467 case 32:
468 return Type::getFloatTy(C);
469 case 64:
470 return Type::getDoubleTy(C);
471 }
472 }
473 llvm_unreachable("Unsupported type in Type::getScalarTy");
474 }
476 const fltSemantics &S);
477
478 //===--------------------------------------------------------------------===//
479 // Convenience methods for getting pointer types.
480 //
483
484 /// Return a pointer to the current type. This is equivalent to
485 /// PointerType::get(Ctx, AddrSpace).
486 /// TODO: Remove this after opaque pointer transition is complete.
487 LLVM_ABI LLVM_DEPRECATED("Use PointerType::get instead", "PointerType::get")
488 PointerType *getPointerTo(unsigned AddrSpace = 0) const;
489
490private:
491 /// Derived types like structures and arrays are sized iff all of the members
492 /// of the type are sized as well. Since asking for their size is relatively
493 /// uncommon, move this operation out-of-line.
494 LLVM_ABI bool
495 isSizedDerivedType(SmallPtrSetImpl<Type *> *Visited = nullptr) const;
496};
497
498// Printing of types.
500 T.print(OS);
501 return OS;
502}
503
504// allow isa<PointerType>(x) to work without DerivedTypes.h included.
505template <> struct isa_impl<PointerType, Type> {
506 static inline bool doit(const Type &Ty) {
507 return Ty.getTypeID() == Type::PointerTyID;
508 }
509};
510
511// Create wrappers for C Binding types (see CBindingWrapping.h).
513
514/* Specialized opaque type conversions.
515 */
517 return reinterpret_cast<Type**>(Tys);
518}
519
520inline LLVMTypeRef *wrap(Type **Tys) {
521 return reinterpret_cast<LLVMTypeRef *>(Tys);
522}
523
524} // end namespace llvm
525
526#endif // LLVM_IR_TYPE_H
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
aarch64 promote const
always inline
#define DEFINE_ISA_CONVERSION_FUNCTIONS(ty, ref)
#define LLVM_ABI
Definition: Compiler.h:213
#define LLVM_READONLY
Definition: Compiler.h:322
Type::TypeID TypeID
raw_pwrite_stream & OS
ArrayRef - Represent a constant reference to an array (0 or more elements consecutively in memory),...
Definition: ArrayRef.h:41
Class to represent integer types.
Definition: DerivedTypes.h:42
This is an important class for using LLVM in a threaded context.
Definition: LLVMContext.h:68
Class to represent pointers.
Definition: DerivedTypes.h:700
A templated base class for SmallPtrSet which provides the typesafe interface that is common across al...
Definition: SmallPtrSet.h:380
StringRef - Represent a constant reference to a string, i.e.
Definition: StringRef.h:55
The instances of the Type class are immutable: once they are created, they are never changed.
Definition: Type.h:45
static LLVM_ABI Type * getFloatTy(LLVMContext &C)
LLVM_ABI TypeSize getPrimitiveSizeInBits() const LLVM_READONLY
Return the basic size of this type if it is a primitive type.
LLVM_ABI bool isFunctionVarArg() const
static LLVM_ABI Type * getPrimitiveType(LLVMContext &C, TypeID IDNumber)
Return a type based on an identifier.
LLVM_ABI bool isIntegerTy(unsigned Bitwidth) const
Return true if this is an IntegerType of the given width.
~Type()=default
bool isIntOrIntVectorTy(unsigned BitWidth) const
Return true if this is an integer type or a vector of integer types of the given width.
Definition: Type.h:250
static LLVM_ABI Type * getFP128Ty(LLVMContext &C)
bool isVectorTy() const
True if this is an instance of VectorType.
Definition: Type.h:273
static LLVM_ABI Type * getPPC_FP128Ty(LLVMContext &C)
static LLVM_ABI Type * getDoubleTy(LLVMContext &C)
bool isX86_FP80Ty() const
Return true if this is x86 long double.
Definition: Type.h:159
LLVM_ABI int getFPMantissaWidth() const
Return the width of the mantissa of this type.
LLVM_ABI bool canLosslesslyBitCastTo(Type *Ty) const
Return true if this type could be converted with a lossless BitCast to type 'Ty'.
LLVM_ABI Type * getExtendedType() const
Given scalar/vector integer type, returns a type with elements twice as wide as in the original type.
bool isArrayTy() const
True if this is an instance of ArrayType.
Definition: Type.h:264
static LLVM_ABI Type * getLabelTy(LLVMContext &C)
bool isLabelTy() const
Return true if this is 'label'.
Definition: Type.h:228
bool isIntOrIntVectorTy() const
Return true if this is an integer type or a vector of integer types.
Definition: Type.h:246
LLVM_ABI bool isEmptyTy() const
Return true if this type is empty, that is, it has no elements or all of its elements are empty.
LLVM_ABI void dump() const
LLVM_ABI bool containsNonLocalTargetExtType() const
static LLVM_ABI IntegerType * getInt8Ty(LLVMContext &C)
bool isPointerTy() const
True if this is an instance of PointerType.
Definition: Type.h:267
static LLVM_ABI IntegerType * getInt32Ty(LLVMContext &C)
Type * getArrayElementType() const
Definition: Type.h:408
bool isFloatTy() const
Return true if this is 'float', a 32-bit IEEE fp type.
Definition: Type.h:153
static LLVM_ABI Type * getHalfTy(LLVMContext &C)
static LLVM_ABI IntegerType * getIntNTy(LLVMContext &C, unsigned N)
bool isBFloatTy() const
Return true if this is 'bfloat', a 16-bit bfloat type.
Definition: Type.h:145
LLVM_ABI StringRef getTargetExtName() const
Type *const * subtype_iterator
Definition: Type.h:361
LLVM_ABI bool isFirstClassType() const
Return true if the type is "first class", meaning it is a valid type for a Value.
static LLVM_ABI Type * getWasm_ExternrefTy(LLVMContext &C)
LLVM_ABI bool containsNonGlobalTargetExtType(SmallPtrSetImpl< const Type * > &Visited) const
Return true if this type is or contains a target extension type that disallows being used as a global...
LLVM_ABI bool isScalableTargetExtTy() const
Return true if this is a target extension type with a scalable layout.
TypeID
Definitions of all of the base types for the Type system.
Definition: Type.h:54
@ X86_AMXTyID
AMX vectors (8192 bits, X86 specific)
Definition: Type.h:66
@ FunctionTyID
Functions.
Definition: Type.h:71
@ ArrayTyID
Arrays.
Definition: Type.h:74
@ TypedPointerTyID
Typed pointer used by some GPU targets.
Definition: Type.h:77
@ HalfTyID
16-bit floating point type
Definition: Type.h:56
@ TargetExtTyID
Target extension type.
Definition: Type.h:78
@ VoidTyID
type with no size
Definition: Type.h:63
@ ScalableVectorTyID
Scalable SIMD vector type.
Definition: Type.h:76
@ LabelTyID
Labels.
Definition: Type.h:64
@ FloatTyID
32-bit floating point type
Definition: Type.h:58
@ StructTyID
Structures.
Definition: Type.h:73
@ IntegerTyID
Arbitrary bit width integers.
Definition: Type.h:70
@ FixedVectorTyID
Fixed width SIMD vector type.
Definition: Type.h:75
@ BFloatTyID
16-bit floating point type (7-bit significand)
Definition: Type.h:57
@ DoubleTyID
64-bit floating point type
Definition: Type.h:59
@ X86_FP80TyID
80-bit floating point type (X87)
Definition: Type.h:60
@ PPC_FP128TyID
128-bit floating point type (two 64-bits, PowerPC)
Definition: Type.h:62
@ MetadataTyID
Metadata.
Definition: Type.h:65
@ TokenTyID
Tokens.
Definition: Type.h:67
@ PointerTyID
Pointers.
Definition: Type.h:72
@ FP128TyID
128-bit floating point type (112-bit significand)
Definition: Type.h:61
ArrayRef< Type * > subtypes() const
Definition: Type.h:365
bool isSingleValueType() const
Return true if the type is a valid type for a register in codegen.
Definition: Type.h:296
static LLVM_ABI IntegerType * getInt1Ty(LLVMContext &C)
unsigned getNumContainedTypes() const
Return the number of types in the derived type.
Definition: Type.h:387
bool isPPC_FP128Ty() const
Return true if this is powerpc long double.
Definition: Type.h:165
unsigned NumContainedTys
Keeps track of how many Type*'s there are in the ContainedTys list.
Definition: Type.h:106
static LLVM_ABI IntegerType * getInt64Ty(LLVMContext &C)
static LLVM_ABI Type * getX86_AMXTy(LLVMContext &C)
bool isFP128Ty() const
Return true if this is 'fp128'.
Definition: Type.h:162
LLVM_ABI Type * getWithNewBitWidth(unsigned NewBitWidth) const
Given an integer or vector type, change the lane bitwidth to NewBitwidth, whilst keeping the old numb...
static LLVM_ABI Type * getBFloatTy(LLVMContext &C)
LLVM_ABI LLVM_DEPRECATED("Use PointerType::get instead", "PointerType::get") PointerType *getPointerTo(unsigned AddrSpace=0) const
Return a pointer to the current type.
bool is16bitFPTy() const
Return true if this is a 16-bit float type.
Definition: Type.h:148
LLVM_ABI StringRef getStructName() const
static LLVM_ABI Type * getVoidTy(LLVMContext &C)
LLVM_ABI unsigned getPointerAddressSpace() const
Get the address space of this pointer or pointer vector type.
LLVM_ABI bool isScalableTy(SmallPtrSetImpl< const Type * > &Visited) const
Return true if this is a type whose size is a known multiple of vscale.
bool isMultiUnitFPType() const
Returns true if this is a floating-point type that is an unevaluated sum of multiple floating-point u...
Definition: Type.h:193
Type(LLVMContext &C, TypeID tid)
Definition: Type.h:93
bool isStructTy() const
True if this is an instance of StructType.
Definition: Type.h:261
LLVM_ABI bool containsNonLocalTargetExtType(SmallPtrSetImpl< const Type * > &Visited) const
Return true if this type is or contains a target extension type that disallows being used as a local.
bool isTargetExtTy() const
Return true if this is a target extension type.
Definition: Type.h:203
bool isSized(SmallPtrSetImpl< Type * > *Visited=nullptr) const
Return true if it makes sense to take the size of this type.
Definition: Type.h:311
bool isAggregateType() const
Return true if the type is an aggregate type.
Definition: Type.h:304
bool isHalfTy() const
Return true if this is 'half', a 16-bit IEEE fp type.
Definition: Type.h:142
LLVMContext & getContext() const
Return the LLVMContext in which this type was uniqued.
Definition: Type.h:128
Type *const * ContainedTys
A pointer to the array of Types contained by this Type.
Definition: Type.h:113
unsigned getSubclassData() const
Definition: Type.h:97
bool isTokenLikeTy() const
Returns true if this is 'token' or a token-like target type.s.
std::reverse_iterator< subtype_iterator > subtype_reverse_iterator
Definition: Type.h:369
bool isDoubleTy() const
Return true if this is 'double', a 64-bit IEEE fp type.
Definition: Type.h:156
void setSubclassData(unsigned val)
Definition: Type.h:99
bool isFloatingPointTy() const
Return true if this is one of the floating-point types.
Definition: Type.h:184
bool isPtrOrPtrVectorTy() const
Return true if this is a pointer type or a vector of pointer types.
Definition: Type.h:270
subtype_iterator subtype_begin() const
Definition: Type.h:363
LLVM_ABI Type * getFunctionParamType(unsigned i) const
bool isX86_AMXTy() const
Return true if this is X86 AMX.
Definition: Type.h:200
static Type * getScalarTy(LLVMContext &C)
Definition: Type.h:461
static LLVM_ABI Type * getX86_FP80Ty(LLVMContext &C)
bool isFunctionTy() const
True if this is an instance of FunctionType.
Definition: Type.h:258
bool isIntOrPtrTy() const
Return true if this is an integer type or a pointer type.
Definition: Type.h:255
static LLVM_ABI IntegerType * getInt16Ty(LLVMContext &C)
LLVM_ABI const fltSemantics & getFltSemantics() const
LLVM_ABI unsigned getScalarSizeInBits() const LLVM_READONLY
If this is a vector type, return the getPrimitiveSizeInBits value for the element type.
bool isIntegerTy() const
True if this is an instance of IntegerType.
Definition: Type.h:240
LLVM_ABI bool containsNonGlobalTargetExtType() const
TypeID getTypeID() const
Return the type id for the type.
Definition: Type.h:136
LLVM_ABI Type * getStructElementType(unsigned N) const
bool isTokenTy() const
Return true if this is 'token'.
Definition: Type.h:234
subtype_reverse_iterator subtype_rend() const
Definition: Type.h:374
static LLVM_ABI Type * getMetadataTy(LLVMContext &C)
static LLVM_ABI IntegerType * getInt128Ty(LLVMContext &C)
LLVM_ABI void print(raw_ostream &O, bool IsForDebug=false, bool NoDetails=false) const
Print the current type.
static LLVM_ABI Type * getFloatingPointTy(LLVMContext &C, const fltSemantics &S)
static LLVM_ABI Type * getWasm_FuncrefTy(LLVMContext &C)
bool isFPOrFPVectorTy() const
Return true if this is a FP type or a vector of FP.
Definition: Type.h:225
subtype_reverse_iterator subtype_rbegin() const
Definition: Type.h:371
Type * getContainedType(unsigned i) const
This method is used to implement the type iterator (defined at the end of the file).
Definition: Type.h:381
subtype_iterator subtype_end() const
Definition: Type.h:364
bool isIEEELikeFPTy() const
Return true if this is a well-behaved IEEE-like type, which has a IEEE compatible layout,...
Definition: Type.h:170
LLVM_ABI bool isRISCVVectorTupleTy() const
LLVM_ABI bool isScalableTy() const
bool isVoidTy() const
Return true if this is 'void'.
Definition: Type.h:139
LLVM_ABI unsigned getStructNumElements() const
LLVM_ABI unsigned getIntegerBitWidth() const
LLVM_ABI unsigned getFunctionNumParams() const
LLVM_ABI uint64_t getArrayNumElements() const
static LLVM_ABI Type * getTokenTy(LLVMContext &C)
Type * getScalarType() const
If this is a vector type, return the element type, otherwise return 'this'.
Definition: Type.h:352
bool isMetadataTy() const
Return true if this is 'metadata'.
Definition: Type.h:231
LLVM_ABI Type * getWithNewType(Type *EltTy) const
Given vector type, change the element type, whilst keeping the old number of elements.
This class implements an extremely fast bulk output stream that can only output to a stream.
Definition: raw_ostream.h:53
struct LLVMOpaqueType * LLVMTypeRef
Each value in the LLVM IR has a type, an LLVMTypeRef.
Definition: Types.h:68
#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
Attribute unwrap(LLVMAttributeRef Attr)
Definition: Attributes.h:351
constexpr unsigned BitWidth
Definition: BitmaskEnum.h:223
LLVMAttributeRef wrap(Attribute Attr)
Definition: Attributes.h:346
#define N
static bool doit(const Type &Ty)
Definition: Type.h:506