31#include "llvm/Config/llvm-config.h"
96 cl::desc(
"Print addresses of instructions when dumping"));
100 cl::desc(
"Pretty print debug locations of instructions when dumping"));
104 cl::desc(
"Pretty print perf data (branch weights, etc) when dumping"));
108 cl::desc(
"Preserve use-list order when writing LLVM assembly."));
112 cl::desc(
"Print address space names"));
131 return VAM->getValue();
144 for (
const Value *
Op :
C->operands())
151 unsigned ID = OM.size() + 1;
158 auto OrderConstantValue = [&OM](
const Value *V) {
163 auto OrderConstantFromMetadata = [&](
Metadata *MD) {
165 OrderConstantValue(VAM->getValue());
167 for (
const auto *VAM : AL->getArgs())
168 OrderConstantValue(VAM->getValue());
173 if (
G.hasInitializer())
189 for (
const Use &U :
F.operands())
195 if (
F.isDeclaration())
208 OrderConstantFromMetadata(DVR.getRawLocation());
209 if (DVR.isDbgAssign())
210 OrderConstantFromMetadata(DVR.getRawAddress());
213 for (
const Value *
Op :
I.operands()) {
226static std::vector<unsigned>
229 using Entry = std::pair<const Use *, unsigned>;
233 if (OM.lookup(U.getUser()))
234 List.
push_back(std::make_pair(&U, List.size()));
245 ID = OM.lookup(BA->getBasicBlock());
246 llvm::sort(List, [&](
const Entry &L,
const Entry &R) {
247 const Use *LU = L.first;
248 const Use *RU = R.first;
252 auto LID = OM.lookup(LU->getUser());
253 auto RID = OM.lookup(RU->getUser());
273 return LU->getOperandNo() < RU->getOperandNo();
274 return LU->getOperandNo() > RU->getOperandNo();
282 std::vector<unsigned> Shuffle(List.size());
283 for (
size_t I = 0,
E = List.size();
I !=
E; ++
I)
284 Shuffle[
I] = List[
I].second;
291 for (
const auto &Pair : OM) {
292 const Value *V = Pair.first;
293 if (V->use_empty() || std::next(V->use_begin()) == V->use_end())
296 std::vector<unsigned> Shuffle =
303 F =
I->getFunction();
308 ULOM[
F][V] = std::move(Shuffle);
315 return MA->getParent() ? MA->getParent()->getParent() :
nullptr;
318 return BB->getParent() ? BB->getParent()->getParent() :
nullptr;
321 const Function *M =
I->getParent() ?
I->getParent()->getParent() :
nullptr;
322 return M ? M->getParent() :
nullptr;
326 return GV->getParent();
351 default: Out <<
"cc" << cc;
break;
374 Out <<
"aarch64_sve_vector_pcs";
377 Out <<
"aarch64_sme_preservemost_from_x0";
380 Out <<
"aarch64_sme_preservemost_from_x1";
383 Out <<
"aarch64_sme_preservemost_from_x2";
411 Out <<
"amdgpu_cs_chain";
414 Out <<
"amdgpu_cs_chain_preserve";
419 Out <<
"amdgpu_gfx_whole_wave";
423 Out <<
"riscv_vector_cc";
425#define CC_VLS_CASE(ABI_VLEN) \
426 case CallingConv::RISCV_VLSCall_##ABI_VLEN: \
427 Out << "riscv_vls_cc(" #ABI_VLEN ")"; \
443 Out <<
"cheriot_compartmentcallcc";
446 Out <<
"cheriot_compartmentcalleecc";
449 Out <<
"cheriot_librarycallcc";
463 assert(!Name.empty() &&
"Cannot get empty name!");
466 bool NeedsQuotes = isdigit(
static_cast<unsigned char>(Name[0]));
468 for (
unsigned char C : Name) {
473 if (!isalnum(
C) &&
C !=
'-' &&
C !=
'.' &&
C !=
'_') {
527 Out << Mask.size() <<
" x i32> ";
529 Out <<
"zeroinitializer";
535 for (
int Elt : Mask) {
550 TypePrinting(
const Module *M =
nullptr)
551 : M(M), TypesIncorporated(M == nullptr) {}
553 TypePrinting(
const TypePrinting &) =
delete;
554 TypePrinting &operator=(
const TypePrinting &) =
delete;
557 TypeFinder &getNamedTypes();
560 std::vector<StructType *> &getNumberedTypes();
566 void printStructBody(StructType *Ty, raw_ostream &OS);
569 void incorporateTypes();
573 bool TypesIncorporated;
575 TypeFinder NamedTypes;
578 DenseMap<StructType *, unsigned> Type2Number;
580 std::vector<StructType *> NumberedTypes;
590std::vector<StructType *> &TypePrinting::getNumberedTypes() {
596 if (NumberedTypes.size() == Type2Number.size())
597 return NumberedTypes;
599 NumberedTypes.resize(Type2Number.size());
600 for (
const auto &
P : Type2Number) {
601 assert(
P.second < NumberedTypes.size() &&
"Didn't get a dense numbering?");
602 assert(!NumberedTypes[
P.second] &&
"Didn't get a unique numbering?");
603 NumberedTypes[
P.second] =
P.first;
605 return NumberedTypes;
608bool TypePrinting::empty() {
610 return NamedTypes.
empty() && Type2Number.empty();
613void TypePrinting::incorporateTypes() {
614 if (TypesIncorporated)
617 NamedTypes.
run(*M,
false);
618 TypesIncorporated =
true;
622 unsigned NextNumber = 0;
624 std::vector<StructType *>::iterator NextToUse = NamedTypes.
begin();
625 for (StructType *STy : NamedTypes) {
627 if (STy->isLiteral())
630 if (STy->getName().empty())
631 Type2Number[STy] = NextNumber++;
636 NamedTypes.erase(NextToUse, NamedTypes.end());
641 bool ForcePrint =
false) {
642 if (AS == 0 && !ForcePrint)
644 OS << Prefix <<
"addrspace(";
648 OS <<
"\"" << ASName <<
"\"";
656void TypePrinting::print(
Type *Ty, raw_ostream &OS) {
658 case Type::VoidTyID: OS <<
"void";
return;
659 case Type::HalfTyID: OS <<
"half";
return;
660 case Type::BFloatTyID: OS <<
"bfloat";
return;
661 case Type::FloatTyID: OS <<
"float";
return;
662 case Type::DoubleTyID: OS <<
"double";
return;
663 case Type::X86_FP80TyID: OS <<
"x86_fp80";
return;
664 case Type::FP128TyID: OS <<
"fp128";
return;
665 case Type::PPC_FP128TyID: OS <<
"ppc_fp128";
return;
666 case Type::LabelTyID: OS <<
"label";
return;
667 case Type::MetadataTyID:
670 case Type::X86_AMXTyID: OS <<
"x86_amx";
return;
671 case Type::TokenTyID: OS <<
"token";
return;
675 case Type::IntegerTyID:
676 OS << 'i' << cast<IntegerType>(Ty)->getBitWidth();
679 case Type::FunctionTyID: {
681 print(FTy->getReturnType(), OS);
684 for (
Type *Ty : FTy->params()) {
693 case Type::StructTyID: {
697 return printStructBody(STy, OS);
703 const auto I = Type2Number.find(STy);
704 if (
I != Type2Number.end())
705 OS <<
'%' <<
I->second;
707 OS <<
"%\"type " << STy <<
'\"';
710 case Type::PointerTyID: {
716 case Type::ArrayTyID: {
718 OS <<
'[' << ATy->getNumElements() <<
" x ";
719 print(ATy->getElementType(), OS);
723 case Type::FixedVectorTyID:
724 case Type::ScalableVectorTyID: {
726 ElementCount
EC = PTy->getElementCount();
730 OS <<
EC.getKnownMinValue() <<
" x ";
731 print(PTy->getElementType(), OS);
735 case Type::TypedPointerTyID: {
741 case Type::TargetExtTyID:
748 Inner->print(OS,
false,
true);
751 OS <<
", " << IntParam;
758void TypePrinting::printStructBody(StructType *STy, raw_ostream &OS) {
800 const Function* TheFunction =
nullptr;
801 bool FunctionProcessed =
false;
802 bool ShouldInitializeAllMetadata;
807 ProcessFunctionHookFn;
822 unsigned mdnNext = 0;
830 unsigned ModulePathNext = 0;
834 unsigned GUIDNext = 0;
838 unsigned TypeIdNext = 0;
843 unsigned TypeIdCompatibleVtableNext = 0;
852 bool ShouldInitializeAllMetadata =
false);
860 bool ShouldInitializeAllMetadata =
false);
877 void createMetadataSlot(
const MDNode *
N)
override;
881 int getLocalSlot(
const Value *V);
883 int getMetadataSlot(
const MDNode *
N)
override;
888 int getTypeIdCompatibleVtableSlot(
StringRef Id);
894 FunctionProcessed =
false;
902 void purgeFunction();
909 unsigned mdn_size()
const {
return mdnMap.size(); }
917 unsigned as_size()
const {
return asMap.size(); }
933 void CreateMetadataSlot(
const MDNode *
N);
936 void CreateFunctionSlot(
const Value *V);
941 inline void CreateModulePathSlot(
StringRef Path);
944 void CreateTypeIdCompatibleVtableSlot(
StringRef Id);
948 void processModule();
956 void processGlobalObjectMetadata(
const GlobalObject &GO);
959 void processFunctionMetadata(
const Function &
F);
965 void processDbgRecordMetadata(
const DbgRecord &DVR);
970 : M(M), F(F), Machine(&Machine) {}
973 bool ShouldInitializeAllMetadata)
974 : ShouldCreateStorage(M),
975 ShouldInitializeAllMetadata(ShouldInitializeAllMetadata), M(M) {}
980 if (!ShouldCreateStorage)
983 ShouldCreateStorage =
false;
985 std::make_unique<SlotTracker>(M, ShouldInitializeAllMetadata);
986 Machine = MachineStorage.get();
987 if (ProcessModuleHookFn)
988 Machine->setProcessHook(ProcessModuleHookFn);
989 if (ProcessFunctionHookFn)
990 Machine->setProcessHook(ProcessFunctionHookFn);
1003 Machine->purgeFunction();
1004 Machine->incorporateFunction(&F);
1009 assert(F &&
"No function incorporated");
1010 return Machine->getLocalSlot(V);
1016 ProcessModuleHookFn = std::move(Fn);
1022 ProcessFunctionHookFn = std::move(Fn);
1052#define ST_DEBUG(X) dbgs() << X
1060 : TheModule(M), ShouldInitializeAllMetadata(ShouldInitializeAllMetadata) {}
1065 : TheModule(
F ?
F->
getParent() : nullptr), TheFunction(
F),
1066 ShouldInitializeAllMetadata(ShouldInitializeAllMetadata) {}
1069 : TheModule(nullptr), ShouldInitializeAllMetadata(
false), TheIndex(Index) {}
1074 TheModule =
nullptr;
1077 if (TheFunction && !FunctionProcessed)
1084 int NumSlots = processIndex();
1091void SlotTracker::processModule() {
1092 ST_DEBUG(
"begin processModule!\n");
1097 CreateModuleSlot(&Var);
1098 processGlobalObjectMetadata(Var);
1099 auto Attrs = Var.getAttributes();
1100 if (Attrs.hasAttributes())
1101 CreateAttributeSetSlot(Attrs);
1106 CreateModuleSlot(&
A);
1109 for (
const GlobalIFunc &
I : TheModule->ifuncs()) {
1111 CreateModuleSlot(&
I);
1112 processGlobalObjectMetadata(
I);
1116 for (
const NamedMDNode &NMD : TheModule->named_metadata()) {
1117 for (
const MDNode *
N : NMD.operands())
1118 CreateMetadataSlot(
N);
1121 for (
const Function &
F : *TheModule) {
1124 CreateModuleSlot(&
F);
1126 if (ShouldInitializeAllMetadata)
1127 processFunctionMetadata(
F);
1131 AttributeSet FnAttrs =
F.getAttributes().getFnAttrs();
1133 CreateAttributeSetSlot(FnAttrs);
1136 if (ProcessModuleHookFn)
1137 ProcessModuleHookFn(
this, TheModule, ShouldInitializeAllMetadata);
1143void SlotTracker::processFunction() {
1144 ST_DEBUG(
"begin processFunction!\n");
1148 if (!ShouldInitializeAllMetadata)
1149 processFunctionMetadata(*TheFunction);
1153 AE = TheFunction->arg_end(); AI != AE; ++AI)
1155 CreateFunctionSlot(&*AI);
1157 ST_DEBUG(
"Inserting Instructions:\n");
1160 for (
auto &BB : *TheFunction) {
1162 CreateFunctionSlot(&BB);
1164 for (
auto &
I : BB) {
1165 if (!
I.getType()->isVoidTy() && !
I.hasName())
1166 CreateFunctionSlot(&
I);
1173 if (
Attrs.hasAttributes())
1174 CreateAttributeSetSlot(Attrs);
1179 if (ProcessFunctionHookFn)
1180 ProcessFunctionHookFn(
this, TheFunction, ShouldInitializeAllMetadata);
1182 FunctionProcessed =
true;
1184 ST_DEBUG(
"end processFunction!\n");
1188int SlotTracker::processIndex() {
1195 std::vector<StringRef> ModulePaths;
1196 for (
auto &[ModPath,
_] : TheIndex->modulePaths())
1197 ModulePaths.push_back(ModPath);
1199 for (
auto &ModPath : ModulePaths)
1200 CreateModulePathSlot(ModPath);
1203 GUIDNext = ModulePathNext;
1205 for (
auto &GlobalList : *TheIndex)
1206 CreateGUIDSlot(GlobalList.first);
1209 TypeIdCompatibleVtableNext = GUIDNext;
1210 for (
auto &TId : TheIndex->typeIdCompatibleVtableMap())
1211 CreateTypeIdCompatibleVtableSlot(TId.first);
1214 TypeIdNext = TypeIdCompatibleVtableNext;
1215 for (
const auto &TID : TheIndex->typeIds())
1216 CreateTypeIdSlot(TID.second.first);
1222void SlotTracker::processGlobalObjectMetadata(
const GlobalObject &GO) {
1225 for (
auto &MD : MDs)
1226 CreateMetadataSlot(MD.second);
1229void SlotTracker::processFunctionMetadata(
const Function &
F) {
1230 processGlobalObjectMetadata(
F);
1231 for (
auto &BB :
F) {
1232 for (
auto &
I : BB) {
1233 for (
const DbgRecord &DR :
I.getDbgRecordRange())
1234 processDbgRecordMetadata(DR);
1235 processInstructionMetadata(
I);
1240void SlotTracker::processDbgRecordMetadata(
const DbgRecord &DR) {
1251 CreateMetadataSlot(
Empty);
1252 if (DVR->getRawVariable())
1253 CreateMetadataSlot(DVR->getRawVariable());
1254 if (DVR->isDbgAssign()) {
1255 if (
auto *AssignID = DVR->getRawAssignID())
1258 CreateMetadataSlot(
Empty);
1261 CreateMetadataSlot(DLR->getRawLabel());
1269void SlotTracker::processInstructionMetadata(
const Instruction &
I) {
1272 if (Function *
F = CI->getCalledFunction())
1273 if (
F->isIntrinsic())
1274 for (
auto &
Op :
I.operands())
1277 CreateMetadataSlot(
N);
1281 I.getAllMetadata(MDs);
1282 for (
auto &MD : MDs)
1283 CreateMetadataSlot(MD.second);
1290 ST_DEBUG(
"begin purgeFunction!\n");
1292 TheFunction =
nullptr;
1293 FunctionProcessed =
false;
1304 return MI == mMap.end() ? -1 : (int)
MI->second;
1310 ProcessModuleHookFn = std::move(Fn);
1316 ProcessFunctionHookFn = std::move(Fn);
1329 return MI == mdnMap.end() ? -1 : (int)
MI->second;
1340 return FI == fMap.end() ? -1 : (int)FI->second;
1349 return AI == asMap.end() ? -1 : (int)AI->second;
1357 auto I = ModulePathMap.find(Path);
1358 return I == ModulePathMap.end() ? -1 : (int)
I->second;
1367 return I == GUIDMap.end() ? -1 : (int)
I->second;
1375 auto I = TypeIdMap.find(Id);
1376 return I == TypeIdMap.end() ? -1 : (int)
I->second;
1384 auto I = TypeIdCompatibleVtableMap.find(Id);
1385 return I == TypeIdCompatibleVtableMap.end() ? -1 : (int)
I->second;
1389void SlotTracker::CreateModuleSlot(
const GlobalValue *V) {
1390 assert(V &&
"Can't insert a null Value into SlotTracker!");
1391 assert(!V->getType()->isVoidTy() &&
"Doesn't need a slot!");
1392 assert(!V->hasName() &&
"Doesn't need a slot!");
1394 unsigned DestSlot = mNext++;
1397 ST_DEBUG(
" Inserting value [" << V->getType() <<
"] = " << V <<
" slot=" <<
1407void SlotTracker::CreateFunctionSlot(
const Value *V) {
1408 assert(!V->getType()->isVoidTy() && !V->hasName() &&
"Doesn't need a slot!");
1410 unsigned DestSlot = fNext++;
1414 ST_DEBUG(
" Inserting value [" << V->getType() <<
"] = " << V <<
" slot=" <<
1415 DestSlot <<
" [o]\n");
1419void SlotTracker::CreateMetadataSlot(
const MDNode *
N) {
1420 assert(
N &&
"Can't insert a null Value into SlotTracker!");
1426 unsigned DestSlot = mdnNext;
1427 if (!mdnMap.insert(std::make_pair(
N, DestSlot)).second)
1432 for (
unsigned i = 0, e =
N->getNumOperands(); i != e; ++i)
1434 CreateMetadataSlot(
Op);
1437void SlotTracker::CreateAttributeSetSlot(
AttributeSet AS) {
1440 if (asMap.try_emplace(AS, asNext).second)
1445void SlotTracker::CreateModulePathSlot(
StringRef Path) {
1446 ModulePathMap[
Path] = ModulePathNext++;
1451 GUIDMap[
GUID] = GUIDNext++;
1455void SlotTracker::CreateTypeIdSlot(
StringRef Id) {
1456 TypeIdMap[
Id] = TypeIdNext++;
1460void SlotTracker::CreateTypeIdCompatibleVtableSlot(
StringRef Id) {
1461 TypeIdCompatibleVtableMap[
Id] = TypeIdCompatibleVtableNext++;
1466struct AsmWriterContext {
1467 TypePrinting *TypePrinter =
nullptr;
1468 SlotTracker *
Machine =
nullptr;
1471 AsmWriterContext(TypePrinting *TP, SlotTracker *ST,
const Module *M =
nullptr)
1474 static AsmWriterContext &getEmpty() {
1475 static AsmWriterContext EmptyCtx(
nullptr,
nullptr);
1481 virtual void onWriteMetadataAsOperand(
const Metadata *) {}
1483 virtual ~AsmWriterContext() =
default;
1492 AsmWriterContext &WriterCtx,
1493 bool PrintType =
false);
1496 AsmWriterContext &WriterCtx,
1497 bool FromValue =
false);
1501 Out << FPO->getFastMathFlags();
1504 if (OBO->hasNoUnsignedWrap())
1506 if (OBO->hasNoSignedWrap())
1512 if (PDI->isDisjoint())
1515 if (
GEP->isInBounds())
1517 else if (
GEP->hasNoUnsignedSignedWrap())
1519 if (
GEP->hasNoUnsignedWrap())
1522 Out <<
" inrange(" <<
InRange->getLower() <<
", " <<
InRange->getUpper()
1526 if (NNI->hasNonNeg())
1529 if (TI->hasNoUnsignedWrap())
1531 if (TI->hasNoSignedWrap())
1534 if (ICmp->hasSameSign())
1550 bool isNaN = APF.
isNaN();
1552 if (!isInf && !isNaN) {
1561 ((StrVal[0] ==
'-' || StrVal[0] ==
'+') &&
isDigit(StrVal[1]))) &&
1562 "[-+]?[0-9] regex does not match!");
1574 static_assert(
sizeof(double) ==
sizeof(
uint64_t),
1575 "assuming that double is 64 bits!");
1633 AsmWriterContext &WriterCtx) {
1635 Type *Ty = CI->getType();
1637 if (Ty->isVectorTy()) {
1639 WriterCtx.TypePrinter->print(Ty->getScalarType(), Out);
1643 if (Ty->getScalarType()->isIntegerTy(1))
1644 Out << (CI->getZExtValue() ?
"true" :
"false");
1646 Out << CI->getValue();
1648 if (Ty->isVectorTy())
1655 Type *Ty = CB->getType();
1657 if (Ty->isVectorTy()) {
1659 WriterCtx.TypePrinter->print(Ty->getScalarType(), Out);
1663 Out << CB->getValue();
1665 if (Ty->isVectorTy())
1672 Type *Ty = CFP->getType();
1674 if (Ty->isVectorTy()) {
1676 WriterCtx.TypePrinter->print(Ty->getScalarType(), Out);
1682 if (Ty->isVectorTy())
1689 Out <<
"zeroinitializer";
1694 Out <<
"blockaddress(";
1703 Out <<
"dso_local_equivalent ";
1718 unsigned NumOpsToWrite = 2;
1719 if (!CPA->getOperand(2)->isNullValue())
1721 if (!CPA->getOperand(3)->isNullValue())
1723 if (!CPA->getOperand(4)->isNullValue())
1727 for (
unsigned i = 0, e = NumOpsToWrite; i != e; ++i) {
1739 for (
const Value *
Op : CA->operands()) {
1750 if (CA->isString()) {
1759 for (
uint64_t i = 0, e = CA->getNumElements(); i != e; ++i) {
1769 if (CS->getType()->isPacked())
1772 if (CS->getNumOperands() != 0) {
1775 for (
const Value *
Op : CS->operands()) {
1782 if (CS->getType()->isPacked())
1807 for (
unsigned i = 0, e = CVVTy->getNumElements(); i != e; ++i) {
1842 if (CE->getOpcode() == Instruction::ShuffleVector) {
1843 if (
auto *SplatVal = CE->getSplatValue()) {
1854 Out << CE->getOpcodeName();
1859 WriterCtx.TypePrinter->print(
GEP->getSourceElementType(), Out);
1864 for (
const Value *
Op : CE->operands()) {
1871 WriterCtx.TypePrinter->print(CE->getType(), Out);
1874 if (CE->getOpcode() == Instruction::ShuffleVector)
1881 Out <<
"<placeholder or erroneous Constant>";
1885 AsmWriterContext &WriterCtx) {
1893 Value *V = MDV->getValue();
1897 WriterCtx.onWriteMetadataAsOperand(MD);
1906struct MDFieldPrinter {
1909 AsmWriterContext &WriterCtx;
1911 explicit MDFieldPrinter(raw_ostream &Out)
1912 : Out(Out), WriterCtx(AsmWriterContext::getEmpty()) {}
1913 MDFieldPrinter(raw_ostream &Out, AsmWriterContext &Ctx)
1914 : Out(Out), WriterCtx(Ctx) {}
1916 void printTag(
const DINode *
N);
1917 void printMacinfoType(
const DIMacroNode *
N);
1918 void printChecksum(
const DIFile::ChecksumInfo<StringRef> &
N);
1919 void printString(StringRef Name, StringRef
Value,
1920 bool ShouldSkipEmpty =
true);
1921 void printMetadata(StringRef Name,
const Metadata *MD,
1922 bool ShouldSkipNull =
true);
1923 void printMetadataOrInt(StringRef Name,
const Metadata *MD,
bool IsUnsigned,
1924 bool ShouldSkipZero =
true);
1925 template <
class IntTy>
1926 void printInt(StringRef Name, IntTy
Int,
bool ShouldSkipZero =
true);
1927 void printAPInt(StringRef Name,
const APInt &
Int,
bool IsUnsigned,
1928 bool ShouldSkipZero);
1929 void printBool(StringRef Name,
bool Value,
1930 std::optional<bool>
Default = std::nullopt);
1933 template <
class IntTy,
class Stringifier>
1934 void printDwarfEnum(StringRef Name, IntTy
Value, Stringifier
toString,
1935 bool ShouldSkipZero =
true);
1937 void printNameTableKind(StringRef Name,
1944void MDFieldPrinter::printTag(
const DINode *
N) {
1945 Out <<
FS <<
"tag: ";
1953void MDFieldPrinter::printMacinfoType(
const DIMacroNode *
N) {
1954 Out <<
FS <<
"type: ";
1959 Out <<
N->getMacinfoType();
1962void MDFieldPrinter::printChecksum(
1965 printString(
"checksum", Checksum.
Value,
false);
1969 bool ShouldSkipEmpty) {
1970 if (ShouldSkipEmpty &&
Value.empty())
1973 Out <<
FS <<
Name <<
": \"";
1979 AsmWriterContext &WriterCtx) {
1985 WriterCtx.onWriteMetadataAsOperand(MD);
1989 bool ShouldSkipNull) {
1990 if (ShouldSkipNull && !MD)
1993 Out <<
FS <<
Name <<
": ";
1998 bool IsUnsigned,
bool ShouldSkipZero) {
2005 printInt(Name, CV->getZExtValue(), ShouldSkipZero);
2007 printInt(Name, CV->getSExtValue(), ShouldSkipZero);
2009 printMetadata(Name, MD);
2012template <
class IntTy>
2013void MDFieldPrinter::printInt(
StringRef Name, IntTy
Int,
bool ShouldSkipZero) {
2014 if (ShouldSkipZero && !
Int)
2021 bool IsUnsigned,
bool ShouldSkipZero) {
2022 if (ShouldSkipZero &&
Int.isZero())
2025 Out <<
FS <<
Name <<
": ";
2026 Int.print(Out, !IsUnsigned);
2030 std::optional<bool>
Default) {
2033 Out <<
FS <<
Name <<
": " << (
Value ?
"true" :
"false");
2040 Out <<
FS <<
Name <<
": ";
2046 for (
auto F : SplitFlags) {
2048 assert(!StringF.empty() &&
"Expected valid flag");
2049 Out << FlagsFS << StringF;
2051 if (Extra || SplitFlags.empty())
2052 Out << FlagsFS << Extra;
2055void MDFieldPrinter::printDISPFlags(
StringRef Name,
2059 Out <<
FS <<
Name <<
": ";
2070 for (
auto F : SplitFlags) {
2072 assert(!StringF.empty() &&
"Expected valid flag");
2073 Out << FlagsFS << StringF;
2075 if (Extra || SplitFlags.empty())
2076 Out << FlagsFS << Extra;
2079void MDFieldPrinter::printEmissionKind(
StringRef Name,
2084void MDFieldPrinter::printNameTableKind(
StringRef Name,
2091void MDFieldPrinter::printFixedPointKind(
StringRef Name,
2096template <
class IntTy,
class Stringifier>
2098 Stringifier
toString,
bool ShouldSkipZero) {
2099 if (ShouldSkipZero && !
Value)
2102 Out <<
FS <<
Name <<
": ";
2111 AsmWriterContext &WriterCtx) {
2112 Out <<
"!GenericDINode(";
2113 MDFieldPrinter
Printer(Out, WriterCtx);
2115 Printer.printString(
"header",
N->getHeader());
2116 if (
N->getNumDwarfOperands()) {
2117 Out <<
Printer.FS <<
"operands: {";
2119 for (
auto &
I :
N->dwarf_operands()) {
2129 AsmWriterContext &WriterCtx) {
2130 Out <<
"!DILocation(";
2131 MDFieldPrinter
Printer(Out, WriterCtx);
2133 Printer.printInt(
"line",
DL->getLine(),
false);
2134 Printer.printInt(
"column",
DL->getColumn());
2135 Printer.printMetadata(
"scope",
DL->getRawScope(),
false);
2136 Printer.printMetadata(
"inlinedAt",
DL->getRawInlinedAt());
2137 Printer.printBool(
"isImplicitCode",
DL->isImplicitCode(),
2139 Printer.printInt(
"atomGroup",
DL->getAtomGroup());
2140 Printer.printInt<
unsigned>(
"atomRank",
DL->getAtomRank());
2145 AsmWriterContext &WriterCtx) {
2146 Out <<
"!DIAssignID()";
2147 MDFieldPrinter
Printer(Out, WriterCtx);
2151 AsmWriterContext &WriterCtx) {
2152 Out <<
"!DISubrange(";
2153 MDFieldPrinter
Printer(Out, WriterCtx);
2155 Printer.printMetadataOrInt(
"count",
N->getRawCountNode(),
2161 Printer.printMetadataOrInt(
"lowerBound",
N->getRawLowerBound(),
2164 Printer.printMetadataOrInt(
"upperBound",
N->getRawUpperBound(),
2167 Printer.printMetadataOrInt(
"stride",
N->getRawStride(),
2175 AsmWriterContext &WriterCtx) {
2176 Out <<
"!DIGenericSubrange(";
2177 MDFieldPrinter
Printer(Out, WriterCtx);
2179 auto GetConstant = [&](
Metadata *Bound) -> std::optional<int64_t> {
2182 return std::nullopt;
2183 if (BE->isConstant() &&
2185 *BE->isConstant()) {
2186 return static_cast<int64_t
>(BE->getElement(1));
2188 return std::nullopt;
2191 auto *
Count =
N->getRawCountNode();
2192 if (
auto ConstantCount = GetConstant(
Count))
2193 Printer.printInt(
"count", *ConstantCount,
2198 auto *LBound =
N->getRawLowerBound();
2199 if (
auto ConstantLBound = GetConstant(LBound))
2200 Printer.printInt(
"lowerBound", *ConstantLBound,
2203 Printer.printMetadata(
"lowerBound", LBound,
true);
2205 auto *UBound =
N->getRawUpperBound();
2206 if (
auto ConstantUBound = GetConstant(UBound))
2207 Printer.printInt(
"upperBound", *ConstantUBound,
2210 Printer.printMetadata(
"upperBound", UBound,
true);
2212 auto *Stride =
N->getRawStride();
2213 if (
auto ConstantStride = GetConstant(Stride))
2214 Printer.printInt(
"stride", *ConstantStride,
2217 Printer.printMetadata(
"stride", Stride,
true);
2223 AsmWriterContext &) {
2224 Out <<
"!DIEnumerator(";
2226 Printer.printString(
"name",
N->getName(),
false);
2227 Printer.printAPInt(
"value",
N->getValue(),
N->isUnsigned(),
2229 if (
N->isUnsigned())
2230 Printer.printBool(
"isUnsigned",
true);
2235 AsmWriterContext &WriterCtx) {
2236 Out <<
"!DIBasicType(";
2237 MDFieldPrinter
Printer(Out, WriterCtx);
2238 if (
N->getTag() != dwarf::DW_TAG_base_type)
2240 Printer.printString(
"name",
N->getName());
2241 Printer.printMetadata(
"scope",
N->getRawScope());
2242 Printer.printMetadata(
"file",
N->getRawFile());
2243 Printer.printInt(
"line",
N->getLine());
2244 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2245 Printer.printInt(
"align",
N->getAlignInBits());
2246 Printer.printInt(
"dataSize",
N->getDataSizeInBits());
2247 Printer.printDwarfEnum(
"encoding",
N->getEncoding(),
2249 Printer.printInt(
"num_extra_inhabitants",
N->getNumExtraInhabitants());
2250 Printer.printDIFlags(
"flags",
N->getFlags());
2255 AsmWriterContext &WriterCtx) {
2256 Out <<
"!DIFixedPointType(";
2257 MDFieldPrinter
Printer(Out, WriterCtx);
2258 if (
N->getTag() != dwarf::DW_TAG_base_type)
2260 Printer.printString(
"name",
N->getName());
2261 Printer.printMetadata(
"scope",
N->getRawScope());
2262 Printer.printMetadata(
"file",
N->getRawFile());
2263 Printer.printInt(
"line",
N->getLine());
2264 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2265 Printer.printInt(
"align",
N->getAlignInBits());
2266 Printer.printDwarfEnum(
"encoding",
N->getEncoding(),
2268 Printer.printDIFlags(
"flags",
N->getFlags());
2269 Printer.printFixedPointKind(
"kind",
N->getKind());
2270 if (
N->isRational()) {
2271 bool IsUnsigned = !
N->isSigned();
2272 Printer.printAPInt(
"numerator",
N->getNumerator(), IsUnsigned,
false);
2273 Printer.printAPInt(
"denominator",
N->getDenominator(), IsUnsigned,
false);
2275 Printer.printInt(
"factor",
N->getFactor());
2281 AsmWriterContext &WriterCtx) {
2282 Out <<
"!DIStringType(";
2283 MDFieldPrinter
Printer(Out, WriterCtx);
2284 if (
N->getTag() != dwarf::DW_TAG_string_type)
2286 Printer.printString(
"name",
N->getName());
2287 Printer.printMetadata(
"stringLength",
N->getRawStringLength());
2288 Printer.printMetadata(
"stringLengthExpression",
N->getRawStringLengthExp());
2289 Printer.printMetadata(
"stringLocationExpression",
2290 N->getRawStringLocationExp());
2291 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2292 Printer.printInt(
"align",
N->getAlignInBits());
2293 Printer.printDwarfEnum(
"encoding",
N->getEncoding(),
2299 AsmWriterContext &WriterCtx) {
2300 Out <<
"!DIDerivedType(";
2301 MDFieldPrinter
Printer(Out, WriterCtx);
2303 Printer.printString(
"name",
N->getName());
2304 Printer.printMetadata(
"scope",
N->getRawScope());
2305 Printer.printMetadata(
"file",
N->getRawFile());
2306 Printer.printInt(
"line",
N->getLine());
2307 Printer.printMetadata(
"baseType",
N->getRawBaseType(),
2309 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2310 Printer.printInt(
"align",
N->getAlignInBits());
2311 Printer.printMetadataOrInt(
"offset",
N->getRawOffsetInBits(),
true);
2312 Printer.printDIFlags(
"flags",
N->getFlags());
2313 Printer.printMetadata(
"extraData",
N->getRawExtraData());
2314 if (
const auto &DWARFAddressSpace =
N->getDWARFAddressSpace())
2315 Printer.printInt(
"dwarfAddressSpace", *DWARFAddressSpace,
2317 Printer.printMetadata(
"annotations",
N->getRawAnnotations());
2318 if (
auto PtrAuthData =
N->getPtrAuthData()) {
2319 Printer.printInt(
"ptrAuthKey", PtrAuthData->key());
2320 Printer.printBool(
"ptrAuthIsAddressDiscriminated",
2321 PtrAuthData->isAddressDiscriminated());
2322 Printer.printInt(
"ptrAuthExtraDiscriminator",
2323 PtrAuthData->extraDiscriminator());
2324 Printer.printBool(
"ptrAuthIsaPointer", PtrAuthData->isaPointer());
2325 Printer.printBool(
"ptrAuthAuthenticatesNullValues",
2326 PtrAuthData->authenticatesNullValues());
2332 AsmWriterContext &WriterCtx) {
2333 Out <<
"!DISubrangeType(";
2334 MDFieldPrinter
Printer(Out, WriterCtx);
2335 Printer.printString(
"name",
N->getName());
2336 Printer.printMetadata(
"scope",
N->getRawScope());
2337 Printer.printMetadata(
"file",
N->getRawFile());
2338 Printer.printInt(
"line",
N->getLine());
2339 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2340 Printer.printInt(
"align",
N->getAlignInBits());
2341 Printer.printDIFlags(
"flags",
N->getFlags());
2342 Printer.printMetadata(
"baseType",
N->getRawBaseType(),
2344 Printer.printMetadata(
"lowerBound",
N->getRawLowerBound());
2345 Printer.printMetadata(
"upperBound",
N->getRawUpperBound());
2346 Printer.printMetadata(
"stride",
N->getRawStride());
2347 Printer.printMetadata(
"bias",
N->getRawBias());
2352 AsmWriterContext &WriterCtx) {
2353 Out <<
"!DICompositeType(";
2354 MDFieldPrinter
Printer(Out, WriterCtx);
2356 Printer.printString(
"name",
N->getName());
2357 Printer.printMetadata(
"scope",
N->getRawScope());
2358 Printer.printMetadata(
"file",
N->getRawFile());
2359 Printer.printInt(
"line",
N->getLine());
2360 Printer.printMetadata(
"baseType",
N->getRawBaseType());
2361 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2362 Printer.printInt(
"align",
N->getAlignInBits());
2363 Printer.printMetadataOrInt(
"offset",
N->getRawOffsetInBits(),
true);
2364 Printer.printInt(
"num_extra_inhabitants",
N->getNumExtraInhabitants());
2365 Printer.printDIFlags(
"flags",
N->getFlags());
2366 Printer.printMetadata(
"elements",
N->getRawElements());
2367 Printer.printDwarfEnum(
"runtimeLang",
N->getRuntimeLang(),
2369 Printer.printMetadata(
"vtableHolder",
N->getRawVTableHolder());
2370 Printer.printMetadata(
"templateParams",
N->getRawTemplateParams());
2371 Printer.printString(
"identifier",
N->getIdentifier());
2372 Printer.printMetadata(
"discriminator",
N->getRawDiscriminator());
2373 Printer.printMetadata(
"dataLocation",
N->getRawDataLocation());
2374 Printer.printMetadata(
"associated",
N->getRawAssociated());
2375 Printer.printMetadata(
"allocated",
N->getRawAllocated());
2376 if (
auto *RankConst =
N->getRankConst())
2377 Printer.printInt(
"rank", RankConst->getSExtValue(),
2380 Printer.printMetadata(
"rank",
N->getRawRank(),
true);
2381 Printer.printMetadata(
"annotations",
N->getRawAnnotations());
2382 if (
auto *Specification =
N->getRawSpecification())
2383 Printer.printMetadata(
"specification", Specification);
2385 if (
auto EnumKind =
N->getEnumKind())
2389 Printer.printMetadata(
"bitStride",
N->getRawBitStride());
2394 AsmWriterContext &WriterCtx) {
2395 Out <<
"!DISubroutineType(";
2396 MDFieldPrinter
Printer(Out, WriterCtx);
2397 Printer.printDIFlags(
"flags",
N->getFlags());
2399 Printer.printMetadata(
"types",
N->getRawTypeArray(),
2407 Printer.printString(
"filename",
N->getFilename(),
2409 Printer.printString(
"directory",
N->getDirectory(),
2412 if (
N->getChecksum())
2413 Printer.printChecksum(*
N->getChecksum());
2415 Printer.printString(
"source", *
N->getSource(),
2421 AsmWriterContext &WriterCtx) {
2422 Out <<
"!DICompileUnit(";
2423 MDFieldPrinter
Printer(Out, WriterCtx);
2429 "sourceLanguageName",
2441 Printer.printMetadata(
"file",
N->getRawFile(),
false);
2442 Printer.printString(
"producer",
N->getProducer());
2443 Printer.printBool(
"isOptimized",
N->isOptimized());
2444 Printer.printString(
"flags",
N->getFlags());
2445 Printer.printInt(
"runtimeVersion",
N->getRuntimeVersion(),
2447 Printer.printString(
"splitDebugFilename",
N->getSplitDebugFilename());
2448 Printer.printEmissionKind(
"emissionKind",
N->getEmissionKind());
2449 Printer.printMetadata(
"enums",
N->getRawEnumTypes());
2450 Printer.printMetadata(
"retainedTypes",
N->getRawRetainedTypes());
2451 Printer.printMetadata(
"globals",
N->getRawGlobalVariables());
2452 Printer.printMetadata(
"imports",
N->getRawImportedEntities());
2453 Printer.printMetadata(
"macros",
N->getRawMacros());
2454 Printer.printInt(
"dwoId",
N->getDWOId());
2455 Printer.printBool(
"splitDebugInlining",
N->getSplitDebugInlining(),
true);
2456 Printer.printBool(
"debugInfoForProfiling",
N->getDebugInfoForProfiling(),
2458 Printer.printNameTableKind(
"nameTableKind",
N->getNameTableKind());
2459 Printer.printBool(
"rangesBaseAddress",
N->getRangesBaseAddress(),
false);
2460 Printer.printString(
"sysroot",
N->getSysRoot());
2461 Printer.printString(
"sdk",
N->getSDK());
2466 AsmWriterContext &WriterCtx) {
2467 Out <<
"!DISubprogram(";
2468 MDFieldPrinter
Printer(Out, WriterCtx);
2469 Printer.printString(
"name",
N->getName());
2470 Printer.printString(
"linkageName",
N->getLinkageName());
2471 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2472 Printer.printMetadata(
"file",
N->getRawFile());
2473 Printer.printInt(
"line",
N->getLine());
2474 Printer.printMetadata(
"type",
N->getRawType());
2475 Printer.printInt(
"scopeLine",
N->getScopeLine());
2476 Printer.printMetadata(
"containingType",
N->getRawContainingType());
2477 if (
N->getVirtuality() != dwarf::DW_VIRTUALITY_none ||
2478 N->getVirtualIndex() != 0)
2479 Printer.printInt(
"virtualIndex",
N->getVirtualIndex(),
false);
2480 Printer.printInt(
"thisAdjustment",
N->getThisAdjustment());
2481 Printer.printDIFlags(
"flags",
N->getFlags());
2482 Printer.printDISPFlags(
"spFlags",
N->getSPFlags());
2483 Printer.printMetadata(
"unit",
N->getRawUnit());
2484 Printer.printMetadata(
"templateParams",
N->getRawTemplateParams());
2485 Printer.printMetadata(
"declaration",
N->getRawDeclaration());
2486 Printer.printMetadata(
"retainedNodes",
N->getRawRetainedNodes());
2487 Printer.printMetadata(
"thrownTypes",
N->getRawThrownTypes());
2488 Printer.printMetadata(
"annotations",
N->getRawAnnotations());
2489 Printer.printString(
"targetFuncName",
N->getTargetFuncName());
2490 Printer.printBool(
"keyInstructions",
N->getKeyInstructionsEnabled(),
false);
2495 AsmWriterContext &WriterCtx) {
2496 Out <<
"!DILexicalBlock(";
2497 MDFieldPrinter
Printer(Out, WriterCtx);
2498 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2499 Printer.printMetadata(
"file",
N->getRawFile());
2500 Printer.printInt(
"line",
N->getLine());
2501 Printer.printInt(
"column",
N->getColumn());
2507 AsmWriterContext &WriterCtx) {
2508 Out <<
"!DILexicalBlockFile(";
2509 MDFieldPrinter
Printer(Out, WriterCtx);
2510 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2511 Printer.printMetadata(
"file",
N->getRawFile());
2512 Printer.printInt(
"discriminator",
N->getDiscriminator(),
2518 AsmWriterContext &WriterCtx) {
2519 Out <<
"!DINamespace(";
2520 MDFieldPrinter
Printer(Out, WriterCtx);
2521 Printer.printString(
"name",
N->getName());
2522 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2523 Printer.printBool(
"exportSymbols",
N->getExportSymbols(),
false);
2528 AsmWriterContext &WriterCtx) {
2529 Out <<
"!DICommonBlock(";
2530 MDFieldPrinter
Printer(Out, WriterCtx);
2531 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2532 Printer.printMetadata(
"declaration",
N->getRawDecl(),
false);
2533 Printer.printString(
"name",
N->getName());
2534 Printer.printMetadata(
"file",
N->getRawFile());
2535 Printer.printInt(
"line",
N->getLineNo());
2540 AsmWriterContext &WriterCtx) {
2542 MDFieldPrinter
Printer(Out, WriterCtx);
2544 Printer.printInt(
"line",
N->getLine());
2545 Printer.printString(
"name",
N->getName());
2546 Printer.printString(
"value",
N->getValue());
2551 AsmWriterContext &WriterCtx) {
2552 Out <<
"!DIMacroFile(";
2553 MDFieldPrinter
Printer(Out, WriterCtx);
2554 Printer.printInt(
"line",
N->getLine());
2555 Printer.printMetadata(
"file",
N->getRawFile(),
false);
2556 Printer.printMetadata(
"nodes",
N->getRawElements());
2561 AsmWriterContext &WriterCtx) {
2562 Out <<
"!DIModule(";
2563 MDFieldPrinter
Printer(Out, WriterCtx);
2564 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2565 Printer.printString(
"name",
N->getName());
2566 Printer.printString(
"configMacros",
N->getConfigurationMacros());
2567 Printer.printString(
"includePath",
N->getIncludePath());
2568 Printer.printString(
"apinotes",
N->getAPINotesFile());
2569 Printer.printMetadata(
"file",
N->getRawFile());
2570 Printer.printInt(
"line",
N->getLineNo());
2571 Printer.printBool(
"isDecl",
N->getIsDecl(),
false);
2577 AsmWriterContext &WriterCtx) {
2578 Out <<
"!DITemplateTypeParameter(";
2579 MDFieldPrinter
Printer(Out, WriterCtx);
2580 Printer.printString(
"name",
N->getName());
2581 Printer.printMetadata(
"type",
N->getRawType(),
false);
2582 Printer.printBool(
"defaulted",
N->isDefault(),
false);
2588 AsmWriterContext &WriterCtx) {
2589 Out <<
"!DITemplateValueParameter(";
2590 MDFieldPrinter
Printer(Out, WriterCtx);
2591 if (
N->getTag() != dwarf::DW_TAG_template_value_parameter)
2593 Printer.printString(
"name",
N->getName());
2594 Printer.printMetadata(
"type",
N->getRawType());
2595 Printer.printBool(
"defaulted",
N->isDefault(),
false);
2596 Printer.printMetadata(
"value",
N->getValue(),
false);
2601 AsmWriterContext &WriterCtx) {
2602 Out <<
"!DIGlobalVariable(";
2603 MDFieldPrinter
Printer(Out, WriterCtx);
2604 Printer.printString(
"name",
N->getName());
2605 Printer.printString(
"linkageName",
N->getLinkageName());
2606 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2607 Printer.printMetadata(
"file",
N->getRawFile());
2608 Printer.printInt(
"line",
N->getLine());
2609 Printer.printMetadata(
"type",
N->getRawType());
2610 Printer.printBool(
"isLocal",
N->isLocalToUnit());
2611 Printer.printBool(
"isDefinition",
N->isDefinition());
2612 Printer.printMetadata(
"declaration",
N->getRawStaticDataMemberDeclaration());
2613 Printer.printMetadata(
"templateParams",
N->getRawTemplateParams());
2614 Printer.printInt(
"align",
N->getAlignInBits());
2615 Printer.printMetadata(
"annotations",
N->getRawAnnotations());
2620 AsmWriterContext &WriterCtx) {
2621 Out <<
"!DILocalVariable(";
2622 MDFieldPrinter
Printer(Out, WriterCtx);
2623 Printer.printString(
"name",
N->getName());
2624 Printer.printInt(
"arg",
N->getArg());
2625 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2626 Printer.printMetadata(
"file",
N->getRawFile());
2627 Printer.printInt(
"line",
N->getLine());
2628 Printer.printMetadata(
"type",
N->getRawType());
2629 Printer.printDIFlags(
"flags",
N->getFlags());
2630 Printer.printInt(
"align",
N->getAlignInBits());
2631 Printer.printMetadata(
"annotations",
N->getRawAnnotations());
2636 AsmWriterContext &WriterCtx) {
2638 MDFieldPrinter
Printer(Out, WriterCtx);
2639 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2640 Printer.printString(
"name",
N->getName());
2641 Printer.printMetadata(
"file",
N->getRawFile());
2642 Printer.printInt(
"line",
N->getLine());
2643 Printer.printInt(
"column",
N->getColumn());
2644 Printer.printBool(
"isArtificial",
N->isArtificial(),
false);
2645 if (
N->getCoroSuspendIdx())
2646 Printer.printInt(
"coroSuspendIdx", *
N->getCoroSuspendIdx(),
2652 AsmWriterContext &WriterCtx) {
2653 Out <<
"!DIExpression(";
2658 assert(!OpStr.empty() &&
"Expected valid opcode");
2662 Out << FS <<
Op.getArg(0);
2665 for (
unsigned A = 0, AE =
Op.getNumArgs();
A != AE; ++
A)
2666 Out << FS <<
Op.getArg(
A);
2670 for (
const auto &
I :
N->getElements())
2677 AsmWriterContext &WriterCtx,
2678 bool FromValue =
false) {
2680 "Unexpected DIArgList metadata outside of value argument");
2681 Out <<
"!DIArgList(";
2683 MDFieldPrinter
Printer(Out, WriterCtx);
2684 for (
const Metadata *Arg :
N->getArgs()) {
2693 AsmWriterContext &WriterCtx) {
2694 Out <<
"!DIGlobalVariableExpression(";
2695 MDFieldPrinter
Printer(Out, WriterCtx);
2696 Printer.printMetadata(
"var",
N->getVariable());
2697 Printer.printMetadata(
"expr",
N->getExpression());
2702 AsmWriterContext &WriterCtx) {
2703 Out <<
"!DIObjCProperty(";
2704 MDFieldPrinter
Printer(Out, WriterCtx);
2705 Printer.printString(
"name",
N->getName());
2706 Printer.printMetadata(
"file",
N->getRawFile());
2707 Printer.printInt(
"line",
N->getLine());
2708 Printer.printString(
"setter",
N->getSetterName());
2709 Printer.printString(
"getter",
N->getGetterName());
2710 Printer.printInt(
"attributes",
N->getAttributes());
2711 Printer.printMetadata(
"type",
N->getRawType());
2716 AsmWriterContext &WriterCtx) {
2717 Out <<
"!DIImportedEntity(";
2718 MDFieldPrinter
Printer(Out, WriterCtx);
2720 Printer.printString(
"name",
N->getName());
2721 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2722 Printer.printMetadata(
"entity",
N->getRawEntity());
2723 Printer.printMetadata(
"file",
N->getRawFile());
2724 Printer.printInt(
"line",
N->getLine());
2725 Printer.printMetadata(
"elements",
N->getRawElements());
2730 AsmWriterContext &Ctx) {
2731 if (
Node->isDistinct())
2733 else if (
Node->isTemporary())
2734 Out <<
"<temporary!> ";
2736 switch (
Node->getMetadataID()) {
2739#define HANDLE_MDNODE_LEAF(CLASS) \
2740 case Metadata::CLASS##Kind: \
2741 write##CLASS(Out, cast<CLASS>(Node), Ctx); \
2743#include "llvm/IR/Metadata.def"
2750 AsmWriterContext &WriterCtx,
2753 WriterCtx.TypePrinter->print(V->getType(), Out);
2764 assert(WriterCtx.TypePrinter &&
"Constants require TypePrinting!");
2771 if (IA->hasSideEffects())
2772 Out <<
"sideeffect ";
2773 if (IA->isAlignStack())
2774 Out <<
"alignstack ";
2777 Out <<
"inteldialect ";
2796 auto *
Machine = WriterCtx.Machine;
2800 Slot =
Machine->getGlobalSlot(GV);
2803 Slot =
Machine->getLocalSlot(V);
2810 Slot =
Machine->getLocalSlot(V);
2817 Slot =
Machine->getGlobalSlot(GV);
2820 Slot =
Machine->getLocalSlot(V);
2829 Out << Prefix << Slot;
2835 AsmWriterContext &WriterCtx,
2849 std::unique_ptr<SlotTracker> MachineStorage;
2851 if (!WriterCtx.Machine) {
2852 MachineStorage = std::make_unique<SlotTracker>(WriterCtx.Context);
2853 WriterCtx.Machine = MachineStorage.get();
2863 Out <<
"<" <<
N <<
">";
2877 assert(WriterCtx.TypePrinter &&
"TypePrinter required for metadata values");
2879 "Unexpected function-local metadata outside of value argument");
2886class AssemblyWriter {
2887 formatted_raw_ostream &Out;
2888 const Module *TheModule =
nullptr;
2889 const ModuleSummaryIndex *TheIndex =
nullptr;
2890 std::unique_ptr<SlotTracker> SlotTrackerStorage;
2892 TypePrinting TypePrinter;
2893 AssemblyAnnotationWriter *AnnotationWriter =
nullptr;
2894 SetVector<const Comdat *> Comdats;
2896 bool ShouldPreserveUseListOrder;
2901 DenseMap<const GlobalValueSummary *, GlobalValue::GUID> SummaryToGUIDMap;
2905 AssemblyWriter(formatted_raw_ostream &o, SlotTracker &Mac,
const Module *M,
2906 AssemblyAnnotationWriter *AAW,
bool IsForDebug,
2907 bool ShouldPreserveUseListOrder =
false);
2909 AssemblyWriter(formatted_raw_ostream &o, SlotTracker &Mac,
2910 const ModuleSummaryIndex *Index,
bool IsForDebug);
2913 return AsmWriterContext(&TypePrinter, &
Machine, TheModule);
2916 void printMDNodeBody(
const MDNode *MD);
2917 void printNamedMDNode(
const NamedMDNode *NMD);
2919 void printModule(
const Module *M);
2921 void writeOperand(
const Value *
Op,
bool PrintType);
2922 void writeParamOperand(
const Value *Operand, AttributeSet Attrs);
2923 void writeOperandBundles(
const CallBase *
Call);
2924 void writeSyncScope(
const LLVMContext &
Context,
2926 void writeAtomic(
const LLVMContext &
Context,
2929 void writeAtomicCmpXchg(
const LLVMContext &
Context,
2934 void writeAllMDNodes();
2935 void writeMDNode(
unsigned Slot,
const MDNode *Node);
2936 void writeAttribute(
const Attribute &Attr,
bool InAttrGroup =
false);
2937 void writeAttributeSet(
const AttributeSet &AttrSet,
bool InAttrGroup =
false);
2938 void writeAllAttributeGroups();
2940 void printTypeIdentities();
2941 void printGlobal(
const GlobalVariable *GV);
2942 void printAlias(
const GlobalAlias *GA);
2943 void printIFunc(
const GlobalIFunc *GI);
2944 void printComdat(
const Comdat *
C);
2945 void printFunction(
const Function *
F);
2946 void printArgument(
const Argument *FA, AttributeSet Attrs);
2948 void printInstructionLine(
const Instruction &
I);
2949 void printInstruction(
const Instruction &
I);
2950 void printDbgMarker(
const DbgMarker &DPI);
2951 void printDbgVariableRecord(
const DbgVariableRecord &DVR);
2952 void printDbgLabelRecord(
const DbgLabelRecord &DLR);
2953 void printDbgRecord(
const DbgRecord &DR);
2954 void printDbgRecordLine(
const DbgRecord &DR);
2956 void printUseListOrder(
const Value *V, ArrayRef<unsigned> Shuffle);
2957 void printUseLists(
const Function *
F);
2959 void printModuleSummaryIndex();
2960 void printSummaryInfo(
unsigned Slot,
const ValueInfo &VI);
2961 void printSummary(
const GlobalValueSummary &Summary);
2962 void printAliasSummary(
const AliasSummary *AS);
2963 void printGlobalVarSummary(
const GlobalVarSummary *GS);
2964 void printFunctionSummary(
const FunctionSummary *FS);
2965 void printTypeIdSummary(
const TypeIdSummary &TIS);
2967 void printTypeTestResolution(
const TypeTestResolution &TTRes);
2968 void printArgs(ArrayRef<uint64_t> Args);
2969 void printWPDRes(
const WholeProgramDevirtResolution &WPDRes);
2970 void printTypeIdInfo(
const FunctionSummary::TypeIdInfo &TIDInfo);
2971 void printVFuncId(
const FunctionSummary::VFuncId VFId);
2979 void printMetadataAttachments(
2980 const SmallVectorImpl<std::pair<unsigned, MDNode *>> &MDs,
2981 StringRef Separator);
2985 void printInfoComment(
const Value &V,
bool isMaterializable =
false);
2989 void printGCRelocateComment(
const GCRelocateInst &Relocate);
2996 bool IsForDebug,
bool ShouldPreserveUseListOrder)
2997 : Out(
o), TheModule(
M),
Machine(Mac), TypePrinter(
M), AnnotationWriter(AAW),
2998 IsForDebug(IsForDebug),
2999 ShouldPreserveUseListOrder(
3002 : ShouldPreserveUseListOrder) {
3005 for (
const GlobalObject &GO : TheModule->global_objects())
3012 : Out(
o), TheIndex(Index),
Machine(Mac), TypePrinter(nullptr),
3013 IsForDebug(IsForDebug),
3016void AssemblyWriter::writeOperand(
const Value *Operand,
bool PrintType) {
3018 Out <<
"<null operand!>";
3025void AssemblyWriter::writeSyncScope(
const LLVMContext &
Context,
3033 Context.getSyncScopeNames(SSNs);
3035 Out <<
" syncscope(\"";
3043void AssemblyWriter::writeAtomic(
const LLVMContext &
Context,
3046 if (Ordering == AtomicOrdering::NotAtomic)
3049 writeSyncScope(
Context, SSID);
3053void AssemblyWriter::writeAtomicCmpXchg(
const LLVMContext &
Context,
3057 assert(SuccessOrdering != AtomicOrdering::NotAtomic &&
3058 FailureOrdering != AtomicOrdering::NotAtomic);
3060 writeSyncScope(
Context, SSID);
3065void AssemblyWriter::writeParamOperand(
const Value *Operand,
3066 AttributeSet Attrs) {
3068 Out <<
"<null operand!>";
3073 TypePrinter.print(Operand->
getType(), Out);
3075 if (
Attrs.hasAttributes()) {
3077 writeAttributeSet(Attrs);
3085void AssemblyWriter::writeOperandBundles(
const CallBase *
Call) {
3101 ListSeparator InnerLS;
3103 for (
const auto &Input : BU.
Inputs) {
3105 if (Input ==
nullptr)
3106 Out <<
"<null operand bundle!>";
3117void AssemblyWriter::printModule(
const Module *M) {
3120 if (ShouldPreserveUseListOrder)
3123 if (!
M->getModuleIdentifier().empty() &&
3126 M->getModuleIdentifier().find(
'\n') == std::string::npos)
3127 Out <<
"; ModuleID = '" <<
M->getModuleIdentifier() <<
"'\n";
3129 if (!
M->getSourceFileName().empty()) {
3130 Out <<
"source_filename = \"";
3135 const std::string &
DL =
M->getDataLayoutStr();
3137 Out <<
"target datalayout = \"" <<
DL <<
"\"\n";
3138 if (!
M->getTargetTriple().empty())
3139 Out <<
"target triple = \"" <<
M->getTargetTriple().str() <<
"\"\n";
3141 if (!
M->getModuleInlineAsm().empty()) {
3145 StringRef
Asm =
M->getModuleInlineAsm();
3148 std::tie(Front, Asm) =
Asm.split(
'\n');
3152 Out <<
"module asm \"";
3155 }
while (!
Asm.empty());
3158 printTypeIdentities();
3161 if (!Comdats.empty())
3163 for (
const Comdat *
C : Comdats) {
3165 if (
C != Comdats.back())
3170 if (!
M->global_empty()) Out <<
'\n';
3171 for (
const GlobalVariable &GV :
M->globals()) {
3172 printGlobal(&GV); Out <<
'\n';
3176 if (!
M->alias_empty()) Out <<
"\n";
3177 for (
const GlobalAlias &GA :
M->aliases())
3181 if (!
M->ifunc_empty()) Out <<
"\n";
3182 for (
const GlobalIFunc &GI :
M->ifuncs())
3186 for (
const Function &
F : *M) {
3192 printUseLists(
nullptr);
3197 writeAllAttributeGroups();
3201 if (!
M->named_metadata_empty()) Out <<
'\n';
3203 for (
const NamedMDNode &Node :
M->named_metadata())
3204 printNamedMDNode(&Node);
3213void AssemblyWriter::printModuleSummaryIndex() {
3215 int NumSlots =
Machine.initializeIndexIfNeeded();
3221 std::vector<std::pair<std::string, ModuleHash>> moduleVec;
3222 std::string RegularLTOModuleName =
3224 moduleVec.resize(TheIndex->modulePaths().size());
3225 for (
auto &[ModPath, ModHash] : TheIndex->modulePaths())
3226 moduleVec[
Machine.getModulePathSlot(ModPath)] = std::make_pair(
3229 ModPath.empty() ? RegularLTOModuleName : std::string(ModPath), ModHash);
3232 for (
auto &ModPair : moduleVec) {
3233 Out <<
"^" << i++ <<
" = module: (";
3236 Out <<
"\", hash: (";
3238 for (
auto Hash : ModPair.second)
3245 for (
auto &GlobalList : *TheIndex) {
3246 auto GUID = GlobalList.first;
3247 for (
auto &Summary : GlobalList.second.getSummaryList())
3252 for (
auto &GlobalList : *TheIndex) {
3253 auto GUID = GlobalList.first;
3254 auto VI = TheIndex->getValueInfo(GlobalList);
3255 printSummaryInfo(
Machine.getGUIDSlot(GUID), VI);
3259 for (
const auto &TID : TheIndex->typeIds()) {
3260 Out <<
"^" <<
Machine.getTypeIdSlot(TID.second.first)
3261 <<
" = typeid: (name: \"" << TID.second.first <<
"\"";
3262 printTypeIdSummary(TID.second.second);
3263 Out <<
") ; guid = " << TID.first <<
"\n";
3267 for (
auto &TId : TheIndex->typeIdCompatibleVtableMap()) {
3269 Out <<
"^" <<
Machine.getTypeIdCompatibleVtableSlot(TId.first)
3270 <<
" = typeidCompatibleVTable: (name: \"" << TId.first <<
"\"";
3271 printTypeIdCompatibleVtableSummary(TId.second);
3272 Out <<
") ; guid = " <<
GUID <<
"\n";
3276 if (TheIndex->getFlags()) {
3277 Out <<
"^" << NumSlots <<
" = flags: " << TheIndex->getFlags() <<
"\n";
3281 Out <<
"^" << NumSlots <<
" = blockcount: " << TheIndex->getBlockCount()
3291 return "singleImpl";
3293 return "branchFunnel";
3304 return "uniformRetVal";
3306 return "uniqueRetVal";
3308 return "virtualConstProp";
3331void AssemblyWriter::printTypeTestResolution(
const TypeTestResolution &TTRes) {
3338 Out <<
", alignLog2: " << TTRes.
AlignLog2;
3340 Out <<
", sizeM1: " << TTRes.
SizeM1;
3343 Out <<
", bitMask: " << (unsigned)TTRes.
BitMask;
3350void AssemblyWriter::printTypeIdSummary(
const TypeIdSummary &TIS) {
3351 Out <<
", summary: (";
3352 printTypeTestResolution(TIS.
TTRes);
3353 if (!TIS.
WPDRes.empty()) {
3354 Out <<
", wpdResolutions: (";
3356 for (
auto &WPDRes : TIS.
WPDRes) {
3358 Out <<
"(offset: " << WPDRes.first <<
", ";
3359 printWPDRes(WPDRes.second);
3367void AssemblyWriter::printTypeIdCompatibleVtableSummary(
3369 Out <<
", summary: (";
3371 for (
auto &
P : TI) {
3373 Out <<
"(offset: " <<
P.AddressPointOffset <<
", ";
3374 Out <<
"^" <<
Machine.getGUIDSlot(
P.VTableVI.getGUID());
3380void AssemblyWriter::printArgs(ArrayRef<uint64_t> Args) {
3384void AssemblyWriter::printWPDRes(
const WholeProgramDevirtResolution &WPDRes) {
3385 Out <<
"wpdRes: (kind: ";
3392 Out <<
", resByArg: (";
3394 for (
auto &ResByArg : WPDRes.
ResByArg) {
3396 printArgs(ResByArg.first);
3397 Out <<
", byArg: (kind: ";
3399 if (ResByArg.second.TheKind ==
3401 ResByArg.second.TheKind ==
3403 Out <<
", info: " << ResByArg.second.Info;
3407 if (ResByArg.second.Byte || ResByArg.second.Bit)
3408 Out <<
", byte: " << ResByArg.second.Byte
3409 <<
", bit: " << ResByArg.second.Bit;
3430void AssemblyWriter::printAliasSummary(
const AliasSummary *AS) {
3431 Out <<
", aliasee: ";
3441void AssemblyWriter::printGlobalVarSummary(
const GlobalVarSummary *GS) {
3442 auto VTableFuncs =
GS->vTableFuncs();
3443 Out <<
", varFlags: (readonly: " <<
GS->VarFlags.MaybeReadOnly <<
", "
3444 <<
"writeonly: " <<
GS->VarFlags.MaybeWriteOnly <<
", "
3445 <<
"constant: " <<
GS->VarFlags.Constant;
3446 if (!VTableFuncs.empty())
3448 <<
"vcall_visibility: " <<
GS->VarFlags.VCallVisibility;
3451 if (!VTableFuncs.empty()) {
3452 Out <<
", vTableFuncs: (";
3454 for (
auto &
P : VTableFuncs) {
3456 Out <<
"(virtFunc: ^" <<
Machine.getGUIDSlot(
P.FuncVI.getGUID())
3457 <<
", offset: " <<
P.VTableOffset;
3475 return "linkonce_odr";
3485 return "extern_weak";
3487 return "available_externally";
3516 return "definition";
3518 return "declaration";
3523void AssemblyWriter::printFunctionSummary(
const FunctionSummary *FS) {
3524 Out <<
", insts: " <<
FS->instCount();
3525 if (
FS->fflags().anyFlagSet())
3526 Out <<
", " <<
FS->fflags();
3528 if (!
FS->calls().empty()) {
3529 Out <<
", calls: (";
3531 for (
auto &
Call :
FS->calls()) {
3533 Out <<
"(callee: ^" <<
Machine.getGUIDSlot(
Call.first.getGUID());
3534 if (
Call.second.getHotness() != CalleeInfo::HotnessType::Unknown)
3538 if (
Call.second.HasTailCall)
3545 if (
const auto *TIdInfo =
FS->getTypeIdInfo())
3546 printTypeIdInfo(*TIdInfo);
3550 auto AllocTypeName = [](uint8_t
Type) ->
const char * {
3552 case (uint8_t)AllocationType::None:
3554 case (uint8_t)AllocationType::NotCold:
3556 case (uint8_t)AllocationType::Cold:
3558 case (uint8_t)AllocationType::Hot:
3564 if (!
FS->allocs().empty()) {
3565 Out <<
", allocs: (";
3567 for (
auto &AI :
FS->allocs()) {
3569 Out <<
"(versions: (";
3571 for (
auto V : AI.Versions) {
3573 Out << AllocTypeName(V);
3575 Out <<
"), memProf: (";
3576 ListSeparator MIBFS;
3577 for (
auto &MIB : AI.MIBs) {
3579 Out <<
"(type: " << AllocTypeName((uint8_t)MIB.AllocType);
3580 Out <<
", stackIds: (";
3581 ListSeparator SIDFS;
3582 for (
auto Id : MIB.StackIdIndices) {
3584 Out << TheIndex->getStackIdAtIndex(Id);
3593 if (!
FS->callsites().empty()) {
3594 Out <<
", callsites: (";
3596 for (
auto &CI :
FS->callsites()) {
3599 Out <<
"(callee: ^" <<
Machine.getGUIDSlot(CI.Callee.getGUID());
3601 Out <<
"(callee: null";
3602 Out <<
", clones: (";
3604 for (
auto V : CI.Clones) {
3608 Out <<
"), stackIds: (";
3609 ListSeparator SIDFS;
3610 for (
auto Id : CI.StackIdIndices) {
3612 Out << TheIndex->getStackIdAtIndex(Id);
3619 auto PrintRange = [&](
const ConstantRange &
Range) {
3623 if (!
FS->paramAccesses().empty()) {
3624 Out <<
", params: (";
3626 for (
auto &PS :
FS->paramAccesses()) {
3628 Out <<
"(param: " << PS.ParamNo;
3629 Out <<
", offset: ";
3631 if (!PS.Calls.empty()) {
3632 Out <<
", calls: (";
3634 for (
auto &
Call : PS.Calls) {
3636 Out <<
"(callee: ^" <<
Machine.getGUIDSlot(
Call.Callee.getGUID());
3637 Out <<
", param: " <<
Call.ParamNo;
3638 Out <<
", offset: ";
3639 PrintRange(
Call.Offsets);
3650void AssemblyWriter::printTypeIdInfo(
3651 const FunctionSummary::TypeIdInfo &TIDInfo) {
3652 Out <<
", typeIdInfo: (";
3653 ListSeparator TIDFS;
3656 Out <<
"typeTests: (";
3659 auto TidIter = TheIndex->typeIds().equal_range(GUID);
3660 if (TidIter.first == TidIter.second) {
3666 for (
const auto &[GUID, TypeIdPair] :
make_range(TidIter)) {
3668 auto Slot =
Machine.getTypeIdSlot(TypeIdPair.first);
3686 "typeTestAssumeConstVCalls");
3691 "typeCheckedLoadConstVCalls");
3696void AssemblyWriter::printVFuncId(
const FunctionSummary::VFuncId VFId) {
3697 auto TidIter = TheIndex->typeIds().equal_range(VFId.
GUID);
3698 if (TidIter.first == TidIter.second) {
3699 Out <<
"vFuncId: (";
3700 Out <<
"guid: " << VFId.
GUID;
3701 Out <<
", offset: " << VFId.
Offset;
3707 for (
const auto &[GUID, TypeIdPair] :
make_range(TidIter)) {
3709 Out <<
"vFuncId: (";
3710 auto Slot =
Machine.getTypeIdSlot(TypeIdPair.first);
3713 Out <<
", offset: " << VFId.
Offset;
3718void AssemblyWriter::printNonConstVCalls(
3720 Out <<
Tag <<
": (";
3722 for (
auto &VFuncId : VCallList) {
3724 printVFuncId(VFuncId);
3729void AssemblyWriter::printConstVCalls(
3731 Out <<
Tag <<
": (";
3733 for (
auto &ConstVCall : VCallList) {
3736 printVFuncId(ConstVCall.VFunc);
3737 if (!ConstVCall.Args.empty()) {
3739 printArgs(ConstVCall.Args);
3746void AssemblyWriter::printSummary(
const GlobalValueSummary &Summary) {
3747 GlobalValueSummary::GVFlags GVFlags =
Summary.flags();
3750 Out <<
"(module: ^" <<
Machine.getModulePathSlot(
Summary.modulePath())
3753 Out <<
", visibility: "
3756 Out <<
", live: " << GVFlags.
Live;
3757 Out <<
", dsoLocal: " << GVFlags.
DSOLocal;
3759 Out <<
", importType: "
3771 auto RefList =
Summary.refs();
3772 if (!RefList.empty()) {
3775 for (
auto &
Ref : RefList) {
3777 if (
Ref.isReadOnly())
3779 else if (
Ref.isWriteOnly())
3780 Out <<
"writeonly ";
3781 Out <<
"^" <<
Machine.getGUIDSlot(
Ref.getGUID());
3789void AssemblyWriter::printSummaryInfo(
unsigned Slot,
const ValueInfo &VI) {
3790 Out <<
"^" <<
Slot <<
" = gv: (";
3791 if (
VI.hasName() && !
VI.name().empty())
3792 Out <<
"name: \"" <<
VI.name() <<
"\"";
3794 Out <<
"guid: " <<
VI.getGUID();
3795 if (!
VI.getSummaryList().empty()) {
3796 Out <<
", summaries: (";
3798 for (
auto &Summary :
VI.getSummaryList()) {
3800 printSummary(*Summary);
3805 if (
VI.hasName() && !
VI.name().empty())
3806 Out <<
" ; guid = " <<
VI.getGUID();
3813 Out <<
"<empty name> ";
3815 unsigned char FirstC =
static_cast<unsigned char>(Name[0]);
3816 if (isalpha(FirstC) || FirstC ==
'-' || FirstC ==
'$' || FirstC ==
'.' ||
3821 for (
unsigned i = 1, e = Name.size(); i != e; ++i) {
3822 unsigned char C = Name[i];
3823 if (isalnum(
C) ||
C ==
'-' ||
C ==
'$' ||
C ==
'.' ||
C ==
'_')
3831void AssemblyWriter::printNamedMDNode(
const NamedMDNode *NMD) {
3866 Out <<
"dso_local ";
3884 Out <<
"thread_local ";
3887 Out <<
"thread_local(localdynamic) ";
3890 Out <<
"thread_local(initialexec) ";
3893 Out <<
"thread_local(localexec) ";
3903 return "local_unnamed_addr";
3905 return "unnamed_addr";
3928void AssemblyWriter::printGlobal(
const GlobalVariable *GV) {
3930 Out <<
"; Materializable\n";
3951 Out << (GV->
isConstant() ?
"constant " :
"global ");
3960 Out <<
", section \"";
3965 Out <<
", partition \"";
3970 Out <<
", code_model \"";
3995 Out <<
", no_sanitize_address";
3997 Out <<
", no_sanitize_hwaddress";
3999 Out <<
", sanitize_memtag";
4001 Out <<
", sanitize_address_dyninit";
4006 Out <<
", align " <<
A->value();
4010 printMetadataAttachments(MDs,
", ");
4013 if (
Attrs.hasAttributes())
4014 Out <<
" #" <<
Machine.getAttributeGroupSlot(Attrs);
4019void AssemblyWriter::printAlias(
const GlobalAlias *GA) {
4021 Out <<
"; Materializable\n";
4041 if (
const Constant *Aliasee = GA->
getAliasee()) {
4044 TypePrinter.print(GA->
getType(), Out);
4045 Out <<
" <<NULL ALIASEE>>";
4049 Out <<
", partition \"";
4058void AssemblyWriter::printIFunc(
const GlobalIFunc *GI) {
4060 Out <<
"; Materializable\n";
4075 if (
const Constant *Resolver = GI->
getResolver()) {
4078 TypePrinter.print(GI->
getType(), Out);
4079 Out <<
" <<NULL RESOLVER>>";
4083 Out <<
", partition \"";
4090 printMetadataAttachments(MDs,
", ");
4097void AssemblyWriter::printComdat(
const Comdat *
C) {
4101void AssemblyWriter::printTypeIdentities() {
4102 if (TypePrinter.empty())
4108 auto &NumberedTypes = TypePrinter.getNumberedTypes();
4109 for (
unsigned I = 0,
E = NumberedTypes.size();
I !=
E; ++
I) {
4110 Out <<
'%' <<
I <<
" = type ";
4114 TypePrinter.printStructBody(NumberedTypes[
I], Out);
4118 auto &NamedTypes = TypePrinter.getNamedTypes();
4119 for (StructType *NamedType : NamedTypes) {
4125 TypePrinter.printStructBody(NamedType, Out);
4131void AssemblyWriter::printFunction(
const Function *
F) {
4132 if (
F->isMaterializable())
4133 Out <<
"; Materializable\n";
4134 else if (AnnotationWriter)
4137 const AttributeList &
Attrs =
F->getAttributes();
4138 if (
Attrs.hasFnAttrs()) {
4139 AttributeSet AS =
Attrs.getFnAttrs();
4140 std::string AttrStr;
4143 if (!Attr.isStringAttribute()) {
4144 if (!AttrStr.empty()) AttrStr +=
' ';
4145 AttrStr += Attr.getAsString();
4149 if (!AttrStr.empty())
4150 Out <<
"; Function Attrs: " << AttrStr <<
'\n';
4154 Out <<
"; Unknown intrinsic\n";
4158 if (
F->isDeclaration()) {
4161 F->getAllMetadata(MDs);
4162 printMetadataAttachments(MDs,
" ");
4173 if (
F->getCallingConv() != CallingConv::C) {
4178 FunctionType *FT =
F->getFunctionType();
4179 if (
Attrs.hasRetAttrs())
4180 Out <<
Attrs.getAsString(AttributeList::ReturnIndex) <<
' ';
4181 TypePrinter.print(
F->getReturnType(), Out);
4188 if (
F->isDeclaration() && !IsForDebug) {
4191 for (
unsigned I = 0,
E = FT->getNumParams();
I !=
E; ++
I) {
4194 TypePrinter.print(FT->getParamType(
I), Out);
4196 AttributeSet ArgAttrs =
Attrs.getParamAttrs(
I);
4199 writeAttributeSet(ArgAttrs);
4205 for (
const Argument &Arg :
F->args()) {
4207 printArgument(&Arg,
Attrs.getParamAttrs(Arg.getArgNo()));
4212 if (FT->isVarArg()) {
4213 if (FT->getNumParams()) Out <<
", ";
4224 bool ForcePrintAddressSpace =
4225 !
Mod ||
Mod->getDataLayout().getProgramAddressSpace() != 0;
4227 "", ForcePrintAddressSpace);
4228 if (
Attrs.hasFnAttrs())
4229 Out <<
" #" <<
Machine.getAttributeGroupSlot(
Attrs.getFnAttrs());
4230 if (
F->hasSection()) {
4231 Out <<
" section \"";
4235 if (
F->hasPartition()) {
4236 Out <<
" partition \"";
4241 if (MaybeAlign
A =
F->getAlign())
4242 Out <<
" align " <<
A->value();
4243 if (MaybeAlign
A =
F->getPreferredAlignment())
4244 Out <<
" prefalign(" <<
A->value() <<
')';
4246 Out <<
" gc \"" <<
F->getGC() <<
'"';
4247 if (
F->hasPrefixData()) {
4249 writeOperand(
F->getPrefixData(),
true);
4251 if (
F->hasPrologueData()) {
4252 Out <<
" prologue ";
4253 writeOperand(
F->getPrologueData(),
true);
4255 if (
F->hasPersonalityFn()) {
4256 Out <<
" personality ";
4257 writeOperand(
F->getPersonalityFn(),
true);
4261 if (
auto *MDProf =
F->getMetadata(LLVMContext::MD_prof)) {
4263 MDProf->print(Out, TheModule,
true);
4267 if (
F->isDeclaration()) {
4271 F->getAllMetadata(MDs);
4272 printMetadataAttachments(MDs,
" ");
4276 for (
const BasicBlock &BB : *
F)
4290void AssemblyWriter::printArgument(
const Argument *Arg, AttributeSet Attrs) {
4292 TypePrinter.print(Arg->
getType(), Out);
4295 if (
Attrs.hasAttributes()) {
4297 writeAttributeSet(Attrs);
4306 assert(Slot != -1 &&
"expect argument in function here");
4307 Out <<
" %" <<
Slot;
4318 }
else if (!IsEntryBlock) {
4320 int Slot =
Machine.getLocalSlot(BB);
4327 if (!IsEntryBlock) {
4332 Out <<
" No predecessors!";
4338 writeOperand(Pred,
false);
4349 for (
const DbgRecord &DR :
I.getDbgRecordRange())
4350 printDbgRecordLine(DR);
4351 printInstructionLine(
I);
4358void AssemblyWriter::printInstructionLine(
const Instruction &
I) {
4359 printInstruction(
I);
4365void AssemblyWriter::printGCRelocateComment(
const GCRelocateInst &Relocate) {
4375void AssemblyWriter::printInfoComment(
const Value &V,
bool isMaterializable) {
4377 printGCRelocateComment(*Relocate);
4379 if (AnnotationWriter && !isMaterializable)
4384 if (
I->getDebugLoc()) {
4386 I->getDebugLoc().print(Out);
4392 if (
auto *MD =
I->getMetadata(LLVMContext::MD_prof)) {
4394 MD->print(Out, TheModule,
true);
4405 if (Operand ==
nullptr) {
4406 Out <<
" <cannot get addrspace!>";
4416 bool ForcePrintAddrSpace =
4417 !
Mod ||
Mod->getDataLayout().getProgramAddressSpace() != 0;
4419 ForcePrintAddrSpace);
4423void AssemblyWriter::printInstruction(
const Instruction &
I) {
4433 }
else if (!
I.getType()->isVoidTy()) {
4435 int SlotNum =
Machine.getLocalSlot(&
I);
4437 Out <<
"<badref> = ";
4439 Out <<
'%' << SlotNum <<
" = ";
4443 if (CI->isMustTailCall())
4445 else if (CI->isTailCall())
4447 else if (CI->isNoTailCall())
4452 Out <<
I.getOpcodeName();
4474 Out <<
' ' << CI->getPredicate();
4481 const Value *Operand =
I.getNumOperands() ?
I.getOperand(0) :
nullptr;
4486 writeOperand(BI->getCondition(),
true);
4488 writeOperand(BI->getSuccessor(0),
true);
4490 writeOperand(BI->getSuccessor(1),
true);
4495 writeOperand(
SI.getCondition(),
true);
4497 writeOperand(
SI.getDefaultDest(),
true);
4499 for (
auto Case :
SI.cases()) {
4501 writeOperand(Case.getCaseValue(),
true);
4503 writeOperand(Case.getCaseSuccessor(),
true);
4509 writeOperand(Operand,
true);
4513 for (
unsigned i = 1, e =
I.getNumOperands(); i != e; ++i) {
4515 writeOperand(
I.getOperand(i),
true);
4520 TypePrinter.print(
I.getType(), Out);
4524 for (
const auto &[V,
Block] :
4525 zip_equal(PN->incoming_values(), PN->blocks())) {
4527 writeOperand(V,
false);
4529 writeOperand(
Block,
false);
4534 writeOperand(
I.getOperand(0),
true);
4539 writeOperand(
I.getOperand(0),
true); Out <<
", ";
4540 writeOperand(
I.getOperand(1),
true);
4545 TypePrinter.print(
I.getType(), Out);
4546 if (LPI->isCleanup() || LPI->getNumClauses() != 0)
4549 if (LPI->isCleanup())
4552 for (
unsigned i = 0, e = LPI->getNumClauses(); i != e; ++i) {
4553 if (i != 0 || LPI->isCleanup()) Out <<
"\n";
4554 if (LPI->isCatch(i))
4559 writeOperand(LPI->getClause(i),
true);
4563 writeOperand(CatchSwitch->getParentPad(),
false);
4566 for (
const BasicBlock *PadBB : CatchSwitch->handlers()) {
4568 writeOperand(PadBB,
true);
4571 if (
const BasicBlock *UnwindDest = CatchSwitch->getUnwindDest())
4572 writeOperand(UnwindDest,
true);
4577 writeOperand(FPI->getParentPad(),
false);
4580 for (
const Value *
Op : FPI->arg_operands()) {
4582 writeOperand(
Op,
true);
4589 writeOperand(CRI->getOperand(0),
false);
4592 writeOperand(CRI->getOperand(1),
true);
4595 writeOperand(CRI->getOperand(0),
false);
4598 if (CRI->hasUnwindDest())
4599 writeOperand(CRI->getOperand(1),
true);
4604 if (CI->getCallingConv() != CallingConv::C) {
4609 Operand = CI->getCalledOperand();
4610 FunctionType *FTy = CI->getFunctionType();
4611 Type *RetTy = FTy->getReturnType();
4612 const AttributeList &PAL = CI->getAttributes();
4614 if (PAL.hasRetAttrs())
4615 Out <<
' ' << PAL.getAsString(AttributeList::ReturnIndex);
4624 TypePrinter.print(FTy->isVarArg() ? FTy : RetTy, Out);
4626 writeOperand(Operand,
false);
4628 bool HasPrettyPrintedArgs =
4633 Function *CalledFunc = CI->getCalledFunction();
4634 auto PrintArgComment = [&](
unsigned ArgNo) {
4638 std::string ArgComment;
4639 raw_string_ostream ArgCommentStream(ArgComment);
4642 if (ArgComment.empty())
4644 Out <<
"/* " << ArgComment <<
" */ ";
4646 if (HasPrettyPrintedArgs) {
4647 for (
unsigned ArgNo = 0, NumArgs = CI->arg_size(); ArgNo < NumArgs;
4650 PrintArgComment(ArgNo);
4651 writeParamOperand(CI->getArgOperand(ArgNo), PAL.getParamAttrs(ArgNo));
4654 for (
unsigned ArgNo = 0, NumArgs = CI->arg_size(); ArgNo < NumArgs;
4657 writeParamOperand(CI->getArgOperand(ArgNo), PAL.getParamAttrs(ArgNo));
4662 if (CI->isMustTailCall() && CI->getParent() &&
4663 CI->getParent()->getParent() &&
4664 CI->getParent()->getParent()->isVarArg()) {
4665 if (CI->arg_size() > 0)
4671 if (PAL.hasFnAttrs())
4672 Out <<
" #" <<
Machine.getAttributeGroupSlot(PAL.getFnAttrs());
4674 writeOperandBundles(CI);
4676 Operand =
II->getCalledOperand();
4677 FunctionType *FTy =
II->getFunctionType();
4678 Type *RetTy = FTy->getReturnType();
4679 const AttributeList &PAL =
II->getAttributes();
4682 if (
II->getCallingConv() != CallingConv::C) {
4687 if (PAL.hasRetAttrs())
4688 Out <<
' ' << PAL.getAsString(AttributeList::ReturnIndex);
4698 TypePrinter.print(FTy->isVarArg() ? FTy : RetTy, Out);
4700 writeOperand(Operand,
false);
4703 for (
unsigned op = 0, Eop =
II->arg_size();
op < Eop; ++
op) {
4705 writeParamOperand(
II->getArgOperand(
op), PAL.getParamAttrs(
op));
4709 if (PAL.hasFnAttrs())
4710 Out <<
" #" <<
Machine.getAttributeGroupSlot(PAL.getFnAttrs());
4712 writeOperandBundles(
II);
4715 writeOperand(
II->getNormalDest(),
true);
4717 writeOperand(
II->getUnwindDest(),
true);
4719 Operand = CBI->getCalledOperand();
4720 FunctionType *FTy = CBI->getFunctionType();
4721 Type *RetTy = FTy->getReturnType();
4722 const AttributeList &PAL = CBI->getAttributes();
4725 if (CBI->getCallingConv() != CallingConv::C) {
4730 if (PAL.hasRetAttrs())
4731 Out <<
' ' << PAL.getAsString(AttributeList::ReturnIndex);
4738 TypePrinter.print(FTy->isVarArg() ? FTy : RetTy, Out);
4740 writeOperand(Operand,
false);
4742 ListSeparator ArgLS;
4743 for (
unsigned op = 0, Eop = CBI->arg_size();
op < Eop; ++
op) {
4745 writeParamOperand(CBI->getArgOperand(
op), PAL.getParamAttrs(
op));
4749 if (PAL.hasFnAttrs())
4750 Out <<
" #" <<
Machine.getAttributeGroupSlot(PAL.getFnAttrs());
4752 writeOperandBundles(CBI);
4755 writeOperand(CBI->getDefaultDest(),
true);
4757 ListSeparator DestLS;
4758 for (
const BasicBlock *Dest : CBI->getIndirectDests()) {
4760 writeOperand(Dest,
true);
4765 if (AI->isUsedWithInAlloca())
4767 if (AI->isSwiftError())
4768 Out <<
"swifterror ";
4769 TypePrinter.print(AI->getAllocatedType(), Out);
4775 if (!AI->getArraySize() || AI->isArrayAllocation() ||
4776 !AI->getArraySize()->getType()->isIntegerTy(32)) {
4778 writeOperand(AI->getArraySize(),
true);
4780 if (MaybeAlign
A = AI->getAlign()) {
4781 Out <<
", align " <<
A->value();
4789 writeOperand(Operand,
true);
4792 TypePrinter.print(
I.getType(), Out);
4796 writeOperand(Operand,
true);
4799 TypePrinter.print(
I.getType(), Out);
4800 }
else if (Operand) {
4803 TypePrinter.print(
GEP->getSourceElementType(), Out);
4807 TypePrinter.print(LI->getType(), Out);
4814 bool PrintAllTypes =
false;
4822 PrintAllTypes =
true;
4824 for (
unsigned i = 1,
E =
I.getNumOperands(); i !=
E; ++i) {
4825 Operand =
I.getOperand(i);
4828 if (Operand && Operand->
getType() != TheType) {
4829 PrintAllTypes =
true;
4835 if (!PrintAllTypes) {
4837 TypePrinter.print(TheType, Out);
4842 for (
const Value *
Op :
I.operands()) {
4844 writeOperand(
Op, PrintAllTypes);
4851 writeAtomic(LI->getContext(), LI->getOrdering(), LI->getSyncScopeID());
4852 if (MaybeAlign
A = LI->getAlign())
4853 Out <<
", align " <<
A->value();
4856 writeAtomic(
SI->getContext(),
SI->getOrdering(),
SI->getSyncScopeID());
4857 if (MaybeAlign
A =
SI->getAlign())
4858 Out <<
", align " <<
A->value();
4860 writeAtomicCmpXchg(CXI->getContext(), CXI->getSuccessOrdering(),
4861 CXI->getFailureOrdering(), CXI->getSyncScopeID());
4862 Out <<
", align " << CXI->getAlign().value();
4864 writeAtomic(RMWI->getContext(), RMWI->getOrdering(),
4865 RMWI->getSyncScopeID());
4866 Out <<
", align " << RMWI->getAlign().value();
4868 writeAtomic(FI->getContext(), FI->getOrdering(), FI->getSyncScopeID());
4876 printMetadataAttachments(InstMD,
", ");
4879 printInfoComment(
I);
4882void AssemblyWriter::printDbgMarker(
const DbgMarker &Marker) {
4886 printDbgRecord(DPR);
4890 Out <<
" DbgMarker -> { ";
4895void AssemblyWriter::printDbgRecord(
const DbgRecord &DR) {
4897 printDbgVariableRecord(*DVR);
4899 printDbgLabelRecord(*DLR);
4904void AssemblyWriter::printDbgVariableRecord(
const DbgVariableRecord &DVR) {
4908 case DbgVariableRecord::LocationType::Value:
4911 case DbgVariableRecord::LocationType::Declare:
4914 case DbgVariableRecord::LocationType::DeclareValue:
4915 Out <<
"declare_value";
4917 case DbgVariableRecord::LocationType::Assign:
4922 "Tried to print a DbgVariableRecord with an invalid LocationType!");
4953void AssemblyWriter::printDbgRecordLine(
const DbgRecord &DR) {
4960void AssemblyWriter::printDbgLabelRecord(
const DbgLabelRecord &Label) {
4962 Out <<
"#dbg_label(";
4969void AssemblyWriter::printMetadataAttachments(
4970 const SmallVectorImpl<std::pair<unsigned, MDNode *>> &MDs,
4971 StringRef Separator) {
4975 if (MDNames.empty())
4976 MDs[0].second->getContext().getMDKindNames(MDNames);
4979 for (
const auto &
I : MDs) {
4980 unsigned Kind =
I.first;
4982 if (Kind < MDNames.size()) {
4986 Out <<
"!<unknown kind #" <<
Kind <<
">";
4992void AssemblyWriter::writeMDNode(
unsigned Slot,
const MDNode *Node) {
4993 Out <<
'!' <<
Slot <<
" = ";
4994 printMDNodeBody(Node);
4998void AssemblyWriter::writeAllMDNodes() {
5004 for (
unsigned i = 0, e = Nodes.
size(); i != e; ++i) {
5005 writeMDNode(i, Nodes[i]);
5009void AssemblyWriter::printMDNodeBody(
const MDNode *Node) {
5014void AssemblyWriter::writeAttribute(
const Attribute &Attr,
bool InAttrGroup) {
5020 Out << Attribute::getNameFromAttrKind(Attr.
getKindAsEnum());
5023 TypePrinter.print(Ty, Out);
5028void AssemblyWriter::writeAttributeSet(
const AttributeSet &AttrSet,
5030 ListSeparator
LS(
" ");
5031 for (
const auto &Attr : AttrSet) {
5033 writeAttribute(Attr, InAttrGroup);
5037void AssemblyWriter::writeAllAttributeGroups() {
5038 std::vector<std::pair<AttributeSet, unsigned>> asVec;
5039 asVec.resize(
Machine.as_size());
5042 asVec[
I.second] =
I;
5044 for (
const auto &
I : asVec)
5045 Out <<
"attributes #" <<
I.second <<
" = { "
5046 <<
I.first.getAsString(
true) <<
" }\n";
5049void AssemblyWriter::printUseListOrder(
const Value *V,
5050 ArrayRef<unsigned> Shuffle) {
5055 Out <<
"uselistorder";
5058 writeOperand(BB->getParent(),
false);
5060 writeOperand(BB,
false);
5063 writeOperand(V,
true);
5066 assert(Shuffle.
size() >= 2 &&
"Shuffle too small");
5070void AssemblyWriter::printUseLists(
const Function *
F) {
5071 auto It = UseListOrders.find(
F);
5072 if (It == UseListOrders.end())
5075 Out <<
"\n; uselistorder directives\n";
5076 for (
const auto &Pair : It->second)
5077 printUseListOrder(Pair.first, Pair.second);
5085 bool ShouldPreserveUseListOrder,
bool IsForDebug)
const {
5088 AssemblyWriter W(OS, SlotTable, this->
getParent(), AAW, IsForDebug,
5089 ShouldPreserveUseListOrder);
5090 W.printFunction(
this);
5094 bool ShouldPreserveUseListOrder,
5095 bool IsForDebug)
const {
5098 AssemblyWriter W(OS, SlotTable, this->
getModule(), AAW,
5100 ShouldPreserveUseListOrder);
5101 W.printBasicBlock(
this);
5105 bool ShouldPreserveUseListOrder,
bool IsForDebug)
const {
5108 AssemblyWriter W(OS, SlotTable,
this, AAW, IsForDebug,
5109 ShouldPreserveUseListOrder);
5110 W.printModule(
this);
5116 AssemblyWriter W(OS, SlotTable,
getParent(),
nullptr, IsForDebug);
5117 W.printNamedMDNode(
this);
5121 bool IsForDebug)
const {
5122 std::optional<SlotTracker> LocalST;
5128 SlotTable = &*LocalST;
5132 AssemblyWriter W(OS, *SlotTable,
getParent(),
nullptr, IsForDebug);
5133 W.printNamedMDNode(
this);
5138 ROS <<
" = comdat ";
5145 ROS <<
"exactmatch";
5151 ROS <<
"nodeduplicate";
5163 TP.print(
const_cast<Type*
>(
this), OS);
5172 TP.printStructBody(STy, OS);
5178 if (
Function *
F = CI->getCalledFunction())
5179 if (
F->isIntrinsic())
5180 for (
auto &
Op :
I.operands())
5190 print(ROS, MST, IsForDebug);
5196 print(ROS, MST, IsForDebug);
5200 bool IsForDebug)
const {
5208 AssemblyWriter W(OS, SlotTable,
getModuleFromDPI(
this),
nullptr, IsForDebug);
5209 W.printDbgMarker(*
this);
5215 print(ROS, MST, IsForDebug);
5219 bool IsForDebug)
const {
5225 ?
Marker->getParent()->getParent()
5229 AssemblyWriter W(OS, SlotTable,
getModuleFromDPI(
this),
nullptr, IsForDebug);
5230 W.printDbgVariableRecord(*
this);
5234 bool IsForDebug)
const {
5240 Marker->getParent() ?
Marker->getParent()->getParent() :
nullptr;
5244 AssemblyWriter W(OS, SlotTable,
getModuleFromDPI(
this),
nullptr, IsForDebug);
5245 W.printDbgLabelRecord(*
this);
5249 bool ShouldInitializeAllMetadata =
false;
5253 ShouldInitializeAllMetadata =
true;
5256 print(ROS, MST, IsForDebug);
5260 bool IsForDebug)
const {
5265 auto IncorporateFunction = [&](
const Function *
F) {
5271 IncorporateFunction(
I->getParent() ?
I->getParent()->getParent() :
nullptr);
5273 W.printInstruction(*
I);
5275 IncorporateFunction(BB->getParent());
5276 AssemblyWriter W(OS, SlotTable,
getModuleFromVal(BB),
nullptr, IsForDebug);
5277 W.printBasicBlock(BB);
5279 AssemblyWriter W(OS, SlotTable, GV->
getParent(),
nullptr, IsForDebug);
5293 TypePrinting TypePrinter;
5294 TypePrinter.print(
C->getType(), OS);
5296 AsmWriterContext WriterCtx(&TypePrinter, MST.
getMachine());
5312 AsmWriterContext WriterCtx(
nullptr,
Machine, M);
5321 TypePrinting TypePrinter(MST.
getModule());
5352 AsmWriterContext &WriterCtx) {
5365struct MDTreeAsmWriterContext :
public AsmWriterContext {
5368 using EntryTy = std::pair<unsigned, std::string>;
5372 SmallPtrSet<const Metadata *, 4> Visited;
5374 raw_ostream &MainOS;
5376 MDTreeAsmWriterContext(TypePrinting *TP, SlotTracker *ST,
const Module *M,
5377 raw_ostream &OS,
const Metadata *InitMD)
5378 : AsmWriterContext(TP,
ST,
M),
Level(0
U), Visited({InitMD}), MainOS(OS) {}
5380 void onWriteMetadataAsOperand(
const Metadata *MD)
override {
5381 if (!Visited.
insert(MD).second)
5385 raw_string_ostream
SS(Str);
5390 unsigned InsertIdx = Buffer.
size() - 1;
5393 Buffer[InsertIdx].second = std::move(
SS.str());
5397 ~MDTreeAsmWriterContext()
override {
5398 for (
const auto &Entry : Buffer) {
5400 unsigned NumIndent =
Entry.first * 2U;
5409 bool OnlyAsOperand,
bool PrintAsTree =
false) {
5412 TypePrinting TypePrinter(M);
5414 std::unique_ptr<AsmWriterContext> WriterCtx;
5415 if (PrintAsTree && !OnlyAsOperand)
5416 WriterCtx = std::make_unique<MDTreeAsmWriterContext>(
5420 std::make_unique<AsmWriterContext>(&TypePrinter, MST.
getMachine(), M);
5449 const Module *M,
bool )
const {
5468 AssemblyWriter W(OS, SlotTable,
this, IsForDebug);
5469 W.printModuleSummaryIndex();
5473 unsigned UB)
const {
5479 if (
I.second >= LB &&
I.second < UB)
5480 L.push_back(std::make_pair(
I.second,
I.first));
5483#if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP)
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
amdgpu next use AMDGPU Next Use Analysis Printer
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 writeDICompositeType(raw_ostream &Out, const DICompositeType *N, AsmWriterContext &WriterCtx)
static void writeDIFixedPointType(raw_ostream &Out, const DIFixedPointType *N, AsmWriterContext &WriterCtx)
static void printDSOLocation(const GlobalValue &GV, formatted_raw_ostream &Out)
static const char * getWholeProgDevirtResKindName(WholeProgramDevirtResolution::Kind K)
static void writeDISubrangeType(raw_ostream &Out, const DISubrangeType *N, AsmWriterContext &WriterCtx)
static void writeAPFloatInternal(raw_ostream &Out, const APFloat &APF)
static void printMetadataImpl(raw_ostream &ROS, const Metadata &MD, ModuleSlotTracker &MST, const Module *M, bool OnlyAsOperand, bool PrintAsTree=false)
static void writeDIStringType(raw_ostream &Out, const DIStringType *N, AsmWriterContext &WriterCtx)
static std::string getLinkageNameWithSpace(GlobalValue::LinkageTypes LT)
static cl::opt< bool > PreserveAssemblyUseListOrder("preserve-ll-uselistorder", cl::Hidden, cl::init(false), cl::desc("Preserve use-list order when writing LLVM assembly."))
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 writeDIBasicType(raw_ostream &Out, const DIBasicType *N, AsmWriterContext &WriterCtx)
static StringRef getUnnamedAddrEncoding(GlobalVariable::UnnamedAddr UA)
static const char * getWholeProgDevirtResByArgKindName(WholeProgramDevirtResolution::ByArg::Kind K)
static void writeMDNodeBodyInternal(raw_ostream &Out, const MDNode *Node, AsmWriterContext &Ctx)
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 cl::opt< bool > PrintAddrspaceName("print-addrspace-name", cl::Hidden, cl::init(false), cl::desc("Print address space names"))
static void writeOptimizationInfo(raw_ostream &Out, const User *U)
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 writeDIDerivedType(raw_ostream &Out, const DIDerivedType *N, AsmWriterContext &WriterCtx)
static void printMetadataIdentifier(StringRef Name, formatted_raw_ostream &Out)
static void printShuffleMask(raw_ostream &Out, Type *Ty, ArrayRef< int > Mask)
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 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 void printCallingConv(unsigned cc, raw_ostream &Out)
static void printAddressSpace(const Module *M, unsigned AS, raw_ostream &OS, StringRef Prefix=" ", StringRef Suffix="", bool ForcePrint=false)
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 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 printThreadLocalModel(GlobalVariable::ThreadLocalMode TLM, formatted_raw_ostream &Out)
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 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 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 writeDILexicalBlockFile(raw_ostream &Out, const DILexicalBlockFile *N, AsmWriterContext &WriterCtx)
static void writeConstantInternal(raw_ostream &Out, const Constant *CV, AsmWriterContext &WriterCtx)
static void writeDIEnumerator(raw_ostream &Out, const DIEnumerator *N, AsmWriterContext &)
static void writeAsOperandInternal(raw_ostream &Out, const Value *V, AsmWriterContext &WriterCtx, bool PrintType=false)
static void printVisibility(GlobalValue::VisibilityTypes Vis, formatted_raw_ostream &Out)
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 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 void printDLLStorageClass(GlobalValue::DLLStorageClassTypes SCT, formatted_raw_ostream &Out)
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...
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 const fltSemantics & IEEEsingle()
static const fltSemantics & BFloat()
static const fltSemantics & IEEEquad()
static const fltSemantics & IEEEdouble()
static const fltSemantics & x87DoubleExtended()
static constexpr roundingMode rmNearestTiesToEven
static const fltSemantics & IEEEhalf()
static const fltSemantics & PPCDoubleDouble()
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),...
size_t size() const
size - Get the array size.
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...
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
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)
Wrapper structure that holds a language name and its version.
uint32_t getVersion() const
Returns language version. Only valid for versioned language names.
bool hasVersionedName() const
uint16_t getName() const
Returns a versioned or unversioned language name.
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
Intrinsic::ID getIntrinsicID() const LLVM_READONLY
getIntrinsicID - This method returns the ID number of the specified function, or Intrinsic::not_intri...
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()
unsigned getAddressSpace() const
Return the address space of the Pointer type.
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.
~SlotTracker() override=default
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.
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.
LLVM_ABI unsigned getByteBitWidth() const
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 SourceLanguageNameString(SourceLanguageName Lang)
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.
LLVM_ABI void printImmArg(ID IID, unsigned ArgIdx, raw_ostream &OS, const Constant *ImmArgVal)
Print the argument info for the arguments with ArgInfo.
LLVM_ABI bool hasPrettyPrintedArgs(ID id)
Returns true if the intrinsic has pretty printed immediate arguments.
@ System
Synchronized with respect to all concurrently executing threads.
initializer< Ty > init(const Ty &Val)
@ 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)
detail::zippy< detail::zip_first, T, U, Args... > zip_equal(T &&t, U &&u, Args &&...args)
zip iterator that assumes that all iteratees have the same length.
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...
constexpr auto equal_to(T &&Arg)
Functor variant of std::equal_to that can be used as a UnaryPredicate in functional algorithms like a...
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
ArrayRef(const T &OneElt) -> ArrayRef< T >
std::string toString(const APInt &I, unsigned Radix, bool Signed, bool formatAsCLiteral=false, bool UpperCase=true, bool InsertSeparators=false)
LLVM_ABI Printable printBasicBlock(const BasicBlock *BB)
Print BasicBlock BB as an operand or print "<nullptr>" if BB is a nullptr.
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...
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.
@ Default
The result value is uniform if and only if all operands are uniform.
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 NoRenameOnPromotion
This field is written by the ThinLTO prelink stage to decide whether a particular static global value...
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:...