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())
1542 unsigned NumDigits = std::max((Val.
getBitWidth() + 3) / 4, 1U);
1544 for (
unsigned i = 0; i < NumDigits - Bits.size(); i++)
1550 bool ForceBitwiseOutput =
false;
1556 ForceBitwiseOutput = !HiWord.
isZero();
1559 if (!ForceBitwiseOutput) {
1562 Out << (APF.
isNegative() ?
'-' :
'+') <<
"inf";
1604 AsmWriterContext &WriterCtx) {
1606 Type *Ty = CI->getType();
1608 if (Ty->isVectorTy()) {
1610 WriterCtx.TypePrinter->print(Ty->getScalarType(), Out);
1614 if (Ty->getScalarType()->isIntegerTy(1))
1615 Out << (CI->getZExtValue() ?
"true" :
"false");
1617 Out << CI->getValue();
1619 if (Ty->isVectorTy())
1626 Type *Ty = CB->getType();
1628 if (Ty->isVectorTy()) {
1630 WriterCtx.TypePrinter->print(Ty->getScalarType(), Out);
1634 Out << CB->getValue();
1636 if (Ty->isVectorTy())
1643 Type *Ty = CFP->getType();
1645 if (Ty->isVectorTy()) {
1646 if (CFP->getValue().bitcastToAPInt().isZero()) {
1647 Out <<
"zeroinitializer";
1652 WriterCtx.TypePrinter->print(Ty->getScalarType(), Out);
1658 if (Ty->isVectorTy())
1665 Out <<
"zeroinitializer";
1670 Out <<
"blockaddress(";
1679 Out <<
"dso_local_equivalent ";
1694 unsigned NumOpsToWrite = 2;
1695 if (!CPA->getOperand(2)->isNullValue())
1703 for (
unsigned i = 0, e = NumOpsToWrite; i != e; ++i) {
1715 for (
const Value *
Op : CA->operands()) {
1726 if (CA->isString()) {
1735 for (
uint64_t i = 0, e = CA->getNumElements(); i != e; ++i) {
1745 if (CS->getType()->isPacked())
1748 if (CS->getNumOperands() != 0) {
1751 for (
const Value *
Op : CS->operands()) {
1758 if (CS->getType()->isPacked())
1783 for (
unsigned i = 0, e = CVVTy->getNumElements(); i != e; ++i) {
1827 if (CE->getOpcode() == Instruction::ShuffleVector) {
1828 if (
auto *SplatVal = CE->getSplatValue()) {
1839 Out << CE->getOpcodeName();
1844 WriterCtx.TypePrinter->print(
GEP->getSourceElementType(), Out);
1849 for (
const Value *
Op : CE->operands()) {
1856 WriterCtx.TypePrinter->print(CE->getType(), Out);
1859 if (CE->getOpcode() == Instruction::ShuffleVector)
1866 Out <<
"<placeholder or erroneous Constant>";
1870 AsmWriterContext &WriterCtx) {
1878 Value *V = MDV->getValue();
1882 WriterCtx.onWriteMetadataAsOperand(MD);
1891struct MDFieldPrinter {
1894 AsmWriterContext &WriterCtx;
1896 explicit MDFieldPrinter(raw_ostream &Out)
1897 : Out(Out), WriterCtx(AsmWriterContext::getEmpty()) {}
1898 MDFieldPrinter(raw_ostream &Out, AsmWriterContext &Ctx)
1899 : Out(Out), WriterCtx(Ctx) {}
1901 void printTag(
const DINode *
N);
1902 void printMacinfoType(
const DIMacroNode *
N);
1903 void printChecksum(
const DIFile::ChecksumInfo<StringRef> &
N);
1904 void printString(StringRef Name, StringRef
Value,
1905 bool ShouldSkipEmpty =
true);
1906 void printMetadata(StringRef Name,
const Metadata *MD,
1907 bool ShouldSkipNull =
true);
1908 void printMetadataOrInt(StringRef Name,
const Metadata *MD,
bool IsUnsigned,
1909 bool ShouldSkipZero =
true);
1910 template <
class IntTy>
1911 void printInt(StringRef Name, IntTy
Int,
bool ShouldSkipZero =
true);
1912 void printAPInt(StringRef Name,
const APInt &
Int,
bool IsUnsigned,
1913 bool ShouldSkipZero);
1914 void printBool(StringRef Name,
bool Value,
1915 std::optional<bool>
Default = std::nullopt);
1918 template <
class IntTy,
class Stringifier>
1919 void printDwarfEnum(StringRef Name, IntTy
Value, Stringifier
toString,
1920 bool ShouldSkipZero =
true);
1922 void printNameTableKind(StringRef Name,
1929void MDFieldPrinter::printTag(
const DINode *
N) {
1930 Out <<
FS <<
"tag: ";
1938void MDFieldPrinter::printMacinfoType(
const DIMacroNode *
N) {
1939 Out <<
FS <<
"type: ";
1944 Out <<
N->getMacinfoType();
1947void MDFieldPrinter::printChecksum(
1950 printString(
"checksum", Checksum.
Value,
false);
1954 bool ShouldSkipEmpty) {
1955 if (ShouldSkipEmpty &&
Value.empty())
1958 Out <<
FS <<
Name <<
": \"";
1964 AsmWriterContext &WriterCtx) {
1970 WriterCtx.onWriteMetadataAsOperand(MD);
1974 bool ShouldSkipNull) {
1975 if (ShouldSkipNull && !MD)
1978 Out <<
FS <<
Name <<
": ";
1983 bool IsUnsigned,
bool ShouldSkipZero) {
1990 printInt(Name, CV->getZExtValue(), ShouldSkipZero);
1992 printInt(Name, CV->getSExtValue(), ShouldSkipZero);
1994 printMetadata(Name, MD);
1997template <
class IntTy>
1998void MDFieldPrinter::printInt(
StringRef Name, IntTy
Int,
bool ShouldSkipZero) {
1999 if (ShouldSkipZero && !
Int)
2006 bool IsUnsigned,
bool ShouldSkipZero) {
2007 if (ShouldSkipZero &&
Int.isZero())
2010 Out <<
FS <<
Name <<
": ";
2011 Int.print(Out, !IsUnsigned);
2015 std::optional<bool>
Default) {
2018 Out <<
FS <<
Name <<
": " << (
Value ?
"true" :
"false");
2025 Out <<
FS <<
Name <<
": ";
2031 for (
auto F : SplitFlags) {
2033 assert(!StringF.empty() &&
"Expected valid flag");
2034 Out << FlagsFS << StringF;
2036 if (Extra || SplitFlags.empty())
2037 Out << FlagsFS << Extra;
2040void MDFieldPrinter::printDISPFlags(
StringRef Name,
2044 Out <<
FS <<
Name <<
": ";
2055 for (
auto F : SplitFlags) {
2057 assert(!StringF.empty() &&
"Expected valid flag");
2058 Out << FlagsFS << StringF;
2060 if (Extra || SplitFlags.empty())
2061 Out << FlagsFS << Extra;
2064void MDFieldPrinter::printEmissionKind(
StringRef Name,
2069void MDFieldPrinter::printNameTableKind(
StringRef Name,
2076void MDFieldPrinter::printFixedPointKind(
StringRef Name,
2081template <
class IntTy,
class Stringifier>
2083 Stringifier
toString,
bool ShouldSkipZero) {
2084 if (ShouldSkipZero && !
Value)
2087 Out <<
FS <<
Name <<
": ";
2096 AsmWriterContext &WriterCtx) {
2097 Out <<
"!GenericDINode(";
2098 MDFieldPrinter
Printer(Out, WriterCtx);
2100 Printer.printString(
"header",
N->getHeader());
2101 if (
N->getNumDwarfOperands()) {
2102 Out <<
Printer.FS <<
"operands: {";
2104 for (
auto &
I :
N->dwarf_operands()) {
2114 AsmWriterContext &WriterCtx) {
2115 Out <<
"!DILocation(";
2116 MDFieldPrinter
Printer(Out, WriterCtx);
2118 Printer.printInt(
"line",
DL->getLine(),
false);
2119 Printer.printInt(
"column",
DL->getColumn());
2120 Printer.printMetadata(
"scope",
DL->getRawScope(),
false);
2121 Printer.printMetadata(
"inlinedAt",
DL->getRawInlinedAt());
2122 Printer.printBool(
"isImplicitCode",
DL->isImplicitCode(),
2124 Printer.printInt(
"atomGroup",
DL->getAtomGroup());
2125 Printer.printInt<
unsigned>(
"atomRank",
DL->getAtomRank());
2130 AsmWriterContext &WriterCtx) {
2131 Out <<
"!DIAssignID()";
2132 MDFieldPrinter
Printer(Out, WriterCtx);
2136 AsmWriterContext &WriterCtx) {
2137 Out <<
"!DISubrange(";
2138 MDFieldPrinter
Printer(Out, WriterCtx);
2140 Printer.printMetadataOrInt(
"count",
N->getRawCountNode(),
2146 Printer.printMetadataOrInt(
"lowerBound",
N->getRawLowerBound(),
2149 Printer.printMetadataOrInt(
"upperBound",
N->getRawUpperBound(),
2152 Printer.printMetadataOrInt(
"stride",
N->getRawStride(),
2160 AsmWriterContext &WriterCtx) {
2161 Out <<
"!DIGenericSubrange(";
2162 MDFieldPrinter
Printer(Out, WriterCtx);
2164 auto GetConstant = [&](
Metadata *Bound) -> std::optional<int64_t> {
2167 return std::nullopt;
2168 if (BE->isConstant() &&
2170 *BE->isConstant()) {
2171 return static_cast<int64_t
>(BE->getElement(1));
2173 return std::nullopt;
2176 auto *
Count =
N->getRawCountNode();
2177 if (
auto ConstantCount = GetConstant(
Count))
2178 Printer.printInt(
"count", *ConstantCount,
2183 auto *LBound =
N->getRawLowerBound();
2184 if (
auto ConstantLBound = GetConstant(LBound))
2185 Printer.printInt(
"lowerBound", *ConstantLBound,
2188 Printer.printMetadata(
"lowerBound", LBound,
true);
2190 auto *UBound =
N->getRawUpperBound();
2191 if (
auto ConstantUBound = GetConstant(UBound))
2192 Printer.printInt(
"upperBound", *ConstantUBound,
2195 Printer.printMetadata(
"upperBound", UBound,
true);
2197 auto *Stride =
N->getRawStride();
2198 if (
auto ConstantStride = GetConstant(Stride))
2199 Printer.printInt(
"stride", *ConstantStride,
2202 Printer.printMetadata(
"stride", Stride,
true);
2208 AsmWriterContext &) {
2209 Out <<
"!DIEnumerator(";
2211 Printer.printString(
"name",
N->getName(),
false);
2212 Printer.printAPInt(
"value",
N->getValue(),
N->isUnsigned(),
2214 if (
N->isUnsigned())
2215 Printer.printBool(
"isUnsigned",
true);
2220 AsmWriterContext &WriterCtx) {
2221 Out <<
"!DIBasicType(";
2222 MDFieldPrinter
Printer(Out, WriterCtx);
2223 if (
N->getTag() != dwarf::DW_TAG_base_type)
2225 Printer.printString(
"name",
N->getName());
2226 Printer.printMetadata(
"scope",
N->getRawScope());
2227 Printer.printMetadata(
"file",
N->getRawFile());
2228 Printer.printInt(
"line",
N->getLine());
2229 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2230 Printer.printInt(
"align",
N->getAlignInBits());
2231 Printer.printInt(
"dataSize",
N->getDataSizeInBits());
2232 Printer.printDwarfEnum(
"encoding",
N->getEncoding(),
2234 Printer.printInt(
"num_extra_inhabitants",
N->getNumExtraInhabitants());
2235 Printer.printDIFlags(
"flags",
N->getFlags());
2240 AsmWriterContext &WriterCtx) {
2241 Out <<
"!DIFixedPointType(";
2242 MDFieldPrinter
Printer(Out, WriterCtx);
2243 if (
N->getTag() != dwarf::DW_TAG_base_type)
2245 Printer.printString(
"name",
N->getName());
2246 Printer.printMetadata(
"scope",
N->getRawScope());
2247 Printer.printMetadata(
"file",
N->getRawFile());
2248 Printer.printInt(
"line",
N->getLine());
2249 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2250 Printer.printInt(
"align",
N->getAlignInBits());
2251 Printer.printDwarfEnum(
"encoding",
N->getEncoding(),
2253 Printer.printDIFlags(
"flags",
N->getFlags());
2254 Printer.printFixedPointKind(
"kind",
N->getKind());
2255 if (
N->isRational()) {
2256 bool IsUnsigned = !
N->isSigned();
2257 Printer.printAPInt(
"numerator",
N->getNumerator(), IsUnsigned,
false);
2258 Printer.printAPInt(
"denominator",
N->getDenominator(), IsUnsigned,
false);
2260 Printer.printInt(
"factor",
N->getFactor());
2266 AsmWriterContext &WriterCtx) {
2267 Out <<
"!DIStringType(";
2268 MDFieldPrinter
Printer(Out, WriterCtx);
2269 if (
N->getTag() != dwarf::DW_TAG_string_type)
2271 Printer.printString(
"name",
N->getName());
2272 Printer.printMetadata(
"stringLength",
N->getRawStringLength());
2273 Printer.printMetadata(
"stringLengthExpression",
N->getRawStringLengthExp());
2274 Printer.printMetadata(
"stringLocationExpression",
2275 N->getRawStringLocationExp());
2276 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2277 Printer.printInt(
"align",
N->getAlignInBits());
2278 Printer.printDwarfEnum(
"encoding",
N->getEncoding(),
2284 AsmWriterContext &WriterCtx) {
2285 Out <<
"!DIDerivedType(";
2286 MDFieldPrinter
Printer(Out, WriterCtx);
2288 Printer.printString(
"name",
N->getName());
2289 Printer.printMetadata(
"scope",
N->getRawScope());
2290 Printer.printMetadata(
"file",
N->getRawFile());
2291 Printer.printInt(
"line",
N->getLine());
2292 Printer.printMetadata(
"baseType",
N->getRawBaseType(),
2294 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2295 Printer.printInt(
"align",
N->getAlignInBits());
2296 Printer.printMetadataOrInt(
"offset",
N->getRawOffsetInBits(),
true);
2297 Printer.printDIFlags(
"flags",
N->getFlags());
2298 Printer.printMetadata(
"extraData",
N->getRawExtraData());
2299 if (
const auto &DWARFAddressSpace =
N->getDWARFAddressSpace())
2300 Printer.printInt(
"dwarfAddressSpace", *DWARFAddressSpace,
2302 Printer.printMetadata(
"annotations",
N->getRawAnnotations());
2303 if (
auto PtrAuthData =
N->getPtrAuthData()) {
2304 Printer.printInt(
"ptrAuthKey", PtrAuthData->key());
2305 Printer.printBool(
"ptrAuthIsAddressDiscriminated",
2306 PtrAuthData->isAddressDiscriminated());
2307 Printer.printInt(
"ptrAuthExtraDiscriminator",
2308 PtrAuthData->extraDiscriminator());
2309 Printer.printBool(
"ptrAuthIsaPointer", PtrAuthData->isaPointer());
2310 Printer.printBool(
"ptrAuthAuthenticatesNullValues",
2311 PtrAuthData->authenticatesNullValues());
2317 AsmWriterContext &WriterCtx) {
2318 Out <<
"!DISubrangeType(";
2319 MDFieldPrinter
Printer(Out, WriterCtx);
2320 Printer.printString(
"name",
N->getName());
2321 Printer.printMetadata(
"scope",
N->getRawScope());
2322 Printer.printMetadata(
"file",
N->getRawFile());
2323 Printer.printInt(
"line",
N->getLine());
2324 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2325 Printer.printInt(
"align",
N->getAlignInBits());
2326 Printer.printDIFlags(
"flags",
N->getFlags());
2327 Printer.printMetadata(
"baseType",
N->getRawBaseType(),
2329 Printer.printMetadata(
"lowerBound",
N->getRawLowerBound());
2330 Printer.printMetadata(
"upperBound",
N->getRawUpperBound());
2331 Printer.printMetadata(
"stride",
N->getRawStride());
2332 Printer.printMetadata(
"bias",
N->getRawBias());
2337 AsmWriterContext &WriterCtx) {
2338 Out <<
"!DICompositeType(";
2339 MDFieldPrinter
Printer(Out, WriterCtx);
2341 Printer.printString(
"name",
N->getName());
2342 Printer.printMetadata(
"scope",
N->getRawScope());
2343 Printer.printMetadata(
"file",
N->getRawFile());
2344 Printer.printInt(
"line",
N->getLine());
2345 Printer.printMetadata(
"baseType",
N->getRawBaseType());
2346 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2347 Printer.printInt(
"align",
N->getAlignInBits());
2348 Printer.printMetadataOrInt(
"offset",
N->getRawOffsetInBits(),
true);
2349 Printer.printInt(
"num_extra_inhabitants",
N->getNumExtraInhabitants());
2350 Printer.printDIFlags(
"flags",
N->getFlags());
2351 Printer.printMetadata(
"elements",
N->getRawElements());
2352 Printer.printDwarfEnum(
"runtimeLang",
N->getRuntimeLang(),
2354 Printer.printMetadata(
"vtableHolder",
N->getRawVTableHolder());
2355 Printer.printMetadata(
"templateParams",
N->getRawTemplateParams());
2356 Printer.printString(
"identifier",
N->getIdentifier());
2357 Printer.printMetadata(
"discriminator",
N->getRawDiscriminator());
2358 Printer.printMetadata(
"dataLocation",
N->getRawDataLocation());
2359 Printer.printMetadata(
"associated",
N->getRawAssociated());
2360 Printer.printMetadata(
"allocated",
N->getRawAllocated());
2361 if (
auto *RankConst =
N->getRankConst())
2362 Printer.printInt(
"rank", RankConst->getSExtValue(),
2365 Printer.printMetadata(
"rank",
N->getRawRank(),
true);
2366 Printer.printMetadata(
"annotations",
N->getRawAnnotations());
2367 if (
auto *Specification =
N->getRawSpecification())
2368 Printer.printMetadata(
"specification", Specification);
2370 if (
auto EnumKind =
N->getEnumKind())
2374 Printer.printMetadata(
"bitStride",
N->getRawBitStride());
2379 AsmWriterContext &WriterCtx) {
2380 Out <<
"!DISubroutineType(";
2381 MDFieldPrinter
Printer(Out, WriterCtx);
2382 Printer.printDIFlags(
"flags",
N->getFlags());
2384 Printer.printMetadata(
"types",
N->getRawTypeArray(),
2392 Printer.printString(
"filename",
N->getFilename(),
2394 Printer.printString(
"directory",
N->getDirectory(),
2397 if (
N->getChecksum())
2398 Printer.printChecksum(*
N->getChecksum());
2400 Printer.printString(
"source", *
N->getSource(),
2406 AsmWriterContext &WriterCtx) {
2407 Out <<
"!DICompileUnit(";
2408 MDFieldPrinter
Printer(Out, WriterCtx);
2414 "sourceLanguageName",
2426 Printer.printMetadata(
"file",
N->getRawFile(),
false);
2427 Printer.printString(
"producer",
N->getProducer());
2428 Printer.printBool(
"isOptimized",
N->isOptimized());
2429 Printer.printString(
"flags",
N->getFlags());
2430 Printer.printInt(
"runtimeVersion",
N->getRuntimeVersion(),
2432 Printer.printString(
"splitDebugFilename",
N->getSplitDebugFilename());
2433 Printer.printEmissionKind(
"emissionKind",
N->getEmissionKind());
2434 Printer.printMetadata(
"enums",
N->getRawEnumTypes());
2435 Printer.printMetadata(
"retainedTypes",
N->getRawRetainedTypes());
2436 Printer.printMetadata(
"globals",
N->getRawGlobalVariables());
2437 Printer.printMetadata(
"imports",
N->getRawImportedEntities());
2438 Printer.printMetadata(
"macros",
N->getRawMacros());
2439 Printer.printInt(
"dwoId",
N->getDWOId());
2440 Printer.printBool(
"splitDebugInlining",
N->getSplitDebugInlining(),
true);
2441 Printer.printBool(
"debugInfoForProfiling",
N->getDebugInfoForProfiling(),
2443 Printer.printNameTableKind(
"nameTableKind",
N->getNameTableKind());
2444 Printer.printBool(
"rangesBaseAddress",
N->getRangesBaseAddress(),
false);
2445 Printer.printString(
"sysroot",
N->getSysRoot());
2446 Printer.printString(
"sdk",
N->getSDK());
2453 AsmWriterContext &WriterCtx) {
2454 Out <<
"!DISubprogram(";
2455 MDFieldPrinter
Printer(Out, WriterCtx);
2456 Printer.printString(
"name",
N->getName());
2457 Printer.printString(
"linkageName",
N->getLinkageName());
2458 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2459 Printer.printMetadata(
"file",
N->getRawFile());
2460 Printer.printInt(
"line",
N->getLine());
2461 Printer.printMetadata(
"type",
N->getRawType());
2462 Printer.printInt(
"scopeLine",
N->getScopeLine());
2463 Printer.printMetadata(
"containingType",
N->getRawContainingType());
2464 if (
N->getVirtuality() != dwarf::DW_VIRTUALITY_none ||
2465 N->getVirtualIndex() != 0)
2466 Printer.printInt(
"virtualIndex",
N->getVirtualIndex(),
false);
2467 Printer.printInt(
"thisAdjustment",
N->getThisAdjustment());
2468 Printer.printDIFlags(
"flags",
N->getFlags());
2469 Printer.printDISPFlags(
"spFlags",
N->getSPFlags());
2470 Printer.printMetadata(
"unit",
N->getRawUnit());
2471 Printer.printMetadata(
"templateParams",
N->getRawTemplateParams());
2472 Printer.printMetadata(
"declaration",
N->getRawDeclaration());
2473 Printer.printMetadata(
"retainedNodes",
N->getRawRetainedNodes());
2474 Printer.printMetadata(
"thrownTypes",
N->getRawThrownTypes());
2475 Printer.printMetadata(
"annotations",
N->getRawAnnotations());
2476 Printer.printString(
"targetFuncName",
N->getTargetFuncName());
2477 Printer.printBool(
"keyInstructions",
N->getKeyInstructionsEnabled(),
false);
2482 AsmWriterContext &WriterCtx) {
2483 Out <<
"!DILexicalBlock(";
2484 MDFieldPrinter
Printer(Out, WriterCtx);
2485 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2486 Printer.printMetadata(
"file",
N->getRawFile());
2487 Printer.printInt(
"line",
N->getLine());
2488 Printer.printInt(
"column",
N->getColumn());
2494 AsmWriterContext &WriterCtx) {
2495 Out <<
"!DILexicalBlockFile(";
2496 MDFieldPrinter
Printer(Out, WriterCtx);
2497 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2498 Printer.printMetadata(
"file",
N->getRawFile());
2499 Printer.printInt(
"discriminator",
N->getDiscriminator(),
2505 AsmWriterContext &WriterCtx) {
2506 Out <<
"!DINamespace(";
2507 MDFieldPrinter
Printer(Out, WriterCtx);
2508 Printer.printString(
"name",
N->getName());
2509 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2510 Printer.printBool(
"exportSymbols",
N->getExportSymbols(),
false);
2515 AsmWriterContext &WriterCtx) {
2516 Out <<
"!DICommonBlock(";
2517 MDFieldPrinter
Printer(Out, WriterCtx);
2518 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2519 Printer.printMetadata(
"declaration",
N->getRawDecl(),
false);
2520 Printer.printString(
"name",
N->getName());
2521 Printer.printMetadata(
"file",
N->getRawFile());
2522 Printer.printInt(
"line",
N->getLineNo());
2527 AsmWriterContext &WriterCtx) {
2529 MDFieldPrinter
Printer(Out, WriterCtx);
2531 Printer.printInt(
"line",
N->getLine());
2532 Printer.printString(
"name",
N->getName());
2533 Printer.printString(
"value",
N->getValue());
2538 AsmWriterContext &WriterCtx) {
2539 Out <<
"!DIMacroFile(";
2540 MDFieldPrinter
Printer(Out, WriterCtx);
2541 Printer.printInt(
"line",
N->getLine());
2542 Printer.printMetadata(
"file",
N->getRawFile(),
false);
2543 Printer.printMetadata(
"nodes",
N->getRawElements());
2548 AsmWriterContext &WriterCtx) {
2549 Out <<
"!DIModule(";
2550 MDFieldPrinter
Printer(Out, WriterCtx);
2551 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2552 Printer.printString(
"name",
N->getName());
2553 Printer.printString(
"configMacros",
N->getConfigurationMacros());
2554 Printer.printString(
"includePath",
N->getIncludePath());
2555 Printer.printString(
"apinotes",
N->getAPINotesFile());
2556 Printer.printMetadata(
"file",
N->getRawFile());
2557 Printer.printInt(
"line",
N->getLineNo());
2558 Printer.printBool(
"isDecl",
N->getIsDecl(),
false);
2564 AsmWriterContext &WriterCtx) {
2565 Out <<
"!DITemplateTypeParameter(";
2566 MDFieldPrinter
Printer(Out, WriterCtx);
2567 Printer.printString(
"name",
N->getName());
2568 Printer.printMetadata(
"type",
N->getRawType(),
false);
2569 Printer.printBool(
"defaulted",
N->isDefault(),
false);
2575 AsmWriterContext &WriterCtx) {
2576 Out <<
"!DITemplateValueParameter(";
2577 MDFieldPrinter
Printer(Out, WriterCtx);
2578 if (
N->getTag() != dwarf::DW_TAG_template_value_parameter)
2580 Printer.printString(
"name",
N->getName());
2581 Printer.printMetadata(
"type",
N->getRawType());
2582 Printer.printBool(
"defaulted",
N->isDefault(),
false);
2583 Printer.printMetadata(
"value",
N->getValue(),
false);
2588 AsmWriterContext &WriterCtx) {
2589 Out <<
"!DIGlobalVariable(";
2590 MDFieldPrinter
Printer(Out, WriterCtx);
2591 Printer.printString(
"name",
N->getName());
2592 Printer.printString(
"linkageName",
N->getLinkageName());
2593 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2594 Printer.printMetadata(
"file",
N->getRawFile());
2595 Printer.printInt(
"line",
N->getLine());
2596 Printer.printMetadata(
"type",
N->getRawType());
2597 Printer.printBool(
"isLocal",
N->isLocalToUnit());
2598 Printer.printBool(
"isDefinition",
N->isDefinition());
2599 Printer.printMetadata(
"declaration",
N->getRawStaticDataMemberDeclaration());
2600 Printer.printMetadata(
"templateParams",
N->getRawTemplateParams());
2601 Printer.printInt(
"align",
N->getAlignInBits());
2602 Printer.printMetadata(
"annotations",
N->getRawAnnotations());
2607 AsmWriterContext &WriterCtx) {
2608 Out <<
"!DILocalVariable(";
2609 MDFieldPrinter
Printer(Out, WriterCtx);
2610 Printer.printString(
"name",
N->getName());
2611 Printer.printInt(
"arg",
N->getArg());
2612 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2613 Printer.printMetadata(
"file",
N->getRawFile());
2614 Printer.printInt(
"line",
N->getLine());
2615 Printer.printMetadata(
"type",
N->getRawType());
2616 Printer.printDIFlags(
"flags",
N->getFlags());
2617 Printer.printInt(
"align",
N->getAlignInBits());
2618 Printer.printMetadata(
"annotations",
N->getRawAnnotations());
2623 AsmWriterContext &WriterCtx) {
2625 MDFieldPrinter
Printer(Out, WriterCtx);
2626 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2627 Printer.printString(
"name",
N->getName());
2628 Printer.printMetadata(
"file",
N->getRawFile());
2629 Printer.printInt(
"line",
N->getLine(),
false);
2630 Printer.printInt(
"column",
N->getColumn());
2631 Printer.printBool(
"isArtificial",
N->isArtificial(),
false);
2632 if (
N->getCoroSuspendIdx())
2633 Printer.printInt(
"coroSuspendIdx", *
N->getCoroSuspendIdx(),
2639 AsmWriterContext &WriterCtx) {
2640 Out <<
"!DIExpression(";
2645 assert(!OpStr.empty() &&
"Expected valid opcode");
2649 Out << FS <<
Op.getArg(0);
2652 for (
unsigned A = 0, AE =
Op.getNumArgs();
A != AE; ++
A)
2653 Out << FS <<
Op.getArg(
A);
2657 for (
const auto &
I :
N->getElements())
2664 AsmWriterContext &WriterCtx,
2665 bool FromValue =
false) {
2667 "Unexpected DIArgList metadata outside of value argument");
2668 Out <<
"!DIArgList(";
2670 MDFieldPrinter
Printer(Out, WriterCtx);
2671 for (
const Metadata *Arg :
N->getArgs()) {
2680 AsmWriterContext &WriterCtx) {
2681 Out <<
"!DIGlobalVariableExpression(";
2682 MDFieldPrinter
Printer(Out, WriterCtx);
2683 Printer.printMetadata(
"var",
N->getVariable());
2684 Printer.printMetadata(
"expr",
N->getExpression());
2689 AsmWriterContext &WriterCtx) {
2690 Out <<
"!DIObjCProperty(";
2691 MDFieldPrinter
Printer(Out, WriterCtx);
2692 Printer.printString(
"name",
N->getName());
2693 Printer.printMetadata(
"file",
N->getRawFile());
2694 Printer.printInt(
"line",
N->getLine());
2695 Printer.printString(
"setter",
N->getSetterName());
2696 Printer.printString(
"getter",
N->getGetterName());
2697 Printer.printInt(
"attributes",
N->getAttributes());
2698 Printer.printMetadata(
"type",
N->getRawType());
2703 AsmWriterContext &WriterCtx) {
2704 Out <<
"!DIImportedEntity(";
2705 MDFieldPrinter
Printer(Out, WriterCtx);
2707 Printer.printString(
"name",
N->getName());
2708 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2709 Printer.printMetadata(
"entity",
N->getRawEntity());
2710 Printer.printMetadata(
"file",
N->getRawFile());
2711 Printer.printInt(
"line",
N->getLine());
2712 Printer.printMetadata(
"elements",
N->getRawElements());
2717 AsmWriterContext &Ctx) {
2718 if (
Node->isDistinct())
2720 else if (
Node->isTemporary())
2721 Out <<
"<temporary!> ";
2723 switch (
Node->getMetadataID()) {
2726#define HANDLE_MDNODE_LEAF(CLASS) \
2727 case Metadata::CLASS##Kind: \
2728 write##CLASS(Out, cast<CLASS>(Node), Ctx); \
2730#include "llvm/IR/Metadata.def"
2737 AsmWriterContext &WriterCtx,
2740 WriterCtx.TypePrinter->print(V->getType(), Out);
2751 assert(WriterCtx.TypePrinter &&
"Constants require TypePrinting!");
2758 if (IA->hasSideEffects())
2759 Out <<
"sideeffect ";
2760 if (IA->isAlignStack())
2761 Out <<
"alignstack ";
2764 Out <<
"inteldialect ";
2783 auto *
Machine = WriterCtx.Machine;
2787 Slot =
Machine->getGlobalSlot(GV);
2790 Slot =
Machine->getLocalSlot(V);
2797 Slot =
Machine->getLocalSlot(V);
2804 Slot =
Machine->getGlobalSlot(GV);
2807 Slot =
Machine->getLocalSlot(V);
2816 Out << Prefix << Slot;
2822 AsmWriterContext &WriterCtx,
2836 std::unique_ptr<SlotTracker> MachineStorage;
2838 if (!WriterCtx.Machine) {
2839 MachineStorage = std::make_unique<SlotTracker>(WriterCtx.Context);
2840 WriterCtx.Machine = MachineStorage.get();
2850 Out <<
"<" <<
N <<
">";
2864 assert(WriterCtx.TypePrinter &&
"TypePrinter required for metadata values");
2866 "Unexpected function-local metadata outside of value argument");
2873class AssemblyWriter {
2874 formatted_raw_ostream &Out;
2875 const Module *TheModule =
nullptr;
2876 const ModuleSummaryIndex *TheIndex =
nullptr;
2877 std::unique_ptr<SlotTracker> SlotTrackerStorage;
2879 TypePrinting TypePrinter;
2880 AssemblyAnnotationWriter *AnnotationWriter =
nullptr;
2881 SetVector<const Comdat *> Comdats;
2883 bool ShouldPreserveUseListOrder;
2888 DenseMap<const GlobalValueSummary *, GlobalValue::GUID> SummaryToGUIDMap;
2892 AssemblyWriter(formatted_raw_ostream &o, SlotTracker &Mac,
const Module *M,
2893 AssemblyAnnotationWriter *AAW,
bool IsForDebug,
2894 bool ShouldPreserveUseListOrder =
false);
2896 AssemblyWriter(formatted_raw_ostream &o, SlotTracker &Mac,
2897 const ModuleSummaryIndex *Index,
bool IsForDebug);
2900 return AsmWriterContext(&TypePrinter, &
Machine, TheModule);
2903 void printMDNodeBody(
const MDNode *MD);
2904 void printNamedMDNode(
const NamedMDNode *NMD);
2906 void printModule(
const Module *M);
2908 void writeOperand(
const Value *
Op,
bool PrintType);
2909 void writeParamOperand(
const Value *Operand, AttributeSet Attrs);
2910 void writeOperandBundles(
const CallBase *
Call);
2911 void writeSyncScope(
const LLVMContext &
Context,
2913 void writeAtomic(
const LLVMContext &
Context,
2916 void writeAtomicCmpXchg(
const LLVMContext &
Context,
2921 void writeAllMDNodes();
2922 void writeMDNode(
unsigned Slot,
const MDNode *Node);
2923 void writeAttribute(
const Attribute &Attr,
bool InAttrGroup =
false);
2924 void writeAttributeSet(
const AttributeSet &AttrSet,
bool InAttrGroup =
false);
2925 void writeAllAttributeGroups();
2927 void printTypeIdentities();
2928 void printGlobal(
const GlobalVariable *GV);
2929 void printAlias(
const GlobalAlias *GA);
2930 void printIFunc(
const GlobalIFunc *GI);
2931 void printComdat(
const Comdat *
C);
2932 void printFunction(
const Function *
F);
2933 void printArgument(
const Argument *FA, AttributeSet Attrs);
2935 void printInstructionLine(
const Instruction &
I);
2936 void printInstruction(
const Instruction &
I);
2937 void printDbgMarker(
const DbgMarker &DPI);
2938 void printDbgVariableRecord(
const DbgVariableRecord &DVR);
2939 void printDbgLabelRecord(
const DbgLabelRecord &DLR);
2940 void printDbgRecord(
const DbgRecord &DR);
2941 void printDbgRecordLine(
const DbgRecord &DR);
2943 void printUseListOrder(
const Value *V, ArrayRef<unsigned> Shuffle);
2944 void printUseLists(
const Function *
F);
2946 void printModuleSummaryIndex();
2947 void printSummaryInfo(
unsigned Slot,
const ValueInfo &VI);
2948 void printSummary(
const GlobalValueSummary &Summary);
2949 void printAliasSummary(
const AliasSummary *AS);
2950 void printGlobalVarSummary(
const GlobalVarSummary *GS);
2951 void printFunctionSummary(
const FunctionSummary *FS);
2952 void printTypeIdSummary(
const TypeIdSummary &TIS);
2954 void printTypeTestResolution(
const TypeTestResolution &TTRes);
2955 void printArgs(ArrayRef<uint64_t> Args);
2956 void printWPDRes(
const WholeProgramDevirtResolution &WPDRes);
2957 void printTypeIdInfo(
const FunctionSummary::TypeIdInfo &TIDInfo);
2958 void printVFuncId(
const FunctionSummary::VFuncId VFId);
2966 void printMetadataAttachments(
2967 const SmallVectorImpl<std::pair<unsigned, MDNode *>> &MDs,
2968 StringRef Separator);
2972 void printInfoComment(
const Value &V,
bool isMaterializable =
false);
2976 void printGCRelocateComment(
const GCRelocateInst &Relocate);
2983 bool IsForDebug,
bool ShouldPreserveUseListOrder)
2984 : Out(
o), TheModule(
M),
Machine(Mac), TypePrinter(
M), AnnotationWriter(AAW),
2985 IsForDebug(IsForDebug),
2986 ShouldPreserveUseListOrder(
2989 : ShouldPreserveUseListOrder) {
2992 for (
const GlobalObject &GO : TheModule->global_objects())
2999 : Out(
o), TheIndex(Index),
Machine(Mac), TypePrinter(nullptr),
3000 IsForDebug(IsForDebug),
3003void AssemblyWriter::writeOperand(
const Value *Operand,
bool PrintType) {
3005 Out <<
"<null operand!>";
3012void AssemblyWriter::writeSyncScope(
const LLVMContext &
Context,
3020 Context.getSyncScopeNames(SSNs);
3022 Out <<
" syncscope(\"";
3030void AssemblyWriter::writeAtomic(
const LLVMContext &
Context,
3033 if (Ordering == AtomicOrdering::NotAtomic)
3036 writeSyncScope(
Context, SSID);
3040void AssemblyWriter::writeAtomicCmpXchg(
const LLVMContext &
Context,
3044 assert(SuccessOrdering != AtomicOrdering::NotAtomic &&
3045 FailureOrdering != AtomicOrdering::NotAtomic);
3047 writeSyncScope(
Context, SSID);
3052void AssemblyWriter::writeParamOperand(
const Value *Operand,
3053 AttributeSet Attrs) {
3055 Out <<
"<null operand!>";
3060 TypePrinter.print(Operand->
getType(), Out);
3062 if (
Attrs.hasAttributes()) {
3064 writeAttributeSet(Attrs);
3072void AssemblyWriter::writeOperandBundles(
const CallBase *
Call) {
3088 ListSeparator InnerLS;
3090 for (
const auto &Input : BU.
Inputs) {
3092 if (Input ==
nullptr)
3093 Out <<
"<null operand bundle!>";
3104void AssemblyWriter::printModule(
const Module *M) {
3107 if (ShouldPreserveUseListOrder)
3110 if (!
M->getModuleIdentifier().empty() &&
3113 M->getModuleIdentifier().find(
'\n') == std::string::npos)
3114 Out <<
"; ModuleID = '" <<
M->getModuleIdentifier() <<
"'\n";
3116 if (!
M->getSourceFileName().empty()) {
3117 Out <<
"source_filename = \"";
3122 const std::string &
DL =
M->getDataLayoutStr();
3124 Out <<
"target datalayout = \"" <<
DL <<
"\"\n";
3125 if (!
M->getTargetTriple().empty())
3126 Out <<
"target triple = \"" <<
M->getTargetTriple().str() <<
"\"\n";
3128 if (!
M->getModuleInlineAsm().empty()) {
3132 StringRef
Asm =
M->getModuleInlineAsm();
3135 std::tie(Front, Asm) =
Asm.split(
'\n');
3139 Out <<
"module asm \"";
3142 }
while (!
Asm.empty());
3145 printTypeIdentities();
3148 if (!Comdats.empty())
3150 for (
const Comdat *
C : Comdats) {
3152 if (
C != Comdats.back())
3157 if (!
M->global_empty()) Out <<
'\n';
3158 for (
const GlobalVariable &GV :
M->globals()) {
3159 printGlobal(&GV); Out <<
'\n';
3163 if (!
M->alias_empty()) Out <<
"\n";
3164 for (
const GlobalAlias &GA :
M->aliases())
3168 if (!
M->ifunc_empty()) Out <<
"\n";
3169 for (
const GlobalIFunc &GI :
M->ifuncs())
3173 for (
const Function &
F : *M) {
3179 printUseLists(
nullptr);
3184 writeAllAttributeGroups();
3188 if (!
M->named_metadata_empty()) Out <<
'\n';
3190 for (
const NamedMDNode &Node :
M->named_metadata())
3191 printNamedMDNode(&Node);
3200void AssemblyWriter::printModuleSummaryIndex() {
3202 int NumSlots =
Machine.initializeIndexIfNeeded();
3208 std::vector<std::pair<std::string, ModuleHash>> moduleVec;
3209 std::string RegularLTOModuleName =
3211 moduleVec.resize(TheIndex->modulePaths().size());
3212 for (
auto &[ModPath, ModHash] : TheIndex->modulePaths())
3213 moduleVec[
Machine.getModulePathSlot(ModPath)] = std::make_pair(
3216 ModPath.empty() ? RegularLTOModuleName : std::string(ModPath), ModHash);
3219 for (
auto &ModPair : moduleVec) {
3220 Out <<
"^" << i++ <<
" = module: (";
3223 Out <<
"\", hash: (";
3225 for (
auto Hash : ModPair.second)
3232 for (
auto &GlobalList : *TheIndex) {
3233 auto GUID = GlobalList.first;
3234 for (
auto &Summary : GlobalList.second.getSummaryList())
3239 for (
auto &GlobalList : *TheIndex) {
3240 auto GUID = GlobalList.first;
3241 auto VI = TheIndex->getValueInfo(GlobalList);
3242 printSummaryInfo(
Machine.getGUIDSlot(GUID), VI);
3246 for (
const auto &TID : TheIndex->typeIds()) {
3247 Out <<
"^" <<
Machine.getTypeIdSlot(TID.second.first)
3248 <<
" = typeid: (name: \"" << TID.second.first <<
"\"";
3249 printTypeIdSummary(TID.second.second);
3250 Out <<
") ; guid = " << TID.first <<
"\n";
3254 for (
auto &TId : TheIndex->typeIdCompatibleVtableMap()) {
3256 Out <<
"^" <<
Machine.getTypeIdCompatibleVtableSlot(TId.first)
3257 <<
" = typeidCompatibleVTable: (name: \"" << TId.first <<
"\"";
3258 printTypeIdCompatibleVtableSummary(TId.second);
3259 Out <<
") ; guid = " <<
GUID <<
"\n";
3263 if (TheIndex->getFlags()) {
3264 Out <<
"^" << NumSlots <<
" = flags: " << TheIndex->getFlags() <<
"\n";
3268 Out <<
"^" << NumSlots <<
" = blockcount: " << TheIndex->getBlockCount()
3278 return "singleImpl";
3280 return "branchFunnel";
3291 return "uniformRetVal";
3293 return "uniqueRetVal";
3295 return "virtualConstProp";
3318void AssemblyWriter::printTypeTestResolution(
const TypeTestResolution &TTRes) {
3325 Out <<
", alignLog2: " << TTRes.
AlignLog2;
3327 Out <<
", sizeM1: " << TTRes.
SizeM1;
3330 Out <<
", bitMask: " << (unsigned)TTRes.
BitMask;
3337void AssemblyWriter::printTypeIdSummary(
const TypeIdSummary &TIS) {
3338 Out <<
", summary: (";
3339 printTypeTestResolution(TIS.
TTRes);
3340 if (!TIS.
WPDRes.empty()) {
3341 Out <<
", wpdResolutions: (";
3343 for (
auto &WPDRes : TIS.
WPDRes) {
3345 Out <<
"(offset: " << WPDRes.first <<
", ";
3346 printWPDRes(WPDRes.second);
3354void AssemblyWriter::printTypeIdCompatibleVtableSummary(
3356 Out <<
", summary: (";
3358 for (
auto &
P : TI) {
3360 Out <<
"(offset: " <<
P.AddressPointOffset <<
", ";
3361 Out <<
"^" <<
Machine.getGUIDSlot(
P.VTableVI.getGUID());
3367void AssemblyWriter::printArgs(ArrayRef<uint64_t> Args) {
3371void AssemblyWriter::printWPDRes(
const WholeProgramDevirtResolution &WPDRes) {
3372 Out <<
"wpdRes: (kind: ";
3379 Out <<
", resByArg: (";
3381 for (
auto &ResByArg : WPDRes.
ResByArg) {
3383 printArgs(ResByArg.first);
3384 Out <<
", byArg: (kind: ";
3386 if (ResByArg.second.TheKind ==
3388 ResByArg.second.TheKind ==
3390 Out <<
", info: " << ResByArg.second.Info;
3394 if (ResByArg.second.Byte || ResByArg.second.Bit)
3395 Out <<
", byte: " << ResByArg.second.Byte
3396 <<
", bit: " << ResByArg.second.Bit;
3417void AssemblyWriter::printAliasSummary(
const AliasSummary *AS) {
3418 Out <<
", aliasee: ";
3428void AssemblyWriter::printGlobalVarSummary(
const GlobalVarSummary *GS) {
3429 auto VTableFuncs =
GS->vTableFuncs();
3430 Out <<
", varFlags: (readonly: " <<
GS->VarFlags.MaybeReadOnly <<
", "
3431 <<
"writeonly: " <<
GS->VarFlags.MaybeWriteOnly <<
", "
3432 <<
"constant: " <<
GS->VarFlags.Constant;
3433 if (!VTableFuncs.empty())
3435 <<
"vcall_visibility: " <<
GS->VarFlags.VCallVisibility;
3438 if (!VTableFuncs.empty()) {
3439 Out <<
", vTableFuncs: (";
3441 for (
auto &
P : VTableFuncs) {
3443 Out <<
"(virtFunc: ^" <<
Machine.getGUIDSlot(
P.FuncVI.getGUID())
3444 <<
", offset: " <<
P.VTableOffset;
3462 return "linkonce_odr";
3472 return "extern_weak";
3474 return "available_externally";
3503 return "definition";
3505 return "declaration";
3510void AssemblyWriter::printFunctionSummary(
const FunctionSummary *FS) {
3511 Out <<
", insts: " <<
FS->instCount();
3512 if (
FS->fflags().anyFlagSet())
3513 Out <<
", " <<
FS->fflags();
3515 if (!
FS->calls().empty()) {
3516 Out <<
", calls: (";
3518 for (
auto &
Call :
FS->calls()) {
3520 Out <<
"(callee: ^" <<
Machine.getGUIDSlot(
Call.first.getGUID());
3521 if (
Call.second.getHotness() != CalleeInfo::HotnessType::Unknown)
3525 if (
Call.second.HasTailCall)
3532 if (
const auto *TIdInfo =
FS->getTypeIdInfo())
3533 printTypeIdInfo(*TIdInfo);
3537 auto AllocTypeName = [](uint8_t
Type) ->
const char * {
3539 case (uint8_t)AllocationType::None:
3541 case (uint8_t)AllocationType::NotCold:
3543 case (uint8_t)AllocationType::Cold:
3545 case (uint8_t)AllocationType::Hot:
3551 if (!
FS->allocs().empty()) {
3552 Out <<
", allocs: (";
3554 for (
auto &AI :
FS->allocs()) {
3556 Out <<
"(versions: (";
3558 for (
auto V : AI.Versions) {
3560 Out << AllocTypeName(V);
3562 Out <<
"), memProf: (";
3563 ListSeparator MIBFS;
3564 for (
auto &MIB : AI.MIBs) {
3566 Out <<
"(type: " << AllocTypeName((uint8_t)MIB.AllocType);
3567 Out <<
", stackIds: (";
3568 ListSeparator SIDFS;
3569 for (
auto Id : MIB.StackIdIndices) {
3571 Out << TheIndex->getStackIdAtIndex(Id);
3580 if (!
FS->callsites().empty()) {
3581 Out <<
", callsites: (";
3583 for (
auto &CI :
FS->callsites()) {
3586 Out <<
"(callee: ^" <<
Machine.getGUIDSlot(CI.Callee.getGUID());
3588 Out <<
"(callee: null";
3589 Out <<
", clones: (";
3591 for (
auto V : CI.Clones) {
3595 Out <<
"), stackIds: (";
3596 ListSeparator SIDFS;
3597 for (
auto Id : CI.StackIdIndices) {
3599 Out << TheIndex->getStackIdAtIndex(Id);
3606 auto PrintRange = [&](
const ConstantRange &
Range) {
3610 if (!
FS->paramAccesses().empty()) {
3611 Out <<
", params: (";
3613 for (
auto &PS :
FS->paramAccesses()) {
3615 Out <<
"(param: " << PS.ParamNo;
3616 Out <<
", offset: ";
3618 if (!PS.Calls.empty()) {
3619 Out <<
", calls: (";
3621 for (
auto &
Call : PS.Calls) {
3623 Out <<
"(callee: ^" <<
Machine.getGUIDSlot(
Call.Callee.getGUID());
3624 Out <<
", param: " <<
Call.ParamNo;
3625 Out <<
", offset: ";
3626 PrintRange(
Call.Offsets);
3637void AssemblyWriter::printTypeIdInfo(
3638 const FunctionSummary::TypeIdInfo &TIDInfo) {
3639 Out <<
", typeIdInfo: (";
3640 ListSeparator TIDFS;
3643 Out <<
"typeTests: (";
3646 auto TidIter = TheIndex->typeIds().equal_range(GUID);
3647 if (TidIter.first == TidIter.second) {
3653 for (
const auto &[GUID, TypeIdPair] :
make_range(TidIter)) {
3655 auto Slot =
Machine.getTypeIdSlot(TypeIdPair.first);
3673 "typeTestAssumeConstVCalls");
3678 "typeCheckedLoadConstVCalls");
3683void AssemblyWriter::printVFuncId(
const FunctionSummary::VFuncId VFId) {
3684 auto TidIter = TheIndex->typeIds().equal_range(VFId.
GUID);
3685 if (TidIter.first == TidIter.second) {
3686 Out <<
"vFuncId: (";
3687 Out <<
"guid: " << VFId.
GUID;
3688 Out <<
", offset: " << VFId.
Offset;
3694 for (
const auto &[GUID, TypeIdPair] :
make_range(TidIter)) {
3696 Out <<
"vFuncId: (";
3697 auto Slot =
Machine.getTypeIdSlot(TypeIdPair.first);
3700 Out <<
", offset: " << VFId.
Offset;
3705void AssemblyWriter::printNonConstVCalls(
3707 Out <<
Tag <<
": (";
3709 for (
auto &VFuncId : VCallList) {
3711 printVFuncId(VFuncId);
3716void AssemblyWriter::printConstVCalls(
3718 Out <<
Tag <<
": (";
3720 for (
auto &ConstVCall : VCallList) {
3723 printVFuncId(ConstVCall.VFunc);
3724 if (!ConstVCall.Args.empty()) {
3726 printArgs(ConstVCall.Args);
3733void AssemblyWriter::printSummary(
const GlobalValueSummary &Summary) {
3734 GlobalValueSummary::GVFlags GVFlags =
Summary.flags();
3737 Out <<
"(module: ^" <<
Machine.getModulePathSlot(
Summary.modulePath())
3740 Out <<
", visibility: "
3743 Out <<
", live: " << GVFlags.
Live;
3744 Out <<
", dsoLocal: " << GVFlags.
DSOLocal;
3746 Out <<
", importType: "
3758 auto RefList =
Summary.refs();
3759 if (!RefList.empty()) {
3762 for (
auto &
Ref : RefList) {
3764 if (
Ref.isReadOnly())
3766 else if (
Ref.isWriteOnly())
3767 Out <<
"writeonly ";
3768 Out <<
"^" <<
Machine.getGUIDSlot(
Ref.getGUID());
3776void AssemblyWriter::printSummaryInfo(
unsigned Slot,
const ValueInfo &VI) {
3777 Out <<
"^" <<
Slot <<
" = gv: (";
3778 if (
VI.hasName() && !
VI.name().empty())
3779 Out <<
"name: \"" <<
VI.name() <<
"\"";
3781 Out <<
"guid: " <<
VI.getGUID();
3782 if (!
VI.getSummaryList().empty()) {
3783 Out <<
", summaries: (";
3785 for (
auto &Summary :
VI.getSummaryList()) {
3787 printSummary(*Summary);
3792 if (
VI.hasName() && !
VI.name().empty())
3793 Out <<
" ; guid = " <<
VI.getGUID();
3800 Out <<
"<empty name> ";
3802 unsigned char FirstC =
static_cast<unsigned char>(Name[0]);
3803 if (isalpha(FirstC) || FirstC ==
'-' || FirstC ==
'$' || FirstC ==
'.' ||
3808 for (
unsigned i = 1, e = Name.size(); i != e; ++i) {
3809 unsigned char C = Name[i];
3810 if (isalnum(
C) ||
C ==
'-' ||
C ==
'$' ||
C ==
'.' ||
C ==
'_')
3818void AssemblyWriter::printNamedMDNode(
const NamedMDNode *NMD) {
3853 Out <<
"dso_local ";
3871 Out <<
"thread_local ";
3874 Out <<
"thread_local(localdynamic) ";
3877 Out <<
"thread_local(initialexec) ";
3880 Out <<
"thread_local(localexec) ";
3890 return "local_unnamed_addr";
3892 return "unnamed_addr";
3915void AssemblyWriter::printGlobal(
const GlobalVariable *GV) {
3917 Out <<
"; Materializable\n";
3938 Out << (GV->
isConstant() ?
"constant " :
"global ");
3947 Out <<
", section \"";
3952 Out <<
", partition \"";
3957 Out <<
", code_model \"";
3982 Out <<
", no_sanitize_address";
3984 Out <<
", no_sanitize_hwaddress";
3986 Out <<
", sanitize_memtag";
3988 Out <<
", sanitize_address_dyninit";
3993 Out <<
", align " <<
A->value();
3997 printMetadataAttachments(MDs,
", ");
4000 if (
Attrs.hasAttributes())
4001 Out <<
" #" <<
Machine.getAttributeGroupSlot(Attrs);
4006void AssemblyWriter::printAlias(
const GlobalAlias *GA) {
4008 Out <<
"; Materializable\n";
4028 if (
const Constant *Aliasee = GA->
getAliasee()) {
4031 TypePrinter.print(GA->
getType(), Out);
4032 Out <<
" <<NULL ALIASEE>>";
4036 Out <<
", partition \"";
4045void AssemblyWriter::printIFunc(
const GlobalIFunc *GI) {
4047 Out <<
"; Materializable\n";
4062 if (
const Constant *Resolver = GI->
getResolver()) {
4065 TypePrinter.print(GI->
getType(), Out);
4066 Out <<
" <<NULL RESOLVER>>";
4070 Out <<
", partition \"";
4077 printMetadataAttachments(MDs,
", ");
4084void AssemblyWriter::printComdat(
const Comdat *
C) {
4088void AssemblyWriter::printTypeIdentities() {
4089 if (TypePrinter.empty())
4095 auto &NumberedTypes = TypePrinter.getNumberedTypes();
4096 for (
unsigned I = 0,
E = NumberedTypes.size();
I !=
E; ++
I) {
4097 Out <<
'%' <<
I <<
" = type ";
4101 TypePrinter.printStructBody(NumberedTypes[
I], Out);
4105 auto &NamedTypes = TypePrinter.getNamedTypes();
4106 for (StructType *NamedType : NamedTypes) {
4112 TypePrinter.printStructBody(NamedType, Out);
4118void AssemblyWriter::printFunction(
const Function *
F) {
4119 if (
F->isMaterializable())
4120 Out <<
"; Materializable\n";
4121 else if (AnnotationWriter)
4124 const AttributeList &
Attrs =
F->getAttributes();
4125 if (
Attrs.hasFnAttrs()) {
4126 AttributeSet AS =
Attrs.getFnAttrs();
4127 std::string AttrStr;
4130 if (!Attr.isStringAttribute()) {
4131 if (!AttrStr.empty()) AttrStr +=
' ';
4132 AttrStr += Attr.getAsString();
4136 if (!AttrStr.empty())
4137 Out <<
"; Function Attrs: " << AttrStr <<
'\n';
4141 Out <<
"; Unknown intrinsic\n";
4145 if (
F->isDeclaration()) {
4148 F->getAllMetadata(MDs);
4149 printMetadataAttachments(MDs,
" ");
4160 if (
F->getCallingConv() != CallingConv::C) {
4165 FunctionType *FT =
F->getFunctionType();
4166 if (
Attrs.hasRetAttrs())
4167 Out <<
Attrs.getAsString(AttributeList::ReturnIndex) <<
' ';
4168 TypePrinter.print(
F->getReturnType(), Out);
4175 if (
F->isDeclaration() && !IsForDebug) {
4178 for (
unsigned I = 0,
E = FT->getNumParams();
I !=
E; ++
I) {
4181 TypePrinter.print(FT->getParamType(
I), Out);
4183 AttributeSet ArgAttrs =
Attrs.getParamAttrs(
I);
4186 writeAttributeSet(ArgAttrs);
4192 for (
const Argument &Arg :
F->args()) {
4194 printArgument(&Arg,
Attrs.getParamAttrs(Arg.getArgNo()));
4199 if (FT->isVarArg()) {
4200 if (FT->getNumParams()) Out <<
", ";
4211 bool ForcePrintAddressSpace =
4212 !
Mod ||
Mod->getDataLayout().getProgramAddressSpace() != 0;
4214 "", ForcePrintAddressSpace);
4215 if (
Attrs.hasFnAttrs())
4216 Out <<
" #" <<
Machine.getAttributeGroupSlot(
Attrs.getFnAttrs());
4217 if (
F->hasSection()) {
4218 Out <<
" section \"";
4222 if (
F->hasPartition()) {
4223 Out <<
" partition \"";
4228 if (MaybeAlign
A =
F->getAlign())
4229 Out <<
" align " <<
A->value();
4230 if (MaybeAlign
A =
F->getPreferredAlignment())
4231 Out <<
" prefalign(" <<
A->value() <<
')';
4233 Out <<
" gc \"" <<
F->getGC() <<
'"';
4234 if (
F->hasPrefixData()) {
4236 writeOperand(
F->getPrefixData(),
true);
4238 if (
F->hasPrologueData()) {
4239 Out <<
" prologue ";
4240 writeOperand(
F->getPrologueData(),
true);
4242 if (
F->hasPersonalityFn()) {
4243 Out <<
" personality ";
4244 writeOperand(
F->getPersonalityFn(),
true);
4248 if (
auto *MDProf =
F->getMetadata(LLVMContext::MD_prof)) {
4250 MDProf->print(Out, TheModule,
true);
4254 if (
F->isDeclaration()) {
4258 F->getAllMetadata(MDs);
4259 printMetadataAttachments(MDs,
" ");
4263 for (
const BasicBlock &BB : *
F)
4277void AssemblyWriter::printArgument(
const Argument *Arg, AttributeSet Attrs) {
4279 TypePrinter.print(Arg->
getType(), Out);
4282 if (
Attrs.hasAttributes()) {
4284 writeAttributeSet(Attrs);
4293 assert(Slot != -1 &&
"expect argument in function here");
4294 Out <<
" %" <<
Slot;
4305 }
else if (!IsEntryBlock) {
4307 int Slot =
Machine.getLocalSlot(BB);
4314 if (!IsEntryBlock) {
4319 Out <<
" No predecessors!";
4325 writeOperand(Pred,
false);
4336 for (
const DbgRecord &DR :
I.getDbgRecordRange())
4337 printDbgRecordLine(DR);
4338 printInstructionLine(
I);
4345void AssemblyWriter::printInstructionLine(
const Instruction &
I) {
4346 printInstruction(
I);
4352void AssemblyWriter::printGCRelocateComment(
const GCRelocateInst &Relocate) {
4362void AssemblyWriter::printInfoComment(
const Value &V,
bool isMaterializable) {
4364 printGCRelocateComment(*Relocate);
4366 if (AnnotationWriter && !isMaterializable)
4371 if (
I->getDebugLoc()) {
4373 I->getDebugLoc().print(Out);
4379 if (
auto *MD =
I->getMetadata(LLVMContext::MD_prof)) {
4381 MD->print(Out, TheModule,
true);
4392 if (Operand ==
nullptr) {
4393 Out <<
" <cannot get addrspace!>";
4403 bool ForcePrintAddrSpace =
4404 !
Mod ||
Mod->getDataLayout().getProgramAddressSpace() != 0;
4406 ForcePrintAddrSpace);
4410void AssemblyWriter::printInstruction(
const Instruction &
I) {
4420 }
else if (!
I.getType()->isVoidTy()) {
4422 int SlotNum =
Machine.getLocalSlot(&
I);
4424 Out <<
"<badref> = ";
4426 Out <<
'%' << SlotNum <<
" = ";
4430 if (CI->isMustTailCall())
4432 else if (CI->isTailCall())
4434 else if (CI->isNoTailCall())
4439 Out <<
I.getOpcodeName();
4461 Out <<
' ' << CI->getPredicate();
4465 if (RMWI->isElementwise())
4466 Out <<
" elementwise";
4471 const Value *Operand =
I.getNumOperands() ?
I.getOperand(0) :
nullptr;
4476 writeOperand(BI->getCondition(),
true);
4478 writeOperand(BI->getSuccessor(0),
true);
4480 writeOperand(BI->getSuccessor(1),
true);
4485 writeOperand(
SI.getCondition(),
true);
4487 writeOperand(
SI.getDefaultDest(),
true);
4489 for (
auto Case :
SI.cases()) {
4491 writeOperand(Case.getCaseValue(),
true);
4493 writeOperand(Case.getCaseSuccessor(),
true);
4499 writeOperand(Operand,
true);
4503 for (
unsigned i = 1, e =
I.getNumOperands(); i != e; ++i) {
4505 writeOperand(
I.getOperand(i),
true);
4510 TypePrinter.print(
I.getType(), Out);
4514 for (
const auto &[V,
Block] :
4515 zip_equal(PN->incoming_values(), PN->blocks())) {
4517 writeOperand(V,
false);
4519 writeOperand(
Block,
false);
4524 writeOperand(
I.getOperand(0),
true);
4529 writeOperand(
I.getOperand(0),
true); Out <<
", ";
4530 writeOperand(
I.getOperand(1),
true);
4535 TypePrinter.print(
I.getType(), Out);
4536 if (LPI->isCleanup() || LPI->getNumClauses() != 0)
4539 if (LPI->isCleanup())
4542 for (
unsigned i = 0, e = LPI->getNumClauses(); i != e; ++i) {
4543 if (i != 0 || LPI->isCleanup()) Out <<
"\n";
4544 if (LPI->isCatch(i))
4549 writeOperand(LPI->getClause(i),
true);
4553 writeOperand(CatchSwitch->getParentPad(),
false);
4556 for (
const BasicBlock *PadBB : CatchSwitch->handlers()) {
4558 writeOperand(PadBB,
true);
4561 if (
const BasicBlock *UnwindDest = CatchSwitch->getUnwindDest())
4562 writeOperand(UnwindDest,
true);
4567 writeOperand(FPI->getParentPad(),
false);
4570 for (
const Value *
Op : FPI->arg_operands()) {
4572 writeOperand(
Op,
true);
4579 writeOperand(CRI->getOperand(0),
false);
4582 writeOperand(CRI->getOperand(1),
true);
4585 writeOperand(CRI->getOperand(0),
false);
4588 if (CRI->hasUnwindDest())
4589 writeOperand(CRI->getOperand(1),
true);
4594 if (CI->getCallingConv() != CallingConv::C) {
4599 Operand = CI->getCalledOperand();
4600 FunctionType *FTy = CI->getFunctionType();
4601 Type *RetTy = FTy->getReturnType();
4602 const AttributeList &PAL = CI->getAttributes();
4604 if (PAL.hasRetAttrs())
4605 Out <<
' ' << PAL.getAsString(AttributeList::ReturnIndex);
4614 TypePrinter.print(FTy->isVarArg() ? FTy : RetTy, Out);
4616 writeOperand(Operand,
false);
4618 bool HasPrettyPrintedArgs =
4623 Function *CalledFunc = CI->getCalledFunction();
4624 auto PrintArgComment = [&](
unsigned ArgNo) {
4628 std::string ArgComment;
4629 raw_string_ostream ArgCommentStream(ArgComment);
4632 if (ArgComment.empty())
4634 Out <<
"/* " << ArgComment <<
" */ ";
4636 if (HasPrettyPrintedArgs) {
4637 for (
unsigned ArgNo = 0, NumArgs = CI->arg_size(); ArgNo < NumArgs;
4640 PrintArgComment(ArgNo);
4641 writeParamOperand(CI->getArgOperand(ArgNo), PAL.getParamAttrs(ArgNo));
4644 for (
unsigned ArgNo = 0, NumArgs = CI->arg_size(); ArgNo < NumArgs;
4647 writeParamOperand(CI->getArgOperand(ArgNo), PAL.getParamAttrs(ArgNo));
4652 if (CI->isMustTailCall() && CI->getParent() &&
4653 CI->getParent()->getParent() &&
4654 CI->getParent()->getParent()->isVarArg()) {
4655 if (CI->arg_size() > 0)
4661 if (PAL.hasFnAttrs())
4662 Out <<
" #" <<
Machine.getAttributeGroupSlot(PAL.getFnAttrs());
4664 writeOperandBundles(CI);
4666 Operand =
II->getCalledOperand();
4667 FunctionType *FTy =
II->getFunctionType();
4668 Type *RetTy = FTy->getReturnType();
4669 const AttributeList &PAL =
II->getAttributes();
4672 if (
II->getCallingConv() != CallingConv::C) {
4677 if (PAL.hasRetAttrs())
4678 Out <<
' ' << PAL.getAsString(AttributeList::ReturnIndex);
4688 TypePrinter.print(FTy->isVarArg() ? FTy : RetTy, Out);
4690 writeOperand(Operand,
false);
4693 for (
unsigned op = 0, Eop =
II->arg_size();
op < Eop; ++
op) {
4695 writeParamOperand(
II->getArgOperand(
op), PAL.getParamAttrs(
op));
4699 if (PAL.hasFnAttrs())
4700 Out <<
" #" <<
Machine.getAttributeGroupSlot(PAL.getFnAttrs());
4702 writeOperandBundles(
II);
4705 writeOperand(
II->getNormalDest(),
true);
4707 writeOperand(
II->getUnwindDest(),
true);
4709 Operand = CBI->getCalledOperand();
4710 FunctionType *FTy = CBI->getFunctionType();
4711 Type *RetTy = FTy->getReturnType();
4712 const AttributeList &PAL = CBI->getAttributes();
4715 if (CBI->getCallingConv() != CallingConv::C) {
4720 if (PAL.hasRetAttrs())
4721 Out <<
' ' << PAL.getAsString(AttributeList::ReturnIndex);
4728 TypePrinter.print(FTy->isVarArg() ? FTy : RetTy, Out);
4730 writeOperand(Operand,
false);
4732 ListSeparator ArgLS;
4733 for (
unsigned op = 0, Eop = CBI->arg_size();
op < Eop; ++
op) {
4735 writeParamOperand(CBI->getArgOperand(
op), PAL.getParamAttrs(
op));
4739 if (PAL.hasFnAttrs())
4740 Out <<
" #" <<
Machine.getAttributeGroupSlot(PAL.getFnAttrs());
4742 writeOperandBundles(CBI);
4745 writeOperand(CBI->getDefaultDest(),
true);
4747 ListSeparator DestLS;
4748 for (
const BasicBlock *Dest : CBI->getIndirectDests()) {
4750 writeOperand(Dest,
true);
4755 if (AI->isUsedWithInAlloca())
4757 if (AI->isSwiftError())
4758 Out <<
"swifterror ";
4759 TypePrinter.print(AI->getAllocatedType(), Out);
4765 if (!AI->getArraySize() || AI->isArrayAllocation() ||
4766 !AI->getArraySize()->getType()->isIntegerTy(32)) {
4768 writeOperand(AI->getArraySize(),
true);
4770 if (MaybeAlign
A = AI->getAlign()) {
4771 Out <<
", align " <<
A->value();
4779 writeOperand(Operand,
true);
4782 TypePrinter.print(
I.getType(), Out);
4786 writeOperand(Operand,
true);
4789 TypePrinter.print(
I.getType(), Out);
4790 }
else if (Operand) {
4793 TypePrinter.print(
GEP->getSourceElementType(), Out);
4797 TypePrinter.print(LI->getType(), Out);
4804 bool PrintAllTypes =
false;
4812 PrintAllTypes =
true;
4814 for (
unsigned i = 1,
E =
I.getNumOperands(); i !=
E; ++i) {
4815 Operand =
I.getOperand(i);
4818 if (Operand && Operand->
getType() != TheType) {
4819 PrintAllTypes =
true;
4825 if (!PrintAllTypes) {
4827 TypePrinter.print(TheType, Out);
4832 for (
const Value *
Op :
I.operands()) {
4834 writeOperand(
Op, PrintAllTypes);
4841 writeAtomic(LI->getContext(), LI->getOrdering(), LI->getSyncScopeID());
4842 if (MaybeAlign
A = LI->getAlign())
4843 Out <<
", align " <<
A->value();
4846 writeAtomic(
SI->getContext(),
SI->getOrdering(),
SI->getSyncScopeID());
4847 if (MaybeAlign
A =
SI->getAlign())
4848 Out <<
", align " <<
A->value();
4850 writeAtomicCmpXchg(CXI->getContext(), CXI->getSuccessOrdering(),
4851 CXI->getFailureOrdering(), CXI->getSyncScopeID());
4852 Out <<
", align " << CXI->getAlign().value();
4854 writeAtomic(RMWI->getContext(), RMWI->getOrdering(),
4855 RMWI->getSyncScopeID());
4856 Out <<
", align " << RMWI->getAlign().value();
4858 writeAtomic(FI->getContext(), FI->getOrdering(), FI->getSyncScopeID());
4866 printMetadataAttachments(InstMD,
", ");
4869 printInfoComment(
I);
4872void AssemblyWriter::printDbgMarker(
const DbgMarker &Marker) {
4876 printDbgRecord(DPR);
4880 Out <<
" DbgMarker -> { ";
4885void AssemblyWriter::printDbgRecord(
const DbgRecord &DR) {
4887 printDbgVariableRecord(*DVR);
4889 printDbgLabelRecord(*DLR);
4894void AssemblyWriter::printDbgVariableRecord(
const DbgVariableRecord &DVR) {
4898 case DbgVariableRecord::LocationType::Value:
4901 case DbgVariableRecord::LocationType::Declare:
4904 case DbgVariableRecord::LocationType::DeclareValue:
4905 Out <<
"declare_value";
4907 case DbgVariableRecord::LocationType::Assign:
4912 "Tried to print a DbgVariableRecord with an invalid LocationType!");
4943void AssemblyWriter::printDbgRecordLine(
const DbgRecord &DR) {
4950void AssemblyWriter::printDbgLabelRecord(
const DbgLabelRecord &Label) {
4952 Out <<
"#dbg_label(";
4959void AssemblyWriter::printMetadataAttachments(
4960 const SmallVectorImpl<std::pair<unsigned, MDNode *>> &MDs,
4961 StringRef Separator) {
4965 if (MDNames.empty())
4966 MDs[0].second->getContext().getMDKindNames(MDNames);
4969 for (
const auto &
I : MDs) {
4970 unsigned Kind =
I.first;
4972 if (Kind < MDNames.size()) {
4976 Out <<
"!<unknown kind #" <<
Kind <<
">";
4982void AssemblyWriter::writeMDNode(
unsigned Slot,
const MDNode *Node) {
4983 Out <<
'!' <<
Slot <<
" = ";
4984 printMDNodeBody(Node);
4988void AssemblyWriter::writeAllMDNodes() {
4994 for (
unsigned i = 0, e = Nodes.
size(); i != e; ++i) {
4995 writeMDNode(i, Nodes[i]);
4999void AssemblyWriter::printMDNodeBody(
const MDNode *Node) {
5004void AssemblyWriter::writeAttribute(
const Attribute &Attr,
bool InAttrGroup) {
5010 Out << Attribute::getNameFromAttrKind(Attr.
getKindAsEnum());
5013 TypePrinter.print(Ty, Out);
5018void AssemblyWriter::writeAttributeSet(
const AttributeSet &AttrSet,
5020 ListSeparator
LS(
" ");
5021 for (
const auto &Attr : AttrSet) {
5023 writeAttribute(Attr, InAttrGroup);
5027void AssemblyWriter::writeAllAttributeGroups() {
5028 std::vector<std::pair<AttributeSet, unsigned>> asVec;
5029 asVec.resize(
Machine.as_size());
5032 asVec[
I.second] =
I;
5034 for (
const auto &
I : asVec)
5035 Out <<
"attributes #" <<
I.second <<
" = { "
5036 <<
I.first.getAsString(
true) <<
" }\n";
5039void AssemblyWriter::printUseListOrder(
const Value *V,
5040 ArrayRef<unsigned> Shuffle) {
5044 Out <<
"uselistorder ";
5045 writeOperand(V,
true);
5047 assert(Shuffle.
size() >= 2 &&
"Shuffle too small");
5051void AssemblyWriter::printUseLists(
const Function *
F) {
5052 auto It = UseListOrders.find(
F);
5053 if (It == UseListOrders.end())
5056 Out <<
"\n; uselistorder directives\n";
5057 for (
const auto &Pair : It->second)
5058 printUseListOrder(Pair.first, Pair.second);
5066 bool ShouldPreserveUseListOrder,
bool IsForDebug)
const {
5069 AssemblyWriter W(OS, SlotTable, this->
getParent(), AAW, IsForDebug,
5070 ShouldPreserveUseListOrder);
5071 W.printFunction(
this);
5075 bool ShouldPreserveUseListOrder,
5076 bool IsForDebug)
const {
5079 AssemblyWriter W(OS, SlotTable, this->
getModule(), AAW,
5081 ShouldPreserveUseListOrder);
5082 W.printBasicBlock(
this);
5086 bool ShouldPreserveUseListOrder,
bool IsForDebug)
const {
5089 AssemblyWriter W(OS, SlotTable,
this, AAW, IsForDebug,
5090 ShouldPreserveUseListOrder);
5091 W.printModule(
this);
5097 AssemblyWriter W(OS, SlotTable,
getParent(),
nullptr, IsForDebug);
5098 W.printNamedMDNode(
this);
5102 bool IsForDebug)
const {
5103 std::optional<SlotTracker> LocalST;
5109 SlotTable = &*LocalST;
5113 AssemblyWriter W(OS, *SlotTable,
getParent(),
nullptr, IsForDebug);
5114 W.printNamedMDNode(
this);
5119 ROS <<
" = comdat ";
5126 ROS <<
"exactmatch";
5132 ROS <<
"nodeduplicate";
5144 TP.print(
const_cast<Type*
>(
this), OS);
5153 TP.printStructBody(STy, OS);
5159 if (
Function *
F = CI->getCalledFunction())
5160 if (
F->isIntrinsic())
5161 for (
auto &
Op :
I.operands())
5171 print(ROS, MST, IsForDebug);
5177 print(ROS, MST, IsForDebug);
5181 bool IsForDebug)
const {
5189 AssemblyWriter W(OS, SlotTable,
getModuleFromDPI(
this),
nullptr, IsForDebug);
5190 W.printDbgMarker(*
this);
5196 print(ROS, MST, IsForDebug);
5200 bool IsForDebug)
const {
5206 ?
Marker->getParent()->getParent()
5210 AssemblyWriter W(OS, SlotTable,
getModuleFromDPI(
this),
nullptr, IsForDebug);
5211 W.printDbgVariableRecord(*
this);
5215 bool IsForDebug)
const {
5221 Marker->getParent() ?
Marker->getParent()->getParent() :
nullptr;
5225 AssemblyWriter W(OS, SlotTable,
getModuleFromDPI(
this),
nullptr, IsForDebug);
5226 W.printDbgLabelRecord(*
this);
5230 bool ShouldInitializeAllMetadata =
false;
5234 ShouldInitializeAllMetadata =
true;
5237 print(ROS, MST, IsForDebug);
5241 bool IsForDebug)
const {
5246 auto IncorporateFunction = [&](
const Function *
F) {
5252 IncorporateFunction(
I->getParent() ?
I->getParent()->getParent() :
nullptr);
5254 W.printInstruction(*
I);
5256 IncorporateFunction(BB->getParent());
5257 AssemblyWriter W(OS, SlotTable,
getModuleFromVal(BB),
nullptr, IsForDebug);
5258 W.printBasicBlock(BB);
5260 AssemblyWriter W(OS, SlotTable, GV->
getParent(),
nullptr, IsForDebug);
5274 TypePrinting TypePrinter;
5275 TypePrinter.print(
C->getType(), OS);
5277 AsmWriterContext WriterCtx(&TypePrinter, MST.
getMachine());
5293 AsmWriterContext WriterCtx(
nullptr,
Machine, M);
5302 TypePrinting TypePrinter(MST.
getModule());
5333 AsmWriterContext &WriterCtx) {
5346struct MDTreeAsmWriterContext :
public AsmWriterContext {
5349 using EntryTy = std::pair<unsigned, std::string>;
5353 SmallPtrSet<const Metadata *, 4> Visited;
5355 raw_ostream &MainOS;
5357 MDTreeAsmWriterContext(TypePrinting *TP, SlotTracker *ST,
const Module *M,
5358 raw_ostream &OS,
const Metadata *InitMD)
5359 : AsmWriterContext(TP,
ST,
M),
Level(0
U), Visited({InitMD}), MainOS(OS) {}
5361 void onWriteMetadataAsOperand(
const Metadata *MD)
override {
5362 if (!Visited.
insert(MD).second)
5366 raw_string_ostream
SS(Str);
5371 unsigned InsertIdx = Buffer.
size() - 1;
5374 Buffer[InsertIdx].second = std::move(
SS.str());
5378 ~MDTreeAsmWriterContext()
override {
5379 for (
const auto &Entry : Buffer) {
5381 unsigned NumIndent =
Entry.first * 2U;
5390 bool OnlyAsOperand,
bool PrintAsTree =
false) {
5393 TypePrinting TypePrinter(M);
5395 std::unique_ptr<AsmWriterContext> WriterCtx;
5396 if (PrintAsTree && !OnlyAsOperand)
5397 WriterCtx = std::make_unique<MDTreeAsmWriterContext>(
5401 std::make_unique<AsmWriterContext>(&TypePrinter, MST.
getMachine(), M);
5430 const Module *M,
bool )
const {
5449 AssemblyWriter W(OS, SlotTable,
this, IsForDebug);
5450 W.printModuleSummaryIndex();
5454 unsigned UB)
const {
5460 if (
I.second >= LB &&
I.second < UB)
5461 L.push_back(std::make_pair(
I.second,
I.first));
5464#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 WriteFullHexAPInt(raw_ostream &Out, const APInt &Val)
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 & PPCDoubleDouble()
void toString(SmallVectorImpl< char > &Str, unsigned FormatPrecision=0, unsigned FormatMaxPadding=3, bool TruncateZero=true) const
const fltSemantics & getSemantics() const
APInt bitcastToAPInt() const
APInt getNaNPayload() const
If the value is a NaN value, return an integer containing the payload of this value.
Class for arbitrary precision integers.
void clearBit(unsigned BitPosition)
Set a given bit to 0.
unsigned getActiveBits() const
Compute the number of active bits in the value.
LLVM_ABI APInt trunc(unsigned width) const
Truncate to new width.
void toStringUnsigned(SmallVectorImpl< char > &Str, unsigned Radix=10) const
Considers the APInt to be unsigned and converts it into a string in the radix given.
bool isZero() const
Determine if this value is zero, i.e. all bits are clear.
bool isSignMask() const
Check if the APInt's value is returned by getSignMask.
unsigned getBitWidth() const
Return the number of bits in the APInt.
APInt lshr(unsigned shiftAmt) const
Logical right-shift function.
Abstract interface of slot tracker storage.
virtual ~AbstractSlotTrackerStorage()
const GlobalValueSummary & getAliasee() const
This class represents an incoming formal argument to a Function.
Represent a constant reference to an array (0 or more elements consecutively in memory),...
size_t size() const
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
static LLVM_ABI ConstantPointerNull * get(PointerType *T)
Static factory methods - Return objects of the specified value.
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 source language identity metadata that includes language name,...
uint32_t getVersion() const
Returns language version. Only valid for versioned language names.
uint16_t getDialect() const
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
LLVM_ABI 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",...
Represent a constant reference to a string, i.e.
constexpr bool empty() const
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 LanguageDialectString(unsigned LanguageDialect)
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).
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...
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:...