20EVT EVT::changeExtendedTypeToInteger()
const {
26EVT EVT::changeExtendedVectorElementTypeToInteger()
const {
33EVT EVT::changeExtendedVectorElementType(
EVT EltVT)
const {
62bool EVT::isExtendedFloatingPoint()
const {
67bool EVT::isExtendedInteger()
const {
72bool EVT::isExtendedScalarInteger()
const {
77bool EVT::isExtendedVector()
const {
82bool EVT::isExtended16BitVector()
const {
83 return isExtendedVector() &&
87bool EVT::isExtended32BitVector()
const {
88 return isExtendedVector() &&
92bool EVT::isExtended64BitVector()
const {
93 return isExtendedVector() &&
97bool EVT::isExtended128BitVector()
const {
98 return isExtendedVector() &&
102bool EVT::isExtended256BitVector()
const {
103 return isExtendedVector() &&
107bool EVT::isExtended512BitVector()
const {
108 return isExtendedVector() &&
112bool EVT::isExtended1024BitVector()
const {
113 return isExtendedVector() &&
117bool EVT::isExtended2048BitVector()
const {
118 return isExtendedVector() &&
122bool EVT::isExtendedFixedLengthVector()
const {
123 return isExtendedVector() && isa<FixedVectorType>(LLVMTy);
126bool EVT::isExtendedScalableVector()
const {
127 return isExtendedVector() && isa<ScalableVectorType>(LLVMTy);
130EVT EVT::getExtendedVectorElementType()
const {
132 return EVT::getEVT(cast<VectorType>(LLVMTy)->getElementType());
135unsigned EVT::getExtendedVectorNumElements()
const {
138 if (
EC.isScalable()) {
140 <<
"The code that requested the fixed number of elements has made the "
141 "assumption that this vector is not scalable. This assumption was "
142 "not correct, and this may lead to broken code\n";
144 return EC.getKnownMinValue();
147ElementCount EVT::getExtendedVectorElementCount()
const {
149 return cast<VectorType>(LLVMTy)->getElementCount();
152TypeSize EVT::getExtendedSizeInBits()
const {
154 if (
IntegerType *ITy = dyn_cast<IntegerType>(LLVMTy))
156 if (
VectorType *VTy = dyn_cast<VectorType>(LLVMTy))
157 return VTy->getPrimitiveSizeInBits();
168 unsigned MinNumElts = Sz / (NF * 8);
169 return "riscv_nxv" + utostr(MinNumElts) +
"i8x" + utostr(NF);
180 case MVT::bf16:
return "bf16";
181 case MVT::ppcf128:
return "ppcf128";
182 case MVT::isVoid:
return "isVoid";
183 case MVT::Other:
return "ch";
184 case MVT::Glue:
return "glue";
185 case MVT::x86mmx:
return "x86mmx";
186 case MVT::x86amx:
return "x86amx";
187 case MVT::i64x8:
return "i64x8";
188 case MVT::Metadata:
return "Metadata";
189 case MVT::Untyped:
return "Untyped";
190 case MVT::funcref:
return "funcref";
191 case MVT::exnref:
return "exnref";
192 case MVT::externref:
return "externref";
193 case MVT::aarch64svcount:
194 return "aarch64svcount";
195 case MVT::spirvbuiltin:
196 return "spirvbuiltin";
197 case MVT::amdgpuBufferFatPointer:
198 return "amdgpuBufferFatPointer";
199 case MVT::amdgpuBufferStridedPointer:
200 return "amdgpuBufferStridedPointer";
201 case MVT::aarch64mfp8:
202 return "aarch64mfp8";
206#if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP)
224 case MVT::aarch64svcount:
226 case MVT::aarch64mfp8:
235#define GET_VT_EVT(Ty, EVT) case MVT::Ty: return EVT;
236#include "llvm/CodeGen/GenVT.inc"
248 assert(Ty !=
nullptr &&
"Invalid type");
251 if (HandleUnknown)
return MVT(MVT::Other);
262 return MVT(MVT::f80);
265 if (TargetExtTy->
getName() ==
"aarch64.svcount")
266 return MVT(MVT::aarch64svcount);
268 return MVT(MVT::spirvbuiltin);
269 if (TargetExtTy->
getName() ==
"riscv.vector.tuple") {
271 ->getMinNumElements() *
278 return MVT(MVT::Other);
334#if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP)
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
This file declares a class to represent arbitrary precision floating point values and provide a varie...
static unsigned getBitWidth(Type *Ty, const DataLayout &DL)
Returns the bitwidth of the given scalar or pointer type.
static LLVM_ABI FixedVectorType * get(Type *ElementType, unsigned NumElts)
Class to represent integer types.
static LLVM_ABI IntegerType * get(LLVMContext &C, unsigned NumBits)
This static method is the primary way of constructing an IntegerType.
This is an important class for using LLVM in a threaded context.
LLVM_ABI void dump() const
Support for debugging, callable in GDB: VT.dump()
@ INVALID_SIMPLE_VALUE_TYPE
static MVT getRISCVVectorTupleVT(unsigned Sz, unsigned NFields)
static LLVM_ABI MVT getVT(Type *Ty, bool HandleUnknown=false)
Return the value type corresponding to the specified type.
LLVM_ABI const fltSemantics & getFltSemantics() const
Returns an APFloat semantics tag appropriate for the value type.
static MVT getVectorVT(MVT VT, unsigned NumElements)
static MVT getIntegerVT(unsigned BitWidth)
MVT getScalarType() const
If this is a vector, return the element type, otherwise return this.
LLVM_ABI void print(raw_ostream &OS) const
Implement operator<<.
bool starts_with(StringRef Prefix) const
Check if this string starts with the given Prefix.
Class to represent target extensions types, which are generally unintrospectable from target-independ...
static LLVM_ABI TargetExtType * get(LLVMContext &Context, StringRef Name, ArrayRef< Type * > Types={}, ArrayRef< unsigned > Ints={})
Return a target extension type having the specified name and optional type and integer parameters.
Type * getTypeParameter(unsigned i) const
unsigned getIntParameter(unsigned i) const
StringRef getName() const
Return the name for this target extension type.
static constexpr TypeSize getFixed(ScalarTy ExactSize)
The instances of the Type class are immutable: once they are created, they are never changed.
bool isVectorTy() const
True if this is an instance of VectorType.
bool isIntOrIntVectorTy() const
Return true if this is an integer type or a vector of integer types.
static LLVM_ABI Type * getWasm_ExternrefTy(LLVMContext &C)
@ X86_AMXTyID
AMX vectors (8192 bits, X86 specific)
@ HalfTyID
16-bit floating point type
@ TargetExtTyID
Target extension type.
@ VoidTyID
type with no size
@ ScalableVectorTyID
Scalable SIMD vector type.
@ FloatTyID
32-bit floating point type
@ IntegerTyID
Arbitrary bit width integers.
@ FixedVectorTyID
Fixed width SIMD vector type.
@ BFloatTyID
16-bit floating point type (7-bit significand)
@ DoubleTyID
64-bit floating point type
@ X86_FP80TyID
80-bit floating point type (X87)
@ PPC_FP128TyID
128-bit floating point type (two 64-bits, PowerPC)
@ FP128TyID
128-bit floating point type (112-bit significand)
static LLVM_ABI Type * getX86_AMXTy(LLVMContext &C)
static LLVM_ABI Type * getVoidTy(LLVMContext &C)
LLVMContext & getContext() const
Return the LLVMContext in which this type was uniqued.
bool isIntegerTy() const
True if this is an instance of IntegerType.
TypeID getTypeID() const
Return the type id for the type.
static LLVM_ABI Type * getMetadataTy(LLVMContext &C)
static LLVM_ABI Type * getWasm_FuncrefTy(LLVMContext &C)
bool isFPOrFPVectorTy() const
Return true if this is a FP type or a vector of FP.
Base class of all SIMD vector types.
ElementCount getElementCount() const
Return an ElementCount instance to represent the (possibly scalable) number of elements in the vector...
static LLVM_ABI VectorType * get(Type *ElementType, ElementCount EC)
This static method is the primary way to construct an VectorType.
Type * getElementType() const
static LLVM_ABI raw_ostream & warning()
Convenience method for printing "warning: " to stderr.
constexpr ScalarTy getKnownMinValue() const
Returns the minimum value this quantity can represent.
This class implements an extremely fast bulk output stream that can only output to a stream.
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
This is an optimization pass for GlobalISel generic memory operations.
LLVM_ABI raw_ostream & dbgs()
dbgs() - This returns a reference to a raw_ostream for debugging messages.
constexpr unsigned BitWidth
static LLVM_ABI const fltSemantics & IEEEsingle() LLVM_READNONE
static LLVM_ABI const fltSemantics & PPCDoubleDouble() LLVM_READNONE
static LLVM_ABI const fltSemantics & x87DoubleExtended() LLVM_READNONE
static LLVM_ABI const fltSemantics & IEEEquad() LLVM_READNONE
static LLVM_ABI const fltSemantics & IEEEdouble() LLVM_READNONE
static LLVM_ABI const fltSemantics & IEEEhalf() LLVM_READNONE
static LLVM_ABI const fltSemantics & BFloat() LLVM_READNONE
static EVT getVectorVT(LLVMContext &Context, EVT VT, unsigned NumElements, bool IsScalable=false)
Returns the EVT that represents a vector NumElements in length, where each element is of type VT.
bool isFloatingPoint() const
Return true if this is a FP or a vector FP type.
ElementCount getVectorElementCount() const
TypeSize getSizeInBits() const
Return the size of the specified value type in bits.
unsigned getRISCVVectorTupleNumFields() const
Given a RISCV vector tuple type, return the num_fields.
uint64_t getScalarSizeInBits() const
static LLVM_ABI EVT getEVT(Type *Ty, bool HandleUnknown=false)
Return the value type corresponding to the specified type.
MVT getSimpleVT() const
Return the SimpleValueType held in the specified simple EVT.
LLVM_ABI void dump() const
Support for debugging, callable in GDB: VT.dump()
static EVT getIntegerVT(LLVMContext &Context, unsigned BitWidth)
Returns the EVT that represents an integer with the given number of bits.
bool isRISCVVectorTuple() const
Return true if this is a vector value type.
LLVM_ABI std::string getEVTString() const
This function returns value type as a string, e.g. "i32".
bool isVector() const
Return true if this is a vector value type.
EVT getScalarType() const
If this is a vector type, return the element type, otherwise return this.
LLVM_ABI Type * getTypeForEVT(LLVMContext &Context) const
This method returns an LLVM type corresponding to the specified EVT.
bool isScalableVector() const
Return true if this is a vector type where the runtime length is machine dependent.
EVT getVectorElementType() const
Given a vector type, return the type of each element.
bool isExtended() const
Test if the given EVT is extended (as opposed to being simple).
void print(raw_ostream &OS) const
Implement operator<<.
LLVM_ABI const fltSemantics & getFltSemantics() const
Returns an APFloat semantics tag appropriate for the value type.
bool isInteger() const
Return true if this is an integer or a vector integer type.