clang 20.0.0git
|
Describes a memory block created by an allocation site. More...
#include "/home/buildbot/as-worker-4/publish-doxygen-docs/llvm-project/clang/lib/AST/ByteCode/Descriptor.h"
Classes | |
struct | UnknownSize |
Token to denote structures of unknown size. More... | |
Public Types | |
using | MetadataSize = std::optional< unsigned > |
Public Member Functions | |
Descriptor (const DeclTy &D, PrimType Type, MetadataSize MD, bool IsConst, bool IsTemporary, bool IsMutable) | |
Allocates a descriptor for a primitive. | |
Descriptor (const DeclTy &D, PrimType Type, MetadataSize MD, size_t NumElems, bool IsConst, bool IsTemporary, bool IsMutable) | |
Allocates a descriptor for an array of primitives. | |
Descriptor (const DeclTy &D, PrimType Type, MetadataSize MDSize, bool IsTemporary, UnknownSize) | |
Allocates a descriptor for an array of primitives of unknown size. | |
Descriptor (const DeclTy &D, const Descriptor *Elem, MetadataSize MD, unsigned NumElems, bool IsConst, bool IsTemporary, bool IsMutable) | |
Allocates a descriptor for an array of composites. | |
Descriptor (const DeclTy &D, const Descriptor *Elem, MetadataSize MD, bool IsTemporary, UnknownSize) | |
Allocates a descriptor for an array of composites of unknown size. | |
Descriptor (const DeclTy &D, const Record *R, MetadataSize MD, bool IsConst, bool IsTemporary, bool IsMutable) | |
Allocates a descriptor for a record. | |
Descriptor (const DeclTy &D) | |
Allocates a dummy descriptor. | |
void | makeDummy () |
Make this descriptor a dummy descriptor. | |
QualType | getType () const |
QualType | getElemQualType () const |
SourceLocation | getLocation () const |
SourceInfo | getLoc () const |
const Decl * | asDecl () const |
const Expr * | asExpr () const |
const DeclTy & | getSource () const |
const ValueDecl * | asValueDecl () const |
const VarDecl * | asVarDecl () const |
const FieldDecl * | asFieldDecl () const |
const RecordDecl * | asRecordDecl () const |
unsigned | getSize () const |
Returns the size of the object without metadata. | |
PrimType | getPrimType () const |
unsigned | getAllocSize () const |
Returns the allocated size, including metadata. | |
unsigned | getElemSize () const |
returns the size of an element when the structure is viewed as an array. | |
unsigned | getMetadataSize () const |
Returns the size of the metadata. | |
unsigned | getNumElems () const |
Returns the number of elements stored in the block. | |
bool | isPrimitiveArray () const |
Checks if the descriptor is of an array of primitives. | |
bool | isCompositeArray () const |
Checks if the descriptor is of an array of composites. | |
bool | isZeroSizeArray () const |
Checks if the descriptor is of an array of zero size. | |
bool | isUnknownSizeArray () const |
Checks if the descriptor is of an array of unknown size. | |
bool | isPrimitive () const |
Checks if the descriptor is of a primitive. | |
bool | isArray () const |
Checks if the descriptor is of an array. | |
bool | isRecord () const |
Checks if the descriptor is of a record. | |
bool | isUnion () const |
Checks if the descriptor is of a union. | |
bool | isDummy () const |
Checks if this is a dummy descriptor. | |
void | dump () const |
void | dump (llvm::raw_ostream &OS) const |
Public Attributes | |
const Record *const | ElemRecord = nullptr |
Pointer to the record, if block contains records. | |
const Descriptor *const | ElemDesc = nullptr |
Descriptor of the array element. | |
const std::optional< PrimType > | PrimT = std::nullopt |
The primitive type this descriptor was created for, or the primitive element type in case this is a primitive array. | |
const bool | IsConst = false |
Flag indicating if the block is mutable. | |
const bool | IsMutable = false |
Flag indicating if a field is mutable. | |
const bool | IsTemporary = false |
Flag indicating if the block is a temporary. | |
const bool | IsArray = false |
Flag indicating if the block is an array. | |
bool | IsDummy = false |
Flag indicating if this is a dummy descriptor. | |
const BlockCtorFn | CtorFn = nullptr |
Storage management methods. | |
const BlockDtorFn | DtorFn = nullptr |
const BlockMoveFn | MoveFn = nullptr |
Static Public Attributes | |
static constexpr MetadataSize | InlineDescMD = sizeof(InlineDescriptor) |
static constexpr MetadataSize | GlobalMD = sizeof(GlobalInlineDescriptor) |
static constexpr unsigned | MaxArrayElemBytes |
Maximum number of bytes to be used for array elements. | |
Describes a memory block created by an allocation site.
Definition at line 116 of file Descriptor.h.
using clang::interp::Descriptor::MetadataSize = std::optional<unsigned> |
Definition at line 136 of file Descriptor.h.
Descriptor::Descriptor | ( | const DeclTy & | D, |
PrimType | Type, | ||
MetadataSize | MD, | ||
size_t | NumElems, | ||
bool | IsConst, | ||
bool | IsTemporary, | ||
bool | IsMutable | ||
) |
Allocates a descriptor for an array of primitives.
Primitive arrays.
Definition at line 325 of file Descriptor.cpp.
References MaxArrayElemBytes.
Descriptor::Descriptor | ( | const DeclTy & | D, |
PrimType | Type, | ||
MetadataSize | MDSize, | ||
bool | IsTemporary, | ||
UnknownSize | |||
) |
Allocates a descriptor for an array of primitives of unknown size.
Primitive unknown-size arrays.
Definition at line 339 of file Descriptor.cpp.
Descriptor::Descriptor | ( | const DeclTy & | D, |
const Descriptor * | Elem, | ||
MetadataSize | MD, | ||
unsigned | NumElems, | ||
bool | IsConst, | ||
bool | IsTemporary, | ||
bool | IsMutable | ||
) |
Allocates a descriptor for an array of composites.
Arrays of composite elements.
Definition at line 351 of file Descriptor.cpp.
Descriptor::Descriptor | ( | const DeclTy & | D, |
const Descriptor * | Elem, | ||
MetadataSize | MD, | ||
bool | IsTemporary, | ||
UnknownSize | |||
) |
Allocates a descriptor for an array of composites of unknown size.
Unknown-size arrays of composite elements.
Definition at line 364 of file Descriptor.cpp.
Descriptor::Descriptor | ( | const DeclTy & | D, |
const Record * | R, | ||
MetadataSize | MD, | ||
bool | IsConst, | ||
bool | IsTemporary, | ||
bool | IsMutable | ||
) |
Allocates a descriptor for a record.
Composite records.
Definition at line 375 of file Descriptor.cpp.
Descriptor::Descriptor | ( | const DeclTy & | D | ) |
|
inline |
Definition at line 204 of file Descriptor.h.
Referenced by asFieldDecl(), asRecordDecl(), asValueDecl(), asVarDecl(), clang::interp::IntPointer::baseCast(), dump(), getType(), clang::interp::Pointer::isField(), and clang::interp::Pointer::toAPValue().
|
inline |
Definition at line 205 of file Descriptor.h.
Referenced by clang::interp::DynamicAllocator::allocate(), clang::interp::CheckNewTypeMismatch(), CheckTemporary(), dump(), clang::interp::Program::dump(), clang::interp::Free(), getType(), clang::interp::InitGlobalTemp(), clang::interp::interp__builtin_assume_aligned(), clang::interp::interp__builtin_operator_delete(), clang::interp::Pointer::pointsToLiteral(), and clang::interp::Pointer::toAPValue().
|
inline |
Definition at line 216 of file Descriptor.h.
References asDecl().
Referenced by clang::interp::Pointer::getField(), and clang::interp::Pointer::toRValue().
|
inline |
Definition at line 220 of file Descriptor.h.
References asDecl().
|
inline |
Definition at line 208 of file Descriptor.h.
References asDecl().
Referenced by clang::interp::CheckDummy(), clang::interp::CheckExtern(), clang::interp::CheckGlobalInitialized(), getType(), clang::interp::interp__builtin_assume_aligned(), clang::interp::interp__builtin_is_aligned_up_down(), and clang::interp::Pointer::toAPValue().
|
inline |
Definition at line 212 of file Descriptor.h.
References asDecl().
Referenced by clang::interp::CheckConstant(), clang::interp::CheckExtern(), clang::interp::CheckInitialized(), and clang::interp::CheckWeak().
LLVM_DUMP_METHOD void Descriptor::dump | ( | ) | const |
Definition at line 212 of file Disasm.cpp.
References dump().
Referenced by dump(), clang::interp::InlineDescriptor::dump(), clang::interp::Block::dump(), and clang::interp::Program::dump().
LLVM_DUMP_METHOD void Descriptor::dump | ( | llvm::raw_ostream & | OS | ) | const |
Definition at line 217 of file Disasm.cpp.
References asDecl(), asExpr(), isCompositeArray(), isDummy(), isPrimitive(), isPrimitiveArray(), isRecord(), isUnion(), isUnknownSizeArray(), and isZeroSizeArray().
|
inline |
Returns the allocated size, including metadata.
Definition at line 236 of file Descriptor.h.
Referenced by clang::interp::Program::createDescriptor(), clang::interp::Program::createGlobalString(), clang::interp::Program::getOrCreateDummy(), clang::interp::Program::getOrCreateRecord(), clang::interp::Block::getSize(), and clang::interp::Block::invokeCtor().
QualType Descriptor::getElemQualType | ( | ) | const |
Definition at line 408 of file Descriptor.cpp.
References clang::Type::getAs(), clang::Type::getAsArrayTypeUnsafe(), clang::ArrayType::getElementType(), clang::Type::getPointeeType(), getType(), isArray(), clang::Type::isArrayType(), clang::Type::isPointerOrReferenceType(), isPrimitiveArray(), and clang::T.
Referenced by enumerateData(), clang::interp::interp__builtin_elementwise_popcount(), clang::interp::interp__builtin_memcpy(), clang::interp::interp__builtin_vector_reduce(), and clang::interp::Pointer::toAPValue().
|
inline |
returns the size of an element when the structure is viewed as an array.
Definition at line 238 of file Descriptor.h.
Referenced by clang::interp::Pointer::elemSize(), getNumElems(), and clang::interp::interp__builtin_strlen().
SourceInfo Descriptor::getLoc | ( | ) | const |
Definition at line 438 of file Descriptor.cpp.
SourceLocation Descriptor::getLocation | ( | ) | const |
Definition at line 430 of file Descriptor.cpp.
References D, E, clang::Expr::getExprLoc(), and clang::Decl::getLocation().
Referenced by clang::interp::CheckFieldsInitialized(), and clang::interp::Pointer::getDeclLoc().
|
inline |
Returns the size of the metadata.
Definition at line 240 of file Descriptor.h.
Referenced by clang::interp::CheckDowncast(), clang::interp::Block::data(), clang::interp::InterpState::deallocate(), clang::interp::Pointer::expand(), and clang::interp::MemberPointer::toPointer().
|
inline |
Returns the number of elements stored in the block.
Definition at line 243 of file Descriptor.h.
References getElemSize(), and getSize().
Referenced by clang::interp::collectBlocks(), clang::interp::copyComposite(), enumerateData(), clang::interp::Pointer::initialize(), clang::interp::interp__builtin_elementwise_popcount(), clang::interp::RunDestructors(), and clang::interp::Pointer::toAPValue().
|
inline |
Definition at line 230 of file Descriptor.h.
References isPrimitive(), isPrimitiveArray(), and PrimT.
Referenced by clang::interp::ArrayElem(), clang::interp::ArrayElemPop(), clang::interp::collectBlocks(), clang::interp::copyComposite(), clang::interp::Program::dump(), and enumerateData().
|
inline |
Returns the size of the object without metadata.
Definition at line 225 of file Descriptor.h.
References isUnknownSizeArray().
Referenced by clang::interp::AllocCN(), clang::interp::Pointer::elemSize(), getNumElems(), and clang::interp::Pointer::getSize().
|
inline |
Definition at line 206 of file Descriptor.h.
Referenced by clang::interp::Pointer::getSource().
QualType Descriptor::getType | ( | ) | const |
Definition at line 393 of file Descriptor.cpp.
References asDecl(), asExpr(), asValueDecl(), D, E, ElemRecord, clang::interp::Record::getDecl(), clang::Expr::getType(), clang::TypeDecl::getTypeForDecl(), isRecord(), and clang::T.
Referenced by enumerateData(), getElemQualType(), clang::interp::Pointer::getType(), and clang::interp::interp__builtin_memcmp().
|
inline |
Checks if the descriptor is of an array.
Definition at line 260 of file Descriptor.h.
References IsArray.
Referenced by getElemQualType(), clang::interp::interp__builtin_memcpy(), and clang::interp::Pointer::toAPValue().
|
inline |
Checks if the descriptor is of an array of composites.
Definition at line 250 of file Descriptor.h.
References ElemDesc, and IsArray.
Referenced by clang::interp::collectBlocks(), dump(), enumerateData(), and clang::interp::RunDestructors().
|
inline |
Checks if this is a dummy descriptor.
Definition at line 266 of file Descriptor.h.
References IsDummy.
Referenced by dump(), clang::interp::Program::dump(), clang::interp::Program::getOrCreateDummy(), and clang::interp::Pointer::isDummy().
|
inline |
Checks if the descriptor is of a primitive.
Definition at line 257 of file Descriptor.h.
References ElemRecord, and IsArray.
Referenced by clang::interp::collectBlocks(), clang::interp::copyComposite(), dump(), clang::interp::Program::dump(), enumerateData(), getPrimType(), and clang::interp::RunDestructors().
|
inline |
Checks if the descriptor is of an array of primitives.
Definition at line 248 of file Descriptor.h.
References ElemDesc, and IsArray.
Referenced by clang::interp::collectBlocks(), clang::interp::copyComposite(), dump(), enumerateData(), getElemQualType(), getPrimType(), clang::interp::Pointer::initialize(), clang::interp::Pointer::inPrimitiveArray(), clang::interp::interp__builtin_elementwise_popcount(), clang::interp::interp__builtin_nan(), clang::interp::interp__builtin_strcmp(), clang::interp::interp__builtin_strlen(), clang::interp::interp__builtin_vector_reduce(), clang::interp::Pointer::isInitialized(), and clang::interp::RunDestructors().
|
inline |
Checks if the descriptor is of a record.
Definition at line 262 of file Descriptor.h.
References ElemRecord, and IsArray.
Referenced by clang::interp::copyComposite(), clang::interp::copyRecord(), dump(), enumerateData(), getType(), isUnion(), clang::interp::RunDestructors(), and clang::interp::runRecordDestructor().
bool Descriptor::isUnion | ( | ) | const |
Checks if the descriptor is of a union.
Definition at line 446 of file Descriptor.cpp.
References ElemRecord, isRecord(), and clang::interp::Record::isUnion().
Referenced by clang::interp::Pointer::activate(), and dump().
|
inline |
Checks if the descriptor is of an array of unknown size.
Definition at line 254 of file Descriptor.h.
Referenced by dump(), getSize(), and clang::interp::Pointer::isUnknownSizeArray().
|
inline |
Checks if the descriptor is of an array of zero size.
Definition at line 252 of file Descriptor.h.
Referenced by dump().
|
inline |
Make this descriptor a dummy descriptor.
Definition at line 197 of file Descriptor.h.
References IsDummy.
Referenced by clang::interp::Program::getOrCreateDummy().
const BlockCtorFn clang::interp::Descriptor::CtorFn = nullptr |
Storage management methods.
Definition at line 165 of file Descriptor.h.
Referenced by clang::interp::Block::invokeCtor().
const BlockDtorFn clang::interp::Descriptor::DtorFn = nullptr |
Definition at line 166 of file Descriptor.h.
Referenced by clang::interp::Block::invokeDtor().
const Descriptor* const clang::interp::Descriptor::ElemDesc = nullptr |
Descriptor of the array element.
Definition at line 148 of file Descriptor.h.
Referenced by clang::interp::Pointer::getElemRecord(), isCompositeArray(), isPrimitiveArray(), and clang::interp::RunDestructors().
const Record* const clang::interp::Descriptor::ElemRecord = nullptr |
Pointer to the record, if block contains records.
Definition at line 146 of file Descriptor.h.
Referenced by clang::interp::IntPointer::atOffset(), clang::interp::IntPointer::baseCast(), clang::interp::collectBlocks(), clang::interp::copyRecord(), enumerateData(), clang::interp::Pointer::getElemRecord(), clang::interp::Pointer::getRecord(), getType(), isPrimitive(), isRecord(), isUnion(), and clang::interp::runRecordDestructor().
|
staticconstexpr |
Definition at line 138 of file Descriptor.h.
Referenced by clang::interp::Program::createGlobalString().
|
staticconstexpr |
Definition at line 137 of file Descriptor.h.
Referenced by clang::interp::DynamicAllocator::allocate(), clang::interp::Compiler< Emitter >::allocateLocal(), clang::interp::Compiler< Emitter >::allocateLocalPrimitive(), clang::interp::Compiler< Emitter >::allocateTemporary(), clang::interp::interp__builtin_operator_new(), clang::interp::Compiler< Emitter >::VisitCastExpr(), and clang::interp::Compiler< Emitter >::VisitCXXNewExpr().
Flag indicating if the block is an array.
Definition at line 160 of file Descriptor.h.
Referenced by clang::interp::Pointer::expand(), clang::interp::Pointer::hasSameArray(), clang::interp::Pointer::inArray(), isArray(), isCompositeArray(), isPrimitive(), isPrimitiveArray(), and isRecord().
Flag indicating if the block is mutable.
Definition at line 154 of file Descriptor.h.
Referenced by clang::interp::Block::invokeCtor(), and clang::interp::Pointer::isConst().
Flag indicating if this is a dummy descriptor.
Definition at line 162 of file Descriptor.h.
Referenced by isDummy(), and makeDummy().
Flag indicating if a field is mutable.
Definition at line 156 of file Descriptor.h.
Referenced by clang::interp::Block::invokeCtor().
Flag indicating if the block is a temporary.
Definition at line 158 of file Descriptor.h.
Referenced by clang::interp::Program::dump(), and clang::interp::Block::isTemporary().
|
staticconstexpr |
Maximum number of bytes to be used for array elements.
Definition at line 141 of file Descriptor.h.
Referenced by clang::interp::CheckArraySize(), Descriptor(), and clang::interp::interp__builtin_operator_new().
const BlockMoveFn clang::interp::Descriptor::MoveFn = nullptr |
Definition at line 167 of file Descriptor.h.
Referenced by clang::interp::InterpState::deallocate().
const std::optional<PrimType> clang::interp::Descriptor::PrimT = std::nullopt |
The primitive type this descriptor was created for, or the primitive element type in case this is a primitive array.
Definition at line 152 of file Descriptor.h.
Referenced by getPrimType().