31#include "llvm/Config/llvm-config.h"
95 cl::desc(
"Print addresses of instructions when dumping"));
99 cl::desc(
"Pretty print debug locations of instructions when dumping"));
103 cl::desc(
"Pretty print perf data (branch weights, etc) when dumping"));
122 return VAM->getValue();
135 for (
const Value *
Op :
C->operands())
142 unsigned ID = OM.size() + 1;
149 auto orderConstantValue = [&OM](
const Value *V) {
154 auto OrderConstantFromMetadata = [&](
Metadata *MD) {
156 orderConstantValue(VAM->getValue());
158 for (
const auto *VAM : AL->getArgs())
159 orderConstantValue(VAM->getValue());
164 if (
G.hasInitializer())
180 for (
const Use &U :
F.operands())
186 if (
F.isDeclaration())
199 OrderConstantFromMetadata(DVR.getRawLocation());
200 if (DVR.isDbgAssign())
201 OrderConstantFromMetadata(DVR.getRawAddress());
204 for (
const Value *
Op :
I.operands()) {
217static std::vector<unsigned>
220 using Entry = std::pair<const Use *, unsigned>;
224 if (OM.lookup(U.getUser()))
225 List.
push_back(std::make_pair(&U, List.size()));
236 ID = OM.lookup(BA->getBasicBlock());
237 llvm::sort(List, [&](
const Entry &L,
const Entry &R) {
238 const Use *LU = L.first;
239 const Use *RU = R.first;
243 auto LID = OM.lookup(LU->getUser());
244 auto RID = OM.lookup(RU->getUser());
264 return LU->getOperandNo() < RU->getOperandNo();
265 return LU->getOperandNo() > RU->getOperandNo();
273 std::vector<unsigned> Shuffle(List.size());
274 for (
size_t I = 0,
E = List.size();
I !=
E; ++
I)
275 Shuffle[
I] = List[
I].second;
282 for (
const auto &Pair : OM) {
283 const Value *V = Pair.first;
284 if (V->use_empty() || std::next(V->use_begin()) == V->use_end())
287 std::vector<unsigned> Shuffle =
294 F =
I->getFunction();
299 ULOM[
F][V] = std::move(Shuffle);
306 return MA->getParent() ? MA->getParent()->getParent() :
nullptr;
309 return BB->getParent() ? BB->getParent()->getParent() :
nullptr;
312 const Function *M =
I->getParent() ?
I->getParent()->getParent() :
nullptr;
313 return M ? M->getParent() :
nullptr;
317 return GV->getParent();
342 default: Out <<
"cc" << cc;
break;
365 Out <<
"aarch64_sve_vector_pcs";
368 Out <<
"aarch64_sme_preservemost_from_x0";
371 Out <<
"aarch64_sme_preservemost_from_x1";
374 Out <<
"aarch64_sme_preservemost_from_x2";
402 Out <<
"amdgpu_cs_chain";
405 Out <<
"amdgpu_cs_chain_preserve";
410 Out <<
"amdgpu_gfx_whole_wave";
414 Out <<
"riscv_vector_cc";
416#define CC_VLS_CASE(ABI_VLEN) \
417 case CallingConv::RISCV_VLSCall_##ABI_VLEN: \
418 Out << "riscv_vls_cc(" #ABI_VLEN ")"; \
445 assert(!Name.empty() &&
"Cannot get empty name!");
448 bool NeedsQuotes = isdigit(
static_cast<unsigned char>(Name[0]));
450 for (
unsigned char C : Name) {
455 if (!isalnum(
C) &&
C !=
'-' &&
C !=
'.' &&
C !=
'_') {
509 Out << Mask.size() <<
" x i32> ";
510 bool FirstElt =
true;
511 if (
all_of(Mask, [](
int Elt) {
return Elt == 0; })) {
512 Out <<
"zeroinitializer";
517 for (
int Elt : Mask) {
536 TypePrinting(
const Module *M =
nullptr) : DeferredM(
M) {}
538 TypePrinting(
const TypePrinting &) =
delete;
539 TypePrinting &operator=(
const TypePrinting &) =
delete;
542 TypeFinder &getNamedTypes();
545 std::vector<StructType *> &getNumberedTypes();
551 void printStructBody(StructType *Ty, raw_ostream &OS);
554 void incorporateTypes();
559 TypeFinder NamedTypes;
562 DenseMap<StructType *, unsigned> Type2Number;
564 std::vector<StructType *> NumberedTypes;
574std::vector<StructType *> &TypePrinting::getNumberedTypes() {
580 if (NumberedTypes.size() == Type2Number.size())
581 return NumberedTypes;
583 NumberedTypes.resize(Type2Number.size());
584 for (
const auto &
P : Type2Number) {
585 assert(
P.second < NumberedTypes.size() &&
"Didn't get a dense numbering?");
586 assert(!NumberedTypes[
P.second] &&
"Didn't get a unique numbering?");
587 NumberedTypes[
P.second] =
P.first;
589 return NumberedTypes;
592bool TypePrinting::empty() {
594 return NamedTypes.
empty() && Type2Number.empty();
597void TypePrinting::incorporateTypes() {
601 NamedTypes.
run(*DeferredM,
false);
606 unsigned NextNumber = 0;
608 std::vector<StructType *>::iterator NextToUse = NamedTypes.
begin();
609 for (StructType *STy : NamedTypes) {
611 if (STy->isLiteral())
614 if (STy->getName().empty())
615 Type2Number[STy] = NextNumber++;
620 NamedTypes.erase(NextToUse, NamedTypes.end());
625void TypePrinting::print(
Type *Ty, raw_ostream &OS) {
627 case Type::VoidTyID: OS <<
"void";
return;
628 case Type::HalfTyID: OS <<
"half";
return;
629 case Type::BFloatTyID: OS <<
"bfloat";
return;
630 case Type::FloatTyID: OS <<
"float";
return;
631 case Type::DoubleTyID: OS <<
"double";
return;
632 case Type::X86_FP80TyID: OS <<
"x86_fp80";
return;
633 case Type::FP128TyID: OS <<
"fp128";
return;
634 case Type::PPC_FP128TyID: OS <<
"ppc_fp128";
return;
635 case Type::LabelTyID: OS <<
"label";
return;
636 case Type::MetadataTyID:
639 case Type::X86_AMXTyID: OS <<
"x86_amx";
return;
640 case Type::TokenTyID: OS <<
"token";
return;
641 case Type::IntegerTyID:
642 OS << 'i' << cast<IntegerType>(Ty)->getBitWidth();
645 case Type::FunctionTyID: {
647 print(FTy->getReturnType(), OS);
650 for (
Type *Ty : FTy->params()) {
659 case Type::StructTyID: {
663 return printStructBody(STy, OS);
669 const auto I = Type2Number.find(STy);
670 if (
I != Type2Number.end())
671 OS <<
'%' <<
I->second;
673 OS <<
"%\"type " << STy <<
'\"';
676 case Type::PointerTyID: {
683 case Type::ArrayTyID: {
685 OS <<
'[' << ATy->getNumElements() <<
" x ";
686 print(ATy->getElementType(), OS);
690 case Type::FixedVectorTyID:
691 case Type::ScalableVectorTyID: {
693 ElementCount
EC = PTy->getElementCount();
697 OS <<
EC.getKnownMinValue() <<
" x ";
698 print(PTy->getElementType(), OS);
702 case Type::TypedPointerTyID: {
708 case Type::TargetExtTyID:
715 Inner->print(OS,
false,
true);
718 OS <<
", " << IntParam;
725void TypePrinting::printStructBody(StructType *STy, raw_ostream &OS) {
769 const Function* TheFunction =
nullptr;
770 bool FunctionProcessed =
false;
771 bool ShouldInitializeAllMetadata;
776 ProcessFunctionHookFn;
791 unsigned mdnNext = 0;
799 unsigned ModulePathNext = 0;
803 unsigned GUIDNext = 0;
807 unsigned TypeIdNext = 0;
812 unsigned TypeIdCompatibleVtableNext = 0;
821 bool ShouldInitializeAllMetadata =
false);
829 bool ShouldInitializeAllMetadata =
false);
846 void createMetadataSlot(
const MDNode *
N)
override;
850 int getLocalSlot(
const Value *V);
852 int getMetadataSlot(
const MDNode *
N)
override;
857 int getTypeIdCompatibleVtableSlot(
StringRef Id);
863 FunctionProcessed =
false;
871 void purgeFunction();
878 unsigned mdn_size()
const {
return mdnMap.size(); }
886 unsigned as_size()
const {
return asMap.size(); }
902 void CreateMetadataSlot(
const MDNode *
N);
905 void CreateFunctionSlot(
const Value *V);
910 inline void CreateModulePathSlot(
StringRef Path);
913 void CreateTypeIdCompatibleVtableSlot(
StringRef Id);
917 void processModule();
925 void processGlobalObjectMetadata(
const GlobalObject &GO);
928 void processFunctionMetadata(
const Function &
F);
934 void processDbgRecordMetadata(
const DbgRecord &DVR);
941 : M(M), F(F), Machine(&Machine) {}
944 bool ShouldInitializeAllMetadata)
945 : ShouldCreateStorage(M),
946 ShouldInitializeAllMetadata(ShouldInitializeAllMetadata), M(M) {}
951 if (!ShouldCreateStorage)
954 ShouldCreateStorage =
false;
956 std::make_unique<SlotTracker>(M, ShouldInitializeAllMetadata);
957 Machine = MachineStorage.get();
958 if (ProcessModuleHookFn)
959 Machine->setProcessHook(ProcessModuleHookFn);
960 if (ProcessFunctionHookFn)
961 Machine->setProcessHook(ProcessFunctionHookFn);
974 Machine->purgeFunction();
975 Machine->incorporateFunction(&F);
980 assert(F &&
"No function incorporated");
981 return Machine->getLocalSlot(V);
987 ProcessModuleHookFn = Fn;
993 ProcessFunctionHookFn = Fn;
1023#define ST_DEBUG(X) dbgs() << X
1031 : TheModule(M), ShouldInitializeAllMetadata(ShouldInitializeAllMetadata) {}
1036 : TheModule(
F ?
F->
getParent() : nullptr), TheFunction(
F),
1037 ShouldInitializeAllMetadata(ShouldInitializeAllMetadata) {}
1040 : TheModule(nullptr), ShouldInitializeAllMetadata(
false), TheIndex(Index) {}
1045 TheModule =
nullptr;
1048 if (TheFunction && !FunctionProcessed)
1055 int NumSlots = processIndex();
1062void SlotTracker::processModule() {
1063 ST_DEBUG(
"begin processModule!\n");
1068 CreateModuleSlot(&Var);
1069 processGlobalObjectMetadata(Var);
1070 auto Attrs = Var.getAttributes();
1071 if (Attrs.hasAttributes())
1072 CreateAttributeSetSlot(Attrs);
1077 CreateModuleSlot(&
A);
1080 for (
const GlobalIFunc &
I : TheModule->ifuncs()) {
1082 CreateModuleSlot(&
I);
1083 processGlobalObjectMetadata(
I);
1087 for (
const NamedMDNode &NMD : TheModule->named_metadata()) {
1088 for (
const MDNode *
N : NMD.operands())
1089 CreateMetadataSlot(
N);
1092 for (
const Function &
F : *TheModule) {
1095 CreateModuleSlot(&
F);
1097 if (ShouldInitializeAllMetadata)
1098 processFunctionMetadata(
F);
1102 AttributeSet FnAttrs =
F.getAttributes().getFnAttrs();
1104 CreateAttributeSetSlot(FnAttrs);
1107 if (ProcessModuleHookFn)
1108 ProcessModuleHookFn(
this, TheModule, ShouldInitializeAllMetadata);
1114void SlotTracker::processFunction() {
1115 ST_DEBUG(
"begin processFunction!\n");
1119 if (!ShouldInitializeAllMetadata)
1120 processFunctionMetadata(*TheFunction);
1124 AE = TheFunction->arg_end(); AI != AE; ++AI)
1126 CreateFunctionSlot(&*AI);
1128 ST_DEBUG(
"Inserting Instructions:\n");
1131 for (
auto &BB : *TheFunction) {
1133 CreateFunctionSlot(&BB);
1135 for (
auto &
I : BB) {
1136 if (!
I.getType()->isVoidTy() && !
I.hasName())
1137 CreateFunctionSlot(&
I);
1144 if (
Attrs.hasAttributes())
1145 CreateAttributeSetSlot(Attrs);
1150 if (ProcessFunctionHookFn)
1151 ProcessFunctionHookFn(
this, TheFunction, ShouldInitializeAllMetadata);
1153 FunctionProcessed =
true;
1155 ST_DEBUG(
"end processFunction!\n");
1159int SlotTracker::processIndex() {
1166 std::vector<StringRef> ModulePaths;
1167 for (
auto &[ModPath,
_] : TheIndex->modulePaths())
1168 ModulePaths.push_back(ModPath);
1170 for (
auto &ModPath : ModulePaths)
1171 CreateModulePathSlot(ModPath);
1174 GUIDNext = ModulePathNext;
1176 for (
auto &GlobalList : *TheIndex)
1177 CreateGUIDSlot(GlobalList.first);
1180 TypeIdCompatibleVtableNext = GUIDNext;
1181 for (
auto &TId : TheIndex->typeIdCompatibleVtableMap())
1182 CreateTypeIdCompatibleVtableSlot(TId.first);
1185 TypeIdNext = TypeIdCompatibleVtableNext;
1186 for (
const auto &TID : TheIndex->typeIds())
1187 CreateTypeIdSlot(TID.second.first);
1193void SlotTracker::processGlobalObjectMetadata(
const GlobalObject &GO) {
1196 for (
auto &MD : MDs)
1197 CreateMetadataSlot(MD.second);
1200void SlotTracker::processFunctionMetadata(
const Function &
F) {
1201 processGlobalObjectMetadata(
F);
1202 for (
auto &BB :
F) {
1203 for (
auto &
I : BB) {
1204 for (
const DbgRecord &DR :
I.getDbgRecordRange())
1205 processDbgRecordMetadata(DR);
1206 processInstructionMetadata(
I);
1211void SlotTracker::processDbgRecordMetadata(
const DbgRecord &DR) {
1222 CreateMetadataSlot(
Empty);
1223 if (DVR->getRawVariable())
1224 CreateMetadataSlot(DVR->getRawVariable());
1225 if (DVR->isDbgAssign()) {
1226 if (
auto *AssignID = DVR->getRawAssignID())
1229 CreateMetadataSlot(
Empty);
1232 CreateMetadataSlot(DLR->getRawLabel());
1240void SlotTracker::processInstructionMetadata(
const Instruction &
I) {
1243 if (Function *
F = CI->getCalledFunction())
1244 if (
F->isIntrinsic())
1245 for (
auto &
Op :
I.operands())
1248 CreateMetadataSlot(
N);
1252 I.getAllMetadata(MDs);
1253 for (
auto &MD : MDs)
1254 CreateMetadataSlot(MD.second);
1261 ST_DEBUG(
"begin purgeFunction!\n");
1263 TheFunction =
nullptr;
1264 FunctionProcessed =
false;
1275 return MI == mMap.end() ? -1 : (int)
MI->second;
1281 ProcessModuleHookFn = Fn;
1287 ProcessFunctionHookFn = Fn;
1300 return MI == mdnMap.end() ? -1 : (int)
MI->second;
1311 return FI == fMap.end() ? -1 : (int)FI->second;
1320 return AI == asMap.end() ? -1 : (int)AI->second;
1328 auto I = ModulePathMap.find(Path);
1329 return I == ModulePathMap.end() ? -1 : (int)
I->second;
1338 return I == GUIDMap.end() ? -1 : (int)
I->second;
1346 auto I = TypeIdMap.find(Id);
1347 return I == TypeIdMap.end() ? -1 : (int)
I->second;
1355 auto I = TypeIdCompatibleVtableMap.find(Id);
1356 return I == TypeIdCompatibleVtableMap.end() ? -1 : (int)
I->second;
1360void SlotTracker::CreateModuleSlot(
const GlobalValue *V) {
1361 assert(V &&
"Can't insert a null Value into SlotTracker!");
1362 assert(!V->getType()->isVoidTy() &&
"Doesn't need a slot!");
1363 assert(!V->hasName() &&
"Doesn't need a slot!");
1365 unsigned DestSlot = mNext++;
1368 ST_DEBUG(
" Inserting value [" << V->getType() <<
"] = " << V <<
" slot=" <<
1378void SlotTracker::CreateFunctionSlot(
const Value *V) {
1379 assert(!V->getType()->isVoidTy() && !V->hasName() &&
"Doesn't need a slot!");
1381 unsigned DestSlot = fNext++;
1385 ST_DEBUG(
" Inserting value [" << V->getType() <<
"] = " << V <<
" slot=" <<
1386 DestSlot <<
" [o]\n");
1390void SlotTracker::CreateMetadataSlot(
const MDNode *
N) {
1391 assert(
N &&
"Can't insert a null Value into SlotTracker!");
1397 unsigned DestSlot = mdnNext;
1398 if (!mdnMap.insert(std::make_pair(
N, DestSlot)).second)
1403 for (
unsigned i = 0, e =
N->getNumOperands(); i != e; ++i)
1405 CreateMetadataSlot(
Op);
1408void SlotTracker::CreateAttributeSetSlot(
AttributeSet AS) {
1411 if (asMap.try_emplace(AS, asNext).second)
1416void SlotTracker::CreateModulePathSlot(
StringRef Path) {
1417 ModulePathMap[
Path] = ModulePathNext++;
1422 GUIDMap[
GUID] = GUIDNext++;
1426void SlotTracker::CreateTypeIdSlot(
StringRef Id) {
1427 TypeIdMap[
Id] = TypeIdNext++;
1431void SlotTracker::CreateTypeIdCompatibleVtableSlot(
StringRef Id) {
1432 TypeIdCompatibleVtableMap[
Id] = TypeIdCompatibleVtableNext++;
1437struct AsmWriterContext {
1438 TypePrinting *TypePrinter =
nullptr;
1439 SlotTracker *
Machine =
nullptr;
1442 AsmWriterContext(TypePrinting *TP, SlotTracker *ST,
const Module *M =
nullptr)
1445 static AsmWriterContext &getEmpty() {
1446 static AsmWriterContext EmptyCtx(
nullptr,
nullptr);
1452 virtual void onWriteMetadataAsOperand(
const Metadata *) {}
1454 virtual ~AsmWriterContext() =
default;
1463 AsmWriterContext &WriterCtx);
1466 AsmWriterContext &WriterCtx,
1467 bool FromValue =
false);
1471 Out << FPO->getFastMathFlags();
1475 if (OBO->hasNoUnsignedWrap())
1477 if (OBO->hasNoSignedWrap())
1485 if (PDI->isDisjoint())
1488 if (
GEP->isInBounds())
1490 else if (
GEP->hasNoUnsignedSignedWrap())
1492 if (
GEP->hasNoUnsignedWrap())
1495 Out <<
" inrange(" <<
InRange->getLower() <<
", " <<
InRange->getUpper()
1499 if (NNI->hasNonNeg())
1502 if (TI->hasNoUnsignedWrap())
1504 if (TI->hasNoSignedWrap())
1507 if (ICmp->hasSameSign())
1523 bool isNaN = APF.
isNaN();
1525 if (!isInf && !isNaN) {
1534 ((StrVal[0] ==
'-' || StrVal[0] ==
'+') &&
isDigit(StrVal[1]))) &&
1535 "[-+]?[0-9] regex does not match!");
1547 static_assert(
sizeof(double) ==
sizeof(
uint64_t),
1548 "assuming that double is 64 bits!");
1606 AsmWriterContext &WriterCtx) {
1608 Type *Ty = CI->getType();
1610 if (Ty->isVectorTy()) {
1612 WriterCtx.TypePrinter->print(Ty->getScalarType(), Out);
1616 if (Ty->getScalarType()->isIntegerTy(1))
1617 Out << (CI->getZExtValue() ?
"true" :
"false");
1619 Out << CI->getValue();
1621 if (Ty->isVectorTy())
1628 Type *Ty = CFP->getType();
1630 if (Ty->isVectorTy()) {
1632 WriterCtx.TypePrinter->print(Ty->getScalarType(), Out);
1638 if (Ty->isVectorTy())
1645 Out <<
"zeroinitializer";
1650 Out <<
"blockaddress(";
1659 Out <<
"dso_local_equivalent ";
1674 unsigned NumOpsToWrite = 2;
1675 if (!CPA->getOperand(2)->isNullValue())
1677 if (!CPA->getOperand(3)->isNullValue())
1681 for (
unsigned i = 0, e = NumOpsToWrite; i != e; ++i) {
1683 WriterCtx.TypePrinter->print(CPA->getOperand(i)->getType(), Out);
1692 Type *ETy = CA->getType()->getElementType();
1694 WriterCtx.TypePrinter->print(ETy, Out);
1697 for (
unsigned i = 1, e = CA->getNumOperands(); i != e; ++i) {
1699 WriterCtx.TypePrinter->print(ETy, Out);
1710 if (CA->isString()) {
1717 Type *ETy = CA->getType()->getElementType();
1719 WriterCtx.TypePrinter->print(ETy, Out);
1722 for (
uint64_t i = 1, e = CA->getNumElements(); i != e; ++i) {
1724 WriterCtx.TypePrinter->print(ETy, Out);
1733 if (CS->getType()->isPacked())
1736 unsigned N = CS->getNumOperands();
1739 WriterCtx.TypePrinter->print(CS->getOperand(0)->getType(), Out);
1744 for (
unsigned i = 1; i <
N; i++) {
1746 WriterCtx.TypePrinter->print(CS->getOperand(i)->getType(), Out);
1755 if (CS->getType()->isPacked())
1762 Type *ETy = CVVTy->getElementType();
1772 WriterCtx.TypePrinter->print(ETy, Out);
1781 WriterCtx.TypePrinter->print(ETy, Out);
1784 for (
unsigned i = 1, e = CVVTy->getNumElements(); i != e; ++i) {
1786 WriterCtx.TypePrinter->print(ETy, Out);
1820 if (CE->getOpcode() == Instruction::ShuffleVector) {
1821 if (
auto *SplatVal = CE->getSplatValue()) {
1824 WriterCtx.TypePrinter->print(SplatVal->getType(), Out);
1833 Out << CE->getOpcodeName();
1838 WriterCtx.TypePrinter->print(
GEP->getSourceElementType(), Out);
1844 WriterCtx.TypePrinter->print((*OI)->getType(), Out);
1847 if (OI+1 != CE->op_end())
1853 WriterCtx.TypePrinter->print(CE->getType(), Out);
1856 if (CE->getOpcode() == Instruction::ShuffleVector)
1863 Out <<
"<placeholder or erroneous Constant>";
1867 AsmWriterContext &WriterCtx) {
1869 for (
unsigned mi = 0, me =
Node->getNumOperands(); mi != me; ++mi) {
1874 Value *V = MDV->getValue();
1875 WriterCtx.TypePrinter->print(V->getType(), Out);
1880 WriterCtx.onWriteMetadataAsOperand(MD);
1891struct FieldSeparator {
1895 FieldSeparator(
const char *Sep =
", ") : Sep(Sep) {}
1903 return OS <<
FS.Sep;
1906struct MDFieldPrinter {
1909 AsmWriterContext &WriterCtx;
1911 explicit MDFieldPrinter(raw_ostream &Out)
1912 : Out(Out), WriterCtx(AsmWriterContext::getEmpty()) {}
1913 MDFieldPrinter(raw_ostream &Out, AsmWriterContext &Ctx)
1914 : Out(Out), WriterCtx(Ctx) {}
1916 void printTag(
const DINode *
N);
1917 void printMacinfoType(
const DIMacroNode *
N);
1918 void printChecksum(
const DIFile::ChecksumInfo<StringRef> &
N);
1919 void printString(StringRef Name, StringRef
Value,
1920 bool ShouldSkipEmpty =
true);
1921 void printMetadata(StringRef Name,
const Metadata *MD,
1922 bool ShouldSkipNull =
true);
1923 void printMetadataOrInt(StringRef Name,
const Metadata *MD,
bool IsUnsigned,
1924 bool ShouldSkipZero =
true);
1925 template <
class IntTy>
1926 void printInt(StringRef Name, IntTy
Int,
bool ShouldSkipZero =
true);
1927 void printAPInt(StringRef Name,
const APInt &
Int,
bool IsUnsigned,
1928 bool ShouldSkipZero);
1929 void printBool(StringRef Name,
bool Value,
1930 std::optional<bool>
Default = std::nullopt);
1933 template <
class IntTy,
class Stringifier>
1934 void printDwarfEnum(StringRef Name, IntTy
Value, Stringifier
toString,
1935 bool ShouldSkipZero =
true);
1937 void printNameTableKind(StringRef Name,
1944void MDFieldPrinter::printTag(
const DINode *
N) {
1945 Out <<
FS <<
"tag: ";
1953void MDFieldPrinter::printMacinfoType(
const DIMacroNode *
N) {
1954 Out <<
FS <<
"type: ";
1959 Out <<
N->getMacinfoType();
1962void MDFieldPrinter::printChecksum(
1965 printString(
"checksum", Checksum.
Value,
false);
1969 bool ShouldSkipEmpty) {
1970 if (ShouldSkipEmpty &&
Value.empty())
1973 Out <<
FS <<
Name <<
": \"";
1979 AsmWriterContext &WriterCtx) {
1985 WriterCtx.onWriteMetadataAsOperand(MD);
1989 bool ShouldSkipNull) {
1990 if (ShouldSkipNull && !MD)
1993 Out <<
FS <<
Name <<
": ";
1998 bool IsUnsigned,
bool ShouldSkipZero) {
2005 printInt(Name, CV->getZExtValue(), ShouldSkipZero);
2007 printInt(Name, CV->getSExtValue(), ShouldSkipZero);
2009 printMetadata(Name, MD);
2012template <
class IntTy>
2013void MDFieldPrinter::printInt(
StringRef Name, IntTy
Int,
bool ShouldSkipZero) {
2014 if (ShouldSkipZero && !
Int)
2021 bool IsUnsigned,
bool ShouldSkipZero) {
2022 if (ShouldSkipZero &&
Int.isZero())
2025 Out <<
FS <<
Name <<
": ";
2026 Int.print(Out, !IsUnsigned);
2030 std::optional<bool>
Default) {
2033 Out <<
FS <<
Name <<
": " << (
Value ?
"true" :
"false");
2040 Out <<
FS <<
Name <<
": ";
2045 FieldSeparator FlagsFS(
" | ");
2046 for (
auto F : SplitFlags) {
2048 assert(!StringF.empty() &&
"Expected valid flag");
2049 Out << FlagsFS << StringF;
2051 if (Extra || SplitFlags.empty())
2052 Out << FlagsFS << Extra;
2055void MDFieldPrinter::printDISPFlags(
StringRef Name,
2059 Out <<
FS <<
Name <<
": ";
2069 FieldSeparator FlagsFS(
" | ");
2070 for (
auto F : SplitFlags) {
2072 assert(!StringF.empty() &&
"Expected valid flag");
2073 Out << FlagsFS << StringF;
2075 if (Extra || SplitFlags.empty())
2076 Out << FlagsFS << Extra;
2079void MDFieldPrinter::printEmissionKind(
StringRef Name,
2084void MDFieldPrinter::printNameTableKind(
StringRef Name,
2091void MDFieldPrinter::printFixedPointKind(
StringRef Name,
2096template <
class IntTy,
class Stringifier>
2098 Stringifier
toString,
bool ShouldSkipZero) {
2099 if (ShouldSkipZero && !
Value)
2102 Out <<
FS <<
Name <<
": ";
2111 AsmWriterContext &WriterCtx) {
2112 Out <<
"!GenericDINode(";
2113 MDFieldPrinter
Printer(Out, WriterCtx);
2115 Printer.printString(
"header",
N->getHeader());
2116 if (
N->getNumDwarfOperands()) {
2117 Out <<
Printer.FS <<
"operands: {";
2119 for (
auto &
I :
N->dwarf_operands()) {
2129 AsmWriterContext &WriterCtx) {
2130 Out <<
"!DILocation(";
2131 MDFieldPrinter
Printer(Out, WriterCtx);
2133 Printer.printInt(
"line",
DL->getLine(),
false);
2134 Printer.printInt(
"column",
DL->getColumn());
2135 Printer.printMetadata(
"scope",
DL->getRawScope(),
false);
2136 Printer.printMetadata(
"inlinedAt",
DL->getRawInlinedAt());
2137 Printer.printBool(
"isImplicitCode",
DL->isImplicitCode(),
2139 Printer.printInt(
"atomGroup",
DL->getAtomGroup());
2140 Printer.printInt<
unsigned>(
"atomRank",
DL->getAtomRank());
2145 AsmWriterContext &WriterCtx) {
2146 Out <<
"!DIAssignID()";
2147 MDFieldPrinter
Printer(Out, WriterCtx);
2151 AsmWriterContext &WriterCtx) {
2152 Out <<
"!DISubrange(";
2153 MDFieldPrinter
Printer(Out, WriterCtx);
2155 Printer.printMetadataOrInt(
"count",
N->getRawCountNode(),
2161 Printer.printMetadataOrInt(
"lowerBound",
N->getRawLowerBound(),
2164 Printer.printMetadataOrInt(
"upperBound",
N->getRawUpperBound(),
2167 Printer.printMetadataOrInt(
"stride",
N->getRawStride(),
2175 AsmWriterContext &WriterCtx) {
2176 Out <<
"!DIGenericSubrange(";
2177 MDFieldPrinter
Printer(Out, WriterCtx);
2179 auto GetConstant = [&](
Metadata *Bound) -> std::optional<int64_t> {
2182 return std::nullopt;
2183 if (BE->isConstant() &&
2185 *BE->isConstant()) {
2186 return static_cast<int64_t
>(BE->getElement(1));
2188 return std::nullopt;
2191 auto *
Count =
N->getRawCountNode();
2192 if (
auto ConstantCount = GetConstant(
Count))
2193 Printer.printInt(
"count", *ConstantCount,
2198 auto *LBound =
N->getRawLowerBound();
2199 if (
auto ConstantLBound = GetConstant(LBound))
2200 Printer.printInt(
"lowerBound", *ConstantLBound,
2203 Printer.printMetadata(
"lowerBound", LBound,
true);
2205 auto *UBound =
N->getRawUpperBound();
2206 if (
auto ConstantUBound = GetConstant(UBound))
2207 Printer.printInt(
"upperBound", *ConstantUBound,
2210 Printer.printMetadata(
"upperBound", UBound,
true);
2212 auto *Stride =
N->getRawStride();
2213 if (
auto ConstantStride = GetConstant(Stride))
2214 Printer.printInt(
"stride", *ConstantStride,
2217 Printer.printMetadata(
"stride", Stride,
true);
2223 AsmWriterContext &) {
2224 Out <<
"!DIEnumerator(";
2226 Printer.printString(
"name",
N->getName(),
false);
2227 Printer.printAPInt(
"value",
N->getValue(),
N->isUnsigned(),
2229 if (
N->isUnsigned())
2230 Printer.printBool(
"isUnsigned",
true);
2235 AsmWriterContext &WriterCtx) {
2236 Out <<
"!DIBasicType(";
2237 MDFieldPrinter
Printer(Out, WriterCtx);
2238 if (
N->getTag() != dwarf::DW_TAG_base_type)
2240 Printer.printString(
"name",
N->getName());
2241 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2242 Printer.printInt(
"align",
N->getAlignInBits());
2243 Printer.printDwarfEnum(
"encoding",
N->getEncoding(),
2245 Printer.printInt(
"num_extra_inhabitants",
N->getNumExtraInhabitants());
2246 Printer.printDIFlags(
"flags",
N->getFlags());
2251 AsmWriterContext &WriterCtx) {
2252 Out <<
"!DIFixedPointType(";
2253 MDFieldPrinter
Printer(Out, WriterCtx);
2254 if (
N->getTag() != dwarf::DW_TAG_base_type)
2256 Printer.printString(
"name",
N->getName());
2257 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2258 Printer.printInt(
"align",
N->getAlignInBits());
2259 Printer.printDwarfEnum(
"encoding",
N->getEncoding(),
2261 Printer.printDIFlags(
"flags",
N->getFlags());
2262 Printer.printFixedPointKind(
"kind",
N->getKind());
2263 if (
N->isRational()) {
2264 bool IsUnsigned = !
N->isSigned();
2265 Printer.printAPInt(
"numerator",
N->getNumerator(), IsUnsigned,
false);
2266 Printer.printAPInt(
"denominator",
N->getDenominator(), IsUnsigned,
false);
2268 Printer.printInt(
"factor",
N->getFactor());
2274 AsmWriterContext &WriterCtx) {
2275 Out <<
"!DIStringType(";
2276 MDFieldPrinter
Printer(Out, WriterCtx);
2277 if (
N->getTag() != dwarf::DW_TAG_string_type)
2279 Printer.printString(
"name",
N->getName());
2280 Printer.printMetadata(
"stringLength",
N->getRawStringLength());
2281 Printer.printMetadata(
"stringLengthExpression",
N->getRawStringLengthExp());
2282 Printer.printMetadata(
"stringLocationExpression",
2283 N->getRawStringLocationExp());
2284 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2285 Printer.printInt(
"align",
N->getAlignInBits());
2286 Printer.printDwarfEnum(
"encoding",
N->getEncoding(),
2292 AsmWriterContext &WriterCtx) {
2293 Out <<
"!DIDerivedType(";
2294 MDFieldPrinter
Printer(Out, WriterCtx);
2296 Printer.printString(
"name",
N->getName());
2297 Printer.printMetadata(
"scope",
N->getRawScope());
2298 Printer.printMetadata(
"file",
N->getRawFile());
2299 Printer.printInt(
"line",
N->getLine());
2300 Printer.printMetadata(
"baseType",
N->getRawBaseType(),
2302 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2303 Printer.printInt(
"align",
N->getAlignInBits());
2304 Printer.printMetadataOrInt(
"offset",
N->getRawOffsetInBits(),
true);
2305 Printer.printDIFlags(
"flags",
N->getFlags());
2306 Printer.printMetadata(
"extraData",
N->getRawExtraData());
2307 if (
const auto &DWARFAddressSpace =
N->getDWARFAddressSpace())
2308 Printer.printInt(
"dwarfAddressSpace", *DWARFAddressSpace,
2310 Printer.printMetadata(
"annotations",
N->getRawAnnotations());
2311 if (
auto PtrAuthData =
N->getPtrAuthData()) {
2312 Printer.printInt(
"ptrAuthKey", PtrAuthData->key());
2313 Printer.printBool(
"ptrAuthIsAddressDiscriminated",
2314 PtrAuthData->isAddressDiscriminated());
2315 Printer.printInt(
"ptrAuthExtraDiscriminator",
2316 PtrAuthData->extraDiscriminator());
2317 Printer.printBool(
"ptrAuthIsaPointer", PtrAuthData->isaPointer());
2318 Printer.printBool(
"ptrAuthAuthenticatesNullValues",
2319 PtrAuthData->authenticatesNullValues());
2325 AsmWriterContext &WriterCtx) {
2326 Out <<
"!DISubrangeType(";
2327 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.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2333 Printer.printInt(
"align",
N->getAlignInBits());
2334 Printer.printDIFlags(
"flags",
N->getFlags());
2335 Printer.printMetadata(
"baseType",
N->getRawBaseType(),
2337 Printer.printMetadata(
"lowerBound",
N->getRawLowerBound());
2338 Printer.printMetadata(
"upperBound",
N->getRawUpperBound());
2339 Printer.printMetadata(
"stride",
N->getRawStride());
2340 Printer.printMetadata(
"bias",
N->getRawBias());
2345 AsmWriterContext &WriterCtx) {
2346 Out <<
"!DICompositeType(";
2347 MDFieldPrinter
Printer(Out, WriterCtx);
2349 Printer.printString(
"name",
N->getName());
2350 Printer.printMetadata(
"scope",
N->getRawScope());
2351 Printer.printMetadata(
"file",
N->getRawFile());
2352 Printer.printInt(
"line",
N->getLine());
2353 Printer.printMetadata(
"baseType",
N->getRawBaseType());
2354 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2355 Printer.printInt(
"align",
N->getAlignInBits());
2356 Printer.printMetadataOrInt(
"offset",
N->getRawOffsetInBits(),
true);
2357 Printer.printInt(
"num_extra_inhabitants",
N->getNumExtraInhabitants());
2358 Printer.printDIFlags(
"flags",
N->getFlags());
2359 Printer.printMetadata(
"elements",
N->getRawElements());
2360 Printer.printDwarfEnum(
"runtimeLang",
N->getRuntimeLang(),
2362 Printer.printMetadata(
"vtableHolder",
N->getRawVTableHolder());
2363 Printer.printMetadata(
"templateParams",
N->getRawTemplateParams());
2364 Printer.printString(
"identifier",
N->getIdentifier());
2365 Printer.printMetadata(
"discriminator",
N->getRawDiscriminator());
2366 Printer.printMetadata(
"dataLocation",
N->getRawDataLocation());
2367 Printer.printMetadata(
"associated",
N->getRawAssociated());
2368 Printer.printMetadata(
"allocated",
N->getRawAllocated());
2369 if (
auto *RankConst =
N->getRankConst())
2370 Printer.printInt(
"rank", RankConst->getSExtValue(),
2373 Printer.printMetadata(
"rank",
N->getRawRank(),
true);
2374 Printer.printMetadata(
"annotations",
N->getRawAnnotations());
2375 if (
auto *Specification =
N->getRawSpecification())
2376 Printer.printMetadata(
"specification", Specification);
2378 if (
auto EnumKind =
N->getEnumKind())
2382 Printer.printMetadata(
"bitStride",
N->getRawBitStride());
2387 AsmWriterContext &WriterCtx) {
2388 Out <<
"!DISubroutineType(";
2389 MDFieldPrinter
Printer(Out, WriterCtx);
2390 Printer.printDIFlags(
"flags",
N->getFlags());
2392 Printer.printMetadata(
"types",
N->getRawTypeArray(),
2400 Printer.printString(
"filename",
N->getFilename(),
2402 Printer.printString(
"directory",
N->getDirectory(),
2405 if (
N->getChecksum())
2406 Printer.printChecksum(*
N->getChecksum());
2408 Printer.printString(
"source", *
N->getSource(),
2414 AsmWriterContext &WriterCtx) {
2415 Out <<
"!DICompileUnit(";
2416 MDFieldPrinter
Printer(Out, WriterCtx);
2417 Printer.printDwarfEnum(
"language",
N->getSourceLanguage(),
2419 Printer.printMetadata(
"file",
N->getRawFile(),
false);
2420 Printer.printString(
"producer",
N->getProducer());
2421 Printer.printBool(
"isOptimized",
N->isOptimized());
2422 Printer.printString(
"flags",
N->getFlags());
2423 Printer.printInt(
"runtimeVersion",
N->getRuntimeVersion(),
2425 Printer.printString(
"splitDebugFilename",
N->getSplitDebugFilename());
2426 Printer.printEmissionKind(
"emissionKind",
N->getEmissionKind());
2427 Printer.printMetadata(
"enums",
N->getRawEnumTypes());
2428 Printer.printMetadata(
"retainedTypes",
N->getRawRetainedTypes());
2429 Printer.printMetadata(
"globals",
N->getRawGlobalVariables());
2430 Printer.printMetadata(
"imports",
N->getRawImportedEntities());
2431 Printer.printMetadata(
"macros",
N->getRawMacros());
2432 Printer.printInt(
"dwoId",
N->getDWOId());
2433 Printer.printBool(
"splitDebugInlining",
N->getSplitDebugInlining(),
true);
2434 Printer.printBool(
"debugInfoForProfiling",
N->getDebugInfoForProfiling(),
2436 Printer.printNameTableKind(
"nameTableKind",
N->getNameTableKind());
2437 Printer.printBool(
"rangesBaseAddress",
N->getRangesBaseAddress(),
false);
2438 Printer.printString(
"sysroot",
N->getSysRoot());
2439 Printer.printString(
"sdk",
N->getSDK());
2444 AsmWriterContext &WriterCtx) {
2445 Out <<
"!DISubprogram(";
2446 MDFieldPrinter
Printer(Out, WriterCtx);
2447 Printer.printString(
"name",
N->getName());
2448 Printer.printString(
"linkageName",
N->getLinkageName());
2449 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2450 Printer.printMetadata(
"file",
N->getRawFile());
2451 Printer.printInt(
"line",
N->getLine());
2452 Printer.printMetadata(
"type",
N->getRawType());
2453 Printer.printInt(
"scopeLine",
N->getScopeLine());
2454 Printer.printMetadata(
"containingType",
N->getRawContainingType());
2455 if (
N->getVirtuality() != dwarf::DW_VIRTUALITY_none ||
2456 N->getVirtualIndex() != 0)
2457 Printer.printInt(
"virtualIndex",
N->getVirtualIndex(),
false);
2458 Printer.printInt(
"thisAdjustment",
N->getThisAdjustment());
2459 Printer.printDIFlags(
"flags",
N->getFlags());
2460 Printer.printDISPFlags(
"spFlags",
N->getSPFlags());
2461 Printer.printMetadata(
"unit",
N->getRawUnit());
2462 Printer.printMetadata(
"templateParams",
N->getRawTemplateParams());
2463 Printer.printMetadata(
"declaration",
N->getRawDeclaration());
2464 Printer.printMetadata(
"retainedNodes",
N->getRawRetainedNodes());
2465 Printer.printMetadata(
"thrownTypes",
N->getRawThrownTypes());
2466 Printer.printMetadata(
"annotations",
N->getRawAnnotations());
2467 Printer.printString(
"targetFuncName",
N->getTargetFuncName());
2468 Printer.printBool(
"keyInstructions",
N->getKeyInstructionsEnabled(),
false);
2473 AsmWriterContext &WriterCtx) {
2474 Out <<
"!DILexicalBlock(";
2475 MDFieldPrinter
Printer(Out, WriterCtx);
2476 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2477 Printer.printMetadata(
"file",
N->getRawFile());
2478 Printer.printInt(
"line",
N->getLine());
2479 Printer.printInt(
"column",
N->getColumn());
2485 AsmWriterContext &WriterCtx) {
2486 Out <<
"!DILexicalBlockFile(";
2487 MDFieldPrinter
Printer(Out, WriterCtx);
2488 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2489 Printer.printMetadata(
"file",
N->getRawFile());
2490 Printer.printInt(
"discriminator",
N->getDiscriminator(),
2496 AsmWriterContext &WriterCtx) {
2497 Out <<
"!DINamespace(";
2498 MDFieldPrinter
Printer(Out, WriterCtx);
2499 Printer.printString(
"name",
N->getName());
2500 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2501 Printer.printBool(
"exportSymbols",
N->getExportSymbols(),
false);
2506 AsmWriterContext &WriterCtx) {
2507 Out <<
"!DICommonBlock(";
2508 MDFieldPrinter
Printer(Out, WriterCtx);
2509 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2510 Printer.printMetadata(
"declaration",
N->getRawDecl(),
false);
2511 Printer.printString(
"name",
N->getName());
2512 Printer.printMetadata(
"file",
N->getRawFile());
2513 Printer.printInt(
"line",
N->getLineNo());
2518 AsmWriterContext &WriterCtx) {
2520 MDFieldPrinter
Printer(Out, WriterCtx);
2522 Printer.printInt(
"line",
N->getLine());
2523 Printer.printString(
"name",
N->getName());
2524 Printer.printString(
"value",
N->getValue());
2529 AsmWriterContext &WriterCtx) {
2530 Out <<
"!DIMacroFile(";
2531 MDFieldPrinter
Printer(Out, WriterCtx);
2532 Printer.printInt(
"line",
N->getLine());
2533 Printer.printMetadata(
"file",
N->getRawFile(),
false);
2534 Printer.printMetadata(
"nodes",
N->getRawElements());
2539 AsmWriterContext &WriterCtx) {
2540 Out <<
"!DIModule(";
2541 MDFieldPrinter
Printer(Out, WriterCtx);
2542 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2543 Printer.printString(
"name",
N->getName());
2544 Printer.printString(
"configMacros",
N->getConfigurationMacros());
2545 Printer.printString(
"includePath",
N->getIncludePath());
2546 Printer.printString(
"apinotes",
N->getAPINotesFile());
2547 Printer.printMetadata(
"file",
N->getRawFile());
2548 Printer.printInt(
"line",
N->getLineNo());
2549 Printer.printBool(
"isDecl",
N->getIsDecl(),
false);
2555 AsmWriterContext &WriterCtx) {
2556 Out <<
"!DITemplateTypeParameter(";
2557 MDFieldPrinter
Printer(Out, WriterCtx);
2558 Printer.printString(
"name",
N->getName());
2559 Printer.printMetadata(
"type",
N->getRawType(),
false);
2560 Printer.printBool(
"defaulted",
N->isDefault(),
false);
2566 AsmWriterContext &WriterCtx) {
2567 Out <<
"!DITemplateValueParameter(";
2568 MDFieldPrinter
Printer(Out, WriterCtx);
2569 if (
N->getTag() != dwarf::DW_TAG_template_value_parameter)
2571 Printer.printString(
"name",
N->getName());
2572 Printer.printMetadata(
"type",
N->getRawType());
2573 Printer.printBool(
"defaulted",
N->isDefault(),
false);
2574 Printer.printMetadata(
"value",
N->getValue(),
false);
2579 AsmWriterContext &WriterCtx) {
2580 Out <<
"!DIGlobalVariable(";
2581 MDFieldPrinter
Printer(Out, WriterCtx);
2582 Printer.printString(
"name",
N->getName());
2583 Printer.printString(
"linkageName",
N->getLinkageName());
2584 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2585 Printer.printMetadata(
"file",
N->getRawFile());
2586 Printer.printInt(
"line",
N->getLine());
2587 Printer.printMetadata(
"type",
N->getRawType());
2588 Printer.printBool(
"isLocal",
N->isLocalToUnit());
2589 Printer.printBool(
"isDefinition",
N->isDefinition());
2590 Printer.printMetadata(
"declaration",
N->getRawStaticDataMemberDeclaration());
2591 Printer.printMetadata(
"templateParams",
N->getRawTemplateParams());
2592 Printer.printInt(
"align",
N->getAlignInBits());
2593 Printer.printMetadata(
"annotations",
N->getRawAnnotations());
2598 AsmWriterContext &WriterCtx) {
2599 Out <<
"!DILocalVariable(";
2600 MDFieldPrinter
Printer(Out, WriterCtx);
2601 Printer.printString(
"name",
N->getName());
2602 Printer.printInt(
"arg",
N->getArg());
2603 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2604 Printer.printMetadata(
"file",
N->getRawFile());
2605 Printer.printInt(
"line",
N->getLine());
2606 Printer.printMetadata(
"type",
N->getRawType());
2607 Printer.printDIFlags(
"flags",
N->getFlags());
2608 Printer.printInt(
"align",
N->getAlignInBits());
2609 Printer.printMetadata(
"annotations",
N->getRawAnnotations());
2614 AsmWriterContext &WriterCtx) {
2616 MDFieldPrinter
Printer(Out, WriterCtx);
2617 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2618 Printer.printString(
"name",
N->getName());
2619 Printer.printMetadata(
"file",
N->getRawFile());
2620 Printer.printInt(
"line",
N->getLine());
2621 Printer.printInt(
"column",
N->getColumn());
2622 Printer.printBool(
"isArtificial",
N->isArtificial(),
false);
2623 if (
N->getCoroSuspendIdx())
2624 Printer.printInt(
"coroSuspendIdx", *
N->getCoroSuspendIdx(),
2630 AsmWriterContext &WriterCtx) {
2631 Out <<
"!DIExpression(";
2636 assert(!OpStr.empty() &&
"Expected valid opcode");
2640 Out << FS <<
Op.getArg(0);
2643 for (
unsigned A = 0, AE =
Op.getNumArgs();
A != AE; ++
A)
2644 Out << FS <<
Op.getArg(
A);
2648 for (
const auto &
I :
N->getElements())
2655 AsmWriterContext &WriterCtx,
2656 bool FromValue =
false) {
2658 "Unexpected DIArgList metadata outside of value argument");
2659 Out <<
"!DIArgList(";
2661 MDFieldPrinter
Printer(Out, WriterCtx);
2671 AsmWriterContext &WriterCtx) {
2672 Out <<
"!DIGlobalVariableExpression(";
2673 MDFieldPrinter
Printer(Out, WriterCtx);
2674 Printer.printMetadata(
"var",
N->getVariable());
2675 Printer.printMetadata(
"expr",
N->getExpression());
2680 AsmWriterContext &WriterCtx) {
2681 Out <<
"!DIObjCProperty(";
2682 MDFieldPrinter
Printer(Out, WriterCtx);
2683 Printer.printString(
"name",
N->getName());
2684 Printer.printMetadata(
"file",
N->getRawFile());
2685 Printer.printInt(
"line",
N->getLine());
2686 Printer.printString(
"setter",
N->getSetterName());
2687 Printer.printString(
"getter",
N->getGetterName());
2688 Printer.printInt(
"attributes",
N->getAttributes());
2689 Printer.printMetadata(
"type",
N->getRawType());
2694 AsmWriterContext &WriterCtx) {
2695 Out <<
"!DIImportedEntity(";
2696 MDFieldPrinter
Printer(Out, WriterCtx);
2698 Printer.printString(
"name",
N->getName());
2699 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2700 Printer.printMetadata(
"entity",
N->getRawEntity());
2701 Printer.printMetadata(
"file",
N->getRawFile());
2702 Printer.printInt(
"line",
N->getLine());
2703 Printer.printMetadata(
"elements",
N->getRawElements());
2708 AsmWriterContext &Ctx) {
2709 if (
Node->isDistinct())
2711 else if (
Node->isTemporary())
2712 Out <<
"<temporary!> ";
2714 switch (
Node->getMetadataID()) {
2717#define HANDLE_MDNODE_LEAF(CLASS) \
2718 case Metadata::CLASS##Kind: \
2719 write##CLASS(Out, cast<CLASS>(Node), Ctx); \
2721#include "llvm/IR/Metadata.def"
2728 AsmWriterContext &WriterCtx) {
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");
2853 WriterCtx.TypePrinter->print(V->getValue()->getType(), Out);
2860class AssemblyWriter {
2861 formatted_raw_ostream &Out;
2862 const Module *TheModule =
nullptr;
2863 const ModuleSummaryIndex *TheIndex =
nullptr;
2864 std::unique_ptr<SlotTracker> SlotTrackerStorage;
2866 TypePrinting TypePrinter;
2867 AssemblyAnnotationWriter *AnnotationWriter =
nullptr;
2868 SetVector<const Comdat *> Comdats;
2870 bool ShouldPreserveUseListOrder;
2875 DenseMap<const GlobalValueSummary *, GlobalValue::GUID> SummaryToGUIDMap;
2879 AssemblyWriter(formatted_raw_ostream &o, SlotTracker &Mac,
const Module *M,
2880 AssemblyAnnotationWriter *AAW,
bool IsForDebug,
2881 bool ShouldPreserveUseListOrder =
false);
2883 AssemblyWriter(formatted_raw_ostream &o, SlotTracker &Mac,
2884 const ModuleSummaryIndex *Index,
bool IsForDebug);
2887 return AsmWriterContext(&TypePrinter, &
Machine, TheModule);
2890 void printMDNodeBody(
const MDNode *MD);
2891 void printNamedMDNode(
const NamedMDNode *NMD);
2893 void printModule(
const Module *M);
2895 void writeOperand(
const Value *
Op,
bool PrintType);
2896 void writeParamOperand(
const Value *Operand, AttributeSet Attrs);
2897 void writeOperandBundles(
const CallBase *
Call);
2898 void writeSyncScope(
const LLVMContext &
Context,
2900 void writeAtomic(
const LLVMContext &
Context,
2903 void writeAtomicCmpXchg(
const LLVMContext &
Context,
2908 void writeAllMDNodes();
2909 void writeMDNode(
unsigned Slot,
const MDNode *Node);
2910 void writeAttribute(
const Attribute &Attr,
bool InAttrGroup =
false);
2911 void writeAttributeSet(
const AttributeSet &AttrSet,
bool InAttrGroup =
false);
2912 void writeAllAttributeGroups();
2914 void printTypeIdentities();
2915 void printGlobal(
const GlobalVariable *GV);
2916 void printAlias(
const GlobalAlias *GA);
2917 void printIFunc(
const GlobalIFunc *GI);
2918 void printComdat(
const Comdat *
C);
2919 void printFunction(
const Function *
F);
2920 void printArgument(
const Argument *FA, AttributeSet Attrs);
2921 void printBasicBlock(
const BasicBlock *BB);
2922 void printInstructionLine(
const Instruction &
I);
2923 void printInstruction(
const Instruction &
I);
2924 void printDbgMarker(
const DbgMarker &DPI);
2925 void printDbgVariableRecord(
const DbgVariableRecord &DVR);
2926 void printDbgLabelRecord(
const DbgLabelRecord &DLR);
2927 void printDbgRecord(
const DbgRecord &DR);
2928 void printDbgRecordLine(
const DbgRecord &DR);
2930 void printUseListOrder(
const Value *V,
const std::vector<unsigned> &Shuffle);
2931 void printUseLists(
const Function *
F);
2933 void printModuleSummaryIndex();
2934 void printSummaryInfo(
unsigned Slot,
const ValueInfo &VI);
2935 void printSummary(
const GlobalValueSummary &Summary);
2936 void printAliasSummary(
const AliasSummary *AS);
2937 void printGlobalVarSummary(
const GlobalVarSummary *GS);
2938 void printFunctionSummary(
const FunctionSummary *FS);
2939 void printTypeIdSummary(
const TypeIdSummary &TIS);
2941 void printTypeTestResolution(
const TypeTestResolution &TTRes);
2942 void printArgs(
const std::vector<uint64_t> &Args);
2943 void printWPDRes(
const WholeProgramDevirtResolution &WPDRes);
2944 void printTypeIdInfo(
const FunctionSummary::TypeIdInfo &TIDInfo);
2945 void printVFuncId(
const FunctionSummary::VFuncId VFId);
2947 printNonConstVCalls(
const std::vector<FunctionSummary::VFuncId> &VCallList,
2950 printConstVCalls(
const std::vector<FunctionSummary::ConstVCall> &VCallList,
2955 void printMetadataAttachments(
2956 const SmallVectorImpl<std::pair<unsigned, MDNode *>> &MDs,
2957 StringRef Separator);
2961 void printInfoComment(
const Value &V);
2965 void printGCRelocateComment(
const GCRelocateInst &Relocate);
2972 bool IsForDebug,
bool ShouldPreserveUseListOrder)
2973 : Out(
o), TheModule(
M),
Machine(Mac), TypePrinter(
M), AnnotationWriter(AAW),
2974 IsForDebug(IsForDebug),
2975 ShouldPreserveUseListOrder(ShouldPreserveUseListOrder) {
2978 for (
const GlobalObject &GO : TheModule->global_objects())
2985 : Out(
o), TheIndex(Index),
Machine(Mac), TypePrinter(nullptr),
2986 IsForDebug(IsForDebug), ShouldPreserveUseListOrder(
false) {}
2988void AssemblyWriter::writeOperand(
const Value *Operand,
bool PrintType) {
2990 Out <<
"<null operand!>";
2994 TypePrinter.print(Operand->
getType(), Out);
3001void AssemblyWriter::writeSyncScope(
const LLVMContext &
Context,
3009 Context.getSyncScopeNames(SSNs);
3011 Out <<
" syncscope(\"";
3019void AssemblyWriter::writeAtomic(
const LLVMContext &
Context,
3022 if (Ordering == AtomicOrdering::NotAtomic)
3025 writeSyncScope(
Context, SSID);
3029void AssemblyWriter::writeAtomicCmpXchg(
const LLVMContext &
Context,
3033 assert(SuccessOrdering != AtomicOrdering::NotAtomic &&
3034 FailureOrdering != AtomicOrdering::NotAtomic);
3036 writeSyncScope(
Context, SSID);
3041void AssemblyWriter::writeParamOperand(
const Value *Operand,
3042 AttributeSet Attrs) {
3044 Out <<
"<null operand!>";
3049 TypePrinter.print(Operand->
getType(), Out);
3051 if (
Attrs.hasAttributes()) {
3053 writeAttributeSet(Attrs);
3061void AssemblyWriter::writeOperandBundles(
const CallBase *
Call) {
3067 bool FirstBundle =
true;
3073 FirstBundle =
false;
3081 bool FirstInput =
true;
3083 for (
const auto &Input : BU.
Inputs) {
3088 if (Input ==
nullptr)
3089 Out <<
"<null operand bundle!>";
3091 TypePrinter.print(Input->getType(), Out);
3103void AssemblyWriter::printModule(
const Module *M) {
3106 if (ShouldPreserveUseListOrder)
3109 if (!
M->getModuleIdentifier().empty() &&
3112 M->getModuleIdentifier().find(
'\n') == std::string::npos)
3113 Out <<
"; ModuleID = '" <<
M->getModuleIdentifier() <<
"'\n";
3115 if (!
M->getSourceFileName().empty()) {
3116 Out <<
"source_filename = \"";
3121 const std::string &
DL =
M->getDataLayoutStr();
3123 Out <<
"target datalayout = \"" <<
DL <<
"\"\n";
3124 if (!
M->getTargetTriple().empty())
3125 Out <<
"target triple = \"" <<
M->getTargetTriple().str() <<
"\"\n";
3127 if (!
M->getModuleInlineAsm().empty()) {
3131 StringRef
Asm =
M->getModuleInlineAsm();
3134 std::tie(Front, Asm) =
Asm.split(
'\n');
3138 Out <<
"module asm \"";
3141 }
while (!
Asm.empty());
3144 printTypeIdentities();
3147 if (!Comdats.empty())
3149 for (
const Comdat *
C : Comdats) {
3151 if (
C != Comdats.back())
3156 if (!
M->global_empty()) Out <<
'\n';
3157 for (
const GlobalVariable &GV :
M->globals()) {
3158 printGlobal(&GV); Out <<
'\n';
3162 if (!
M->alias_empty()) Out <<
"\n";
3163 for (
const GlobalAlias &GA :
M->aliases())
3167 if (!
M->ifunc_empty()) Out <<
"\n";
3168 for (
const GlobalIFunc &GI :
M->ifuncs())
3172 for (
const Function &
F : *M) {
3178 printUseLists(
nullptr);
3183 writeAllAttributeGroups();
3187 if (!
M->named_metadata_empty()) Out <<
'\n';
3189 for (
const NamedMDNode &Node :
M->named_metadata())
3190 printNamedMDNode(&Node);
3199void AssemblyWriter::printModuleSummaryIndex() {
3201 int NumSlots =
Machine.initializeIndexIfNeeded();
3207 std::vector<std::pair<std::string, ModuleHash>> moduleVec;
3208 std::string RegularLTOModuleName =
3210 moduleVec.resize(TheIndex->modulePaths().size());
3211 for (
auto &[ModPath, ModHash] : TheIndex->modulePaths())
3212 moduleVec[
Machine.getModulePathSlot(ModPath)] = std::make_pair(
3215 ModPath.empty() ? RegularLTOModuleName : std::string(ModPath), ModHash);
3218 for (
auto &ModPair : moduleVec) {
3219 Out <<
"^" << i++ <<
" = module: (";
3222 Out <<
"\", hash: (";
3224 for (
auto Hash : ModPair.second)
3231 for (
auto &GlobalList : *TheIndex) {
3232 auto GUID = GlobalList.first;
3233 for (
auto &Summary : GlobalList.second.SummaryList)
3238 for (
auto &GlobalList : *TheIndex) {
3239 auto GUID = GlobalList.first;
3240 auto VI = TheIndex->getValueInfo(GlobalList);
3241 printSummaryInfo(
Machine.getGUIDSlot(GUID), VI);
3245 for (
const auto &TID : TheIndex->typeIds()) {
3246 Out <<
"^" <<
Machine.getTypeIdSlot(TID.second.first)
3247 <<
" = typeid: (name: \"" << TID.second.first <<
"\"";
3248 printTypeIdSummary(TID.second.second);
3249 Out <<
") ; guid = " << TID.first <<
"\n";
3253 for (
auto &TId : TheIndex->typeIdCompatibleVtableMap()) {
3255 Out <<
"^" <<
Machine.getTypeIdCompatibleVtableSlot(TId.first)
3256 <<
" = typeidCompatibleVTable: (name: \"" << TId.first <<
"\"";
3257 printTypeIdCompatibleVtableSummary(TId.second);
3258 Out <<
") ; guid = " <<
GUID <<
"\n";
3262 if (TheIndex->getFlags()) {
3263 Out <<
"^" << NumSlots <<
" = flags: " << TheIndex->getFlags() <<
"\n";
3267 Out <<
"^" << NumSlots <<
" = blockcount: " << TheIndex->getBlockCount()
3277 return "singleImpl";
3279 return "branchFunnel";
3290 return "uniformRetVal";
3292 return "uniqueRetVal";
3294 return "virtualConstProp";
3317void AssemblyWriter::printTypeTestResolution(
const TypeTestResolution &TTRes) {
3324 Out <<
", alignLog2: " << TTRes.
AlignLog2;
3326 Out <<
", sizeM1: " << TTRes.
SizeM1;
3329 Out <<
", bitMask: " << (unsigned)TTRes.
BitMask;
3336void AssemblyWriter::printTypeIdSummary(
const TypeIdSummary &TIS) {
3337 Out <<
", summary: (";
3338 printTypeTestResolution(TIS.
TTRes);
3339 if (!TIS.
WPDRes.empty()) {
3340 Out <<
", wpdResolutions: (";
3342 for (
auto &WPDRes : TIS.
WPDRes) {
3344 Out <<
"(offset: " << WPDRes.first <<
", ";
3345 printWPDRes(WPDRes.second);
3353void AssemblyWriter::printTypeIdCompatibleVtableSummary(
3355 Out <<
", summary: (";
3357 for (
auto &
P : TI) {
3359 Out <<
"(offset: " <<
P.AddressPointOffset <<
", ";
3360 Out <<
"^" <<
Machine.getGUIDSlot(
P.VTableVI.getGUID());
3366void AssemblyWriter::printArgs(
const std::vector<uint64_t> &Args) {
3369 for (
auto arg : Args) {
3376void AssemblyWriter::printWPDRes(
const WholeProgramDevirtResolution &WPDRes) {
3377 Out <<
"wpdRes: (kind: ";
3384 Out <<
", resByArg: (";
3386 for (
auto &ResByArg : WPDRes.
ResByArg) {
3388 printArgs(ResByArg.first);
3389 Out <<
", byArg: (kind: ";
3391 if (ResByArg.second.TheKind ==
3393 ResByArg.second.TheKind ==
3395 Out <<
", info: " << ResByArg.second.Info;
3399 if (ResByArg.second.Byte || ResByArg.second.Bit)
3400 Out <<
", byte: " << ResByArg.second.Byte
3401 <<
", bit: " << ResByArg.second.Bit;
3422void AssemblyWriter::printAliasSummary(
const AliasSummary *AS) {
3423 Out <<
", aliasee: ";
3433void AssemblyWriter::printGlobalVarSummary(
const GlobalVarSummary *GS) {
3434 auto VTableFuncs =
GS->vTableFuncs();
3435 Out <<
", varFlags: (readonly: " <<
GS->VarFlags.MaybeReadOnly <<
", "
3436 <<
"writeonly: " <<
GS->VarFlags.MaybeWriteOnly <<
", "
3437 <<
"constant: " <<
GS->VarFlags.Constant;
3438 if (!VTableFuncs.empty())
3440 <<
"vcall_visibility: " <<
GS->VarFlags.VCallVisibility;
3443 if (!VTableFuncs.empty()) {
3444 Out <<
", vTableFuncs: (";
3446 for (
auto &
P : VTableFuncs) {
3448 Out <<
"(virtFunc: ^" <<
Machine.getGUIDSlot(
P.FuncVI.getGUID())
3449 <<
", offset: " <<
P.VTableOffset;
3467 return "linkonce_odr";
3477 return "extern_weak";
3479 return "available_externally";
3508 return "definition";
3510 return "declaration";
3515void AssemblyWriter::printFunctionSummary(
const FunctionSummary *FS) {
3516 Out <<
", insts: " <<
FS->instCount();
3517 if (
FS->fflags().anyFlagSet())
3518 Out <<
", " <<
FS->fflags();
3520 if (!
FS->calls().empty()) {
3521 Out <<
", calls: (";
3523 for (
auto &
Call :
FS->calls()) {
3525 Out <<
"(callee: ^" <<
Machine.getGUIDSlot(
Call.first.getGUID());
3526 if (
Call.second.getHotness() != CalleeInfo::HotnessType::Unknown)
3528 else if (
Call.second.RelBlockFreq)
3529 Out <<
", relbf: " <<
Call.second.RelBlockFreq;
3532 if (
Call.second.HasTailCall)
3539 if (
const auto *TIdInfo =
FS->getTypeIdInfo())
3540 printTypeIdInfo(*TIdInfo);
3544 auto AllocTypeName = [](uint8_t
Type) ->
const char * {
3546 case (uint8_t)AllocationType::None:
3548 case (uint8_t)AllocationType::NotCold:
3550 case (uint8_t)AllocationType::Cold:
3552 case (uint8_t)AllocationType::Hot:
3558 if (!
FS->allocs().empty()) {
3559 Out <<
", allocs: (";
3561 for (
auto &AI :
FS->allocs()) {
3563 Out <<
"(versions: (";
3565 for (
auto V : AI.Versions) {
3567 Out << AllocTypeName(V);
3569 Out <<
"), memProf: (";
3570 FieldSeparator MIBFS;
3571 for (
auto &MIB : AI.MIBs) {
3573 Out <<
"(type: " << AllocTypeName((uint8_t)MIB.AllocType);
3574 Out <<
", stackIds: (";
3575 FieldSeparator SIDFS;
3576 for (
auto Id : MIB.StackIdIndices) {
3578 Out << TheIndex->getStackIdAtIndex(Id);
3587 if (!
FS->callsites().empty()) {
3588 Out <<
", callsites: (";
3589 FieldSeparator SNFS;
3590 for (
auto &CI :
FS->callsites()) {
3593 Out <<
"(callee: ^" <<
Machine.getGUIDSlot(CI.Callee.getGUID());
3595 Out <<
"(callee: null";
3596 Out <<
", clones: (";
3598 for (
auto V : CI.Clones) {
3602 Out <<
"), stackIds: (";
3603 FieldSeparator SIDFS;
3604 for (
auto Id : CI.StackIdIndices) {
3606 Out << TheIndex->getStackIdAtIndex(Id);
3613 auto PrintRange = [&](
const ConstantRange &
Range) {
3617 if (!
FS->paramAccesses().empty()) {
3618 Out <<
", params: (";
3620 for (
auto &PS :
FS->paramAccesses()) {
3622 Out <<
"(param: " << PS.ParamNo;
3623 Out <<
", offset: ";
3625 if (!PS.Calls.empty()) {
3626 Out <<
", calls: (";
3628 for (
auto &
Call : PS.Calls) {
3630 Out <<
"(callee: ^" <<
Machine.getGUIDSlot(
Call.Callee.getGUID());
3631 Out <<
", param: " <<
Call.ParamNo;
3632 Out <<
", offset: ";
3633 PrintRange(
Call.Offsets);
3644void AssemblyWriter::printTypeIdInfo(
3645 const FunctionSummary::TypeIdInfo &TIDInfo) {
3646 Out <<
", typeIdInfo: (";
3647 FieldSeparator TIDFS;
3650 Out <<
"typeTests: (";
3653 auto TidIter = TheIndex->typeIds().equal_range(GUID);
3654 if (TidIter.first == TidIter.second) {
3660 for (
const auto &[GUID, TypeIdPair] :
make_range(TidIter)) {
3662 auto Slot =
Machine.getTypeIdSlot(TypeIdPair.first);
3680 "typeTestAssumeConstVCalls");
3685 "typeCheckedLoadConstVCalls");
3690void AssemblyWriter::printVFuncId(
const FunctionSummary::VFuncId VFId) {
3691 auto TidIter = TheIndex->typeIds().equal_range(VFId.
GUID);
3692 if (TidIter.first == TidIter.second) {
3693 Out <<
"vFuncId: (";
3694 Out <<
"guid: " << VFId.
GUID;
3695 Out <<
", offset: " << VFId.
Offset;
3701 for (
const auto &[GUID, TypeIdPair] :
make_range(TidIter)) {
3703 Out <<
"vFuncId: (";
3704 auto Slot =
Machine.getTypeIdSlot(TypeIdPair.first);
3707 Out <<
", offset: " << VFId.
Offset;
3712void AssemblyWriter::printNonConstVCalls(
3713 const std::vector<FunctionSummary::VFuncId> &VCallList,
const char *
Tag) {
3714 Out <<
Tag <<
": (";
3716 for (
auto &VFuncId : VCallList) {
3718 printVFuncId(VFuncId);
3723void AssemblyWriter::printConstVCalls(
3724 const std::vector<FunctionSummary::ConstVCall> &VCallList,
3726 Out <<
Tag <<
": (";
3728 for (
auto &ConstVCall : VCallList) {
3731 printVFuncId(ConstVCall.VFunc);
3732 if (!ConstVCall.Args.empty()) {
3734 printArgs(ConstVCall.Args);
3741void AssemblyWriter::printSummary(
const GlobalValueSummary &Summary) {
3742 GlobalValueSummary::GVFlags GVFlags =
Summary.flags();
3745 Out <<
"(module: ^" <<
Machine.getModulePathSlot(
Summary.modulePath())
3748 Out <<
", visibility: "
3751 Out <<
", live: " << GVFlags.
Live;
3752 Out <<
", dsoLocal: " << GVFlags.
DSOLocal;
3754 Out <<
", importType: "
3765 auto RefList =
Summary.refs();
3766 if (!RefList.empty()) {
3769 for (
auto &
Ref : RefList) {
3771 if (
Ref.isReadOnly())
3773 else if (
Ref.isWriteOnly())
3774 Out <<
"writeonly ";
3775 Out <<
"^" <<
Machine.getGUIDSlot(
Ref.getGUID());
3783void AssemblyWriter::printSummaryInfo(
unsigned Slot,
const ValueInfo &VI) {
3784 Out <<
"^" <<
Slot <<
" = gv: (";
3785 if (
VI.hasName() && !
VI.name().empty())
3786 Out <<
"name: \"" <<
VI.name() <<
"\"";
3788 Out <<
"guid: " <<
VI.getGUID();
3789 if (!
VI.getSummaryList().empty()) {
3790 Out <<
", summaries: (";
3792 for (
auto &Summary :
VI.getSummaryList()) {
3794 printSummary(*Summary);
3799 if (
VI.hasName() && !
VI.name().empty())
3800 Out <<
" ; guid = " <<
VI.getGUID();
3807 Out <<
"<empty name> ";
3809 unsigned char FirstC =
static_cast<unsigned char>(Name[0]);
3810 if (isalpha(FirstC) || FirstC ==
'-' || FirstC ==
'$' || FirstC ==
'.' ||
3815 for (
unsigned i = 1, e = Name.size(); i != e; ++i) {
3816 unsigned char C = Name[i];
3817 if (isalnum(
C) ||
C ==
'-' ||
C ==
'$' ||
C ==
'.' ||
C ==
'_')
3825void AssemblyWriter::printNamedMDNode(
const NamedMDNode *NMD) {
3862 Out <<
"dso_local ";
3880 Out <<
"thread_local ";
3883 Out <<
"thread_local(localdynamic) ";
3886 Out <<
"thread_local(initialexec) ";
3889 Out <<
"thread_local(localexec) ";
3899 return "local_unnamed_addr";
3901 return "unnamed_addr";
3924void AssemblyWriter::printGlobal(
const GlobalVariable *GV) {
3926 Out <<
"; Materializable\n";
3947 Out << (GV->
isConstant() ?
"constant " :
"global ");
3956 Out <<
", section \"";
3961 Out <<
", partition \"";
3966 Out <<
", code_model \"";
3991 Out <<
", no_sanitize_address";
3993 Out <<
", no_sanitize_hwaddress";
3995 Out <<
", sanitize_memtag";
3997 Out <<
", sanitize_address_dyninit";
4002 Out <<
", align " <<
A->value();
4006 printMetadataAttachments(MDs,
", ");
4009 if (
Attrs.hasAttributes())
4010 Out <<
" #" <<
Machine.getAttributeGroupSlot(Attrs);
4012 printInfoComment(*GV);
4015void AssemblyWriter::printAlias(
const GlobalAlias *GA) {
4017 Out <<
"; Materializable\n";
4037 if (
const Constant *Aliasee = GA->
getAliasee()) {
4040 TypePrinter.print(GA->
getType(), Out);
4041 Out <<
" <<NULL ALIASEE>>";
4045 Out <<
", partition \"";
4050 printInfoComment(*GA);
4054void AssemblyWriter::printIFunc(
const GlobalIFunc *GI) {
4056 Out <<
"; Materializable\n";
4071 if (
const Constant *Resolver = GI->
getResolver()) {
4074 TypePrinter.print(GI->
getType(), Out);
4075 Out <<
" <<NULL RESOLVER>>";
4079 Out <<
", partition \"";
4086 printMetadataAttachments(MDs,
", ");
4089 printInfoComment(*GI);
4093void AssemblyWriter::printComdat(
const Comdat *
C) {
4097void AssemblyWriter::printTypeIdentities() {
4098 if (TypePrinter.empty())
4104 auto &NumberedTypes = TypePrinter.getNumberedTypes();
4105 for (
unsigned I = 0,
E = NumberedTypes.size();
I !=
E; ++
I) {
4106 Out <<
'%' <<
I <<
" = type ";
4110 TypePrinter.printStructBody(NumberedTypes[
I], Out);
4114 auto &NamedTypes = TypePrinter.getNamedTypes();
4115 for (StructType *NamedType : NamedTypes) {
4121 TypePrinter.printStructBody(NamedType, Out);
4127void AssemblyWriter::printFunction(
const Function *
F) {
4130 if (
F->isMaterializable())
4131 Out <<
"; Materializable\n";
4133 const AttributeList &
Attrs =
F->getAttributes();
4134 if (
Attrs.hasFnAttrs()) {
4135 AttributeSet AS =
Attrs.getFnAttrs();
4136 std::string AttrStr;
4139 if (!Attr.isStringAttribute()) {
4140 if (!AttrStr.empty()) AttrStr +=
' ';
4141 AttrStr += Attr.getAsString();
4145 if (!AttrStr.empty())
4146 Out <<
"; Function Attrs: " << AttrStr <<
'\n';
4150 Out <<
"; Unknown intrinsic\n";
4154 if (
F->isDeclaration()) {
4157 F->getAllMetadata(MDs);
4158 printMetadataAttachments(MDs,
" ");
4169 if (
F->getCallingConv() != CallingConv::C) {
4174 FunctionType *FT =
F->getFunctionType();
4175 if (
Attrs.hasRetAttrs())
4176 Out <<
Attrs.getAsString(AttributeList::ReturnIndex) <<
' ';
4177 TypePrinter.print(
F->getReturnType(), Out);
4184 if (
F->isDeclaration() && !IsForDebug) {
4186 for (
unsigned I = 0,
E = FT->getNumParams();
I !=
E; ++
I) {
4191 TypePrinter.print(FT->getParamType(
I), Out);
4193 AttributeSet ArgAttrs =
Attrs.getParamAttrs(
I);
4196 writeAttributeSet(ArgAttrs);
4201 for (
const Argument &Arg :
F->args()) {
4203 if (Arg.getArgNo() != 0)
4205 printArgument(&Arg,
Attrs.getParamAttrs(Arg.getArgNo()));
4210 if (FT->isVarArg()) {
4211 if (FT->getNumParams()) Out <<
", ";
4222 if (
F->getAddressSpace() != 0 || !
Mod ||
4223 Mod->getDataLayout().getProgramAddressSpace() != 0)
4224 Out <<
" addrspace(" <<
F->getAddressSpace() <<
")";
4225 if (
Attrs.hasFnAttrs())
4226 Out <<
" #" <<
Machine.getAttributeGroupSlot(
Attrs.getFnAttrs());
4227 if (
F->hasSection()) {
4228 Out <<
" section \"";
4232 if (
F->hasPartition()) {
4233 Out <<
" partition \"";
4238 if (MaybeAlign
A =
F->getAlign())
4239 Out <<
" align " <<
A->value();
4241 Out <<
" gc \"" <<
F->getGC() <<
'"';
4242 if (
F->hasPrefixData()) {
4244 writeOperand(
F->getPrefixData(),
true);
4246 if (
F->hasPrologueData()) {
4247 Out <<
" prologue ";
4248 writeOperand(
F->getPrologueData(),
true);
4250 if (
F->hasPersonalityFn()) {
4251 Out <<
" personality ";
4252 writeOperand(
F->getPersonalityFn(),
true);
4256 if (
auto *MDProf =
F->getMetadata(LLVMContext::MD_prof)) {
4258 MDProf->print(Out, TheModule,
true);
4262 if (
F->isDeclaration()) {
4266 F->getAllMetadata(MDs);
4267 printMetadataAttachments(MDs,
" ");
4271 for (
const BasicBlock &BB : *
F)
4272 printBasicBlock(&BB);
4285void AssemblyWriter::printArgument(
const Argument *Arg, AttributeSet Attrs) {
4287 TypePrinter.print(Arg->
getType(), Out);
4290 if (
Attrs.hasAttributes()) {
4292 writeAttributeSet(Attrs);
4301 assert(Slot != -1 &&
"expect argument in function here");
4302 Out <<
" %" <<
Slot;
4307void AssemblyWriter::printBasicBlock(
const BasicBlock *BB) {
4313 }
else if (!IsEntryBlock) {
4322 if (!IsEntryBlock) {
4329 Out <<
" No predecessors!";
4332 writeOperand(*PI,
false);
4333 for (++PI; PI != PE; ++PI) {
4335 writeOperand(*PI,
false);
4345 for (
const Instruction &
I : *BB) {
4346 for (
const DbgRecord &DR :
I.getDbgRecordRange())
4347 printDbgRecordLine(DR);
4348 printInstructionLine(
I);
4355void AssemblyWriter::printInstructionLine(
const Instruction &
I) {
4356 printInstruction(
I);
4362void AssemblyWriter::printGCRelocateComment(
const GCRelocateInst &Relocate) {
4372void AssemblyWriter::printInfoComment(
const Value &V) {
4374 printGCRelocateComment(*Relocate);
4376 if (AnnotationWriter) {
4382 if (
I->getDebugLoc()) {
4384 I->getDebugLoc().print(Out);
4390 if (
auto *MD =
I->getMetadata(LLVMContext::MD_prof)) {
4392 MD->print(Out, TheModule,
true);
4404 if (Operand ==
nullptr) {
4405 Out <<
" <cannot get addrspace!>";
4409 bool PrintAddrSpace = CallAddrSpace != 0;
4410 if (!PrintAddrSpace) {
4415 if (!
Mod ||
Mod->getDataLayout().getProgramAddressSpace() != 0)
4416 PrintAddrSpace =
true;
4419 Out <<
" addrspace(" << CallAddrSpace <<
")";
4423void AssemblyWriter::printInstruction(
const Instruction &
I) {
4433 }
else if (!
I.getType()->isVoidTy()) {
4435 int SlotNum =
Machine.getLocalSlot(&
I);
4437 Out <<
"<badref> = ";
4439 Out <<
'%' << SlotNum <<
" = ";
4443 if (CI->isMustTailCall())
4445 else if (CI->isTailCall())
4447 else if (CI->isNoTailCall())
4452 Out <<
I.getOpcodeName();
4474 Out <<
' ' << CI->getPredicate();
4481 const Value *Operand =
I.getNumOperands() ?
I.getOperand(0) :
nullptr;
4487 writeOperand(BI.getCondition(),
true);
4489 writeOperand(BI.getSuccessor(0),
true);
4491 writeOperand(BI.getSuccessor(1),
true);
4497 writeOperand(
SI.getCondition(),
true);
4499 writeOperand(
SI.getDefaultDest(),
true);
4501 for (
auto Case :
SI.cases()) {
4503 writeOperand(Case.getCaseValue(),
true);
4505 writeOperand(Case.getCaseSuccessor(),
true);
4511 writeOperand(Operand,
true);
4514 for (
unsigned i = 1, e =
I.getNumOperands(); i != e; ++i) {
4517 writeOperand(
I.getOperand(i),
true);
4522 TypePrinter.print(
I.getType(), Out);
4525 for (
unsigned op = 0, Eop = PN->getNumIncomingValues();
op < Eop; ++
op) {
4526 if (
op) Out <<
", ";
4528 writeOperand(PN->getIncomingValue(
op),
false); Out <<
", ";
4529 writeOperand(PN->getIncomingBlock(
op),
false); Out <<
" ]";
4533 writeOperand(
I.getOperand(0),
true);
4534 for (
unsigned i : EVI->indices())
4538 writeOperand(
I.getOperand(0),
true); Out <<
", ";
4539 writeOperand(
I.getOperand(1),
true);
4540 for (
unsigned i : IVI->indices())
4544 TypePrinter.print(
I.getType(), Out);
4545 if (LPI->isCleanup() || LPI->getNumClauses() != 0)
4548 if (LPI->isCleanup())
4551 for (
unsigned i = 0, e = LPI->getNumClauses(); i != e; ++i) {
4552 if (i != 0 || LPI->isCleanup()) Out <<
"\n";
4553 if (LPI->isCatch(i))
4558 writeOperand(LPI->getClause(i),
true);
4562 writeOperand(CatchSwitch->getParentPad(),
false);
4565 for (
const BasicBlock *PadBB : CatchSwitch->handlers()) {
4568 writeOperand(PadBB,
true);
4572 if (
const BasicBlock *UnwindDest = CatchSwitch->getUnwindDest())
4573 writeOperand(UnwindDest,
true);
4578 writeOperand(FPI->getParentPad(),
false);
4583 writeOperand(FPI->getArgOperand(
Op),
true);
4590 writeOperand(CRI->getOperand(0),
false);
4593 writeOperand(CRI->getOperand(1),
true);
4596 writeOperand(CRI->getOperand(0),
false);
4599 if (CRI->hasUnwindDest())
4600 writeOperand(CRI->getOperand(1),
true);
4605 if (CI->getCallingConv() != CallingConv::C) {
4610 Operand = CI->getCalledOperand();
4611 FunctionType *FTy = CI->getFunctionType();
4612 Type *RetTy = FTy->getReturnType();
4613 const AttributeList &PAL = CI->getAttributes();
4615 if (PAL.hasRetAttrs())
4616 Out <<
' ' << PAL.getAsString(AttributeList::ReturnIndex);
4625 TypePrinter.print(FTy->isVarArg() ? FTy : RetTy, Out);
4627 writeOperand(Operand,
false);
4629 for (
unsigned op = 0, Eop = CI->arg_size();
op < Eop; ++
op) {
4632 writeParamOperand(CI->getArgOperand(
op), PAL.getParamAttrs(
op));
4637 if (CI->isMustTailCall() && CI->getParent() &&
4638 CI->getParent()->getParent() &&
4639 CI->getParent()->getParent()->isVarArg()) {
4640 if (CI->arg_size() > 0)
4646 if (PAL.hasFnAttrs())
4647 Out <<
" #" <<
Machine.getAttributeGroupSlot(PAL.getFnAttrs());
4649 writeOperandBundles(CI);
4651 Operand =
II->getCalledOperand();
4652 FunctionType *FTy =
II->getFunctionType();
4653 Type *RetTy = FTy->getReturnType();
4654 const AttributeList &PAL =
II->getAttributes();
4657 if (
II->getCallingConv() != CallingConv::C) {
4662 if (PAL.hasRetAttrs())
4663 Out <<
' ' << PAL.getAsString(AttributeList::ReturnIndex);
4673 TypePrinter.print(FTy->isVarArg() ? FTy : RetTy, Out);
4675 writeOperand(Operand,
false);
4677 for (
unsigned op = 0, Eop =
II->arg_size();
op < Eop; ++
op) {
4680 writeParamOperand(
II->getArgOperand(
op), PAL.getParamAttrs(
op));
4684 if (PAL.hasFnAttrs())
4685 Out <<
" #" <<
Machine.getAttributeGroupSlot(PAL.getFnAttrs());
4687 writeOperandBundles(
II);
4690 writeOperand(
II->getNormalDest(),
true);
4692 writeOperand(
II->getUnwindDest(),
true);
4694 Operand = CBI->getCalledOperand();
4695 FunctionType *FTy = CBI->getFunctionType();
4696 Type *RetTy = FTy->getReturnType();
4697 const AttributeList &PAL = CBI->getAttributes();
4700 if (CBI->getCallingConv() != CallingConv::C) {
4705 if (PAL.hasRetAttrs())
4706 Out <<
' ' << PAL.getAsString(AttributeList::ReturnIndex);
4713 TypePrinter.print(FTy->isVarArg() ? FTy : RetTy, Out);
4715 writeOperand(Operand,
false);
4717 for (
unsigned op = 0, Eop = CBI->arg_size();
op < Eop; ++
op) {
4720 writeParamOperand(CBI->getArgOperand(
op), PAL.getParamAttrs(
op));
4724 if (PAL.hasFnAttrs())
4725 Out <<
" #" <<
Machine.getAttributeGroupSlot(PAL.getFnAttrs());
4727 writeOperandBundles(CBI);
4730 writeOperand(CBI->getDefaultDest(),
true);
4732 for (
unsigned i = 0, e = CBI->getNumIndirectDests(); i != e; ++i) {
4735 writeOperand(CBI->getIndirectDest(i),
true);
4740 if (AI->isUsedWithInAlloca())
4742 if (AI->isSwiftError())
4743 Out <<
"swifterror ";
4744 TypePrinter.print(AI->getAllocatedType(), Out);
4750 if (!AI->getArraySize() || AI->isArrayAllocation() ||
4751 !AI->getArraySize()->getType()->isIntegerTy(32)) {
4753 writeOperand(AI->getArraySize(),
true);
4755 if (MaybeAlign
A = AI->getAlign()) {
4756 Out <<
", align " <<
A->value();
4759 unsigned AddrSpace = AI->getAddressSpace();
4760 if (AddrSpace != 0) {
4761 Out <<
", addrspace(" << AddrSpace <<
')';
4766 writeOperand(Operand,
true);
4769 TypePrinter.print(
I.getType(), Out);
4773 writeOperand(Operand,
true);
4776 TypePrinter.print(
I.getType(), Out);
4777 }
else if (Operand) {
4780 TypePrinter.print(
GEP->getSourceElementType(), Out);
4784 TypePrinter.print(LI->getType(), Out);
4791 bool PrintAllTypes =
false;
4799 PrintAllTypes =
true;
4801 for (
unsigned i = 1,
E =
I.getNumOperands(); i !=
E; ++i) {
4802 Operand =
I.getOperand(i);
4805 if (Operand && Operand->
getType() != TheType) {
4806 PrintAllTypes =
true;
4812 if (!PrintAllTypes) {
4814 TypePrinter.print(TheType, Out);
4818 for (
unsigned i = 0,
E =
I.getNumOperands(); i !=
E; ++i) {
4820 writeOperand(
I.getOperand(i), PrintAllTypes);
4827 writeAtomic(LI->getContext(), LI->getOrdering(), LI->getSyncScopeID());
4828 if (MaybeAlign
A = LI->getAlign())
4829 Out <<
", align " <<
A->value();
4832 writeAtomic(
SI->getContext(),
SI->getOrdering(),
SI->getSyncScopeID());
4833 if (MaybeAlign
A =
SI->getAlign())
4834 Out <<
", align " <<
A->value();
4836 writeAtomicCmpXchg(CXI->getContext(), CXI->getSuccessOrdering(),
4837 CXI->getFailureOrdering(), CXI->getSyncScopeID());
4838 Out <<
", align " << CXI->getAlign().value();
4840 writeAtomic(RMWI->getContext(), RMWI->getOrdering(),
4841 RMWI->getSyncScopeID());
4842 Out <<
", align " << RMWI->getAlign().value();
4844 writeAtomic(FI->getContext(), FI->getOrdering(), FI->getSyncScopeID());
4852 printMetadataAttachments(InstMD,
", ");
4855 printInfoComment(
I);
4858void AssemblyWriter::printDbgMarker(
const DbgMarker &Marker) {
4862 printDbgRecord(DPR);
4866 Out <<
" DbgMarker -> { ";
4871void AssemblyWriter::printDbgRecord(
const DbgRecord &DR) {
4873 printDbgVariableRecord(*DVR);
4875 printDbgLabelRecord(*DLR);
4880void AssemblyWriter::printDbgVariableRecord(
const DbgVariableRecord &DVR) {
4884 case DbgVariableRecord::LocationType::Value:
4887 case DbgVariableRecord::LocationType::Declare:
4890 case DbgVariableRecord::LocationType::Assign:
4895 "Tried to print a DbgVariableRecord with an invalid LocationType!");
4926void AssemblyWriter::printDbgRecordLine(
const DbgRecord &DR) {
4933void AssemblyWriter::printDbgLabelRecord(
const DbgLabelRecord &Label) {
4935 Out <<
"#dbg_label(";
4942void AssemblyWriter::printMetadataAttachments(
4943 const SmallVectorImpl<std::pair<unsigned, MDNode *>> &MDs,
4944 StringRef Separator) {
4948 if (MDNames.empty())
4949 MDs[0].second->getContext().getMDKindNames(MDNames);
4952 for (
const auto &
I : MDs) {
4953 unsigned Kind =
I.first;
4955 if (Kind < MDNames.size()) {
4959 Out <<
"!<unknown kind #" <<
Kind <<
">";
4965void AssemblyWriter::writeMDNode(
unsigned Slot,
const MDNode *Node) {
4966 Out <<
'!' <<
Slot <<
" = ";
4967 printMDNodeBody(Node);
4971void AssemblyWriter::writeAllMDNodes() {
4977 for (
unsigned i = 0, e = Nodes.
size(); i != e; ++i) {
4978 writeMDNode(i, Nodes[i]);
4982void AssemblyWriter::printMDNodeBody(
const MDNode *Node) {
4987void AssemblyWriter::writeAttribute(
const Attribute &Attr,
bool InAttrGroup) {
4993 Out << Attribute::getNameFromAttrKind(Attr.
getKindAsEnum());
4996 TypePrinter.print(Ty, Out);
5001void AssemblyWriter::writeAttributeSet(
const AttributeSet &AttrSet,
5003 bool FirstAttr =
true;
5004 for (
const auto &Attr : AttrSet) {
5007 writeAttribute(Attr, InAttrGroup);
5012void AssemblyWriter::writeAllAttributeGroups() {
5013 std::vector<std::pair<AttributeSet, unsigned>> asVec;
5014 asVec.resize(
Machine.as_size());
5017 asVec[
I.second] =
I;
5019 for (
const auto &
I : asVec)
5020 Out <<
"attributes #" <<
I.second <<
" = { "
5021 <<
I.first.getAsString(
true) <<
" }\n";
5024void AssemblyWriter::printUseListOrder(
const Value *V,
5025 const std::vector<unsigned> &Shuffle) {
5030 Out <<
"uselistorder";
5033 writeOperand(BB->getParent(),
false);
5035 writeOperand(BB,
false);
5038 writeOperand(V,
true);
5041 assert(Shuffle.size() >= 2 &&
"Shuffle too small");
5045void AssemblyWriter::printUseLists(
const Function *
F) {
5046 auto It = UseListOrders.find(
F);
5047 if (It == UseListOrders.end())
5050 Out <<
"\n; uselistorder directives\n";
5051 for (
const auto &Pair : It->second)
5052 printUseListOrder(Pair.first, Pair.second);
5060 bool ShouldPreserveUseListOrder,
5061 bool IsForDebug)
const {
5064 AssemblyWriter W(OS, SlotTable, this->
getParent(), AAW,
5066 ShouldPreserveUseListOrder);
5067 W.printFunction(
this);
5071 bool ShouldPreserveUseListOrder,
5072 bool IsForDebug)
const {
5075 AssemblyWriter W(OS, SlotTable, this->
getModule(), AAW,
5077 ShouldPreserveUseListOrder);
5078 W.printBasicBlock(
this);
5082 bool ShouldPreserveUseListOrder,
bool IsForDebug)
const {
5085 AssemblyWriter W(OS, SlotTable,
this, AAW, IsForDebug,
5086 ShouldPreserveUseListOrder);
5087 W.printModule(
this);
5093 AssemblyWriter W(OS, SlotTable,
getParent(),
nullptr, IsForDebug);
5094 W.printNamedMDNode(
this);
5098 bool IsForDebug)
const {
5099 std::optional<SlotTracker> LocalST;
5105 SlotTable = &*LocalST;
5109 AssemblyWriter W(OS, *SlotTable,
getParent(),
nullptr, IsForDebug);
5110 W.printNamedMDNode(
this);
5115 ROS <<
" = comdat ";
5122 ROS <<
"exactmatch";
5128 ROS <<
"nodeduplicate";
5140 TP.print(
const_cast<Type*
>(
this), OS);
5149 TP.printStructBody(STy, OS);
5155 if (
Function *
F = CI->getCalledFunction())
5156 if (
F->isIntrinsic())
5157 for (
auto &
Op :
I.operands())
5167 print(ROS, MST, IsForDebug);
5173 print(ROS, MST, IsForDebug);
5177 bool IsForDebug)
const {
5182 auto incorporateFunction = [&](
const Function *
F) {
5187 AssemblyWriter W(OS, SlotTable,
getModuleFromDPI(
this),
nullptr, IsForDebug);
5188 W.printDbgMarker(*
this);
5194 print(ROS, MST, IsForDebug);
5198 bool IsForDebug)
const {
5203 auto incorporateFunction = [&](
const Function *
F) {
5208 ?
Marker->getParent()->getParent()
5210 AssemblyWriter W(OS, SlotTable,
getModuleFromDPI(
this),
nullptr, IsForDebug);
5211 W.printDbgVariableRecord(*
this);
5215 bool IsForDebug)
const {
5220 auto incorporateFunction = [&](
const Function *
F) {
5224 incorporateFunction(
Marker->getParent() ?
Marker->getParent()->getParent()
5226 AssemblyWriter W(OS, SlotTable,
getModuleFromDPI(
this),
nullptr, IsForDebug);
5227 W.printDbgLabelRecord(*
this);
5231 bool ShouldInitializeAllMetadata =
false;
5235 ShouldInitializeAllMetadata =
true;
5238 print(ROS, MST, IsForDebug);
5242 bool IsForDebug)
const {
5247 auto incorporateFunction = [&](
const Function *
F) {
5253 incorporateFunction(
I->getParent() ?
I->getParent()->getParent() :
nullptr);
5255 W.printInstruction(*
I);
5257 incorporateFunction(BB->getParent());
5258 AssemblyWriter W(OS, SlotTable,
getModuleFromVal(BB),
nullptr, IsForDebug);
5259 W.printBasicBlock(BB);
5261 AssemblyWriter W(OS, SlotTable, GV->
getParent(),
nullptr, IsForDebug);
5275 TypePrinting TypePrinter;
5276 TypePrinter.print(
C->getType(), OS);
5278 AsmWriterContext WriterCtx(&TypePrinter, MST.
getMachine());
5294 AsmWriterContext WriterCtx(
nullptr,
Machine, M);
5303 TypePrinting TypePrinter(MST.
getModule());
5305 TypePrinter.print(V.getType(), O);
5339 AsmWriterContext &WriterCtx) {
5352struct MDTreeAsmWriterContext :
public AsmWriterContext {
5355 using EntryTy = std::pair<unsigned, std::string>;
5359 SmallPtrSet<const Metadata *, 4> Visited;
5361 raw_ostream &MainOS;
5363 MDTreeAsmWriterContext(TypePrinting *TP, SlotTracker *ST,
const Module *M,
5364 raw_ostream &OS,
const Metadata *InitMD)
5365 : AsmWriterContext(TP,
ST,
M),
Level(0
U), Visited({InitMD}), MainOS(OS) {}
5367 void onWriteMetadataAsOperand(
const Metadata *MD)
override {
5368 if (!Visited.
insert(MD).second)
5372 raw_string_ostream
SS(Str);
5377 unsigned InsertIdx = Buffer.
size() - 1;
5380 Buffer[InsertIdx].second = std::move(
SS.str());
5384 ~MDTreeAsmWriterContext() {
5385 for (
const auto &Entry : Buffer) {
5387 unsigned NumIndent =
Entry.first * 2U;
5396 bool OnlyAsOperand,
bool PrintAsTree =
false) {
5399 TypePrinting TypePrinter(M);
5401 std::unique_ptr<AsmWriterContext> WriterCtx;
5402 if (PrintAsTree && !OnlyAsOperand)
5403 WriterCtx = std::make_unique<MDTreeAsmWriterContext>(
5407 std::make_unique<AsmWriterContext>(&TypePrinter, MST.
getMachine(), M);
5436 const Module *M,
bool )
const {
5455 AssemblyWriter W(OS, SlotTable,
this, IsForDebug);
5456 W.printModuleSummaryIndex();
5460 unsigned UB)
const {
5466 if (
I.second >= LB &&
I.second < UB)
5467 L.push_back(std::make_pair(
I.second,
I.first));
5470#if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP)
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
This file declares a class to represent arbitrary precision floating point values and provide a varie...
This file implements a class to represent arbitrary precision integral constant values and operations...
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
static void print(raw_ostream &Out, object::Archive::Kind Kind, T Val)
static void writeDIMacro(raw_ostream &Out, const DIMacro *N, AsmWriterContext &WriterCtx)
static void writeMetadataAsOperand(raw_ostream &Out, const Metadata *MD, AsmWriterContext &WriterCtx)
static void writeDIGlobalVariableExpression(raw_ostream &Out, const DIGlobalVariableExpression *N, AsmWriterContext &WriterCtx)
static void PrintCallingConv(unsigned cc, raw_ostream &Out)
static void writeDICompositeType(raw_ostream &Out, const DICompositeType *N, AsmWriterContext &WriterCtx)
static void writeDIFixedPointType(raw_ostream &Out, const DIFixedPointType *N, AsmWriterContext &WriterCtx)
static const char * getWholeProgDevirtResKindName(WholeProgramDevirtResolution::Kind K)
static void writeDISubrangeType(raw_ostream &Out, const DISubrangeType *N, AsmWriterContext &WriterCtx)
static void printMetadataImpl(raw_ostream &ROS, const Metadata &MD, ModuleSlotTracker &MST, const Module *M, bool OnlyAsOperand, bool PrintAsTree=false)
static void WriteOptimizationInfo(raw_ostream &Out, const User *U)
static void writeDIStringType(raw_ostream &Out, const DIStringType *N, AsmWriterContext &WriterCtx)
static std::string getLinkageNameWithSpace(GlobalValue::LinkageTypes LT)
static std::vector< unsigned > predictValueUseListOrder(const Value *V, unsigned ID, const OrderMap &OM)
static void writeDIGlobalVariable(raw_ostream &Out, const DIGlobalVariable *N, AsmWriterContext &WriterCtx)
static void orderValue(const Value *V, OrderMap &OM)
static void PrintThreadLocalModel(GlobalVariable::ThreadLocalMode TLM, formatted_raw_ostream &Out)
static void writeDIBasicType(raw_ostream &Out, const DIBasicType *N, AsmWriterContext &WriterCtx)
static void PrintLLVMName(raw_ostream &OS, StringRef Name, PrefixType Prefix)
Turn the specified name into an 'LLVM name', which is either prefixed with % (if the string only cont...
static StringRef getUnnamedAddrEncoding(GlobalVariable::UnnamedAddr UA)
static const char * getWholeProgDevirtResByArgKindName(WholeProgramDevirtResolution::ByArg::Kind K)
static void PrintShuffleMask(raw_ostream &Out, Type *Ty, ArrayRef< int > Mask)
static void writeDIModule(raw_ostream &Out, const DIModule *N, AsmWriterContext &WriterCtx)
static void writeDIFile(raw_ostream &Out, const DIFile *N, AsmWriterContext &)
static void writeDISubroutineType(raw_ostream &Out, const DISubroutineType *N, AsmWriterContext &WriterCtx)
static bool isReferencingMDNode(const Instruction &I)
#define CC_VLS_CASE(ABI_VLEN)
static void writeDILabel(raw_ostream &Out, const DILabel *N, AsmWriterContext &WriterCtx)
static void WriteMDNodeBodyInternal(raw_ostream &Out, const MDNode *Node, AsmWriterContext &Ctx)
static void writeDIDerivedType(raw_ostream &Out, const DIDerivedType *N, AsmWriterContext &WriterCtx)
static void printMetadataIdentifier(StringRef Name, formatted_raw_ostream &Out)
static void writeDIImportedEntity(raw_ostream &Out, const DIImportedEntity *N, AsmWriterContext &WriterCtx)
static const Module * getModuleFromDPI(const DbgMarker *Marker)
static void printAsOperandImpl(const Value &V, raw_ostream &O, bool PrintType, ModuleSlotTracker &MST)
static void writeDIObjCProperty(raw_ostream &Out, const DIObjCProperty *N, AsmWriterContext &WriterCtx)
static void PrintDLLStorageClass(GlobalValue::DLLStorageClassTypes SCT, formatted_raw_ostream &Out)
static void writeDISubprogram(raw_ostream &Out, const DISubprogram *N, AsmWriterContext &WriterCtx)
static const char * getSummaryKindName(GlobalValueSummary::SummaryKind SK)
static OrderMap orderModule(const Module *M)
static const char * getVisibilityName(GlobalValue::VisibilityTypes Vis)
static cl::opt< bool > PrintInstDebugLocs("print-inst-debug-locs", cl::Hidden, cl::desc("Pretty print debug locations of instructions when dumping"))
static void printMetadataImplRec(raw_ostream &ROS, const Metadata &MD, AsmWriterContext &WriterCtx)
Recursive version of printMetadataImpl.
static SlotTracker * createSlotTracker(const Value *V)
static void WriteAPFloatInternal(raw_ostream &Out, const APFloat &APF)
static void writeDILocation(raw_ostream &Out, const DILocation *DL, AsmWriterContext &WriterCtx)
static void writeDINamespace(raw_ostream &Out, const DINamespace *N, AsmWriterContext &WriterCtx)
DenseMap< const Function *, MapVector< const Value *, std::vector< unsigned > > > UseListOrderMap
static void writeDICommonBlock(raw_ostream &Out, const DICommonBlock *N, AsmWriterContext &WriterCtx)
static UseListOrderMap predictUseListOrder(const Module *M)
static void WriteConstantInternal(raw_ostream &Out, const Constant *CV, AsmWriterContext &WriterCtx)
static void WriteAsOperandInternal(raw_ostream &Out, const Value *V, AsmWriterContext &WriterCtx)
static std::string getLinkageName(GlobalValue::LinkageTypes LT)
static void writeGenericDINode(raw_ostream &Out, const GenericDINode *N, AsmWriterContext &WriterCtx)
static void writeDILocalVariable(raw_ostream &Out, const DILocalVariable *N, AsmWriterContext &WriterCtx)
static const char * getTTResKindName(TypeTestResolution::Kind K)
static void writeDITemplateTypeParameter(raw_ostream &Out, const DITemplateTypeParameter *N, AsmWriterContext &WriterCtx)
static const char * getImportTypeName(GlobalValueSummary::ImportKind IK)
static void writeDICompileUnit(raw_ostream &Out, const DICompileUnit *N, AsmWriterContext &WriterCtx)
static const Module * getModuleFromVal(const Value *V)
static void maybePrintCallAddrSpace(const Value *Operand, const Instruction *I, raw_ostream &Out)
static void writeDIGenericSubrange(raw_ostream &Out, const DIGenericSubrange *N, AsmWriterContext &WriterCtx)
static void writeDISubrange(raw_ostream &Out, const DISubrange *N, AsmWriterContext &WriterCtx)
static void PrintVisibility(GlobalValue::VisibilityTypes Vis, formatted_raw_ostream &Out)
static void writeDILexicalBlockFile(raw_ostream &Out, const DILexicalBlockFile *N, AsmWriterContext &WriterCtx)
static void writeDIEnumerator(raw_ostream &Out, const DIEnumerator *N, AsmWriterContext &)
static cl::opt< bool > PrintProfData("print-prof-data", cl::Hidden, cl::desc("Pretty print perf data (branch weights, etc) when dumping"))
static void writeMDTuple(raw_ostream &Out, const MDTuple *Node, AsmWriterContext &WriterCtx)
static void writeDIExpression(raw_ostream &Out, const DIExpression *N, AsmWriterContext &WriterCtx)
static void PrintDSOLocation(const GlobalValue &GV, formatted_raw_ostream &Out)
static cl::opt< bool > PrintInstAddrs("print-inst-addrs", cl::Hidden, cl::desc("Print addresses of instructions when dumping"))
static void writeDIAssignID(raw_ostream &Out, const DIAssignID *DL, AsmWriterContext &WriterCtx)
static void writeDILexicalBlock(raw_ostream &Out, const DILexicalBlock *N, AsmWriterContext &WriterCtx)
static void maybePrintComdat(formatted_raw_ostream &Out, const GlobalObject &GO)
static bool printWithoutType(const Value &V, raw_ostream &O, SlotTracker *Machine, const Module *M)
Print without a type, skipping the TypePrinting object.
static void writeDIArgList(raw_ostream &Out, const DIArgList *N, AsmWriterContext &WriterCtx, bool FromValue=false)
static void writeDITemplateValueParameter(raw_ostream &Out, const DITemplateValueParameter *N, AsmWriterContext &WriterCtx)
static const Value * skipMetadataWrapper(const Value *V)
Look for a value that might be wrapped as metadata, e.g.
static void writeDIMacroFile(raw_ostream &Out, const DIMacroFile *N, AsmWriterContext &WriterCtx)
Atomic ordering constants.
This file contains the simple types necessary to represent the attributes associated with functions a...
static const Function * getParent(const Value *V)
static GCRegistry::Add< ErlangGC > A("erlang", "erlang-compatible garbage collector")
static GCRegistry::Add< CoreCLRGC > E("coreclr", "CoreCLR-compatible GC")
#define LLVM_DUMP_METHOD
Mark debug helper function definitions like dump() that should not be stripped from debug builds.
This file contains the declarations for the subclasses of Constant, which represent the different fla...
dxil pretty DXIL Metadata Pretty Printer
This file defines the DenseMap class.
This file contains constants used for implementing Dwarf debug support.
This file contains the declaration of the GlobalIFunc class, which represents a single indirect funct...
GlobalValue::SanitizerMetadata SanitizerMetadata
This file provides various utilities for inspecting and working with the control flow graph in LLVM I...
This file contains an interface for creating legacy passes to print out IR in various granularities.
Module.h This file contains the declarations for the Module class.
This defines the Use class.
const size_t AbstractManglingParser< Derived, Alloc >::NumOps
Machine Check Debug Module
static bool InRange(int64_t Value, unsigned short Shift, int LBound, int HBound)
ModuleSummaryIndex.h This file contains the declarations the classes that hold the module index and s...
static bool processFunction(Function &F, NVPTXTargetMachine &TM)
ConstantRange Range(APInt(BitWidth, Low), APInt(BitWidth, High))
uint64_t IntrinsicInst * II
Function const char TargetMachine * Machine
if(auto Err=PB.parsePassPipeline(MPM, Passes)) return wrap(std MPM run * Mod
static StringRef getName(Value *V)
This file provides utility classes that use RAII to save and restore values.
This file implements a set that has insertion order iteration characteristics.
This file defines the SmallPtrSet class.
This file defines the SmallString class.
This file defines the SmallVector class.
LocallyHashedType DenseMapInfo< LocallyHashedType >::Empty
static UseListOrderStack predictUseListOrder(const Module &M)
static APFloat getSNaN(const fltSemantics &Sem, bool Negative=false, const APInt *payload=nullptr)
Factory for SNaN values.
LLVM_ABI opStatus convert(const fltSemantics &ToSemantics, roundingMode RM, bool *losesInfo)
LLVM_ABI double convertToDouble() const
Converts this APFloat to host double value.
void toString(SmallVectorImpl< char > &Str, unsigned FormatPrecision=0, unsigned FormatMaxPadding=3, bool TruncateZero=true) const
const fltSemantics & getSemantics() const
APInt bitcastToAPInt() const
Class for arbitrary precision integers.
LLVM_ABI APInt getLoBits(unsigned numBits) const
Compute an APInt containing numBits lowbits from this APInt.
uint64_t getZExtValue() const
Get zero extended value.
LLVM_ABI APInt getHiBits(unsigned numBits) const
Compute an APInt containing numBits highbits from this APInt.
Abstract interface of slot tracker storage.
virtual ~AbstractSlotTrackerStorage()
const GlobalValueSummary & getAliasee() const
This class represents an incoming formal argument to a Function.
ArrayRef - Represent a constant reference to an array (0 or more elements consecutively in memory),...
virtual void emitBasicBlockStartAnnot(const BasicBlock *, formatted_raw_ostream &)
emitBasicBlockStartAnnot - This may be implemented to emit a string right after the basic block label...
virtual void emitBasicBlockEndAnnot(const BasicBlock *, formatted_raw_ostream &)
emitBasicBlockEndAnnot - This may be implemented to emit a string right after the basic block.
virtual void emitFunctionAnnot(const Function *, formatted_raw_ostream &)
emitFunctionAnnot - This may be implemented to emit a string right before the start of a function.
virtual void emitInstructionAnnot(const Instruction *, formatted_raw_ostream &)
emitInstructionAnnot - This may be implemented to emit a string right before an instruction is emitte...
virtual void printInfoComment(const Value &, formatted_raw_ostream &)
printInfoComment - This may be implemented to emit a comment to the right of an instruction or global...
virtual ~AssemblyAnnotationWriter()
static LLVM_ABI StringRef getOperationName(BinOp Op)
This class holds the attributes for a particular argument, parameter, function, or return value.
bool hasAttributes() const
Return true if attributes exists in this set.
LLVM_ABI std::string getAsString(bool InAttrGrp=false) const
The Attribute is converted to a string of equivalent mnemonic.
LLVM_ABI Attribute::AttrKind getKindAsEnum() const
Return the attribute's kind as an enum (Attribute::AttrKind).
LLVM_ABI bool isTypeAttribute() const
Return true if the attribute is a type attribute.
LLVM_ABI Type * getValueAsType() const
Return the attribute's value as a Type.
LLVM Basic Block Representation.
const Function * getParent() const
Return the enclosing method, or null if none.
LLVM_ABI void print(raw_ostream &OS, AssemblyAnnotationWriter *AAW=nullptr, bool ShouldPreserveUseListOrder=false, bool IsForDebug=false) const
Print the basic block to an output stream with an optional AssemblyAnnotationWriter.
LLVM_ABI bool isEntryBlock() const
Return true if this is the entry block of the containing function.
LLVM_ABI const Module * getModule() const
Return the module owning the function this basic block belongs to, or nullptr if the function does no...
The address of a basic block.
OperandBundleUse getOperandBundleAt(unsigned Index) const
Return the operand bundle at a specific index.
unsigned getNumOperandBundles() const
Return the number of operand bundles associated with this User.
AttributeList getAttributes() const
Return the attributes for this call.
bool hasOperandBundles() const
Return true if this User has any operand bundles.
LLVM_ABI void print(raw_ostream &OS, bool IsForDebug=false) const
LLVM_ABI void dump() const
@ Largest
The linker will choose the largest COMDAT.
@ SameSize
The data referenced by the COMDAT must be the same size.
@ Any
The linker may choose any COMDAT.
@ NoDeduplicate
No deduplication is performed.
@ ExactMatch
The data referenced by the COMDAT must be the same.
SelectionKind getSelectionKind() const
ConstantArray - Constant Array Declarations.
An array constant whose element type is a simple 1/2/4/8-byte integer or float/double,...
A constant value that is initialized with an expression using other constant values.
ConstantFP - Floating Point Values [float, double].
This is the shared class of boolean and integer constants.
A signed pointer, in the ptrauth sense.
LLVM_ABI APInt getSignedMin() const
Return the smallest signed value contained in the ConstantRange.
LLVM_ABI APInt getSignedMax() const
Return the largest signed value contained in the ConstantRange.
This is an important base class in LLVM.
LLVM_ABI Constant * getSplatValue(bool AllowPoison=false) const
If all elements of the vector constant have the same value, return that value.
LLVM_ABI Constant * getAggregateElement(unsigned Elt) const
For aggregates (struct/array/vector) return the constant that corresponds to the specified element if...
List of ValueAsMetadata, to be used as an argument to a dbg.value intrinsic.
Basic type, like 'int' or 'float'.
static LLVM_ABI const char * nameTableKindString(DebugNameTableKind PK)
static LLVM_ABI const char * emissionKindString(DebugEmissionKind EK)
A lightweight wrapper around an expression operand.
static LLVM_ABI const char * fixedPointKindString(FixedPointKind)
A pair of DIGlobalVariable and DIExpression.
An imported module (C++ using directive or similar).
Macro Info DWARF-like metadata node.
Represents a module in the programming language, for example, a Clang module, or a Fortran module.
Tagged DWARF-like metadata node.
static LLVM_ABI DIFlags splitFlags(DIFlags Flags, SmallVectorImpl< DIFlags > &SplitFlags)
Split up a flags bitfield.
static LLVM_ABI StringRef getFlagString(DIFlags Flag)
String type, Fortran CHARACTER(n)
Subprogram description. Uses SubclassData1.
static LLVM_ABI DISPFlags splitFlags(DISPFlags Flags, SmallVectorImpl< DISPFlags > &SplitFlags)
Split up a flags bitfield for easier printing.
static LLVM_ABI StringRef getFlagString(DISPFlags Flag)
DISPFlags
Debug info subprogram flags.
Type array for a subprogram.
LLVM_ABI void print(raw_ostream &O, bool IsForDebug=false) const
Per-instruction record of debug-info.
LLVM_ABI void dump() const
Instruction * MarkedInstr
Link back to the Instruction that owns this marker.
LLVM_ABI void print(raw_ostream &O, bool IsForDebug=false) const
Implement operator<< on DbgMarker.
LLVM_ABI const BasicBlock * getParent() const
simple_ilist< DbgRecord > StoredDbgRecords
List of DbgRecords, the non-instruction equivalent of llvm.dbg.
Base class for non-instruction debug metadata records that have positions within IR.
DebugLoc getDebugLoc() const
LLVM_ABI void dump() const
DbgMarker * Marker
Marker that this DbgRecord is linked into.
Record of a variable value-assignment, aka a non instruction representation of the dbg....
LocationType getType() const
LLVM_ABI void print(raw_ostream &O, bool IsForDebug=false) const
MDNode * getRawExpression() const
MDNode * getRawAddressExpression() const
Metadata * getRawAssignID() const
MDNode * getRawVariable() const
Metadata * getRawLocation() const
Returns the metadata operand for the first location description.
Metadata * getRawAddress() const
MDNode * getAsMDNode() const
Return this as a bar MDNode.
DenseMapIterator< KeyT, ValueT, KeyInfoT, BucketT > iterator
Utility class for floating point operations which can have information about relaxed accuracy require...
void print(raw_ostream &OS, AssemblyAnnotationWriter *AAW=nullptr, bool ShouldPreserveUseListOrder=false, bool IsForDebug=false) const
Print the function to an output stream with an optional AssemblyAnnotationWriter.
const Function & getFunction() const
const Argument * const_arg_iterator
LLVM_ABI Value * getBasePtr() const
LLVM_ABI Value * getDerivedPtr() const
Generic tagged DWARF-like metadata node.
const Constant * getAliasee() const
const Constant * getResolver() const
StringRef getSection() const
Get the custom section of this global if it has one.
LLVM_ABI void getAllMetadata(SmallVectorImpl< std::pair< unsigned, MDNode * > > &MDs) const
Appends all metadata attached to this value to MDs, sorting by KindID.
const Comdat * getComdat() const
bool hasSection() const
Check if this global has a custom object file section.
SummaryKind
Sububclass discriminator (for dyn_cast<> et al.)
bool hasPartition() const
static LLVM_ABI GUID getGUIDAssumingExternalLinkage(StringRef GlobalName)
Return a 64-bit global unique ID constructed from the name of a global symbol.
LLVM_ABI const SanitizerMetadata & getSanitizerMetadata() const
bool hasExternalLinkage() const
VisibilityTypes getVisibility() const
bool isImplicitDSOLocal() const
LinkageTypes getLinkage() const
uint64_t GUID
Declare a type to represent a global unique identifier for a global value.
ThreadLocalMode getThreadLocalMode() const
DLLStorageClassTypes
Storage classes of global values for PE targets.
@ DLLExportStorageClass
Function to be accessible from DLL.
@ DLLImportStorageClass
Function to be imported from DLL.
bool hasSanitizerMetadata() const
LLVM_ABI StringRef getPartition() const
Module * getParent()
Get the module that this global value is contained inside of...
PointerType * getType() const
Global values are always pointers.
VisibilityTypes
An enumeration for the kinds of visibility of global values.
@ DefaultVisibility
The GV is visible.
@ HiddenVisibility
The GV is hidden.
@ ProtectedVisibility
The GV is protected.
LLVM_ABI bool isMaterializable() const
If this function's Module is being lazily streamed in functions from disk or some other source,...
UnnamedAddr getUnnamedAddr() const
LinkageTypes
An enumeration for the kinds of linkage for global values.
@ PrivateLinkage
Like Internal, but omit from symbol table.
@ CommonLinkage
Tentative definitions.
@ InternalLinkage
Rename collisions when linking (static functions).
@ LinkOnceAnyLinkage
Keep one copy of function when linking (inline)
@ WeakODRLinkage
Same, but only replaced by something equivalent.
@ ExternalLinkage
Externally visible function.
@ WeakAnyLinkage
Keep one copy of named function when linking (weak)
@ AppendingLinkage
Special purpose, only applies to global arrays.
@ AvailableExternallyLinkage
Available for inspection, not emission.
@ ExternalWeakLinkage
ExternalWeak linkage description.
@ LinkOnceODRLinkage
Same, but only replaced by something equivalent.
DLLStorageClassTypes getDLLStorageClass() const
Type * getValueType() const
const Constant * getInitializer() const
getInitializer - Return the initializer for this global variable.
bool isExternallyInitialized() const
bool hasInitializer() const
Definitions have initializers, declarations don't.
AttributeSet getAttributes() const
Return the attribute set for this global.
std::optional< CodeModel::Model > getCodeModel() const
Get the custom code model of this global if it has one.
MaybeAlign getAlign() const
Returns the alignment of the given variable.
bool isConstant() const
If the value is a global constant, its value is immutable throughout the runtime execution of the pro...
A helper class to return the specified delimiter string after the first invocation of operator String...
LLVM_ABI void printTree(raw_ostream &OS, const Module *M=nullptr) const
Print in tree shape.
LLVM_ABI void dumpTree() const
User-friendly dump in tree shape.
This class implements a map that also provides access to all stored values in a deterministic order.
Manage lifetime of a slot tracker for printing IR.
const Module * getModule() const
ModuleSlotTracker(SlotTracker &Machine, const Module *M, const Function *F=nullptr)
Wrap a preinitialized SlotTracker.
virtual ~ModuleSlotTracker()
Destructor to clean up storage.
std::vector< std::pair< unsigned, const MDNode * > > MachineMDNodeListType
int getLocalSlot(const Value *V)
Return the slot number of the specified local value.
void collectMDNodes(MachineMDNodeListType &L, unsigned LB, unsigned UB) const
SlotTracker * getMachine()
Lazily creates a slot tracker.
void setProcessHook(std::function< void(AbstractSlotTrackerStorage *, const Module *, bool)>)
void incorporateFunction(const Function &F)
Incorporate the given function.
Class to hold module path string table and global value map, and encapsulate methods for operating on...
static constexpr const char * getRegularLTOModuleName()
LLVM_ABI void dump() const
Dump to stderr (for debugging).
LLVM_ABI void print(raw_ostream &OS, bool IsForDebug=false) const
Print to an output stream.
A Module instance is used to store all the information related to an LLVM module.
iterator_range< alias_iterator > aliases()
iterator_range< global_iterator > globals()
void print(raw_ostream &OS, AssemblyAnnotationWriter *AAW, bool ShouldPreserveUseListOrder=false, bool IsForDebug=false) const
Print the module to an output stream with an optional AssemblyAnnotationWriter.
void dump() const
Dump the module to stderr (for debugging).
LLVM_ABI void dump() const
LLVM_ABI StringRef getName() const
LLVM_ABI void print(raw_ostream &ROS, bool IsForDebug=false) const
LLVM_ABI MDNode * getOperand(unsigned i) const
LLVM_ABI unsigned getNumOperands() const
Utility class for integer operators which may exhibit overflow - Add, Sub, Mul, and Shl.
unsigned getAddressSpace() const
Return the address space of the Pointer type.
An or instruction, which can be marked as "disjoint", indicating that the inputs don't have a 1 in th...
A udiv, sdiv, lshr, or ashr instruction, which can be marked as "exact", indicating that no bits are ...
This class provides computation of slot numbers for LLVM Assembly writing.
DenseMap< const Value *, unsigned > ValueMap
ValueMap - A mapping of Values to slot numbers.
int getMetadataSlot(const MDNode *N) override
getMetadataSlot - Get the slot number of a MDNode.
int getTypeIdCompatibleVtableSlot(StringRef Id)
int getModulePathSlot(StringRef Path)
unsigned mdn_size() const
SlotTracker(const SlotTracker &)=delete
void purgeFunction()
After calling incorporateFunction, use this method to remove the most recently incorporated function ...
int getTypeIdSlot(StringRef Id)
void initializeIfNeeded()
These functions do the actual initialization.
int getGlobalSlot(const GlobalValue *V)
getGlobalSlot - Get the slot number of a global value.
const Function * getFunction() const
unsigned getNextMetadataSlot() override
DenseMap< GlobalValue::GUID, unsigned >::iterator guid_iterator
GUID map iterators.
void incorporateFunction(const Function *F)
If you'd like to deal with a function instead of just a module, use this method to get its data into ...
int getLocalSlot(const Value *V)
Return the slot number of the specified value in it's type plane.
int getAttributeGroupSlot(AttributeSet AS)
SlotTracker(const Module *M, bool ShouldInitializeAllMetadata=false)
Construct from a module.
void createMetadataSlot(const MDNode *N) override
getMetadataSlot - Get the slot number of a MDNode.
void setProcessHook(std::function< void(AbstractSlotTrackerStorage *, const Module *, bool)>)
DenseMap< const MDNode *, unsigned >::iterator mdn_iterator
MDNode map iterators.
SlotTracker & operator=(const SlotTracker &)=delete
int getGUIDSlot(GlobalValue::GUID GUID)
int initializeIndexIfNeeded()
DenseMap< AttributeSet, unsigned >::iterator as_iterator
AttributeSet map iterators.
std::pair< iterator, bool > insert(PtrType Ptr)
Inserts Ptr if and only if there is no element in the container equal to Ptr.
SmallString - A SmallString is just a SmallVector with methods and accessors that make it work better...
reference emplace_back(ArgTypes &&... Args)
void push_back(const T &Elt)
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
StringMap - This is an unconventional map that is specialized for handling keys that are "strings",...
StringRef - Represent a constant reference to a string, i.e.
constexpr bool empty() const
empty - Check if the string is empty.
Class to represent struct types.
ArrayRef< Type * > elements() const
unsigned getNumElements() const
Random access to the elements.
bool isLiteral() const
Return true if this type is uniqued by structural equivalence, false if it is a struct definition.
bool isOpaque() const
Return true if this is a type with an identity that has no body specified yet.
LLVM_ABI StringRef getName() const
Return the name for this struct type if it has an identity.
ArrayRef< Type * > type_params() const
Return the type parameters for this particular target extension type.
ArrayRef< unsigned > int_params() const
Return the integer parameters for this particular target extension type.
TypeFinder - Walk over a module, identifying all of the types that are used by the module.
void run(const Module &M, bool onlyNamed)
The instances of the Type class are immutable: once they are created, they are never changed.
LLVM_ABI unsigned getPointerAddressSpace() const
Get the address space of this pointer or pointer vector type.
LLVM_ABI StringRef getTargetExtName() const
Type(LLVMContext &C, TypeID tid)
LLVM_ABI void dump() const
LLVM_ABI void print(raw_ostream &O, bool IsForDebug=false, bool NoDetails=false) const
Print the current type.
TypeID getTypeID() const
Return the type id for the type.
Type * getElementType() const
unsigned getAddressSpace() const
Return the address space of the Pointer type.
A Use represents the edge between a Value definition and its users.
const Use * const_op_iterator
LLVM Value Representation.
Type * getType() const
All values are typed, get the type of this value.
LLVM_ABI void print(raw_ostream &O, bool IsForDebug=false) const
Implement operator<< on Value.
LLVM_ABI void getAllMetadata(SmallVectorImpl< std::pair< unsigned, MDNode * > > &MDs) const
Appends all metadata attached to this value to MDs, sorting by KindID.
iterator_range< user_iterator > users()
LLVM_ABI void printAsOperand(raw_ostream &O, bool PrintType=true, const Module *M=nullptr) const
Print the name of this Value out to the specified raw_ostream.
iterator_range< use_iterator > uses()
LLVM_ABI StringRef getName() const
Return a constant reference to the value's name.
LLVM_ABI void dump() const
Support for debugging, callable in GDB: V->dump()
This class implements an extremely fast bulk output stream that can only output to a stream.
raw_ostream & indent(unsigned NumSpaces)
indent - Insert 'NumSpaces' spaces.
LLVM_ABI StringRef EnumKindString(unsigned EnumKind)
LLVM_ABI StringRef LanguageString(unsigned Language)
LLVM_ABI StringRef AttributeEncodingString(unsigned Encoding)
LLVM_ABI StringRef ConventionString(unsigned Convention)
LLVM_ABI StringRef MacinfoString(unsigned Encoding)
LLVM_ABI StringRef OperationEncodingString(unsigned Encoding)
LLVM_ABI StringRef TagString(unsigned Tag)
This provides a very simple, boring adaptor for a begin and end iterator into a range type.
This file contains the declaration of the Comdat class, which represents a single COMDAT in LLVM.
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
constexpr char Attrs[]
Key for Kernel::Metadata::mAttrs.
unsigned ID
LLVM IR allows to use arbitrary numbers as calling convention identifiers.
@ AArch64_VectorCall
Used between AArch64 Advanced SIMD functions.
@ X86_64_SysV
The C convention as specified in the x86-64 supplement to the System V ABI, used on most non-Windows ...
@ RISCV_VectorCall
Calling convention used for RISC-V V-extension.
@ AMDGPU_CS
Used for Mesa/AMDPAL compute shaders.
@ AMDGPU_VS
Used for Mesa vertex shaders, or AMDPAL last shader stage before rasterization (vertex shader if tess...
@ AVR_SIGNAL
Used for AVR signal routines.
@ Swift
Calling convention for Swift.
@ AMDGPU_KERNEL
Used for AMDGPU code object kernels.
@ AArch64_SVE_VectorCall
Used between AArch64 SVE functions.
@ ARM_APCS
ARM Procedure Calling Standard (obsolete, but still used on some targets).
@ 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).
@ 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.
@ CXX_FAST_TLS
Used for access functions.
@ X86_INTR
x86 hardware interrupt context.
@ AArch64_SME_ABI_Support_Routines_PreserveMost_From_X0
Preserve X0-X13, X19-X29, SP, Z0-Z31, P0-P15.
@ AMDGPU_CS_Chain
Used on AMDGPUs to give the middle-end more control over argument placement.
@ GHC
Used by the Glasgow Haskell Compiler (GHC).
@ AMDGPU_PS
Used for Mesa/AMDPAL pixel shaders.
@ Cold
Attempts to make code in the caller as efficient as possible under the assumption that the call is no...
@ AArch64_SME_ABI_Support_Routines_PreserveMost_From_X1
Preserve X1-X15, X19-X29, SP, Z0-Z31, P0-P15.
@ X86_ThisCall
Similar to X86_StdCall.
@ PTX_Device
Call to a PTX device function.
@ SPIR_KERNEL
Used for SPIR kernel functions.
@ PreserveAll
Used for runtime calls that preserves (almost) all registers.
@ X86_StdCall
stdcall is mostly used by the Win32 API.
@ SPIR_FUNC
Used for SPIR non-kernel device functions.
@ Fast
Attempts to make calls as fast as possible (e.g.
@ MSP430_INTR
Used for MSP430 interrupt routines.
@ X86_VectorCall
MSVC calling convention that passes vectors and vector aggregates in SSE registers.
@ Intel_OCL_BI
Used for Intel OpenCL built-ins.
@ PreserveNone
Used for runtime calls that preserves none general registers.
@ AMDGPU_ES
Used for AMDPAL shader stage before geometry shader if geometry is in use.
@ Tail
Attemps to make calls as fast as possible while guaranteeing that tail call optimization can always b...
@ Win64
The C convention as implemented on Windows/x86-64 and AArch64.
@ PTX_Kernel
Call to a PTX kernel. Passes all arguments in parameter space.
@ SwiftTail
This follows the Swift calling convention in how arguments are passed but guarantees tail calls will ...
@ GRAAL
Used by GraalVM. Two additional registers are reserved.
@ AMDGPU_LS
Used for AMDPAL vertex shader if tessellation is in use.
@ ARM_AAPCS_VFP
Same as ARM_AAPCS, but uses hard floating point ABI.
@ X86_RegCall
Register calling convention used for parameters transfer optimization.
@ M68k_RTD
Used for M68k rtd-based CC (similar to X86's stdcall).
@ C
The default llvm calling convention, compatible with C.
@ X86_FastCall
'fast' analog of X86_StdCall.
@ System
Synchronized with respect to all concurrently executing threads.
@ DW_OP_LLVM_convert
Only used in LLVM metadata.
Context & getContext() const
This is an optimization pass for GlobalISel generic memory operations.
void dump(const SparseBitVector< ElementSize > &LHS, raw_ostream &out)
FunctionAddr VTableAddr Value
bool all_of(R &&range, UnaryPredicate P)
Provide wrappers to std::all_of which take ranges instead of having to pass begin/end explicitly.
Printable print(const GCNRegPressure &RP, const GCNSubtarget *ST=nullptr, unsigned DynamicVGPRBlockSize=0)
auto pred_end(const MachineBasicBlock *BB)
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...
PredIterator< const BasicBlock, Value::const_user_iterator > const_pred_iterator
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
raw_ostream & operator<<(raw_ostream &OS, const APFixedPoint &FX)
std::string toString(const APInt &I, unsigned Radix, bool Signed, bool formatAsCLiteral=false, bool UpperCase=true, bool InsertSeparators=false)
auto pred_begin(const MachineBasicBlock *BB)
decltype(auto) cast(const From &Val)
cast<X> - Return the argument parameter cast to the specified type.
std::vector< TypeIdOffsetVtableInfo > TypeIdCompatibleVtableInfo
List of vtable definitions decorated by a particular type identifier, and their corresponding offsets...
@ Default
The result values are uniform if and only if all operands are uniform.
static auto filterDbgVars(iterator_range< simple_ilist< DbgRecord >::iterator > R)
Filter the DbgRecord range to DbgVariableRecord types only and downcast.
LLVM_ABI void printLLVMNameWithoutPrefix(raw_ostream &OS, StringRef Name)
Print out a name of an LLVM value without any prefixes.
static LLVM_ABI const fltSemantics & IEEEsingle() LLVM_READNONE
static constexpr roundingMode rmNearestTiesToEven
static LLVM_ABI const fltSemantics & PPCDoubleDouble() LLVM_READNONE
static LLVM_ABI const fltSemantics & x87DoubleExtended() LLVM_READNONE
static LLVM_ABI const fltSemantics & IEEEquad() LLVM_READNONE
static LLVM_ABI const fltSemantics & IEEEdouble() LLVM_READNONE
static LLVM_ABI const fltSemantics & IEEEhalf() LLVM_READNONE
static LLVM_ABI const fltSemantics & BFloat() LLVM_READNONE
A single checksum, represented by a Kind and a Value (a string).
T Value
The string value of the checksum.
StringRef getKindAsString() const
std::vector< ConstVCall > TypeCheckedLoadConstVCalls
std::vector< VFuncId > TypeCheckedLoadVCalls
std::vector< ConstVCall > TypeTestAssumeConstVCalls
List of virtual calls made by this function using (respectively) llvm.assume(llvm....
std::vector< GlobalValue::GUID > TypeTests
List of type identifiers used by this function in llvm.type.test intrinsics referenced by something o...
std::vector< VFuncId > TypeTestAssumeVCalls
List of virtual calls made by this function using (respectively) llvm.assume(llvm....
unsigned DSOLocal
Indicates that the linker resolved the symbol to a definition from within the same linkage unit.
unsigned CanAutoHide
In the per-module summary, indicates that the global value is linkonce_odr and global unnamed addr (s...
unsigned ImportType
This field is written by the ThinLTO indexing step to postlink combined summary.
unsigned NotEligibleToImport
Indicate if the global value cannot be imported (e.g.
unsigned Linkage
The linkage type of the associated global value.
unsigned Visibility
Indicates the visibility.
unsigned Live
In per-module summary, indicate that the global value must be considered a live root for index-based ...
StringRef getTagName() const
Return the tag of this operand bundle as a string.
A utility class that uses RAII to save and restore the value of a variable.
std::map< uint64_t, WholeProgramDevirtResolution > WPDRes
Mapping from byte offset to whole-program devirt resolution for that (typeid, byte offset) pair.
Kind
Specifies which kind of type check we should emit for this byte array.
@ Unknown
Unknown (analysis not performed, don't lower)
@ Single
Single element (last example in "Short Inline Bit Vectors")
@ Inline
Inlined bit vector ("Short Inline Bit Vectors")
@ Unsat
Unsatisfiable type (i.e. no global has this type metadata)
@ AllOnes
All-ones bit vector ("Eliminating Bit Vector Checks for All-Ones Bit Vectors")
@ ByteArray
Test a byte array (first example)
unsigned SizeM1BitWidth
Range of size-1 expressed as a bit width.
enum llvm::TypeTestResolution::Kind TheKind
@ UniformRetVal
Uniform return value optimization.
@ VirtualConstProp
Virtual constant propagation.
@ UniqueRetVal
Unique return value optimization.
@ Indir
Just do a regular virtual call.
enum llvm::WholeProgramDevirtResolution::Kind TheKind
std::map< std::vector< uint64_t >, ByArg > ResByArg
Resolutions for calls with all constant integer arguments (excluding the first argument,...
std::string SingleImplName
@ SingleImpl
Single implementation devirtualization.
@ Indir
Just do a regular virtual call.
@ BranchFunnel
When retpoline mitigation is enabled, use a branch funnel that is defined in the merged module.
Function object to check whether the second component of a container supported by std::get (like std:...