31#include "llvm/Config/llvm-config.h"
95 cl::desc(
"Print addresses of instructions when dumping"));
99 cl::desc(
"Pretty print debug locations of instructions when dumping"));
103 cl::desc(
"Pretty print perf data (branch weights, etc) when dumping"));
122 return VAM->getValue();
135 for (
const Value *
Op :
C->operands())
142 unsigned ID = OM.size() + 1;
149 auto orderConstantValue = [&OM](
const Value *V) {
154 auto OrderConstantFromMetadata = [&](
Metadata *MD) {
156 orderConstantValue(VAM->getValue());
158 for (
const auto *VAM : AL->getArgs())
159 orderConstantValue(VAM->getValue());
164 if (
G.hasInitializer())
180 for (
const Use &U :
F.operands())
186 if (
F.isDeclaration())
199 OrderConstantFromMetadata(DVR.getRawLocation());
200 if (DVR.isDbgAssign())
201 OrderConstantFromMetadata(DVR.getRawAddress());
204 for (
const Value *
Op :
I.operands()) {
217static std::vector<unsigned>
220 using Entry = std::pair<const Use *, unsigned>;
224 if (OM.lookup(U.getUser()))
225 List.
push_back(std::make_pair(&U, List.size()));
236 ID = OM.lookup(BA->getBasicBlock());
237 llvm::sort(List, [&](
const Entry &L,
const Entry &R) {
238 const Use *LU = L.first;
239 const Use *RU = R.first;
243 auto LID = OM.lookup(LU->getUser());
244 auto RID = OM.lookup(RU->getUser());
264 return LU->getOperandNo() < RU->getOperandNo();
265 return LU->getOperandNo() > RU->getOperandNo();
273 std::vector<unsigned> Shuffle(List.size());
274 for (
size_t I = 0,
E = List.size();
I !=
E; ++
I)
275 Shuffle[
I] = List[
I].second;
282 for (
const auto &Pair : OM) {
283 const Value *V = Pair.first;
284 if (V->use_empty() || std::next(V->use_begin()) == V->use_end())
287 std::vector<unsigned> Shuffle =
294 F =
I->getFunction();
299 ULOM[
F][V] = std::move(Shuffle);
306 return MA->getParent() ? MA->getParent()->getParent() :
nullptr;
309 return BB->getParent() ? BB->getParent()->getParent() :
nullptr;
312 const Function *M =
I->getParent() ?
I->getParent()->getParent() :
nullptr;
313 return M ? M->getParent() :
nullptr;
317 return GV->getParent();
342 default: Out <<
"cc" << cc;
break;
365 Out <<
"aarch64_sve_vector_pcs";
368 Out <<
"aarch64_sme_preservemost_from_x0";
371 Out <<
"aarch64_sme_preservemost_from_x1";
374 Out <<
"aarch64_sme_preservemost_from_x2";
402 Out <<
"amdgpu_cs_chain";
405 Out <<
"amdgpu_cs_chain_preserve";
410 Out <<
"amdgpu_gfx_whole_wave";
414 Out <<
"riscv_vector_cc";
416#define CC_VLS_CASE(ABI_VLEN) \
417 case CallingConv::RISCV_VLSCall_##ABI_VLEN: \
418 Out << "riscv_vls_cc(" #ABI_VLEN ")"; \
434 Out <<
"cheriot_compartmentcallcc";
437 Out <<
"cheriot_compartmentcalleecc";
440 Out <<
"cheriot_librarycallcc";
454 assert(!Name.empty() &&
"Cannot get empty name!");
457 bool NeedsQuotes = isdigit(
static_cast<unsigned char>(Name[0]));
459 for (
unsigned char C : Name) {
464 if (!isalnum(
C) &&
C !=
'-' &&
C !=
'.' &&
C !=
'_') {
518 Out << Mask.size() <<
" x i32> ";
519 if (
all_of(Mask, [](
int Elt) {
return Elt == 0; })) {
520 Out <<
"zeroinitializer";
526 for (
int Elt : Mask) {
541 TypePrinting(
const Module *M =
nullptr) : DeferredM(
M) {}
543 TypePrinting(
const TypePrinting &) =
delete;
544 TypePrinting &operator=(
const TypePrinting &) =
delete;
547 TypeFinder &getNamedTypes();
550 std::vector<StructType *> &getNumberedTypes();
556 void printStructBody(StructType *Ty, raw_ostream &OS);
559 void incorporateTypes();
564 TypeFinder NamedTypes;
567 DenseMap<StructType *, unsigned> Type2Number;
569 std::vector<StructType *> NumberedTypes;
579std::vector<StructType *> &TypePrinting::getNumberedTypes() {
585 if (NumberedTypes.size() == Type2Number.size())
586 return NumberedTypes;
588 NumberedTypes.resize(Type2Number.size());
589 for (
const auto &
P : Type2Number) {
590 assert(
P.second < NumberedTypes.size() &&
"Didn't get a dense numbering?");
591 assert(!NumberedTypes[
P.second] &&
"Didn't get a unique numbering?");
592 NumberedTypes[
P.second] =
P.first;
594 return NumberedTypes;
597bool TypePrinting::empty() {
599 return NamedTypes.
empty() && Type2Number.empty();
602void TypePrinting::incorporateTypes() {
606 NamedTypes.
run(*DeferredM,
false);
611 unsigned NextNumber = 0;
613 std::vector<StructType *>::iterator NextToUse = NamedTypes.
begin();
614 for (StructType *STy : NamedTypes) {
616 if (STy->isLiteral())
619 if (STy->getName().empty())
620 Type2Number[STy] = NextNumber++;
625 NamedTypes.erase(NextToUse, NamedTypes.end());
630void TypePrinting::print(
Type *Ty, raw_ostream &OS) {
632 case Type::VoidTyID: OS <<
"void";
return;
633 case Type::HalfTyID: OS <<
"half";
return;
634 case Type::BFloatTyID: OS <<
"bfloat";
return;
635 case Type::FloatTyID: OS <<
"float";
return;
636 case Type::DoubleTyID: OS <<
"double";
return;
637 case Type::X86_FP80TyID: OS <<
"x86_fp80";
return;
638 case Type::FP128TyID: OS <<
"fp128";
return;
639 case Type::PPC_FP128TyID: OS <<
"ppc_fp128";
return;
640 case Type::LabelTyID: OS <<
"label";
return;
641 case Type::MetadataTyID:
644 case Type::X86_AMXTyID: OS <<
"x86_amx";
return;
645 case Type::TokenTyID: OS <<
"token";
return;
646 case Type::IntegerTyID:
647 OS << 'i' << cast<IntegerType>(Ty)->getBitWidth();
650 case Type::FunctionTyID: {
652 print(FTy->getReturnType(), OS);
655 for (
Type *Ty : FTy->params()) {
664 case Type::StructTyID: {
668 return printStructBody(STy, OS);
674 const auto I = Type2Number.find(STy);
675 if (
I != Type2Number.end())
676 OS <<
'%' <<
I->second;
678 OS <<
"%\"type " << STy <<
'\"';
681 case Type::PointerTyID: {
688 case Type::ArrayTyID: {
690 OS <<
'[' << ATy->getNumElements() <<
" x ";
691 print(ATy->getElementType(), OS);
695 case Type::FixedVectorTyID:
696 case Type::ScalableVectorTyID: {
698 ElementCount
EC = PTy->getElementCount();
702 OS <<
EC.getKnownMinValue() <<
" x ";
703 print(PTy->getElementType(), OS);
707 case Type::TypedPointerTyID: {
713 case Type::TargetExtTyID:
720 Inner->print(OS,
false,
true);
723 OS <<
", " << IntParam;
730void TypePrinting::printStructBody(StructType *STy, raw_ostream &OS) {
774 const Function* TheFunction =
nullptr;
775 bool FunctionProcessed =
false;
776 bool ShouldInitializeAllMetadata;
781 ProcessFunctionHookFn;
796 unsigned mdnNext = 0;
804 unsigned ModulePathNext = 0;
808 unsigned GUIDNext = 0;
812 unsigned TypeIdNext = 0;
817 unsigned TypeIdCompatibleVtableNext = 0;
826 bool ShouldInitializeAllMetadata =
false);
834 bool ShouldInitializeAllMetadata =
false);
851 void createMetadataSlot(
const MDNode *
N)
override;
855 int getLocalSlot(
const Value *V);
857 int getMetadataSlot(
const MDNode *
N)
override;
862 int getTypeIdCompatibleVtableSlot(
StringRef Id);
868 FunctionProcessed =
false;
876 void purgeFunction();
883 unsigned mdn_size()
const {
return mdnMap.size(); }
891 unsigned as_size()
const {
return asMap.size(); }
907 void CreateMetadataSlot(
const MDNode *
N);
910 void CreateFunctionSlot(
const Value *V);
915 inline void CreateModulePathSlot(
StringRef Path);
918 void CreateTypeIdCompatibleVtableSlot(
StringRef Id);
922 void processModule();
930 void processGlobalObjectMetadata(
const GlobalObject &GO);
933 void processFunctionMetadata(
const Function &
F);
939 void processDbgRecordMetadata(
const DbgRecord &DVR);
946 : M(M), F(F), Machine(&Machine) {}
949 bool ShouldInitializeAllMetadata)
950 : ShouldCreateStorage(M),
951 ShouldInitializeAllMetadata(ShouldInitializeAllMetadata), M(M) {}
956 if (!ShouldCreateStorage)
959 ShouldCreateStorage =
false;
961 std::make_unique<SlotTracker>(M, ShouldInitializeAllMetadata);
962 Machine = MachineStorage.get();
963 if (ProcessModuleHookFn)
964 Machine->setProcessHook(ProcessModuleHookFn);
965 if (ProcessFunctionHookFn)
966 Machine->setProcessHook(ProcessFunctionHookFn);
979 Machine->purgeFunction();
980 Machine->incorporateFunction(&F);
985 assert(F &&
"No function incorporated");
986 return Machine->getLocalSlot(V);
992 ProcessModuleHookFn = Fn;
998 ProcessFunctionHookFn = Fn;
1028#define ST_DEBUG(X) dbgs() << X
1036 : TheModule(M), ShouldInitializeAllMetadata(ShouldInitializeAllMetadata) {}
1041 : TheModule(
F ?
F->
getParent() : nullptr), TheFunction(
F),
1042 ShouldInitializeAllMetadata(ShouldInitializeAllMetadata) {}
1045 : TheModule(nullptr), ShouldInitializeAllMetadata(
false), TheIndex(Index) {}
1050 TheModule =
nullptr;
1053 if (TheFunction && !FunctionProcessed)
1060 int NumSlots = processIndex();
1067void SlotTracker::processModule() {
1068 ST_DEBUG(
"begin processModule!\n");
1073 CreateModuleSlot(&Var);
1074 processGlobalObjectMetadata(Var);
1075 auto Attrs = Var.getAttributes();
1076 if (Attrs.hasAttributes())
1077 CreateAttributeSetSlot(Attrs);
1082 CreateModuleSlot(&
A);
1085 for (
const GlobalIFunc &
I : TheModule->ifuncs()) {
1087 CreateModuleSlot(&
I);
1088 processGlobalObjectMetadata(
I);
1092 for (
const NamedMDNode &NMD : TheModule->named_metadata()) {
1093 for (
const MDNode *
N : NMD.operands())
1094 CreateMetadataSlot(
N);
1097 for (
const Function &
F : *TheModule) {
1100 CreateModuleSlot(&
F);
1102 if (ShouldInitializeAllMetadata)
1103 processFunctionMetadata(
F);
1107 AttributeSet FnAttrs =
F.getAttributes().getFnAttrs();
1109 CreateAttributeSetSlot(FnAttrs);
1112 if (ProcessModuleHookFn)
1113 ProcessModuleHookFn(
this, TheModule, ShouldInitializeAllMetadata);
1119void SlotTracker::processFunction() {
1120 ST_DEBUG(
"begin processFunction!\n");
1124 if (!ShouldInitializeAllMetadata)
1125 processFunctionMetadata(*TheFunction);
1129 AE = TheFunction->arg_end(); AI != AE; ++AI)
1131 CreateFunctionSlot(&*AI);
1133 ST_DEBUG(
"Inserting Instructions:\n");
1136 for (
auto &BB : *TheFunction) {
1138 CreateFunctionSlot(&BB);
1140 for (
auto &
I : BB) {
1141 if (!
I.getType()->isVoidTy() && !
I.hasName())
1142 CreateFunctionSlot(&
I);
1149 if (
Attrs.hasAttributes())
1150 CreateAttributeSetSlot(Attrs);
1155 if (ProcessFunctionHookFn)
1156 ProcessFunctionHookFn(
this, TheFunction, ShouldInitializeAllMetadata);
1158 FunctionProcessed =
true;
1160 ST_DEBUG(
"end processFunction!\n");
1164int SlotTracker::processIndex() {
1171 std::vector<StringRef> ModulePaths;
1172 for (
auto &[ModPath,
_] : TheIndex->modulePaths())
1173 ModulePaths.push_back(ModPath);
1175 for (
auto &ModPath : ModulePaths)
1176 CreateModulePathSlot(ModPath);
1179 GUIDNext = ModulePathNext;
1181 for (
auto &GlobalList : *TheIndex)
1182 CreateGUIDSlot(GlobalList.first);
1185 TypeIdCompatibleVtableNext = GUIDNext;
1186 for (
auto &TId : TheIndex->typeIdCompatibleVtableMap())
1187 CreateTypeIdCompatibleVtableSlot(TId.first);
1190 TypeIdNext = TypeIdCompatibleVtableNext;
1191 for (
const auto &TID : TheIndex->typeIds())
1192 CreateTypeIdSlot(TID.second.first);
1198void SlotTracker::processGlobalObjectMetadata(
const GlobalObject &GO) {
1201 for (
auto &MD : MDs)
1202 CreateMetadataSlot(MD.second);
1205void SlotTracker::processFunctionMetadata(
const Function &
F) {
1206 processGlobalObjectMetadata(
F);
1207 for (
auto &BB :
F) {
1208 for (
auto &
I : BB) {
1209 for (
const DbgRecord &DR :
I.getDbgRecordRange())
1210 processDbgRecordMetadata(DR);
1211 processInstructionMetadata(
I);
1216void SlotTracker::processDbgRecordMetadata(
const DbgRecord &DR) {
1227 CreateMetadataSlot(
Empty);
1228 if (DVR->getRawVariable())
1229 CreateMetadataSlot(DVR->getRawVariable());
1230 if (DVR->isDbgAssign()) {
1231 if (
auto *AssignID = DVR->getRawAssignID())
1234 CreateMetadataSlot(
Empty);
1237 CreateMetadataSlot(DLR->getRawLabel());
1245void SlotTracker::processInstructionMetadata(
const Instruction &
I) {
1248 if (Function *
F = CI->getCalledFunction())
1249 if (
F->isIntrinsic())
1250 for (
auto &
Op :
I.operands())
1253 CreateMetadataSlot(
N);
1257 I.getAllMetadata(MDs);
1258 for (
auto &MD : MDs)
1259 CreateMetadataSlot(MD.second);
1266 ST_DEBUG(
"begin purgeFunction!\n");
1268 TheFunction =
nullptr;
1269 FunctionProcessed =
false;
1280 return MI == mMap.end() ? -1 : (int)
MI->second;
1286 ProcessModuleHookFn = Fn;
1292 ProcessFunctionHookFn = Fn;
1305 return MI == mdnMap.end() ? -1 : (int)
MI->second;
1316 return FI == fMap.end() ? -1 : (int)FI->second;
1325 return AI == asMap.end() ? -1 : (int)AI->second;
1333 auto I = ModulePathMap.find(Path);
1334 return I == ModulePathMap.end() ? -1 : (int)
I->second;
1343 return I == GUIDMap.end() ? -1 : (int)
I->second;
1351 auto I = TypeIdMap.find(Id);
1352 return I == TypeIdMap.end() ? -1 : (int)
I->second;
1360 auto I = TypeIdCompatibleVtableMap.find(Id);
1361 return I == TypeIdCompatibleVtableMap.end() ? -1 : (int)
I->second;
1365void SlotTracker::CreateModuleSlot(
const GlobalValue *V) {
1366 assert(V &&
"Can't insert a null Value into SlotTracker!");
1367 assert(!V->getType()->isVoidTy() &&
"Doesn't need a slot!");
1368 assert(!V->hasName() &&
"Doesn't need a slot!");
1370 unsigned DestSlot = mNext++;
1373 ST_DEBUG(
" Inserting value [" << V->getType() <<
"] = " << V <<
" slot=" <<
1383void SlotTracker::CreateFunctionSlot(
const Value *V) {
1384 assert(!V->getType()->isVoidTy() && !V->hasName() &&
"Doesn't need a slot!");
1386 unsigned DestSlot = fNext++;
1390 ST_DEBUG(
" Inserting value [" << V->getType() <<
"] = " << V <<
" slot=" <<
1391 DestSlot <<
" [o]\n");
1395void SlotTracker::CreateMetadataSlot(
const MDNode *
N) {
1396 assert(
N &&
"Can't insert a null Value into SlotTracker!");
1402 unsigned DestSlot = mdnNext;
1403 if (!mdnMap.insert(std::make_pair(
N, DestSlot)).second)
1408 for (
unsigned i = 0, e =
N->getNumOperands(); i != e; ++i)
1410 CreateMetadataSlot(
Op);
1413void SlotTracker::CreateAttributeSetSlot(
AttributeSet AS) {
1416 if (asMap.try_emplace(AS, asNext).second)
1421void SlotTracker::CreateModulePathSlot(
StringRef Path) {
1422 ModulePathMap[
Path] = ModulePathNext++;
1427 GUIDMap[
GUID] = GUIDNext++;
1431void SlotTracker::CreateTypeIdSlot(
StringRef Id) {
1432 TypeIdMap[
Id] = TypeIdNext++;
1436void SlotTracker::CreateTypeIdCompatibleVtableSlot(
StringRef Id) {
1437 TypeIdCompatibleVtableMap[
Id] = TypeIdCompatibleVtableNext++;
1442struct AsmWriterContext {
1443 TypePrinting *TypePrinter =
nullptr;
1444 SlotTracker *
Machine =
nullptr;
1447 AsmWriterContext(TypePrinting *TP, SlotTracker *ST,
const Module *M =
nullptr)
1450 static AsmWriterContext &getEmpty() {
1451 static AsmWriterContext EmptyCtx(
nullptr,
nullptr);
1457 virtual void onWriteMetadataAsOperand(
const Metadata *) {}
1459 virtual ~AsmWriterContext() =
default;
1468 AsmWriterContext &WriterCtx,
1469 bool PrintType =
false);
1472 AsmWriterContext &WriterCtx,
1473 bool FromValue =
false);
1477 Out << FPO->getFastMathFlags();
1481 if (OBO->hasNoUnsignedWrap())
1483 if (OBO->hasNoSignedWrap())
1491 if (PDI->isDisjoint())
1494 if (
GEP->isInBounds())
1496 else if (
GEP->hasNoUnsignedSignedWrap())
1498 if (
GEP->hasNoUnsignedWrap())
1501 Out <<
" inrange(" <<
InRange->getLower() <<
", " <<
InRange->getUpper()
1505 if (NNI->hasNonNeg())
1508 if (TI->hasNoUnsignedWrap())
1510 if (TI->hasNoSignedWrap())
1513 if (ICmp->hasSameSign())
1529 bool isNaN = APF.
isNaN();
1531 if (!isInf && !isNaN) {
1540 ((StrVal[0] ==
'-' || StrVal[0] ==
'+') &&
isDigit(StrVal[1]))) &&
1541 "[-+]?[0-9] regex does not match!");
1553 static_assert(
sizeof(double) ==
sizeof(
uint64_t),
1554 "assuming that double is 64 bits!");
1612 AsmWriterContext &WriterCtx) {
1614 Type *Ty = CI->getType();
1616 if (Ty->isVectorTy()) {
1618 WriterCtx.TypePrinter->print(Ty->getScalarType(), Out);
1622 if (Ty->getScalarType()->isIntegerTy(1))
1623 Out << (CI->getZExtValue() ?
"true" :
"false");
1625 Out << CI->getValue();
1627 if (Ty->isVectorTy())
1634 Type *Ty = CFP->getType();
1636 if (Ty->isVectorTy()) {
1638 WriterCtx.TypePrinter->print(Ty->getScalarType(), Out);
1644 if (Ty->isVectorTy())
1651 Out <<
"zeroinitializer";
1656 Out <<
"blockaddress(";
1665 Out <<
"dso_local_equivalent ";
1680 unsigned NumOpsToWrite = 2;
1681 if (!CPA->getOperand(2)->isNullValue())
1683 if (!CPA->getOperand(3)->isNullValue())
1687 for (
unsigned i = 0, e = NumOpsToWrite; i != e; ++i) {
1699 for (
const Value *
Op : CA->operands()) {
1710 if (CA->isString()) {
1719 for (
uint64_t i = 0, e = CA->getNumElements(); i != e; ++i) {
1729 if (CS->getType()->isPacked())
1732 if (CS->getNumOperands() != 0) {
1735 for (
const Value *
Op : CS->operands()) {
1742 if (CS->getType()->isPacked())
1766 for (
unsigned i = 0, e = CVVTy->getNumElements(); i != e; ++i) {
1801 if (CE->getOpcode() == Instruction::ShuffleVector) {
1802 if (
auto *SplatVal = CE->getSplatValue()) {
1812 Out << CE->getOpcodeName();
1817 WriterCtx.TypePrinter->print(
GEP->getSourceElementType(), Out);
1822 for (
const Value *
Op : CE->operands()) {
1829 WriterCtx.TypePrinter->print(CE->getType(), Out);
1832 if (CE->getOpcode() == Instruction::ShuffleVector)
1839 Out <<
"<placeholder or erroneous Constant>";
1843 AsmWriterContext &WriterCtx) {
1851 Value *V = MDV->getValue();
1855 WriterCtx.onWriteMetadataAsOperand(MD);
1864struct MDFieldPrinter {
1867 AsmWriterContext &WriterCtx;
1869 explicit MDFieldPrinter(raw_ostream &Out)
1870 : Out(Out), WriterCtx(AsmWriterContext::getEmpty()) {}
1871 MDFieldPrinter(raw_ostream &Out, AsmWriterContext &Ctx)
1872 : Out(Out), WriterCtx(Ctx) {}
1874 void printTag(
const DINode *
N);
1875 void printMacinfoType(
const DIMacroNode *
N);
1876 void printChecksum(
const DIFile::ChecksumInfo<StringRef> &
N);
1877 void printString(StringRef Name, StringRef
Value,
1878 bool ShouldSkipEmpty =
true);
1879 void printMetadata(StringRef Name,
const Metadata *MD,
1880 bool ShouldSkipNull =
true);
1881 void printMetadataOrInt(StringRef Name,
const Metadata *MD,
bool IsUnsigned,
1882 bool ShouldSkipZero =
true);
1883 template <
class IntTy>
1884 void printInt(StringRef Name, IntTy
Int,
bool ShouldSkipZero =
true);
1885 void printAPInt(StringRef Name,
const APInt &
Int,
bool IsUnsigned,
1886 bool ShouldSkipZero);
1887 void printBool(StringRef Name,
bool Value,
1888 std::optional<bool>
Default = std::nullopt);
1891 template <
class IntTy,
class Stringifier>
1892 void printDwarfEnum(StringRef Name, IntTy
Value, Stringifier
toString,
1893 bool ShouldSkipZero =
true);
1895 void printNameTableKind(StringRef Name,
1902void MDFieldPrinter::printTag(
const DINode *
N) {
1903 Out <<
FS <<
"tag: ";
1911void MDFieldPrinter::printMacinfoType(
const DIMacroNode *
N) {
1912 Out <<
FS <<
"type: ";
1917 Out <<
N->getMacinfoType();
1920void MDFieldPrinter::printChecksum(
1923 printString(
"checksum", Checksum.
Value,
false);
1927 bool ShouldSkipEmpty) {
1928 if (ShouldSkipEmpty &&
Value.empty())
1931 Out <<
FS <<
Name <<
": \"";
1937 AsmWriterContext &WriterCtx) {
1943 WriterCtx.onWriteMetadataAsOperand(MD);
1947 bool ShouldSkipNull) {
1948 if (ShouldSkipNull && !MD)
1951 Out <<
FS <<
Name <<
": ";
1956 bool IsUnsigned,
bool ShouldSkipZero) {
1963 printInt(Name, CV->getZExtValue(), ShouldSkipZero);
1965 printInt(Name, CV->getSExtValue(), ShouldSkipZero);
1967 printMetadata(Name, MD);
1970template <
class IntTy>
1971void MDFieldPrinter::printInt(
StringRef Name, IntTy
Int,
bool ShouldSkipZero) {
1972 if (ShouldSkipZero && !
Int)
1979 bool IsUnsigned,
bool ShouldSkipZero) {
1980 if (ShouldSkipZero &&
Int.isZero())
1983 Out <<
FS <<
Name <<
": ";
1984 Int.print(Out, !IsUnsigned);
1988 std::optional<bool>
Default) {
1991 Out <<
FS <<
Name <<
": " << (
Value ?
"true" :
"false");
1998 Out <<
FS <<
Name <<
": ";
2004 for (
auto F : SplitFlags) {
2006 assert(!StringF.empty() &&
"Expected valid flag");
2007 Out << FlagsFS << StringF;
2009 if (Extra || SplitFlags.empty())
2010 Out << FlagsFS << Extra;
2013void MDFieldPrinter::printDISPFlags(
StringRef Name,
2017 Out <<
FS <<
Name <<
": ";
2028 for (
auto F : SplitFlags) {
2030 assert(!StringF.empty() &&
"Expected valid flag");
2031 Out << FlagsFS << StringF;
2033 if (Extra || SplitFlags.empty())
2034 Out << FlagsFS << Extra;
2037void MDFieldPrinter::printEmissionKind(
StringRef Name,
2042void MDFieldPrinter::printNameTableKind(
StringRef Name,
2049void MDFieldPrinter::printFixedPointKind(
StringRef Name,
2054template <
class IntTy,
class Stringifier>
2056 Stringifier
toString,
bool ShouldSkipZero) {
2057 if (ShouldSkipZero && !
Value)
2060 Out <<
FS <<
Name <<
": ";
2069 AsmWriterContext &WriterCtx) {
2070 Out <<
"!GenericDINode(";
2071 MDFieldPrinter
Printer(Out, WriterCtx);
2073 Printer.printString(
"header",
N->getHeader());
2074 if (
N->getNumDwarfOperands()) {
2075 Out <<
Printer.FS <<
"operands: {";
2077 for (
auto &
I :
N->dwarf_operands()) {
2087 AsmWriterContext &WriterCtx) {
2088 Out <<
"!DILocation(";
2089 MDFieldPrinter
Printer(Out, WriterCtx);
2091 Printer.printInt(
"line",
DL->getLine(),
false);
2092 Printer.printInt(
"column",
DL->getColumn());
2093 Printer.printMetadata(
"scope",
DL->getRawScope(),
false);
2094 Printer.printMetadata(
"inlinedAt",
DL->getRawInlinedAt());
2095 Printer.printBool(
"isImplicitCode",
DL->isImplicitCode(),
2097 Printer.printInt(
"atomGroup",
DL->getAtomGroup());
2098 Printer.printInt<
unsigned>(
"atomRank",
DL->getAtomRank());
2103 AsmWriterContext &WriterCtx) {
2104 Out <<
"!DIAssignID()";
2105 MDFieldPrinter
Printer(Out, WriterCtx);
2109 AsmWriterContext &WriterCtx) {
2110 Out <<
"!DISubrange(";
2111 MDFieldPrinter
Printer(Out, WriterCtx);
2113 Printer.printMetadataOrInt(
"count",
N->getRawCountNode(),
2119 Printer.printMetadataOrInt(
"lowerBound",
N->getRawLowerBound(),
2122 Printer.printMetadataOrInt(
"upperBound",
N->getRawUpperBound(),
2125 Printer.printMetadataOrInt(
"stride",
N->getRawStride(),
2133 AsmWriterContext &WriterCtx) {
2134 Out <<
"!DIGenericSubrange(";
2135 MDFieldPrinter
Printer(Out, WriterCtx);
2137 auto GetConstant = [&](
Metadata *Bound) -> std::optional<int64_t> {
2140 return std::nullopt;
2141 if (BE->isConstant() &&
2143 *BE->isConstant()) {
2144 return static_cast<int64_t
>(BE->getElement(1));
2146 return std::nullopt;
2149 auto *
Count =
N->getRawCountNode();
2150 if (
auto ConstantCount = GetConstant(
Count))
2151 Printer.printInt(
"count", *ConstantCount,
2156 auto *LBound =
N->getRawLowerBound();
2157 if (
auto ConstantLBound = GetConstant(LBound))
2158 Printer.printInt(
"lowerBound", *ConstantLBound,
2161 Printer.printMetadata(
"lowerBound", LBound,
true);
2163 auto *UBound =
N->getRawUpperBound();
2164 if (
auto ConstantUBound = GetConstant(UBound))
2165 Printer.printInt(
"upperBound", *ConstantUBound,
2168 Printer.printMetadata(
"upperBound", UBound,
true);
2170 auto *Stride =
N->getRawStride();
2171 if (
auto ConstantStride = GetConstant(Stride))
2172 Printer.printInt(
"stride", *ConstantStride,
2175 Printer.printMetadata(
"stride", Stride,
true);
2181 AsmWriterContext &) {
2182 Out <<
"!DIEnumerator(";
2184 Printer.printString(
"name",
N->getName(),
false);
2185 Printer.printAPInt(
"value",
N->getValue(),
N->isUnsigned(),
2187 if (
N->isUnsigned())
2188 Printer.printBool(
"isUnsigned",
true);
2193 AsmWriterContext &WriterCtx) {
2194 Out <<
"!DIBasicType(";
2195 MDFieldPrinter
Printer(Out, WriterCtx);
2196 if (
N->getTag() != dwarf::DW_TAG_base_type)
2198 Printer.printString(
"name",
N->getName());
2199 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2200 Printer.printInt(
"align",
N->getAlignInBits());
2201 Printer.printDwarfEnum(
"encoding",
N->getEncoding(),
2203 Printer.printInt(
"num_extra_inhabitants",
N->getNumExtraInhabitants());
2204 Printer.printDIFlags(
"flags",
N->getFlags());
2209 AsmWriterContext &WriterCtx) {
2210 Out <<
"!DIFixedPointType(";
2211 MDFieldPrinter
Printer(Out, WriterCtx);
2212 if (
N->getTag() != dwarf::DW_TAG_base_type)
2214 Printer.printString(
"name",
N->getName());
2215 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2216 Printer.printInt(
"align",
N->getAlignInBits());
2217 Printer.printDwarfEnum(
"encoding",
N->getEncoding(),
2219 Printer.printDIFlags(
"flags",
N->getFlags());
2220 Printer.printFixedPointKind(
"kind",
N->getKind());
2221 if (
N->isRational()) {
2222 bool IsUnsigned = !
N->isSigned();
2223 Printer.printAPInt(
"numerator",
N->getNumerator(), IsUnsigned,
false);
2224 Printer.printAPInt(
"denominator",
N->getDenominator(), IsUnsigned,
false);
2226 Printer.printInt(
"factor",
N->getFactor());
2232 AsmWriterContext &WriterCtx) {
2233 Out <<
"!DIStringType(";
2234 MDFieldPrinter
Printer(Out, WriterCtx);
2235 if (
N->getTag() != dwarf::DW_TAG_string_type)
2237 Printer.printString(
"name",
N->getName());
2238 Printer.printMetadata(
"stringLength",
N->getRawStringLength());
2239 Printer.printMetadata(
"stringLengthExpression",
N->getRawStringLengthExp());
2240 Printer.printMetadata(
"stringLocationExpression",
2241 N->getRawStringLocationExp());
2242 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2243 Printer.printInt(
"align",
N->getAlignInBits());
2244 Printer.printDwarfEnum(
"encoding",
N->getEncoding(),
2250 AsmWriterContext &WriterCtx) {
2251 Out <<
"!DIDerivedType(";
2252 MDFieldPrinter
Printer(Out, WriterCtx);
2254 Printer.printString(
"name",
N->getName());
2255 Printer.printMetadata(
"scope",
N->getRawScope());
2256 Printer.printMetadata(
"file",
N->getRawFile());
2257 Printer.printInt(
"line",
N->getLine());
2258 Printer.printMetadata(
"baseType",
N->getRawBaseType(),
2260 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2261 Printer.printInt(
"align",
N->getAlignInBits());
2262 Printer.printMetadataOrInt(
"offset",
N->getRawOffsetInBits(),
true);
2263 Printer.printDIFlags(
"flags",
N->getFlags());
2264 Printer.printMetadata(
"extraData",
N->getRawExtraData());
2265 if (
const auto &DWARFAddressSpace =
N->getDWARFAddressSpace())
2266 Printer.printInt(
"dwarfAddressSpace", *DWARFAddressSpace,
2268 Printer.printMetadata(
"annotations",
N->getRawAnnotations());
2269 if (
auto PtrAuthData =
N->getPtrAuthData()) {
2270 Printer.printInt(
"ptrAuthKey", PtrAuthData->key());
2271 Printer.printBool(
"ptrAuthIsAddressDiscriminated",
2272 PtrAuthData->isAddressDiscriminated());
2273 Printer.printInt(
"ptrAuthExtraDiscriminator",
2274 PtrAuthData->extraDiscriminator());
2275 Printer.printBool(
"ptrAuthIsaPointer", PtrAuthData->isaPointer());
2276 Printer.printBool(
"ptrAuthAuthenticatesNullValues",
2277 PtrAuthData->authenticatesNullValues());
2283 AsmWriterContext &WriterCtx) {
2284 Out <<
"!DISubrangeType(";
2285 MDFieldPrinter
Printer(Out, WriterCtx);
2286 Printer.printString(
"name",
N->getName());
2287 Printer.printMetadata(
"scope",
N->getRawScope());
2288 Printer.printMetadata(
"file",
N->getRawFile());
2289 Printer.printInt(
"line",
N->getLine());
2290 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2291 Printer.printInt(
"align",
N->getAlignInBits());
2292 Printer.printDIFlags(
"flags",
N->getFlags());
2293 Printer.printMetadata(
"baseType",
N->getRawBaseType(),
2295 Printer.printMetadata(
"lowerBound",
N->getRawLowerBound());
2296 Printer.printMetadata(
"upperBound",
N->getRawUpperBound());
2297 Printer.printMetadata(
"stride",
N->getRawStride());
2298 Printer.printMetadata(
"bias",
N->getRawBias());
2303 AsmWriterContext &WriterCtx) {
2304 Out <<
"!DICompositeType(";
2305 MDFieldPrinter
Printer(Out, WriterCtx);
2307 Printer.printString(
"name",
N->getName());
2308 Printer.printMetadata(
"scope",
N->getRawScope());
2309 Printer.printMetadata(
"file",
N->getRawFile());
2310 Printer.printInt(
"line",
N->getLine());
2311 Printer.printMetadata(
"baseType",
N->getRawBaseType());
2312 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2313 Printer.printInt(
"align",
N->getAlignInBits());
2314 Printer.printMetadataOrInt(
"offset",
N->getRawOffsetInBits(),
true);
2315 Printer.printInt(
"num_extra_inhabitants",
N->getNumExtraInhabitants());
2316 Printer.printDIFlags(
"flags",
N->getFlags());
2317 Printer.printMetadata(
"elements",
N->getRawElements());
2318 Printer.printDwarfEnum(
"runtimeLang",
N->getRuntimeLang(),
2320 Printer.printMetadata(
"vtableHolder",
N->getRawVTableHolder());
2321 Printer.printMetadata(
"templateParams",
N->getRawTemplateParams());
2322 Printer.printString(
"identifier",
N->getIdentifier());
2323 Printer.printMetadata(
"discriminator",
N->getRawDiscriminator());
2324 Printer.printMetadata(
"dataLocation",
N->getRawDataLocation());
2325 Printer.printMetadata(
"associated",
N->getRawAssociated());
2326 Printer.printMetadata(
"allocated",
N->getRawAllocated());
2327 if (
auto *RankConst =
N->getRankConst())
2328 Printer.printInt(
"rank", RankConst->getSExtValue(),
2331 Printer.printMetadata(
"rank",
N->getRawRank(),
true);
2332 Printer.printMetadata(
"annotations",
N->getRawAnnotations());
2333 if (
auto *Specification =
N->getRawSpecification())
2334 Printer.printMetadata(
"specification", Specification);
2336 if (
auto EnumKind =
N->getEnumKind())
2340 Printer.printMetadata(
"bitStride",
N->getRawBitStride());
2345 AsmWriterContext &WriterCtx) {
2346 Out <<
"!DISubroutineType(";
2347 MDFieldPrinter
Printer(Out, WriterCtx);
2348 Printer.printDIFlags(
"flags",
N->getFlags());
2350 Printer.printMetadata(
"types",
N->getRawTypeArray(),
2358 Printer.printString(
"filename",
N->getFilename(),
2360 Printer.printString(
"directory",
N->getDirectory(),
2363 if (
N->getChecksum())
2364 Printer.printChecksum(*
N->getChecksum());
2366 Printer.printString(
"source", *
N->getSource(),
2372 AsmWriterContext &WriterCtx) {
2373 Out <<
"!DICompileUnit(";
2374 MDFieldPrinter
Printer(Out, WriterCtx);
2375 Printer.printDwarfEnum(
"language",
N->getSourceLanguage(),
2377 Printer.printMetadata(
"file",
N->getRawFile(),
false);
2378 Printer.printString(
"producer",
N->getProducer());
2379 Printer.printBool(
"isOptimized",
N->isOptimized());
2380 Printer.printString(
"flags",
N->getFlags());
2381 Printer.printInt(
"runtimeVersion",
N->getRuntimeVersion(),
2383 Printer.printString(
"splitDebugFilename",
N->getSplitDebugFilename());
2384 Printer.printEmissionKind(
"emissionKind",
N->getEmissionKind());
2385 Printer.printMetadata(
"enums",
N->getRawEnumTypes());
2386 Printer.printMetadata(
"retainedTypes",
N->getRawRetainedTypes());
2387 Printer.printMetadata(
"globals",
N->getRawGlobalVariables());
2388 Printer.printMetadata(
"imports",
N->getRawImportedEntities());
2389 Printer.printMetadata(
"macros",
N->getRawMacros());
2390 Printer.printInt(
"dwoId",
N->getDWOId());
2391 Printer.printBool(
"splitDebugInlining",
N->getSplitDebugInlining(),
true);
2392 Printer.printBool(
"debugInfoForProfiling",
N->getDebugInfoForProfiling(),
2394 Printer.printNameTableKind(
"nameTableKind",
N->getNameTableKind());
2395 Printer.printBool(
"rangesBaseAddress",
N->getRangesBaseAddress(),
false);
2396 Printer.printString(
"sysroot",
N->getSysRoot());
2397 Printer.printString(
"sdk",
N->getSDK());
2402 AsmWriterContext &WriterCtx) {
2403 Out <<
"!DISubprogram(";
2404 MDFieldPrinter
Printer(Out, WriterCtx);
2405 Printer.printString(
"name",
N->getName());
2406 Printer.printString(
"linkageName",
N->getLinkageName());
2407 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2408 Printer.printMetadata(
"file",
N->getRawFile());
2409 Printer.printInt(
"line",
N->getLine());
2410 Printer.printMetadata(
"type",
N->getRawType());
2411 Printer.printInt(
"scopeLine",
N->getScopeLine());
2412 Printer.printMetadata(
"containingType",
N->getRawContainingType());
2413 if (
N->getVirtuality() != dwarf::DW_VIRTUALITY_none ||
2414 N->getVirtualIndex() != 0)
2415 Printer.printInt(
"virtualIndex",
N->getVirtualIndex(),
false);
2416 Printer.printInt(
"thisAdjustment",
N->getThisAdjustment());
2417 Printer.printDIFlags(
"flags",
N->getFlags());
2418 Printer.printDISPFlags(
"spFlags",
N->getSPFlags());
2419 Printer.printMetadata(
"unit",
N->getRawUnit());
2420 Printer.printMetadata(
"templateParams",
N->getRawTemplateParams());
2421 Printer.printMetadata(
"declaration",
N->getRawDeclaration());
2422 Printer.printMetadata(
"retainedNodes",
N->getRawRetainedNodes());
2423 Printer.printMetadata(
"thrownTypes",
N->getRawThrownTypes());
2424 Printer.printMetadata(
"annotations",
N->getRawAnnotations());
2425 Printer.printString(
"targetFuncName",
N->getTargetFuncName());
2426 Printer.printBool(
"keyInstructions",
N->getKeyInstructionsEnabled(),
false);
2431 AsmWriterContext &WriterCtx) {
2432 Out <<
"!DILexicalBlock(";
2433 MDFieldPrinter
Printer(Out, WriterCtx);
2434 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2435 Printer.printMetadata(
"file",
N->getRawFile());
2436 Printer.printInt(
"line",
N->getLine());
2437 Printer.printInt(
"column",
N->getColumn());
2443 AsmWriterContext &WriterCtx) {
2444 Out <<
"!DILexicalBlockFile(";
2445 MDFieldPrinter
Printer(Out, WriterCtx);
2446 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2447 Printer.printMetadata(
"file",
N->getRawFile());
2448 Printer.printInt(
"discriminator",
N->getDiscriminator(),
2454 AsmWriterContext &WriterCtx) {
2455 Out <<
"!DINamespace(";
2456 MDFieldPrinter
Printer(Out, WriterCtx);
2457 Printer.printString(
"name",
N->getName());
2458 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2459 Printer.printBool(
"exportSymbols",
N->getExportSymbols(),
false);
2464 AsmWriterContext &WriterCtx) {
2465 Out <<
"!DICommonBlock(";
2466 MDFieldPrinter
Printer(Out, WriterCtx);
2467 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2468 Printer.printMetadata(
"declaration",
N->getRawDecl(),
false);
2469 Printer.printString(
"name",
N->getName());
2470 Printer.printMetadata(
"file",
N->getRawFile());
2471 Printer.printInt(
"line",
N->getLineNo());
2476 AsmWriterContext &WriterCtx) {
2478 MDFieldPrinter
Printer(Out, WriterCtx);
2480 Printer.printInt(
"line",
N->getLine());
2481 Printer.printString(
"name",
N->getName());
2482 Printer.printString(
"value",
N->getValue());
2487 AsmWriterContext &WriterCtx) {
2488 Out <<
"!DIMacroFile(";
2489 MDFieldPrinter
Printer(Out, WriterCtx);
2490 Printer.printInt(
"line",
N->getLine());
2491 Printer.printMetadata(
"file",
N->getRawFile(),
false);
2492 Printer.printMetadata(
"nodes",
N->getRawElements());
2497 AsmWriterContext &WriterCtx) {
2498 Out <<
"!DIModule(";
2499 MDFieldPrinter
Printer(Out, WriterCtx);
2500 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2501 Printer.printString(
"name",
N->getName());
2502 Printer.printString(
"configMacros",
N->getConfigurationMacros());
2503 Printer.printString(
"includePath",
N->getIncludePath());
2504 Printer.printString(
"apinotes",
N->getAPINotesFile());
2505 Printer.printMetadata(
"file",
N->getRawFile());
2506 Printer.printInt(
"line",
N->getLineNo());
2507 Printer.printBool(
"isDecl",
N->getIsDecl(),
false);
2513 AsmWriterContext &WriterCtx) {
2514 Out <<
"!DITemplateTypeParameter(";
2515 MDFieldPrinter
Printer(Out, WriterCtx);
2516 Printer.printString(
"name",
N->getName());
2517 Printer.printMetadata(
"type",
N->getRawType(),
false);
2518 Printer.printBool(
"defaulted",
N->isDefault(),
false);
2524 AsmWriterContext &WriterCtx) {
2525 Out <<
"!DITemplateValueParameter(";
2526 MDFieldPrinter
Printer(Out, WriterCtx);
2527 if (
N->getTag() != dwarf::DW_TAG_template_value_parameter)
2529 Printer.printString(
"name",
N->getName());
2530 Printer.printMetadata(
"type",
N->getRawType());
2531 Printer.printBool(
"defaulted",
N->isDefault(),
false);
2532 Printer.printMetadata(
"value",
N->getValue(),
false);
2537 AsmWriterContext &WriterCtx) {
2538 Out <<
"!DIGlobalVariable(";
2539 MDFieldPrinter
Printer(Out, WriterCtx);
2540 Printer.printString(
"name",
N->getName());
2541 Printer.printString(
"linkageName",
N->getLinkageName());
2542 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2543 Printer.printMetadata(
"file",
N->getRawFile());
2544 Printer.printInt(
"line",
N->getLine());
2545 Printer.printMetadata(
"type",
N->getRawType());
2546 Printer.printBool(
"isLocal",
N->isLocalToUnit());
2547 Printer.printBool(
"isDefinition",
N->isDefinition());
2548 Printer.printMetadata(
"declaration",
N->getRawStaticDataMemberDeclaration());
2549 Printer.printMetadata(
"templateParams",
N->getRawTemplateParams());
2550 Printer.printInt(
"align",
N->getAlignInBits());
2551 Printer.printMetadata(
"annotations",
N->getRawAnnotations());
2556 AsmWriterContext &WriterCtx) {
2557 Out <<
"!DILocalVariable(";
2558 MDFieldPrinter
Printer(Out, WriterCtx);
2559 Printer.printString(
"name",
N->getName());
2560 Printer.printInt(
"arg",
N->getArg());
2561 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2562 Printer.printMetadata(
"file",
N->getRawFile());
2563 Printer.printInt(
"line",
N->getLine());
2564 Printer.printMetadata(
"type",
N->getRawType());
2565 Printer.printDIFlags(
"flags",
N->getFlags());
2566 Printer.printInt(
"align",
N->getAlignInBits());
2567 Printer.printMetadata(
"annotations",
N->getRawAnnotations());
2572 AsmWriterContext &WriterCtx) {
2574 MDFieldPrinter
Printer(Out, WriterCtx);
2575 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2576 Printer.printString(
"name",
N->getName());
2577 Printer.printMetadata(
"file",
N->getRawFile());
2578 Printer.printInt(
"line",
N->getLine());
2579 Printer.printInt(
"column",
N->getColumn());
2580 Printer.printBool(
"isArtificial",
N->isArtificial(),
false);
2581 if (
N->getCoroSuspendIdx())
2582 Printer.printInt(
"coroSuspendIdx", *
N->getCoroSuspendIdx(),
2588 AsmWriterContext &WriterCtx) {
2589 Out <<
"!DIExpression(";
2594 assert(!OpStr.empty() &&
"Expected valid opcode");
2598 Out << FS <<
Op.getArg(0);
2601 for (
unsigned A = 0, AE =
Op.getNumArgs();
A != AE; ++
A)
2602 Out << FS <<
Op.getArg(
A);
2606 for (
const auto &
I :
N->getElements())
2613 AsmWriterContext &WriterCtx,
2614 bool FromValue =
false) {
2616 "Unexpected DIArgList metadata outside of value argument");
2617 Out <<
"!DIArgList(";
2619 MDFieldPrinter
Printer(Out, WriterCtx);
2620 for (
const Metadata *Arg :
N->getArgs()) {
2629 AsmWriterContext &WriterCtx) {
2630 Out <<
"!DIGlobalVariableExpression(";
2631 MDFieldPrinter
Printer(Out, WriterCtx);
2632 Printer.printMetadata(
"var",
N->getVariable());
2633 Printer.printMetadata(
"expr",
N->getExpression());
2638 AsmWriterContext &WriterCtx) {
2639 Out <<
"!DIObjCProperty(";
2640 MDFieldPrinter
Printer(Out, WriterCtx);
2641 Printer.printString(
"name",
N->getName());
2642 Printer.printMetadata(
"file",
N->getRawFile());
2643 Printer.printInt(
"line",
N->getLine());
2644 Printer.printString(
"setter",
N->getSetterName());
2645 Printer.printString(
"getter",
N->getGetterName());
2646 Printer.printInt(
"attributes",
N->getAttributes());
2647 Printer.printMetadata(
"type",
N->getRawType());
2652 AsmWriterContext &WriterCtx) {
2653 Out <<
"!DIImportedEntity(";
2654 MDFieldPrinter
Printer(Out, WriterCtx);
2656 Printer.printString(
"name",
N->getName());
2657 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2658 Printer.printMetadata(
"entity",
N->getRawEntity());
2659 Printer.printMetadata(
"file",
N->getRawFile());
2660 Printer.printInt(
"line",
N->getLine());
2661 Printer.printMetadata(
"elements",
N->getRawElements());
2666 AsmWriterContext &Ctx) {
2667 if (
Node->isDistinct())
2669 else if (
Node->isTemporary())
2670 Out <<
"<temporary!> ";
2672 switch (
Node->getMetadataID()) {
2675#define HANDLE_MDNODE_LEAF(CLASS) \
2676 case Metadata::CLASS##Kind: \
2677 write##CLASS(Out, cast<CLASS>(Node), Ctx); \
2679#include "llvm/IR/Metadata.def"
2686 AsmWriterContext &WriterCtx,
2689 WriterCtx.TypePrinter->print(V->getType(), Out);
2700 assert(WriterCtx.TypePrinter &&
"Constants require TypePrinting!");
2707 if (IA->hasSideEffects())
2708 Out <<
"sideeffect ";
2709 if (IA->isAlignStack())
2710 Out <<
"alignstack ";
2713 Out <<
"inteldialect ";
2732 auto *
Machine = WriterCtx.Machine;
2736 Slot =
Machine->getGlobalSlot(GV);
2739 Slot =
Machine->getLocalSlot(V);
2746 Slot =
Machine->getLocalSlot(V);
2753 Slot =
Machine->getGlobalSlot(GV);
2756 Slot =
Machine->getLocalSlot(V);
2765 Out << Prefix << Slot;
2771 AsmWriterContext &WriterCtx,
2785 std::unique_ptr<SlotTracker> MachineStorage;
2787 if (!WriterCtx.Machine) {
2788 MachineStorage = std::make_unique<SlotTracker>(WriterCtx.Context);
2789 WriterCtx.Machine = MachineStorage.get();
2799 Out <<
"<" <<
N <<
">";
2813 assert(WriterCtx.TypePrinter &&
"TypePrinter required for metadata values");
2815 "Unexpected function-local metadata outside of value argument");
2822class AssemblyWriter {
2823 formatted_raw_ostream &Out;
2824 const Module *TheModule =
nullptr;
2825 const ModuleSummaryIndex *TheIndex =
nullptr;
2826 std::unique_ptr<SlotTracker> SlotTrackerStorage;
2828 TypePrinting TypePrinter;
2829 AssemblyAnnotationWriter *AnnotationWriter =
nullptr;
2830 SetVector<const Comdat *> Comdats;
2832 bool ShouldPreserveUseListOrder;
2837 DenseMap<const GlobalValueSummary *, GlobalValue::GUID> SummaryToGUIDMap;
2841 AssemblyWriter(formatted_raw_ostream &o, SlotTracker &Mac,
const Module *M,
2842 AssemblyAnnotationWriter *AAW,
bool IsForDebug,
2843 bool ShouldPreserveUseListOrder =
false);
2845 AssemblyWriter(formatted_raw_ostream &o, SlotTracker &Mac,
2846 const ModuleSummaryIndex *Index,
bool IsForDebug);
2849 return AsmWriterContext(&TypePrinter, &
Machine, TheModule);
2852 void printMDNodeBody(
const MDNode *MD);
2853 void printNamedMDNode(
const NamedMDNode *NMD);
2855 void printModule(
const Module *M);
2857 void writeOperand(
const Value *
Op,
bool PrintType);
2858 void writeParamOperand(
const Value *Operand, AttributeSet Attrs);
2859 void writeOperandBundles(
const CallBase *
Call);
2860 void writeSyncScope(
const LLVMContext &
Context,
2862 void writeAtomic(
const LLVMContext &
Context,
2865 void writeAtomicCmpXchg(
const LLVMContext &
Context,
2870 void writeAllMDNodes();
2871 void writeMDNode(
unsigned Slot,
const MDNode *Node);
2872 void writeAttribute(
const Attribute &Attr,
bool InAttrGroup =
false);
2873 void writeAttributeSet(
const AttributeSet &AttrSet,
bool InAttrGroup =
false);
2874 void writeAllAttributeGroups();
2876 void printTypeIdentities();
2877 void printGlobal(
const GlobalVariable *GV);
2878 void printAlias(
const GlobalAlias *GA);
2879 void printIFunc(
const GlobalIFunc *GI);
2880 void printComdat(
const Comdat *
C);
2881 void printFunction(
const Function *
F);
2882 void printArgument(
const Argument *FA, AttributeSet Attrs);
2883 void printBasicBlock(
const BasicBlock *BB);
2884 void printInstructionLine(
const Instruction &
I);
2885 void printInstruction(
const Instruction &
I);
2886 void printDbgMarker(
const DbgMarker &DPI);
2887 void printDbgVariableRecord(
const DbgVariableRecord &DVR);
2888 void printDbgLabelRecord(
const DbgLabelRecord &DLR);
2889 void printDbgRecord(
const DbgRecord &DR);
2890 void printDbgRecordLine(
const DbgRecord &DR);
2892 void printUseListOrder(
const Value *V,
const std::vector<unsigned> &Shuffle);
2893 void printUseLists(
const Function *
F);
2895 void printModuleSummaryIndex();
2896 void printSummaryInfo(
unsigned Slot,
const ValueInfo &VI);
2897 void printSummary(
const GlobalValueSummary &Summary);
2898 void printAliasSummary(
const AliasSummary *AS);
2899 void printGlobalVarSummary(
const GlobalVarSummary *GS);
2900 void printFunctionSummary(
const FunctionSummary *FS);
2901 void printTypeIdSummary(
const TypeIdSummary &TIS);
2903 void printTypeTestResolution(
const TypeTestResolution &TTRes);
2904 void printArgs(
const std::vector<uint64_t> &Args);
2905 void printWPDRes(
const WholeProgramDevirtResolution &WPDRes);
2906 void printTypeIdInfo(
const FunctionSummary::TypeIdInfo &TIDInfo);
2907 void printVFuncId(
const FunctionSummary::VFuncId VFId);
2909 printNonConstVCalls(
const std::vector<FunctionSummary::VFuncId> &VCallList,
2912 printConstVCalls(
const std::vector<FunctionSummary::ConstVCall> &VCallList,
2917 void printMetadataAttachments(
2918 const SmallVectorImpl<std::pair<unsigned, MDNode *>> &MDs,
2919 StringRef Separator);
2923 void printInfoComment(
const Value &V);
2927 void printGCRelocateComment(
const GCRelocateInst &Relocate);
2934 bool IsForDebug,
bool ShouldPreserveUseListOrder)
2935 : Out(
o), TheModule(
M),
Machine(Mac), TypePrinter(
M), AnnotationWriter(AAW),
2936 IsForDebug(IsForDebug),
2937 ShouldPreserveUseListOrder(ShouldPreserveUseListOrder) {
2940 for (
const GlobalObject &GO : TheModule->global_objects())
2947 : Out(
o), TheIndex(Index),
Machine(Mac), TypePrinter(nullptr),
2948 IsForDebug(IsForDebug), ShouldPreserveUseListOrder(
false) {}
2950void AssemblyWriter::writeOperand(
const Value *Operand,
bool PrintType) {
2952 Out <<
"<null operand!>";
2959void AssemblyWriter::writeSyncScope(
const LLVMContext &
Context,
2967 Context.getSyncScopeNames(SSNs);
2969 Out <<
" syncscope(\"";
2977void AssemblyWriter::writeAtomic(
const LLVMContext &
Context,
2980 if (Ordering == AtomicOrdering::NotAtomic)
2983 writeSyncScope(
Context, SSID);
2987void AssemblyWriter::writeAtomicCmpXchg(
const LLVMContext &
Context,
2991 assert(SuccessOrdering != AtomicOrdering::NotAtomic &&
2992 FailureOrdering != AtomicOrdering::NotAtomic);
2994 writeSyncScope(
Context, SSID);
2999void AssemblyWriter::writeParamOperand(
const Value *Operand,
3000 AttributeSet Attrs) {
3002 Out <<
"<null operand!>";
3007 TypePrinter.print(Operand->
getType(), Out);
3009 if (
Attrs.hasAttributes()) {
3011 writeAttributeSet(Attrs);
3019void AssemblyWriter::writeOperandBundles(
const CallBase *
Call) {
3035 ListSeparator InnerLS;
3037 for (
const auto &Input : BU.
Inputs) {
3039 if (Input ==
nullptr)
3040 Out <<
"<null operand bundle!>";
3051void AssemblyWriter::printModule(
const Module *M) {
3054 if (ShouldPreserveUseListOrder)
3057 if (!
M->getModuleIdentifier().empty() &&
3060 M->getModuleIdentifier().find(
'\n') == std::string::npos)
3061 Out <<
"; ModuleID = '" <<
M->getModuleIdentifier() <<
"'\n";
3063 if (!
M->getSourceFileName().empty()) {
3064 Out <<
"source_filename = \"";
3069 const std::string &
DL =
M->getDataLayoutStr();
3071 Out <<
"target datalayout = \"" <<
DL <<
"\"\n";
3072 if (!
M->getTargetTriple().empty())
3073 Out <<
"target triple = \"" <<
M->getTargetTriple().str() <<
"\"\n";
3075 if (!
M->getModuleInlineAsm().empty()) {
3079 StringRef
Asm =
M->getModuleInlineAsm();
3082 std::tie(Front, Asm) =
Asm.split(
'\n');
3086 Out <<
"module asm \"";
3089 }
while (!
Asm.empty());
3092 printTypeIdentities();
3095 if (!Comdats.empty())
3097 for (
const Comdat *
C : Comdats) {
3099 if (
C != Comdats.back())
3104 if (!
M->global_empty()) Out <<
'\n';
3105 for (
const GlobalVariable &GV :
M->globals()) {
3106 printGlobal(&GV); Out <<
'\n';
3110 if (!
M->alias_empty()) Out <<
"\n";
3111 for (
const GlobalAlias &GA :
M->aliases())
3115 if (!
M->ifunc_empty()) Out <<
"\n";
3116 for (
const GlobalIFunc &GI :
M->ifuncs())
3120 for (
const Function &
F : *M) {
3126 printUseLists(
nullptr);
3131 writeAllAttributeGroups();
3135 if (!
M->named_metadata_empty()) Out <<
'\n';
3137 for (
const NamedMDNode &Node :
M->named_metadata())
3138 printNamedMDNode(&Node);
3147void AssemblyWriter::printModuleSummaryIndex() {
3149 int NumSlots =
Machine.initializeIndexIfNeeded();
3155 std::vector<std::pair<std::string, ModuleHash>> moduleVec;
3156 std::string RegularLTOModuleName =
3158 moduleVec.resize(TheIndex->modulePaths().size());
3159 for (
auto &[ModPath, ModHash] : TheIndex->modulePaths())
3160 moduleVec[
Machine.getModulePathSlot(ModPath)] = std::make_pair(
3163 ModPath.empty() ? RegularLTOModuleName : std::string(ModPath), ModHash);
3166 for (
auto &ModPair : moduleVec) {
3167 Out <<
"^" << i++ <<
" = module: (";
3170 Out <<
"\", hash: (";
3172 for (
auto Hash : ModPair.second)
3179 for (
auto &GlobalList : *TheIndex) {
3180 auto GUID = GlobalList.first;
3181 for (
auto &Summary : GlobalList.second.SummaryList)
3186 for (
auto &GlobalList : *TheIndex) {
3187 auto GUID = GlobalList.first;
3188 auto VI = TheIndex->getValueInfo(GlobalList);
3189 printSummaryInfo(
Machine.getGUIDSlot(GUID), VI);
3193 for (
const auto &TID : TheIndex->typeIds()) {
3194 Out <<
"^" <<
Machine.getTypeIdSlot(TID.second.first)
3195 <<
" = typeid: (name: \"" << TID.second.first <<
"\"";
3196 printTypeIdSummary(TID.second.second);
3197 Out <<
") ; guid = " << TID.first <<
"\n";
3201 for (
auto &TId : TheIndex->typeIdCompatibleVtableMap()) {
3203 Out <<
"^" <<
Machine.getTypeIdCompatibleVtableSlot(TId.first)
3204 <<
" = typeidCompatibleVTable: (name: \"" << TId.first <<
"\"";
3205 printTypeIdCompatibleVtableSummary(TId.second);
3206 Out <<
") ; guid = " <<
GUID <<
"\n";
3210 if (TheIndex->getFlags()) {
3211 Out <<
"^" << NumSlots <<
" = flags: " << TheIndex->getFlags() <<
"\n";
3215 Out <<
"^" << NumSlots <<
" = blockcount: " << TheIndex->getBlockCount()
3225 return "singleImpl";
3227 return "branchFunnel";
3238 return "uniformRetVal";
3240 return "uniqueRetVal";
3242 return "virtualConstProp";
3265void AssemblyWriter::printTypeTestResolution(
const TypeTestResolution &TTRes) {
3272 Out <<
", alignLog2: " << TTRes.
AlignLog2;
3274 Out <<
", sizeM1: " << TTRes.
SizeM1;
3277 Out <<
", bitMask: " << (unsigned)TTRes.
BitMask;
3284void AssemblyWriter::printTypeIdSummary(
const TypeIdSummary &TIS) {
3285 Out <<
", summary: (";
3286 printTypeTestResolution(TIS.
TTRes);
3287 if (!TIS.
WPDRes.empty()) {
3288 Out <<
", wpdResolutions: (";
3290 for (
auto &WPDRes : TIS.
WPDRes) {
3292 Out <<
"(offset: " << WPDRes.first <<
", ";
3293 printWPDRes(WPDRes.second);
3301void AssemblyWriter::printTypeIdCompatibleVtableSummary(
3303 Out <<
", summary: (";
3305 for (
auto &
P : TI) {
3307 Out <<
"(offset: " <<
P.AddressPointOffset <<
", ";
3308 Out <<
"^" <<
Machine.getGUIDSlot(
P.VTableVI.getGUID());
3314void AssemblyWriter::printArgs(
const std::vector<uint64_t> &Args) {
3317 for (
auto arg : Args) {
3324void AssemblyWriter::printWPDRes(
const WholeProgramDevirtResolution &WPDRes) {
3325 Out <<
"wpdRes: (kind: ";
3332 Out <<
", resByArg: (";
3334 for (
auto &ResByArg : WPDRes.
ResByArg) {
3336 printArgs(ResByArg.first);
3337 Out <<
", byArg: (kind: ";
3339 if (ResByArg.second.TheKind ==
3341 ResByArg.second.TheKind ==
3343 Out <<
", info: " << ResByArg.second.Info;
3347 if (ResByArg.second.Byte || ResByArg.second.Bit)
3348 Out <<
", byte: " << ResByArg.second.Byte
3349 <<
", bit: " << ResByArg.second.Bit;
3370void AssemblyWriter::printAliasSummary(
const AliasSummary *AS) {
3371 Out <<
", aliasee: ";
3381void AssemblyWriter::printGlobalVarSummary(
const GlobalVarSummary *GS) {
3382 auto VTableFuncs =
GS->vTableFuncs();
3383 Out <<
", varFlags: (readonly: " <<
GS->VarFlags.MaybeReadOnly <<
", "
3384 <<
"writeonly: " <<
GS->VarFlags.MaybeWriteOnly <<
", "
3385 <<
"constant: " <<
GS->VarFlags.Constant;
3386 if (!VTableFuncs.empty())
3388 <<
"vcall_visibility: " <<
GS->VarFlags.VCallVisibility;
3391 if (!VTableFuncs.empty()) {
3392 Out <<
", vTableFuncs: (";
3394 for (
auto &
P : VTableFuncs) {
3396 Out <<
"(virtFunc: ^" <<
Machine.getGUIDSlot(
P.FuncVI.getGUID())
3397 <<
", offset: " <<
P.VTableOffset;
3415 return "linkonce_odr";
3425 return "extern_weak";
3427 return "available_externally";
3456 return "definition";
3458 return "declaration";
3463void AssemblyWriter::printFunctionSummary(
const FunctionSummary *FS) {
3464 Out <<
", insts: " <<
FS->instCount();
3465 if (
FS->fflags().anyFlagSet())
3466 Out <<
", " <<
FS->fflags();
3468 if (!
FS->calls().empty()) {
3469 Out <<
", calls: (";
3471 for (
auto &
Call :
FS->calls()) {
3473 Out <<
"(callee: ^" <<
Machine.getGUIDSlot(
Call.first.getGUID());
3474 if (
Call.second.getHotness() != CalleeInfo::HotnessType::Unknown)
3476 else if (
Call.second.RelBlockFreq)
3477 Out <<
", relbf: " <<
Call.second.RelBlockFreq;
3480 if (
Call.second.HasTailCall)
3487 if (
const auto *TIdInfo =
FS->getTypeIdInfo())
3488 printTypeIdInfo(*TIdInfo);
3492 auto AllocTypeName = [](uint8_t
Type) ->
const char * {
3494 case (uint8_t)AllocationType::None:
3496 case (uint8_t)AllocationType::NotCold:
3498 case (uint8_t)AllocationType::Cold:
3500 case (uint8_t)AllocationType::Hot:
3506 if (!
FS->allocs().empty()) {
3507 Out <<
", allocs: (";
3509 for (
auto &AI :
FS->allocs()) {
3511 Out <<
"(versions: (";
3513 for (
auto V : AI.Versions) {
3515 Out << AllocTypeName(V);
3517 Out <<
"), memProf: (";
3518 ListSeparator MIBFS;
3519 for (
auto &MIB : AI.MIBs) {
3521 Out <<
"(type: " << AllocTypeName((uint8_t)MIB.AllocType);
3522 Out <<
", stackIds: (";
3523 ListSeparator SIDFS;
3524 for (
auto Id : MIB.StackIdIndices) {
3526 Out << TheIndex->getStackIdAtIndex(Id);
3535 if (!
FS->callsites().empty()) {
3536 Out <<
", callsites: (";
3538 for (
auto &CI :
FS->callsites()) {
3541 Out <<
"(callee: ^" <<
Machine.getGUIDSlot(CI.Callee.getGUID());
3543 Out <<
"(callee: null";
3544 Out <<
", clones: (";
3546 for (
auto V : CI.Clones) {
3550 Out <<
"), stackIds: (";
3551 ListSeparator SIDFS;
3552 for (
auto Id : CI.StackIdIndices) {
3554 Out << TheIndex->getStackIdAtIndex(Id);
3561 auto PrintRange = [&](
const ConstantRange &
Range) {
3565 if (!
FS->paramAccesses().empty()) {
3566 Out <<
", params: (";
3568 for (
auto &PS :
FS->paramAccesses()) {
3570 Out <<
"(param: " << PS.ParamNo;
3571 Out <<
", offset: ";
3573 if (!PS.Calls.empty()) {
3574 Out <<
", calls: (";
3576 for (
auto &
Call : PS.Calls) {
3578 Out <<
"(callee: ^" <<
Machine.getGUIDSlot(
Call.Callee.getGUID());
3579 Out <<
", param: " <<
Call.ParamNo;
3580 Out <<
", offset: ";
3581 PrintRange(
Call.Offsets);
3592void AssemblyWriter::printTypeIdInfo(
3593 const FunctionSummary::TypeIdInfo &TIDInfo) {
3594 Out <<
", typeIdInfo: (";
3595 ListSeparator TIDFS;
3598 Out <<
"typeTests: (";
3601 auto TidIter = TheIndex->typeIds().equal_range(GUID);
3602 if (TidIter.first == TidIter.second) {
3608 for (
const auto &[GUID, TypeIdPair] :
make_range(TidIter)) {
3610 auto Slot =
Machine.getTypeIdSlot(TypeIdPair.first);
3628 "typeTestAssumeConstVCalls");
3633 "typeCheckedLoadConstVCalls");
3638void AssemblyWriter::printVFuncId(
const FunctionSummary::VFuncId VFId) {
3639 auto TidIter = TheIndex->typeIds().equal_range(VFId.
GUID);
3640 if (TidIter.first == TidIter.second) {
3641 Out <<
"vFuncId: (";
3642 Out <<
"guid: " << VFId.
GUID;
3643 Out <<
", offset: " << VFId.
Offset;
3649 for (
const auto &[GUID, TypeIdPair] :
make_range(TidIter)) {
3651 Out <<
"vFuncId: (";
3652 auto Slot =
Machine.getTypeIdSlot(TypeIdPair.first);
3655 Out <<
", offset: " << VFId.
Offset;
3660void AssemblyWriter::printNonConstVCalls(
3661 const std::vector<FunctionSummary::VFuncId> &VCallList,
const char *
Tag) {
3662 Out <<
Tag <<
": (";
3664 for (
auto &VFuncId : VCallList) {
3666 printVFuncId(VFuncId);
3671void AssemblyWriter::printConstVCalls(
3672 const std::vector<FunctionSummary::ConstVCall> &VCallList,
3674 Out <<
Tag <<
": (";
3676 for (
auto &ConstVCall : VCallList) {
3679 printVFuncId(ConstVCall.VFunc);
3680 if (!ConstVCall.Args.empty()) {
3682 printArgs(ConstVCall.Args);
3689void AssemblyWriter::printSummary(
const GlobalValueSummary &Summary) {
3690 GlobalValueSummary::GVFlags GVFlags =
Summary.flags();
3693 Out <<
"(module: ^" <<
Machine.getModulePathSlot(
Summary.modulePath())
3696 Out <<
", visibility: "
3699 Out <<
", live: " << GVFlags.
Live;
3700 Out <<
", dsoLocal: " << GVFlags.
DSOLocal;
3702 Out <<
", importType: "
3713 auto RefList =
Summary.refs();
3714 if (!RefList.empty()) {
3717 for (
auto &
Ref : RefList) {
3719 if (
Ref.isReadOnly())
3721 else if (
Ref.isWriteOnly())
3722 Out <<
"writeonly ";
3723 Out <<
"^" <<
Machine.getGUIDSlot(
Ref.getGUID());
3731void AssemblyWriter::printSummaryInfo(
unsigned Slot,
const ValueInfo &VI) {
3732 Out <<
"^" <<
Slot <<
" = gv: (";
3733 if (
VI.hasName() && !
VI.name().empty())
3734 Out <<
"name: \"" <<
VI.name() <<
"\"";
3736 Out <<
"guid: " <<
VI.getGUID();
3737 if (!
VI.getSummaryList().empty()) {
3738 Out <<
", summaries: (";
3740 for (
auto &Summary :
VI.getSummaryList()) {
3742 printSummary(*Summary);
3747 if (
VI.hasName() && !
VI.name().empty())
3748 Out <<
" ; guid = " <<
VI.getGUID();
3755 Out <<
"<empty name> ";
3757 unsigned char FirstC =
static_cast<unsigned char>(Name[0]);
3758 if (isalpha(FirstC) || FirstC ==
'-' || FirstC ==
'$' || FirstC ==
'.' ||
3763 for (
unsigned i = 1, e = Name.size(); i != e; ++i) {
3764 unsigned char C = Name[i];
3765 if (isalnum(
C) ||
C ==
'-' ||
C ==
'$' ||
C ==
'.' ||
C ==
'_')
3773void AssemblyWriter::printNamedMDNode(
const NamedMDNode *NMD) {
3808 Out <<
"dso_local ";
3826 Out <<
"thread_local ";
3829 Out <<
"thread_local(localdynamic) ";
3832 Out <<
"thread_local(initialexec) ";
3835 Out <<
"thread_local(localexec) ";
3845 return "local_unnamed_addr";
3847 return "unnamed_addr";
3870void AssemblyWriter::printGlobal(
const GlobalVariable *GV) {
3872 Out <<
"; Materializable\n";
3893 Out << (GV->
isConstant() ?
"constant " :
"global ");
3902 Out <<
", section \"";
3907 Out <<
", partition \"";
3912 Out <<
", code_model \"";
3937 Out <<
", no_sanitize_address";
3939 Out <<
", no_sanitize_hwaddress";
3941 Out <<
", sanitize_memtag";
3943 Out <<
", sanitize_address_dyninit";
3948 Out <<
", align " <<
A->value();
3952 printMetadataAttachments(MDs,
", ");
3955 if (
Attrs.hasAttributes())
3956 Out <<
" #" <<
Machine.getAttributeGroupSlot(Attrs);
3958 printInfoComment(*GV);
3961void AssemblyWriter::printAlias(
const GlobalAlias *GA) {
3963 Out <<
"; Materializable\n";
3983 if (
const Constant *Aliasee = GA->
getAliasee()) {
3986 TypePrinter.print(GA->
getType(), Out);
3987 Out <<
" <<NULL ALIASEE>>";
3991 Out <<
", partition \"";
3996 printInfoComment(*GA);
4000void AssemblyWriter::printIFunc(
const GlobalIFunc *GI) {
4002 Out <<
"; Materializable\n";
4017 if (
const Constant *Resolver = GI->
getResolver()) {
4020 TypePrinter.print(GI->
getType(), Out);
4021 Out <<
" <<NULL RESOLVER>>";
4025 Out <<
", partition \"";
4032 printMetadataAttachments(MDs,
", ");
4035 printInfoComment(*GI);
4039void AssemblyWriter::printComdat(
const Comdat *
C) {
4043void AssemblyWriter::printTypeIdentities() {
4044 if (TypePrinter.empty())
4050 auto &NumberedTypes = TypePrinter.getNumberedTypes();
4051 for (
unsigned I = 0,
E = NumberedTypes.size();
I !=
E; ++
I) {
4052 Out <<
'%' <<
I <<
" = type ";
4056 TypePrinter.printStructBody(NumberedTypes[
I], Out);
4060 auto &NamedTypes = TypePrinter.getNamedTypes();
4061 for (StructType *NamedType : NamedTypes) {
4067 TypePrinter.printStructBody(NamedType, Out);
4073void AssemblyWriter::printFunction(
const Function *
F) {
4076 if (
F->isMaterializable())
4077 Out <<
"; Materializable\n";
4079 const AttributeList &
Attrs =
F->getAttributes();
4080 if (
Attrs.hasFnAttrs()) {
4081 AttributeSet AS =
Attrs.getFnAttrs();
4082 std::string AttrStr;
4085 if (!Attr.isStringAttribute()) {
4086 if (!AttrStr.empty()) AttrStr +=
' ';
4087 AttrStr += Attr.getAsString();
4091 if (!AttrStr.empty())
4092 Out <<
"; Function Attrs: " << AttrStr <<
'\n';
4096 Out <<
"; Unknown intrinsic\n";
4100 if (
F->isDeclaration()) {
4103 F->getAllMetadata(MDs);
4104 printMetadataAttachments(MDs,
" ");
4115 if (
F->getCallingConv() != CallingConv::C) {
4120 FunctionType *FT =
F->getFunctionType();
4121 if (
Attrs.hasRetAttrs())
4122 Out <<
Attrs.getAsString(AttributeList::ReturnIndex) <<
' ';
4123 TypePrinter.print(
F->getReturnType(), Out);
4130 if (
F->isDeclaration() && !IsForDebug) {
4133 for (
unsigned I = 0,
E = FT->getNumParams();
I !=
E; ++
I) {
4136 TypePrinter.print(FT->getParamType(
I), Out);
4138 AttributeSet ArgAttrs =
Attrs.getParamAttrs(
I);
4141 writeAttributeSet(ArgAttrs);
4147 for (
const Argument &Arg :
F->args()) {
4149 printArgument(&Arg,
Attrs.getParamAttrs(Arg.getArgNo()));
4154 if (FT->isVarArg()) {
4155 if (FT->getNumParams()) Out <<
", ";
4166 if (
F->getAddressSpace() != 0 || !
Mod ||
4167 Mod->getDataLayout().getProgramAddressSpace() != 0)
4168 Out <<
" addrspace(" <<
F->getAddressSpace() <<
")";
4169 if (
Attrs.hasFnAttrs())
4170 Out <<
" #" <<
Machine.getAttributeGroupSlot(
Attrs.getFnAttrs());
4171 if (
F->hasSection()) {
4172 Out <<
" section \"";
4176 if (
F->hasPartition()) {
4177 Out <<
" partition \"";
4182 if (MaybeAlign
A =
F->getAlign())
4183 Out <<
" align " <<
A->value();
4185 Out <<
" gc \"" <<
F->getGC() <<
'"';
4186 if (
F->hasPrefixData()) {
4188 writeOperand(
F->getPrefixData(),
true);
4190 if (
F->hasPrologueData()) {
4191 Out <<
" prologue ";
4192 writeOperand(
F->getPrologueData(),
true);
4194 if (
F->hasPersonalityFn()) {
4195 Out <<
" personality ";
4196 writeOperand(
F->getPersonalityFn(),
true);
4200 if (
auto *MDProf =
F->getMetadata(LLVMContext::MD_prof)) {
4202 MDProf->print(Out, TheModule,
true);
4206 if (
F->isDeclaration()) {
4210 F->getAllMetadata(MDs);
4211 printMetadataAttachments(MDs,
" ");
4215 for (
const BasicBlock &BB : *
F)
4216 printBasicBlock(&BB);
4229void AssemblyWriter::printArgument(
const Argument *Arg, AttributeSet Attrs) {
4231 TypePrinter.print(Arg->
getType(), Out);
4234 if (
Attrs.hasAttributes()) {
4236 writeAttributeSet(Attrs);
4245 assert(Slot != -1 &&
"expect argument in function here");
4246 Out <<
" %" <<
Slot;
4251void AssemblyWriter::printBasicBlock(
const BasicBlock *BB) {
4257 }
else if (!IsEntryBlock) {
4266 if (!IsEntryBlock) {
4271 Out <<
" No predecessors!";
4277 writeOperand(Pred,
false);
4287 for (
const Instruction &
I : *BB) {
4288 for (
const DbgRecord &DR :
I.getDbgRecordRange())
4289 printDbgRecordLine(DR);
4290 printInstructionLine(
I);
4297void AssemblyWriter::printInstructionLine(
const Instruction &
I) {
4298 printInstruction(
I);
4304void AssemblyWriter::printGCRelocateComment(
const GCRelocateInst &Relocate) {
4314void AssemblyWriter::printInfoComment(
const Value &V) {
4316 printGCRelocateComment(*Relocate);
4318 if (AnnotationWriter) {
4324 if (
I->getDebugLoc()) {
4326 I->getDebugLoc().print(Out);
4332 if (
auto *MD =
I->getMetadata(LLVMContext::MD_prof)) {
4334 MD->print(Out, TheModule,
true);
4346 if (Operand ==
nullptr) {
4347 Out <<
" <cannot get addrspace!>";
4351 bool PrintAddrSpace = CallAddrSpace != 0;
4352 if (!PrintAddrSpace) {
4357 if (!
Mod ||
Mod->getDataLayout().getProgramAddressSpace() != 0)
4358 PrintAddrSpace =
true;
4361 Out <<
" addrspace(" << CallAddrSpace <<
")";
4365void AssemblyWriter::printInstruction(
const Instruction &
I) {
4375 }
else if (!
I.getType()->isVoidTy()) {
4377 int SlotNum =
Machine.getLocalSlot(&
I);
4379 Out <<
"<badref> = ";
4381 Out <<
'%' << SlotNum <<
" = ";
4385 if (CI->isMustTailCall())
4387 else if (CI->isTailCall())
4389 else if (CI->isNoTailCall())
4394 Out <<
I.getOpcodeName();
4416 Out <<
' ' << CI->getPredicate();
4423 const Value *Operand =
I.getNumOperands() ?
I.getOperand(0) :
nullptr;
4429 writeOperand(BI.getCondition(),
true);
4431 writeOperand(BI.getSuccessor(0),
true);
4433 writeOperand(BI.getSuccessor(1),
true);
4439 writeOperand(
SI.getCondition(),
true);
4441 writeOperand(
SI.getDefaultDest(),
true);
4443 for (
auto Case :
SI.cases()) {
4445 writeOperand(Case.getCaseValue(),
true);
4447 writeOperand(Case.getCaseSuccessor(),
true);
4453 writeOperand(Operand,
true);
4457 for (
unsigned i = 1, e =
I.getNumOperands(); i != e; ++i) {
4459 writeOperand(
I.getOperand(i),
true);
4464 TypePrinter.print(
I.getType(), Out);
4468 for (
unsigned op = 0, Eop = PN->getNumIncomingValues();
op < Eop; ++
op) {
4470 writeOperand(PN->getIncomingValue(
op),
false); Out <<
", ";
4471 writeOperand(PN->getIncomingBlock(
op),
false); Out <<
" ]";
4475 writeOperand(
I.getOperand(0),
true);
4476 for (
unsigned i : EVI->indices())
4480 writeOperand(
I.getOperand(0),
true); Out <<
", ";
4481 writeOperand(
I.getOperand(1),
true);
4482 for (
unsigned i : IVI->indices())
4486 TypePrinter.print(
I.getType(), Out);
4487 if (LPI->isCleanup() || LPI->getNumClauses() != 0)
4490 if (LPI->isCleanup())
4493 for (
unsigned i = 0, e = LPI->getNumClauses(); i != e; ++i) {
4494 if (i != 0 || LPI->isCleanup()) Out <<
"\n";
4495 if (LPI->isCatch(i))
4500 writeOperand(LPI->getClause(i),
true);
4504 writeOperand(CatchSwitch->getParentPad(),
false);
4507 for (
const BasicBlock *PadBB : CatchSwitch->handlers()) {
4509 writeOperand(PadBB,
true);
4512 if (
const BasicBlock *UnwindDest = CatchSwitch->getUnwindDest())
4513 writeOperand(UnwindDest,
true);
4518 writeOperand(FPI->getParentPad(),
false);
4521 for (
const Value *
Op : FPI->arg_operands()) {
4523 writeOperand(
Op,
true);
4530 writeOperand(CRI->getOperand(0),
false);
4533 writeOperand(CRI->getOperand(1),
true);
4536 writeOperand(CRI->getOperand(0),
false);
4539 if (CRI->hasUnwindDest())
4540 writeOperand(CRI->getOperand(1),
true);
4545 if (CI->getCallingConv() != CallingConv::C) {
4550 Operand = CI->getCalledOperand();
4551 FunctionType *FTy = CI->getFunctionType();
4552 Type *RetTy = FTy->getReturnType();
4553 const AttributeList &PAL = CI->getAttributes();
4555 if (PAL.hasRetAttrs())
4556 Out <<
' ' << PAL.getAsString(AttributeList::ReturnIndex);
4565 TypePrinter.print(FTy->isVarArg() ? FTy : RetTy, Out);
4567 writeOperand(Operand,
false);
4570 for (
unsigned op = 0, Eop = CI->arg_size();
op < Eop; ++
op) {
4572 writeParamOperand(CI->getArgOperand(
op), PAL.getParamAttrs(
op));
4577 if (CI->isMustTailCall() && CI->getParent() &&
4578 CI->getParent()->getParent() &&
4579 CI->getParent()->getParent()->isVarArg()) {
4580 if (CI->arg_size() > 0)
4586 if (PAL.hasFnAttrs())
4587 Out <<
" #" <<
Machine.getAttributeGroupSlot(PAL.getFnAttrs());
4589 writeOperandBundles(CI);
4591 Operand =
II->getCalledOperand();
4592 FunctionType *FTy =
II->getFunctionType();
4593 Type *RetTy = FTy->getReturnType();
4594 const AttributeList &PAL =
II->getAttributes();
4597 if (
II->getCallingConv() != CallingConv::C) {
4602 if (PAL.hasRetAttrs())
4603 Out <<
' ' << PAL.getAsString(AttributeList::ReturnIndex);
4613 TypePrinter.print(FTy->isVarArg() ? FTy : RetTy, Out);
4615 writeOperand(Operand,
false);
4618 for (
unsigned op = 0, Eop =
II->arg_size();
op < Eop; ++
op) {
4620 writeParamOperand(
II->getArgOperand(
op), PAL.getParamAttrs(
op));
4624 if (PAL.hasFnAttrs())
4625 Out <<
" #" <<
Machine.getAttributeGroupSlot(PAL.getFnAttrs());
4627 writeOperandBundles(
II);
4630 writeOperand(
II->getNormalDest(),
true);
4632 writeOperand(
II->getUnwindDest(),
true);
4634 Operand = CBI->getCalledOperand();
4635 FunctionType *FTy = CBI->getFunctionType();
4636 Type *RetTy = FTy->getReturnType();
4637 const AttributeList &PAL = CBI->getAttributes();
4640 if (CBI->getCallingConv() != CallingConv::C) {
4645 if (PAL.hasRetAttrs())
4646 Out <<
' ' << PAL.getAsString(AttributeList::ReturnIndex);
4653 TypePrinter.print(FTy->isVarArg() ? FTy : RetTy, Out);
4655 writeOperand(Operand,
false);
4657 ListSeparator ArgLS;
4658 for (
unsigned op = 0, Eop = CBI->arg_size();
op < Eop; ++
op) {
4660 writeParamOperand(CBI->getArgOperand(
op), PAL.getParamAttrs(
op));
4664 if (PAL.hasFnAttrs())
4665 Out <<
" #" <<
Machine.getAttributeGroupSlot(PAL.getFnAttrs());
4667 writeOperandBundles(CBI);
4670 writeOperand(CBI->getDefaultDest(),
true);
4672 ListSeparator DestLS;
4673 for (
const BasicBlock *Dest : CBI->getIndirectDests()) {
4675 writeOperand(Dest,
true);
4680 if (AI->isUsedWithInAlloca())
4682 if (AI->isSwiftError())
4683 Out <<
"swifterror ";
4684 TypePrinter.print(AI->getAllocatedType(), Out);
4690 if (!AI->getArraySize() || AI->isArrayAllocation() ||
4691 !AI->getArraySize()->getType()->isIntegerTy(32)) {
4693 writeOperand(AI->getArraySize(),
true);
4695 if (MaybeAlign
A = AI->getAlign()) {
4696 Out <<
", align " <<
A->value();
4699 unsigned AddrSpace = AI->getAddressSpace();
4700 if (AddrSpace != 0) {
4701 Out <<
", addrspace(" << AddrSpace <<
')';
4706 writeOperand(Operand,
true);
4709 TypePrinter.print(
I.getType(), Out);
4713 writeOperand(Operand,
true);
4716 TypePrinter.print(
I.getType(), Out);
4717 }
else if (Operand) {
4720 TypePrinter.print(
GEP->getSourceElementType(), Out);
4724 TypePrinter.print(LI->getType(), Out);
4731 bool PrintAllTypes =
false;
4739 PrintAllTypes =
true;
4741 for (
unsigned i = 1,
E =
I.getNumOperands(); i !=
E; ++i) {
4742 Operand =
I.getOperand(i);
4745 if (Operand && Operand->
getType() != TheType) {
4746 PrintAllTypes =
true;
4752 if (!PrintAllTypes) {
4754 TypePrinter.print(TheType, Out);
4759 for (
const Value *
Op :
I.operands()) {
4761 writeOperand(
Op, PrintAllTypes);
4768 writeAtomic(LI->getContext(), LI->getOrdering(), LI->getSyncScopeID());
4769 if (MaybeAlign
A = LI->getAlign())
4770 Out <<
", align " <<
A->value();
4773 writeAtomic(
SI->getContext(),
SI->getOrdering(),
SI->getSyncScopeID());
4774 if (MaybeAlign
A =
SI->getAlign())
4775 Out <<
", align " <<
A->value();
4777 writeAtomicCmpXchg(CXI->getContext(), CXI->getSuccessOrdering(),
4778 CXI->getFailureOrdering(), CXI->getSyncScopeID());
4779 Out <<
", align " << CXI->getAlign().value();
4781 writeAtomic(RMWI->getContext(), RMWI->getOrdering(),
4782 RMWI->getSyncScopeID());
4783 Out <<
", align " << RMWI->getAlign().value();
4785 writeAtomic(FI->getContext(), FI->getOrdering(), FI->getSyncScopeID());
4793 printMetadataAttachments(InstMD,
", ");
4796 printInfoComment(
I);
4799void AssemblyWriter::printDbgMarker(
const DbgMarker &Marker) {
4803 printDbgRecord(DPR);
4807 Out <<
" DbgMarker -> { ";
4812void AssemblyWriter::printDbgRecord(
const DbgRecord &DR) {
4814 printDbgVariableRecord(*DVR);
4816 printDbgLabelRecord(*DLR);
4821void AssemblyWriter::printDbgVariableRecord(
const DbgVariableRecord &DVR) {
4825 case DbgVariableRecord::LocationType::Value:
4828 case DbgVariableRecord::LocationType::Declare:
4831 case DbgVariableRecord::LocationType::Assign:
4836 "Tried to print a DbgVariableRecord with an invalid LocationType!");
4867void AssemblyWriter::printDbgRecordLine(
const DbgRecord &DR) {
4874void AssemblyWriter::printDbgLabelRecord(
const DbgLabelRecord &Label) {
4876 Out <<
"#dbg_label(";
4883void AssemblyWriter::printMetadataAttachments(
4884 const SmallVectorImpl<std::pair<unsigned, MDNode *>> &MDs,
4885 StringRef Separator) {
4889 if (MDNames.empty())
4890 MDs[0].second->getContext().getMDKindNames(MDNames);
4893 for (
const auto &
I : MDs) {
4894 unsigned Kind =
I.first;
4896 if (Kind < MDNames.size()) {
4900 Out <<
"!<unknown kind #" <<
Kind <<
">";
4906void AssemblyWriter::writeMDNode(
unsigned Slot,
const MDNode *Node) {
4907 Out <<
'!' <<
Slot <<
" = ";
4908 printMDNodeBody(Node);
4912void AssemblyWriter::writeAllMDNodes() {
4918 for (
unsigned i = 0, e = Nodes.
size(); i != e; ++i) {
4919 writeMDNode(i, Nodes[i]);
4923void AssemblyWriter::printMDNodeBody(
const MDNode *Node) {
4928void AssemblyWriter::writeAttribute(
const Attribute &Attr,
bool InAttrGroup) {
4934 Out << Attribute::getNameFromAttrKind(Attr.
getKindAsEnum());
4937 TypePrinter.print(Ty, Out);
4942void AssemblyWriter::writeAttributeSet(
const AttributeSet &AttrSet,
4944 bool FirstAttr =
true;
4945 for (
const auto &Attr : AttrSet) {
4948 writeAttribute(Attr, InAttrGroup);
4953void AssemblyWriter::writeAllAttributeGroups() {
4954 std::vector<std::pair<AttributeSet, unsigned>> asVec;
4955 asVec.resize(
Machine.as_size());
4958 asVec[
I.second] =
I;
4960 for (
const auto &
I : asVec)
4961 Out <<
"attributes #" <<
I.second <<
" = { "
4962 <<
I.first.getAsString(
true) <<
" }\n";
4965void AssemblyWriter::printUseListOrder(
const Value *V,
4966 const std::vector<unsigned> &Shuffle) {
4971 Out <<
"uselistorder";
4974 writeOperand(BB->getParent(),
false);
4976 writeOperand(BB,
false);
4979 writeOperand(V,
true);
4982 assert(Shuffle.size() >= 2 &&
"Shuffle too small");
4986void AssemblyWriter::printUseLists(
const Function *
F) {
4987 auto It = UseListOrders.find(
F);
4988 if (It == UseListOrders.end())
4991 Out <<
"\n; uselistorder directives\n";
4992 for (
const auto &Pair : It->second)
4993 printUseListOrder(Pair.first, Pair.second);
5001 bool ShouldPreserveUseListOrder,
5002 bool IsForDebug)
const {
5005 AssemblyWriter W(OS, SlotTable, this->
getParent(), AAW,
5007 ShouldPreserveUseListOrder);
5008 W.printFunction(
this);
5012 bool ShouldPreserveUseListOrder,
5013 bool IsForDebug)
const {
5016 AssemblyWriter W(OS, SlotTable, this->
getModule(), AAW,
5018 ShouldPreserveUseListOrder);
5019 W.printBasicBlock(
this);
5023 bool ShouldPreserveUseListOrder,
bool IsForDebug)
const {
5026 AssemblyWriter W(OS, SlotTable,
this, AAW, IsForDebug,
5027 ShouldPreserveUseListOrder);
5028 W.printModule(
this);
5034 AssemblyWriter W(OS, SlotTable,
getParent(),
nullptr, IsForDebug);
5035 W.printNamedMDNode(
this);
5039 bool IsForDebug)
const {
5040 std::optional<SlotTracker> LocalST;
5046 SlotTable = &*LocalST;
5050 AssemblyWriter W(OS, *SlotTable,
getParent(),
nullptr, IsForDebug);
5051 W.printNamedMDNode(
this);
5056 ROS <<
" = comdat ";
5063 ROS <<
"exactmatch";
5069 ROS <<
"nodeduplicate";
5081 TP.print(
const_cast<Type*
>(
this), OS);
5090 TP.printStructBody(STy, OS);
5096 if (
Function *
F = CI->getCalledFunction())
5097 if (
F->isIntrinsic())
5098 for (
auto &
Op :
I.operands())
5108 print(ROS, MST, IsForDebug);
5114 print(ROS, MST, IsForDebug);
5118 bool IsForDebug)
const {
5123 auto incorporateFunction = [&](
const Function *
F) {
5128 AssemblyWriter W(OS, SlotTable,
getModuleFromDPI(
this),
nullptr, IsForDebug);
5129 W.printDbgMarker(*
this);
5135 print(ROS, MST, IsForDebug);
5139 bool IsForDebug)
const {
5144 auto incorporateFunction = [&](
const Function *
F) {
5149 ?
Marker->getParent()->getParent()
5151 AssemblyWriter W(OS, SlotTable,
getModuleFromDPI(
this),
nullptr, IsForDebug);
5152 W.printDbgVariableRecord(*
this);
5156 bool IsForDebug)
const {
5161 auto incorporateFunction = [&](
const Function *
F) {
5165 incorporateFunction(
Marker->getParent() ?
Marker->getParent()->getParent()
5167 AssemblyWriter W(OS, SlotTable,
getModuleFromDPI(
this),
nullptr, IsForDebug);
5168 W.printDbgLabelRecord(*
this);
5172 bool ShouldInitializeAllMetadata =
false;
5176 ShouldInitializeAllMetadata =
true;
5179 print(ROS, MST, IsForDebug);
5183 bool IsForDebug)
const {
5188 auto incorporateFunction = [&](
const Function *
F) {
5194 incorporateFunction(
I->getParent() ?
I->getParent()->getParent() :
nullptr);
5196 W.printInstruction(*
I);
5198 incorporateFunction(BB->getParent());
5199 AssemblyWriter W(OS, SlotTable,
getModuleFromVal(BB),
nullptr, IsForDebug);
5200 W.printBasicBlock(BB);
5202 AssemblyWriter W(OS, SlotTable, GV->
getParent(),
nullptr, IsForDebug);
5216 TypePrinting TypePrinter;
5217 TypePrinter.print(
C->getType(), OS);
5219 AsmWriterContext WriterCtx(&TypePrinter, MST.
getMachine());
5235 AsmWriterContext WriterCtx(
nullptr,
Machine, M);
5244 TypePrinting TypePrinter(MST.
getModule());
5275 AsmWriterContext &WriterCtx) {
5288struct MDTreeAsmWriterContext :
public AsmWriterContext {
5291 using EntryTy = std::pair<unsigned, std::string>;
5295 SmallPtrSet<const Metadata *, 4> Visited;
5297 raw_ostream &MainOS;
5299 MDTreeAsmWriterContext(TypePrinting *TP, SlotTracker *ST,
const Module *M,
5300 raw_ostream &OS,
const Metadata *InitMD)
5301 : AsmWriterContext(TP,
ST,
M),
Level(0
U), Visited({InitMD}), MainOS(OS) {}
5303 void onWriteMetadataAsOperand(
const Metadata *MD)
override {
5304 if (!Visited.
insert(MD).second)
5308 raw_string_ostream
SS(Str);
5313 unsigned InsertIdx = Buffer.
size() - 1;
5316 Buffer[InsertIdx].second = std::move(
SS.str());
5320 ~MDTreeAsmWriterContext() {
5321 for (
const auto &Entry : Buffer) {
5323 unsigned NumIndent =
Entry.first * 2U;
5332 bool OnlyAsOperand,
bool PrintAsTree =
false) {
5335 TypePrinting TypePrinter(M);
5337 std::unique_ptr<AsmWriterContext> WriterCtx;
5338 if (PrintAsTree && !OnlyAsOperand)
5339 WriterCtx = std::make_unique<MDTreeAsmWriterContext>(
5343 std::make_unique<AsmWriterContext>(&TypePrinter, MST.
getMachine(), M);
5372 const Module *M,
bool )
const {
5391 AssemblyWriter W(OS, SlotTable,
this, IsForDebug);
5392 W.printModuleSummaryIndex();
5396 unsigned UB)
const {
5402 if (
I.second >= LB &&
I.second < UB)
5403 L.push_back(std::make_pair(
I.second,
I.first));
5406#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...
This file implements a class to represent arbitrary precision integral constant values and operations...
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
static void print(raw_ostream &Out, object::Archive::Kind Kind, T Val)
static void writeDIMacro(raw_ostream &Out, const DIMacro *N, AsmWriterContext &WriterCtx)
static void writeMetadataAsOperand(raw_ostream &Out, const Metadata *MD, AsmWriterContext &WriterCtx)
static void writeDIGlobalVariableExpression(raw_ostream &Out, const DIGlobalVariableExpression *N, AsmWriterContext &WriterCtx)
static void PrintCallingConv(unsigned cc, raw_ostream &Out)
static void writeDICompositeType(raw_ostream &Out, const DICompositeType *N, AsmWriterContext &WriterCtx)
static void writeDIFixedPointType(raw_ostream &Out, const DIFixedPointType *N, AsmWriterContext &WriterCtx)
static const char * getWholeProgDevirtResKindName(WholeProgramDevirtResolution::Kind K)
static void writeDISubrangeType(raw_ostream &Out, const DISubrangeType *N, AsmWriterContext &WriterCtx)
static void printMetadataImpl(raw_ostream &ROS, const Metadata &MD, ModuleSlotTracker &MST, const Module *M, bool OnlyAsOperand, bool PrintAsTree=false)
static void WriteOptimizationInfo(raw_ostream &Out, const User *U)
static void writeDIStringType(raw_ostream &Out, const DIStringType *N, AsmWriterContext &WriterCtx)
static std::string getLinkageNameWithSpace(GlobalValue::LinkageTypes LT)
static std::vector< unsigned > predictValueUseListOrder(const Value *V, unsigned ID, const OrderMap &OM)
static void writeDIGlobalVariable(raw_ostream &Out, const DIGlobalVariable *N, AsmWriterContext &WriterCtx)
static void orderValue(const Value *V, OrderMap &OM)
static void PrintThreadLocalModel(GlobalVariable::ThreadLocalMode TLM, formatted_raw_ostream &Out)
static void writeDIBasicType(raw_ostream &Out, const DIBasicType *N, AsmWriterContext &WriterCtx)
static void PrintLLVMName(raw_ostream &OS, StringRef Name, PrefixType Prefix)
Turn the specified name into an 'LLVM name', which is either prefixed with % (if the string only cont...
static StringRef getUnnamedAddrEncoding(GlobalVariable::UnnamedAddr UA)
static const char * getWholeProgDevirtResByArgKindName(WholeProgramDevirtResolution::ByArg::Kind K)
static void PrintShuffleMask(raw_ostream &Out, Type *Ty, ArrayRef< int > Mask)
static void WriteAsOperandInternal(raw_ostream &Out, const Value *V, AsmWriterContext &WriterCtx, bool PrintType=false)
static void writeDIModule(raw_ostream &Out, const DIModule *N, AsmWriterContext &WriterCtx)
static void writeDIFile(raw_ostream &Out, const DIFile *N, AsmWriterContext &)
static void writeDISubroutineType(raw_ostream &Out, const DISubroutineType *N, AsmWriterContext &WriterCtx)
static bool isReferencingMDNode(const Instruction &I)
#define CC_VLS_CASE(ABI_VLEN)
static void writeDILabel(raw_ostream &Out, const DILabel *N, AsmWriterContext &WriterCtx)
static void WriteMDNodeBodyInternal(raw_ostream &Out, const MDNode *Node, AsmWriterContext &Ctx)
static void writeDIDerivedType(raw_ostream &Out, const DIDerivedType *N, AsmWriterContext &WriterCtx)
static void printMetadataIdentifier(StringRef Name, formatted_raw_ostream &Out)
static void writeDIImportedEntity(raw_ostream &Out, const DIImportedEntity *N, AsmWriterContext &WriterCtx)
static const Module * getModuleFromDPI(const DbgMarker *Marker)
static void printAsOperandImpl(const Value &V, raw_ostream &O, bool PrintType, ModuleSlotTracker &MST)
static void writeDIObjCProperty(raw_ostream &Out, const DIObjCProperty *N, AsmWriterContext &WriterCtx)
static void PrintDLLStorageClass(GlobalValue::DLLStorageClassTypes SCT, formatted_raw_ostream &Out)
static void writeDISubprogram(raw_ostream &Out, const DISubprogram *N, AsmWriterContext &WriterCtx)
static const char * getSummaryKindName(GlobalValueSummary::SummaryKind SK)
static OrderMap orderModule(const Module *M)
static const char * getVisibilityName(GlobalValue::VisibilityTypes Vis)
static cl::opt< bool > PrintInstDebugLocs("print-inst-debug-locs", cl::Hidden, cl::desc("Pretty print debug locations of instructions when dumping"))
static void printMetadataImplRec(raw_ostream &ROS, const Metadata &MD, AsmWriterContext &WriterCtx)
Recursive version of printMetadataImpl.
static SlotTracker * createSlotTracker(const Value *V)
static void WriteAPFloatInternal(raw_ostream &Out, const APFloat &APF)
static void writeDILocation(raw_ostream &Out, const DILocation *DL, AsmWriterContext &WriterCtx)
static void writeDINamespace(raw_ostream &Out, const DINamespace *N, AsmWriterContext &WriterCtx)
DenseMap< const Function *, MapVector< const Value *, std::vector< unsigned > > > UseListOrderMap
static void writeDICommonBlock(raw_ostream &Out, const DICommonBlock *N, AsmWriterContext &WriterCtx)
static UseListOrderMap predictUseListOrder(const Module *M)
static void WriteConstantInternal(raw_ostream &Out, const Constant *CV, AsmWriterContext &WriterCtx)
static std::string getLinkageName(GlobalValue::LinkageTypes LT)
static void writeGenericDINode(raw_ostream &Out, const GenericDINode *N, AsmWriterContext &WriterCtx)
static void writeDILocalVariable(raw_ostream &Out, const DILocalVariable *N, AsmWriterContext &WriterCtx)
static const char * getTTResKindName(TypeTestResolution::Kind K)
static void writeDITemplateTypeParameter(raw_ostream &Out, const DITemplateTypeParameter *N, AsmWriterContext &WriterCtx)
static const char * getImportTypeName(GlobalValueSummary::ImportKind IK)
static void writeDICompileUnit(raw_ostream &Out, const DICompileUnit *N, AsmWriterContext &WriterCtx)
static const Module * getModuleFromVal(const Value *V)
static void maybePrintCallAddrSpace(const Value *Operand, const Instruction *I, raw_ostream &Out)
static void writeDIGenericSubrange(raw_ostream &Out, const DIGenericSubrange *N, AsmWriterContext &WriterCtx)
static void writeDISubrange(raw_ostream &Out, const DISubrange *N, AsmWriterContext &WriterCtx)
static void PrintVisibility(GlobalValue::VisibilityTypes Vis, formatted_raw_ostream &Out)
static void writeDILexicalBlockFile(raw_ostream &Out, const DILexicalBlockFile *N, AsmWriterContext &WriterCtx)
static void writeDIEnumerator(raw_ostream &Out, const DIEnumerator *N, AsmWriterContext &)
static cl::opt< bool > PrintProfData("print-prof-data", cl::Hidden, cl::desc("Pretty print perf data (branch weights, etc) when dumping"))
static void writeMDTuple(raw_ostream &Out, const MDTuple *Node, AsmWriterContext &WriterCtx)
static void writeDIExpression(raw_ostream &Out, const DIExpression *N, AsmWriterContext &WriterCtx)
static void PrintDSOLocation(const GlobalValue &GV, formatted_raw_ostream &Out)
static cl::opt< bool > PrintInstAddrs("print-inst-addrs", cl::Hidden, cl::desc("Print addresses of instructions when dumping"))
static void writeDIAssignID(raw_ostream &Out, const DIAssignID *DL, AsmWriterContext &WriterCtx)
static void writeDILexicalBlock(raw_ostream &Out, const DILexicalBlock *N, AsmWriterContext &WriterCtx)
static void maybePrintComdat(formatted_raw_ostream &Out, const GlobalObject &GO)
static bool printWithoutType(const Value &V, raw_ostream &O, SlotTracker *Machine, const Module *M)
Print without a type, skipping the TypePrinting object.
static void writeDIArgList(raw_ostream &Out, const DIArgList *N, AsmWriterContext &WriterCtx, bool FromValue=false)
static void writeDITemplateValueParameter(raw_ostream &Out, const DITemplateValueParameter *N, AsmWriterContext &WriterCtx)
static const Value * skipMetadataWrapper(const Value *V)
Look for a value that might be wrapped as metadata, e.g.
static void writeDIMacroFile(raw_ostream &Out, const DIMacroFile *N, AsmWriterContext &WriterCtx)
Atomic ordering constants.
This file contains the simple types necessary to represent the attributes associated with functions a...
static const Function * getParent(const Value *V)
static GCRegistry::Add< ErlangGC > A("erlang", "erlang-compatible garbage collector")
static GCRegistry::Add< CoreCLRGC > E("coreclr", "CoreCLR-compatible GC")
#define LLVM_DUMP_METHOD
Mark debug helper function definitions like dump() that should not be stripped from debug builds.
This file contains the declarations for the subclasses of Constant, which represent the different fla...
dxil pretty DXIL Metadata Pretty Printer
This file defines the DenseMap class.
This file contains constants used for implementing Dwarf debug support.
This file contains the declaration of the GlobalIFunc class, which represents a single indirect funct...
GlobalValue::SanitizerMetadata SanitizerMetadata
This file provides various utilities for inspecting and working with the control flow graph in LLVM I...
This file contains an interface for creating legacy passes to print out IR in various granularities.
Module.h This file contains the declarations for the Module class.
This defines the Use class.
Machine Check Debug Module
static bool InRange(int64_t Value, unsigned short Shift, int LBound, int HBound)
ModuleSummaryIndex.h This file contains the declarations the classes that hold the module index and s...
static bool processFunction(Function &F, NVPTXTargetMachine &TM)
ConstantRange Range(APInt(BitWidth, Low), APInt(BitWidth, High))
uint64_t IntrinsicInst * II
Function const char TargetMachine * Machine
if(auto Err=PB.parsePassPipeline(MPM, Passes)) return wrap(std MPM run * Mod
static StringRef getName(Value *V)
This file provides utility classes that use RAII to save and restore values.
This file implements a set that has insertion order iteration characteristics.
This file defines the SmallPtrSet class.
This file defines the SmallString class.
This file defines the SmallVector class.
LocallyHashedType DenseMapInfo< LocallyHashedType >::Empty
static UseListOrderStack predictUseListOrder(const Module &M)
static APFloat getSNaN(const fltSemantics &Sem, bool Negative=false, const APInt *payload=nullptr)
Factory for SNaN values.
LLVM_ABI opStatus convert(const fltSemantics &ToSemantics, roundingMode RM, bool *losesInfo)
LLVM_ABI double convertToDouble() const
Converts this APFloat to host double value.
void toString(SmallVectorImpl< char > &Str, unsigned FormatPrecision=0, unsigned FormatMaxPadding=3, bool TruncateZero=true) const
const fltSemantics & getSemantics() const
APInt bitcastToAPInt() const
Class for arbitrary precision integers.
LLVM_ABI APInt getLoBits(unsigned numBits) const
Compute an APInt containing numBits lowbits from this APInt.
uint64_t getZExtValue() const
Get zero extended value.
LLVM_ABI APInt getHiBits(unsigned numBits) const
Compute an APInt containing numBits highbits from this APInt.
Abstract interface of slot tracker storage.
virtual ~AbstractSlotTrackerStorage()
const GlobalValueSummary & getAliasee() const
This class represents an incoming formal argument to a Function.
ArrayRef - Represent a constant reference to an array (0 or more elements consecutively in memory),...
virtual void emitBasicBlockStartAnnot(const BasicBlock *, formatted_raw_ostream &)
emitBasicBlockStartAnnot - This may be implemented to emit a string right after the basic block label...
virtual void emitBasicBlockEndAnnot(const BasicBlock *, formatted_raw_ostream &)
emitBasicBlockEndAnnot - This may be implemented to emit a string right after the basic block.
virtual void emitFunctionAnnot(const Function *, formatted_raw_ostream &)
emitFunctionAnnot - This may be implemented to emit a string right before the start of a function.
virtual void emitInstructionAnnot(const Instruction *, formatted_raw_ostream &)
emitInstructionAnnot - This may be implemented to emit a string right before an instruction is emitte...
virtual void printInfoComment(const Value &, formatted_raw_ostream &)
printInfoComment - This may be implemented to emit a comment to the right of an instruction or global...
virtual ~AssemblyAnnotationWriter()
static LLVM_ABI StringRef getOperationName(BinOp Op)
This class holds the attributes for a particular argument, parameter, function, or return value.
bool hasAttributes() const
Return true if attributes exists in this set.
LLVM_ABI std::string getAsString(bool InAttrGrp=false) const
The Attribute is converted to a string of equivalent mnemonic.
LLVM_ABI Attribute::AttrKind getKindAsEnum() const
Return the attribute's kind as an enum (Attribute::AttrKind).
LLVM_ABI bool isTypeAttribute() const
Return true if the attribute is a type attribute.
LLVM_ABI Type * getValueAsType() const
Return the attribute's value as a Type.
LLVM Basic Block Representation.
const Function * getParent() const
Return the enclosing method, or null if none.
LLVM_ABI void print(raw_ostream &OS, AssemblyAnnotationWriter *AAW=nullptr, bool ShouldPreserveUseListOrder=false, bool IsForDebug=false) const
Print the basic block to an output stream with an optional AssemblyAnnotationWriter.
LLVM_ABI bool isEntryBlock() const
Return true if this is the entry block of the containing function.
LLVM_ABI const Module * getModule() const
Return the module owning the function this basic block belongs to, or nullptr if the function does no...
The address of a basic block.
OperandBundleUse getOperandBundleAt(unsigned Index) const
Return the operand bundle at a specific index.
unsigned getNumOperandBundles() const
Return the number of operand bundles associated with this User.
AttributeList getAttributes() const
Return the attributes for this call.
bool hasOperandBundles() const
Return true if this User has any operand bundles.
LLVM_ABI void print(raw_ostream &OS, bool IsForDebug=false) const
LLVM_ABI void dump() const
@ Largest
The linker will choose the largest COMDAT.
@ SameSize
The data referenced by the COMDAT must be the same size.
@ Any
The linker may choose any COMDAT.
@ NoDeduplicate
No deduplication is performed.
@ ExactMatch
The data referenced by the COMDAT must be the same.
SelectionKind getSelectionKind() const
ConstantArray - Constant Array Declarations.
An array constant whose element type is a simple 1/2/4/8-byte integer or float/double,...
A constant value that is initialized with an expression using other constant values.
ConstantFP - Floating Point Values [float, double].
This is the shared class of boolean and integer constants.
A signed pointer, in the ptrauth sense.
LLVM_ABI APInt getSignedMin() const
Return the smallest signed value contained in the ConstantRange.
LLVM_ABI APInt getSignedMax() const
Return the largest signed value contained in the ConstantRange.
This is an important base class in LLVM.
LLVM_ABI Constant * getSplatValue(bool AllowPoison=false) const
If all elements of the vector constant have the same value, return that value.
LLVM_ABI Constant * getAggregateElement(unsigned Elt) const
For aggregates (struct/array/vector) return the constant that corresponds to the specified element if...
List of ValueAsMetadata, to be used as an argument to a dbg.value intrinsic.
Basic type, like 'int' or 'float'.
static LLVM_ABI const char * nameTableKindString(DebugNameTableKind PK)
static LLVM_ABI const char * emissionKindString(DebugEmissionKind EK)
A lightweight wrapper around an expression operand.
static LLVM_ABI const char * fixedPointKindString(FixedPointKind)
A pair of DIGlobalVariable and DIExpression.
An imported module (C++ using directive or similar).
Macro Info DWARF-like metadata node.
Represents a module in the programming language, for example, a Clang module, or a Fortran module.
Tagged DWARF-like metadata node.
static LLVM_ABI DIFlags splitFlags(DIFlags Flags, SmallVectorImpl< DIFlags > &SplitFlags)
Split up a flags bitfield.
static LLVM_ABI StringRef getFlagString(DIFlags Flag)
String type, Fortran CHARACTER(n)
Subprogram description. Uses SubclassData1.
static LLVM_ABI DISPFlags splitFlags(DISPFlags Flags, SmallVectorImpl< DISPFlags > &SplitFlags)
Split up a flags bitfield for easier printing.
static LLVM_ABI StringRef getFlagString(DISPFlags Flag)
DISPFlags
Debug info subprogram flags.
Type array for a subprogram.
LLVM_ABI void print(raw_ostream &O, bool IsForDebug=false) const
Per-instruction record of debug-info.
LLVM_ABI void dump() const
Instruction * MarkedInstr
Link back to the Instruction that owns this marker.
LLVM_ABI void print(raw_ostream &O, bool IsForDebug=false) const
Implement operator<< on DbgMarker.
LLVM_ABI const BasicBlock * getParent() const
simple_ilist< DbgRecord > StoredDbgRecords
List of DbgRecords, the non-instruction equivalent of llvm.dbg.
Base class for non-instruction debug metadata records that have positions within IR.
DebugLoc getDebugLoc() const
LLVM_ABI void dump() const
DbgMarker * Marker
Marker that this DbgRecord is linked into.
Record of a variable value-assignment, aka a non instruction representation of the dbg....
LocationType getType() const
LLVM_ABI void print(raw_ostream &O, bool IsForDebug=false) const
MDNode * getRawExpression() const
MDNode * getRawAddressExpression() const
Metadata * getRawAssignID() const
MDNode * getRawVariable() const
Metadata * getRawLocation() const
Returns the metadata operand for the first location description.
Metadata * getRawAddress() const
MDNode * getAsMDNode() const
Return this as a bar MDNode.
DenseMapIterator< KeyT, ValueT, KeyInfoT, BucketT > iterator
Utility class for floating point operations which can have information about relaxed accuracy require...
void print(raw_ostream &OS, AssemblyAnnotationWriter *AAW=nullptr, bool ShouldPreserveUseListOrder=false, bool IsForDebug=false) const
Print the function to an output stream with an optional AssemblyAnnotationWriter.
const Function & getFunction() const
const Argument * const_arg_iterator
LLVM_ABI Value * getBasePtr() const
LLVM_ABI Value * getDerivedPtr() const
Generic tagged DWARF-like metadata node.
const Constant * getAliasee() const
const Constant * getResolver() const
StringRef getSection() const
Get the custom section of this global if it has one.
LLVM_ABI void getAllMetadata(SmallVectorImpl< std::pair< unsigned, MDNode * > > &MDs) const
Appends all metadata attached to this value to MDs, sorting by KindID.
const Comdat * getComdat() const
bool hasSection() const
Check if this global has a custom object file section.
SummaryKind
Sububclass discriminator (for dyn_cast<> et al.)
bool hasPartition() const
static LLVM_ABI GUID getGUIDAssumingExternalLinkage(StringRef GlobalName)
Return a 64-bit global unique ID constructed from the name of a global symbol.
LLVM_ABI const SanitizerMetadata & getSanitizerMetadata() const
bool hasExternalLinkage() const
VisibilityTypes getVisibility() const
bool isImplicitDSOLocal() const
LinkageTypes getLinkage() const
uint64_t GUID
Declare a type to represent a global unique identifier for a global value.
ThreadLocalMode getThreadLocalMode() const
DLLStorageClassTypes
Storage classes of global values for PE targets.
@ DLLExportStorageClass
Function to be accessible from DLL.
@ DLLImportStorageClass
Function to be imported from DLL.
bool hasSanitizerMetadata() const
LLVM_ABI StringRef getPartition() const
Module * getParent()
Get the module that this global value is contained inside of...
PointerType * getType() const
Global values are always pointers.
VisibilityTypes
An enumeration for the kinds of visibility of global values.
@ DefaultVisibility
The GV is visible.
@ HiddenVisibility
The GV is hidden.
@ ProtectedVisibility
The GV is protected.
LLVM_ABI bool isMaterializable() const
If this function's Module is being lazily streamed in functions from disk or some other source,...
UnnamedAddr getUnnamedAddr() const
LinkageTypes
An enumeration for the kinds of linkage for global values.
@ PrivateLinkage
Like Internal, but omit from symbol table.
@ CommonLinkage
Tentative definitions.
@ InternalLinkage
Rename collisions when linking (static functions).
@ LinkOnceAnyLinkage
Keep one copy of function when linking (inline)
@ WeakODRLinkage
Same, but only replaced by something equivalent.
@ ExternalLinkage
Externally visible function.
@ WeakAnyLinkage
Keep one copy of named function when linking (weak)
@ AppendingLinkage
Special purpose, only applies to global arrays.
@ AvailableExternallyLinkage
Available for inspection, not emission.
@ ExternalWeakLinkage
ExternalWeak linkage description.
@ LinkOnceODRLinkage
Same, but only replaced by something equivalent.
DLLStorageClassTypes getDLLStorageClass() const
Type * getValueType() const
const Constant * getInitializer() const
getInitializer - Return the initializer for this global variable.
bool isExternallyInitialized() const
bool hasInitializer() const
Definitions have initializers, declarations don't.
AttributeSet getAttributes() const
Return the attribute set for this global.
std::optional< CodeModel::Model > getCodeModel() const
Get the custom code model of this global if it has one.
MaybeAlign getAlign() const
Returns the alignment of the given variable.
bool isConstant() const
If the value is a global constant, its value is immutable throughout the runtime execution of the pro...
A helper class to return the specified delimiter string after the first invocation of operator String...
LLVM_ABI void printTree(raw_ostream &OS, const Module *M=nullptr) const
Print in tree shape.
LLVM_ABI void dumpTree() const
User-friendly dump in tree shape.
This class implements a map that also provides access to all stored values in a deterministic order.
Manage lifetime of a slot tracker for printing IR.
const Module * getModule() const
ModuleSlotTracker(SlotTracker &Machine, const Module *M, const Function *F=nullptr)
Wrap a preinitialized SlotTracker.
virtual ~ModuleSlotTracker()
Destructor to clean up storage.
std::vector< std::pair< unsigned, const MDNode * > > MachineMDNodeListType
int getLocalSlot(const Value *V)
Return the slot number of the specified local value.
void collectMDNodes(MachineMDNodeListType &L, unsigned LB, unsigned UB) const
SlotTracker * getMachine()
Lazily creates a slot tracker.
void setProcessHook(std::function< void(AbstractSlotTrackerStorage *, const Module *, bool)>)
void incorporateFunction(const Function &F)
Incorporate the given function.
Class to hold module path string table and global value map, and encapsulate methods for operating on...
static constexpr const char * getRegularLTOModuleName()
LLVM_ABI void dump() const
Dump to stderr (for debugging).
LLVM_ABI void print(raw_ostream &OS, bool IsForDebug=false) const
Print to an output stream.
A Module instance is used to store all the information related to an LLVM module.
iterator_range< alias_iterator > aliases()
iterator_range< global_iterator > globals()
void print(raw_ostream &OS, AssemblyAnnotationWriter *AAW, bool ShouldPreserveUseListOrder=false, bool IsForDebug=false) const
Print the module to an output stream with an optional AssemblyAnnotationWriter.
void dump() const
Dump the module to stderr (for debugging).
LLVM_ABI void dump() const
LLVM_ABI StringRef getName() const
LLVM_ABI void print(raw_ostream &ROS, bool IsForDebug=false) const
iterator_range< op_iterator > operands()
Utility class for integer operators which may exhibit overflow - Add, Sub, Mul, and Shl.
unsigned getAddressSpace() const
Return the address space of the Pointer type.
An or instruction, which can be marked as "disjoint", indicating that the inputs don't have a 1 in th...
A udiv, sdiv, lshr, or ashr instruction, which can be marked as "exact", indicating that no bits are ...
This class provides computation of slot numbers for LLVM Assembly writing.
DenseMap< const Value *, unsigned > ValueMap
ValueMap - A mapping of Values to slot numbers.
int getMetadataSlot(const MDNode *N) override
getMetadataSlot - Get the slot number of a MDNode.
int getTypeIdCompatibleVtableSlot(StringRef Id)
int getModulePathSlot(StringRef Path)
unsigned mdn_size() const
SlotTracker(const SlotTracker &)=delete
void purgeFunction()
After calling incorporateFunction, use this method to remove the most recently incorporated function ...
int getTypeIdSlot(StringRef Id)
void initializeIfNeeded()
These functions do the actual initialization.
int getGlobalSlot(const GlobalValue *V)
getGlobalSlot - Get the slot number of a global value.
const Function * getFunction() const
unsigned getNextMetadataSlot() override
DenseMap< GlobalValue::GUID, unsigned >::iterator guid_iterator
GUID map iterators.
void incorporateFunction(const Function *F)
If you'd like to deal with a function instead of just a module, use this method to get its data into ...
int getLocalSlot(const Value *V)
Return the slot number of the specified value in it's type plane.
int getAttributeGroupSlot(AttributeSet AS)
SlotTracker(const Module *M, bool ShouldInitializeAllMetadata=false)
Construct from a module.
void createMetadataSlot(const MDNode *N) override
getMetadataSlot - Get the slot number of a MDNode.
void setProcessHook(std::function< void(AbstractSlotTrackerStorage *, const Module *, bool)>)
DenseMap< const MDNode *, unsigned >::iterator mdn_iterator
MDNode map iterators.
SlotTracker & operator=(const SlotTracker &)=delete
int getGUIDSlot(GlobalValue::GUID GUID)
int initializeIndexIfNeeded()
DenseMap< AttributeSet, unsigned >::iterator as_iterator
AttributeSet map iterators.
std::pair< iterator, bool > insert(PtrType Ptr)
Inserts Ptr if and only if there is no element in the container equal to Ptr.
SmallString - A SmallString is just a SmallVector with methods and accessors that make it work better...
reference emplace_back(ArgTypes &&... Args)
void push_back(const T &Elt)
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
StringMap - This is an unconventional map that is specialized for handling keys that are "strings",...
StringRef - Represent a constant reference to a string, i.e.
constexpr bool empty() const
empty - Check if the string is empty.
Class to represent struct types.
ArrayRef< Type * > elements() const
unsigned getNumElements() const
Random access to the elements.
bool isLiteral() const
Return true if this type is uniqued by structural equivalence, false if it is a struct definition.
bool isOpaque() const
Return true if this is a type with an identity that has no body specified yet.
LLVM_ABI StringRef getName() const
Return the name for this struct type if it has an identity.
ArrayRef< Type * > type_params() const
Return the type parameters for this particular target extension type.
ArrayRef< unsigned > int_params() const
Return the integer parameters for this particular target extension type.
TypeFinder - Walk over a module, identifying all of the types that are used by the module.
void run(const Module &M, bool onlyNamed)
The instances of the Type class are immutable: once they are created, they are never changed.
LLVM_ABI unsigned getPointerAddressSpace() const
Get the address space of this pointer or pointer vector type.
LLVM_ABI StringRef getTargetExtName() const
Type(LLVMContext &C, TypeID tid)
LLVM_ABI void dump() const
LLVM_ABI void print(raw_ostream &O, bool IsForDebug=false, bool NoDetails=false) const
Print the current type.
TypeID getTypeID() const
Return the type id for the type.
Type * getElementType() const
unsigned getAddressSpace() const
Return the address space of the Pointer type.
A Use represents the edge between a Value definition and its users.
LLVM Value Representation.
Type * getType() const
All values are typed, get the type of this value.
LLVM_ABI void print(raw_ostream &O, bool IsForDebug=false) const
Implement operator<< on Value.
LLVM_ABI void getAllMetadata(SmallVectorImpl< std::pair< unsigned, MDNode * > > &MDs) const
Appends all metadata attached to this value to MDs, sorting by KindID.
iterator_range< user_iterator > users()
LLVM_ABI void printAsOperand(raw_ostream &O, bool PrintType=true, const Module *M=nullptr) const
Print the name of this Value out to the specified raw_ostream.
iterator_range< use_iterator > uses()
LLVM_ABI StringRef getName() const
Return a constant reference to the value's name.
LLVM_ABI void dump() const
Support for debugging, callable in GDB: V->dump()
This class implements an extremely fast bulk output stream that can only output to a stream.
raw_ostream & indent(unsigned NumSpaces)
indent - Insert 'NumSpaces' spaces.
LLVM_ABI StringRef EnumKindString(unsigned EnumKind)
LLVM_ABI StringRef LanguageString(unsigned Language)
LLVM_ABI StringRef AttributeEncodingString(unsigned Encoding)
LLVM_ABI StringRef ConventionString(unsigned Convention)
LLVM_ABI StringRef MacinfoString(unsigned Encoding)
LLVM_ABI StringRef OperationEncodingString(unsigned Encoding)
LLVM_ABI StringRef TagString(unsigned Tag)
This provides a very simple, boring adaptor for a begin and end iterator into a range type.
This file contains the declaration of the Comdat class, which represents a single COMDAT in LLVM.
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
constexpr char Attrs[]
Key for Kernel::Metadata::mAttrs.
unsigned ID
LLVM IR allows to use arbitrary numbers as calling convention identifiers.
@ AArch64_VectorCall
Used between AArch64 Advanced SIMD functions.
@ X86_64_SysV
The C convention as specified in the x86-64 supplement to the System V ABI, used on most non-Windows ...
@ RISCV_VectorCall
Calling convention used for RISC-V V-extension.
@ AMDGPU_CS
Used for Mesa/AMDPAL compute shaders.
@ AMDGPU_VS
Used for Mesa vertex shaders, or AMDPAL last shader stage before rasterization (vertex shader if tess...
@ AVR_SIGNAL
Used for AVR signal routines.
@ Swift
Calling convention for Swift.
@ AMDGPU_KERNEL
Used for AMDGPU code object kernels.
@ AArch64_SVE_VectorCall
Used between AArch64 SVE functions.
@ ARM_APCS
ARM Procedure Calling Standard (obsolete, but still used on some targets).
@ CHERIoT_CompartmentCall
Calling convention used for CHERIoT when crossing a protection boundary.
@ CFGuard_Check
Special calling convention on Windows for calling the Control Guard Check ICall funtion.
@ AVR_INTR
Used for AVR interrupt routines.
@ PreserveMost
Used for runtime calls that preserves most registers.
@ AnyReg
OBSOLETED - Used for stack based JavaScript calls.
@ AMDGPU_Gfx
Used for AMD graphics targets.
@ DUMMY_HHVM
Placeholders for HHVM calling conventions (deprecated, removed).
@ AMDGPU_CS_ChainPreserve
Used on AMDGPUs to give the middle-end more control over argument placement.
@ AMDGPU_HS
Used for Mesa/AMDPAL hull shaders (= tessellation control shaders).
@ ARM_AAPCS
ARM Architecture Procedure Calling Standard calling convention (aka EABI).
@ CHERIoT_CompartmentCallee
Calling convention used for the callee of CHERIoT_CompartmentCall.
@ AMDGPU_GS
Used for Mesa/AMDPAL geometry shaders.
@ AArch64_SME_ABI_Support_Routines_PreserveMost_From_X2
Preserve X2-X15, X19-X29, SP, Z0-Z31, P0-P15.
@ CHERIoT_LibraryCall
Calling convention used for CHERIoT for cross-library calls to a stateless compartment.
@ CXX_FAST_TLS
Used for access functions.
@ X86_INTR
x86 hardware interrupt context.
@ AArch64_SME_ABI_Support_Routines_PreserveMost_From_X0
Preserve X0-X13, X19-X29, SP, Z0-Z31, P0-P15.
@ AMDGPU_CS_Chain
Used on AMDGPUs to give the middle-end more control over argument placement.
@ GHC
Used by the Glasgow Haskell Compiler (GHC).
@ AMDGPU_PS
Used for Mesa/AMDPAL pixel shaders.
@ Cold
Attempts to make code in the caller as efficient as possible under the assumption that the call is no...
@ AArch64_SME_ABI_Support_Routines_PreserveMost_From_X1
Preserve X1-X15, X19-X29, SP, Z0-Z31, P0-P15.
@ X86_ThisCall
Similar to X86_StdCall.
@ PTX_Device
Call to a PTX device function.
@ SPIR_KERNEL
Used for SPIR kernel functions.
@ PreserveAll
Used for runtime calls that preserves (almost) all registers.
@ X86_StdCall
stdcall is mostly used by the Win32 API.
@ SPIR_FUNC
Used for SPIR non-kernel device functions.
@ Fast
Attempts to make calls as fast as possible (e.g.
@ MSP430_INTR
Used for MSP430 interrupt routines.
@ X86_VectorCall
MSVC calling convention that passes vectors and vector aggregates in SSE registers.
@ Intel_OCL_BI
Used for Intel OpenCL built-ins.
@ PreserveNone
Used for runtime calls that preserves none general registers.
@ AMDGPU_ES
Used for AMDPAL shader stage before geometry shader if geometry is in use.
@ Tail
Attemps to make calls as fast as possible while guaranteeing that tail call optimization can always b...
@ Win64
The C convention as implemented on Windows/x86-64 and AArch64.
@ PTX_Kernel
Call to a PTX kernel. Passes all arguments in parameter space.
@ SwiftTail
This follows the Swift calling convention in how arguments are passed but guarantees tail calls will ...
@ GRAAL
Used by GraalVM. Two additional registers are reserved.
@ AMDGPU_LS
Used for AMDPAL vertex shader if tessellation is in use.
@ ARM_AAPCS_VFP
Same as ARM_AAPCS, but uses hard floating point ABI.
@ X86_RegCall
Register calling convention used for parameters transfer optimization.
@ M68k_RTD
Used for M68k rtd-based CC (similar to X86's stdcall).
@ C
The default llvm calling convention, compatible with C.
@ X86_FastCall
'fast' analog of X86_StdCall.
@ System
Synchronized with respect to all concurrently executing threads.
@ DW_OP_LLVM_convert
Only used in LLVM metadata.
Context & getContext() const
This is an optimization pass for GlobalISel generic memory operations.
void dump(const SparseBitVector< ElementSize > &LHS, raw_ostream &out)
FunctionAddr VTableAddr Value
bool all_of(R &&range, UnaryPredicate P)
Provide wrappers to std::all_of which take ranges instead of having to pass begin/end explicitly.
Printable print(const GCNRegPressure &RP, const GCNSubtarget *ST=nullptr, unsigned DynamicVGPRBlockSize=0)
InterleavedRange< Range > interleaved(const Range &R, StringRef Separator=", ", StringRef Prefix="", StringRef Suffix="")
Output range R as a sequence of interleaved elements.
const char * getHotnessName(CalleeInfo::HotnessType HT)
decltype(auto) dyn_cast(const From &Val)
dyn_cast<X> - Return the argument parameter cast to the specified type.
auto dyn_cast_if_present(const Y &Val)
dyn_cast_if_present<X> - Functionally identical to dyn_cast, except that a null (or none in the case ...
iterator_range< T > make_range(T x, T y)
Convenience function for iterating over sub-ranges.
LLVM_ABI void printEscapedString(StringRef Name, raw_ostream &Out)
Print each character of the specified string, escaping it if it is not printable or if it is an escap...
const char * toIRString(AtomicOrdering ao)
String used by LLVM IR to represent atomic ordering.
auto dyn_cast_or_null(const Y &Val)
void sort(IteratorTy Start, IteratorTy End)
LLVM_ABI raw_ostream & dbgs()
dbgs() - This returns a reference to a raw_ostream for debugging messages.
char hexdigit(unsigned X, bool LowerCase=false)
hexdigit - Return the hexadecimal character for the given number X (which should be less than 16).
bool isDigit(char C)
Checks if character C is one of the 10 decimal digits.
FunctionAddr VTableAddr Count
bool is_sorted(R &&Range, Compare C)
Wrapper function around std::is_sorted to check if elements in a range R are sorted with respect to a...
class LLVM_GSL_OWNER SmallVector
Forward declaration of SmallVector so that calculateSmallVectorDefaultInlinedElements can reference s...
FormattedNumber format_hex(uint64_t N, unsigned Width, bool Upper=false)
format_hex - Output N as a fixed width hexadecimal.
FormattedNumber format_hex_no_prefix(uint64_t N, unsigned Width, bool Upper=false)
format_hex_no_prefix - Output N as a fixed width hexadecimal.
bool isa(const From &Val)
isa<X> - Return true if the parameter to the template is an instance of one of the template type argu...
constexpr int PoisonMaskElem
AtomicOrdering
Atomic ordering for LLVM's memory model.
@ Ref
The access may reference the value stored in memory.
DWARFExpression::Operation Op
std::string toString(const APInt &I, unsigned Radix, bool Signed, bool formatAsCLiteral=false, bool UpperCase=true, bool InsertSeparators=false)
decltype(auto) cast(const From &Val)
cast<X> - Return the argument parameter cast to the specified type.
auto predecessors(const MachineBasicBlock *BB)
bool pred_empty(const BasicBlock *BB)
std::vector< TypeIdOffsetVtableInfo > TypeIdCompatibleVtableInfo
List of vtable definitions decorated by a particular type identifier, and their corresponding offsets...
@ Default
The result values are uniform if and only if all operands are uniform.
static auto filterDbgVars(iterator_range< simple_ilist< DbgRecord >::iterator > R)
Filter the DbgRecord range to DbgVariableRecord types only and downcast.
LLVM_ABI void printLLVMNameWithoutPrefix(raw_ostream &OS, StringRef Name)
Print out a name of an LLVM value without any prefixes.
static LLVM_ABI const fltSemantics & IEEEsingle() LLVM_READNONE
static constexpr roundingMode rmNearestTiesToEven
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
A single checksum, represented by a Kind and a Value (a string).
T Value
The string value of the checksum.
StringRef getKindAsString() const
std::vector< ConstVCall > TypeCheckedLoadConstVCalls
std::vector< VFuncId > TypeCheckedLoadVCalls
std::vector< ConstVCall > TypeTestAssumeConstVCalls
List of virtual calls made by this function using (respectively) llvm.assume(llvm....
std::vector< GlobalValue::GUID > TypeTests
List of type identifiers used by this function in llvm.type.test intrinsics referenced by something o...
std::vector< VFuncId > TypeTestAssumeVCalls
List of virtual calls made by this function using (respectively) llvm.assume(llvm....
unsigned DSOLocal
Indicates that the linker resolved the symbol to a definition from within the same linkage unit.
unsigned CanAutoHide
In the per-module summary, indicates that the global value is linkonce_odr and global unnamed addr (s...
unsigned ImportType
This field is written by the ThinLTO indexing step to postlink combined summary.
unsigned NotEligibleToImport
Indicate if the global value cannot be imported (e.g.
unsigned Linkage
The linkage type of the associated global value.
unsigned Visibility
Indicates the visibility.
unsigned Live
In per-module summary, indicate that the global value must be considered a live root for index-based ...
StringRef getTagName() const
Return the tag of this operand bundle as a string.
A utility class that uses RAII to save and restore the value of a variable.
std::map< uint64_t, WholeProgramDevirtResolution > WPDRes
Mapping from byte offset to whole-program devirt resolution for that (typeid, byte offset) pair.
Kind
Specifies which kind of type check we should emit for this byte array.
@ Unknown
Unknown (analysis not performed, don't lower)
@ Single
Single element (last example in "Short Inline Bit Vectors")
@ Inline
Inlined bit vector ("Short Inline Bit Vectors")
@ Unsat
Unsatisfiable type (i.e. no global has this type metadata)
@ AllOnes
All-ones bit vector ("Eliminating Bit Vector Checks for All-Ones Bit Vectors")
@ ByteArray
Test a byte array (first example)
unsigned SizeM1BitWidth
Range of size-1 expressed as a bit width.
enum llvm::TypeTestResolution::Kind TheKind
@ UniformRetVal
Uniform return value optimization.
@ VirtualConstProp
Virtual constant propagation.
@ UniqueRetVal
Unique return value optimization.
@ Indir
Just do a regular virtual call.
enum llvm::WholeProgramDevirtResolution::Kind TheKind
std::map< std::vector< uint64_t >, ByArg > ResByArg
Resolutions for calls with all constant integer arguments (excluding the first argument,...
std::string SingleImplName
@ SingleImpl
Single implementation devirtualization.
@ Indir
Just do a regular virtual call.
@ BranchFunnel
When retpoline mitigation is enabled, use a branch funnel that is defined in the merged module.
Function object to check whether the second component of a container supported by std::get (like std:...