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;
672 case Type::IntegerTyID:
673 OS << 'i' << cast<IntegerType>(Ty)->getBitWidth();
676 case Type::FunctionTyID: {
678 print(FTy->getReturnType(), OS);
681 for (
Type *Ty : FTy->params()) {
690 case Type::StructTyID: {
694 return printStructBody(STy, OS);
700 const auto I = Type2Number.find(STy);
701 if (
I != Type2Number.end())
702 OS <<
'%' <<
I->second;
704 OS <<
"%\"type " << STy <<
'\"';
707 case Type::PointerTyID: {
713 case Type::ArrayTyID: {
715 OS <<
'[' << ATy->getNumElements() <<
" x ";
716 print(ATy->getElementType(), OS);
720 case Type::FixedVectorTyID:
721 case Type::ScalableVectorTyID: {
723 ElementCount
EC = PTy->getElementCount();
727 OS <<
EC.getKnownMinValue() <<
" x ";
728 print(PTy->getElementType(), OS);
732 case Type::TypedPointerTyID: {
738 case Type::TargetExtTyID:
745 Inner->print(OS,
false,
true);
748 OS <<
", " << IntParam;
755void TypePrinting::printStructBody(StructType *STy, raw_ostream &OS) {
797 const Function* TheFunction =
nullptr;
798 bool FunctionProcessed =
false;
799 bool ShouldInitializeAllMetadata;
804 ProcessFunctionHookFn;
819 unsigned mdnNext = 0;
827 unsigned ModulePathNext = 0;
831 unsigned GUIDNext = 0;
835 unsigned TypeIdNext = 0;
840 unsigned TypeIdCompatibleVtableNext = 0;
849 bool ShouldInitializeAllMetadata =
false);
857 bool ShouldInitializeAllMetadata =
false);
874 void createMetadataSlot(
const MDNode *
N)
override;
878 int getLocalSlot(
const Value *V);
880 int getMetadataSlot(
const MDNode *
N)
override;
885 int getTypeIdCompatibleVtableSlot(
StringRef Id);
891 FunctionProcessed =
false;
899 void purgeFunction();
906 unsigned mdn_size()
const {
return mdnMap.size(); }
914 unsigned as_size()
const {
return asMap.size(); }
930 void CreateMetadataSlot(
const MDNode *
N);
933 void CreateFunctionSlot(
const Value *V);
938 inline void CreateModulePathSlot(
StringRef Path);
941 void CreateTypeIdCompatibleVtableSlot(
StringRef Id);
945 void processModule();
953 void processGlobalObjectMetadata(
const GlobalObject &GO);
956 void processFunctionMetadata(
const Function &
F);
962 void processDbgRecordMetadata(
const DbgRecord &DVR);
967 : M(M), F(F), Machine(&Machine) {}
970 bool ShouldInitializeAllMetadata)
971 : ShouldCreateStorage(M),
972 ShouldInitializeAllMetadata(ShouldInitializeAllMetadata), M(M) {}
977 if (!ShouldCreateStorage)
980 ShouldCreateStorage =
false;
982 std::make_unique<SlotTracker>(M, ShouldInitializeAllMetadata);
983 Machine = MachineStorage.get();
984 if (ProcessModuleHookFn)
985 Machine->setProcessHook(ProcessModuleHookFn);
986 if (ProcessFunctionHookFn)
987 Machine->setProcessHook(ProcessFunctionHookFn);
1000 Machine->purgeFunction();
1001 Machine->incorporateFunction(&F);
1006 assert(F &&
"No function incorporated");
1007 return Machine->getLocalSlot(V);
1013 ProcessModuleHookFn = std::move(Fn);
1019 ProcessFunctionHookFn = std::move(Fn);
1049#define ST_DEBUG(X) dbgs() << X
1057 : TheModule(M), ShouldInitializeAllMetadata(ShouldInitializeAllMetadata) {}
1062 : TheModule(
F ?
F->
getParent() : nullptr), TheFunction(
F),
1063 ShouldInitializeAllMetadata(ShouldInitializeAllMetadata) {}
1066 : TheModule(nullptr), ShouldInitializeAllMetadata(
false), TheIndex(Index) {}
1071 TheModule =
nullptr;
1074 if (TheFunction && !FunctionProcessed)
1081 int NumSlots = processIndex();
1088void SlotTracker::processModule() {
1089 ST_DEBUG(
"begin processModule!\n");
1094 CreateModuleSlot(&Var);
1095 processGlobalObjectMetadata(Var);
1096 auto Attrs = Var.getAttributes();
1097 if (Attrs.hasAttributes())
1098 CreateAttributeSetSlot(Attrs);
1103 CreateModuleSlot(&
A);
1106 for (
const GlobalIFunc &
I : TheModule->ifuncs()) {
1108 CreateModuleSlot(&
I);
1109 processGlobalObjectMetadata(
I);
1113 for (
const NamedMDNode &NMD : TheModule->named_metadata()) {
1114 for (
const MDNode *
N : NMD.operands())
1115 CreateMetadataSlot(
N);
1118 for (
const Function &
F : *TheModule) {
1121 CreateModuleSlot(&
F);
1123 if (ShouldInitializeAllMetadata)
1124 processFunctionMetadata(
F);
1128 AttributeSet FnAttrs =
F.getAttributes().getFnAttrs();
1130 CreateAttributeSetSlot(FnAttrs);
1133 if (ProcessModuleHookFn)
1134 ProcessModuleHookFn(
this, TheModule, ShouldInitializeAllMetadata);
1140void SlotTracker::processFunction() {
1141 ST_DEBUG(
"begin processFunction!\n");
1145 if (!ShouldInitializeAllMetadata)
1146 processFunctionMetadata(*TheFunction);
1150 AE = TheFunction->arg_end(); AI != AE; ++AI)
1152 CreateFunctionSlot(&*AI);
1154 ST_DEBUG(
"Inserting Instructions:\n");
1157 for (
auto &BB : *TheFunction) {
1159 CreateFunctionSlot(&BB);
1161 for (
auto &
I : BB) {
1162 if (!
I.getType()->isVoidTy() && !
I.hasName())
1163 CreateFunctionSlot(&
I);
1170 if (
Attrs.hasAttributes())
1171 CreateAttributeSetSlot(Attrs);
1176 if (ProcessFunctionHookFn)
1177 ProcessFunctionHookFn(
this, TheFunction, ShouldInitializeAllMetadata);
1179 FunctionProcessed =
true;
1181 ST_DEBUG(
"end processFunction!\n");
1185int SlotTracker::processIndex() {
1192 std::vector<StringRef> ModulePaths;
1193 for (
auto &[ModPath,
_] : TheIndex->modulePaths())
1194 ModulePaths.push_back(ModPath);
1196 for (
auto &ModPath : ModulePaths)
1197 CreateModulePathSlot(ModPath);
1200 GUIDNext = ModulePathNext;
1202 for (
auto &GlobalList : *TheIndex)
1203 CreateGUIDSlot(GlobalList.first);
1206 TypeIdCompatibleVtableNext = GUIDNext;
1207 for (
auto &TId : TheIndex->typeIdCompatibleVtableMap())
1208 CreateTypeIdCompatibleVtableSlot(TId.first);
1211 TypeIdNext = TypeIdCompatibleVtableNext;
1212 for (
const auto &TID : TheIndex->typeIds())
1213 CreateTypeIdSlot(TID.second.first);
1219void SlotTracker::processGlobalObjectMetadata(
const GlobalObject &GO) {
1222 for (
auto &MD : MDs)
1223 CreateMetadataSlot(MD.second);
1226void SlotTracker::processFunctionMetadata(
const Function &
F) {
1227 processGlobalObjectMetadata(
F);
1228 for (
auto &BB :
F) {
1229 for (
auto &
I : BB) {
1230 for (
const DbgRecord &DR :
I.getDbgRecordRange())
1231 processDbgRecordMetadata(DR);
1232 processInstructionMetadata(
I);
1237void SlotTracker::processDbgRecordMetadata(
const DbgRecord &DR) {
1248 CreateMetadataSlot(
Empty);
1249 if (DVR->getRawVariable())
1250 CreateMetadataSlot(DVR->getRawVariable());
1251 if (DVR->isDbgAssign()) {
1252 if (
auto *AssignID = DVR->getRawAssignID())
1255 CreateMetadataSlot(
Empty);
1258 CreateMetadataSlot(DLR->getRawLabel());
1266void SlotTracker::processInstructionMetadata(
const Instruction &
I) {
1269 if (Function *
F = CI->getCalledFunction())
1270 if (
F->isIntrinsic())
1271 for (
auto &
Op :
I.operands())
1274 CreateMetadataSlot(
N);
1278 I.getAllMetadata(MDs);
1279 for (
auto &MD : MDs)
1280 CreateMetadataSlot(MD.second);
1287 ST_DEBUG(
"begin purgeFunction!\n");
1289 TheFunction =
nullptr;
1290 FunctionProcessed =
false;
1301 return MI == mMap.end() ? -1 : (int)
MI->second;
1307 ProcessModuleHookFn = std::move(Fn);
1313 ProcessFunctionHookFn = std::move(Fn);
1326 return MI == mdnMap.end() ? -1 : (int)
MI->second;
1337 return FI == fMap.end() ? -1 : (int)FI->second;
1346 return AI == asMap.end() ? -1 : (int)AI->second;
1354 auto I = ModulePathMap.find(Path);
1355 return I == ModulePathMap.end() ? -1 : (int)
I->second;
1364 return I == GUIDMap.end() ? -1 : (int)
I->second;
1372 auto I = TypeIdMap.find(Id);
1373 return I == TypeIdMap.end() ? -1 : (int)
I->second;
1381 auto I = TypeIdCompatibleVtableMap.find(Id);
1382 return I == TypeIdCompatibleVtableMap.end() ? -1 : (int)
I->second;
1386void SlotTracker::CreateModuleSlot(
const GlobalValue *V) {
1387 assert(V &&
"Can't insert a null Value into SlotTracker!");
1388 assert(!V->getType()->isVoidTy() &&
"Doesn't need a slot!");
1389 assert(!V->hasName() &&
"Doesn't need a slot!");
1391 unsigned DestSlot = mNext++;
1394 ST_DEBUG(
" Inserting value [" << V->getType() <<
"] = " << V <<
" slot=" <<
1404void SlotTracker::CreateFunctionSlot(
const Value *V) {
1405 assert(!V->getType()->isVoidTy() && !V->hasName() &&
"Doesn't need a slot!");
1407 unsigned DestSlot = fNext++;
1411 ST_DEBUG(
" Inserting value [" << V->getType() <<
"] = " << V <<
" slot=" <<
1412 DestSlot <<
" [o]\n");
1416void SlotTracker::CreateMetadataSlot(
const MDNode *
N) {
1417 assert(
N &&
"Can't insert a null Value into SlotTracker!");
1423 unsigned DestSlot = mdnNext;
1424 if (!mdnMap.insert(std::make_pair(
N, DestSlot)).second)
1429 for (
unsigned i = 0, e =
N->getNumOperands(); i != e; ++i)
1431 CreateMetadataSlot(
Op);
1434void SlotTracker::CreateAttributeSetSlot(
AttributeSet AS) {
1437 if (asMap.try_emplace(AS, asNext).second)
1442void SlotTracker::CreateModulePathSlot(
StringRef Path) {
1443 ModulePathMap[
Path] = ModulePathNext++;
1448 GUIDMap[
GUID] = GUIDNext++;
1452void SlotTracker::CreateTypeIdSlot(
StringRef Id) {
1453 TypeIdMap[
Id] = TypeIdNext++;
1457void SlotTracker::CreateTypeIdCompatibleVtableSlot(
StringRef Id) {
1458 TypeIdCompatibleVtableMap[
Id] = TypeIdCompatibleVtableNext++;
1463struct AsmWriterContext {
1464 TypePrinting *TypePrinter =
nullptr;
1465 SlotTracker *
Machine =
nullptr;
1468 AsmWriterContext(TypePrinting *TP, SlotTracker *ST,
const Module *M =
nullptr)
1471 static AsmWriterContext &getEmpty() {
1472 static AsmWriterContext EmptyCtx(
nullptr,
nullptr);
1478 virtual void onWriteMetadataAsOperand(
const Metadata *) {}
1480 virtual ~AsmWriterContext() =
default;
1489 AsmWriterContext &WriterCtx,
1490 bool PrintType =
false);
1493 AsmWriterContext &WriterCtx,
1494 bool FromValue =
false);
1498 Out << FPO->getFastMathFlags();
1501 if (OBO->hasNoUnsignedWrap())
1503 if (OBO->hasNoSignedWrap())
1509 if (PDI->isDisjoint())
1512 if (
GEP->isInBounds())
1514 else if (
GEP->hasNoUnsignedSignedWrap())
1516 if (
GEP->hasNoUnsignedWrap())
1519 Out <<
" inrange(" <<
InRange->getLower() <<
", " <<
InRange->getUpper()
1523 if (NNI->hasNonNeg())
1526 if (TI->hasNoUnsignedWrap())
1528 if (TI->hasNoSignedWrap())
1531 if (ICmp->hasSameSign())
1547 bool isNaN = APF.
isNaN();
1549 if (!isInf && !isNaN) {
1558 ((StrVal[0] ==
'-' || StrVal[0] ==
'+') &&
isDigit(StrVal[1]))) &&
1559 "[-+]?[0-9] regex does not match!");
1571 static_assert(
sizeof(double) ==
sizeof(
uint64_t),
1572 "assuming that double is 64 bits!");
1630 AsmWriterContext &WriterCtx) {
1632 Type *Ty = CI->getType();
1634 if (Ty->isVectorTy()) {
1636 WriterCtx.TypePrinter->print(Ty->getScalarType(), Out);
1640 if (Ty->getScalarType()->isIntegerTy(1))
1641 Out << (CI->getZExtValue() ?
"true" :
"false");
1643 Out << CI->getValue();
1645 if (Ty->isVectorTy())
1652 Type *Ty = CFP->getType();
1654 if (Ty->isVectorTy()) {
1656 WriterCtx.TypePrinter->print(Ty->getScalarType(), Out);
1662 if (Ty->isVectorTy())
1669 Out <<
"zeroinitializer";
1674 Out <<
"blockaddress(";
1683 Out <<
"dso_local_equivalent ";
1698 unsigned NumOpsToWrite = 2;
1699 if (!CPA->getOperand(2)->isNullValue())
1701 if (!CPA->getOperand(3)->isNullValue())
1703 if (!CPA->getOperand(4)->isNullValue())
1707 for (
unsigned i = 0, e = NumOpsToWrite; i != e; ++i) {
1719 for (
const Value *
Op : CA->operands()) {
1730 if (CA->isString()) {
1739 for (
uint64_t i = 0, e = CA->getNumElements(); i != e; ++i) {
1749 if (CS->getType()->isPacked())
1752 if (CS->getNumOperands() != 0) {
1755 for (
const Value *
Op : CS->operands()) {
1762 if (CS->getType()->isPacked())
1786 for (
unsigned i = 0, e = CVVTy->getNumElements(); i != e; ++i) {
1821 if (CE->getOpcode() == Instruction::ShuffleVector) {
1822 if (
auto *SplatVal = CE->getSplatValue()) {
1832 Out << CE->getOpcodeName();
1837 WriterCtx.TypePrinter->print(
GEP->getSourceElementType(), Out);
1842 for (
const Value *
Op : CE->operands()) {
1849 WriterCtx.TypePrinter->print(CE->getType(), Out);
1852 if (CE->getOpcode() == Instruction::ShuffleVector)
1859 Out <<
"<placeholder or erroneous Constant>";
1863 AsmWriterContext &WriterCtx) {
1871 Value *V = MDV->getValue();
1875 WriterCtx.onWriteMetadataAsOperand(MD);
1884struct MDFieldPrinter {
1887 AsmWriterContext &WriterCtx;
1889 explicit MDFieldPrinter(raw_ostream &Out)
1890 : Out(Out), WriterCtx(AsmWriterContext::getEmpty()) {}
1891 MDFieldPrinter(raw_ostream &Out, AsmWriterContext &Ctx)
1892 : Out(Out), WriterCtx(Ctx) {}
1894 void printTag(
const DINode *
N);
1895 void printMacinfoType(
const DIMacroNode *
N);
1896 void printChecksum(
const DIFile::ChecksumInfo<StringRef> &
N);
1897 void printString(StringRef Name, StringRef
Value,
1898 bool ShouldSkipEmpty =
true);
1899 void printMetadata(StringRef Name,
const Metadata *MD,
1900 bool ShouldSkipNull =
true);
1901 void printMetadataOrInt(StringRef Name,
const Metadata *MD,
bool IsUnsigned,
1902 bool ShouldSkipZero =
true);
1903 template <
class IntTy>
1904 void printInt(StringRef Name, IntTy
Int,
bool ShouldSkipZero =
true);
1905 void printAPInt(StringRef Name,
const APInt &
Int,
bool IsUnsigned,
1906 bool ShouldSkipZero);
1907 void printBool(StringRef Name,
bool Value,
1908 std::optional<bool>
Default = std::nullopt);
1911 template <
class IntTy,
class Stringifier>
1912 void printDwarfEnum(StringRef Name, IntTy
Value, Stringifier
toString,
1913 bool ShouldSkipZero =
true);
1915 void printNameTableKind(StringRef Name,
1922void MDFieldPrinter::printTag(
const DINode *
N) {
1923 Out <<
FS <<
"tag: ";
1931void MDFieldPrinter::printMacinfoType(
const DIMacroNode *
N) {
1932 Out <<
FS <<
"type: ";
1937 Out <<
N->getMacinfoType();
1940void MDFieldPrinter::printChecksum(
1943 printString(
"checksum", Checksum.
Value,
false);
1947 bool ShouldSkipEmpty) {
1948 if (ShouldSkipEmpty &&
Value.empty())
1951 Out <<
FS <<
Name <<
": \"";
1957 AsmWriterContext &WriterCtx) {
1963 WriterCtx.onWriteMetadataAsOperand(MD);
1967 bool ShouldSkipNull) {
1968 if (ShouldSkipNull && !MD)
1971 Out <<
FS <<
Name <<
": ";
1976 bool IsUnsigned,
bool ShouldSkipZero) {
1983 printInt(Name, CV->getZExtValue(), ShouldSkipZero);
1985 printInt(Name, CV->getSExtValue(), ShouldSkipZero);
1987 printMetadata(Name, MD);
1990template <
class IntTy>
1991void MDFieldPrinter::printInt(
StringRef Name, IntTy
Int,
bool ShouldSkipZero) {
1992 if (ShouldSkipZero && !
Int)
1999 bool IsUnsigned,
bool ShouldSkipZero) {
2000 if (ShouldSkipZero &&
Int.isZero())
2003 Out <<
FS <<
Name <<
": ";
2004 Int.print(Out, !IsUnsigned);
2008 std::optional<bool>
Default) {
2011 Out <<
FS <<
Name <<
": " << (
Value ?
"true" :
"false");
2018 Out <<
FS <<
Name <<
": ";
2024 for (
auto F : SplitFlags) {
2026 assert(!StringF.empty() &&
"Expected valid flag");
2027 Out << FlagsFS << StringF;
2029 if (Extra || SplitFlags.empty())
2030 Out << FlagsFS << Extra;
2033void MDFieldPrinter::printDISPFlags(
StringRef Name,
2037 Out <<
FS <<
Name <<
": ";
2048 for (
auto F : SplitFlags) {
2050 assert(!StringF.empty() &&
"Expected valid flag");
2051 Out << FlagsFS << StringF;
2053 if (Extra || SplitFlags.empty())
2054 Out << FlagsFS << Extra;
2057void MDFieldPrinter::printEmissionKind(
StringRef Name,
2062void MDFieldPrinter::printNameTableKind(
StringRef Name,
2069void MDFieldPrinter::printFixedPointKind(
StringRef Name,
2074template <
class IntTy,
class Stringifier>
2076 Stringifier
toString,
bool ShouldSkipZero) {
2077 if (ShouldSkipZero && !
Value)
2080 Out <<
FS <<
Name <<
": ";
2089 AsmWriterContext &WriterCtx) {
2090 Out <<
"!GenericDINode(";
2091 MDFieldPrinter
Printer(Out, WriterCtx);
2093 Printer.printString(
"header",
N->getHeader());
2094 if (
N->getNumDwarfOperands()) {
2095 Out <<
Printer.FS <<
"operands: {";
2097 for (
auto &
I :
N->dwarf_operands()) {
2107 AsmWriterContext &WriterCtx) {
2108 Out <<
"!DILocation(";
2109 MDFieldPrinter
Printer(Out, WriterCtx);
2111 Printer.printInt(
"line",
DL->getLine(),
false);
2112 Printer.printInt(
"column",
DL->getColumn());
2113 Printer.printMetadata(
"scope",
DL->getRawScope(),
false);
2114 Printer.printMetadata(
"inlinedAt",
DL->getRawInlinedAt());
2115 Printer.printBool(
"isImplicitCode",
DL->isImplicitCode(),
2117 Printer.printInt(
"atomGroup",
DL->getAtomGroup());
2118 Printer.printInt<
unsigned>(
"atomRank",
DL->getAtomRank());
2123 AsmWriterContext &WriterCtx) {
2124 Out <<
"!DIAssignID()";
2125 MDFieldPrinter
Printer(Out, WriterCtx);
2129 AsmWriterContext &WriterCtx) {
2130 Out <<
"!DISubrange(";
2131 MDFieldPrinter
Printer(Out, WriterCtx);
2133 Printer.printMetadataOrInt(
"count",
N->getRawCountNode(),
2139 Printer.printMetadataOrInt(
"lowerBound",
N->getRawLowerBound(),
2142 Printer.printMetadataOrInt(
"upperBound",
N->getRawUpperBound(),
2145 Printer.printMetadataOrInt(
"stride",
N->getRawStride(),
2153 AsmWriterContext &WriterCtx) {
2154 Out <<
"!DIGenericSubrange(";
2155 MDFieldPrinter
Printer(Out, WriterCtx);
2157 auto GetConstant = [&](
Metadata *Bound) -> std::optional<int64_t> {
2160 return std::nullopt;
2161 if (BE->isConstant() &&
2163 *BE->isConstant()) {
2164 return static_cast<int64_t
>(BE->getElement(1));
2166 return std::nullopt;
2169 auto *
Count =
N->getRawCountNode();
2170 if (
auto ConstantCount = GetConstant(
Count))
2171 Printer.printInt(
"count", *ConstantCount,
2176 auto *LBound =
N->getRawLowerBound();
2177 if (
auto ConstantLBound = GetConstant(LBound))
2178 Printer.printInt(
"lowerBound", *ConstantLBound,
2181 Printer.printMetadata(
"lowerBound", LBound,
true);
2183 auto *UBound =
N->getRawUpperBound();
2184 if (
auto ConstantUBound = GetConstant(UBound))
2185 Printer.printInt(
"upperBound", *ConstantUBound,
2188 Printer.printMetadata(
"upperBound", UBound,
true);
2190 auto *Stride =
N->getRawStride();
2191 if (
auto ConstantStride = GetConstant(Stride))
2192 Printer.printInt(
"stride", *ConstantStride,
2195 Printer.printMetadata(
"stride", Stride,
true);
2201 AsmWriterContext &) {
2202 Out <<
"!DIEnumerator(";
2204 Printer.printString(
"name",
N->getName(),
false);
2205 Printer.printAPInt(
"value",
N->getValue(),
N->isUnsigned(),
2207 if (
N->isUnsigned())
2208 Printer.printBool(
"isUnsigned",
true);
2213 AsmWriterContext &WriterCtx) {
2214 Out <<
"!DIBasicType(";
2215 MDFieldPrinter
Printer(Out, WriterCtx);
2216 if (
N->getTag() != dwarf::DW_TAG_base_type)
2218 Printer.printString(
"name",
N->getName());
2219 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2220 Printer.printInt(
"align",
N->getAlignInBits());
2221 Printer.printInt(
"dataSize",
N->getDataSizeInBits());
2222 Printer.printDwarfEnum(
"encoding",
N->getEncoding(),
2224 Printer.printInt(
"num_extra_inhabitants",
N->getNumExtraInhabitants());
2225 Printer.printDIFlags(
"flags",
N->getFlags());
2230 AsmWriterContext &WriterCtx) {
2231 Out <<
"!DIFixedPointType(";
2232 MDFieldPrinter
Printer(Out, WriterCtx);
2233 if (
N->getTag() != dwarf::DW_TAG_base_type)
2235 Printer.printString(
"name",
N->getName());
2236 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2237 Printer.printInt(
"align",
N->getAlignInBits());
2238 Printer.printDwarfEnum(
"encoding",
N->getEncoding(),
2240 Printer.printDIFlags(
"flags",
N->getFlags());
2241 Printer.printFixedPointKind(
"kind",
N->getKind());
2242 if (
N->isRational()) {
2243 bool IsUnsigned = !
N->isSigned();
2244 Printer.printAPInt(
"numerator",
N->getNumerator(), IsUnsigned,
false);
2245 Printer.printAPInt(
"denominator",
N->getDenominator(), IsUnsigned,
false);
2247 Printer.printInt(
"factor",
N->getFactor());
2253 AsmWriterContext &WriterCtx) {
2254 Out <<
"!DIStringType(";
2255 MDFieldPrinter
Printer(Out, WriterCtx);
2256 if (
N->getTag() != dwarf::DW_TAG_string_type)
2258 Printer.printString(
"name",
N->getName());
2259 Printer.printMetadata(
"stringLength",
N->getRawStringLength());
2260 Printer.printMetadata(
"stringLengthExpression",
N->getRawStringLengthExp());
2261 Printer.printMetadata(
"stringLocationExpression",
2262 N->getRawStringLocationExp());
2263 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2264 Printer.printInt(
"align",
N->getAlignInBits());
2265 Printer.printDwarfEnum(
"encoding",
N->getEncoding(),
2271 AsmWriterContext &WriterCtx) {
2272 Out <<
"!DIDerivedType(";
2273 MDFieldPrinter
Printer(Out, WriterCtx);
2275 Printer.printString(
"name",
N->getName());
2276 Printer.printMetadata(
"scope",
N->getRawScope());
2277 Printer.printMetadata(
"file",
N->getRawFile());
2278 Printer.printInt(
"line",
N->getLine());
2279 Printer.printMetadata(
"baseType",
N->getRawBaseType(),
2281 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2282 Printer.printInt(
"align",
N->getAlignInBits());
2283 Printer.printMetadataOrInt(
"offset",
N->getRawOffsetInBits(),
true);
2284 Printer.printDIFlags(
"flags",
N->getFlags());
2285 Printer.printMetadata(
"extraData",
N->getRawExtraData());
2286 if (
const auto &DWARFAddressSpace =
N->getDWARFAddressSpace())
2287 Printer.printInt(
"dwarfAddressSpace", *DWARFAddressSpace,
2289 Printer.printMetadata(
"annotations",
N->getRawAnnotations());
2290 if (
auto PtrAuthData =
N->getPtrAuthData()) {
2291 Printer.printInt(
"ptrAuthKey", PtrAuthData->key());
2292 Printer.printBool(
"ptrAuthIsAddressDiscriminated",
2293 PtrAuthData->isAddressDiscriminated());
2294 Printer.printInt(
"ptrAuthExtraDiscriminator",
2295 PtrAuthData->extraDiscriminator());
2296 Printer.printBool(
"ptrAuthIsaPointer", PtrAuthData->isaPointer());
2297 Printer.printBool(
"ptrAuthAuthenticatesNullValues",
2298 PtrAuthData->authenticatesNullValues());
2304 AsmWriterContext &WriterCtx) {
2305 Out <<
"!DISubrangeType(";
2306 MDFieldPrinter
Printer(Out, WriterCtx);
2307 Printer.printString(
"name",
N->getName());
2308 Printer.printMetadata(
"scope",
N->getRawScope());
2309 Printer.printMetadata(
"file",
N->getRawFile());
2310 Printer.printInt(
"line",
N->getLine());
2311 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2312 Printer.printInt(
"align",
N->getAlignInBits());
2313 Printer.printDIFlags(
"flags",
N->getFlags());
2314 Printer.printMetadata(
"baseType",
N->getRawBaseType(),
2316 Printer.printMetadata(
"lowerBound",
N->getRawLowerBound());
2317 Printer.printMetadata(
"upperBound",
N->getRawUpperBound());
2318 Printer.printMetadata(
"stride",
N->getRawStride());
2319 Printer.printMetadata(
"bias",
N->getRawBias());
2324 AsmWriterContext &WriterCtx) {
2325 Out <<
"!DICompositeType(";
2326 MDFieldPrinter
Printer(Out, WriterCtx);
2328 Printer.printString(
"name",
N->getName());
2329 Printer.printMetadata(
"scope",
N->getRawScope());
2330 Printer.printMetadata(
"file",
N->getRawFile());
2331 Printer.printInt(
"line",
N->getLine());
2332 Printer.printMetadata(
"baseType",
N->getRawBaseType());
2333 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2334 Printer.printInt(
"align",
N->getAlignInBits());
2335 Printer.printMetadataOrInt(
"offset",
N->getRawOffsetInBits(),
true);
2336 Printer.printInt(
"num_extra_inhabitants",
N->getNumExtraInhabitants());
2337 Printer.printDIFlags(
"flags",
N->getFlags());
2338 Printer.printMetadata(
"elements",
N->getRawElements());
2339 Printer.printDwarfEnum(
"runtimeLang",
N->getRuntimeLang(),
2341 Printer.printMetadata(
"vtableHolder",
N->getRawVTableHolder());
2342 Printer.printMetadata(
"templateParams",
N->getRawTemplateParams());
2343 Printer.printString(
"identifier",
N->getIdentifier());
2344 Printer.printMetadata(
"discriminator",
N->getRawDiscriminator());
2345 Printer.printMetadata(
"dataLocation",
N->getRawDataLocation());
2346 Printer.printMetadata(
"associated",
N->getRawAssociated());
2347 Printer.printMetadata(
"allocated",
N->getRawAllocated());
2348 if (
auto *RankConst =
N->getRankConst())
2349 Printer.printInt(
"rank", RankConst->getSExtValue(),
2352 Printer.printMetadata(
"rank",
N->getRawRank(),
true);
2353 Printer.printMetadata(
"annotations",
N->getRawAnnotations());
2354 if (
auto *Specification =
N->getRawSpecification())
2355 Printer.printMetadata(
"specification", Specification);
2357 if (
auto EnumKind =
N->getEnumKind())
2361 Printer.printMetadata(
"bitStride",
N->getRawBitStride());
2366 AsmWriterContext &WriterCtx) {
2367 Out <<
"!DISubroutineType(";
2368 MDFieldPrinter
Printer(Out, WriterCtx);
2369 Printer.printDIFlags(
"flags",
N->getFlags());
2371 Printer.printMetadata(
"types",
N->getRawTypeArray(),
2379 Printer.printString(
"filename",
N->getFilename(),
2381 Printer.printString(
"directory",
N->getDirectory(),
2384 if (
N->getChecksum())
2385 Printer.printChecksum(*
N->getChecksum());
2387 Printer.printString(
"source", *
N->getSource(),
2393 AsmWriterContext &WriterCtx) {
2394 Out <<
"!DICompileUnit(";
2395 MDFieldPrinter
Printer(Out, WriterCtx);
2401 "sourceLanguageName",
2413 Printer.printMetadata(
"file",
N->getRawFile(),
false);
2414 Printer.printString(
"producer",
N->getProducer());
2415 Printer.printBool(
"isOptimized",
N->isOptimized());
2416 Printer.printString(
"flags",
N->getFlags());
2417 Printer.printInt(
"runtimeVersion",
N->getRuntimeVersion(),
2419 Printer.printString(
"splitDebugFilename",
N->getSplitDebugFilename());
2420 Printer.printEmissionKind(
"emissionKind",
N->getEmissionKind());
2421 Printer.printMetadata(
"enums",
N->getRawEnumTypes());
2422 Printer.printMetadata(
"retainedTypes",
N->getRawRetainedTypes());
2423 Printer.printMetadata(
"globals",
N->getRawGlobalVariables());
2424 Printer.printMetadata(
"imports",
N->getRawImportedEntities());
2425 Printer.printMetadata(
"macros",
N->getRawMacros());
2426 Printer.printInt(
"dwoId",
N->getDWOId());
2427 Printer.printBool(
"splitDebugInlining",
N->getSplitDebugInlining(),
true);
2428 Printer.printBool(
"debugInfoForProfiling",
N->getDebugInfoForProfiling(),
2430 Printer.printNameTableKind(
"nameTableKind",
N->getNameTableKind());
2431 Printer.printBool(
"rangesBaseAddress",
N->getRangesBaseAddress(),
false);
2432 Printer.printString(
"sysroot",
N->getSysRoot());
2433 Printer.printString(
"sdk",
N->getSDK());
2438 AsmWriterContext &WriterCtx) {
2439 Out <<
"!DISubprogram(";
2440 MDFieldPrinter
Printer(Out, WriterCtx);
2441 Printer.printString(
"name",
N->getName());
2442 Printer.printString(
"linkageName",
N->getLinkageName());
2443 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2444 Printer.printMetadata(
"file",
N->getRawFile());
2445 Printer.printInt(
"line",
N->getLine());
2446 Printer.printMetadata(
"type",
N->getRawType());
2447 Printer.printInt(
"scopeLine",
N->getScopeLine());
2448 Printer.printMetadata(
"containingType",
N->getRawContainingType());
2449 if (
N->getVirtuality() != dwarf::DW_VIRTUALITY_none ||
2450 N->getVirtualIndex() != 0)
2451 Printer.printInt(
"virtualIndex",
N->getVirtualIndex(),
false);
2452 Printer.printInt(
"thisAdjustment",
N->getThisAdjustment());
2453 Printer.printDIFlags(
"flags",
N->getFlags());
2454 Printer.printDISPFlags(
"spFlags",
N->getSPFlags());
2455 Printer.printMetadata(
"unit",
N->getRawUnit());
2456 Printer.printMetadata(
"templateParams",
N->getRawTemplateParams());
2457 Printer.printMetadata(
"declaration",
N->getRawDeclaration());
2458 Printer.printMetadata(
"retainedNodes",
N->getRawRetainedNodes());
2459 Printer.printMetadata(
"thrownTypes",
N->getRawThrownTypes());
2460 Printer.printMetadata(
"annotations",
N->getRawAnnotations());
2461 Printer.printString(
"targetFuncName",
N->getTargetFuncName());
2462 Printer.printBool(
"keyInstructions",
N->getKeyInstructionsEnabled(),
false);
2467 AsmWriterContext &WriterCtx) {
2468 Out <<
"!DILexicalBlock(";
2469 MDFieldPrinter
Printer(Out, WriterCtx);
2470 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2471 Printer.printMetadata(
"file",
N->getRawFile());
2472 Printer.printInt(
"line",
N->getLine());
2473 Printer.printInt(
"column",
N->getColumn());
2479 AsmWriterContext &WriterCtx) {
2480 Out <<
"!DILexicalBlockFile(";
2481 MDFieldPrinter
Printer(Out, WriterCtx);
2482 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2483 Printer.printMetadata(
"file",
N->getRawFile());
2484 Printer.printInt(
"discriminator",
N->getDiscriminator(),
2490 AsmWriterContext &WriterCtx) {
2491 Out <<
"!DINamespace(";
2492 MDFieldPrinter
Printer(Out, WriterCtx);
2493 Printer.printString(
"name",
N->getName());
2494 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2495 Printer.printBool(
"exportSymbols",
N->getExportSymbols(),
false);
2500 AsmWriterContext &WriterCtx) {
2501 Out <<
"!DICommonBlock(";
2502 MDFieldPrinter
Printer(Out, WriterCtx);
2503 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2504 Printer.printMetadata(
"declaration",
N->getRawDecl(),
false);
2505 Printer.printString(
"name",
N->getName());
2506 Printer.printMetadata(
"file",
N->getRawFile());
2507 Printer.printInt(
"line",
N->getLineNo());
2512 AsmWriterContext &WriterCtx) {
2514 MDFieldPrinter
Printer(Out, WriterCtx);
2516 Printer.printInt(
"line",
N->getLine());
2517 Printer.printString(
"name",
N->getName());
2518 Printer.printString(
"value",
N->getValue());
2523 AsmWriterContext &WriterCtx) {
2524 Out <<
"!DIMacroFile(";
2525 MDFieldPrinter
Printer(Out, WriterCtx);
2526 Printer.printInt(
"line",
N->getLine());
2527 Printer.printMetadata(
"file",
N->getRawFile(),
false);
2528 Printer.printMetadata(
"nodes",
N->getRawElements());
2533 AsmWriterContext &WriterCtx) {
2534 Out <<
"!DIModule(";
2535 MDFieldPrinter
Printer(Out, WriterCtx);
2536 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2537 Printer.printString(
"name",
N->getName());
2538 Printer.printString(
"configMacros",
N->getConfigurationMacros());
2539 Printer.printString(
"includePath",
N->getIncludePath());
2540 Printer.printString(
"apinotes",
N->getAPINotesFile());
2541 Printer.printMetadata(
"file",
N->getRawFile());
2542 Printer.printInt(
"line",
N->getLineNo());
2543 Printer.printBool(
"isDecl",
N->getIsDecl(),
false);
2549 AsmWriterContext &WriterCtx) {
2550 Out <<
"!DITemplateTypeParameter(";
2551 MDFieldPrinter
Printer(Out, WriterCtx);
2552 Printer.printString(
"name",
N->getName());
2553 Printer.printMetadata(
"type",
N->getRawType(),
false);
2554 Printer.printBool(
"defaulted",
N->isDefault(),
false);
2560 AsmWriterContext &WriterCtx) {
2561 Out <<
"!DITemplateValueParameter(";
2562 MDFieldPrinter
Printer(Out, WriterCtx);
2563 if (
N->getTag() != dwarf::DW_TAG_template_value_parameter)
2565 Printer.printString(
"name",
N->getName());
2566 Printer.printMetadata(
"type",
N->getRawType());
2567 Printer.printBool(
"defaulted",
N->isDefault(),
false);
2568 Printer.printMetadata(
"value",
N->getValue(),
false);
2573 AsmWriterContext &WriterCtx) {
2574 Out <<
"!DIGlobalVariable(";
2575 MDFieldPrinter
Printer(Out, WriterCtx);
2576 Printer.printString(
"name",
N->getName());
2577 Printer.printString(
"linkageName",
N->getLinkageName());
2578 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2579 Printer.printMetadata(
"file",
N->getRawFile());
2580 Printer.printInt(
"line",
N->getLine());
2581 Printer.printMetadata(
"type",
N->getRawType());
2582 Printer.printBool(
"isLocal",
N->isLocalToUnit());
2583 Printer.printBool(
"isDefinition",
N->isDefinition());
2584 Printer.printMetadata(
"declaration",
N->getRawStaticDataMemberDeclaration());
2585 Printer.printMetadata(
"templateParams",
N->getRawTemplateParams());
2586 Printer.printInt(
"align",
N->getAlignInBits());
2587 Printer.printMetadata(
"annotations",
N->getRawAnnotations());
2592 AsmWriterContext &WriterCtx) {
2593 Out <<
"!DILocalVariable(";
2594 MDFieldPrinter
Printer(Out, WriterCtx);
2595 Printer.printString(
"name",
N->getName());
2596 Printer.printInt(
"arg",
N->getArg());
2597 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2598 Printer.printMetadata(
"file",
N->getRawFile());
2599 Printer.printInt(
"line",
N->getLine());
2600 Printer.printMetadata(
"type",
N->getRawType());
2601 Printer.printDIFlags(
"flags",
N->getFlags());
2602 Printer.printInt(
"align",
N->getAlignInBits());
2603 Printer.printMetadata(
"annotations",
N->getRawAnnotations());
2608 AsmWriterContext &WriterCtx) {
2610 MDFieldPrinter
Printer(Out, WriterCtx);
2611 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2612 Printer.printString(
"name",
N->getName());
2613 Printer.printMetadata(
"file",
N->getRawFile());
2614 Printer.printInt(
"line",
N->getLine());
2615 Printer.printInt(
"column",
N->getColumn());
2616 Printer.printBool(
"isArtificial",
N->isArtificial(),
false);
2617 if (
N->getCoroSuspendIdx())
2618 Printer.printInt(
"coroSuspendIdx", *
N->getCoroSuspendIdx(),
2624 AsmWriterContext &WriterCtx) {
2625 Out <<
"!DIExpression(";
2630 assert(!OpStr.empty() &&
"Expected valid opcode");
2634 Out << FS <<
Op.getArg(0);
2637 for (
unsigned A = 0, AE =
Op.getNumArgs();
A != AE; ++
A)
2638 Out << FS <<
Op.getArg(
A);
2642 for (
const auto &
I :
N->getElements())
2649 AsmWriterContext &WriterCtx,
2650 bool FromValue =
false) {
2652 "Unexpected DIArgList metadata outside of value argument");
2653 Out <<
"!DIArgList(";
2655 MDFieldPrinter
Printer(Out, WriterCtx);
2656 for (
const Metadata *Arg :
N->getArgs()) {
2665 AsmWriterContext &WriterCtx) {
2666 Out <<
"!DIGlobalVariableExpression(";
2667 MDFieldPrinter
Printer(Out, WriterCtx);
2668 Printer.printMetadata(
"var",
N->getVariable());
2669 Printer.printMetadata(
"expr",
N->getExpression());
2674 AsmWriterContext &WriterCtx) {
2675 Out <<
"!DIObjCProperty(";
2676 MDFieldPrinter
Printer(Out, WriterCtx);
2677 Printer.printString(
"name",
N->getName());
2678 Printer.printMetadata(
"file",
N->getRawFile());
2679 Printer.printInt(
"line",
N->getLine());
2680 Printer.printString(
"setter",
N->getSetterName());
2681 Printer.printString(
"getter",
N->getGetterName());
2682 Printer.printInt(
"attributes",
N->getAttributes());
2683 Printer.printMetadata(
"type",
N->getRawType());
2688 AsmWriterContext &WriterCtx) {
2689 Out <<
"!DIImportedEntity(";
2690 MDFieldPrinter
Printer(Out, WriterCtx);
2692 Printer.printString(
"name",
N->getName());
2693 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2694 Printer.printMetadata(
"entity",
N->getRawEntity());
2695 Printer.printMetadata(
"file",
N->getRawFile());
2696 Printer.printInt(
"line",
N->getLine());
2697 Printer.printMetadata(
"elements",
N->getRawElements());
2702 AsmWriterContext &Ctx) {
2703 if (
Node->isDistinct())
2705 else if (
Node->isTemporary())
2706 Out <<
"<temporary!> ";
2708 switch (
Node->getMetadataID()) {
2711#define HANDLE_MDNODE_LEAF(CLASS) \
2712 case Metadata::CLASS##Kind: \
2713 write##CLASS(Out, cast<CLASS>(Node), Ctx); \
2715#include "llvm/IR/Metadata.def"
2722 AsmWriterContext &WriterCtx,
2725 WriterCtx.TypePrinter->print(V->getType(), Out);
2736 assert(WriterCtx.TypePrinter &&
"Constants require TypePrinting!");
2743 if (IA->hasSideEffects())
2744 Out <<
"sideeffect ";
2745 if (IA->isAlignStack())
2746 Out <<
"alignstack ";
2749 Out <<
"inteldialect ";
2768 auto *
Machine = WriterCtx.Machine;
2772 Slot =
Machine->getGlobalSlot(GV);
2775 Slot =
Machine->getLocalSlot(V);
2782 Slot =
Machine->getLocalSlot(V);
2789 Slot =
Machine->getGlobalSlot(GV);
2792 Slot =
Machine->getLocalSlot(V);
2801 Out << Prefix << Slot;
2807 AsmWriterContext &WriterCtx,
2821 std::unique_ptr<SlotTracker> MachineStorage;
2823 if (!WriterCtx.Machine) {
2824 MachineStorage = std::make_unique<SlotTracker>(WriterCtx.Context);
2825 WriterCtx.Machine = MachineStorage.get();
2835 Out <<
"<" <<
N <<
">";
2849 assert(WriterCtx.TypePrinter &&
"TypePrinter required for metadata values");
2851 "Unexpected function-local metadata outside of value argument");
2858class AssemblyWriter {
2859 formatted_raw_ostream &Out;
2860 const Module *TheModule =
nullptr;
2861 const ModuleSummaryIndex *TheIndex =
nullptr;
2862 std::unique_ptr<SlotTracker> SlotTrackerStorage;
2864 TypePrinting TypePrinter;
2865 AssemblyAnnotationWriter *AnnotationWriter =
nullptr;
2866 SetVector<const Comdat *> Comdats;
2868 bool ShouldPreserveUseListOrder;
2873 DenseMap<const GlobalValueSummary *, GlobalValue::GUID> SummaryToGUIDMap;
2877 AssemblyWriter(formatted_raw_ostream &o, SlotTracker &Mac,
const Module *M,
2878 AssemblyAnnotationWriter *AAW,
bool IsForDebug,
2879 bool ShouldPreserveUseListOrder =
false);
2881 AssemblyWriter(formatted_raw_ostream &o, SlotTracker &Mac,
2882 const ModuleSummaryIndex *Index,
bool IsForDebug);
2885 return AsmWriterContext(&TypePrinter, &
Machine, TheModule);
2888 void printMDNodeBody(
const MDNode *MD);
2889 void printNamedMDNode(
const NamedMDNode *NMD);
2891 void printModule(
const Module *M);
2893 void writeOperand(
const Value *
Op,
bool PrintType);
2894 void writeParamOperand(
const Value *Operand, AttributeSet Attrs);
2895 void writeOperandBundles(
const CallBase *
Call);
2896 void writeSyncScope(
const LLVMContext &
Context,
2898 void writeAtomic(
const LLVMContext &
Context,
2901 void writeAtomicCmpXchg(
const LLVMContext &
Context,
2906 void writeAllMDNodes();
2907 void writeMDNode(
unsigned Slot,
const MDNode *Node);
2908 void writeAttribute(
const Attribute &Attr,
bool InAttrGroup =
false);
2909 void writeAttributeSet(
const AttributeSet &AttrSet,
bool InAttrGroup =
false);
2910 void writeAllAttributeGroups();
2912 void printTypeIdentities();
2913 void printGlobal(
const GlobalVariable *GV);
2914 void printAlias(
const GlobalAlias *GA);
2915 void printIFunc(
const GlobalIFunc *GI);
2916 void printComdat(
const Comdat *
C);
2917 void printFunction(
const Function *
F);
2918 void printArgument(
const Argument *FA, AttributeSet Attrs);
2920 void printInstructionLine(
const Instruction &
I);
2921 void printInstruction(
const Instruction &
I);
2922 void printDbgMarker(
const DbgMarker &DPI);
2923 void printDbgVariableRecord(
const DbgVariableRecord &DVR);
2924 void printDbgLabelRecord(
const DbgLabelRecord &DLR);
2925 void printDbgRecord(
const DbgRecord &DR);
2926 void printDbgRecordLine(
const DbgRecord &DR);
2928 void printUseListOrder(
const Value *V, ArrayRef<unsigned> Shuffle);
2929 void printUseLists(
const Function *
F);
2931 void printModuleSummaryIndex();
2932 void printSummaryInfo(
unsigned Slot,
const ValueInfo &VI);
2933 void printSummary(
const GlobalValueSummary &Summary);
2934 void printAliasSummary(
const AliasSummary *AS);
2935 void printGlobalVarSummary(
const GlobalVarSummary *GS);
2936 void printFunctionSummary(
const FunctionSummary *FS);
2937 void printTypeIdSummary(
const TypeIdSummary &TIS);
2939 void printTypeTestResolution(
const TypeTestResolution &TTRes);
2940 void printArgs(ArrayRef<uint64_t> Args);
2941 void printWPDRes(
const WholeProgramDevirtResolution &WPDRes);
2942 void printTypeIdInfo(
const FunctionSummary::TypeIdInfo &TIDInfo);
2943 void printVFuncId(
const FunctionSummary::VFuncId VFId);
2951 void printMetadataAttachments(
2952 const SmallVectorImpl<std::pair<unsigned, MDNode *>> &MDs,
2953 StringRef Separator);
2957 void printInfoComment(
const Value &V,
bool isMaterializable =
false);
2961 void printGCRelocateComment(
const GCRelocateInst &Relocate);
2968 bool IsForDebug,
bool ShouldPreserveUseListOrder)
2969 : Out(
o), TheModule(
M),
Machine(Mac), TypePrinter(
M), AnnotationWriter(AAW),
2970 IsForDebug(IsForDebug),
2971 ShouldPreserveUseListOrder(
2974 : ShouldPreserveUseListOrder) {
2977 for (
const GlobalObject &GO : TheModule->global_objects())
2984 : Out(
o), TheIndex(Index),
Machine(Mac), TypePrinter(nullptr),
2985 IsForDebug(IsForDebug),
2988void AssemblyWriter::writeOperand(
const Value *Operand,
bool PrintType) {
2990 Out <<
"<null operand!>";
2997void AssemblyWriter::writeSyncScope(
const LLVMContext &
Context,
3005 Context.getSyncScopeNames(SSNs);
3007 Out <<
" syncscope(\"";
3015void AssemblyWriter::writeAtomic(
const LLVMContext &
Context,
3018 if (Ordering == AtomicOrdering::NotAtomic)
3021 writeSyncScope(
Context, SSID);
3025void AssemblyWriter::writeAtomicCmpXchg(
const LLVMContext &
Context,
3029 assert(SuccessOrdering != AtomicOrdering::NotAtomic &&
3030 FailureOrdering != AtomicOrdering::NotAtomic);
3032 writeSyncScope(
Context, SSID);
3037void AssemblyWriter::writeParamOperand(
const Value *Operand,
3038 AttributeSet Attrs) {
3040 Out <<
"<null operand!>";
3045 TypePrinter.print(Operand->
getType(), Out);
3047 if (
Attrs.hasAttributes()) {
3049 writeAttributeSet(Attrs);
3057void AssemblyWriter::writeOperandBundles(
const CallBase *
Call) {
3073 ListSeparator InnerLS;
3075 for (
const auto &Input : BU.
Inputs) {
3077 if (Input ==
nullptr)
3078 Out <<
"<null operand bundle!>";
3089void AssemblyWriter::printModule(
const Module *M) {
3092 if (ShouldPreserveUseListOrder)
3095 if (!
M->getModuleIdentifier().empty() &&
3098 M->getModuleIdentifier().find(
'\n') == std::string::npos)
3099 Out <<
"; ModuleID = '" <<
M->getModuleIdentifier() <<
"'\n";
3101 if (!
M->getSourceFileName().empty()) {
3102 Out <<
"source_filename = \"";
3107 const std::string &
DL =
M->getDataLayoutStr();
3109 Out <<
"target datalayout = \"" <<
DL <<
"\"\n";
3110 if (!
M->getTargetTriple().empty())
3111 Out <<
"target triple = \"" <<
M->getTargetTriple().str() <<
"\"\n";
3113 if (!
M->getModuleInlineAsm().empty()) {
3117 StringRef
Asm =
M->getModuleInlineAsm();
3120 std::tie(Front, Asm) =
Asm.split(
'\n');
3124 Out <<
"module asm \"";
3127 }
while (!
Asm.empty());
3130 printTypeIdentities();
3133 if (!Comdats.empty())
3135 for (
const Comdat *
C : Comdats) {
3137 if (
C != Comdats.back())
3142 if (!
M->global_empty()) Out <<
'\n';
3143 for (
const GlobalVariable &GV :
M->globals()) {
3144 printGlobal(&GV); Out <<
'\n';
3148 if (!
M->alias_empty()) Out <<
"\n";
3149 for (
const GlobalAlias &GA :
M->aliases())
3153 if (!
M->ifunc_empty()) Out <<
"\n";
3154 for (
const GlobalIFunc &GI :
M->ifuncs())
3158 for (
const Function &
F : *M) {
3164 printUseLists(
nullptr);
3169 writeAllAttributeGroups();
3173 if (!
M->named_metadata_empty()) Out <<
'\n';
3175 for (
const NamedMDNode &Node :
M->named_metadata())
3176 printNamedMDNode(&Node);
3185void AssemblyWriter::printModuleSummaryIndex() {
3187 int NumSlots =
Machine.initializeIndexIfNeeded();
3193 std::vector<std::pair<std::string, ModuleHash>> moduleVec;
3194 std::string RegularLTOModuleName =
3196 moduleVec.resize(TheIndex->modulePaths().size());
3197 for (
auto &[ModPath, ModHash] : TheIndex->modulePaths())
3198 moduleVec[
Machine.getModulePathSlot(ModPath)] = std::make_pair(
3201 ModPath.empty() ? RegularLTOModuleName : std::string(ModPath), ModHash);
3204 for (
auto &ModPair : moduleVec) {
3205 Out <<
"^" << i++ <<
" = module: (";
3208 Out <<
"\", hash: (";
3210 for (
auto Hash : ModPair.second)
3217 for (
auto &GlobalList : *TheIndex) {
3218 auto GUID = GlobalList.first;
3219 for (
auto &Summary : GlobalList.second.getSummaryList())
3224 for (
auto &GlobalList : *TheIndex) {
3225 auto GUID = GlobalList.first;
3226 auto VI = TheIndex->getValueInfo(GlobalList);
3227 printSummaryInfo(
Machine.getGUIDSlot(GUID), VI);
3231 for (
const auto &TID : TheIndex->typeIds()) {
3232 Out <<
"^" <<
Machine.getTypeIdSlot(TID.second.first)
3233 <<
" = typeid: (name: \"" << TID.second.first <<
"\"";
3234 printTypeIdSummary(TID.second.second);
3235 Out <<
") ; guid = " << TID.first <<
"\n";
3239 for (
auto &TId : TheIndex->typeIdCompatibleVtableMap()) {
3241 Out <<
"^" <<
Machine.getTypeIdCompatibleVtableSlot(TId.first)
3242 <<
" = typeidCompatibleVTable: (name: \"" << TId.first <<
"\"";
3243 printTypeIdCompatibleVtableSummary(TId.second);
3244 Out <<
") ; guid = " <<
GUID <<
"\n";
3248 if (TheIndex->getFlags()) {
3249 Out <<
"^" << NumSlots <<
" = flags: " << TheIndex->getFlags() <<
"\n";
3253 Out <<
"^" << NumSlots <<
" = blockcount: " << TheIndex->getBlockCount()
3263 return "singleImpl";
3265 return "branchFunnel";
3276 return "uniformRetVal";
3278 return "uniqueRetVal";
3280 return "virtualConstProp";
3303void AssemblyWriter::printTypeTestResolution(
const TypeTestResolution &TTRes) {
3310 Out <<
", alignLog2: " << TTRes.
AlignLog2;
3312 Out <<
", sizeM1: " << TTRes.
SizeM1;
3315 Out <<
", bitMask: " << (unsigned)TTRes.
BitMask;
3322void AssemblyWriter::printTypeIdSummary(
const TypeIdSummary &TIS) {
3323 Out <<
", summary: (";
3324 printTypeTestResolution(TIS.
TTRes);
3325 if (!TIS.
WPDRes.empty()) {
3326 Out <<
", wpdResolutions: (";
3328 for (
auto &WPDRes : TIS.
WPDRes) {
3330 Out <<
"(offset: " << WPDRes.first <<
", ";
3331 printWPDRes(WPDRes.second);
3339void AssemblyWriter::printTypeIdCompatibleVtableSummary(
3341 Out <<
", summary: (";
3343 for (
auto &
P : TI) {
3345 Out <<
"(offset: " <<
P.AddressPointOffset <<
", ";
3346 Out <<
"^" <<
Machine.getGUIDSlot(
P.VTableVI.getGUID());
3352void AssemblyWriter::printArgs(ArrayRef<uint64_t> Args) {
3356void AssemblyWriter::printWPDRes(
const WholeProgramDevirtResolution &WPDRes) {
3357 Out <<
"wpdRes: (kind: ";
3364 Out <<
", resByArg: (";
3366 for (
auto &ResByArg : WPDRes.
ResByArg) {
3368 printArgs(ResByArg.first);
3369 Out <<
", byArg: (kind: ";
3371 if (ResByArg.second.TheKind ==
3373 ResByArg.second.TheKind ==
3375 Out <<
", info: " << ResByArg.second.Info;
3379 if (ResByArg.second.Byte || ResByArg.second.Bit)
3380 Out <<
", byte: " << ResByArg.second.Byte
3381 <<
", bit: " << ResByArg.second.Bit;
3402void AssemblyWriter::printAliasSummary(
const AliasSummary *AS) {
3403 Out <<
", aliasee: ";
3413void AssemblyWriter::printGlobalVarSummary(
const GlobalVarSummary *GS) {
3414 auto VTableFuncs =
GS->vTableFuncs();
3415 Out <<
", varFlags: (readonly: " <<
GS->VarFlags.MaybeReadOnly <<
", "
3416 <<
"writeonly: " <<
GS->VarFlags.MaybeWriteOnly <<
", "
3417 <<
"constant: " <<
GS->VarFlags.Constant;
3418 if (!VTableFuncs.empty())
3420 <<
"vcall_visibility: " <<
GS->VarFlags.VCallVisibility;
3423 if (!VTableFuncs.empty()) {
3424 Out <<
", vTableFuncs: (";
3426 for (
auto &
P : VTableFuncs) {
3428 Out <<
"(virtFunc: ^" <<
Machine.getGUIDSlot(
P.FuncVI.getGUID())
3429 <<
", offset: " <<
P.VTableOffset;
3447 return "linkonce_odr";
3457 return "extern_weak";
3459 return "available_externally";
3488 return "definition";
3490 return "declaration";
3495void AssemblyWriter::printFunctionSummary(
const FunctionSummary *FS) {
3496 Out <<
", insts: " <<
FS->instCount();
3497 if (
FS->fflags().anyFlagSet())
3498 Out <<
", " <<
FS->fflags();
3500 if (!
FS->calls().empty()) {
3501 Out <<
", calls: (";
3503 for (
auto &
Call :
FS->calls()) {
3505 Out <<
"(callee: ^" <<
Machine.getGUIDSlot(
Call.first.getGUID());
3506 if (
Call.second.getHotness() != CalleeInfo::HotnessType::Unknown)
3510 if (
Call.second.HasTailCall)
3517 if (
const auto *TIdInfo =
FS->getTypeIdInfo())
3518 printTypeIdInfo(*TIdInfo);
3522 auto AllocTypeName = [](uint8_t
Type) ->
const char * {
3524 case (uint8_t)AllocationType::None:
3526 case (uint8_t)AllocationType::NotCold:
3528 case (uint8_t)AllocationType::Cold:
3530 case (uint8_t)AllocationType::Hot:
3536 if (!
FS->allocs().empty()) {
3537 Out <<
", allocs: (";
3539 for (
auto &AI :
FS->allocs()) {
3541 Out <<
"(versions: (";
3543 for (
auto V : AI.Versions) {
3545 Out << AllocTypeName(V);
3547 Out <<
"), memProf: (";
3548 ListSeparator MIBFS;
3549 for (
auto &MIB : AI.MIBs) {
3551 Out <<
"(type: " << AllocTypeName((uint8_t)MIB.AllocType);
3552 Out <<
", stackIds: (";
3553 ListSeparator SIDFS;
3554 for (
auto Id : MIB.StackIdIndices) {
3556 Out << TheIndex->getStackIdAtIndex(Id);
3565 if (!
FS->callsites().empty()) {
3566 Out <<
", callsites: (";
3568 for (
auto &CI :
FS->callsites()) {
3571 Out <<
"(callee: ^" <<
Machine.getGUIDSlot(CI.Callee.getGUID());
3573 Out <<
"(callee: null";
3574 Out <<
", clones: (";
3576 for (
auto V : CI.Clones) {
3580 Out <<
"), stackIds: (";
3581 ListSeparator SIDFS;
3582 for (
auto Id : CI.StackIdIndices) {
3584 Out << TheIndex->getStackIdAtIndex(Id);
3591 auto PrintRange = [&](
const ConstantRange &
Range) {
3595 if (!
FS->paramAccesses().empty()) {
3596 Out <<
", params: (";
3598 for (
auto &PS :
FS->paramAccesses()) {
3600 Out <<
"(param: " << PS.ParamNo;
3601 Out <<
", offset: ";
3603 if (!PS.Calls.empty()) {
3604 Out <<
", calls: (";
3606 for (
auto &
Call : PS.Calls) {
3608 Out <<
"(callee: ^" <<
Machine.getGUIDSlot(
Call.Callee.getGUID());
3609 Out <<
", param: " <<
Call.ParamNo;
3610 Out <<
", offset: ";
3611 PrintRange(
Call.Offsets);
3622void AssemblyWriter::printTypeIdInfo(
3623 const FunctionSummary::TypeIdInfo &TIDInfo) {
3624 Out <<
", typeIdInfo: (";
3625 ListSeparator TIDFS;
3628 Out <<
"typeTests: (";
3631 auto TidIter = TheIndex->typeIds().equal_range(GUID);
3632 if (TidIter.first == TidIter.second) {
3638 for (
const auto &[GUID, TypeIdPair] :
make_range(TidIter)) {
3640 auto Slot =
Machine.getTypeIdSlot(TypeIdPair.first);
3658 "typeTestAssumeConstVCalls");
3663 "typeCheckedLoadConstVCalls");
3668void AssemblyWriter::printVFuncId(
const FunctionSummary::VFuncId VFId) {
3669 auto TidIter = TheIndex->typeIds().equal_range(VFId.
GUID);
3670 if (TidIter.first == TidIter.second) {
3671 Out <<
"vFuncId: (";
3672 Out <<
"guid: " << VFId.
GUID;
3673 Out <<
", offset: " << VFId.
Offset;
3679 for (
const auto &[GUID, TypeIdPair] :
make_range(TidIter)) {
3681 Out <<
"vFuncId: (";
3682 auto Slot =
Machine.getTypeIdSlot(TypeIdPair.first);
3685 Out <<
", offset: " << VFId.
Offset;
3690void AssemblyWriter::printNonConstVCalls(
3692 Out <<
Tag <<
": (";
3694 for (
auto &VFuncId : VCallList) {
3696 printVFuncId(VFuncId);
3701void AssemblyWriter::printConstVCalls(
3703 Out <<
Tag <<
": (";
3705 for (
auto &ConstVCall : VCallList) {
3708 printVFuncId(ConstVCall.VFunc);
3709 if (!ConstVCall.Args.empty()) {
3711 printArgs(ConstVCall.Args);
3718void AssemblyWriter::printSummary(
const GlobalValueSummary &Summary) {
3719 GlobalValueSummary::GVFlags GVFlags =
Summary.flags();
3722 Out <<
"(module: ^" <<
Machine.getModulePathSlot(
Summary.modulePath())
3725 Out <<
", visibility: "
3728 Out <<
", live: " << GVFlags.
Live;
3729 Out <<
", dsoLocal: " << GVFlags.
DSOLocal;
3731 Out <<
", importType: "
3742 auto RefList =
Summary.refs();
3743 if (!RefList.empty()) {
3746 for (
auto &
Ref : RefList) {
3748 if (
Ref.isReadOnly())
3750 else if (
Ref.isWriteOnly())
3751 Out <<
"writeonly ";
3752 Out <<
"^" <<
Machine.getGUIDSlot(
Ref.getGUID());
3760void AssemblyWriter::printSummaryInfo(
unsigned Slot,
const ValueInfo &VI) {
3761 Out <<
"^" <<
Slot <<
" = gv: (";
3762 if (
VI.hasName() && !
VI.name().empty())
3763 Out <<
"name: \"" <<
VI.name() <<
"\"";
3765 Out <<
"guid: " <<
VI.getGUID();
3766 if (!
VI.getSummaryList().empty()) {
3767 Out <<
", summaries: (";
3769 for (
auto &Summary :
VI.getSummaryList()) {
3771 printSummary(*Summary);
3776 if (
VI.hasName() && !
VI.name().empty())
3777 Out <<
" ; guid = " <<
VI.getGUID();
3784 Out <<
"<empty name> ";
3786 unsigned char FirstC =
static_cast<unsigned char>(Name[0]);
3787 if (isalpha(FirstC) || FirstC ==
'-' || FirstC ==
'$' || FirstC ==
'.' ||
3792 for (
unsigned i = 1, e = Name.size(); i != e; ++i) {
3793 unsigned char C = Name[i];
3794 if (isalnum(
C) ||
C ==
'-' ||
C ==
'$' ||
C ==
'.' ||
C ==
'_')
3802void AssemblyWriter::printNamedMDNode(
const NamedMDNode *NMD) {
3837 Out <<
"dso_local ";
3855 Out <<
"thread_local ";
3858 Out <<
"thread_local(localdynamic) ";
3861 Out <<
"thread_local(initialexec) ";
3864 Out <<
"thread_local(localexec) ";
3874 return "local_unnamed_addr";
3876 return "unnamed_addr";
3899void AssemblyWriter::printGlobal(
const GlobalVariable *GV) {
3901 Out <<
"; Materializable\n";
3922 Out << (GV->
isConstant() ?
"constant " :
"global ");
3931 Out <<
", section \"";
3936 Out <<
", partition \"";
3941 Out <<
", code_model \"";
3966 Out <<
", no_sanitize_address";
3968 Out <<
", no_sanitize_hwaddress";
3970 Out <<
", sanitize_memtag";
3972 Out <<
", sanitize_address_dyninit";
3977 Out <<
", align " <<
A->value();
3981 printMetadataAttachments(MDs,
", ");
3984 if (
Attrs.hasAttributes())
3985 Out <<
" #" <<
Machine.getAttributeGroupSlot(Attrs);
3990void AssemblyWriter::printAlias(
const GlobalAlias *GA) {
3992 Out <<
"; Materializable\n";
4012 if (
const Constant *Aliasee = GA->
getAliasee()) {
4015 TypePrinter.print(GA->
getType(), Out);
4016 Out <<
" <<NULL ALIASEE>>";
4020 Out <<
", partition \"";
4029void AssemblyWriter::printIFunc(
const GlobalIFunc *GI) {
4031 Out <<
"; Materializable\n";
4046 if (
const Constant *Resolver = GI->
getResolver()) {
4049 TypePrinter.print(GI->
getType(), Out);
4050 Out <<
" <<NULL RESOLVER>>";
4054 Out <<
", partition \"";
4061 printMetadataAttachments(MDs,
", ");
4068void AssemblyWriter::printComdat(
const Comdat *
C) {
4072void AssemblyWriter::printTypeIdentities() {
4073 if (TypePrinter.empty())
4079 auto &NumberedTypes = TypePrinter.getNumberedTypes();
4080 for (
unsigned I = 0,
E = NumberedTypes.size();
I !=
E; ++
I) {
4081 Out <<
'%' <<
I <<
" = type ";
4085 TypePrinter.printStructBody(NumberedTypes[
I], Out);
4089 auto &NamedTypes = TypePrinter.getNamedTypes();
4090 for (StructType *NamedType : NamedTypes) {
4096 TypePrinter.printStructBody(NamedType, Out);
4102void AssemblyWriter::printFunction(
const Function *
F) {
4103 if (
F->isMaterializable())
4104 Out <<
"; Materializable\n";
4105 else if (AnnotationWriter)
4108 const AttributeList &
Attrs =
F->getAttributes();
4109 if (
Attrs.hasFnAttrs()) {
4110 AttributeSet AS =
Attrs.getFnAttrs();
4111 std::string AttrStr;
4114 if (!Attr.isStringAttribute()) {
4115 if (!AttrStr.empty()) AttrStr +=
' ';
4116 AttrStr += Attr.getAsString();
4120 if (!AttrStr.empty())
4121 Out <<
"; Function Attrs: " << AttrStr <<
'\n';
4125 Out <<
"; Unknown intrinsic\n";
4129 if (
F->isDeclaration()) {
4132 F->getAllMetadata(MDs);
4133 printMetadataAttachments(MDs,
" ");
4144 if (
F->getCallingConv() != CallingConv::C) {
4149 FunctionType *FT =
F->getFunctionType();
4150 if (
Attrs.hasRetAttrs())
4151 Out <<
Attrs.getAsString(AttributeList::ReturnIndex) <<
' ';
4152 TypePrinter.print(
F->getReturnType(), Out);
4159 if (
F->isDeclaration() && !IsForDebug) {
4162 for (
unsigned I = 0,
E = FT->getNumParams();
I !=
E; ++
I) {
4165 TypePrinter.print(FT->getParamType(
I), Out);
4167 AttributeSet ArgAttrs =
Attrs.getParamAttrs(
I);
4170 writeAttributeSet(ArgAttrs);
4176 for (
const Argument &Arg :
F->args()) {
4178 printArgument(&Arg,
Attrs.getParamAttrs(Arg.getArgNo()));
4183 if (FT->isVarArg()) {
4184 if (FT->getNumParams()) Out <<
", ";
4195 bool ForcePrintAddressSpace =
4196 !
Mod ||
Mod->getDataLayout().getProgramAddressSpace() != 0;
4198 "", ForcePrintAddressSpace);
4199 if (
Attrs.hasFnAttrs())
4200 Out <<
" #" <<
Machine.getAttributeGroupSlot(
Attrs.getFnAttrs());
4201 if (
F->hasSection()) {
4202 Out <<
" section \"";
4206 if (
F->hasPartition()) {
4207 Out <<
" partition \"";
4212 if (MaybeAlign
A =
F->getAlign())
4213 Out <<
" align " <<
A->value();
4215 Out <<
" gc \"" <<
F->getGC() <<
'"';
4216 if (
F->hasPrefixData()) {
4218 writeOperand(
F->getPrefixData(),
true);
4220 if (
F->hasPrologueData()) {
4221 Out <<
" prologue ";
4222 writeOperand(
F->getPrologueData(),
true);
4224 if (
F->hasPersonalityFn()) {
4225 Out <<
" personality ";
4226 writeOperand(
F->getPersonalityFn(),
true);
4230 if (
auto *MDProf =
F->getMetadata(LLVMContext::MD_prof)) {
4232 MDProf->print(Out, TheModule,
true);
4236 if (
F->isDeclaration()) {
4240 F->getAllMetadata(MDs);
4241 printMetadataAttachments(MDs,
" ");
4245 for (
const BasicBlock &BB : *
F)
4259void AssemblyWriter::printArgument(
const Argument *Arg, AttributeSet Attrs) {
4261 TypePrinter.print(Arg->
getType(), Out);
4264 if (
Attrs.hasAttributes()) {
4266 writeAttributeSet(Attrs);
4275 assert(Slot != -1 &&
"expect argument in function here");
4276 Out <<
" %" <<
Slot;
4287 }
else if (!IsEntryBlock) {
4289 int Slot =
Machine.getLocalSlot(BB);
4296 if (!IsEntryBlock) {
4301 Out <<
" No predecessors!";
4307 writeOperand(Pred,
false);
4318 for (
const DbgRecord &DR :
I.getDbgRecordRange())
4319 printDbgRecordLine(DR);
4320 printInstructionLine(
I);
4327void AssemblyWriter::printInstructionLine(
const Instruction &
I) {
4328 printInstruction(
I);
4334void AssemblyWriter::printGCRelocateComment(
const GCRelocateInst &Relocate) {
4344void AssemblyWriter::printInfoComment(
const Value &V,
bool isMaterializable) {
4346 printGCRelocateComment(*Relocate);
4348 if (AnnotationWriter && !isMaterializable)
4353 if (
I->getDebugLoc()) {
4355 I->getDebugLoc().print(Out);
4361 if (
auto *MD =
I->getMetadata(LLVMContext::MD_prof)) {
4363 MD->print(Out, TheModule,
true);
4374 if (Operand ==
nullptr) {
4375 Out <<
" <cannot get addrspace!>";
4385 bool ForcePrintAddrSpace =
4386 !
Mod ||
Mod->getDataLayout().getProgramAddressSpace() != 0;
4388 ForcePrintAddrSpace);
4392void AssemblyWriter::printInstruction(
const Instruction &
I) {
4402 }
else if (!
I.getType()->isVoidTy()) {
4404 int SlotNum =
Machine.getLocalSlot(&
I);
4406 Out <<
"<badref> = ";
4408 Out <<
'%' << SlotNum <<
" = ";
4412 if (CI->isMustTailCall())
4414 else if (CI->isTailCall())
4416 else if (CI->isNoTailCall())
4421 Out <<
I.getOpcodeName();
4443 Out <<
' ' << CI->getPredicate();
4450 const Value *Operand =
I.getNumOperands() ?
I.getOperand(0) :
nullptr;
4456 writeOperand(BI.getCondition(),
true);
4458 writeOperand(BI.getSuccessor(0),
true);
4460 writeOperand(BI.getSuccessor(1),
true);
4466 writeOperand(
SI.getCondition(),
true);
4468 writeOperand(
SI.getDefaultDest(),
true);
4470 for (
auto Case :
SI.cases()) {
4472 writeOperand(Case.getCaseValue(),
true);
4474 writeOperand(Case.getCaseSuccessor(),
true);
4480 writeOperand(Operand,
true);
4484 for (
unsigned i = 1, e =
I.getNumOperands(); i != e; ++i) {
4486 writeOperand(
I.getOperand(i),
true);
4491 TypePrinter.print(
I.getType(), Out);
4495 for (
const auto &[V,
Block] :
4496 zip_equal(PN->incoming_values(), PN->blocks())) {
4498 writeOperand(V,
false);
4500 writeOperand(
Block,
false);
4505 writeOperand(
I.getOperand(0),
true);
4510 writeOperand(
I.getOperand(0),
true); Out <<
", ";
4511 writeOperand(
I.getOperand(1),
true);
4516 TypePrinter.print(
I.getType(), Out);
4517 if (LPI->isCleanup() || LPI->getNumClauses() != 0)
4520 if (LPI->isCleanup())
4523 for (
unsigned i = 0, e = LPI->getNumClauses(); i != e; ++i) {
4524 if (i != 0 || LPI->isCleanup()) Out <<
"\n";
4525 if (LPI->isCatch(i))
4530 writeOperand(LPI->getClause(i),
true);
4534 writeOperand(CatchSwitch->getParentPad(),
false);
4537 for (
const BasicBlock *PadBB : CatchSwitch->handlers()) {
4539 writeOperand(PadBB,
true);
4542 if (
const BasicBlock *UnwindDest = CatchSwitch->getUnwindDest())
4543 writeOperand(UnwindDest,
true);
4548 writeOperand(FPI->getParentPad(),
false);
4551 for (
const Value *
Op : FPI->arg_operands()) {
4553 writeOperand(
Op,
true);
4560 writeOperand(CRI->getOperand(0),
false);
4563 writeOperand(CRI->getOperand(1),
true);
4566 writeOperand(CRI->getOperand(0),
false);
4569 if (CRI->hasUnwindDest())
4570 writeOperand(CRI->getOperand(1),
true);
4575 if (CI->getCallingConv() != CallingConv::C) {
4580 Operand = CI->getCalledOperand();
4581 FunctionType *FTy = CI->getFunctionType();
4582 Type *RetTy = FTy->getReturnType();
4583 const AttributeList &PAL = CI->getAttributes();
4585 if (PAL.hasRetAttrs())
4586 Out <<
' ' << PAL.getAsString(AttributeList::ReturnIndex);
4595 TypePrinter.print(FTy->isVarArg() ? FTy : RetTy, Out);
4597 writeOperand(Operand,
false);
4599 bool HasPrettyPrintedArgs =
4604 Function *CalledFunc = CI->getCalledFunction();
4605 auto PrintArgComment = [&](
unsigned ArgNo) {
4609 std::string ArgComment;
4610 raw_string_ostream ArgCommentStream(ArgComment);
4613 if (ArgComment.empty())
4615 Out <<
"/* " << ArgComment <<
" */ ";
4617 if (HasPrettyPrintedArgs) {
4618 for (
unsigned ArgNo = 0, NumArgs = CI->arg_size(); ArgNo < NumArgs;
4621 PrintArgComment(ArgNo);
4622 writeParamOperand(CI->getArgOperand(ArgNo), PAL.getParamAttrs(ArgNo));
4625 for (
unsigned ArgNo = 0, NumArgs = CI->arg_size(); ArgNo < NumArgs;
4628 writeParamOperand(CI->getArgOperand(ArgNo), PAL.getParamAttrs(ArgNo));
4633 if (CI->isMustTailCall() && CI->getParent() &&
4634 CI->getParent()->getParent() &&
4635 CI->getParent()->getParent()->isVarArg()) {
4636 if (CI->arg_size() > 0)
4642 if (PAL.hasFnAttrs())
4643 Out <<
" #" <<
Machine.getAttributeGroupSlot(PAL.getFnAttrs());
4645 writeOperandBundles(CI);
4647 Operand =
II->getCalledOperand();
4648 FunctionType *FTy =
II->getFunctionType();
4649 Type *RetTy = FTy->getReturnType();
4650 const AttributeList &PAL =
II->getAttributes();
4653 if (
II->getCallingConv() != CallingConv::C) {
4658 if (PAL.hasRetAttrs())
4659 Out <<
' ' << PAL.getAsString(AttributeList::ReturnIndex);
4669 TypePrinter.print(FTy->isVarArg() ? FTy : RetTy, Out);
4671 writeOperand(Operand,
false);
4674 for (
unsigned op = 0, Eop =
II->arg_size();
op < Eop; ++
op) {
4676 writeParamOperand(
II->getArgOperand(
op), PAL.getParamAttrs(
op));
4680 if (PAL.hasFnAttrs())
4681 Out <<
" #" <<
Machine.getAttributeGroupSlot(PAL.getFnAttrs());
4683 writeOperandBundles(
II);
4686 writeOperand(
II->getNormalDest(),
true);
4688 writeOperand(
II->getUnwindDest(),
true);
4690 Operand = CBI->getCalledOperand();
4691 FunctionType *FTy = CBI->getFunctionType();
4692 Type *RetTy = FTy->getReturnType();
4693 const AttributeList &PAL = CBI->getAttributes();
4696 if (CBI->getCallingConv() != CallingConv::C) {
4701 if (PAL.hasRetAttrs())
4702 Out <<
' ' << PAL.getAsString(AttributeList::ReturnIndex);
4709 TypePrinter.print(FTy->isVarArg() ? FTy : RetTy, Out);
4711 writeOperand(Operand,
false);
4713 ListSeparator ArgLS;
4714 for (
unsigned op = 0, Eop = CBI->arg_size();
op < Eop; ++
op) {
4716 writeParamOperand(CBI->getArgOperand(
op), PAL.getParamAttrs(
op));
4720 if (PAL.hasFnAttrs())
4721 Out <<
" #" <<
Machine.getAttributeGroupSlot(PAL.getFnAttrs());
4723 writeOperandBundles(CBI);
4726 writeOperand(CBI->getDefaultDest(),
true);
4728 ListSeparator DestLS;
4729 for (
const BasicBlock *Dest : CBI->getIndirectDests()) {
4731 writeOperand(Dest,
true);
4736 if (AI->isUsedWithInAlloca())
4738 if (AI->isSwiftError())
4739 Out <<
"swifterror ";
4740 TypePrinter.print(AI->getAllocatedType(), Out);
4746 if (!AI->getArraySize() || AI->isArrayAllocation() ||
4747 !AI->getArraySize()->getType()->isIntegerTy(32)) {
4749 writeOperand(AI->getArraySize(),
true);
4751 if (MaybeAlign
A = AI->getAlign()) {
4752 Out <<
", align " <<
A->value();
4760 writeOperand(Operand,
true);
4763 TypePrinter.print(
I.getType(), Out);
4767 writeOperand(Operand,
true);
4770 TypePrinter.print(
I.getType(), Out);
4771 }
else if (Operand) {
4774 TypePrinter.print(
GEP->getSourceElementType(), Out);
4778 TypePrinter.print(LI->getType(), Out);
4785 bool PrintAllTypes =
false;
4793 PrintAllTypes =
true;
4795 for (
unsigned i = 1,
E =
I.getNumOperands(); i !=
E; ++i) {
4796 Operand =
I.getOperand(i);
4799 if (Operand && Operand->
getType() != TheType) {
4800 PrintAllTypes =
true;
4806 if (!PrintAllTypes) {
4808 TypePrinter.print(TheType, Out);
4813 for (
const Value *
Op :
I.operands()) {
4815 writeOperand(
Op, PrintAllTypes);
4822 writeAtomic(LI->getContext(), LI->getOrdering(), LI->getSyncScopeID());
4823 if (MaybeAlign
A = LI->getAlign())
4824 Out <<
", align " <<
A->value();
4827 writeAtomic(
SI->getContext(),
SI->getOrdering(),
SI->getSyncScopeID());
4828 if (MaybeAlign
A =
SI->getAlign())
4829 Out <<
", align " <<
A->value();
4831 writeAtomicCmpXchg(CXI->getContext(), CXI->getSuccessOrdering(),
4832 CXI->getFailureOrdering(), CXI->getSyncScopeID());
4833 Out <<
", align " << CXI->getAlign().value();
4835 writeAtomic(RMWI->getContext(), RMWI->getOrdering(),
4836 RMWI->getSyncScopeID());
4837 Out <<
", align " << RMWI->getAlign().value();
4839 writeAtomic(FI->getContext(), FI->getOrdering(), FI->getSyncScopeID());
4847 printMetadataAttachments(InstMD,
", ");
4850 printInfoComment(
I);
4853void AssemblyWriter::printDbgMarker(
const DbgMarker &Marker) {
4857 printDbgRecord(DPR);
4861 Out <<
" DbgMarker -> { ";
4866void AssemblyWriter::printDbgRecord(
const DbgRecord &DR) {
4868 printDbgVariableRecord(*DVR);
4870 printDbgLabelRecord(*DLR);
4875void AssemblyWriter::printDbgVariableRecord(
const DbgVariableRecord &DVR) {
4879 case DbgVariableRecord::LocationType::Value:
4882 case DbgVariableRecord::LocationType::Declare:
4885 case DbgVariableRecord::LocationType::DeclareValue:
4886 Out <<
"declare_value";
4888 case DbgVariableRecord::LocationType::Assign:
4893 "Tried to print a DbgVariableRecord with an invalid LocationType!");
4924void AssemblyWriter::printDbgRecordLine(
const DbgRecord &DR) {
4931void AssemblyWriter::printDbgLabelRecord(
const DbgLabelRecord &Label) {
4933 Out <<
"#dbg_label(";
4940void AssemblyWriter::printMetadataAttachments(
4941 const SmallVectorImpl<std::pair<unsigned, MDNode *>> &MDs,
4942 StringRef Separator) {
4946 if (MDNames.empty())
4947 MDs[0].second->getContext().getMDKindNames(MDNames);
4950 for (
const auto &
I : MDs) {
4951 unsigned Kind =
I.first;
4953 if (Kind < MDNames.size()) {
4957 Out <<
"!<unknown kind #" <<
Kind <<
">";
4963void AssemblyWriter::writeMDNode(
unsigned Slot,
const MDNode *Node) {
4964 Out <<
'!' <<
Slot <<
" = ";
4965 printMDNodeBody(Node);
4969void AssemblyWriter::writeAllMDNodes() {
4975 for (
unsigned i = 0, e = Nodes.
size(); i != e; ++i) {
4976 writeMDNode(i, Nodes[i]);
4980void AssemblyWriter::printMDNodeBody(
const MDNode *Node) {
4985void AssemblyWriter::writeAttribute(
const Attribute &Attr,
bool InAttrGroup) {
4991 Out << Attribute::getNameFromAttrKind(Attr.
getKindAsEnum());
4994 TypePrinter.print(Ty, Out);
4999void AssemblyWriter::writeAttributeSet(
const AttributeSet &AttrSet,
5001 ListSeparator
LS(
" ");
5002 for (
const auto &Attr : AttrSet) {
5004 writeAttribute(Attr, InAttrGroup);
5008void AssemblyWriter::writeAllAttributeGroups() {
5009 std::vector<std::pair<AttributeSet, unsigned>> asVec;
5010 asVec.resize(
Machine.as_size());
5013 asVec[
I.second] =
I;
5015 for (
const auto &
I : asVec)
5016 Out <<
"attributes #" <<
I.second <<
" = { "
5017 <<
I.first.getAsString(
true) <<
" }\n";
5020void AssemblyWriter::printUseListOrder(
const Value *V,
5021 ArrayRef<unsigned> Shuffle) {
5026 Out <<
"uselistorder";
5029 writeOperand(BB->getParent(),
false);
5031 writeOperand(BB,
false);
5034 writeOperand(V,
true);
5037 assert(Shuffle.
size() >= 2 &&
"Shuffle too small");
5041void AssemblyWriter::printUseLists(
const Function *
F) {
5042 auto It = UseListOrders.find(
F);
5043 if (It == UseListOrders.end())
5046 Out <<
"\n; uselistorder directives\n";
5047 for (
const auto &Pair : It->second)
5048 printUseListOrder(Pair.first, Pair.second);
5056 bool ShouldPreserveUseListOrder,
bool IsForDebug)
const {
5059 AssemblyWriter W(OS, SlotTable, this->
getParent(), AAW, IsForDebug,
5060 ShouldPreserveUseListOrder);
5061 W.printFunction(
this);
5065 bool ShouldPreserveUseListOrder,
5066 bool IsForDebug)
const {
5069 AssemblyWriter W(OS, SlotTable, this->
getModule(), AAW,
5071 ShouldPreserveUseListOrder);
5072 W.printBasicBlock(
this);
5076 bool ShouldPreserveUseListOrder,
bool IsForDebug)
const {
5079 AssemblyWriter W(OS, SlotTable,
this, AAW, IsForDebug,
5080 ShouldPreserveUseListOrder);
5081 W.printModule(
this);
5087 AssemblyWriter W(OS, SlotTable,
getParent(),
nullptr, IsForDebug);
5088 W.printNamedMDNode(
this);
5092 bool IsForDebug)
const {
5093 std::optional<SlotTracker> LocalST;
5099 SlotTable = &*LocalST;
5103 AssemblyWriter W(OS, *SlotTable,
getParent(),
nullptr, IsForDebug);
5104 W.printNamedMDNode(
this);
5109 ROS <<
" = comdat ";
5116 ROS <<
"exactmatch";
5122 ROS <<
"nodeduplicate";
5134 TP.print(
const_cast<Type*
>(
this), OS);
5143 TP.printStructBody(STy, OS);
5149 if (
Function *
F = CI->getCalledFunction())
5150 if (
F->isIntrinsic())
5151 for (
auto &
Op :
I.operands())
5161 print(ROS, MST, IsForDebug);
5167 print(ROS, MST, IsForDebug);
5171 bool IsForDebug)
const {
5179 AssemblyWriter W(OS, SlotTable,
getModuleFromDPI(
this),
nullptr, IsForDebug);
5180 W.printDbgMarker(*
this);
5186 print(ROS, MST, IsForDebug);
5190 bool IsForDebug)
const {
5196 ?
Marker->getParent()->getParent()
5200 AssemblyWriter W(OS, SlotTable,
getModuleFromDPI(
this),
nullptr, IsForDebug);
5201 W.printDbgVariableRecord(*
this);
5205 bool IsForDebug)
const {
5211 Marker->getParent() ?
Marker->getParent()->getParent() :
nullptr;
5215 AssemblyWriter W(OS, SlotTable,
getModuleFromDPI(
this),
nullptr, IsForDebug);
5216 W.printDbgLabelRecord(*
this);
5220 bool ShouldInitializeAllMetadata =
false;
5224 ShouldInitializeAllMetadata =
true;
5227 print(ROS, MST, IsForDebug);
5231 bool IsForDebug)
const {
5236 auto IncorporateFunction = [&](
const Function *
F) {
5242 IncorporateFunction(
I->getParent() ?
I->getParent()->getParent() :
nullptr);
5244 W.printInstruction(*
I);
5246 IncorporateFunction(BB->getParent());
5247 AssemblyWriter W(OS, SlotTable,
getModuleFromVal(BB),
nullptr, IsForDebug);
5248 W.printBasicBlock(BB);
5250 AssemblyWriter W(OS, SlotTable, GV->
getParent(),
nullptr, IsForDebug);
5264 TypePrinting TypePrinter;
5265 TypePrinter.print(
C->getType(), OS);
5267 AsmWriterContext WriterCtx(&TypePrinter, MST.
getMachine());
5283 AsmWriterContext WriterCtx(
nullptr,
Machine, M);
5292 TypePrinting TypePrinter(MST.
getModule());
5323 AsmWriterContext &WriterCtx) {
5336struct MDTreeAsmWriterContext :
public AsmWriterContext {
5339 using EntryTy = std::pair<unsigned, std::string>;
5343 SmallPtrSet<const Metadata *, 4> Visited;
5345 raw_ostream &MainOS;
5347 MDTreeAsmWriterContext(TypePrinting *TP, SlotTracker *ST,
const Module *M,
5348 raw_ostream &OS,
const Metadata *InitMD)
5349 : AsmWriterContext(TP,
ST,
M),
Level(0
U), Visited({InitMD}), MainOS(OS) {}
5351 void onWriteMetadataAsOperand(
const Metadata *MD)
override {
5352 if (!Visited.
insert(MD).second)
5356 raw_string_ostream
SS(Str);
5361 unsigned InsertIdx = Buffer.
size() - 1;
5364 Buffer[InsertIdx].second = std::move(
SS.str());
5368 ~MDTreeAsmWriterContext()
override {
5369 for (
const auto &Entry : Buffer) {
5371 unsigned NumIndent =
Entry.first * 2U;
5380 bool OnlyAsOperand,
bool PrintAsTree =
false) {
5383 TypePrinting TypePrinter(M);
5385 std::unique_ptr<AsmWriterContext> WriterCtx;
5386 if (PrintAsTree && !OnlyAsOperand)
5387 WriterCtx = std::make_unique<MDTreeAsmWriterContext>(
5391 std::make_unique<AsmWriterContext>(&TypePrinter, MST.
getMachine(), M);
5420 const Module *M,
bool )
const {
5439 AssemblyWriter W(OS, SlotTable,
this, IsForDebug);
5440 W.printModuleSummaryIndex();
5444 unsigned UB)
const {
5450 if (
I.second >= LB &&
I.second < UB)
5451 L.push_back(std::make_pair(
I.second,
I.first));
5454#if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP)
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
This file declares a class to represent arbitrary precision floating point values and provide a varie...
This file implements a class to represent arbitrary precision integral constant values and operations...
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
static void print(raw_ostream &Out, object::Archive::Kind Kind, T Val)
static void writeDIMacro(raw_ostream &Out, const DIMacro *N, AsmWriterContext &WriterCtx)
static void writeMetadataAsOperand(raw_ostream &Out, const Metadata *MD, AsmWriterContext &WriterCtx)
static void writeDIGlobalVariableExpression(raw_ostream &Out, const DIGlobalVariableExpression *N, AsmWriterContext &WriterCtx)
static void writeDICompositeType(raw_ostream &Out, const DICompositeType *N, AsmWriterContext &WriterCtx)
static void writeDIFixedPointType(raw_ostream &Out, const DIFixedPointType *N, AsmWriterContext &WriterCtx)
static void printDSOLocation(const GlobalValue &GV, formatted_raw_ostream &Out)
static const char * getWholeProgDevirtResKindName(WholeProgramDevirtResolution::Kind K)
static void writeDISubrangeType(raw_ostream &Out, const DISubrangeType *N, AsmWriterContext &WriterCtx)
static void writeAPFloatInternal(raw_ostream &Out, const APFloat &APF)
static void printMetadataImpl(raw_ostream &ROS, const Metadata &MD, ModuleSlotTracker &MST, const Module *M, bool OnlyAsOperand, bool PrintAsTree=false)
static void writeDIStringType(raw_ostream &Out, const DIStringType *N, AsmWriterContext &WriterCtx)
static std::string getLinkageNameWithSpace(GlobalValue::LinkageTypes LT)
static cl::opt< bool > PreserveAssemblyUseListOrder("preserve-ll-uselistorder", cl::Hidden, cl::init(false), cl::desc("Preserve use-list order when writing LLVM assembly."))
static std::vector< unsigned > predictValueUseListOrder(const Value *V, unsigned ID, const OrderMap &OM)
static void writeDIGlobalVariable(raw_ostream &Out, const DIGlobalVariable *N, AsmWriterContext &WriterCtx)
static void orderValue(const Value *V, OrderMap &OM)
static void writeDIBasicType(raw_ostream &Out, const DIBasicType *N, AsmWriterContext &WriterCtx)
static StringRef getUnnamedAddrEncoding(GlobalVariable::UnnamedAddr UA)
static const char * getWholeProgDevirtResByArgKindName(WholeProgramDevirtResolution::ByArg::Kind K)
static void writeMDNodeBodyInternal(raw_ostream &Out, const MDNode *Node, AsmWriterContext &Ctx)
static void writeDIModule(raw_ostream &Out, const DIModule *N, AsmWriterContext &WriterCtx)
static void writeDIFile(raw_ostream &Out, const DIFile *N, AsmWriterContext &)
static void writeDISubroutineType(raw_ostream &Out, const DISubroutineType *N, AsmWriterContext &WriterCtx)
static cl::opt< bool > PrintAddrspaceName("print-addrspace-name", cl::Hidden, cl::init(false), cl::desc("Print address space names"))
static void writeOptimizationInfo(raw_ostream &Out, const User *U)
static bool isReferencingMDNode(const Instruction &I)
#define CC_VLS_CASE(ABI_VLEN)
static void writeDILabel(raw_ostream &Out, const DILabel *N, AsmWriterContext &WriterCtx)
static void writeDIDerivedType(raw_ostream &Out, const DIDerivedType *N, AsmWriterContext &WriterCtx)
static void printMetadataIdentifier(StringRef Name, formatted_raw_ostream &Out)
static void printShuffleMask(raw_ostream &Out, Type *Ty, ArrayRef< int > Mask)
static void writeDIImportedEntity(raw_ostream &Out, const DIImportedEntity *N, AsmWriterContext &WriterCtx)
static const Module * getModuleFromDPI(const DbgMarker *Marker)
static void printAsOperandImpl(const Value &V, raw_ostream &O, bool PrintType, ModuleSlotTracker &MST)
static void writeDIObjCProperty(raw_ostream &Out, const DIObjCProperty *N, AsmWriterContext &WriterCtx)
static void writeDISubprogram(raw_ostream &Out, const DISubprogram *N, AsmWriterContext &WriterCtx)
static const char * getSummaryKindName(GlobalValueSummary::SummaryKind SK)
static OrderMap orderModule(const Module *M)
static const char * getVisibilityName(GlobalValue::VisibilityTypes Vis)
static void printCallingConv(unsigned cc, raw_ostream &Out)
static void printAddressSpace(const Module *M, unsigned AS, raw_ostream &OS, StringRef Prefix=" ", StringRef Suffix="", bool ForcePrint=false)
static cl::opt< bool > PrintInstDebugLocs("print-inst-debug-locs", cl::Hidden, cl::desc("Pretty print debug locations of instructions when dumping"))
static void printMetadataImplRec(raw_ostream &ROS, const Metadata &MD, AsmWriterContext &WriterCtx)
Recursive version of printMetadataImpl.
static SlotTracker * createSlotTracker(const Value *V)
static void writeDILocation(raw_ostream &Out, const DILocation *DL, AsmWriterContext &WriterCtx)
static void writeDINamespace(raw_ostream &Out, const DINamespace *N, AsmWriterContext &WriterCtx)
DenseMap< const Function *, MapVector< const Value *, std::vector< unsigned > > > UseListOrderMap
static void writeDICommonBlock(raw_ostream &Out, const DICommonBlock *N, AsmWriterContext &WriterCtx)
static UseListOrderMap predictUseListOrder(const Module *M)
static void printThreadLocalModel(GlobalVariable::ThreadLocalMode TLM, formatted_raw_ostream &Out)
static std::string getLinkageName(GlobalValue::LinkageTypes LT)
static void writeGenericDINode(raw_ostream &Out, const GenericDINode *N, AsmWriterContext &WriterCtx)
static void writeDILocalVariable(raw_ostream &Out, const DILocalVariable *N, AsmWriterContext &WriterCtx)
static const char * getTTResKindName(TypeTestResolution::Kind K)
static void writeDITemplateTypeParameter(raw_ostream &Out, const DITemplateTypeParameter *N, AsmWriterContext &WriterCtx)
static const char * getImportTypeName(GlobalValueSummary::ImportKind IK)
static void writeDICompileUnit(raw_ostream &Out, const DICompileUnit *N, AsmWriterContext &WriterCtx)
static const Module * getModuleFromVal(const Value *V)
static void printLLVMName(raw_ostream &OS, StringRef Name, PrefixType Prefix)
Turn the specified name into an 'LLVM name', which is either prefixed with % (if the string only cont...
static void maybePrintCallAddrSpace(const Value *Operand, const Instruction *I, raw_ostream &Out)
static void writeDIGenericSubrange(raw_ostream &Out, const DIGenericSubrange *N, AsmWriterContext &WriterCtx)
static void writeDISubrange(raw_ostream &Out, const DISubrange *N, AsmWriterContext &WriterCtx)
static void writeDILexicalBlockFile(raw_ostream &Out, const DILexicalBlockFile *N, AsmWriterContext &WriterCtx)
static void writeConstantInternal(raw_ostream &Out, const Constant *CV, AsmWriterContext &WriterCtx)
static void writeDIEnumerator(raw_ostream &Out, const DIEnumerator *N, AsmWriterContext &)
static void writeAsOperandInternal(raw_ostream &Out, const Value *V, AsmWriterContext &WriterCtx, bool PrintType=false)
static void printVisibility(GlobalValue::VisibilityTypes Vis, formatted_raw_ostream &Out)
static cl::opt< bool > PrintProfData("print-prof-data", cl::Hidden, cl::desc("Pretty print perf data (branch weights, etc) when dumping"))
static void writeMDTuple(raw_ostream &Out, const MDTuple *Node, AsmWriterContext &WriterCtx)
static void writeDIExpression(raw_ostream &Out, const DIExpression *N, AsmWriterContext &WriterCtx)
static cl::opt< bool > PrintInstAddrs("print-inst-addrs", cl::Hidden, cl::desc("Print addresses of instructions when dumping"))
static void writeDIAssignID(raw_ostream &Out, const DIAssignID *DL, AsmWriterContext &WriterCtx)
static void writeDILexicalBlock(raw_ostream &Out, const DILexicalBlock *N, AsmWriterContext &WriterCtx)
static void maybePrintComdat(formatted_raw_ostream &Out, const GlobalObject &GO)
static void printDLLStorageClass(GlobalValue::DLLStorageClassTypes SCT, formatted_raw_ostream &Out)
static bool printWithoutType(const Value &V, raw_ostream &O, SlotTracker *Machine, const Module *M)
Print without a type, skipping the TypePrinting object.
static void writeDIArgList(raw_ostream &Out, const DIArgList *N, AsmWriterContext &WriterCtx, bool FromValue=false)
static void writeDITemplateValueParameter(raw_ostream &Out, const DITemplateValueParameter *N, AsmWriterContext &WriterCtx)
static const Value * skipMetadataWrapper(const Value *V)
Look for a value that might be wrapped as metadata, e.g.
static void writeDIMacroFile(raw_ostream &Out, const DIMacroFile *N, AsmWriterContext &WriterCtx)
Atomic ordering constants.
This file contains the simple types necessary to represent the attributes associated with functions a...
static const Function * getParent(const Value *V)
static GCRegistry::Add< ErlangGC > A("erlang", "erlang-compatible garbage collector")
static GCRegistry::Add< CoreCLRGC > E("coreclr", "CoreCLR-compatible GC")
#define LLVM_DUMP_METHOD
Mark debug helper function definitions like dump() that should not be stripped from debug builds.
This file contains the declarations for the subclasses of Constant, which represent the different fla...
dxil pretty DXIL Metadata Pretty Printer
This file defines the DenseMap class.
This file contains constants used for implementing Dwarf debug support.
This file contains the declaration of the GlobalIFunc class, which represents a single indirect funct...
GlobalValue::SanitizerMetadata SanitizerMetadata
This file provides various utilities for inspecting and working with the control flow graph in LLVM I...
This file contains an interface for creating legacy passes to print out IR in various granularities.
Module.h This file contains the declarations for the Module class.
This defines the Use class.
Machine Check Debug Module
static bool InRange(int64_t Value, unsigned short Shift, int LBound, int HBound)
ModuleSummaryIndex.h This file contains the declarations the classes that hold the module index and s...
static bool processFunction(Function &F, NVPTXTargetMachine &TM)
ConstantRange Range(APInt(BitWidth, Low), APInt(BitWidth, High))
uint64_t IntrinsicInst * II
Function const char TargetMachine * Machine
if(auto Err=PB.parsePassPipeline(MPM, Passes)) return wrap(std MPM run * Mod
static StringRef getName(Value *V)
This file provides utility classes that use RAII to save and restore values.
This file implements a set that has insertion order iteration characteristics.
This file defines the SmallPtrSet class.
This file defines the SmallString class.
This file defines the SmallVector class.
LocallyHashedType DenseMapInfo< LocallyHashedType >::Empty
static UseListOrderStack predictUseListOrder(const Module &M)
static const fltSemantics & IEEEsingle()
static const fltSemantics & BFloat()
static const fltSemantics & IEEEquad()
static const fltSemantics & IEEEdouble()
static const fltSemantics & x87DoubleExtended()
static constexpr roundingMode rmNearestTiesToEven
static const fltSemantics & IEEEhalf()
static const fltSemantics & PPCDoubleDouble()
static APFloat getSNaN(const fltSemantics &Sem, bool Negative=false, const APInt *payload=nullptr)
Factory for SNaN values.
LLVM_ABI opStatus convert(const fltSemantics &ToSemantics, roundingMode RM, bool *losesInfo)
LLVM_ABI double convertToDouble() const
Converts this APFloat to host double value.
void toString(SmallVectorImpl< char > &Str, unsigned FormatPrecision=0, unsigned FormatMaxPadding=3, bool TruncateZero=true) const
const fltSemantics & getSemantics() const
APInt bitcastToAPInt() const
Class for arbitrary precision integers.
LLVM_ABI APInt getLoBits(unsigned numBits) const
Compute an APInt containing numBits lowbits from this APInt.
uint64_t getZExtValue() const
Get zero extended value.
LLVM_ABI APInt getHiBits(unsigned numBits) const
Compute an APInt containing numBits highbits from this APInt.
Abstract interface of slot tracker storage.
virtual ~AbstractSlotTrackerStorage()
const GlobalValueSummary & getAliasee() const
This class represents an incoming formal argument to a Function.
ArrayRef - Represent a constant reference to an array (0 or more elements consecutively in memory),...
size_t size() const
size - Get the array size.
virtual void emitBasicBlockStartAnnot(const BasicBlock *, formatted_raw_ostream &)
emitBasicBlockStartAnnot - This may be implemented to emit a string right after the basic block label...
virtual void emitBasicBlockEndAnnot(const BasicBlock *, formatted_raw_ostream &)
emitBasicBlockEndAnnot - This may be implemented to emit a string right after the basic block.
virtual void emitFunctionAnnot(const Function *, formatted_raw_ostream &)
emitFunctionAnnot - This may be implemented to emit a string right before the start of a function.
virtual void emitInstructionAnnot(const Instruction *, formatted_raw_ostream &)
emitInstructionAnnot - This may be implemented to emit a string right before an instruction is emitte...
virtual void printInfoComment(const Value &, formatted_raw_ostream &)
printInfoComment - This may be implemented to emit a comment to the right of an instruction or global...
virtual ~AssemblyAnnotationWriter()
static LLVM_ABI StringRef getOperationName(BinOp Op)
This class holds the attributes for a particular argument, parameter, function, or return value.
bool hasAttributes() const
Return true if attributes exists in this set.
LLVM_ABI std::string getAsString(bool InAttrGrp=false) const
The Attribute is converted to a string of equivalent mnemonic.
LLVM_ABI Attribute::AttrKind getKindAsEnum() const
Return the attribute's kind as an enum (Attribute::AttrKind).
LLVM_ABI bool isTypeAttribute() const
Return true if the attribute is a type attribute.
LLVM_ABI Type * getValueAsType() const
Return the attribute's value as a Type.
LLVM Basic Block Representation.
const Function * getParent() const
Return the enclosing method, or null if none.
LLVM_ABI void print(raw_ostream &OS, AssemblyAnnotationWriter *AAW=nullptr, bool ShouldPreserveUseListOrder=false, bool IsForDebug=false) const
Print the basic block to an output stream with an optional AssemblyAnnotationWriter.
LLVM_ABI bool isEntryBlock() const
Return true if this is the entry block of the containing function.
LLVM_ABI const Module * getModule() const
Return the module owning the function this basic block belongs to, or nullptr if the function does no...
OperandBundleUse getOperandBundleAt(unsigned Index) const
Return the operand bundle at a specific index.
unsigned getNumOperandBundles() const
Return the number of operand bundles associated with this User.
AttributeList getAttributes() const
Return the attributes for this call.
bool hasOperandBundles() const
Return true if this User has any operand bundles.
LLVM_ABI void print(raw_ostream &OS, bool IsForDebug=false) const
LLVM_ABI void dump() const
@ Largest
The linker will choose the largest COMDAT.
@ SameSize
The data referenced by the COMDAT must be the same size.
@ Any
The linker may choose any COMDAT.
@ NoDeduplicate
No deduplication is performed.
@ ExactMatch
The data referenced by the COMDAT must be the same.
SelectionKind getSelectionKind() const
LLVM_ABI APInt getSignedMin() const
Return the smallest signed value contained in the ConstantRange.
LLVM_ABI APInt getSignedMax() const
Return the largest signed value contained in the ConstantRange.
This is an important base class in LLVM.
LLVM_ABI Constant * getSplatValue(bool AllowPoison=false) const
If all elements of the vector constant have the same value, return that value.
LLVM_ABI Constant * getAggregateElement(unsigned Elt) const
For aggregates (struct/array/vector) return the constant that corresponds to the specified element if...
List of ValueAsMetadata, to be used as an argument to a dbg.value intrinsic.
Basic type, like 'int' or 'float'.
static LLVM_ABI const char * nameTableKindString(DebugNameTableKind PK)
static LLVM_ABI const char * emissionKindString(DebugEmissionKind EK)
A lightweight wrapper around an expression operand.
static LLVM_ABI const char * fixedPointKindString(FixedPointKind)
A pair of DIGlobalVariable and DIExpression.
An imported module (C++ using directive or similar).
Macro Info DWARF-like metadata node.
Represents a module in the programming language, for example, a Clang module, or a Fortran module.
Tagged DWARF-like metadata node.
static LLVM_ABI DIFlags splitFlags(DIFlags Flags, SmallVectorImpl< DIFlags > &SplitFlags)
Split up a flags bitfield.
static LLVM_ABI StringRef getFlagString(DIFlags Flag)
Wrapper structure that holds a language name and its version.
uint32_t getVersion() const
Returns language version. Only valid for versioned language names.
bool hasVersionedName() const
uint16_t getName() const
Returns a versioned or unversioned language name.
String type, Fortran CHARACTER(n)
Subprogram description. Uses SubclassData1.
static LLVM_ABI DISPFlags splitFlags(DISPFlags Flags, SmallVectorImpl< DISPFlags > &SplitFlags)
Split up a flags bitfield for easier printing.
static LLVM_ABI StringRef getFlagString(DISPFlags Flag)
DISPFlags
Debug info subprogram flags.
Type array for a subprogram.
LLVM_ABI void print(raw_ostream &O, bool IsForDebug=false) const
Per-instruction record of debug-info.
LLVM_ABI void dump() const
Instruction * MarkedInstr
Link back to the Instruction that owns this marker.
LLVM_ABI void print(raw_ostream &O, bool IsForDebug=false) const
Implement operator<< on DbgMarker.
LLVM_ABI const BasicBlock * getParent() const
simple_ilist< DbgRecord > StoredDbgRecords
List of DbgRecords, the non-instruction equivalent of llvm.dbg.
Base class for non-instruction debug metadata records that have positions within IR.
DebugLoc getDebugLoc() const
LLVM_ABI void dump() const
DbgMarker * Marker
Marker that this DbgRecord is linked into.
Record of a variable value-assignment, aka a non instruction representation of the dbg....
LocationType getType() const
LLVM_ABI void print(raw_ostream &O, bool IsForDebug=false) const
MDNode * getRawExpression() const
MDNode * getRawAddressExpression() const
Metadata * getRawAssignID() const
MDNode * getRawVariable() const
Metadata * getRawLocation() const
Returns the metadata operand for the first location description.
Metadata * getRawAddress() const
MDNode * getAsMDNode() const
Return this as a bar MDNode.
DenseMapIterator< KeyT, ValueT, KeyInfoT, BucketT > iterator
Intrinsic::ID getIntrinsicID() const LLVM_READONLY
getIntrinsicID - This method returns the ID number of the specified function, or Intrinsic::not_intri...
void print(raw_ostream &OS, AssemblyAnnotationWriter *AAW=nullptr, bool ShouldPreserveUseListOrder=false, bool IsForDebug=false) const
Print the function to an output stream with an optional AssemblyAnnotationWriter.
const Function & getFunction() const
const Argument * const_arg_iterator
LLVM_ABI Value * getBasePtr() const
LLVM_ABI Value * getDerivedPtr() const
Generic tagged DWARF-like metadata node.
const Constant * getAliasee() const
const Constant * getResolver() const
StringRef getSection() const
Get the custom section of this global if it has one.
LLVM_ABI void getAllMetadata(SmallVectorImpl< std::pair< unsigned, MDNode * > > &MDs) const
Appends all metadata attached to this value to MDs, sorting by KindID.
const Comdat * getComdat() const
bool hasSection() const
Check if this global has a custom object file section.
SummaryKind
Sububclass discriminator (for dyn_cast<> et al.)
bool hasPartition() const
static LLVM_ABI GUID getGUIDAssumingExternalLinkage(StringRef GlobalName)
Return a 64-bit global unique ID constructed from the name of a global symbol.
LLVM_ABI const SanitizerMetadata & getSanitizerMetadata() const
bool hasExternalLinkage() const
VisibilityTypes getVisibility() const
bool isImplicitDSOLocal() const
LinkageTypes getLinkage() const
uint64_t GUID
Declare a type to represent a global unique identifier for a global value.
ThreadLocalMode getThreadLocalMode() const
DLLStorageClassTypes
Storage classes of global values for PE targets.
@ DLLExportStorageClass
Function to be accessible from DLL.
@ DLLImportStorageClass
Function to be imported from DLL.
bool hasSanitizerMetadata() const
LLVM_ABI StringRef getPartition() const
Module * getParent()
Get the module that this global value is contained inside of...
PointerType * getType() const
Global values are always pointers.
VisibilityTypes
An enumeration for the kinds of visibility of global values.
@ DefaultVisibility
The GV is visible.
@ HiddenVisibility
The GV is hidden.
@ ProtectedVisibility
The GV is protected.
LLVM_ABI bool isMaterializable() const
If this function's Module is being lazily streamed in functions from disk or some other source,...
UnnamedAddr getUnnamedAddr() const
LinkageTypes
An enumeration for the kinds of linkage for global values.
@ PrivateLinkage
Like Internal, but omit from symbol table.
@ CommonLinkage
Tentative definitions.
@ InternalLinkage
Rename collisions when linking (static functions).
@ LinkOnceAnyLinkage
Keep one copy of function when linking (inline)
@ WeakODRLinkage
Same, but only replaced by something equivalent.
@ ExternalLinkage
Externally visible function.
@ WeakAnyLinkage
Keep one copy of named function when linking (weak)
@ AppendingLinkage
Special purpose, only applies to global arrays.
@ AvailableExternallyLinkage
Available for inspection, not emission.
@ ExternalWeakLinkage
ExternalWeak linkage description.
@ LinkOnceODRLinkage
Same, but only replaced by something equivalent.
DLLStorageClassTypes getDLLStorageClass() const
Type * getValueType() const
const Constant * getInitializer() const
getInitializer - Return the initializer for this global variable.
bool isExternallyInitialized() const
bool hasInitializer() const
Definitions have initializers, declarations don't.
AttributeSet getAttributes() const
Return the attribute set for this global.
std::optional< CodeModel::Model > getCodeModel() const
Get the custom code model of this global if it has one.
MaybeAlign getAlign() const
Returns the alignment of the given variable.
bool isConstant() const
If the value is a global constant, its value is immutable throughout the runtime execution of the pro...
A helper class to return the specified delimiter string after the first invocation of operator String...
LLVM_ABI void printTree(raw_ostream &OS, const Module *M=nullptr) const
Print in tree shape.
LLVM_ABI void dumpTree() const
User-friendly dump in tree shape.
This class implements a map that also provides access to all stored values in a deterministic order.
Manage lifetime of a slot tracker for printing IR.
const Module * getModule() const
ModuleSlotTracker(SlotTracker &Machine, const Module *M, const Function *F=nullptr)
Wrap a preinitialized SlotTracker.
virtual ~ModuleSlotTracker()
Destructor to clean up storage.
std::vector< std::pair< unsigned, const MDNode * > > MachineMDNodeListType
int getLocalSlot(const Value *V)
Return the slot number of the specified local value.
void collectMDNodes(MachineMDNodeListType &L, unsigned LB, unsigned UB) const
SlotTracker * getMachine()
Lazily creates a slot tracker.
void setProcessHook(std::function< void(AbstractSlotTrackerStorage *, const Module *, bool)>)
void incorporateFunction(const Function &F)
Incorporate the given function.
Class to hold module path string table and global value map, and encapsulate methods for operating on...
static constexpr const char * getRegularLTOModuleName()
LLVM_ABI void dump() const
Dump to stderr (for debugging).
LLVM_ABI void print(raw_ostream &OS, bool IsForDebug=false) const
Print to an output stream.
A Module instance is used to store all the information related to an LLVM module.
iterator_range< alias_iterator > aliases()
iterator_range< global_iterator > globals()
void print(raw_ostream &OS, AssemblyAnnotationWriter *AAW, bool ShouldPreserveUseListOrder=false, bool IsForDebug=false) const
Print the module to an output stream with an optional AssemblyAnnotationWriter.
void dump() const
Dump the module to stderr (for debugging).
LLVM_ABI void dump() const
LLVM_ABI StringRef getName() const
LLVM_ABI void print(raw_ostream &ROS, bool IsForDebug=false) const
iterator_range< op_iterator > operands()
unsigned getAddressSpace() const
Return the address space of the Pointer type.
This class provides computation of slot numbers for LLVM Assembly writing.
DenseMap< const Value *, unsigned > ValueMap
ValueMap - A mapping of Values to slot numbers.
int getMetadataSlot(const MDNode *N) override
getMetadataSlot - Get the slot number of a MDNode.
~SlotTracker() override=default
int getTypeIdCompatibleVtableSlot(StringRef Id)
int getModulePathSlot(StringRef Path)
unsigned mdn_size() const
SlotTracker(const SlotTracker &)=delete
void purgeFunction()
After calling incorporateFunction, use this method to remove the most recently incorporated function ...
int getTypeIdSlot(StringRef Id)
void initializeIfNeeded()
These functions do the actual initialization.
int getGlobalSlot(const GlobalValue *V)
getGlobalSlot - Get the slot number of a global value.
const Function * getFunction() const
unsigned getNextMetadataSlot() override
DenseMap< GlobalValue::GUID, unsigned >::iterator guid_iterator
GUID map iterators.
void incorporateFunction(const Function *F)
If you'd like to deal with a function instead of just a module, use this method to get its data into ...
int getLocalSlot(const Value *V)
Return the slot number of the specified value in it's type plane.
int getAttributeGroupSlot(AttributeSet AS)
SlotTracker(const Module *M, bool ShouldInitializeAllMetadata=false)
Construct from a module.
void createMetadataSlot(const MDNode *N) override
getMetadataSlot - Get the slot number of a MDNode.
void setProcessHook(std::function< void(AbstractSlotTrackerStorage *, const Module *, bool)>)
DenseMap< const MDNode *, unsigned >::iterator mdn_iterator
MDNode map iterators.
SlotTracker & operator=(const SlotTracker &)=delete
int getGUIDSlot(GlobalValue::GUID GUID)
int initializeIndexIfNeeded()
DenseMap< AttributeSet, unsigned >::iterator as_iterator
AttributeSet map iterators.
std::pair< iterator, bool > insert(PtrType Ptr)
Inserts Ptr if and only if there is no element in the container equal to Ptr.
SmallString - A SmallString is just a SmallVector with methods and accessors that make it work better...
reference emplace_back(ArgTypes &&... Args)
void push_back(const T &Elt)
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
StringMap - This is an unconventional map that is specialized for handling keys that are "strings",...
StringRef - Represent a constant reference to a string, i.e.
constexpr bool empty() const
empty - Check if the string is empty.
ArrayRef< Type * > elements() const
unsigned getNumElements() const
Random access to the elements.
bool isLiteral() const
Return true if this type is uniqued by structural equivalence, false if it is a struct definition.
bool isOpaque() const
Return true if this is a type with an identity that has no body specified yet.
LLVM_ABI StringRef getName() const
Return the name for this struct type if it has an identity.
ArrayRef< Type * > type_params() const
Return the type parameters for this particular target extension type.
ArrayRef< unsigned > int_params() const
Return the integer parameters for this particular target extension type.
TypeFinder - Walk over a module, identifying all of the types that are used by the module.
void run(const Module &M, bool onlyNamed)
The instances of the Type class are immutable: once they are created, they are never changed.
LLVM_ABI unsigned getPointerAddressSpace() const
Get the address space of this pointer or pointer vector type.
LLVM_ABI StringRef getTargetExtName() const
Type(LLVMContext &C, TypeID tid)
LLVM_ABI void dump() const
LLVM_ABI void print(raw_ostream &O, bool IsForDebug=false, bool NoDetails=false) const
Print the current type.
TypeID getTypeID() const
Return the type id for the type.
Type * getElementType() const
unsigned getAddressSpace() const
Return the address space of the Pointer type.
A Use represents the edge between a Value definition and its users.
LLVM Value Representation.
Type * getType() const
All values are typed, get the type of this value.
LLVM_ABI void print(raw_ostream &O, bool IsForDebug=false) const
Implement operator<< on Value.
LLVM_ABI void getAllMetadata(SmallVectorImpl< std::pair< unsigned, MDNode * > > &MDs) const
Appends all metadata attached to this value to MDs, sorting by KindID.
iterator_range< user_iterator > users()
LLVM_ABI void printAsOperand(raw_ostream &O, bool PrintType=true, const Module *M=nullptr) const
Print the name of this Value out to the specified raw_ostream.
iterator_range< use_iterator > uses()
LLVM_ABI StringRef getName() const
Return a constant reference to the value's name.
LLVM_ABI void dump() const
Support for debugging, callable in GDB: V->dump()
This class implements an extremely fast bulk output stream that can only output to a stream.
raw_ostream & indent(unsigned NumSpaces)
indent - Insert 'NumSpaces' spaces.
LLVM_ABI StringRef SourceLanguageNameString(SourceLanguageName Lang)
LLVM_ABI StringRef EnumKindString(unsigned EnumKind)
LLVM_ABI StringRef LanguageString(unsigned Language)
LLVM_ABI StringRef AttributeEncodingString(unsigned Encoding)
LLVM_ABI StringRef ConventionString(unsigned Convention)
LLVM_ABI StringRef MacinfoString(unsigned Encoding)
LLVM_ABI StringRef OperationEncodingString(unsigned Encoding)
LLVM_ABI StringRef TagString(unsigned Tag)
This provides a very simple, boring adaptor for a begin and end iterator into a range type.
This file contains the declaration of the Comdat class, which represents a single COMDAT in LLVM.
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
constexpr char Attrs[]
Key for Kernel::Metadata::mAttrs.
unsigned ID
LLVM IR allows to use arbitrary numbers as calling convention identifiers.
@ AArch64_VectorCall
Used between AArch64 Advanced SIMD functions.
@ X86_64_SysV
The C convention as specified in the x86-64 supplement to the System V ABI, used on most non-Windows ...
@ RISCV_VectorCall
Calling convention used for RISC-V V-extension.
@ AMDGPU_CS
Used for Mesa/AMDPAL compute shaders.
@ AMDGPU_VS
Used for Mesa vertex shaders, or AMDPAL last shader stage before rasterization (vertex shader if tess...
@ AVR_SIGNAL
Used for AVR signal routines.
@ Swift
Calling convention for Swift.
@ AMDGPU_KERNEL
Used for AMDGPU code object kernels.
@ AArch64_SVE_VectorCall
Used between AArch64 SVE functions.
@ ARM_APCS
ARM Procedure Calling Standard (obsolete, but still used on some targets).
@ CHERIoT_CompartmentCall
Calling convention used for CHERIoT when crossing a protection boundary.
@ CFGuard_Check
Special calling convention on Windows for calling the Control Guard Check ICall funtion.
@ AVR_INTR
Used for AVR interrupt routines.
@ PreserveMost
Used for runtime calls that preserves most registers.
@ AnyReg
OBSOLETED - Used for stack based JavaScript calls.
@ AMDGPU_Gfx
Used for AMD graphics targets.
@ DUMMY_HHVM
Placeholders for HHVM calling conventions (deprecated, removed).
@ AMDGPU_CS_ChainPreserve
Used on AMDGPUs to give the middle-end more control over argument placement.
@ AMDGPU_HS
Used for Mesa/AMDPAL hull shaders (= tessellation control shaders).
@ ARM_AAPCS
ARM Architecture Procedure Calling Standard calling convention (aka EABI).
@ CHERIoT_CompartmentCallee
Calling convention used for the callee of CHERIoT_CompartmentCall.
@ AMDGPU_GS
Used for Mesa/AMDPAL geometry shaders.
@ AArch64_SME_ABI_Support_Routines_PreserveMost_From_X2
Preserve X2-X15, X19-X29, SP, Z0-Z31, P0-P15.
@ CHERIoT_LibraryCall
Calling convention used for CHERIoT for cross-library calls to a stateless compartment.
@ CXX_FAST_TLS
Used for access functions.
@ X86_INTR
x86 hardware interrupt context.
@ AArch64_SME_ABI_Support_Routines_PreserveMost_From_X0
Preserve X0-X13, X19-X29, SP, Z0-Z31, P0-P15.
@ AMDGPU_CS_Chain
Used on AMDGPUs to give the middle-end more control over argument placement.
@ GHC
Used by the Glasgow Haskell Compiler (GHC).
@ AMDGPU_PS
Used for Mesa/AMDPAL pixel shaders.
@ Cold
Attempts to make code in the caller as efficient as possible under the assumption that the call is no...
@ AArch64_SME_ABI_Support_Routines_PreserveMost_From_X1
Preserve X1-X15, X19-X29, SP, Z0-Z31, P0-P15.
@ X86_ThisCall
Similar to X86_StdCall.
@ PTX_Device
Call to a PTX device function.
@ SPIR_KERNEL
Used for SPIR kernel functions.
@ PreserveAll
Used for runtime calls that preserves (almost) all registers.
@ X86_StdCall
stdcall is mostly used by the Win32 API.
@ SPIR_FUNC
Used for SPIR non-kernel device functions.
@ Fast
Attempts to make calls as fast as possible (e.g.
@ MSP430_INTR
Used for MSP430 interrupt routines.
@ X86_VectorCall
MSVC calling convention that passes vectors and vector aggregates in SSE registers.
@ Intel_OCL_BI
Used for Intel OpenCL built-ins.
@ PreserveNone
Used for runtime calls that preserves none general registers.
@ AMDGPU_ES
Used for AMDPAL shader stage before geometry shader if geometry is in use.
@ Tail
Attemps to make calls as fast as possible while guaranteeing that tail call optimization can always b...
@ Win64
The C convention as implemented on Windows/x86-64 and AArch64.
@ PTX_Kernel
Call to a PTX kernel. Passes all arguments in parameter space.
@ SwiftTail
This follows the Swift calling convention in how arguments are passed but guarantees tail calls will ...
@ GRAAL
Used by GraalVM. Two additional registers are reserved.
@ AMDGPU_LS
Used for AMDPAL vertex shader if tessellation is in use.
@ ARM_AAPCS_VFP
Same as ARM_AAPCS, but uses hard floating point ABI.
@ X86_RegCall
Register calling convention used for parameters transfer optimization.
@ M68k_RTD
Used for M68k rtd-based CC (similar to X86's stdcall).
@ C
The default llvm calling convention, compatible with C.
@ X86_FastCall
'fast' analog of X86_StdCall.
LLVM_ABI void printImmArg(ID IID, unsigned ArgIdx, raw_ostream &OS, const Constant *ImmArgVal)
Print the argument info for the arguments with ArgInfo.
LLVM_ABI bool hasPrettyPrintedArgs(ID id)
Returns true if the intrinsic has pretty printed immediate arguments.
@ System
Synchronized with respect to all concurrently executing threads.
initializer< Ty > init(const Ty &Val)
@ DW_OP_LLVM_convert
Only used in LLVM metadata.
Context & getContext() const
This is an optimization pass for GlobalISel generic memory operations.
void dump(const SparseBitVector< ElementSize > &LHS, raw_ostream &out)
FunctionAddr VTableAddr Value
bool all_of(R &&range, UnaryPredicate P)
Provide wrappers to std::all_of which take ranges instead of having to pass begin/end explicitly.
Printable print(const GCNRegPressure &RP, const GCNSubtarget *ST=nullptr, unsigned DynamicVGPRBlockSize=0)
detail::zippy< detail::zip_first, T, U, Args... > zip_equal(T &&t, U &&u, Args &&...args)
zip iterator that assumes that all iteratees have the same length.
InterleavedRange< Range > interleaved(const Range &R, StringRef Separator=", ", StringRef Prefix="", StringRef Suffix="")
Output range R as a sequence of interleaved elements.
const char * getHotnessName(CalleeInfo::HotnessType HT)
decltype(auto) dyn_cast(const From &Val)
dyn_cast<X> - Return the argument parameter cast to the specified type.
auto dyn_cast_if_present(const Y &Val)
dyn_cast_if_present<X> - Functionally identical to dyn_cast, except that a null (or none in the case ...
iterator_range< T > make_range(T x, T y)
Convenience function for iterating over sub-ranges.
LLVM_ABI void printEscapedString(StringRef Name, raw_ostream &Out)
Print each character of the specified string, escaping it if it is not printable or if it is an escap...
constexpr auto equal_to(T &&Arg)
Functor variant of std::equal_to that can be used as a UnaryPredicate in functional algorithms like a...
const char * toIRString(AtomicOrdering ao)
String used by LLVM IR to represent atomic ordering.
auto dyn_cast_or_null(const Y &Val)
void sort(IteratorTy Start, IteratorTy End)
LLVM_ABI raw_ostream & dbgs()
dbgs() - This returns a reference to a raw_ostream for debugging messages.
char hexdigit(unsigned X, bool LowerCase=false)
hexdigit - Return the hexadecimal character for the given number X (which should be less than 16).
bool isDigit(char C)
Checks if character C is one of the 10 decimal digits.
FunctionAddr VTableAddr Count
bool is_sorted(R &&Range, Compare C)
Wrapper function around std::is_sorted to check if elements in a range R are sorted with respect to a...
class LLVM_GSL_OWNER SmallVector
Forward declaration of SmallVector so that calculateSmallVectorDefaultInlinedElements can reference s...
FormattedNumber format_hex(uint64_t N, unsigned Width, bool Upper=false)
format_hex - Output N as a fixed width hexadecimal.
FormattedNumber format_hex_no_prefix(uint64_t N, unsigned Width, bool Upper=false)
format_hex_no_prefix - Output N as a fixed width hexadecimal.
bool isa(const From &Val)
isa<X> - Return true if the parameter to the template is an instance of one of the template type argu...
constexpr int PoisonMaskElem
AtomicOrdering
Atomic ordering for LLVM's memory model.
@ Ref
The access may reference the value stored in memory.
DWARFExpression::Operation Op
ArrayRef(const T &OneElt) -> ArrayRef< T >
std::string toString(const APInt &I, unsigned Radix, bool Signed, bool formatAsCLiteral=false, bool UpperCase=true, bool InsertSeparators=false)
LLVM_ABI Printable printBasicBlock(const BasicBlock *BB)
Print BasicBlock BB as an operand or print "<nullptr>" if BB is a nullptr.
decltype(auto) cast(const From &Val)
cast<X> - Return the argument parameter cast to the specified type.
auto predecessors(const MachineBasicBlock *BB)
bool pred_empty(const BasicBlock *BB)
std::vector< TypeIdOffsetVtableInfo > TypeIdCompatibleVtableInfo
List of vtable definitions decorated by a particular type identifier, and their corresponding offsets...
@ Default
The result values are uniform if and only if all operands are uniform.
static auto filterDbgVars(iterator_range< simple_ilist< DbgRecord >::iterator > R)
Filter the DbgRecord range to DbgVariableRecord types only and downcast.
LLVM_ABI void printLLVMNameWithoutPrefix(raw_ostream &OS, StringRef Name)
Print out a name of an LLVM value without any prefixes.
A single checksum, represented by a Kind and a Value (a string).
T Value
The string value of the checksum.
StringRef getKindAsString() const
std::vector< ConstVCall > TypeCheckedLoadConstVCalls
std::vector< VFuncId > TypeCheckedLoadVCalls
std::vector< ConstVCall > TypeTestAssumeConstVCalls
List of virtual calls made by this function using (respectively) llvm.assume(llvm....
std::vector< GlobalValue::GUID > TypeTests
List of type identifiers used by this function in llvm.type.test intrinsics referenced by something o...
std::vector< VFuncId > TypeTestAssumeVCalls
List of virtual calls made by this function using (respectively) llvm.assume(llvm....
unsigned DSOLocal
Indicates that the linker resolved the symbol to a definition from within the same linkage unit.
unsigned CanAutoHide
In the per-module summary, indicates that the global value is linkonce_odr and global unnamed addr (s...
unsigned ImportType
This field is written by the ThinLTO indexing step to postlink combined summary.
unsigned NotEligibleToImport
Indicate if the global value cannot be imported (e.g.
unsigned Linkage
The linkage type of the associated global value.
unsigned Visibility
Indicates the visibility.
unsigned Live
In per-module summary, indicate that the global value must be considered a live root for index-based ...
StringRef getTagName() const
Return the tag of this operand bundle as a string.
A utility class that uses RAII to save and restore the value of a variable.
std::map< uint64_t, WholeProgramDevirtResolution > WPDRes
Mapping from byte offset to whole-program devirt resolution for that (typeid, byte offset) pair.
Kind
Specifies which kind of type check we should emit for this byte array.
@ Unknown
Unknown (analysis not performed, don't lower)
@ Single
Single element (last example in "Short Inline Bit Vectors")
@ Inline
Inlined bit vector ("Short Inline Bit Vectors")
@ Unsat
Unsatisfiable type (i.e. no global has this type metadata)
@ AllOnes
All-ones bit vector ("Eliminating Bit Vector Checks for All-Ones Bit Vectors")
@ ByteArray
Test a byte array (first example)
unsigned SizeM1BitWidth
Range of size-1 expressed as a bit width.
enum llvm::TypeTestResolution::Kind TheKind
@ UniformRetVal
Uniform return value optimization.
@ VirtualConstProp
Virtual constant propagation.
@ UniqueRetVal
Unique return value optimization.
@ Indir
Just do a regular virtual call.
enum llvm::WholeProgramDevirtResolution::Kind TheKind
std::map< std::vector< uint64_t >, ByArg > ResByArg
Resolutions for calls with all constant integer arguments (excluding the first argument,...
std::string SingleImplName
@ SingleImpl
Single implementation devirtualization.
@ Indir
Just do a regular virtual call.
@ BranchFunnel
When retpoline mitigation is enabled, use a branch funnel that is defined in the merged module.
Function object to check whether the second component of a container supported by std::get (like std:...