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);
1086 for (
const NamedMDNode &NMD : TheModule->named_metadata()) {
1087 for (
const MDNode *
N : NMD.operands())
1088 CreateMetadataSlot(
N);
1091 for (
const Function &
F : *TheModule) {
1094 CreateModuleSlot(&
F);
1096 if (ShouldInitializeAllMetadata)
1097 processFunctionMetadata(
F);
1101 AttributeSet FnAttrs =
F.getAttributes().getFnAttrs();
1103 CreateAttributeSetSlot(FnAttrs);
1106 if (ProcessModuleHookFn)
1107 ProcessModuleHookFn(
this, TheModule, ShouldInitializeAllMetadata);
1113void SlotTracker::processFunction() {
1114 ST_DEBUG(
"begin processFunction!\n");
1118 if (!ShouldInitializeAllMetadata)
1119 processFunctionMetadata(*TheFunction);
1123 AE = TheFunction->arg_end(); AI != AE; ++AI)
1125 CreateFunctionSlot(&*AI);
1127 ST_DEBUG(
"Inserting Instructions:\n");
1130 for (
auto &BB : *TheFunction) {
1132 CreateFunctionSlot(&BB);
1134 for (
auto &
I : BB) {
1135 if (!
I.getType()->isVoidTy() && !
I.hasName())
1136 CreateFunctionSlot(&
I);
1143 if (
Attrs.hasAttributes())
1144 CreateAttributeSetSlot(Attrs);
1149 if (ProcessFunctionHookFn)
1150 ProcessFunctionHookFn(
this, TheFunction, ShouldInitializeAllMetadata);
1152 FunctionProcessed =
true;
1154 ST_DEBUG(
"end processFunction!\n");
1158int SlotTracker::processIndex() {
1165 std::vector<StringRef> ModulePaths;
1166 for (
auto &[ModPath,
_] : TheIndex->modulePaths())
1167 ModulePaths.push_back(ModPath);
1169 for (
auto &ModPath : ModulePaths)
1170 CreateModulePathSlot(ModPath);
1173 GUIDNext = ModulePathNext;
1175 for (
auto &GlobalList : *TheIndex)
1176 CreateGUIDSlot(GlobalList.first);
1179 TypeIdCompatibleVtableNext = GUIDNext;
1180 for (
auto &TId : TheIndex->typeIdCompatibleVtableMap())
1181 CreateTypeIdCompatibleVtableSlot(TId.first);
1184 TypeIdNext = TypeIdCompatibleVtableNext;
1185 for (
const auto &TID : TheIndex->typeIds())
1186 CreateTypeIdSlot(TID.second.first);
1192void SlotTracker::processGlobalObjectMetadata(
const GlobalObject &GO) {
1195 for (
auto &MD : MDs)
1196 CreateMetadataSlot(MD.second);
1199void SlotTracker::processFunctionMetadata(
const Function &
F) {
1200 processGlobalObjectMetadata(
F);
1201 for (
auto &BB :
F) {
1202 for (
auto &
I : BB) {
1203 for (
const DbgRecord &DR :
I.getDbgRecordRange())
1204 processDbgRecordMetadata(DR);
1205 processInstructionMetadata(
I);
1210void SlotTracker::processDbgRecordMetadata(
const DbgRecord &DR) {
1221 CreateMetadataSlot(
Empty);
1222 if (DVR->getRawVariable())
1223 CreateMetadataSlot(DVR->getRawVariable());
1224 if (DVR->isDbgAssign()) {
1225 if (
auto *AssignID = DVR->getRawAssignID())
1228 CreateMetadataSlot(
Empty);
1231 CreateMetadataSlot(DLR->getRawLabel());
1239void SlotTracker::processInstructionMetadata(
const Instruction &
I) {
1242 if (Function *
F = CI->getCalledFunction())
1243 if (
F->isIntrinsic())
1244 for (
auto &
Op :
I.operands())
1247 CreateMetadataSlot(
N);
1251 I.getAllMetadata(MDs);
1252 for (
auto &MD : MDs)
1253 CreateMetadataSlot(MD.second);
1260 ST_DEBUG(
"begin purgeFunction!\n");
1262 TheFunction =
nullptr;
1263 FunctionProcessed =
false;
1274 return MI == mMap.end() ? -1 : (int)
MI->second;
1280 ProcessModuleHookFn = Fn;
1286 ProcessFunctionHookFn = Fn;
1299 return MI == mdnMap.end() ? -1 : (int)
MI->second;
1310 return FI == fMap.end() ? -1 : (int)FI->second;
1319 return AI == asMap.end() ? -1 : (int)AI->second;
1327 auto I = ModulePathMap.find(Path);
1328 return I == ModulePathMap.end() ? -1 : (int)
I->second;
1337 return I == GUIDMap.end() ? -1 : (int)
I->second;
1345 auto I = TypeIdMap.find(Id);
1346 return I == TypeIdMap.end() ? -1 : (int)
I->second;
1354 auto I = TypeIdCompatibleVtableMap.find(Id);
1355 return I == TypeIdCompatibleVtableMap.end() ? -1 : (int)
I->second;
1359void SlotTracker::CreateModuleSlot(
const GlobalValue *V) {
1360 assert(V &&
"Can't insert a null Value into SlotTracker!");
1361 assert(!V->getType()->isVoidTy() &&
"Doesn't need a slot!");
1362 assert(!V->hasName() &&
"Doesn't need a slot!");
1364 unsigned DestSlot = mNext++;
1367 ST_DEBUG(
" Inserting value [" << V->getType() <<
"] = " << V <<
" slot=" <<
1377void SlotTracker::CreateFunctionSlot(
const Value *V) {
1378 assert(!V->getType()->isVoidTy() && !V->hasName() &&
"Doesn't need a slot!");
1380 unsigned DestSlot = fNext++;
1384 ST_DEBUG(
" Inserting value [" << V->getType() <<
"] = " << V <<
" slot=" <<
1385 DestSlot <<
" [o]\n");
1389void SlotTracker::CreateMetadataSlot(
const MDNode *
N) {
1390 assert(
N &&
"Can't insert a null Value into SlotTracker!");
1396 unsigned DestSlot = mdnNext;
1397 if (!mdnMap.insert(std::make_pair(
N, DestSlot)).second)
1402 for (
unsigned i = 0, e =
N->getNumOperands(); i != e; ++i)
1404 CreateMetadataSlot(
Op);
1407void SlotTracker::CreateAttributeSetSlot(
AttributeSet AS) {
1410 if (asMap.try_emplace(AS, asNext).second)
1415void SlotTracker::CreateModulePathSlot(
StringRef Path) {
1416 ModulePathMap[
Path] = ModulePathNext++;
1421 GUIDMap[
GUID] = GUIDNext++;
1425void SlotTracker::CreateTypeIdSlot(
StringRef Id) {
1426 TypeIdMap[
Id] = TypeIdNext++;
1430void SlotTracker::CreateTypeIdCompatibleVtableSlot(
StringRef Id) {
1431 TypeIdCompatibleVtableMap[
Id] = TypeIdCompatibleVtableNext++;
1436struct AsmWriterContext {
1437 TypePrinting *TypePrinter =
nullptr;
1438 SlotTracker *
Machine =
nullptr;
1441 AsmWriterContext(TypePrinting *TP, SlotTracker *ST,
const Module *M =
nullptr)
1444 static AsmWriterContext &getEmpty() {
1445 static AsmWriterContext EmptyCtx(
nullptr,
nullptr);
1451 virtual void onWriteMetadataAsOperand(
const Metadata *) {}
1453 virtual ~AsmWriterContext() =
default;
1462 AsmWriterContext &WriterCtx);
1465 AsmWriterContext &WriterCtx,
1466 bool FromValue =
false);
1470 Out << FPO->getFastMathFlags();
1474 if (OBO->hasNoUnsignedWrap())
1476 if (OBO->hasNoSignedWrap())
1484 if (PDI->isDisjoint())
1487 if (
GEP->isInBounds())
1489 else if (
GEP->hasNoUnsignedSignedWrap())
1491 if (
GEP->hasNoUnsignedWrap())
1494 Out <<
" inrange(" <<
InRange->getLower() <<
", " <<
InRange->getUpper()
1498 if (NNI->hasNonNeg())
1501 if (TI->hasNoUnsignedWrap())
1503 if (TI->hasNoSignedWrap())
1506 if (ICmp->hasSameSign())
1522 bool isNaN = APF.
isNaN();
1524 if (!isInf && !isNaN) {
1533 ((StrVal[0] ==
'-' || StrVal[0] ==
'+') &&
isDigit(StrVal[1]))) &&
1534 "[-+]?[0-9] regex does not match!");
1546 static_assert(
sizeof(double) ==
sizeof(
uint64_t),
1547 "assuming that double is 64 bits!");
1605 AsmWriterContext &WriterCtx) {
1607 Type *Ty = CI->getType();
1609 if (Ty->isVectorTy()) {
1611 WriterCtx.TypePrinter->print(Ty->getScalarType(), Out);
1615 if (Ty->getScalarType()->isIntegerTy(1))
1616 Out << (CI->getZExtValue() ?
"true" :
"false");
1618 Out << CI->getValue();
1620 if (Ty->isVectorTy())
1627 Type *Ty = CFP->getType();
1629 if (Ty->isVectorTy()) {
1631 WriterCtx.TypePrinter->print(Ty->getScalarType(), Out);
1637 if (Ty->isVectorTy())
1644 Out <<
"zeroinitializer";
1649 Out <<
"blockaddress(";
1658 Out <<
"dso_local_equivalent ";
1673 unsigned NumOpsToWrite = 2;
1674 if (!CPA->getOperand(2)->isNullValue())
1676 if (!CPA->getOperand(3)->isNullValue())
1680 for (
unsigned i = 0, e = NumOpsToWrite; i != e; ++i) {
1682 WriterCtx.TypePrinter->print(CPA->getOperand(i)->getType(), Out);
1691 Type *ETy = CA->getType()->getElementType();
1693 WriterCtx.TypePrinter->print(ETy, Out);
1696 for (
unsigned i = 1, e = CA->getNumOperands(); i != e; ++i) {
1698 WriterCtx.TypePrinter->print(ETy, Out);
1709 if (CA->isString()) {
1716 Type *ETy = CA->getType()->getElementType();
1718 WriterCtx.TypePrinter->print(ETy, Out);
1721 for (
uint64_t i = 1, e = CA->getNumElements(); i != e; ++i) {
1723 WriterCtx.TypePrinter->print(ETy, Out);
1732 if (CS->getType()->isPacked())
1735 unsigned N = CS->getNumOperands();
1738 WriterCtx.TypePrinter->print(CS->getOperand(0)->getType(), Out);
1743 for (
unsigned i = 1; i <
N; i++) {
1745 WriterCtx.TypePrinter->print(CS->getOperand(i)->getType(), Out);
1754 if (CS->getType()->isPacked())
1761 Type *ETy = CVVTy->getElementType();
1771 WriterCtx.TypePrinter->print(ETy, Out);
1780 WriterCtx.TypePrinter->print(ETy, Out);
1783 for (
unsigned i = 1, e = CVVTy->getNumElements(); i != e; ++i) {
1785 WriterCtx.TypePrinter->print(ETy, Out);
1819 if (CE->getOpcode() == Instruction::ShuffleVector) {
1820 if (
auto *SplatVal = CE->getSplatValue()) {
1823 WriterCtx.TypePrinter->print(SplatVal->getType(), Out);
1832 Out << CE->getOpcodeName();
1837 WriterCtx.TypePrinter->print(
GEP->getSourceElementType(), Out);
1843 WriterCtx.TypePrinter->print((*OI)->getType(), Out);
1846 if (OI+1 != CE->op_end())
1852 WriterCtx.TypePrinter->print(CE->getType(), Out);
1855 if (CE->getOpcode() == Instruction::ShuffleVector)
1862 Out <<
"<placeholder or erroneous Constant>";
1866 AsmWriterContext &WriterCtx) {
1868 for (
unsigned mi = 0, me =
Node->getNumOperands(); mi != me; ++mi) {
1873 Value *V = MDV->getValue();
1874 WriterCtx.TypePrinter->print(V->getType(), Out);
1879 WriterCtx.onWriteMetadataAsOperand(MD);
1890struct FieldSeparator {
1894 FieldSeparator(
const char *Sep =
", ") : Sep(Sep) {}
1902 return OS <<
FS.Sep;
1905struct MDFieldPrinter {
1908 AsmWriterContext &WriterCtx;
1910 explicit MDFieldPrinter(raw_ostream &Out)
1911 : Out(Out), WriterCtx(AsmWriterContext::getEmpty()) {}
1912 MDFieldPrinter(raw_ostream &Out, AsmWriterContext &Ctx)
1913 : Out(Out), WriterCtx(Ctx) {}
1915 void printTag(
const DINode *
N);
1916 void printMacinfoType(
const DIMacroNode *
N);
1917 void printChecksum(
const DIFile::ChecksumInfo<StringRef> &
N);
1918 void printString(StringRef Name, StringRef
Value,
1919 bool ShouldSkipEmpty =
true);
1920 void printMetadata(StringRef Name,
const Metadata *MD,
1921 bool ShouldSkipNull =
true);
1922 void printMetadataOrInt(StringRef Name,
const Metadata *MD,
bool IsUnsigned,
1923 bool ShouldSkipZero =
true);
1924 template <
class IntTy>
1925 void printInt(StringRef Name, IntTy
Int,
bool ShouldSkipZero =
true);
1926 void printAPInt(StringRef Name,
const APInt &
Int,
bool IsUnsigned,
1927 bool ShouldSkipZero);
1928 void printBool(StringRef Name,
bool Value,
1929 std::optional<bool>
Default = std::nullopt);
1932 template <
class IntTy,
class Stringifier>
1933 void printDwarfEnum(StringRef Name, IntTy
Value, Stringifier
toString,
1934 bool ShouldSkipZero =
true);
1936 void printNameTableKind(StringRef Name,
1943void MDFieldPrinter::printTag(
const DINode *
N) {
1944 Out <<
FS <<
"tag: ";
1952void MDFieldPrinter::printMacinfoType(
const DIMacroNode *
N) {
1953 Out <<
FS <<
"type: ";
1958 Out <<
N->getMacinfoType();
1961void MDFieldPrinter::printChecksum(
1964 printString(
"checksum", Checksum.
Value,
false);
1968 bool ShouldSkipEmpty) {
1969 if (ShouldSkipEmpty &&
Value.empty())
1972 Out <<
FS <<
Name <<
": \"";
1978 AsmWriterContext &WriterCtx) {
1984 WriterCtx.onWriteMetadataAsOperand(MD);
1988 bool ShouldSkipNull) {
1989 if (ShouldSkipNull && !MD)
1992 Out <<
FS <<
Name <<
": ";
1997 bool IsUnsigned,
bool ShouldSkipZero) {
2004 printInt(Name, CV->getZExtValue(), ShouldSkipZero);
2006 printInt(Name, CV->getSExtValue(), ShouldSkipZero);
2008 printMetadata(Name, MD);
2011template <
class IntTy>
2012void MDFieldPrinter::printInt(
StringRef Name, IntTy
Int,
bool ShouldSkipZero) {
2013 if (ShouldSkipZero && !
Int)
2020 bool IsUnsigned,
bool ShouldSkipZero) {
2021 if (ShouldSkipZero &&
Int.isZero())
2024 Out <<
FS <<
Name <<
": ";
2025 Int.print(Out, !IsUnsigned);
2029 std::optional<bool>
Default) {
2032 Out <<
FS <<
Name <<
": " << (
Value ?
"true" :
"false");
2039 Out <<
FS <<
Name <<
": ";
2044 FieldSeparator FlagsFS(
" | ");
2045 for (
auto F : SplitFlags) {
2047 assert(!StringF.empty() &&
"Expected valid flag");
2048 Out << FlagsFS << StringF;
2050 if (Extra || SplitFlags.empty())
2051 Out << FlagsFS << Extra;
2054void MDFieldPrinter::printDISPFlags(
StringRef Name,
2058 Out <<
FS <<
Name <<
": ";
2068 FieldSeparator FlagsFS(
" | ");
2069 for (
auto F : SplitFlags) {
2071 assert(!StringF.empty() &&
"Expected valid flag");
2072 Out << FlagsFS << StringF;
2074 if (Extra || SplitFlags.empty())
2075 Out << FlagsFS << Extra;
2078void MDFieldPrinter::printEmissionKind(
StringRef Name,
2083void MDFieldPrinter::printNameTableKind(
StringRef Name,
2090void MDFieldPrinter::printFixedPointKind(
StringRef Name,
2095template <
class IntTy,
class Stringifier>
2097 Stringifier
toString,
bool ShouldSkipZero) {
2098 if (ShouldSkipZero && !
Value)
2101 Out <<
FS <<
Name <<
": ";
2110 AsmWriterContext &WriterCtx) {
2111 Out <<
"!GenericDINode(";
2112 MDFieldPrinter
Printer(Out, WriterCtx);
2114 Printer.printString(
"header",
N->getHeader());
2115 if (
N->getNumDwarfOperands()) {
2116 Out <<
Printer.FS <<
"operands: {";
2118 for (
auto &
I :
N->dwarf_operands()) {
2128 AsmWriterContext &WriterCtx) {
2129 Out <<
"!DILocation(";
2130 MDFieldPrinter
Printer(Out, WriterCtx);
2132 Printer.printInt(
"line",
DL->getLine(),
false);
2133 Printer.printInt(
"column",
DL->getColumn());
2134 Printer.printMetadata(
"scope",
DL->getRawScope(),
false);
2135 Printer.printMetadata(
"inlinedAt",
DL->getRawInlinedAt());
2136 Printer.printBool(
"isImplicitCode",
DL->isImplicitCode(),
2138 Printer.printInt(
"atomGroup",
DL->getAtomGroup());
2139 Printer.printInt<
unsigned>(
"atomRank",
DL->getAtomRank());
2144 AsmWriterContext &WriterCtx) {
2145 Out <<
"!DIAssignID()";
2146 MDFieldPrinter
Printer(Out, WriterCtx);
2150 AsmWriterContext &WriterCtx) {
2151 Out <<
"!DISubrange(";
2152 MDFieldPrinter
Printer(Out, WriterCtx);
2154 Printer.printMetadataOrInt(
"count",
N->getRawCountNode(),
2160 Printer.printMetadataOrInt(
"lowerBound",
N->getRawLowerBound(),
2163 Printer.printMetadataOrInt(
"upperBound",
N->getRawUpperBound(),
2166 Printer.printMetadataOrInt(
"stride",
N->getRawStride(),
2174 AsmWriterContext &WriterCtx) {
2175 Out <<
"!DIGenericSubrange(";
2176 MDFieldPrinter
Printer(Out, WriterCtx);
2178 auto GetConstant = [&](
Metadata *Bound) -> std::optional<int64_t> {
2181 return std::nullopt;
2182 if (BE->isConstant() &&
2184 *BE->isConstant()) {
2185 return static_cast<int64_t
>(BE->getElement(1));
2187 return std::nullopt;
2190 auto *
Count =
N->getRawCountNode();
2191 if (
auto ConstantCount = GetConstant(
Count))
2192 Printer.printInt(
"count", *ConstantCount,
2197 auto *LBound =
N->getRawLowerBound();
2198 if (
auto ConstantLBound = GetConstant(LBound))
2199 Printer.printInt(
"lowerBound", *ConstantLBound,
2202 Printer.printMetadata(
"lowerBound", LBound,
true);
2204 auto *UBound =
N->getRawUpperBound();
2205 if (
auto ConstantUBound = GetConstant(UBound))
2206 Printer.printInt(
"upperBound", *ConstantUBound,
2209 Printer.printMetadata(
"upperBound", UBound,
true);
2211 auto *Stride =
N->getRawStride();
2212 if (
auto ConstantStride = GetConstant(Stride))
2213 Printer.printInt(
"stride", *ConstantStride,
2216 Printer.printMetadata(
"stride", Stride,
true);
2222 AsmWriterContext &) {
2223 Out <<
"!DIEnumerator(";
2225 Printer.printString(
"name",
N->getName(),
false);
2226 Printer.printAPInt(
"value",
N->getValue(),
N->isUnsigned(),
2228 if (
N->isUnsigned())
2229 Printer.printBool(
"isUnsigned",
true);
2234 AsmWriterContext &WriterCtx) {
2235 Out <<
"!DIBasicType(";
2236 MDFieldPrinter
Printer(Out, WriterCtx);
2237 if (
N->getTag() != dwarf::DW_TAG_base_type)
2239 Printer.printString(
"name",
N->getName());
2240 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2241 Printer.printInt(
"align",
N->getAlignInBits());
2242 Printer.printDwarfEnum(
"encoding",
N->getEncoding(),
2244 Printer.printInt(
"num_extra_inhabitants",
N->getNumExtraInhabitants());
2245 Printer.printDIFlags(
"flags",
N->getFlags());
2250 AsmWriterContext &WriterCtx) {
2251 Out <<
"!DIFixedPointType(";
2252 MDFieldPrinter
Printer(Out, WriterCtx);
2253 if (
N->getTag() != dwarf::DW_TAG_base_type)
2255 Printer.printString(
"name",
N->getName());
2256 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2257 Printer.printInt(
"align",
N->getAlignInBits());
2258 Printer.printDwarfEnum(
"encoding",
N->getEncoding(),
2260 Printer.printDIFlags(
"flags",
N->getFlags());
2261 Printer.printFixedPointKind(
"kind",
N->getKind());
2262 if (
N->isRational()) {
2263 bool IsUnsigned = !
N->isSigned();
2264 Printer.printAPInt(
"numerator",
N->getNumerator(), IsUnsigned,
false);
2265 Printer.printAPInt(
"denominator",
N->getDenominator(), IsUnsigned,
false);
2267 Printer.printInt(
"factor",
N->getFactor());
2273 AsmWriterContext &WriterCtx) {
2274 Out <<
"!DIStringType(";
2275 MDFieldPrinter
Printer(Out, WriterCtx);
2276 if (
N->getTag() != dwarf::DW_TAG_string_type)
2278 Printer.printString(
"name",
N->getName());
2279 Printer.printMetadata(
"stringLength",
N->getRawStringLength());
2280 Printer.printMetadata(
"stringLengthExpression",
N->getRawStringLengthExp());
2281 Printer.printMetadata(
"stringLocationExpression",
2282 N->getRawStringLocationExp());
2283 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2284 Printer.printInt(
"align",
N->getAlignInBits());
2285 Printer.printDwarfEnum(
"encoding",
N->getEncoding(),
2291 AsmWriterContext &WriterCtx) {
2292 Out <<
"!DIDerivedType(";
2293 MDFieldPrinter
Printer(Out, WriterCtx);
2295 Printer.printString(
"name",
N->getName());
2296 Printer.printMetadata(
"scope",
N->getRawScope());
2297 Printer.printMetadata(
"file",
N->getRawFile());
2298 Printer.printInt(
"line",
N->getLine());
2299 Printer.printMetadata(
"baseType",
N->getRawBaseType(),
2301 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2302 Printer.printInt(
"align",
N->getAlignInBits());
2303 Printer.printMetadataOrInt(
"offset",
N->getRawOffsetInBits(),
true);
2304 Printer.printDIFlags(
"flags",
N->getFlags());
2305 Printer.printMetadata(
"extraData",
N->getRawExtraData());
2306 if (
const auto &DWARFAddressSpace =
N->getDWARFAddressSpace())
2307 Printer.printInt(
"dwarfAddressSpace", *DWARFAddressSpace,
2309 Printer.printMetadata(
"annotations",
N->getRawAnnotations());
2310 if (
auto PtrAuthData =
N->getPtrAuthData()) {
2311 Printer.printInt(
"ptrAuthKey", PtrAuthData->key());
2312 Printer.printBool(
"ptrAuthIsAddressDiscriminated",
2313 PtrAuthData->isAddressDiscriminated());
2314 Printer.printInt(
"ptrAuthExtraDiscriminator",
2315 PtrAuthData->extraDiscriminator());
2316 Printer.printBool(
"ptrAuthIsaPointer", PtrAuthData->isaPointer());
2317 Printer.printBool(
"ptrAuthAuthenticatesNullValues",
2318 PtrAuthData->authenticatesNullValues());
2324 AsmWriterContext &WriterCtx) {
2325 Out <<
"!DISubrangeType(";
2326 MDFieldPrinter
Printer(Out, WriterCtx);
2327 Printer.printString(
"name",
N->getName());
2328 Printer.printMetadata(
"scope",
N->getRawScope());
2329 Printer.printMetadata(
"file",
N->getRawFile());
2330 Printer.printInt(
"line",
N->getLine());
2331 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2332 Printer.printInt(
"align",
N->getAlignInBits());
2333 Printer.printDIFlags(
"flags",
N->getFlags());
2334 Printer.printMetadata(
"baseType",
N->getRawBaseType(),
2336 Printer.printMetadata(
"lowerBound",
N->getRawLowerBound());
2337 Printer.printMetadata(
"upperBound",
N->getRawUpperBound());
2338 Printer.printMetadata(
"stride",
N->getRawStride());
2339 Printer.printMetadata(
"bias",
N->getRawBias());
2344 AsmWriterContext &WriterCtx) {
2345 Out <<
"!DICompositeType(";
2346 MDFieldPrinter
Printer(Out, WriterCtx);
2348 Printer.printString(
"name",
N->getName());
2349 Printer.printMetadata(
"scope",
N->getRawScope());
2350 Printer.printMetadata(
"file",
N->getRawFile());
2351 Printer.printInt(
"line",
N->getLine());
2352 Printer.printMetadata(
"baseType",
N->getRawBaseType());
2353 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2354 Printer.printInt(
"align",
N->getAlignInBits());
2355 Printer.printMetadataOrInt(
"offset",
N->getRawOffsetInBits(),
true);
2356 Printer.printInt(
"num_extra_inhabitants",
N->getNumExtraInhabitants());
2357 Printer.printDIFlags(
"flags",
N->getFlags());
2358 Printer.printMetadata(
"elements",
N->getRawElements());
2359 Printer.printDwarfEnum(
"runtimeLang",
N->getRuntimeLang(),
2361 Printer.printMetadata(
"vtableHolder",
N->getRawVTableHolder());
2362 Printer.printMetadata(
"templateParams",
N->getRawTemplateParams());
2363 Printer.printString(
"identifier",
N->getIdentifier());
2364 Printer.printMetadata(
"discriminator",
N->getRawDiscriminator());
2365 Printer.printMetadata(
"dataLocation",
N->getRawDataLocation());
2366 Printer.printMetadata(
"associated",
N->getRawAssociated());
2367 Printer.printMetadata(
"allocated",
N->getRawAllocated());
2368 if (
auto *RankConst =
N->getRankConst())
2369 Printer.printInt(
"rank", RankConst->getSExtValue(),
2372 Printer.printMetadata(
"rank",
N->getRawRank(),
true);
2373 Printer.printMetadata(
"annotations",
N->getRawAnnotations());
2374 if (
auto *Specification =
N->getRawSpecification())
2375 Printer.printMetadata(
"specification", Specification);
2377 if (
auto EnumKind =
N->getEnumKind())
2381 Printer.printMetadata(
"bitStride",
N->getRawBitStride());
2386 AsmWriterContext &WriterCtx) {
2387 Out <<
"!DISubroutineType(";
2388 MDFieldPrinter
Printer(Out, WriterCtx);
2389 Printer.printDIFlags(
"flags",
N->getFlags());
2391 Printer.printMetadata(
"types",
N->getRawTypeArray(),
2399 Printer.printString(
"filename",
N->getFilename(),
2401 Printer.printString(
"directory",
N->getDirectory(),
2404 if (
N->getChecksum())
2405 Printer.printChecksum(*
N->getChecksum());
2407 Printer.printString(
"source", *
N->getSource(),
2413 AsmWriterContext &WriterCtx) {
2414 Out <<
"!DICompileUnit(";
2415 MDFieldPrinter
Printer(Out, WriterCtx);
2416 Printer.printDwarfEnum(
"language",
N->getSourceLanguage(),
2418 Printer.printMetadata(
"file",
N->getRawFile(),
false);
2419 Printer.printString(
"producer",
N->getProducer());
2420 Printer.printBool(
"isOptimized",
N->isOptimized());
2421 Printer.printString(
"flags",
N->getFlags());
2422 Printer.printInt(
"runtimeVersion",
N->getRuntimeVersion(),
2424 Printer.printString(
"splitDebugFilename",
N->getSplitDebugFilename());
2425 Printer.printEmissionKind(
"emissionKind",
N->getEmissionKind());
2426 Printer.printMetadata(
"enums",
N->getRawEnumTypes());
2427 Printer.printMetadata(
"retainedTypes",
N->getRawRetainedTypes());
2428 Printer.printMetadata(
"globals",
N->getRawGlobalVariables());
2429 Printer.printMetadata(
"imports",
N->getRawImportedEntities());
2430 Printer.printMetadata(
"macros",
N->getRawMacros());
2431 Printer.printInt(
"dwoId",
N->getDWOId());
2432 Printer.printBool(
"splitDebugInlining",
N->getSplitDebugInlining(),
true);
2433 Printer.printBool(
"debugInfoForProfiling",
N->getDebugInfoForProfiling(),
2435 Printer.printNameTableKind(
"nameTableKind",
N->getNameTableKind());
2436 Printer.printBool(
"rangesBaseAddress",
N->getRangesBaseAddress(),
false);
2437 Printer.printString(
"sysroot",
N->getSysRoot());
2438 Printer.printString(
"sdk",
N->getSDK());
2443 AsmWriterContext &WriterCtx) {
2444 Out <<
"!DISubprogram(";
2445 MDFieldPrinter
Printer(Out, WriterCtx);
2446 Printer.printString(
"name",
N->getName());
2447 Printer.printString(
"linkageName",
N->getLinkageName());
2448 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2449 Printer.printMetadata(
"file",
N->getRawFile());
2450 Printer.printInt(
"line",
N->getLine());
2451 Printer.printMetadata(
"type",
N->getRawType());
2452 Printer.printInt(
"scopeLine",
N->getScopeLine());
2453 Printer.printMetadata(
"containingType",
N->getRawContainingType());
2454 if (
N->getVirtuality() != dwarf::DW_VIRTUALITY_none ||
2455 N->getVirtualIndex() != 0)
2456 Printer.printInt(
"virtualIndex",
N->getVirtualIndex(),
false);
2457 Printer.printInt(
"thisAdjustment",
N->getThisAdjustment());
2458 Printer.printDIFlags(
"flags",
N->getFlags());
2459 Printer.printDISPFlags(
"spFlags",
N->getSPFlags());
2460 Printer.printMetadata(
"unit",
N->getRawUnit());
2461 Printer.printMetadata(
"templateParams",
N->getRawTemplateParams());
2462 Printer.printMetadata(
"declaration",
N->getRawDeclaration());
2463 Printer.printMetadata(
"retainedNodes",
N->getRawRetainedNodes());
2464 Printer.printMetadata(
"thrownTypes",
N->getRawThrownTypes());
2465 Printer.printMetadata(
"annotations",
N->getRawAnnotations());
2466 Printer.printString(
"targetFuncName",
N->getTargetFuncName());
2467 Printer.printBool(
"keyInstructions",
N->getKeyInstructionsEnabled(),
false);
2472 AsmWriterContext &WriterCtx) {
2473 Out <<
"!DILexicalBlock(";
2474 MDFieldPrinter
Printer(Out, WriterCtx);
2475 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2476 Printer.printMetadata(
"file",
N->getRawFile());
2477 Printer.printInt(
"line",
N->getLine());
2478 Printer.printInt(
"column",
N->getColumn());
2484 AsmWriterContext &WriterCtx) {
2485 Out <<
"!DILexicalBlockFile(";
2486 MDFieldPrinter
Printer(Out, WriterCtx);
2487 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2488 Printer.printMetadata(
"file",
N->getRawFile());
2489 Printer.printInt(
"discriminator",
N->getDiscriminator(),
2495 AsmWriterContext &WriterCtx) {
2496 Out <<
"!DINamespace(";
2497 MDFieldPrinter
Printer(Out, WriterCtx);
2498 Printer.printString(
"name",
N->getName());
2499 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2500 Printer.printBool(
"exportSymbols",
N->getExportSymbols(),
false);
2505 AsmWriterContext &WriterCtx) {
2506 Out <<
"!DICommonBlock(";
2507 MDFieldPrinter
Printer(Out, WriterCtx);
2508 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2509 Printer.printMetadata(
"declaration",
N->getRawDecl(),
false);
2510 Printer.printString(
"name",
N->getName());
2511 Printer.printMetadata(
"file",
N->getRawFile());
2512 Printer.printInt(
"line",
N->getLineNo());
2517 AsmWriterContext &WriterCtx) {
2519 MDFieldPrinter
Printer(Out, WriterCtx);
2521 Printer.printInt(
"line",
N->getLine());
2522 Printer.printString(
"name",
N->getName());
2523 Printer.printString(
"value",
N->getValue());
2528 AsmWriterContext &WriterCtx) {
2529 Out <<
"!DIMacroFile(";
2530 MDFieldPrinter
Printer(Out, WriterCtx);
2531 Printer.printInt(
"line",
N->getLine());
2532 Printer.printMetadata(
"file",
N->getRawFile(),
false);
2533 Printer.printMetadata(
"nodes",
N->getRawElements());
2538 AsmWriterContext &WriterCtx) {
2539 Out <<
"!DIModule(";
2540 MDFieldPrinter
Printer(Out, WriterCtx);
2541 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2542 Printer.printString(
"name",
N->getName());
2543 Printer.printString(
"configMacros",
N->getConfigurationMacros());
2544 Printer.printString(
"includePath",
N->getIncludePath());
2545 Printer.printString(
"apinotes",
N->getAPINotesFile());
2546 Printer.printMetadata(
"file",
N->getRawFile());
2547 Printer.printInt(
"line",
N->getLineNo());
2548 Printer.printBool(
"isDecl",
N->getIsDecl(),
false);
2554 AsmWriterContext &WriterCtx) {
2555 Out <<
"!DITemplateTypeParameter(";
2556 MDFieldPrinter
Printer(Out, WriterCtx);
2557 Printer.printString(
"name",
N->getName());
2558 Printer.printMetadata(
"type",
N->getRawType(),
false);
2559 Printer.printBool(
"defaulted",
N->isDefault(),
false);
2565 AsmWriterContext &WriterCtx) {
2566 Out <<
"!DITemplateValueParameter(";
2567 MDFieldPrinter
Printer(Out, WriterCtx);
2568 if (
N->getTag() != dwarf::DW_TAG_template_value_parameter)
2570 Printer.printString(
"name",
N->getName());
2571 Printer.printMetadata(
"type",
N->getRawType());
2572 Printer.printBool(
"defaulted",
N->isDefault(),
false);
2573 Printer.printMetadata(
"value",
N->getValue(),
false);
2578 AsmWriterContext &WriterCtx) {
2579 Out <<
"!DIGlobalVariable(";
2580 MDFieldPrinter
Printer(Out, WriterCtx);
2581 Printer.printString(
"name",
N->getName());
2582 Printer.printString(
"linkageName",
N->getLinkageName());
2583 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2584 Printer.printMetadata(
"file",
N->getRawFile());
2585 Printer.printInt(
"line",
N->getLine());
2586 Printer.printMetadata(
"type",
N->getRawType());
2587 Printer.printBool(
"isLocal",
N->isLocalToUnit());
2588 Printer.printBool(
"isDefinition",
N->isDefinition());
2589 Printer.printMetadata(
"declaration",
N->getRawStaticDataMemberDeclaration());
2590 Printer.printMetadata(
"templateParams",
N->getRawTemplateParams());
2591 Printer.printInt(
"align",
N->getAlignInBits());
2592 Printer.printMetadata(
"annotations",
N->getRawAnnotations());
2597 AsmWriterContext &WriterCtx) {
2598 Out <<
"!DILocalVariable(";
2599 MDFieldPrinter
Printer(Out, WriterCtx);
2600 Printer.printString(
"name",
N->getName());
2601 Printer.printInt(
"arg",
N->getArg());
2602 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2603 Printer.printMetadata(
"file",
N->getRawFile());
2604 Printer.printInt(
"line",
N->getLine());
2605 Printer.printMetadata(
"type",
N->getRawType());
2606 Printer.printDIFlags(
"flags",
N->getFlags());
2607 Printer.printInt(
"align",
N->getAlignInBits());
2608 Printer.printMetadata(
"annotations",
N->getRawAnnotations());
2613 AsmWriterContext &WriterCtx) {
2615 MDFieldPrinter
Printer(Out, WriterCtx);
2616 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2617 Printer.printString(
"name",
N->getName());
2618 Printer.printMetadata(
"file",
N->getRawFile());
2619 Printer.printInt(
"line",
N->getLine());
2620 Printer.printInt(
"column",
N->getColumn());
2621 Printer.printBool(
"isArtificial",
N->isArtificial(),
false);
2622 if (
N->getCoroSuspendIdx())
2623 Printer.printInt(
"coroSuspendIdx", *
N->getCoroSuspendIdx(),
2629 AsmWriterContext &WriterCtx) {
2630 Out <<
"!DIExpression(";
2635 assert(!OpStr.empty() &&
"Expected valid opcode");
2639 Out << FS <<
Op.getArg(0);
2642 for (
unsigned A = 0, AE =
Op.getNumArgs();
A != AE; ++
A)
2643 Out << FS <<
Op.getArg(
A);
2647 for (
const auto &
I :
N->getElements())
2654 AsmWriterContext &WriterCtx,
2655 bool FromValue =
false) {
2657 "Unexpected DIArgList metadata outside of value argument");
2658 Out <<
"!DIArgList(";
2660 MDFieldPrinter
Printer(Out, WriterCtx);
2670 AsmWriterContext &WriterCtx) {
2671 Out <<
"!DIGlobalVariableExpression(";
2672 MDFieldPrinter
Printer(Out, WriterCtx);
2673 Printer.printMetadata(
"var",
N->getVariable());
2674 Printer.printMetadata(
"expr",
N->getExpression());
2679 AsmWriterContext &WriterCtx) {
2680 Out <<
"!DIObjCProperty(";
2681 MDFieldPrinter
Printer(Out, WriterCtx);
2682 Printer.printString(
"name",
N->getName());
2683 Printer.printMetadata(
"file",
N->getRawFile());
2684 Printer.printInt(
"line",
N->getLine());
2685 Printer.printString(
"setter",
N->getSetterName());
2686 Printer.printString(
"getter",
N->getGetterName());
2687 Printer.printInt(
"attributes",
N->getAttributes());
2688 Printer.printMetadata(
"type",
N->getRawType());
2693 AsmWriterContext &WriterCtx) {
2694 Out <<
"!DIImportedEntity(";
2695 MDFieldPrinter
Printer(Out, WriterCtx);
2697 Printer.printString(
"name",
N->getName());
2698 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2699 Printer.printMetadata(
"entity",
N->getRawEntity());
2700 Printer.printMetadata(
"file",
N->getRawFile());
2701 Printer.printInt(
"line",
N->getLine());
2702 Printer.printMetadata(
"elements",
N->getRawElements());
2707 AsmWriterContext &Ctx) {
2708 if (
Node->isDistinct())
2710 else if (
Node->isTemporary())
2711 Out <<
"<temporary!> ";
2713 switch (
Node->getMetadataID()) {
2716#define HANDLE_MDNODE_LEAF(CLASS) \
2717 case Metadata::CLASS##Kind: \
2718 write##CLASS(Out, cast<CLASS>(Node), Ctx); \
2720#include "llvm/IR/Metadata.def"
2727 AsmWriterContext &WriterCtx) {
2735 assert(WriterCtx.TypePrinter &&
"Constants require TypePrinting!");
2742 if (IA->hasSideEffects())
2743 Out <<
"sideeffect ";
2744 if (IA->isAlignStack())
2745 Out <<
"alignstack ";
2748 Out <<
"inteldialect ";
2767 auto *
Machine = WriterCtx.Machine;
2771 Slot =
Machine->getGlobalSlot(GV);
2774 Slot =
Machine->getLocalSlot(V);
2781 Slot =
Machine->getLocalSlot(V);
2788 Slot =
Machine->getGlobalSlot(GV);
2791 Slot =
Machine->getLocalSlot(V);
2800 Out << Prefix << Slot;
2806 AsmWriterContext &WriterCtx,
2820 std::unique_ptr<SlotTracker> MachineStorage;
2822 if (!WriterCtx.Machine) {
2823 MachineStorage = std::make_unique<SlotTracker>(WriterCtx.Context);
2824 WriterCtx.Machine = MachineStorage.get();
2834 Out <<
"<" <<
N <<
">";
2848 assert(WriterCtx.TypePrinter &&
"TypePrinter required for metadata values");
2850 "Unexpected function-local metadata outside of value argument");
2852 WriterCtx.TypePrinter->print(V->getValue()->getType(), Out);
2859class AssemblyWriter {
2860 formatted_raw_ostream &Out;
2861 const Module *TheModule =
nullptr;
2862 const ModuleSummaryIndex *TheIndex =
nullptr;
2863 std::unique_ptr<SlotTracker> SlotTrackerStorage;
2865 TypePrinting TypePrinter;
2866 AssemblyAnnotationWriter *AnnotationWriter =
nullptr;
2867 SetVector<const Comdat *> Comdats;
2869 bool ShouldPreserveUseListOrder;
2874 DenseMap<const GlobalValueSummary *, GlobalValue::GUID> SummaryToGUIDMap;
2878 AssemblyWriter(formatted_raw_ostream &o, SlotTracker &Mac,
const Module *M,
2879 AssemblyAnnotationWriter *AAW,
bool IsForDebug,
2880 bool ShouldPreserveUseListOrder =
false);
2882 AssemblyWriter(formatted_raw_ostream &o, SlotTracker &Mac,
2883 const ModuleSummaryIndex *Index,
bool IsForDebug);
2886 return AsmWriterContext(&TypePrinter, &
Machine, TheModule);
2889 void printMDNodeBody(
const MDNode *MD);
2890 void printNamedMDNode(
const NamedMDNode *NMD);
2892 void printModule(
const Module *M);
2894 void writeOperand(
const Value *
Op,
bool PrintType);
2895 void writeParamOperand(
const Value *Operand, AttributeSet Attrs);
2896 void writeOperandBundles(
const CallBase *
Call);
2897 void writeSyncScope(
const LLVMContext &
Context,
2899 void writeAtomic(
const LLVMContext &
Context,
2902 void writeAtomicCmpXchg(
const LLVMContext &
Context,
2907 void writeAllMDNodes();
2908 void writeMDNode(
unsigned Slot,
const MDNode *Node);
2909 void writeAttribute(
const Attribute &Attr,
bool InAttrGroup =
false);
2910 void writeAttributeSet(
const AttributeSet &AttrSet,
bool InAttrGroup =
false);
2911 void writeAllAttributeGroups();
2913 void printTypeIdentities();
2914 void printGlobal(
const GlobalVariable *GV);
2915 void printAlias(
const GlobalAlias *GA);
2916 void printIFunc(
const GlobalIFunc *GI);
2917 void printComdat(
const Comdat *
C);
2918 void printFunction(
const Function *
F);
2919 void printArgument(
const Argument *FA, AttributeSet Attrs);
2920 void printBasicBlock(
const BasicBlock *BB);
2921 void printInstructionLine(
const Instruction &
I);
2922 void printInstruction(
const Instruction &
I);
2923 void printDbgMarker(
const DbgMarker &DPI);
2924 void printDbgVariableRecord(
const DbgVariableRecord &DVR);
2925 void printDbgLabelRecord(
const DbgLabelRecord &DLR);
2926 void printDbgRecord(
const DbgRecord &DR);
2927 void printDbgRecordLine(
const DbgRecord &DR);
2929 void printUseListOrder(
const Value *V,
const std::vector<unsigned> &Shuffle);
2930 void printUseLists(
const Function *
F);
2932 void printModuleSummaryIndex();
2933 void printSummaryInfo(
unsigned Slot,
const ValueInfo &VI);
2934 void printSummary(
const GlobalValueSummary &Summary);
2935 void printAliasSummary(
const AliasSummary *AS);
2936 void printGlobalVarSummary(
const GlobalVarSummary *GS);
2937 void printFunctionSummary(
const FunctionSummary *FS);
2938 void printTypeIdSummary(
const TypeIdSummary &TIS);
2940 void printTypeTestResolution(
const TypeTestResolution &TTRes);
2941 void printArgs(
const std::vector<uint64_t> &Args);
2942 void printWPDRes(
const WholeProgramDevirtResolution &WPDRes);
2943 void printTypeIdInfo(
const FunctionSummary::TypeIdInfo &TIDInfo);
2944 void printVFuncId(
const FunctionSummary::VFuncId VFId);
2946 printNonConstVCalls(
const std::vector<FunctionSummary::VFuncId> &VCallList,
2949 printConstVCalls(
const std::vector<FunctionSummary::ConstVCall> &VCallList,
2954 void printMetadataAttachments(
2955 const SmallVectorImpl<std::pair<unsigned, MDNode *>> &MDs,
2956 StringRef Separator);
2960 void printInfoComment(
const Value &V);
2964 void printGCRelocateComment(
const GCRelocateInst &Relocate);
2971 bool IsForDebug,
bool ShouldPreserveUseListOrder)
2972 : Out(
o), TheModule(
M),
Machine(Mac), TypePrinter(
M), AnnotationWriter(AAW),
2973 IsForDebug(IsForDebug),
2974 ShouldPreserveUseListOrder(ShouldPreserveUseListOrder) {
2977 for (
const GlobalObject &GO : TheModule->global_objects())
2984 : Out(
o), TheIndex(Index),
Machine(Mac), TypePrinter(nullptr),
2985 IsForDebug(IsForDebug), ShouldPreserveUseListOrder(
false) {}
2987void AssemblyWriter::writeOperand(
const Value *Operand,
bool PrintType) {
2989 Out <<
"<null operand!>";
2993 TypePrinter.print(Operand->
getType(), Out);
3000void AssemblyWriter::writeSyncScope(
const LLVMContext &
Context,
3008 Context.getSyncScopeNames(SSNs);
3010 Out <<
" syncscope(\"";
3018void AssemblyWriter::writeAtomic(
const LLVMContext &
Context,
3021 if (Ordering == AtomicOrdering::NotAtomic)
3024 writeSyncScope(
Context, SSID);
3028void AssemblyWriter::writeAtomicCmpXchg(
const LLVMContext &
Context,
3032 assert(SuccessOrdering != AtomicOrdering::NotAtomic &&
3033 FailureOrdering != AtomicOrdering::NotAtomic);
3035 writeSyncScope(
Context, SSID);
3040void AssemblyWriter::writeParamOperand(
const Value *Operand,
3041 AttributeSet Attrs) {
3043 Out <<
"<null operand!>";
3048 TypePrinter.print(Operand->
getType(), Out);
3050 if (
Attrs.hasAttributes()) {
3052 writeAttributeSet(Attrs);
3060void AssemblyWriter::writeOperandBundles(
const CallBase *
Call) {
3066 bool FirstBundle =
true;
3072 FirstBundle =
false;
3080 bool FirstInput =
true;
3082 for (
const auto &Input : BU.
Inputs) {
3087 if (Input ==
nullptr)
3088 Out <<
"<null operand bundle!>";
3090 TypePrinter.print(Input->getType(), Out);
3102void AssemblyWriter::printModule(
const Module *M) {
3105 if (ShouldPreserveUseListOrder)
3108 if (!
M->getModuleIdentifier().empty() &&
3111 M->getModuleIdentifier().find(
'\n') == std::string::npos)
3112 Out <<
"; ModuleID = '" <<
M->getModuleIdentifier() <<
"'\n";
3114 if (!
M->getSourceFileName().empty()) {
3115 Out <<
"source_filename = \"";
3120 const std::string &
DL =
M->getDataLayoutStr();
3122 Out <<
"target datalayout = \"" <<
DL <<
"\"\n";
3123 if (!
M->getTargetTriple().empty())
3124 Out <<
"target triple = \"" <<
M->getTargetTriple().str() <<
"\"\n";
3126 if (!
M->getModuleInlineAsm().empty()) {
3130 StringRef
Asm =
M->getModuleInlineAsm();
3133 std::tie(Front, Asm) =
Asm.split(
'\n');
3137 Out <<
"module asm \"";
3140 }
while (!
Asm.empty());
3143 printTypeIdentities();
3146 if (!Comdats.empty())
3148 for (
const Comdat *
C : Comdats) {
3150 if (
C != Comdats.back())
3155 if (!
M->global_empty()) Out <<
'\n';
3156 for (
const GlobalVariable &GV :
M->globals()) {
3157 printGlobal(&GV); Out <<
'\n';
3161 if (!
M->alias_empty()) Out <<
"\n";
3162 for (
const GlobalAlias &GA :
M->aliases())
3166 if (!
M->ifunc_empty()) Out <<
"\n";
3167 for (
const GlobalIFunc &GI :
M->ifuncs())
3171 for (
const Function &
F : *M) {
3177 printUseLists(
nullptr);
3182 writeAllAttributeGroups();
3186 if (!
M->named_metadata_empty()) Out <<
'\n';
3188 for (
const NamedMDNode &Node :
M->named_metadata())
3189 printNamedMDNode(&Node);
3198void AssemblyWriter::printModuleSummaryIndex() {
3200 int NumSlots =
Machine.initializeIndexIfNeeded();
3206 std::vector<std::pair<std::string, ModuleHash>> moduleVec;
3207 std::string RegularLTOModuleName =
3209 moduleVec.resize(TheIndex->modulePaths().size());
3210 for (
auto &[ModPath, ModHash] : TheIndex->modulePaths())
3211 moduleVec[
Machine.getModulePathSlot(ModPath)] = std::make_pair(
3214 ModPath.empty() ? RegularLTOModuleName : std::string(ModPath), ModHash);
3217 for (
auto &ModPair : moduleVec) {
3218 Out <<
"^" << i++ <<
" = module: (";
3221 Out <<
"\", hash: (";
3223 for (
auto Hash : ModPair.second)
3230 for (
auto &GlobalList : *TheIndex) {
3231 auto GUID = GlobalList.first;
3232 for (
auto &Summary : GlobalList.second.SummaryList)
3237 for (
auto &GlobalList : *TheIndex) {
3238 auto GUID = GlobalList.first;
3239 auto VI = TheIndex->getValueInfo(GlobalList);
3240 printSummaryInfo(
Machine.getGUIDSlot(GUID), VI);
3244 for (
const auto &TID : TheIndex->typeIds()) {
3245 Out <<
"^" <<
Machine.getTypeIdSlot(TID.second.first)
3246 <<
" = typeid: (name: \"" << TID.second.first <<
"\"";
3247 printTypeIdSummary(TID.second.second);
3248 Out <<
") ; guid = " << TID.first <<
"\n";
3252 for (
auto &TId : TheIndex->typeIdCompatibleVtableMap()) {
3254 Out <<
"^" <<
Machine.getTypeIdCompatibleVtableSlot(TId.first)
3255 <<
" = typeidCompatibleVTable: (name: \"" << TId.first <<
"\"";
3256 printTypeIdCompatibleVtableSummary(TId.second);
3257 Out <<
") ; guid = " <<
GUID <<
"\n";
3261 if (TheIndex->getFlags()) {
3262 Out <<
"^" << NumSlots <<
" = flags: " << TheIndex->getFlags() <<
"\n";
3266 Out <<
"^" << NumSlots <<
" = blockcount: " << TheIndex->getBlockCount()
3276 return "singleImpl";
3278 return "branchFunnel";
3289 return "uniformRetVal";
3291 return "uniqueRetVal";
3293 return "virtualConstProp";
3316void AssemblyWriter::printTypeTestResolution(
const TypeTestResolution &TTRes) {
3323 Out <<
", alignLog2: " << TTRes.
AlignLog2;
3325 Out <<
", sizeM1: " << TTRes.
SizeM1;
3328 Out <<
", bitMask: " << (unsigned)TTRes.
BitMask;
3335void AssemblyWriter::printTypeIdSummary(
const TypeIdSummary &TIS) {
3336 Out <<
", summary: (";
3337 printTypeTestResolution(TIS.
TTRes);
3338 if (!TIS.
WPDRes.empty()) {
3339 Out <<
", wpdResolutions: (";
3341 for (
auto &WPDRes : TIS.
WPDRes) {
3343 Out <<
"(offset: " << WPDRes.first <<
", ";
3344 printWPDRes(WPDRes.second);
3352void AssemblyWriter::printTypeIdCompatibleVtableSummary(
3354 Out <<
", summary: (";
3356 for (
auto &
P : TI) {
3358 Out <<
"(offset: " <<
P.AddressPointOffset <<
", ";
3359 Out <<
"^" <<
Machine.getGUIDSlot(
P.VTableVI.getGUID());
3365void AssemblyWriter::printArgs(
const std::vector<uint64_t> &Args) {
3368 for (
auto arg : Args) {
3375void AssemblyWriter::printWPDRes(
const WholeProgramDevirtResolution &WPDRes) {
3376 Out <<
"wpdRes: (kind: ";
3383 Out <<
", resByArg: (";
3385 for (
auto &ResByArg : WPDRes.
ResByArg) {
3387 printArgs(ResByArg.first);
3388 Out <<
", byArg: (kind: ";
3390 if (ResByArg.second.TheKind ==
3392 ResByArg.second.TheKind ==
3394 Out <<
", info: " << ResByArg.second.Info;
3398 if (ResByArg.second.Byte || ResByArg.second.Bit)
3399 Out <<
", byte: " << ResByArg.second.Byte
3400 <<
", bit: " << ResByArg.second.Bit;
3421void AssemblyWriter::printAliasSummary(
const AliasSummary *AS) {
3422 Out <<
", aliasee: ";
3432void AssemblyWriter::printGlobalVarSummary(
const GlobalVarSummary *GS) {
3433 auto VTableFuncs =
GS->vTableFuncs();
3434 Out <<
", varFlags: (readonly: " <<
GS->VarFlags.MaybeReadOnly <<
", "
3435 <<
"writeonly: " <<
GS->VarFlags.MaybeWriteOnly <<
", "
3436 <<
"constant: " <<
GS->VarFlags.Constant;
3437 if (!VTableFuncs.empty())
3439 <<
"vcall_visibility: " <<
GS->VarFlags.VCallVisibility;
3442 if (!VTableFuncs.empty()) {
3443 Out <<
", vTableFuncs: (";
3445 for (
auto &
P : VTableFuncs) {
3447 Out <<
"(virtFunc: ^" <<
Machine.getGUIDSlot(
P.FuncVI.getGUID())
3448 <<
", offset: " <<
P.VTableOffset;
3466 return "linkonce_odr";
3476 return "extern_weak";
3478 return "available_externally";
3507 return "definition";
3509 return "declaration";
3514void AssemblyWriter::printFunctionSummary(
const FunctionSummary *FS) {
3515 Out <<
", insts: " <<
FS->instCount();
3516 if (
FS->fflags().anyFlagSet())
3517 Out <<
", " <<
FS->fflags();
3519 if (!
FS->calls().empty()) {
3520 Out <<
", calls: (";
3522 for (
auto &
Call :
FS->calls()) {
3524 Out <<
"(callee: ^" <<
Machine.getGUIDSlot(
Call.first.getGUID());
3525 if (
Call.second.getHotness() != CalleeInfo::HotnessType::Unknown)
3527 else if (
Call.second.RelBlockFreq)
3528 Out <<
", relbf: " <<
Call.second.RelBlockFreq;
3531 if (
Call.second.HasTailCall)
3538 if (
const auto *TIdInfo =
FS->getTypeIdInfo())
3539 printTypeIdInfo(*TIdInfo);
3543 auto AllocTypeName = [](uint8_t
Type) ->
const char * {
3545 case (uint8_t)AllocationType::None:
3547 case (uint8_t)AllocationType::NotCold:
3549 case (uint8_t)AllocationType::Cold:
3551 case (uint8_t)AllocationType::Hot:
3557 if (!
FS->allocs().empty()) {
3558 Out <<
", allocs: (";
3560 for (
auto &AI :
FS->allocs()) {
3562 Out <<
"(versions: (";
3564 for (
auto V : AI.Versions) {
3566 Out << AllocTypeName(V);
3568 Out <<
"), memProf: (";
3569 FieldSeparator MIBFS;
3570 for (
auto &MIB : AI.MIBs) {
3572 Out <<
"(type: " << AllocTypeName((uint8_t)MIB.AllocType);
3573 Out <<
", stackIds: (";
3574 FieldSeparator SIDFS;
3575 for (
auto Id : MIB.StackIdIndices) {
3577 Out << TheIndex->getStackIdAtIndex(Id);
3586 if (!
FS->callsites().empty()) {
3587 Out <<
", callsites: (";
3588 FieldSeparator SNFS;
3589 for (
auto &CI :
FS->callsites()) {
3592 Out <<
"(callee: ^" <<
Machine.getGUIDSlot(CI.Callee.getGUID());
3594 Out <<
"(callee: null";
3595 Out <<
", clones: (";
3597 for (
auto V : CI.Clones) {
3601 Out <<
"), stackIds: (";
3602 FieldSeparator SIDFS;
3603 for (
auto Id : CI.StackIdIndices) {
3605 Out << TheIndex->getStackIdAtIndex(Id);
3612 auto PrintRange = [&](
const ConstantRange &
Range) {
3616 if (!
FS->paramAccesses().empty()) {
3617 Out <<
", params: (";
3619 for (
auto &PS :
FS->paramAccesses()) {
3621 Out <<
"(param: " << PS.ParamNo;
3622 Out <<
", offset: ";
3624 if (!PS.Calls.empty()) {
3625 Out <<
", calls: (";
3627 for (
auto &
Call : PS.Calls) {
3629 Out <<
"(callee: ^" <<
Machine.getGUIDSlot(
Call.Callee.getGUID());
3630 Out <<
", param: " <<
Call.ParamNo;
3631 Out <<
", offset: ";
3632 PrintRange(
Call.Offsets);
3643void AssemblyWriter::printTypeIdInfo(
3644 const FunctionSummary::TypeIdInfo &TIDInfo) {
3645 Out <<
", typeIdInfo: (";
3646 FieldSeparator TIDFS;
3649 Out <<
"typeTests: (";
3652 auto TidIter = TheIndex->typeIds().equal_range(GUID);
3653 if (TidIter.first == TidIter.second) {
3659 for (
const auto &[GUID, TypeIdPair] :
make_range(TidIter)) {
3661 auto Slot =
Machine.getTypeIdSlot(TypeIdPair.first);
3679 "typeTestAssumeConstVCalls");
3684 "typeCheckedLoadConstVCalls");
3689void AssemblyWriter::printVFuncId(
const FunctionSummary::VFuncId VFId) {
3690 auto TidIter = TheIndex->typeIds().equal_range(VFId.
GUID);
3691 if (TidIter.first == TidIter.second) {
3692 Out <<
"vFuncId: (";
3693 Out <<
"guid: " << VFId.
GUID;
3694 Out <<
", offset: " << VFId.
Offset;
3700 for (
const auto &[GUID, TypeIdPair] :
make_range(TidIter)) {
3702 Out <<
"vFuncId: (";
3703 auto Slot =
Machine.getTypeIdSlot(TypeIdPair.first);
3706 Out <<
", offset: " << VFId.
Offset;
3711void AssemblyWriter::printNonConstVCalls(
3712 const std::vector<FunctionSummary::VFuncId> &VCallList,
const char *
Tag) {
3713 Out <<
Tag <<
": (";
3715 for (
auto &VFuncId : VCallList) {
3717 printVFuncId(VFuncId);
3722void AssemblyWriter::printConstVCalls(
3723 const std::vector<FunctionSummary::ConstVCall> &VCallList,
3725 Out <<
Tag <<
": (";
3727 for (
auto &ConstVCall : VCallList) {
3730 printVFuncId(ConstVCall.VFunc);
3731 if (!ConstVCall.Args.empty()) {
3733 printArgs(ConstVCall.Args);
3740void AssemblyWriter::printSummary(
const GlobalValueSummary &Summary) {
3741 GlobalValueSummary::GVFlags GVFlags =
Summary.flags();
3744 Out <<
"(module: ^" <<
Machine.getModulePathSlot(
Summary.modulePath())
3747 Out <<
", visibility: "
3750 Out <<
", live: " << GVFlags.
Live;
3751 Out <<
", dsoLocal: " << GVFlags.
DSOLocal;
3753 Out <<
", importType: "
3764 auto RefList =
Summary.refs();
3765 if (!RefList.empty()) {
3768 for (
auto &
Ref : RefList) {
3770 if (
Ref.isReadOnly())
3772 else if (
Ref.isWriteOnly())
3773 Out <<
"writeonly ";
3774 Out <<
"^" <<
Machine.getGUIDSlot(
Ref.getGUID());
3782void AssemblyWriter::printSummaryInfo(
unsigned Slot,
const ValueInfo &VI) {
3783 Out <<
"^" <<
Slot <<
" = gv: (";
3784 if (
VI.hasName() && !
VI.name().empty())
3785 Out <<
"name: \"" <<
VI.name() <<
"\"";
3787 Out <<
"guid: " <<
VI.getGUID();
3788 if (!
VI.getSummaryList().empty()) {
3789 Out <<
", summaries: (";
3791 for (
auto &Summary :
VI.getSummaryList()) {
3793 printSummary(*Summary);
3798 if (
VI.hasName() && !
VI.name().empty())
3799 Out <<
" ; guid = " <<
VI.getGUID();
3806 Out <<
"<empty name> ";
3808 unsigned char FirstC =
static_cast<unsigned char>(Name[0]);
3809 if (isalpha(FirstC) || FirstC ==
'-' || FirstC ==
'$' || FirstC ==
'.' ||
3814 for (
unsigned i = 1, e = Name.size(); i != e; ++i) {
3815 unsigned char C = Name[i];
3816 if (isalnum(
C) ||
C ==
'-' ||
C ==
'$' ||
C ==
'.' ||
C ==
'_')
3824void AssemblyWriter::printNamedMDNode(
const NamedMDNode *NMD) {
3861 Out <<
"dso_local ";
3879 Out <<
"thread_local ";
3882 Out <<
"thread_local(localdynamic) ";
3885 Out <<
"thread_local(initialexec) ";
3888 Out <<
"thread_local(localexec) ";
3898 return "local_unnamed_addr";
3900 return "unnamed_addr";
3923void AssemblyWriter::printGlobal(
const GlobalVariable *GV) {
3925 Out <<
"; Materializable\n";
3946 Out << (GV->
isConstant() ?
"constant " :
"global ");
3955 Out <<
", section \"";
3960 Out <<
", partition \"";
3965 Out <<
", code_model \"";
3990 Out <<
", no_sanitize_address";
3992 Out <<
", no_sanitize_hwaddress";
3994 Out <<
", sanitize_memtag";
3996 Out <<
", sanitize_address_dyninit";
4001 Out <<
", align " <<
A->value();
4005 printMetadataAttachments(MDs,
", ");
4008 if (
Attrs.hasAttributes())
4009 Out <<
" #" <<
Machine.getAttributeGroupSlot(Attrs);
4011 printInfoComment(*GV);
4014void AssemblyWriter::printAlias(
const GlobalAlias *GA) {
4016 Out <<
"; Materializable\n";
4036 if (
const Constant *Aliasee = GA->
getAliasee()) {
4039 TypePrinter.print(GA->
getType(), Out);
4040 Out <<
" <<NULL ALIASEE>>";
4044 Out <<
", partition \"";
4049 printInfoComment(*GA);
4053void AssemblyWriter::printIFunc(
const GlobalIFunc *GI) {
4055 Out <<
"; Materializable\n";
4070 if (
const Constant *Resolver = GI->
getResolver()) {
4073 TypePrinter.print(GI->
getType(), Out);
4074 Out <<
" <<NULL RESOLVER>>";
4078 Out <<
", partition \"";
4083 printInfoComment(*GI);
4087void AssemblyWriter::printComdat(
const Comdat *
C) {
4091void AssemblyWriter::printTypeIdentities() {
4092 if (TypePrinter.empty())
4098 auto &NumberedTypes = TypePrinter.getNumberedTypes();
4099 for (
unsigned I = 0,
E = NumberedTypes.size();
I !=
E; ++
I) {
4100 Out <<
'%' <<
I <<
" = type ";
4104 TypePrinter.printStructBody(NumberedTypes[
I], Out);
4108 auto &NamedTypes = TypePrinter.getNamedTypes();
4109 for (StructType *NamedType : NamedTypes) {
4115 TypePrinter.printStructBody(NamedType, Out);
4121void AssemblyWriter::printFunction(
const Function *
F) {
4124 if (
F->isMaterializable())
4125 Out <<
"; Materializable\n";
4127 const AttributeList &
Attrs =
F->getAttributes();
4128 if (
Attrs.hasFnAttrs()) {
4129 AttributeSet AS =
Attrs.getFnAttrs();
4130 std::string AttrStr;
4133 if (!Attr.isStringAttribute()) {
4134 if (!AttrStr.empty()) AttrStr +=
' ';
4135 AttrStr += Attr.getAsString();
4139 if (!AttrStr.empty())
4140 Out <<
"; Function Attrs: " << AttrStr <<
'\n';
4144 Out <<
"; Unknown intrinsic\n";
4148 if (
F->isDeclaration()) {
4151 F->getAllMetadata(MDs);
4152 printMetadataAttachments(MDs,
" ");
4163 if (
F->getCallingConv() != CallingConv::C) {
4168 FunctionType *FT =
F->getFunctionType();
4169 if (
Attrs.hasRetAttrs())
4170 Out <<
Attrs.getAsString(AttributeList::ReturnIndex) <<
' ';
4171 TypePrinter.print(
F->getReturnType(), Out);
4178 if (
F->isDeclaration() && !IsForDebug) {
4180 for (
unsigned I = 0,
E = FT->getNumParams();
I !=
E; ++
I) {
4185 TypePrinter.print(FT->getParamType(
I), Out);
4187 AttributeSet ArgAttrs =
Attrs.getParamAttrs(
I);
4190 writeAttributeSet(ArgAttrs);
4195 for (
const Argument &Arg :
F->args()) {
4197 if (Arg.getArgNo() != 0)
4199 printArgument(&Arg,
Attrs.getParamAttrs(Arg.getArgNo()));
4204 if (FT->isVarArg()) {
4205 if (FT->getNumParams()) Out <<
", ";
4216 if (
F->getAddressSpace() != 0 || !
Mod ||
4217 Mod->getDataLayout().getProgramAddressSpace() != 0)
4218 Out <<
" addrspace(" <<
F->getAddressSpace() <<
")";
4219 if (
Attrs.hasFnAttrs())
4220 Out <<
" #" <<
Machine.getAttributeGroupSlot(
Attrs.getFnAttrs());
4221 if (
F->hasSection()) {
4222 Out <<
" section \"";
4226 if (
F->hasPartition()) {
4227 Out <<
" partition \"";
4232 if (MaybeAlign
A =
F->getAlign())
4233 Out <<
" align " <<
A->value();
4235 Out <<
" gc \"" <<
F->getGC() <<
'"';
4236 if (
F->hasPrefixData()) {
4238 writeOperand(
F->getPrefixData(),
true);
4240 if (
F->hasPrologueData()) {
4241 Out <<
" prologue ";
4242 writeOperand(
F->getPrologueData(),
true);
4244 if (
F->hasPersonalityFn()) {
4245 Out <<
" personality ";
4246 writeOperand(
F->getPersonalityFn(),
true);
4250 if (
auto *MDProf =
F->getMetadata(LLVMContext::MD_prof)) {
4252 MDProf->print(Out, TheModule,
true);
4256 if (
F->isDeclaration()) {
4260 F->getAllMetadata(MDs);
4261 printMetadataAttachments(MDs,
" ");
4265 for (
const BasicBlock &BB : *
F)
4266 printBasicBlock(&BB);
4279void AssemblyWriter::printArgument(
const Argument *Arg, AttributeSet Attrs) {
4281 TypePrinter.print(Arg->
getType(), Out);
4284 if (
Attrs.hasAttributes()) {
4286 writeAttributeSet(Attrs);
4295 assert(Slot != -1 &&
"expect argument in function here");
4296 Out <<
" %" <<
Slot;
4301void AssemblyWriter::printBasicBlock(
const BasicBlock *BB) {
4307 }
else if (!IsEntryBlock) {
4316 if (!IsEntryBlock) {
4323 Out <<
" No predecessors!";
4326 writeOperand(*PI,
false);
4327 for (++PI; PI != PE; ++PI) {
4329 writeOperand(*PI,
false);
4339 for (
const Instruction &
I : *BB) {
4340 for (
const DbgRecord &DR :
I.getDbgRecordRange())
4341 printDbgRecordLine(DR);
4342 printInstructionLine(
I);
4349void AssemblyWriter::printInstructionLine(
const Instruction &
I) {
4350 printInstruction(
I);
4356void AssemblyWriter::printGCRelocateComment(
const GCRelocateInst &Relocate) {
4366void AssemblyWriter::printInfoComment(
const Value &V) {
4368 printGCRelocateComment(*Relocate);
4370 if (AnnotationWriter) {
4376 if (
I->getDebugLoc()) {
4378 I->getDebugLoc().print(Out);
4384 if (
auto *MD =
I->getMetadata(LLVMContext::MD_prof)) {
4386 MD->print(Out, TheModule,
true);
4398 if (Operand ==
nullptr) {
4399 Out <<
" <cannot get addrspace!>";
4403 bool PrintAddrSpace = CallAddrSpace != 0;
4404 if (!PrintAddrSpace) {
4409 if (!
Mod ||
Mod->getDataLayout().getProgramAddressSpace() != 0)
4410 PrintAddrSpace =
true;
4413 Out <<
" addrspace(" << CallAddrSpace <<
")";
4417void AssemblyWriter::printInstruction(
const Instruction &
I) {
4427 }
else if (!
I.getType()->isVoidTy()) {
4429 int SlotNum =
Machine.getLocalSlot(&
I);
4431 Out <<
"<badref> = ";
4433 Out <<
'%' << SlotNum <<
" = ";
4437 if (CI->isMustTailCall())
4439 else if (CI->isTailCall())
4441 else if (CI->isNoTailCall())
4446 Out <<
I.getOpcodeName();
4468 Out <<
' ' << CI->getPredicate();
4475 const Value *Operand =
I.getNumOperands() ?
I.getOperand(0) :
nullptr;
4481 writeOperand(BI.getCondition(),
true);
4483 writeOperand(BI.getSuccessor(0),
true);
4485 writeOperand(BI.getSuccessor(1),
true);
4491 writeOperand(
SI.getCondition(),
true);
4493 writeOperand(
SI.getDefaultDest(),
true);
4495 for (
auto Case :
SI.cases()) {
4497 writeOperand(Case.getCaseValue(),
true);
4499 writeOperand(Case.getCaseSuccessor(),
true);
4505 writeOperand(Operand,
true);
4508 for (
unsigned i = 1, e =
I.getNumOperands(); i != e; ++i) {
4511 writeOperand(
I.getOperand(i),
true);
4516 TypePrinter.print(
I.getType(), Out);
4519 for (
unsigned op = 0, Eop = PN->getNumIncomingValues();
op < Eop; ++
op) {
4520 if (
op) Out <<
", ";
4522 writeOperand(PN->getIncomingValue(
op),
false); Out <<
", ";
4523 writeOperand(PN->getIncomingBlock(
op),
false); Out <<
" ]";
4527 writeOperand(
I.getOperand(0),
true);
4528 for (
unsigned i : EVI->indices())
4532 writeOperand(
I.getOperand(0),
true); Out <<
", ";
4533 writeOperand(
I.getOperand(1),
true);
4534 for (
unsigned i : IVI->indices())
4538 TypePrinter.print(
I.getType(), Out);
4539 if (LPI->isCleanup() || LPI->getNumClauses() != 0)
4542 if (LPI->isCleanup())
4545 for (
unsigned i = 0, e = LPI->getNumClauses(); i != e; ++i) {
4546 if (i != 0 || LPI->isCleanup()) Out <<
"\n";
4547 if (LPI->isCatch(i))
4552 writeOperand(LPI->getClause(i),
true);
4556 writeOperand(CatchSwitch->getParentPad(),
false);
4559 for (
const BasicBlock *PadBB : CatchSwitch->handlers()) {
4562 writeOperand(PadBB,
true);
4566 if (
const BasicBlock *UnwindDest = CatchSwitch->getUnwindDest())
4567 writeOperand(UnwindDest,
true);
4572 writeOperand(FPI->getParentPad(),
false);
4577 writeOperand(FPI->getArgOperand(
Op),
true);
4584 writeOperand(CRI->getOperand(0),
false);
4587 writeOperand(CRI->getOperand(1),
true);
4590 writeOperand(CRI->getOperand(0),
false);
4593 if (CRI->hasUnwindDest())
4594 writeOperand(CRI->getOperand(1),
true);
4599 if (CI->getCallingConv() != CallingConv::C) {
4604 Operand = CI->getCalledOperand();
4605 FunctionType *FTy = CI->getFunctionType();
4606 Type *RetTy = FTy->getReturnType();
4607 const AttributeList &PAL = CI->getAttributes();
4609 if (PAL.hasRetAttrs())
4610 Out <<
' ' << PAL.getAsString(AttributeList::ReturnIndex);
4619 TypePrinter.print(FTy->isVarArg() ? FTy : RetTy, Out);
4621 writeOperand(Operand,
false);
4623 for (
unsigned op = 0, Eop = CI->arg_size();
op < Eop; ++
op) {
4626 writeParamOperand(CI->getArgOperand(
op), PAL.getParamAttrs(
op));
4631 if (CI->isMustTailCall() && CI->getParent() &&
4632 CI->getParent()->getParent() &&
4633 CI->getParent()->getParent()->isVarArg()) {
4634 if (CI->arg_size() > 0)
4640 if (PAL.hasFnAttrs())
4641 Out <<
" #" <<
Machine.getAttributeGroupSlot(PAL.getFnAttrs());
4643 writeOperandBundles(CI);
4645 Operand =
II->getCalledOperand();
4646 FunctionType *FTy =
II->getFunctionType();
4647 Type *RetTy = FTy->getReturnType();
4648 const AttributeList &PAL =
II->getAttributes();
4651 if (
II->getCallingConv() != CallingConv::C) {
4656 if (PAL.hasRetAttrs())
4657 Out <<
' ' << PAL.getAsString(AttributeList::ReturnIndex);
4667 TypePrinter.print(FTy->isVarArg() ? FTy : RetTy, Out);
4669 writeOperand(Operand,
false);
4671 for (
unsigned op = 0, Eop =
II->arg_size();
op < Eop; ++
op) {
4674 writeParamOperand(
II->getArgOperand(
op), PAL.getParamAttrs(
op));
4678 if (PAL.hasFnAttrs())
4679 Out <<
" #" <<
Machine.getAttributeGroupSlot(PAL.getFnAttrs());
4681 writeOperandBundles(
II);
4684 writeOperand(
II->getNormalDest(),
true);
4686 writeOperand(
II->getUnwindDest(),
true);
4688 Operand = CBI->getCalledOperand();
4689 FunctionType *FTy = CBI->getFunctionType();
4690 Type *RetTy = FTy->getReturnType();
4691 const AttributeList &PAL = CBI->getAttributes();
4694 if (CBI->getCallingConv() != CallingConv::C) {
4699 if (PAL.hasRetAttrs())
4700 Out <<
' ' << PAL.getAsString(AttributeList::ReturnIndex);
4707 TypePrinter.print(FTy->isVarArg() ? FTy : RetTy, Out);
4709 writeOperand(Operand,
false);
4711 for (
unsigned op = 0, Eop = CBI->arg_size();
op < Eop; ++
op) {
4714 writeParamOperand(CBI->getArgOperand(
op), PAL.getParamAttrs(
op));
4718 if (PAL.hasFnAttrs())
4719 Out <<
" #" <<
Machine.getAttributeGroupSlot(PAL.getFnAttrs());
4721 writeOperandBundles(CBI);
4724 writeOperand(CBI->getDefaultDest(),
true);
4726 for (
unsigned i = 0, e = CBI->getNumIndirectDests(); i != e; ++i) {
4729 writeOperand(CBI->getIndirectDest(i),
true);
4734 if (AI->isUsedWithInAlloca())
4736 if (AI->isSwiftError())
4737 Out <<
"swifterror ";
4738 TypePrinter.print(AI->getAllocatedType(), Out);
4744 if (!AI->getArraySize() || AI->isArrayAllocation() ||
4745 !AI->getArraySize()->getType()->isIntegerTy(32)) {
4747 writeOperand(AI->getArraySize(),
true);
4749 if (MaybeAlign
A = AI->getAlign()) {
4750 Out <<
", align " <<
A->value();
4753 unsigned AddrSpace = AI->getAddressSpace();
4754 if (AddrSpace != 0) {
4755 Out <<
", addrspace(" << AddrSpace <<
')';
4760 writeOperand(Operand,
true);
4763 TypePrinter.print(
I.getType(), Out);
4767 writeOperand(Operand,
true);
4770 TypePrinter.print(
I.getType(), Out);
4771 }
else if (Operand) {
4774 TypePrinter.print(
GEP->getSourceElementType(), Out);
4778 TypePrinter.print(LI->getType(), Out);
4785 bool PrintAllTypes =
false;
4793 PrintAllTypes =
true;
4795 for (
unsigned i = 1,
E =
I.getNumOperands(); i !=
E; ++i) {
4796 Operand =
I.getOperand(i);
4799 if (Operand && Operand->
getType() != TheType) {
4800 PrintAllTypes =
true;
4806 if (!PrintAllTypes) {
4808 TypePrinter.print(TheType, Out);
4812 for (
unsigned i = 0,
E =
I.getNumOperands(); i !=
E; ++i) {
4814 writeOperand(
I.getOperand(i), PrintAllTypes);
4821 writeAtomic(LI->getContext(), LI->getOrdering(), LI->getSyncScopeID());
4822 if (MaybeAlign
A = LI->getAlign())
4823 Out <<
", align " <<
A->value();
4826 writeAtomic(
SI->getContext(),
SI->getOrdering(),
SI->getSyncScopeID());
4827 if (MaybeAlign
A =
SI->getAlign())
4828 Out <<
", align " <<
A->value();
4830 writeAtomicCmpXchg(CXI->getContext(), CXI->getSuccessOrdering(),
4831 CXI->getFailureOrdering(), CXI->getSyncScopeID());
4832 Out <<
", align " << CXI->getAlign().value();
4834 writeAtomic(RMWI->getContext(), RMWI->getOrdering(),
4835 RMWI->getSyncScopeID());
4836 Out <<
", align " << RMWI->getAlign().value();
4838 writeAtomic(FI->getContext(), FI->getOrdering(), FI->getSyncScopeID());
4846 printMetadataAttachments(InstMD,
", ");
4849 printInfoComment(
I);
4852void AssemblyWriter::printDbgMarker(
const DbgMarker &Marker) {
4856 printDbgRecord(DPR);
4860 Out <<
" DbgMarker -> { ";
4865void AssemblyWriter::printDbgRecord(
const DbgRecord &DR) {
4867 printDbgVariableRecord(*DVR);
4869 printDbgLabelRecord(*DLR);
4874void AssemblyWriter::printDbgVariableRecord(
const DbgVariableRecord &DVR) {
4878 case DbgVariableRecord::LocationType::Value:
4881 case DbgVariableRecord::LocationType::Declare:
4884 case DbgVariableRecord::LocationType::Assign:
4889 "Tried to print a DbgVariableRecord with an invalid LocationType!");
4920void AssemblyWriter::printDbgRecordLine(
const DbgRecord &DR) {
4927void AssemblyWriter::printDbgLabelRecord(
const DbgLabelRecord &Label) {
4929 Out <<
"#dbg_label(";
4936void AssemblyWriter::printMetadataAttachments(
4937 const SmallVectorImpl<std::pair<unsigned, MDNode *>> &MDs,
4938 StringRef Separator) {
4942 if (MDNames.empty())
4943 MDs[0].second->getContext().getMDKindNames(MDNames);
4946 for (
const auto &
I : MDs) {
4947 unsigned Kind =
I.first;
4949 if (Kind < MDNames.size()) {
4953 Out <<
"!<unknown kind #" <<
Kind <<
">";
4959void AssemblyWriter::writeMDNode(
unsigned Slot,
const MDNode *Node) {
4960 Out <<
'!' <<
Slot <<
" = ";
4961 printMDNodeBody(Node);
4965void AssemblyWriter::writeAllMDNodes() {
4971 for (
unsigned i = 0, e = Nodes.
size(); i != e; ++i) {
4972 writeMDNode(i, Nodes[i]);
4976void AssemblyWriter::printMDNodeBody(
const MDNode *Node) {
4981void AssemblyWriter::writeAttribute(
const Attribute &Attr,
bool InAttrGroup) {
4987 Out << Attribute::getNameFromAttrKind(Attr.
getKindAsEnum());
4990 TypePrinter.print(Ty, Out);
4995void AssemblyWriter::writeAttributeSet(
const AttributeSet &AttrSet,
4997 bool FirstAttr =
true;
4998 for (
const auto &Attr : AttrSet) {
5001 writeAttribute(Attr, InAttrGroup);
5006void AssemblyWriter::writeAllAttributeGroups() {
5007 std::vector<std::pair<AttributeSet, unsigned>> asVec;
5008 asVec.resize(
Machine.as_size());
5011 asVec[
I.second] =
I;
5013 for (
const auto &
I : asVec)
5014 Out <<
"attributes #" <<
I.second <<
" = { "
5015 <<
I.first.getAsString(
true) <<
" }\n";
5018void AssemblyWriter::printUseListOrder(
const Value *V,
5019 const std::vector<unsigned> &Shuffle) {
5024 Out <<
"uselistorder";
5027 writeOperand(BB->getParent(),
false);
5029 writeOperand(BB,
false);
5032 writeOperand(V,
true);
5035 assert(Shuffle.size() >= 2 &&
"Shuffle too small");
5039void AssemblyWriter::printUseLists(
const Function *
F) {
5040 auto It = UseListOrders.find(
F);
5041 if (It == UseListOrders.end())
5044 Out <<
"\n; uselistorder directives\n";
5045 for (
const auto &Pair : It->second)
5046 printUseListOrder(Pair.first, Pair.second);
5054 bool ShouldPreserveUseListOrder,
5055 bool IsForDebug)
const {
5058 AssemblyWriter W(OS, SlotTable, this->
getParent(), AAW,
5060 ShouldPreserveUseListOrder);
5061 W.printFunction(
this);
5065 bool ShouldPreserveUseListOrder,
5066 bool IsForDebug)
const {
5069 AssemblyWriter W(OS, SlotTable, this->
getModule(), AAW,
5071 ShouldPreserveUseListOrder);
5072 W.printBasicBlock(
this);
5076 bool ShouldPreserveUseListOrder,
bool IsForDebug)
const {
5079 AssemblyWriter W(OS, SlotTable,
this, AAW, IsForDebug,
5080 ShouldPreserveUseListOrder);
5081 W.printModule(
this);
5087 AssemblyWriter W(OS, SlotTable,
getParent(),
nullptr, IsForDebug);
5088 W.printNamedMDNode(
this);
5092 bool IsForDebug)
const {
5093 std::optional<SlotTracker> LocalST;
5099 SlotTable = &*LocalST;
5103 AssemblyWriter W(OS, *SlotTable,
getParent(),
nullptr, IsForDebug);
5104 W.printNamedMDNode(
this);
5109 ROS <<
" = comdat ";
5116 ROS <<
"exactmatch";
5122 ROS <<
"nodeduplicate";
5134 TP.print(
const_cast<Type*
>(
this), OS);
5143 TP.printStructBody(STy, OS);
5149 if (
Function *
F = CI->getCalledFunction())
5150 if (
F->isIntrinsic())
5151 for (
auto &
Op :
I.operands())
5161 print(ROS, MST, IsForDebug);
5167 print(ROS, MST, IsForDebug);
5171 bool IsForDebug)
const {
5176 auto incorporateFunction = [&](
const Function *
F) {
5181 AssemblyWriter W(OS, SlotTable,
getModuleFromDPI(
this),
nullptr, IsForDebug);
5182 W.printDbgMarker(*
this);
5188 print(ROS, MST, IsForDebug);
5192 bool IsForDebug)
const {
5197 auto incorporateFunction = [&](
const Function *
F) {
5202 ?
Marker->getParent()->getParent()
5204 AssemblyWriter W(OS, SlotTable,
getModuleFromDPI(
this),
nullptr, IsForDebug);
5205 W.printDbgVariableRecord(*
this);
5209 bool IsForDebug)
const {
5214 auto incorporateFunction = [&](
const Function *
F) {
5218 incorporateFunction(
Marker->getParent() ?
Marker->getParent()->getParent()
5220 AssemblyWriter W(OS, SlotTable,
getModuleFromDPI(
this),
nullptr, IsForDebug);
5221 W.printDbgLabelRecord(*
this);
5225 bool ShouldInitializeAllMetadata =
false;
5229 ShouldInitializeAllMetadata =
true;
5232 print(ROS, MST, IsForDebug);
5236 bool IsForDebug)
const {
5241 auto incorporateFunction = [&](
const Function *
F) {
5247 incorporateFunction(
I->getParent() ?
I->getParent()->getParent() :
nullptr);
5249 W.printInstruction(*
I);
5251 incorporateFunction(BB->getParent());
5252 AssemblyWriter W(OS, SlotTable,
getModuleFromVal(BB),
nullptr, IsForDebug);
5253 W.printBasicBlock(BB);
5255 AssemblyWriter W(OS, SlotTable, GV->
getParent(),
nullptr, IsForDebug);
5269 TypePrinting TypePrinter;
5270 TypePrinter.print(
C->getType(), OS);
5272 AsmWriterContext WriterCtx(&TypePrinter, MST.
getMachine());
5288 AsmWriterContext WriterCtx(
nullptr,
Machine, M);
5297 TypePrinting TypePrinter(MST.
getModule());
5299 TypePrinter.print(V.getType(), O);
5333 AsmWriterContext &WriterCtx) {
5346struct MDTreeAsmWriterContext :
public AsmWriterContext {
5349 using EntryTy = std::pair<unsigned, std::string>;
5353 SmallPtrSet<const Metadata *, 4> Visited;
5355 raw_ostream &MainOS;
5357 MDTreeAsmWriterContext(TypePrinting *TP, SlotTracker *ST,
const Module *M,
5358 raw_ostream &OS,
const Metadata *InitMD)
5359 : AsmWriterContext(TP,
ST,
M),
Level(0
U), Visited({InitMD}), MainOS(OS) {}
5361 void onWriteMetadataAsOperand(
const Metadata *MD)
override {
5362 if (!Visited.
insert(MD).second)
5366 raw_string_ostream
SS(Str);
5371 unsigned InsertIdx = Buffer.
size() - 1;
5374 Buffer[InsertIdx].second = std::move(
SS.str());
5378 ~MDTreeAsmWriterContext() {
5379 for (
const auto &Entry : Buffer) {
5381 unsigned NumIndent =
Entry.first * 2U;
5390 bool OnlyAsOperand,
bool PrintAsTree =
false) {
5393 TypePrinting TypePrinter(M);
5395 std::unique_ptr<AsmWriterContext> WriterCtx;
5396 if (PrintAsTree && !OnlyAsOperand)
5397 WriterCtx = std::make_unique<MDTreeAsmWriterContext>(
5401 std::make_unique<AsmWriterContext>(&TypePrinter, MST.
getMachine(), M);
5430 const Module *M,
bool )
const {
5449 AssemblyWriter W(OS, SlotTable,
this, IsForDebug);
5450 W.printModuleSummaryIndex();
5454 unsigned UB)
const {
5460 if (
I.second >= LB &&
I.second < UB)
5461 L.push_back(std::make_pair(
I.second,
I.first));
5464#if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP)
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
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:...