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"));
107 cl::desc(
"Preserve use-list order when writing LLVM assembly."));
126 return VAM->getValue();
139 for (
const Value *
Op :
C->operands())
146 unsigned ID = OM.size() + 1;
153 auto OrderConstantValue = [&OM](
const Value *V) {
158 auto OrderConstantFromMetadata = [&](
Metadata *MD) {
160 OrderConstantValue(VAM->getValue());
162 for (
const auto *VAM : AL->getArgs())
163 OrderConstantValue(VAM->getValue());
168 if (
G.hasInitializer())
184 for (
const Use &U :
F.operands())
190 if (
F.isDeclaration())
203 OrderConstantFromMetadata(DVR.getRawLocation());
204 if (DVR.isDbgAssign())
205 OrderConstantFromMetadata(DVR.getRawAddress());
208 for (
const Value *
Op :
I.operands()) {
221static std::vector<unsigned>
224 using Entry = std::pair<const Use *, unsigned>;
228 if (OM.lookup(U.getUser()))
229 List.
push_back(std::make_pair(&U, List.size()));
240 ID = OM.lookup(BA->getBasicBlock());
241 llvm::sort(List, [&](
const Entry &L,
const Entry &R) {
242 const Use *LU = L.first;
243 const Use *RU = R.first;
247 auto LID = OM.lookup(LU->getUser());
248 auto RID = OM.lookup(RU->getUser());
268 return LU->getOperandNo() < RU->getOperandNo();
269 return LU->getOperandNo() > RU->getOperandNo();
277 std::vector<unsigned> Shuffle(List.size());
278 for (
size_t I = 0,
E = List.size();
I !=
E; ++
I)
279 Shuffle[
I] = List[
I].second;
286 for (
const auto &Pair : OM) {
287 const Value *V = Pair.first;
288 if (V->use_empty() || std::next(V->use_begin()) == V->use_end())
291 std::vector<unsigned> Shuffle =
298 F =
I->getFunction();
303 ULOM[
F][V] = std::move(Shuffle);
310 return MA->getParent() ? MA->getParent()->getParent() :
nullptr;
313 return BB->getParent() ? BB->getParent()->getParent() :
nullptr;
316 const Function *M =
I->getParent() ?
I->getParent()->getParent() :
nullptr;
317 return M ? M->getParent() :
nullptr;
321 return GV->getParent();
346 default: Out <<
"cc" << cc;
break;
369 Out <<
"aarch64_sve_vector_pcs";
372 Out <<
"aarch64_sme_preservemost_from_x0";
375 Out <<
"aarch64_sme_preservemost_from_x1";
378 Out <<
"aarch64_sme_preservemost_from_x2";
406 Out <<
"amdgpu_cs_chain";
409 Out <<
"amdgpu_cs_chain_preserve";
414 Out <<
"amdgpu_gfx_whole_wave";
418 Out <<
"riscv_vector_cc";
420#define CC_VLS_CASE(ABI_VLEN) \
421 case CallingConv::RISCV_VLSCall_##ABI_VLEN: \
422 Out << "riscv_vls_cc(" #ABI_VLEN ")"; \
438 Out <<
"cheriot_compartmentcallcc";
441 Out <<
"cheriot_compartmentcalleecc";
444 Out <<
"cheriot_librarycallcc";
458 assert(!Name.empty() &&
"Cannot get empty name!");
461 bool NeedsQuotes = isdigit(
static_cast<unsigned char>(Name[0]));
463 for (
unsigned char C : Name) {
468 if (!isalnum(
C) &&
C !=
'-' &&
C !=
'.' &&
C !=
'_') {
522 Out << Mask.size() <<
" x i32> ";
523 if (
all_of(Mask, [](
int Elt) {
return Elt == 0; })) {
524 Out <<
"zeroinitializer";
530 for (
int Elt : Mask) {
545 TypePrinting(
const Module *M =
nullptr) : DeferredM(
M) {}
547 TypePrinting(
const TypePrinting &) =
delete;
548 TypePrinting &operator=(
const TypePrinting &) =
delete;
551 TypeFinder &getNamedTypes();
554 std::vector<StructType *> &getNumberedTypes();
560 void printStructBody(StructType *Ty, raw_ostream &OS);
563 void incorporateTypes();
568 TypeFinder NamedTypes;
571 DenseMap<StructType *, unsigned> Type2Number;
573 std::vector<StructType *> NumberedTypes;
583std::vector<StructType *> &TypePrinting::getNumberedTypes() {
589 if (NumberedTypes.size() == Type2Number.size())
590 return NumberedTypes;
592 NumberedTypes.resize(Type2Number.size());
593 for (
const auto &
P : Type2Number) {
594 assert(
P.second < NumberedTypes.size() &&
"Didn't get a dense numbering?");
595 assert(!NumberedTypes[
P.second] &&
"Didn't get a unique numbering?");
596 NumberedTypes[
P.second] =
P.first;
598 return NumberedTypes;
601bool TypePrinting::empty() {
603 return NamedTypes.
empty() && Type2Number.empty();
606void TypePrinting::incorporateTypes() {
610 NamedTypes.
run(*DeferredM,
false);
615 unsigned NextNumber = 0;
617 std::vector<StructType *>::iterator NextToUse = NamedTypes.
begin();
618 for (StructType *STy : NamedTypes) {
620 if (STy->isLiteral())
623 if (STy->getName().empty())
624 Type2Number[STy] = NextNumber++;
629 NamedTypes.erase(NextToUse, NamedTypes.end());
634void TypePrinting::print(
Type *Ty, raw_ostream &OS) {
636 case Type::VoidTyID: OS <<
"void";
return;
637 case Type::HalfTyID: OS <<
"half";
return;
638 case Type::BFloatTyID: OS <<
"bfloat";
return;
639 case Type::FloatTyID: OS <<
"float";
return;
640 case Type::DoubleTyID: OS <<
"double";
return;
641 case Type::X86_FP80TyID: OS <<
"x86_fp80";
return;
642 case Type::FP128TyID: OS <<
"fp128";
return;
643 case Type::PPC_FP128TyID: OS <<
"ppc_fp128";
return;
644 case Type::LabelTyID: OS <<
"label";
return;
645 case Type::MetadataTyID:
648 case Type::X86_AMXTyID: OS <<
"x86_amx";
return;
649 case Type::TokenTyID: OS <<
"token";
return;
650 case Type::IntegerTyID:
651 OS << 'i' << cast<IntegerType>(Ty)->getBitWidth();
654 case Type::FunctionTyID: {
656 print(FTy->getReturnType(), OS);
659 for (
Type *Ty : FTy->params()) {
668 case Type::StructTyID: {
672 return printStructBody(STy, OS);
678 const auto I = Type2Number.find(STy);
679 if (
I != Type2Number.end())
680 OS <<
'%' <<
I->second;
682 OS <<
"%\"type " << STy <<
'\"';
685 case Type::PointerTyID: {
692 case Type::ArrayTyID: {
694 OS <<
'[' << ATy->getNumElements() <<
" x ";
695 print(ATy->getElementType(), OS);
699 case Type::FixedVectorTyID:
700 case Type::ScalableVectorTyID: {
702 ElementCount
EC = PTy->getElementCount();
706 OS <<
EC.getKnownMinValue() <<
" x ";
707 print(PTy->getElementType(), OS);
711 case Type::TypedPointerTyID: {
717 case Type::TargetExtTyID:
724 Inner->print(OS,
false,
true);
727 OS <<
", " << IntParam;
734void TypePrinting::printStructBody(StructType *STy, raw_ostream &OS) {
776 const Function* TheFunction =
nullptr;
777 bool FunctionProcessed =
false;
778 bool ShouldInitializeAllMetadata;
783 ProcessFunctionHookFn;
798 unsigned mdnNext = 0;
806 unsigned ModulePathNext = 0;
810 unsigned GUIDNext = 0;
814 unsigned TypeIdNext = 0;
819 unsigned TypeIdCompatibleVtableNext = 0;
828 bool ShouldInitializeAllMetadata =
false);
836 bool ShouldInitializeAllMetadata =
false);
853 void createMetadataSlot(
const MDNode *
N)
override;
857 int getLocalSlot(
const Value *V);
859 int getMetadataSlot(
const MDNode *
N)
override;
864 int getTypeIdCompatibleVtableSlot(
StringRef Id);
870 FunctionProcessed =
false;
878 void purgeFunction();
885 unsigned mdn_size()
const {
return mdnMap.size(); }
893 unsigned as_size()
const {
return asMap.size(); }
909 void CreateMetadataSlot(
const MDNode *
N);
912 void CreateFunctionSlot(
const Value *V);
917 inline void CreateModulePathSlot(
StringRef Path);
920 void CreateTypeIdCompatibleVtableSlot(
StringRef Id);
924 void processModule();
932 void processGlobalObjectMetadata(
const GlobalObject &GO);
935 void processFunctionMetadata(
const Function &
F);
941 void processDbgRecordMetadata(
const DbgRecord &DVR);
946 : M(M), F(F), Machine(&Machine) {}
949 bool ShouldInitializeAllMetadata)
950 : ShouldCreateStorage(M),
951 ShouldInitializeAllMetadata(ShouldInitializeAllMetadata), M(M) {}
956 if (!ShouldCreateStorage)
959 ShouldCreateStorage =
false;
961 std::make_unique<SlotTracker>(M, ShouldInitializeAllMetadata);
962 Machine = MachineStorage.get();
963 if (ProcessModuleHookFn)
964 Machine->setProcessHook(ProcessModuleHookFn);
965 if (ProcessFunctionHookFn)
966 Machine->setProcessHook(ProcessFunctionHookFn);
979 Machine->purgeFunction();
980 Machine->incorporateFunction(&F);
985 assert(F &&
"No function incorporated");
986 return Machine->getLocalSlot(V);
992 ProcessModuleHookFn = Fn;
998 ProcessFunctionHookFn = Fn;
1028#define ST_DEBUG(X) dbgs() << X
1036 : TheModule(M), ShouldInitializeAllMetadata(ShouldInitializeAllMetadata) {}
1041 : TheModule(
F ?
F->
getParent() : nullptr), TheFunction(
F),
1042 ShouldInitializeAllMetadata(ShouldInitializeAllMetadata) {}
1045 : TheModule(nullptr), ShouldInitializeAllMetadata(
false), TheIndex(Index) {}
1050 TheModule =
nullptr;
1053 if (TheFunction && !FunctionProcessed)
1060 int NumSlots = processIndex();
1067void SlotTracker::processModule() {
1068 ST_DEBUG(
"begin processModule!\n");
1073 CreateModuleSlot(&Var);
1074 processGlobalObjectMetadata(Var);
1075 auto Attrs = Var.getAttributes();
1076 if (Attrs.hasAttributes())
1077 CreateAttributeSetSlot(Attrs);
1082 CreateModuleSlot(&
A);
1085 for (
const GlobalIFunc &
I : TheModule->ifuncs()) {
1087 CreateModuleSlot(&
I);
1088 processGlobalObjectMetadata(
I);
1092 for (
const NamedMDNode &NMD : TheModule->named_metadata()) {
1093 for (
const MDNode *
N : NMD.operands())
1094 CreateMetadataSlot(
N);
1097 for (
const Function &
F : *TheModule) {
1100 CreateModuleSlot(&
F);
1102 if (ShouldInitializeAllMetadata)
1103 processFunctionMetadata(
F);
1107 AttributeSet FnAttrs =
F.getAttributes().getFnAttrs();
1109 CreateAttributeSetSlot(FnAttrs);
1112 if (ProcessModuleHookFn)
1113 ProcessModuleHookFn(
this, TheModule, ShouldInitializeAllMetadata);
1119void SlotTracker::processFunction() {
1120 ST_DEBUG(
"begin processFunction!\n");
1124 if (!ShouldInitializeAllMetadata)
1125 processFunctionMetadata(*TheFunction);
1129 AE = TheFunction->arg_end(); AI != AE; ++AI)
1131 CreateFunctionSlot(&*AI);
1133 ST_DEBUG(
"Inserting Instructions:\n");
1136 for (
auto &BB : *TheFunction) {
1138 CreateFunctionSlot(&BB);
1140 for (
auto &
I : BB) {
1141 if (!
I.getType()->isVoidTy() && !
I.hasName())
1142 CreateFunctionSlot(&
I);
1149 if (
Attrs.hasAttributes())
1150 CreateAttributeSetSlot(Attrs);
1155 if (ProcessFunctionHookFn)
1156 ProcessFunctionHookFn(
this, TheFunction, ShouldInitializeAllMetadata);
1158 FunctionProcessed =
true;
1160 ST_DEBUG(
"end processFunction!\n");
1164int SlotTracker::processIndex() {
1171 std::vector<StringRef> ModulePaths;
1172 for (
auto &[ModPath,
_] : TheIndex->modulePaths())
1173 ModulePaths.push_back(ModPath);
1175 for (
auto &ModPath : ModulePaths)
1176 CreateModulePathSlot(ModPath);
1179 GUIDNext = ModulePathNext;
1181 for (
auto &GlobalList : *TheIndex)
1182 CreateGUIDSlot(GlobalList.first);
1185 TypeIdCompatibleVtableNext = GUIDNext;
1186 for (
auto &TId : TheIndex->typeIdCompatibleVtableMap())
1187 CreateTypeIdCompatibleVtableSlot(TId.first);
1190 TypeIdNext = TypeIdCompatibleVtableNext;
1191 for (
const auto &TID : TheIndex->typeIds())
1192 CreateTypeIdSlot(TID.second.first);
1198void SlotTracker::processGlobalObjectMetadata(
const GlobalObject &GO) {
1201 for (
auto &MD : MDs)
1202 CreateMetadataSlot(MD.second);
1205void SlotTracker::processFunctionMetadata(
const Function &
F) {
1206 processGlobalObjectMetadata(
F);
1207 for (
auto &BB :
F) {
1208 for (
auto &
I : BB) {
1209 for (
const DbgRecord &DR :
I.getDbgRecordRange())
1210 processDbgRecordMetadata(DR);
1211 processInstructionMetadata(
I);
1216void SlotTracker::processDbgRecordMetadata(
const DbgRecord &DR) {
1227 CreateMetadataSlot(
Empty);
1228 if (DVR->getRawVariable())
1229 CreateMetadataSlot(DVR->getRawVariable());
1230 if (DVR->isDbgAssign()) {
1231 if (
auto *AssignID = DVR->getRawAssignID())
1234 CreateMetadataSlot(
Empty);
1237 CreateMetadataSlot(DLR->getRawLabel());
1245void SlotTracker::processInstructionMetadata(
const Instruction &
I) {
1248 if (Function *
F = CI->getCalledFunction())
1249 if (
F->isIntrinsic())
1250 for (
auto &
Op :
I.operands())
1253 CreateMetadataSlot(
N);
1257 I.getAllMetadata(MDs);
1258 for (
auto &MD : MDs)
1259 CreateMetadataSlot(MD.second);
1266 ST_DEBUG(
"begin purgeFunction!\n");
1268 TheFunction =
nullptr;
1269 FunctionProcessed =
false;
1280 return MI == mMap.end() ? -1 : (int)
MI->second;
1286 ProcessModuleHookFn = Fn;
1292 ProcessFunctionHookFn = Fn;
1305 return MI == mdnMap.end() ? -1 : (int)
MI->second;
1316 return FI == fMap.end() ? -1 : (int)FI->second;
1325 return AI == asMap.end() ? -1 : (int)AI->second;
1333 auto I = ModulePathMap.find(Path);
1334 return I == ModulePathMap.end() ? -1 : (int)
I->second;
1343 return I == GUIDMap.end() ? -1 : (int)
I->second;
1351 auto I = TypeIdMap.find(Id);
1352 return I == TypeIdMap.end() ? -1 : (int)
I->second;
1360 auto I = TypeIdCompatibleVtableMap.find(Id);
1361 return I == TypeIdCompatibleVtableMap.end() ? -1 : (int)
I->second;
1365void SlotTracker::CreateModuleSlot(
const GlobalValue *V) {
1366 assert(V &&
"Can't insert a null Value into SlotTracker!");
1367 assert(!V->getType()->isVoidTy() &&
"Doesn't need a slot!");
1368 assert(!V->hasName() &&
"Doesn't need a slot!");
1370 unsigned DestSlot = mNext++;
1373 ST_DEBUG(
" Inserting value [" << V->getType() <<
"] = " << V <<
" slot=" <<
1383void SlotTracker::CreateFunctionSlot(
const Value *V) {
1384 assert(!V->getType()->isVoidTy() && !V->hasName() &&
"Doesn't need a slot!");
1386 unsigned DestSlot = fNext++;
1390 ST_DEBUG(
" Inserting value [" << V->getType() <<
"] = " << V <<
" slot=" <<
1391 DestSlot <<
" [o]\n");
1395void SlotTracker::CreateMetadataSlot(
const MDNode *
N) {
1396 assert(
N &&
"Can't insert a null Value into SlotTracker!");
1402 unsigned DestSlot = mdnNext;
1403 if (!mdnMap.insert(std::make_pair(
N, DestSlot)).second)
1408 for (
unsigned i = 0, e =
N->getNumOperands(); i != e; ++i)
1410 CreateMetadataSlot(
Op);
1413void SlotTracker::CreateAttributeSetSlot(
AttributeSet AS) {
1416 if (asMap.try_emplace(AS, asNext).second)
1421void SlotTracker::CreateModulePathSlot(
StringRef Path) {
1422 ModulePathMap[
Path] = ModulePathNext++;
1427 GUIDMap[
GUID] = GUIDNext++;
1431void SlotTracker::CreateTypeIdSlot(
StringRef Id) {
1432 TypeIdMap[
Id] = TypeIdNext++;
1436void SlotTracker::CreateTypeIdCompatibleVtableSlot(
StringRef Id) {
1437 TypeIdCompatibleVtableMap[
Id] = TypeIdCompatibleVtableNext++;
1442struct AsmWriterContext {
1443 TypePrinting *TypePrinter =
nullptr;
1444 SlotTracker *
Machine =
nullptr;
1447 AsmWriterContext(TypePrinting *TP, SlotTracker *ST,
const Module *M =
nullptr)
1450 static AsmWriterContext &getEmpty() {
1451 static AsmWriterContext EmptyCtx(
nullptr,
nullptr);
1457 virtual void onWriteMetadataAsOperand(
const Metadata *) {}
1459 virtual ~AsmWriterContext() =
default;
1468 AsmWriterContext &WriterCtx,
1469 bool PrintType =
false);
1472 AsmWriterContext &WriterCtx,
1473 bool FromValue =
false);
1477 Out << FPO->getFastMathFlags();
1480 if (OBO->hasNoUnsignedWrap())
1482 if (OBO->hasNoSignedWrap())
1488 if (PDI->isDisjoint())
1491 if (
GEP->isInBounds())
1493 else if (
GEP->hasNoUnsignedSignedWrap())
1495 if (
GEP->hasNoUnsignedWrap())
1498 Out <<
" inrange(" <<
InRange->getLower() <<
", " <<
InRange->getUpper()
1502 if (NNI->hasNonNeg())
1505 if (TI->hasNoUnsignedWrap())
1507 if (TI->hasNoSignedWrap())
1510 if (ICmp->hasSameSign())
1526 bool isNaN = APF.
isNaN();
1528 if (!isInf && !isNaN) {
1537 ((StrVal[0] ==
'-' || StrVal[0] ==
'+') &&
isDigit(StrVal[1]))) &&
1538 "[-+]?[0-9] regex does not match!");
1550 static_assert(
sizeof(double) ==
sizeof(
uint64_t),
1551 "assuming that double is 64 bits!");
1609 AsmWriterContext &WriterCtx) {
1611 Type *Ty = CI->getType();
1613 if (Ty->isVectorTy()) {
1615 WriterCtx.TypePrinter->print(Ty->getScalarType(), Out);
1619 if (Ty->getScalarType()->isIntegerTy(1))
1620 Out << (CI->getZExtValue() ?
"true" :
"false");
1622 Out << CI->getValue();
1624 if (Ty->isVectorTy())
1631 Type *Ty = CFP->getType();
1633 if (Ty->isVectorTy()) {
1635 WriterCtx.TypePrinter->print(Ty->getScalarType(), Out);
1641 if (Ty->isVectorTy())
1648 Out <<
"zeroinitializer";
1653 Out <<
"blockaddress(";
1662 Out <<
"dso_local_equivalent ";
1677 unsigned NumOpsToWrite = 2;
1678 if (!CPA->getOperand(2)->isNullValue())
1680 if (!CPA->getOperand(3)->isNullValue())
1684 for (
unsigned i = 0, e = NumOpsToWrite; i != e; ++i) {
1696 for (
const Value *
Op : CA->operands()) {
1707 if (CA->isString()) {
1716 for (
uint64_t i = 0, e = CA->getNumElements(); i != e; ++i) {
1726 if (CS->getType()->isPacked())
1729 if (CS->getNumOperands() != 0) {
1732 for (
const Value *
Op : CS->operands()) {
1739 if (CS->getType()->isPacked())
1763 for (
unsigned i = 0, e = CVVTy->getNumElements(); i != e; ++i) {
1798 if (CE->getOpcode() == Instruction::ShuffleVector) {
1799 if (
auto *SplatVal = CE->getSplatValue()) {
1809 Out << CE->getOpcodeName();
1814 WriterCtx.TypePrinter->print(
GEP->getSourceElementType(), Out);
1819 for (
const Value *
Op : CE->operands()) {
1826 WriterCtx.TypePrinter->print(CE->getType(), Out);
1829 if (CE->getOpcode() == Instruction::ShuffleVector)
1836 Out <<
"<placeholder or erroneous Constant>";
1840 AsmWriterContext &WriterCtx) {
1848 Value *V = MDV->getValue();
1852 WriterCtx.onWriteMetadataAsOperand(MD);
1861struct MDFieldPrinter {
1864 AsmWriterContext &WriterCtx;
1866 explicit MDFieldPrinter(raw_ostream &Out)
1867 : Out(Out), WriterCtx(AsmWriterContext::getEmpty()) {}
1868 MDFieldPrinter(raw_ostream &Out, AsmWriterContext &Ctx)
1869 : Out(Out), WriterCtx(Ctx) {}
1871 void printTag(
const DINode *
N);
1872 void printMacinfoType(
const DIMacroNode *
N);
1873 void printChecksum(
const DIFile::ChecksumInfo<StringRef> &
N);
1874 void printString(StringRef Name, StringRef
Value,
1875 bool ShouldSkipEmpty =
true);
1876 void printMetadata(StringRef Name,
const Metadata *MD,
1877 bool ShouldSkipNull =
true);
1878 void printMetadataOrInt(StringRef Name,
const Metadata *MD,
bool IsUnsigned,
1879 bool ShouldSkipZero =
true);
1880 template <
class IntTy>
1881 void printInt(StringRef Name, IntTy
Int,
bool ShouldSkipZero =
true);
1882 void printAPInt(StringRef Name,
const APInt &
Int,
bool IsUnsigned,
1883 bool ShouldSkipZero);
1884 void printBool(StringRef Name,
bool Value,
1885 std::optional<bool>
Default = std::nullopt);
1888 template <
class IntTy,
class Stringifier>
1889 void printDwarfEnum(StringRef Name, IntTy
Value, Stringifier
toString,
1890 bool ShouldSkipZero =
true);
1892 void printNameTableKind(StringRef Name,
1899void MDFieldPrinter::printTag(
const DINode *
N) {
1900 Out <<
FS <<
"tag: ";
1908void MDFieldPrinter::printMacinfoType(
const DIMacroNode *
N) {
1909 Out <<
FS <<
"type: ";
1914 Out <<
N->getMacinfoType();
1917void MDFieldPrinter::printChecksum(
1920 printString(
"checksum", Checksum.
Value,
false);
1924 bool ShouldSkipEmpty) {
1925 if (ShouldSkipEmpty &&
Value.empty())
1928 Out <<
FS <<
Name <<
": \"";
1934 AsmWriterContext &WriterCtx) {
1940 WriterCtx.onWriteMetadataAsOperand(MD);
1944 bool ShouldSkipNull) {
1945 if (ShouldSkipNull && !MD)
1948 Out <<
FS <<
Name <<
": ";
1953 bool IsUnsigned,
bool ShouldSkipZero) {
1960 printInt(Name, CV->getZExtValue(), ShouldSkipZero);
1962 printInt(Name, CV->getSExtValue(), ShouldSkipZero);
1964 printMetadata(Name, MD);
1967template <
class IntTy>
1968void MDFieldPrinter::printInt(
StringRef Name, IntTy
Int,
bool ShouldSkipZero) {
1969 if (ShouldSkipZero && !
Int)
1976 bool IsUnsigned,
bool ShouldSkipZero) {
1977 if (ShouldSkipZero &&
Int.isZero())
1980 Out <<
FS <<
Name <<
": ";
1981 Int.print(Out, !IsUnsigned);
1985 std::optional<bool>
Default) {
1988 Out <<
FS <<
Name <<
": " << (
Value ?
"true" :
"false");
1995 Out <<
FS <<
Name <<
": ";
2001 for (
auto F : SplitFlags) {
2003 assert(!StringF.empty() &&
"Expected valid flag");
2004 Out << FlagsFS << StringF;
2006 if (Extra || SplitFlags.empty())
2007 Out << FlagsFS << Extra;
2010void MDFieldPrinter::printDISPFlags(
StringRef Name,
2014 Out <<
FS <<
Name <<
": ";
2025 for (
auto F : SplitFlags) {
2027 assert(!StringF.empty() &&
"Expected valid flag");
2028 Out << FlagsFS << StringF;
2030 if (Extra || SplitFlags.empty())
2031 Out << FlagsFS << Extra;
2034void MDFieldPrinter::printEmissionKind(
StringRef Name,
2039void MDFieldPrinter::printNameTableKind(
StringRef Name,
2046void MDFieldPrinter::printFixedPointKind(
StringRef Name,
2051template <
class IntTy,
class Stringifier>
2053 Stringifier
toString,
bool ShouldSkipZero) {
2054 if (ShouldSkipZero && !
Value)
2057 Out <<
FS <<
Name <<
": ";
2066 AsmWriterContext &WriterCtx) {
2067 Out <<
"!GenericDINode(";
2068 MDFieldPrinter
Printer(Out, WriterCtx);
2070 Printer.printString(
"header",
N->getHeader());
2071 if (
N->getNumDwarfOperands()) {
2072 Out <<
Printer.FS <<
"operands: {";
2074 for (
auto &
I :
N->dwarf_operands()) {
2084 AsmWriterContext &WriterCtx) {
2085 Out <<
"!DILocation(";
2086 MDFieldPrinter
Printer(Out, WriterCtx);
2088 Printer.printInt(
"line",
DL->getLine(),
false);
2089 Printer.printInt(
"column",
DL->getColumn());
2090 Printer.printMetadata(
"scope",
DL->getRawScope(),
false);
2091 Printer.printMetadata(
"inlinedAt",
DL->getRawInlinedAt());
2092 Printer.printBool(
"isImplicitCode",
DL->isImplicitCode(),
2094 Printer.printInt(
"atomGroup",
DL->getAtomGroup());
2095 Printer.printInt<
unsigned>(
"atomRank",
DL->getAtomRank());
2100 AsmWriterContext &WriterCtx) {
2101 Out <<
"!DIAssignID()";
2102 MDFieldPrinter
Printer(Out, WriterCtx);
2106 AsmWriterContext &WriterCtx) {
2107 Out <<
"!DISubrange(";
2108 MDFieldPrinter
Printer(Out, WriterCtx);
2110 Printer.printMetadataOrInt(
"count",
N->getRawCountNode(),
2116 Printer.printMetadataOrInt(
"lowerBound",
N->getRawLowerBound(),
2119 Printer.printMetadataOrInt(
"upperBound",
N->getRawUpperBound(),
2122 Printer.printMetadataOrInt(
"stride",
N->getRawStride(),
2130 AsmWriterContext &WriterCtx) {
2131 Out <<
"!DIGenericSubrange(";
2132 MDFieldPrinter
Printer(Out, WriterCtx);
2134 auto GetConstant = [&](
Metadata *Bound) -> std::optional<int64_t> {
2137 return std::nullopt;
2138 if (BE->isConstant() &&
2140 *BE->isConstant()) {
2141 return static_cast<int64_t
>(BE->getElement(1));
2143 return std::nullopt;
2146 auto *
Count =
N->getRawCountNode();
2147 if (
auto ConstantCount = GetConstant(
Count))
2148 Printer.printInt(
"count", *ConstantCount,
2153 auto *LBound =
N->getRawLowerBound();
2154 if (
auto ConstantLBound = GetConstant(LBound))
2155 Printer.printInt(
"lowerBound", *ConstantLBound,
2158 Printer.printMetadata(
"lowerBound", LBound,
true);
2160 auto *UBound =
N->getRawUpperBound();
2161 if (
auto ConstantUBound = GetConstant(UBound))
2162 Printer.printInt(
"upperBound", *ConstantUBound,
2165 Printer.printMetadata(
"upperBound", UBound,
true);
2167 auto *Stride =
N->getRawStride();
2168 if (
auto ConstantStride = GetConstant(Stride))
2169 Printer.printInt(
"stride", *ConstantStride,
2172 Printer.printMetadata(
"stride", Stride,
true);
2178 AsmWriterContext &) {
2179 Out <<
"!DIEnumerator(";
2181 Printer.printString(
"name",
N->getName(),
false);
2182 Printer.printAPInt(
"value",
N->getValue(),
N->isUnsigned(),
2184 if (
N->isUnsigned())
2185 Printer.printBool(
"isUnsigned",
true);
2190 AsmWriterContext &WriterCtx) {
2191 Out <<
"!DIBasicType(";
2192 MDFieldPrinter
Printer(Out, WriterCtx);
2193 if (
N->getTag() != dwarf::DW_TAG_base_type)
2195 Printer.printString(
"name",
N->getName());
2196 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2197 Printer.printInt(
"align",
N->getAlignInBits());
2198 Printer.printInt(
"dataSize",
N->getDataSizeInBits());
2199 Printer.printDwarfEnum(
"encoding",
N->getEncoding(),
2201 Printer.printInt(
"num_extra_inhabitants",
N->getNumExtraInhabitants());
2202 Printer.printDIFlags(
"flags",
N->getFlags());
2207 AsmWriterContext &WriterCtx) {
2208 Out <<
"!DIFixedPointType(";
2209 MDFieldPrinter
Printer(Out, WriterCtx);
2210 if (
N->getTag() != dwarf::DW_TAG_base_type)
2212 Printer.printString(
"name",
N->getName());
2213 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2214 Printer.printInt(
"align",
N->getAlignInBits());
2215 Printer.printDwarfEnum(
"encoding",
N->getEncoding(),
2217 Printer.printDIFlags(
"flags",
N->getFlags());
2218 Printer.printFixedPointKind(
"kind",
N->getKind());
2219 if (
N->isRational()) {
2220 bool IsUnsigned = !
N->isSigned();
2221 Printer.printAPInt(
"numerator",
N->getNumerator(), IsUnsigned,
false);
2222 Printer.printAPInt(
"denominator",
N->getDenominator(), IsUnsigned,
false);
2224 Printer.printInt(
"factor",
N->getFactor());
2230 AsmWriterContext &WriterCtx) {
2231 Out <<
"!DIStringType(";
2232 MDFieldPrinter
Printer(Out, WriterCtx);
2233 if (
N->getTag() != dwarf::DW_TAG_string_type)
2235 Printer.printString(
"name",
N->getName());
2236 Printer.printMetadata(
"stringLength",
N->getRawStringLength());
2237 Printer.printMetadata(
"stringLengthExpression",
N->getRawStringLengthExp());
2238 Printer.printMetadata(
"stringLocationExpression",
2239 N->getRawStringLocationExp());
2240 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2241 Printer.printInt(
"align",
N->getAlignInBits());
2242 Printer.printDwarfEnum(
"encoding",
N->getEncoding(),
2248 AsmWriterContext &WriterCtx) {
2249 Out <<
"!DIDerivedType(";
2250 MDFieldPrinter
Printer(Out, WriterCtx);
2252 Printer.printString(
"name",
N->getName());
2253 Printer.printMetadata(
"scope",
N->getRawScope());
2254 Printer.printMetadata(
"file",
N->getRawFile());
2255 Printer.printInt(
"line",
N->getLine());
2256 Printer.printMetadata(
"baseType",
N->getRawBaseType(),
2258 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2259 Printer.printInt(
"align",
N->getAlignInBits());
2260 Printer.printMetadataOrInt(
"offset",
N->getRawOffsetInBits(),
true);
2261 Printer.printDIFlags(
"flags",
N->getFlags());
2262 Printer.printMetadata(
"extraData",
N->getRawExtraData());
2263 if (
const auto &DWARFAddressSpace =
N->getDWARFAddressSpace())
2264 Printer.printInt(
"dwarfAddressSpace", *DWARFAddressSpace,
2266 Printer.printMetadata(
"annotations",
N->getRawAnnotations());
2267 if (
auto PtrAuthData =
N->getPtrAuthData()) {
2268 Printer.printInt(
"ptrAuthKey", PtrAuthData->key());
2269 Printer.printBool(
"ptrAuthIsAddressDiscriminated",
2270 PtrAuthData->isAddressDiscriminated());
2271 Printer.printInt(
"ptrAuthExtraDiscriminator",
2272 PtrAuthData->extraDiscriminator());
2273 Printer.printBool(
"ptrAuthIsaPointer", PtrAuthData->isaPointer());
2274 Printer.printBool(
"ptrAuthAuthenticatesNullValues",
2275 PtrAuthData->authenticatesNullValues());
2281 AsmWriterContext &WriterCtx) {
2282 Out <<
"!DISubrangeType(";
2283 MDFieldPrinter
Printer(Out, WriterCtx);
2284 Printer.printString(
"name",
N->getName());
2285 Printer.printMetadata(
"scope",
N->getRawScope());
2286 Printer.printMetadata(
"file",
N->getRawFile());
2287 Printer.printInt(
"line",
N->getLine());
2288 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2289 Printer.printInt(
"align",
N->getAlignInBits());
2290 Printer.printDIFlags(
"flags",
N->getFlags());
2291 Printer.printMetadata(
"baseType",
N->getRawBaseType(),
2293 Printer.printMetadata(
"lowerBound",
N->getRawLowerBound());
2294 Printer.printMetadata(
"upperBound",
N->getRawUpperBound());
2295 Printer.printMetadata(
"stride",
N->getRawStride());
2296 Printer.printMetadata(
"bias",
N->getRawBias());
2301 AsmWriterContext &WriterCtx) {
2302 Out <<
"!DICompositeType(";
2303 MDFieldPrinter
Printer(Out, WriterCtx);
2305 Printer.printString(
"name",
N->getName());
2306 Printer.printMetadata(
"scope",
N->getRawScope());
2307 Printer.printMetadata(
"file",
N->getRawFile());
2308 Printer.printInt(
"line",
N->getLine());
2309 Printer.printMetadata(
"baseType",
N->getRawBaseType());
2310 Printer.printMetadataOrInt(
"size",
N->getRawSizeInBits(),
true);
2311 Printer.printInt(
"align",
N->getAlignInBits());
2312 Printer.printMetadataOrInt(
"offset",
N->getRawOffsetInBits(),
true);
2313 Printer.printInt(
"num_extra_inhabitants",
N->getNumExtraInhabitants());
2314 Printer.printDIFlags(
"flags",
N->getFlags());
2315 Printer.printMetadata(
"elements",
N->getRawElements());
2316 Printer.printDwarfEnum(
"runtimeLang",
N->getRuntimeLang(),
2318 Printer.printMetadata(
"vtableHolder",
N->getRawVTableHolder());
2319 Printer.printMetadata(
"templateParams",
N->getRawTemplateParams());
2320 Printer.printString(
"identifier",
N->getIdentifier());
2321 Printer.printMetadata(
"discriminator",
N->getRawDiscriminator());
2322 Printer.printMetadata(
"dataLocation",
N->getRawDataLocation());
2323 Printer.printMetadata(
"associated",
N->getRawAssociated());
2324 Printer.printMetadata(
"allocated",
N->getRawAllocated());
2325 if (
auto *RankConst =
N->getRankConst())
2326 Printer.printInt(
"rank", RankConst->getSExtValue(),
2329 Printer.printMetadata(
"rank",
N->getRawRank(),
true);
2330 Printer.printMetadata(
"annotations",
N->getRawAnnotations());
2331 if (
auto *Specification =
N->getRawSpecification())
2332 Printer.printMetadata(
"specification", Specification);
2334 if (
auto EnumKind =
N->getEnumKind())
2338 Printer.printMetadata(
"bitStride",
N->getRawBitStride());
2343 AsmWriterContext &WriterCtx) {
2344 Out <<
"!DISubroutineType(";
2345 MDFieldPrinter
Printer(Out, WriterCtx);
2346 Printer.printDIFlags(
"flags",
N->getFlags());
2348 Printer.printMetadata(
"types",
N->getRawTypeArray(),
2356 Printer.printString(
"filename",
N->getFilename(),
2358 Printer.printString(
"directory",
N->getDirectory(),
2361 if (
N->getChecksum())
2362 Printer.printChecksum(*
N->getChecksum());
2364 Printer.printString(
"source", *
N->getSource(),
2370 AsmWriterContext &WriterCtx) {
2371 Out <<
"!DICompileUnit(";
2372 MDFieldPrinter
Printer(Out, WriterCtx);
2378 "sourceLanguageName",
2390 Printer.printMetadata(
"file",
N->getRawFile(),
false);
2391 Printer.printString(
"producer",
N->getProducer());
2392 Printer.printBool(
"isOptimized",
N->isOptimized());
2393 Printer.printString(
"flags",
N->getFlags());
2394 Printer.printInt(
"runtimeVersion",
N->getRuntimeVersion(),
2396 Printer.printString(
"splitDebugFilename",
N->getSplitDebugFilename());
2397 Printer.printEmissionKind(
"emissionKind",
N->getEmissionKind());
2398 Printer.printMetadata(
"enums",
N->getRawEnumTypes());
2399 Printer.printMetadata(
"retainedTypes",
N->getRawRetainedTypes());
2400 Printer.printMetadata(
"globals",
N->getRawGlobalVariables());
2401 Printer.printMetadata(
"imports",
N->getRawImportedEntities());
2402 Printer.printMetadata(
"macros",
N->getRawMacros());
2403 Printer.printInt(
"dwoId",
N->getDWOId());
2404 Printer.printBool(
"splitDebugInlining",
N->getSplitDebugInlining(),
true);
2405 Printer.printBool(
"debugInfoForProfiling",
N->getDebugInfoForProfiling(),
2407 Printer.printNameTableKind(
"nameTableKind",
N->getNameTableKind());
2408 Printer.printBool(
"rangesBaseAddress",
N->getRangesBaseAddress(),
false);
2409 Printer.printString(
"sysroot",
N->getSysRoot());
2410 Printer.printString(
"sdk",
N->getSDK());
2415 AsmWriterContext &WriterCtx) {
2416 Out <<
"!DISubprogram(";
2417 MDFieldPrinter
Printer(Out, WriterCtx);
2418 Printer.printString(
"name",
N->getName());
2419 Printer.printString(
"linkageName",
N->getLinkageName());
2420 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2421 Printer.printMetadata(
"file",
N->getRawFile());
2422 Printer.printInt(
"line",
N->getLine());
2423 Printer.printMetadata(
"type",
N->getRawType());
2424 Printer.printInt(
"scopeLine",
N->getScopeLine());
2425 Printer.printMetadata(
"containingType",
N->getRawContainingType());
2426 if (
N->getVirtuality() != dwarf::DW_VIRTUALITY_none ||
2427 N->getVirtualIndex() != 0)
2428 Printer.printInt(
"virtualIndex",
N->getVirtualIndex(),
false);
2429 Printer.printInt(
"thisAdjustment",
N->getThisAdjustment());
2430 Printer.printDIFlags(
"flags",
N->getFlags());
2431 Printer.printDISPFlags(
"spFlags",
N->getSPFlags());
2432 Printer.printMetadata(
"unit",
N->getRawUnit());
2433 Printer.printMetadata(
"templateParams",
N->getRawTemplateParams());
2434 Printer.printMetadata(
"declaration",
N->getRawDeclaration());
2435 Printer.printMetadata(
"retainedNodes",
N->getRawRetainedNodes());
2436 Printer.printMetadata(
"thrownTypes",
N->getRawThrownTypes());
2437 Printer.printMetadata(
"annotations",
N->getRawAnnotations());
2438 Printer.printString(
"targetFuncName",
N->getTargetFuncName());
2439 Printer.printBool(
"keyInstructions",
N->getKeyInstructionsEnabled(),
false);
2444 AsmWriterContext &WriterCtx) {
2445 Out <<
"!DILexicalBlock(";
2446 MDFieldPrinter
Printer(Out, WriterCtx);
2447 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2448 Printer.printMetadata(
"file",
N->getRawFile());
2449 Printer.printInt(
"line",
N->getLine());
2450 Printer.printInt(
"column",
N->getColumn());
2456 AsmWriterContext &WriterCtx) {
2457 Out <<
"!DILexicalBlockFile(";
2458 MDFieldPrinter
Printer(Out, WriterCtx);
2459 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2460 Printer.printMetadata(
"file",
N->getRawFile());
2461 Printer.printInt(
"discriminator",
N->getDiscriminator(),
2467 AsmWriterContext &WriterCtx) {
2468 Out <<
"!DINamespace(";
2469 MDFieldPrinter
Printer(Out, WriterCtx);
2470 Printer.printString(
"name",
N->getName());
2471 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2472 Printer.printBool(
"exportSymbols",
N->getExportSymbols(),
false);
2477 AsmWriterContext &WriterCtx) {
2478 Out <<
"!DICommonBlock(";
2479 MDFieldPrinter
Printer(Out, WriterCtx);
2480 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2481 Printer.printMetadata(
"declaration",
N->getRawDecl(),
false);
2482 Printer.printString(
"name",
N->getName());
2483 Printer.printMetadata(
"file",
N->getRawFile());
2484 Printer.printInt(
"line",
N->getLineNo());
2489 AsmWriterContext &WriterCtx) {
2491 MDFieldPrinter
Printer(Out, WriterCtx);
2493 Printer.printInt(
"line",
N->getLine());
2494 Printer.printString(
"name",
N->getName());
2495 Printer.printString(
"value",
N->getValue());
2500 AsmWriterContext &WriterCtx) {
2501 Out <<
"!DIMacroFile(";
2502 MDFieldPrinter
Printer(Out, WriterCtx);
2503 Printer.printInt(
"line",
N->getLine());
2504 Printer.printMetadata(
"file",
N->getRawFile(),
false);
2505 Printer.printMetadata(
"nodes",
N->getRawElements());
2510 AsmWriterContext &WriterCtx) {
2511 Out <<
"!DIModule(";
2512 MDFieldPrinter
Printer(Out, WriterCtx);
2513 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2514 Printer.printString(
"name",
N->getName());
2515 Printer.printString(
"configMacros",
N->getConfigurationMacros());
2516 Printer.printString(
"includePath",
N->getIncludePath());
2517 Printer.printString(
"apinotes",
N->getAPINotesFile());
2518 Printer.printMetadata(
"file",
N->getRawFile());
2519 Printer.printInt(
"line",
N->getLineNo());
2520 Printer.printBool(
"isDecl",
N->getIsDecl(),
false);
2526 AsmWriterContext &WriterCtx) {
2527 Out <<
"!DITemplateTypeParameter(";
2528 MDFieldPrinter
Printer(Out, WriterCtx);
2529 Printer.printString(
"name",
N->getName());
2530 Printer.printMetadata(
"type",
N->getRawType(),
false);
2531 Printer.printBool(
"defaulted",
N->isDefault(),
false);
2537 AsmWriterContext &WriterCtx) {
2538 Out <<
"!DITemplateValueParameter(";
2539 MDFieldPrinter
Printer(Out, WriterCtx);
2540 if (
N->getTag() != dwarf::DW_TAG_template_value_parameter)
2542 Printer.printString(
"name",
N->getName());
2543 Printer.printMetadata(
"type",
N->getRawType());
2544 Printer.printBool(
"defaulted",
N->isDefault(),
false);
2545 Printer.printMetadata(
"value",
N->getValue(),
false);
2550 AsmWriterContext &WriterCtx) {
2551 Out <<
"!DIGlobalVariable(";
2552 MDFieldPrinter
Printer(Out, WriterCtx);
2553 Printer.printString(
"name",
N->getName());
2554 Printer.printString(
"linkageName",
N->getLinkageName());
2555 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2556 Printer.printMetadata(
"file",
N->getRawFile());
2557 Printer.printInt(
"line",
N->getLine());
2558 Printer.printMetadata(
"type",
N->getRawType());
2559 Printer.printBool(
"isLocal",
N->isLocalToUnit());
2560 Printer.printBool(
"isDefinition",
N->isDefinition());
2561 Printer.printMetadata(
"declaration",
N->getRawStaticDataMemberDeclaration());
2562 Printer.printMetadata(
"templateParams",
N->getRawTemplateParams());
2563 Printer.printInt(
"align",
N->getAlignInBits());
2564 Printer.printMetadata(
"annotations",
N->getRawAnnotations());
2569 AsmWriterContext &WriterCtx) {
2570 Out <<
"!DILocalVariable(";
2571 MDFieldPrinter
Printer(Out, WriterCtx);
2572 Printer.printString(
"name",
N->getName());
2573 Printer.printInt(
"arg",
N->getArg());
2574 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2575 Printer.printMetadata(
"file",
N->getRawFile());
2576 Printer.printInt(
"line",
N->getLine());
2577 Printer.printMetadata(
"type",
N->getRawType());
2578 Printer.printDIFlags(
"flags",
N->getFlags());
2579 Printer.printInt(
"align",
N->getAlignInBits());
2580 Printer.printMetadata(
"annotations",
N->getRawAnnotations());
2585 AsmWriterContext &WriterCtx) {
2587 MDFieldPrinter
Printer(Out, WriterCtx);
2588 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2589 Printer.printString(
"name",
N->getName());
2590 Printer.printMetadata(
"file",
N->getRawFile());
2591 Printer.printInt(
"line",
N->getLine());
2592 Printer.printInt(
"column",
N->getColumn());
2593 Printer.printBool(
"isArtificial",
N->isArtificial(),
false);
2594 if (
N->getCoroSuspendIdx())
2595 Printer.printInt(
"coroSuspendIdx", *
N->getCoroSuspendIdx(),
2601 AsmWriterContext &WriterCtx) {
2602 Out <<
"!DIExpression(";
2607 assert(!OpStr.empty() &&
"Expected valid opcode");
2611 Out << FS <<
Op.getArg(0);
2614 for (
unsigned A = 0, AE =
Op.getNumArgs();
A != AE; ++
A)
2615 Out << FS <<
Op.getArg(
A);
2619 for (
const auto &
I :
N->getElements())
2626 AsmWriterContext &WriterCtx,
2627 bool FromValue =
false) {
2629 "Unexpected DIArgList metadata outside of value argument");
2630 Out <<
"!DIArgList(";
2632 MDFieldPrinter
Printer(Out, WriterCtx);
2633 for (
const Metadata *Arg :
N->getArgs()) {
2642 AsmWriterContext &WriterCtx) {
2643 Out <<
"!DIGlobalVariableExpression(";
2644 MDFieldPrinter
Printer(Out, WriterCtx);
2645 Printer.printMetadata(
"var",
N->getVariable());
2646 Printer.printMetadata(
"expr",
N->getExpression());
2651 AsmWriterContext &WriterCtx) {
2652 Out <<
"!DIObjCProperty(";
2653 MDFieldPrinter
Printer(Out, WriterCtx);
2654 Printer.printString(
"name",
N->getName());
2655 Printer.printMetadata(
"file",
N->getRawFile());
2656 Printer.printInt(
"line",
N->getLine());
2657 Printer.printString(
"setter",
N->getSetterName());
2658 Printer.printString(
"getter",
N->getGetterName());
2659 Printer.printInt(
"attributes",
N->getAttributes());
2660 Printer.printMetadata(
"type",
N->getRawType());
2665 AsmWriterContext &WriterCtx) {
2666 Out <<
"!DIImportedEntity(";
2667 MDFieldPrinter
Printer(Out, WriterCtx);
2669 Printer.printString(
"name",
N->getName());
2670 Printer.printMetadata(
"scope",
N->getRawScope(),
false);
2671 Printer.printMetadata(
"entity",
N->getRawEntity());
2672 Printer.printMetadata(
"file",
N->getRawFile());
2673 Printer.printInt(
"line",
N->getLine());
2674 Printer.printMetadata(
"elements",
N->getRawElements());
2679 AsmWriterContext &Ctx) {
2680 if (
Node->isDistinct())
2682 else if (
Node->isTemporary())
2683 Out <<
"<temporary!> ";
2685 switch (
Node->getMetadataID()) {
2688#define HANDLE_MDNODE_LEAF(CLASS) \
2689 case Metadata::CLASS##Kind: \
2690 write##CLASS(Out, cast<CLASS>(Node), Ctx); \
2692#include "llvm/IR/Metadata.def"
2699 AsmWriterContext &WriterCtx,
2702 WriterCtx.TypePrinter->print(V->getType(), Out);
2713 assert(WriterCtx.TypePrinter &&
"Constants require TypePrinting!");
2720 if (IA->hasSideEffects())
2721 Out <<
"sideeffect ";
2722 if (IA->isAlignStack())
2723 Out <<
"alignstack ";
2726 Out <<
"inteldialect ";
2745 auto *
Machine = WriterCtx.Machine;
2749 Slot =
Machine->getGlobalSlot(GV);
2752 Slot =
Machine->getLocalSlot(V);
2759 Slot =
Machine->getLocalSlot(V);
2766 Slot =
Machine->getGlobalSlot(GV);
2769 Slot =
Machine->getLocalSlot(V);
2778 Out << Prefix << Slot;
2784 AsmWriterContext &WriterCtx,
2798 std::unique_ptr<SlotTracker> MachineStorage;
2800 if (!WriterCtx.Machine) {
2801 MachineStorage = std::make_unique<SlotTracker>(WriterCtx.Context);
2802 WriterCtx.Machine = MachineStorage.get();
2812 Out <<
"<" <<
N <<
">";
2826 assert(WriterCtx.TypePrinter &&
"TypePrinter required for metadata values");
2828 "Unexpected function-local metadata outside of value argument");
2835class AssemblyWriter {
2836 formatted_raw_ostream &Out;
2837 const Module *TheModule =
nullptr;
2838 const ModuleSummaryIndex *TheIndex =
nullptr;
2839 std::unique_ptr<SlotTracker> SlotTrackerStorage;
2841 TypePrinting TypePrinter;
2842 AssemblyAnnotationWriter *AnnotationWriter =
nullptr;
2843 SetVector<const Comdat *> Comdats;
2845 bool ShouldPreserveUseListOrder;
2850 DenseMap<const GlobalValueSummary *, GlobalValue::GUID> SummaryToGUIDMap;
2854 AssemblyWriter(formatted_raw_ostream &o, SlotTracker &Mac,
const Module *M,
2855 AssemblyAnnotationWriter *AAW,
bool IsForDebug,
2856 bool ShouldPreserveUseListOrder =
false);
2858 AssemblyWriter(formatted_raw_ostream &o, SlotTracker &Mac,
2859 const ModuleSummaryIndex *Index,
bool IsForDebug);
2862 return AsmWriterContext(&TypePrinter, &
Machine, TheModule);
2865 void printMDNodeBody(
const MDNode *MD);
2866 void printNamedMDNode(
const NamedMDNode *NMD);
2868 void printModule(
const Module *M);
2870 void writeOperand(
const Value *
Op,
bool PrintType);
2871 void writeParamOperand(
const Value *Operand, AttributeSet Attrs);
2872 void writeOperandBundles(
const CallBase *
Call);
2873 void writeSyncScope(
const LLVMContext &
Context,
2875 void writeAtomic(
const LLVMContext &
Context,
2878 void writeAtomicCmpXchg(
const LLVMContext &
Context,
2883 void writeAllMDNodes();
2884 void writeMDNode(
unsigned Slot,
const MDNode *Node);
2885 void writeAttribute(
const Attribute &Attr,
bool InAttrGroup =
false);
2886 void writeAttributeSet(
const AttributeSet &AttrSet,
bool InAttrGroup =
false);
2887 void writeAllAttributeGroups();
2889 void printTypeIdentities();
2890 void printGlobal(
const GlobalVariable *GV);
2891 void printAlias(
const GlobalAlias *GA);
2892 void printIFunc(
const GlobalIFunc *GI);
2893 void printComdat(
const Comdat *
C);
2894 void printFunction(
const Function *
F);
2895 void printArgument(
const Argument *FA, AttributeSet Attrs);
2897 void printInstructionLine(
const Instruction &
I);
2898 void printInstruction(
const Instruction &
I);
2899 void printDbgMarker(
const DbgMarker &DPI);
2900 void printDbgVariableRecord(
const DbgVariableRecord &DVR);
2901 void printDbgLabelRecord(
const DbgLabelRecord &DLR);
2902 void printDbgRecord(
const DbgRecord &DR);
2903 void printDbgRecordLine(
const DbgRecord &DR);
2905 void printUseListOrder(
const Value *V, ArrayRef<unsigned> Shuffle);
2906 void printUseLists(
const Function *
F);
2908 void printModuleSummaryIndex();
2909 void printSummaryInfo(
unsigned Slot,
const ValueInfo &VI);
2910 void printSummary(
const GlobalValueSummary &Summary);
2911 void printAliasSummary(
const AliasSummary *AS);
2912 void printGlobalVarSummary(
const GlobalVarSummary *GS);
2913 void printFunctionSummary(
const FunctionSummary *FS);
2914 void printTypeIdSummary(
const TypeIdSummary &TIS);
2916 void printTypeTestResolution(
const TypeTestResolution &TTRes);
2917 void printArgs(ArrayRef<uint64_t> Args);
2918 void printWPDRes(
const WholeProgramDevirtResolution &WPDRes);
2919 void printTypeIdInfo(
const FunctionSummary::TypeIdInfo &TIDInfo);
2920 void printVFuncId(
const FunctionSummary::VFuncId VFId);
2928 void printMetadataAttachments(
2929 const SmallVectorImpl<std::pair<unsigned, MDNode *>> &MDs,
2930 StringRef Separator);
2934 void printInfoComment(
const Value &V);
2938 void printGCRelocateComment(
const GCRelocateInst &Relocate);
2945 bool IsForDebug,
bool ShouldPreserveUseListOrder)
2946 : Out(
o), TheModule(
M),
Machine(Mac), TypePrinter(
M), AnnotationWriter(AAW),
2947 IsForDebug(IsForDebug),
2948 ShouldPreserveUseListOrder(
2951 : ShouldPreserveUseListOrder) {
2954 for (
const GlobalObject &GO : TheModule->global_objects())
2961 : Out(
o), TheIndex(Index),
Machine(Mac), TypePrinter(nullptr),
2962 IsForDebug(IsForDebug),
2965void AssemblyWriter::writeOperand(
const Value *Operand,
bool PrintType) {
2967 Out <<
"<null operand!>";
2974void AssemblyWriter::writeSyncScope(
const LLVMContext &
Context,
2982 Context.getSyncScopeNames(SSNs);
2984 Out <<
" syncscope(\"";
2992void AssemblyWriter::writeAtomic(
const LLVMContext &
Context,
2995 if (Ordering == AtomicOrdering::NotAtomic)
2998 writeSyncScope(
Context, SSID);
3002void AssemblyWriter::writeAtomicCmpXchg(
const LLVMContext &
Context,
3006 assert(SuccessOrdering != AtomicOrdering::NotAtomic &&
3007 FailureOrdering != AtomicOrdering::NotAtomic);
3009 writeSyncScope(
Context, SSID);
3014void AssemblyWriter::writeParamOperand(
const Value *Operand,
3015 AttributeSet Attrs) {
3017 Out <<
"<null operand!>";
3022 TypePrinter.print(Operand->
getType(), Out);
3024 if (
Attrs.hasAttributes()) {
3026 writeAttributeSet(Attrs);
3034void AssemblyWriter::writeOperandBundles(
const CallBase *
Call) {
3050 ListSeparator InnerLS;
3052 for (
const auto &Input : BU.
Inputs) {
3054 if (Input ==
nullptr)
3055 Out <<
"<null operand bundle!>";
3066void AssemblyWriter::printModule(
const Module *M) {
3069 if (ShouldPreserveUseListOrder)
3072 if (!
M->getModuleIdentifier().empty() &&
3075 M->getModuleIdentifier().find(
'\n') == std::string::npos)
3076 Out <<
"; ModuleID = '" <<
M->getModuleIdentifier() <<
"'\n";
3078 if (!
M->getSourceFileName().empty()) {
3079 Out <<
"source_filename = \"";
3084 const std::string &
DL =
M->getDataLayoutStr();
3086 Out <<
"target datalayout = \"" <<
DL <<
"\"\n";
3087 if (!
M->getTargetTriple().empty())
3088 Out <<
"target triple = \"" <<
M->getTargetTriple().str() <<
"\"\n";
3090 if (!
M->getModuleInlineAsm().empty()) {
3094 StringRef
Asm =
M->getModuleInlineAsm();
3097 std::tie(Front, Asm) =
Asm.split(
'\n');
3101 Out <<
"module asm \"";
3104 }
while (!
Asm.empty());
3107 printTypeIdentities();
3110 if (!Comdats.empty())
3112 for (
const Comdat *
C : Comdats) {
3114 if (
C != Comdats.back())
3119 if (!
M->global_empty()) Out <<
'\n';
3120 for (
const GlobalVariable &GV :
M->globals()) {
3121 printGlobal(&GV); Out <<
'\n';
3125 if (!
M->alias_empty()) Out <<
"\n";
3126 for (
const GlobalAlias &GA :
M->aliases())
3130 if (!
M->ifunc_empty()) Out <<
"\n";
3131 for (
const GlobalIFunc &GI :
M->ifuncs())
3135 for (
const Function &
F : *M) {
3141 printUseLists(
nullptr);
3146 writeAllAttributeGroups();
3150 if (!
M->named_metadata_empty()) Out <<
'\n';
3152 for (
const NamedMDNode &Node :
M->named_metadata())
3153 printNamedMDNode(&Node);
3162void AssemblyWriter::printModuleSummaryIndex() {
3164 int NumSlots =
Machine.initializeIndexIfNeeded();
3170 std::vector<std::pair<std::string, ModuleHash>> moduleVec;
3171 std::string RegularLTOModuleName =
3173 moduleVec.resize(TheIndex->modulePaths().size());
3174 for (
auto &[ModPath, ModHash] : TheIndex->modulePaths())
3175 moduleVec[
Machine.getModulePathSlot(ModPath)] = std::make_pair(
3178 ModPath.empty() ? RegularLTOModuleName : std::string(ModPath), ModHash);
3181 for (
auto &ModPair : moduleVec) {
3182 Out <<
"^" << i++ <<
" = module: (";
3185 Out <<
"\", hash: (";
3187 for (
auto Hash : ModPair.second)
3194 for (
auto &GlobalList : *TheIndex) {
3195 auto GUID = GlobalList.first;
3196 for (
auto &Summary : GlobalList.second.getSummaryList())
3201 for (
auto &GlobalList : *TheIndex) {
3202 auto GUID = GlobalList.first;
3203 auto VI = TheIndex->getValueInfo(GlobalList);
3204 printSummaryInfo(
Machine.getGUIDSlot(GUID), VI);
3208 for (
const auto &TID : TheIndex->typeIds()) {
3209 Out <<
"^" <<
Machine.getTypeIdSlot(TID.second.first)
3210 <<
" = typeid: (name: \"" << TID.second.first <<
"\"";
3211 printTypeIdSummary(TID.second.second);
3212 Out <<
") ; guid = " << TID.first <<
"\n";
3216 for (
auto &TId : TheIndex->typeIdCompatibleVtableMap()) {
3218 Out <<
"^" <<
Machine.getTypeIdCompatibleVtableSlot(TId.first)
3219 <<
" = typeidCompatibleVTable: (name: \"" << TId.first <<
"\"";
3220 printTypeIdCompatibleVtableSummary(TId.second);
3221 Out <<
") ; guid = " <<
GUID <<
"\n";
3225 if (TheIndex->getFlags()) {
3226 Out <<
"^" << NumSlots <<
" = flags: " << TheIndex->getFlags() <<
"\n";
3230 Out <<
"^" << NumSlots <<
" = blockcount: " << TheIndex->getBlockCount()
3240 return "singleImpl";
3242 return "branchFunnel";
3253 return "uniformRetVal";
3255 return "uniqueRetVal";
3257 return "virtualConstProp";
3280void AssemblyWriter::printTypeTestResolution(
const TypeTestResolution &TTRes) {
3287 Out <<
", alignLog2: " << TTRes.
AlignLog2;
3289 Out <<
", sizeM1: " << TTRes.
SizeM1;
3292 Out <<
", bitMask: " << (unsigned)TTRes.
BitMask;
3299void AssemblyWriter::printTypeIdSummary(
const TypeIdSummary &TIS) {
3300 Out <<
", summary: (";
3301 printTypeTestResolution(TIS.
TTRes);
3302 if (!TIS.
WPDRes.empty()) {
3303 Out <<
", wpdResolutions: (";
3305 for (
auto &WPDRes : TIS.
WPDRes) {
3307 Out <<
"(offset: " << WPDRes.first <<
", ";
3308 printWPDRes(WPDRes.second);
3316void AssemblyWriter::printTypeIdCompatibleVtableSummary(
3318 Out <<
", summary: (";
3320 for (
auto &
P : TI) {
3322 Out <<
"(offset: " <<
P.AddressPointOffset <<
", ";
3323 Out <<
"^" <<
Machine.getGUIDSlot(
P.VTableVI.getGUID());
3329void AssemblyWriter::printArgs(ArrayRef<uint64_t> Args) {
3333void AssemblyWriter::printWPDRes(
const WholeProgramDevirtResolution &WPDRes) {
3334 Out <<
"wpdRes: (kind: ";
3341 Out <<
", resByArg: (";
3343 for (
auto &ResByArg : WPDRes.
ResByArg) {
3345 printArgs(ResByArg.first);
3346 Out <<
", byArg: (kind: ";
3348 if (ResByArg.second.TheKind ==
3350 ResByArg.second.TheKind ==
3352 Out <<
", info: " << ResByArg.second.Info;
3356 if (ResByArg.second.Byte || ResByArg.second.Bit)
3357 Out <<
", byte: " << ResByArg.second.Byte
3358 <<
", bit: " << ResByArg.second.Bit;
3379void AssemblyWriter::printAliasSummary(
const AliasSummary *AS) {
3380 Out <<
", aliasee: ";
3390void AssemblyWriter::printGlobalVarSummary(
const GlobalVarSummary *GS) {
3391 auto VTableFuncs =
GS->vTableFuncs();
3392 Out <<
", varFlags: (readonly: " <<
GS->VarFlags.MaybeReadOnly <<
", "
3393 <<
"writeonly: " <<
GS->VarFlags.MaybeWriteOnly <<
", "
3394 <<
"constant: " <<
GS->VarFlags.Constant;
3395 if (!VTableFuncs.empty())
3397 <<
"vcall_visibility: " <<
GS->VarFlags.VCallVisibility;
3400 if (!VTableFuncs.empty()) {
3401 Out <<
", vTableFuncs: (";
3403 for (
auto &
P : VTableFuncs) {
3405 Out <<
"(virtFunc: ^" <<
Machine.getGUIDSlot(
P.FuncVI.getGUID())
3406 <<
", offset: " <<
P.VTableOffset;
3424 return "linkonce_odr";
3434 return "extern_weak";
3436 return "available_externally";
3465 return "definition";
3467 return "declaration";
3472void AssemblyWriter::printFunctionSummary(
const FunctionSummary *FS) {
3473 Out <<
", insts: " <<
FS->instCount();
3474 if (
FS->fflags().anyFlagSet())
3475 Out <<
", " <<
FS->fflags();
3477 if (!
FS->calls().empty()) {
3478 Out <<
", calls: (";
3480 for (
auto &
Call :
FS->calls()) {
3482 Out <<
"(callee: ^" <<
Machine.getGUIDSlot(
Call.first.getGUID());
3483 if (
Call.second.getHotness() != CalleeInfo::HotnessType::Unknown)
3485 else if (
Call.second.RelBlockFreq)
3486 Out <<
", relbf: " <<
Call.second.RelBlockFreq;
3489 if (
Call.second.HasTailCall)
3496 if (
const auto *TIdInfo =
FS->getTypeIdInfo())
3497 printTypeIdInfo(*TIdInfo);
3501 auto AllocTypeName = [](uint8_t
Type) ->
const char * {
3503 case (uint8_t)AllocationType::None:
3505 case (uint8_t)AllocationType::NotCold:
3507 case (uint8_t)AllocationType::Cold:
3509 case (uint8_t)AllocationType::Hot:
3515 if (!
FS->allocs().empty()) {
3516 Out <<
", allocs: (";
3518 for (
auto &AI :
FS->allocs()) {
3520 Out <<
"(versions: (";
3522 for (
auto V : AI.Versions) {
3524 Out << AllocTypeName(V);
3526 Out <<
"), memProf: (";
3527 ListSeparator MIBFS;
3528 for (
auto &MIB : AI.MIBs) {
3530 Out <<
"(type: " << AllocTypeName((uint8_t)MIB.AllocType);
3531 Out <<
", stackIds: (";
3532 ListSeparator SIDFS;
3533 for (
auto Id : MIB.StackIdIndices) {
3535 Out << TheIndex->getStackIdAtIndex(Id);
3544 if (!
FS->callsites().empty()) {
3545 Out <<
", callsites: (";
3547 for (
auto &CI :
FS->callsites()) {
3550 Out <<
"(callee: ^" <<
Machine.getGUIDSlot(CI.Callee.getGUID());
3552 Out <<
"(callee: null";
3553 Out <<
", clones: (";
3555 for (
auto V : CI.Clones) {
3559 Out <<
"), stackIds: (";
3560 ListSeparator SIDFS;
3561 for (
auto Id : CI.StackIdIndices) {
3563 Out << TheIndex->getStackIdAtIndex(Id);
3570 auto PrintRange = [&](
const ConstantRange &
Range) {
3574 if (!
FS->paramAccesses().empty()) {
3575 Out <<
", params: (";
3577 for (
auto &PS :
FS->paramAccesses()) {
3579 Out <<
"(param: " << PS.ParamNo;
3580 Out <<
", offset: ";
3582 if (!PS.Calls.empty()) {
3583 Out <<
", calls: (";
3585 for (
auto &
Call : PS.Calls) {
3587 Out <<
"(callee: ^" <<
Machine.getGUIDSlot(
Call.Callee.getGUID());
3588 Out <<
", param: " <<
Call.ParamNo;
3589 Out <<
", offset: ";
3590 PrintRange(
Call.Offsets);
3601void AssemblyWriter::printTypeIdInfo(
3602 const FunctionSummary::TypeIdInfo &TIDInfo) {
3603 Out <<
", typeIdInfo: (";
3604 ListSeparator TIDFS;
3607 Out <<
"typeTests: (";
3610 auto TidIter = TheIndex->typeIds().equal_range(GUID);
3611 if (TidIter.first == TidIter.second) {
3617 for (
const auto &[GUID, TypeIdPair] :
make_range(TidIter)) {
3619 auto Slot =
Machine.getTypeIdSlot(TypeIdPair.first);
3637 "typeTestAssumeConstVCalls");
3642 "typeCheckedLoadConstVCalls");
3647void AssemblyWriter::printVFuncId(
const FunctionSummary::VFuncId VFId) {
3648 auto TidIter = TheIndex->typeIds().equal_range(VFId.
GUID);
3649 if (TidIter.first == TidIter.second) {
3650 Out <<
"vFuncId: (";
3651 Out <<
"guid: " << VFId.
GUID;
3652 Out <<
", offset: " << VFId.
Offset;
3658 for (
const auto &[GUID, TypeIdPair] :
make_range(TidIter)) {
3660 Out <<
"vFuncId: (";
3661 auto Slot =
Machine.getTypeIdSlot(TypeIdPair.first);
3664 Out <<
", offset: " << VFId.
Offset;
3669void AssemblyWriter::printNonConstVCalls(
3671 Out <<
Tag <<
": (";
3673 for (
auto &VFuncId : VCallList) {
3675 printVFuncId(VFuncId);
3680void AssemblyWriter::printConstVCalls(
3682 Out <<
Tag <<
": (";
3684 for (
auto &ConstVCall : VCallList) {
3687 printVFuncId(ConstVCall.VFunc);
3688 if (!ConstVCall.Args.empty()) {
3690 printArgs(ConstVCall.Args);
3697void AssemblyWriter::printSummary(
const GlobalValueSummary &Summary) {
3698 GlobalValueSummary::GVFlags GVFlags =
Summary.flags();
3701 Out <<
"(module: ^" <<
Machine.getModulePathSlot(
Summary.modulePath())
3704 Out <<
", visibility: "
3707 Out <<
", live: " << GVFlags.
Live;
3708 Out <<
", dsoLocal: " << GVFlags.
DSOLocal;
3710 Out <<
", importType: "
3721 auto RefList =
Summary.refs();
3722 if (!RefList.empty()) {
3725 for (
auto &
Ref : RefList) {
3727 if (
Ref.isReadOnly())
3729 else if (
Ref.isWriteOnly())
3730 Out <<
"writeonly ";
3731 Out <<
"^" <<
Machine.getGUIDSlot(
Ref.getGUID());
3739void AssemblyWriter::printSummaryInfo(
unsigned Slot,
const ValueInfo &VI) {
3740 Out <<
"^" <<
Slot <<
" = gv: (";
3741 if (
VI.hasName() && !
VI.name().empty())
3742 Out <<
"name: \"" <<
VI.name() <<
"\"";
3744 Out <<
"guid: " <<
VI.getGUID();
3745 if (!
VI.getSummaryList().empty()) {
3746 Out <<
", summaries: (";
3748 for (
auto &Summary :
VI.getSummaryList()) {
3750 printSummary(*Summary);
3755 if (
VI.hasName() && !
VI.name().empty())
3756 Out <<
" ; guid = " <<
VI.getGUID();
3763 Out <<
"<empty name> ";
3765 unsigned char FirstC =
static_cast<unsigned char>(Name[0]);
3766 if (isalpha(FirstC) || FirstC ==
'-' || FirstC ==
'$' || FirstC ==
'.' ||
3771 for (
unsigned i = 1, e = Name.size(); i != e; ++i) {
3772 unsigned char C = Name[i];
3773 if (isalnum(
C) ||
C ==
'-' ||
C ==
'$' ||
C ==
'.' ||
C ==
'_')
3781void AssemblyWriter::printNamedMDNode(
const NamedMDNode *NMD) {
3816 Out <<
"dso_local ";
3834 Out <<
"thread_local ";
3837 Out <<
"thread_local(localdynamic) ";
3840 Out <<
"thread_local(initialexec) ";
3843 Out <<
"thread_local(localexec) ";
3853 return "local_unnamed_addr";
3855 return "unnamed_addr";
3878void AssemblyWriter::printGlobal(
const GlobalVariable *GV) {
3880 Out <<
"; Materializable\n";
3901 Out << (GV->
isConstant() ?
"constant " :
"global ");
3910 Out <<
", section \"";
3915 Out <<
", partition \"";
3920 Out <<
", code_model \"";
3945 Out <<
", no_sanitize_address";
3947 Out <<
", no_sanitize_hwaddress";
3949 Out <<
", sanitize_memtag";
3951 Out <<
", sanitize_address_dyninit";
3956 Out <<
", align " <<
A->value();
3960 printMetadataAttachments(MDs,
", ");
3963 if (
Attrs.hasAttributes())
3964 Out <<
" #" <<
Machine.getAttributeGroupSlot(Attrs);
3966 printInfoComment(*GV);
3969void AssemblyWriter::printAlias(
const GlobalAlias *GA) {
3971 Out <<
"; Materializable\n";
3991 if (
const Constant *Aliasee = GA->
getAliasee()) {
3994 TypePrinter.print(GA->
getType(), Out);
3995 Out <<
" <<NULL ALIASEE>>";
3999 Out <<
", partition \"";
4004 printInfoComment(*GA);
4008void AssemblyWriter::printIFunc(
const GlobalIFunc *GI) {
4010 Out <<
"; Materializable\n";
4025 if (
const Constant *Resolver = GI->
getResolver()) {
4028 TypePrinter.print(GI->
getType(), Out);
4029 Out <<
" <<NULL RESOLVER>>";
4033 Out <<
", partition \"";
4040 printMetadataAttachments(MDs,
", ");
4043 printInfoComment(*GI);
4047void AssemblyWriter::printComdat(
const Comdat *
C) {
4051void AssemblyWriter::printTypeIdentities() {
4052 if (TypePrinter.empty())
4058 auto &NumberedTypes = TypePrinter.getNumberedTypes();
4059 for (
unsigned I = 0,
E = NumberedTypes.size();
I !=
E; ++
I) {
4060 Out <<
'%' <<
I <<
" = type ";
4064 TypePrinter.printStructBody(NumberedTypes[
I], Out);
4068 auto &NamedTypes = TypePrinter.getNamedTypes();
4069 for (StructType *NamedType : NamedTypes) {
4075 TypePrinter.printStructBody(NamedType, Out);
4081void AssemblyWriter::printFunction(
const Function *
F) {
4082 if (
F->isMaterializable())
4083 Out <<
"; Materializable\n";
4084 else if (AnnotationWriter)
4087 const AttributeList &
Attrs =
F->getAttributes();
4088 if (
Attrs.hasFnAttrs()) {
4089 AttributeSet AS =
Attrs.getFnAttrs();
4090 std::string AttrStr;
4093 if (!Attr.isStringAttribute()) {
4094 if (!AttrStr.empty()) AttrStr +=
' ';
4095 AttrStr += Attr.getAsString();
4099 if (!AttrStr.empty())
4100 Out <<
"; Function Attrs: " << AttrStr <<
'\n';
4104 Out <<
"; Unknown intrinsic\n";
4108 if (
F->isDeclaration()) {
4111 F->getAllMetadata(MDs);
4112 printMetadataAttachments(MDs,
" ");
4123 if (
F->getCallingConv() != CallingConv::C) {
4128 FunctionType *FT =
F->getFunctionType();
4129 if (
Attrs.hasRetAttrs())
4130 Out <<
Attrs.getAsString(AttributeList::ReturnIndex) <<
' ';
4131 TypePrinter.print(
F->getReturnType(), Out);
4138 if (
F->isDeclaration() && !IsForDebug) {
4141 for (
unsigned I = 0,
E = FT->getNumParams();
I !=
E; ++
I) {
4144 TypePrinter.print(FT->getParamType(
I), Out);
4146 AttributeSet ArgAttrs =
Attrs.getParamAttrs(
I);
4149 writeAttributeSet(ArgAttrs);
4155 for (
const Argument &Arg :
F->args()) {
4157 printArgument(&Arg,
Attrs.getParamAttrs(Arg.getArgNo()));
4162 if (FT->isVarArg()) {
4163 if (FT->getNumParams()) Out <<
", ";
4174 if (
F->getAddressSpace() != 0 || !
Mod ||
4175 Mod->getDataLayout().getProgramAddressSpace() != 0)
4176 Out <<
" addrspace(" <<
F->getAddressSpace() <<
")";
4177 if (
Attrs.hasFnAttrs())
4178 Out <<
" #" <<
Machine.getAttributeGroupSlot(
Attrs.getFnAttrs());
4179 if (
F->hasSection()) {
4180 Out <<
" section \"";
4184 if (
F->hasPartition()) {
4185 Out <<
" partition \"";
4190 if (MaybeAlign
A =
F->getAlign())
4191 Out <<
" align " <<
A->value();
4193 Out <<
" gc \"" <<
F->getGC() <<
'"';
4194 if (
F->hasPrefixData()) {
4196 writeOperand(
F->getPrefixData(),
true);
4198 if (
F->hasPrologueData()) {
4199 Out <<
" prologue ";
4200 writeOperand(
F->getPrologueData(),
true);
4202 if (
F->hasPersonalityFn()) {
4203 Out <<
" personality ";
4204 writeOperand(
F->getPersonalityFn(),
true);
4208 if (
auto *MDProf =
F->getMetadata(LLVMContext::MD_prof)) {
4210 MDProf->print(Out, TheModule,
true);
4214 if (
F->isDeclaration()) {
4218 F->getAllMetadata(MDs);
4219 printMetadataAttachments(MDs,
" ");
4223 for (
const BasicBlock &BB : *
F)
4237void AssemblyWriter::printArgument(
const Argument *Arg, AttributeSet Attrs) {
4239 TypePrinter.print(Arg->
getType(), Out);
4242 if (
Attrs.hasAttributes()) {
4244 writeAttributeSet(Attrs);
4253 assert(Slot != -1 &&
"expect argument in function here");
4254 Out <<
" %" <<
Slot;
4265 }
else if (!IsEntryBlock) {
4267 int Slot =
Machine.getLocalSlot(BB);
4274 if (!IsEntryBlock) {
4279 Out <<
" No predecessors!";
4285 writeOperand(Pred,
false);
4296 for (
const DbgRecord &DR :
I.getDbgRecordRange())
4297 printDbgRecordLine(DR);
4298 printInstructionLine(
I);
4305void AssemblyWriter::printInstructionLine(
const Instruction &
I) {
4306 printInstruction(
I);
4312void AssemblyWriter::printGCRelocateComment(
const GCRelocateInst &Relocate) {
4322void AssemblyWriter::printInfoComment(
const Value &V) {
4324 printGCRelocateComment(*Relocate);
4326 if (AnnotationWriter) {
4332 if (
I->getDebugLoc()) {
4334 I->getDebugLoc().print(Out);
4340 if (
auto *MD =
I->getMetadata(LLVMContext::MD_prof)) {
4342 MD->print(Out, TheModule,
true);
4354 if (Operand ==
nullptr) {
4355 Out <<
" <cannot get addrspace!>";
4359 bool PrintAddrSpace = CallAddrSpace != 0;
4360 if (!PrintAddrSpace) {
4365 if (!
Mod ||
Mod->getDataLayout().getProgramAddressSpace() != 0)
4366 PrintAddrSpace =
true;
4369 Out <<
" addrspace(" << CallAddrSpace <<
")";
4373void AssemblyWriter::printInstruction(
const Instruction &
I) {
4383 }
else if (!
I.getType()->isVoidTy()) {
4385 int SlotNum =
Machine.getLocalSlot(&
I);
4387 Out <<
"<badref> = ";
4389 Out <<
'%' << SlotNum <<
" = ";
4393 if (CI->isMustTailCall())
4395 else if (CI->isTailCall())
4397 else if (CI->isNoTailCall())
4402 Out <<
I.getOpcodeName();
4424 Out <<
' ' << CI->getPredicate();
4431 const Value *Operand =
I.getNumOperands() ?
I.getOperand(0) :
nullptr;
4437 writeOperand(BI.getCondition(),
true);
4439 writeOperand(BI.getSuccessor(0),
true);
4441 writeOperand(BI.getSuccessor(1),
true);
4447 writeOperand(
SI.getCondition(),
true);
4449 writeOperand(
SI.getDefaultDest(),
true);
4451 for (
auto Case :
SI.cases()) {
4453 writeOperand(Case.getCaseValue(),
true);
4455 writeOperand(Case.getCaseSuccessor(),
true);
4461 writeOperand(Operand,
true);
4465 for (
unsigned i = 1, e =
I.getNumOperands(); i != e; ++i) {
4467 writeOperand(
I.getOperand(i),
true);
4472 TypePrinter.print(
I.getType(), Out);
4476 for (
const auto &[V,
Block] :
4477 zip_equal(PN->incoming_values(), PN->blocks())) {
4479 writeOperand(V,
false);
4481 writeOperand(
Block,
false);
4486 writeOperand(
I.getOperand(0),
true);
4491 writeOperand(
I.getOperand(0),
true); Out <<
", ";
4492 writeOperand(
I.getOperand(1),
true);
4497 TypePrinter.print(
I.getType(), Out);
4498 if (LPI->isCleanup() || LPI->getNumClauses() != 0)
4501 if (LPI->isCleanup())
4504 for (
unsigned i = 0, e = LPI->getNumClauses(); i != e; ++i) {
4505 if (i != 0 || LPI->isCleanup()) Out <<
"\n";
4506 if (LPI->isCatch(i))
4511 writeOperand(LPI->getClause(i),
true);
4515 writeOperand(CatchSwitch->getParentPad(),
false);
4518 for (
const BasicBlock *PadBB : CatchSwitch->handlers()) {
4520 writeOperand(PadBB,
true);
4523 if (
const BasicBlock *UnwindDest = CatchSwitch->getUnwindDest())
4524 writeOperand(UnwindDest,
true);
4529 writeOperand(FPI->getParentPad(),
false);
4532 for (
const Value *
Op : FPI->arg_operands()) {
4534 writeOperand(
Op,
true);
4541 writeOperand(CRI->getOperand(0),
false);
4544 writeOperand(CRI->getOperand(1),
true);
4547 writeOperand(CRI->getOperand(0),
false);
4550 if (CRI->hasUnwindDest())
4551 writeOperand(CRI->getOperand(1),
true);
4556 if (CI->getCallingConv() != CallingConv::C) {
4561 Operand = CI->getCalledOperand();
4562 FunctionType *FTy = CI->getFunctionType();
4563 Type *RetTy = FTy->getReturnType();
4564 const AttributeList &PAL = CI->getAttributes();
4566 if (PAL.hasRetAttrs())
4567 Out <<
' ' << PAL.getAsString(AttributeList::ReturnIndex);
4576 TypePrinter.print(FTy->isVarArg() ? FTy : RetTy, Out);
4578 writeOperand(Operand,
false);
4581 for (
unsigned op = 0, Eop = CI->arg_size();
op < Eop; ++
op) {
4583 writeParamOperand(CI->getArgOperand(
op), PAL.getParamAttrs(
op));
4588 if (CI->isMustTailCall() && CI->getParent() &&
4589 CI->getParent()->getParent() &&
4590 CI->getParent()->getParent()->isVarArg()) {
4591 if (CI->arg_size() > 0)
4597 if (PAL.hasFnAttrs())
4598 Out <<
" #" <<
Machine.getAttributeGroupSlot(PAL.getFnAttrs());
4600 writeOperandBundles(CI);
4602 Operand =
II->getCalledOperand();
4603 FunctionType *FTy =
II->getFunctionType();
4604 Type *RetTy = FTy->getReturnType();
4605 const AttributeList &PAL =
II->getAttributes();
4608 if (
II->getCallingConv() != CallingConv::C) {
4613 if (PAL.hasRetAttrs())
4614 Out <<
' ' << PAL.getAsString(AttributeList::ReturnIndex);
4624 TypePrinter.print(FTy->isVarArg() ? FTy : RetTy, Out);
4626 writeOperand(Operand,
false);
4629 for (
unsigned op = 0, Eop =
II->arg_size();
op < Eop; ++
op) {
4631 writeParamOperand(
II->getArgOperand(
op), PAL.getParamAttrs(
op));
4635 if (PAL.hasFnAttrs())
4636 Out <<
" #" <<
Machine.getAttributeGroupSlot(PAL.getFnAttrs());
4638 writeOperandBundles(
II);
4641 writeOperand(
II->getNormalDest(),
true);
4643 writeOperand(
II->getUnwindDest(),
true);
4645 Operand = CBI->getCalledOperand();
4646 FunctionType *FTy = CBI->getFunctionType();
4647 Type *RetTy = FTy->getReturnType();
4648 const AttributeList &PAL = CBI->getAttributes();
4651 if (CBI->getCallingConv() != CallingConv::C) {
4656 if (PAL.hasRetAttrs())
4657 Out <<
' ' << PAL.getAsString(AttributeList::ReturnIndex);
4664 TypePrinter.print(FTy->isVarArg() ? FTy : RetTy, Out);
4666 writeOperand(Operand,
false);
4668 ListSeparator ArgLS;
4669 for (
unsigned op = 0, Eop = CBI->arg_size();
op < Eop; ++
op) {
4671 writeParamOperand(CBI->getArgOperand(
op), PAL.getParamAttrs(
op));
4675 if (PAL.hasFnAttrs())
4676 Out <<
" #" <<
Machine.getAttributeGroupSlot(PAL.getFnAttrs());
4678 writeOperandBundles(CBI);
4681 writeOperand(CBI->getDefaultDest(),
true);
4683 ListSeparator DestLS;
4684 for (
const BasicBlock *Dest : CBI->getIndirectDests()) {
4686 writeOperand(Dest,
true);
4691 if (AI->isUsedWithInAlloca())
4693 if (AI->isSwiftError())
4694 Out <<
"swifterror ";
4695 TypePrinter.print(AI->getAllocatedType(), Out);
4701 if (!AI->getArraySize() || AI->isArrayAllocation() ||
4702 !AI->getArraySize()->getType()->isIntegerTy(32)) {
4704 writeOperand(AI->getArraySize(),
true);
4706 if (MaybeAlign
A = AI->getAlign()) {
4707 Out <<
", align " <<
A->value();
4710 unsigned AddrSpace = AI->getAddressSpace();
4712 Out <<
", addrspace(" << AddrSpace <<
')';
4716 writeOperand(Operand,
true);
4719 TypePrinter.print(
I.getType(), Out);
4723 writeOperand(Operand,
true);
4726 TypePrinter.print(
I.getType(), Out);
4727 }
else if (Operand) {
4730 TypePrinter.print(
GEP->getSourceElementType(), Out);
4734 TypePrinter.print(LI->getType(), Out);
4741 bool PrintAllTypes =
false;
4749 PrintAllTypes =
true;
4751 for (
unsigned i = 1,
E =
I.getNumOperands(); i !=
E; ++i) {
4752 Operand =
I.getOperand(i);
4755 if (Operand && Operand->
getType() != TheType) {
4756 PrintAllTypes =
true;
4762 if (!PrintAllTypes) {
4764 TypePrinter.print(TheType, Out);
4769 for (
const Value *
Op :
I.operands()) {
4771 writeOperand(
Op, PrintAllTypes);
4778 writeAtomic(LI->getContext(), LI->getOrdering(), LI->getSyncScopeID());
4779 if (MaybeAlign
A = LI->getAlign())
4780 Out <<
", align " <<
A->value();
4783 writeAtomic(
SI->getContext(),
SI->getOrdering(),
SI->getSyncScopeID());
4784 if (MaybeAlign
A =
SI->getAlign())
4785 Out <<
", align " <<
A->value();
4787 writeAtomicCmpXchg(CXI->getContext(), CXI->getSuccessOrdering(),
4788 CXI->getFailureOrdering(), CXI->getSyncScopeID());
4789 Out <<
", align " << CXI->getAlign().value();
4791 writeAtomic(RMWI->getContext(), RMWI->getOrdering(),
4792 RMWI->getSyncScopeID());
4793 Out <<
", align " << RMWI->getAlign().value();
4795 writeAtomic(FI->getContext(), FI->getOrdering(), FI->getSyncScopeID());
4803 printMetadataAttachments(InstMD,
", ");
4806 printInfoComment(
I);
4809void AssemblyWriter::printDbgMarker(
const DbgMarker &Marker) {
4813 printDbgRecord(DPR);
4817 Out <<
" DbgMarker -> { ";
4822void AssemblyWriter::printDbgRecord(
const DbgRecord &DR) {
4824 printDbgVariableRecord(*DVR);
4826 printDbgLabelRecord(*DLR);
4831void AssemblyWriter::printDbgVariableRecord(
const DbgVariableRecord &DVR) {
4835 case DbgVariableRecord::LocationType::Value:
4838 case DbgVariableRecord::LocationType::Declare:
4841 case DbgVariableRecord::LocationType::Assign:
4846 "Tried to print a DbgVariableRecord with an invalid LocationType!");
4877void AssemblyWriter::printDbgRecordLine(
const DbgRecord &DR) {
4884void AssemblyWriter::printDbgLabelRecord(
const DbgLabelRecord &Label) {
4886 Out <<
"#dbg_label(";
4893void AssemblyWriter::printMetadataAttachments(
4894 const SmallVectorImpl<std::pair<unsigned, MDNode *>> &MDs,
4895 StringRef Separator) {
4899 if (MDNames.empty())
4900 MDs[0].second->getContext().getMDKindNames(MDNames);
4903 for (
const auto &
I : MDs) {
4904 unsigned Kind =
I.first;
4906 if (Kind < MDNames.size()) {
4910 Out <<
"!<unknown kind #" <<
Kind <<
">";
4916void AssemblyWriter::writeMDNode(
unsigned Slot,
const MDNode *Node) {
4917 Out <<
'!' <<
Slot <<
" = ";
4918 printMDNodeBody(Node);
4922void AssemblyWriter::writeAllMDNodes() {
4928 for (
unsigned i = 0, e = Nodes.
size(); i != e; ++i) {
4929 writeMDNode(i, Nodes[i]);
4933void AssemblyWriter::printMDNodeBody(
const MDNode *Node) {
4938void AssemblyWriter::writeAttribute(
const Attribute &Attr,
bool InAttrGroup) {
4944 Out << Attribute::getNameFromAttrKind(Attr.
getKindAsEnum());
4947 TypePrinter.print(Ty, Out);
4952void AssemblyWriter::writeAttributeSet(
const AttributeSet &AttrSet,
4954 ListSeparator
LS(
" ");
4955 for (
const auto &Attr : AttrSet) {
4957 writeAttribute(Attr, InAttrGroup);
4961void AssemblyWriter::writeAllAttributeGroups() {
4962 std::vector<std::pair<AttributeSet, unsigned>> asVec;
4963 asVec.resize(
Machine.as_size());
4966 asVec[
I.second] =
I;
4968 for (
const auto &
I : asVec)
4969 Out <<
"attributes #" <<
I.second <<
" = { "
4970 <<
I.first.getAsString(
true) <<
" }\n";
4973void AssemblyWriter::printUseListOrder(
const Value *V,
4974 ArrayRef<unsigned> Shuffle) {
4979 Out <<
"uselistorder";
4982 writeOperand(BB->getParent(),
false);
4984 writeOperand(BB,
false);
4987 writeOperand(V,
true);
4990 assert(Shuffle.
size() >= 2 &&
"Shuffle too small");
4994void AssemblyWriter::printUseLists(
const Function *
F) {
4995 auto It = UseListOrders.find(
F);
4996 if (It == UseListOrders.end())
4999 Out <<
"\n; uselistorder directives\n";
5000 for (
const auto &Pair : It->second)
5001 printUseListOrder(Pair.first, Pair.second);
5009 bool ShouldPreserveUseListOrder,
5010 bool IsForDebug)
const {
5013 AssemblyWriter W(OS, SlotTable, this->
getParent(), AAW,
5015 ShouldPreserveUseListOrder);
5016 W.printFunction(
this);
5020 bool ShouldPreserveUseListOrder,
5021 bool IsForDebug)
const {
5024 AssemblyWriter W(OS, SlotTable, this->
getModule(), AAW,
5026 ShouldPreserveUseListOrder);
5027 W.printBasicBlock(
this);
5031 bool ShouldPreserveUseListOrder,
bool IsForDebug)
const {
5034 AssemblyWriter W(OS, SlotTable,
this, AAW, IsForDebug,
5035 ShouldPreserveUseListOrder);
5036 W.printModule(
this);
5042 AssemblyWriter W(OS, SlotTable,
getParent(),
nullptr, IsForDebug);
5043 W.printNamedMDNode(
this);
5047 bool IsForDebug)
const {
5048 std::optional<SlotTracker> LocalST;
5054 SlotTable = &*LocalST;
5058 AssemblyWriter W(OS, *SlotTable,
getParent(),
nullptr, IsForDebug);
5059 W.printNamedMDNode(
this);
5064 ROS <<
" = comdat ";
5071 ROS <<
"exactmatch";
5077 ROS <<
"nodeduplicate";
5089 TP.print(
const_cast<Type*
>(
this), OS);
5098 TP.printStructBody(STy, OS);
5104 if (
Function *
F = CI->getCalledFunction())
5105 if (
F->isIntrinsic())
5106 for (
auto &
Op :
I.operands())
5116 print(ROS, MST, IsForDebug);
5122 print(ROS, MST, IsForDebug);
5126 bool IsForDebug)
const {
5134 AssemblyWriter W(OS, SlotTable,
getModuleFromDPI(
this),
nullptr, IsForDebug);
5135 W.printDbgMarker(*
this);
5141 print(ROS, MST, IsForDebug);
5145 bool IsForDebug)
const {
5151 ?
Marker->getParent()->getParent()
5155 AssemblyWriter W(OS, SlotTable,
getModuleFromDPI(
this),
nullptr, IsForDebug);
5156 W.printDbgVariableRecord(*
this);
5160 bool IsForDebug)
const {
5166 Marker->getParent() ?
Marker->getParent()->getParent() :
nullptr;
5170 AssemblyWriter W(OS, SlotTable,
getModuleFromDPI(
this),
nullptr, IsForDebug);
5171 W.printDbgLabelRecord(*
this);
5175 bool ShouldInitializeAllMetadata =
false;
5179 ShouldInitializeAllMetadata =
true;
5182 print(ROS, MST, IsForDebug);
5186 bool IsForDebug)
const {
5191 auto IncorporateFunction = [&](
const Function *
F) {
5197 IncorporateFunction(
I->getParent() ?
I->getParent()->getParent() :
nullptr);
5199 W.printInstruction(*
I);
5201 IncorporateFunction(BB->getParent());
5202 AssemblyWriter W(OS, SlotTable,
getModuleFromVal(BB),
nullptr, IsForDebug);
5203 W.printBasicBlock(BB);
5205 AssemblyWriter W(OS, SlotTable, GV->
getParent(),
nullptr, IsForDebug);
5219 TypePrinting TypePrinter;
5220 TypePrinter.print(
C->getType(), OS);
5222 AsmWriterContext WriterCtx(&TypePrinter, MST.
getMachine());
5238 AsmWriterContext WriterCtx(
nullptr,
Machine, M);
5247 TypePrinting TypePrinter(MST.
getModule());
5278 AsmWriterContext &WriterCtx) {
5291struct MDTreeAsmWriterContext :
public AsmWriterContext {
5294 using EntryTy = std::pair<unsigned, std::string>;
5298 SmallPtrSet<const Metadata *, 4> Visited;
5300 raw_ostream &MainOS;
5302 MDTreeAsmWriterContext(TypePrinting *TP, SlotTracker *ST,
const Module *M,
5303 raw_ostream &OS,
const Metadata *InitMD)
5304 : AsmWriterContext(TP,
ST,
M),
Level(0
U), Visited({InitMD}), MainOS(OS) {}
5306 void onWriteMetadataAsOperand(
const Metadata *MD)
override {
5307 if (!Visited.
insert(MD).second)
5311 raw_string_ostream
SS(Str);
5316 unsigned InsertIdx = Buffer.
size() - 1;
5319 Buffer[InsertIdx].second = std::move(
SS.str());
5323 ~MDTreeAsmWriterContext()
override {
5324 for (
const auto &Entry : Buffer) {
5326 unsigned NumIndent =
Entry.first * 2U;
5335 bool OnlyAsOperand,
bool PrintAsTree =
false) {
5338 TypePrinting TypePrinter(M);
5340 std::unique_ptr<AsmWriterContext> WriterCtx;
5341 if (PrintAsTree && !OnlyAsOperand)
5342 WriterCtx = std::make_unique<MDTreeAsmWriterContext>(
5346 std::make_unique<AsmWriterContext>(&TypePrinter, MST.
getMachine(), M);
5375 const Module *M,
bool )
const {
5394 AssemblyWriter W(OS, SlotTable,
this, IsForDebug);
5395 W.printModuleSummaryIndex();
5399 unsigned UB)
const {
5405 if (
I.second >= LB &&
I.second < UB)
5406 L.push_back(std::make_pair(
I.second,
I.first));
5409#if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP)
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
This file declares a class to represent arbitrary precision floating point values and provide a varie...
This file implements a class to represent arbitrary precision integral constant values and operations...
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
static void print(raw_ostream &Out, object::Archive::Kind Kind, T Val)
static void writeDIMacro(raw_ostream &Out, const DIMacro *N, AsmWriterContext &WriterCtx)
static void writeMetadataAsOperand(raw_ostream &Out, const Metadata *MD, AsmWriterContext &WriterCtx)
static void writeDIGlobalVariableExpression(raw_ostream &Out, const DIGlobalVariableExpression *N, AsmWriterContext &WriterCtx)
static void writeDICompositeType(raw_ostream &Out, const DICompositeType *N, AsmWriterContext &WriterCtx)
static void writeDIFixedPointType(raw_ostream &Out, const DIFixedPointType *N, AsmWriterContext &WriterCtx)
static void printDSOLocation(const GlobalValue &GV, formatted_raw_ostream &Out)
static const char * getWholeProgDevirtResKindName(WholeProgramDevirtResolution::Kind K)
static void writeDISubrangeType(raw_ostream &Out, const DISubrangeType *N, AsmWriterContext &WriterCtx)
static void writeAPFloatInternal(raw_ostream &Out, const APFloat &APF)
static void printMetadataImpl(raw_ostream &ROS, const Metadata &MD, ModuleSlotTracker &MST, const Module *M, bool OnlyAsOperand, bool PrintAsTree=false)
static void writeDIStringType(raw_ostream &Out, const DIStringType *N, AsmWriterContext &WriterCtx)
static std::string getLinkageNameWithSpace(GlobalValue::LinkageTypes LT)
static cl::opt< bool > PreserveAssemblyUseListOrder("preserve-ll-uselistorder", cl::Hidden, cl::init(false), cl::desc("Preserve use-list order when writing LLVM assembly."))
static std::vector< unsigned > predictValueUseListOrder(const Value *V, unsigned ID, const OrderMap &OM)
static void writeDIGlobalVariable(raw_ostream &Out, const DIGlobalVariable *N, AsmWriterContext &WriterCtx)
static void orderValue(const Value *V, OrderMap &OM)
static void writeDIBasicType(raw_ostream &Out, const DIBasicType *N, AsmWriterContext &WriterCtx)
static StringRef getUnnamedAddrEncoding(GlobalVariable::UnnamedAddr UA)
static const char * getWholeProgDevirtResByArgKindName(WholeProgramDevirtResolution::ByArg::Kind K)
static void writeMDNodeBodyInternal(raw_ostream &Out, const MDNode *Node, AsmWriterContext &Ctx)
static void writeDIModule(raw_ostream &Out, const DIModule *N, AsmWriterContext &WriterCtx)
static void writeDIFile(raw_ostream &Out, const DIFile *N, AsmWriterContext &)
static void writeDISubroutineType(raw_ostream &Out, const DISubroutineType *N, AsmWriterContext &WriterCtx)
static void writeOptimizationInfo(raw_ostream &Out, const User *U)
static bool isReferencingMDNode(const Instruction &I)
#define CC_VLS_CASE(ABI_VLEN)
static void writeDILabel(raw_ostream &Out, const DILabel *N, AsmWriterContext &WriterCtx)
static void writeDIDerivedType(raw_ostream &Out, const DIDerivedType *N, AsmWriterContext &WriterCtx)
static void printMetadataIdentifier(StringRef Name, formatted_raw_ostream &Out)
static void printShuffleMask(raw_ostream &Out, Type *Ty, ArrayRef< int > Mask)
static void writeDIImportedEntity(raw_ostream &Out, const DIImportedEntity *N, AsmWriterContext &WriterCtx)
static const Module * getModuleFromDPI(const DbgMarker *Marker)
static void printAsOperandImpl(const Value &V, raw_ostream &O, bool PrintType, ModuleSlotTracker &MST)
static void writeDIObjCProperty(raw_ostream &Out, const DIObjCProperty *N, AsmWriterContext &WriterCtx)
static void writeDISubprogram(raw_ostream &Out, const DISubprogram *N, AsmWriterContext &WriterCtx)
static const char * getSummaryKindName(GlobalValueSummary::SummaryKind SK)
static OrderMap orderModule(const Module *M)
static const char * getVisibilityName(GlobalValue::VisibilityTypes Vis)
static void printCallingConv(unsigned cc, raw_ostream &Out)
static cl::opt< bool > PrintInstDebugLocs("print-inst-debug-locs", cl::Hidden, cl::desc("Pretty print debug locations of instructions when dumping"))
static void printMetadataImplRec(raw_ostream &ROS, const Metadata &MD, AsmWriterContext &WriterCtx)
Recursive version of printMetadataImpl.
static SlotTracker * createSlotTracker(const Value *V)
static void writeDILocation(raw_ostream &Out, const DILocation *DL, AsmWriterContext &WriterCtx)
static void writeDINamespace(raw_ostream &Out, const DINamespace *N, AsmWriterContext &WriterCtx)
DenseMap< const Function *, MapVector< const Value *, std::vector< unsigned > > > UseListOrderMap
static void writeDICommonBlock(raw_ostream &Out, const DICommonBlock *N, AsmWriterContext &WriterCtx)
static UseListOrderMap predictUseListOrder(const Module *M)
static void printThreadLocalModel(GlobalVariable::ThreadLocalMode TLM, formatted_raw_ostream &Out)
static std::string getLinkageName(GlobalValue::LinkageTypes LT)
static void writeGenericDINode(raw_ostream &Out, const GenericDINode *N, AsmWriterContext &WriterCtx)
static void writeDILocalVariable(raw_ostream &Out, const DILocalVariable *N, AsmWriterContext &WriterCtx)
static const char * getTTResKindName(TypeTestResolution::Kind K)
static void writeDITemplateTypeParameter(raw_ostream &Out, const DITemplateTypeParameter *N, AsmWriterContext &WriterCtx)
static const char * getImportTypeName(GlobalValueSummary::ImportKind IK)
static void writeDICompileUnit(raw_ostream &Out, const DICompileUnit *N, AsmWriterContext &WriterCtx)
static const Module * getModuleFromVal(const Value *V)
static void printLLVMName(raw_ostream &OS, StringRef Name, PrefixType Prefix)
Turn the specified name into an 'LLVM name', which is either prefixed with % (if the string only cont...
static void maybePrintCallAddrSpace(const Value *Operand, const Instruction *I, raw_ostream &Out)
static void writeDIGenericSubrange(raw_ostream &Out, const DIGenericSubrange *N, AsmWriterContext &WriterCtx)
static void writeDISubrange(raw_ostream &Out, const DISubrange *N, AsmWriterContext &WriterCtx)
static void writeDILexicalBlockFile(raw_ostream &Out, const DILexicalBlockFile *N, AsmWriterContext &WriterCtx)
static void writeConstantInternal(raw_ostream &Out, const Constant *CV, AsmWriterContext &WriterCtx)
static void writeDIEnumerator(raw_ostream &Out, const DIEnumerator *N, AsmWriterContext &)
static void writeAsOperandInternal(raw_ostream &Out, const Value *V, AsmWriterContext &WriterCtx, bool PrintType=false)
static void printVisibility(GlobalValue::VisibilityTypes Vis, formatted_raw_ostream &Out)
static cl::opt< bool > PrintProfData("print-prof-data", cl::Hidden, cl::desc("Pretty print perf data (branch weights, etc) when dumping"))
static void writeMDTuple(raw_ostream &Out, const MDTuple *Node, AsmWriterContext &WriterCtx)
static void writeDIExpression(raw_ostream &Out, const DIExpression *N, AsmWriterContext &WriterCtx)
static cl::opt< bool > PrintInstAddrs("print-inst-addrs", cl::Hidden, cl::desc("Print addresses of instructions when dumping"))
static void writeDIAssignID(raw_ostream &Out, const DIAssignID *DL, AsmWriterContext &WriterCtx)
static void writeDILexicalBlock(raw_ostream &Out, const DILexicalBlock *N, AsmWriterContext &WriterCtx)
static void maybePrintComdat(formatted_raw_ostream &Out, const GlobalObject &GO)
static void printDLLStorageClass(GlobalValue::DLLStorageClassTypes SCT, formatted_raw_ostream &Out)
static bool printWithoutType(const Value &V, raw_ostream &O, SlotTracker *Machine, const Module *M)
Print without a type, skipping the TypePrinting object.
static void writeDIArgList(raw_ostream &Out, const DIArgList *N, AsmWriterContext &WriterCtx, bool FromValue=false)
static void writeDITemplateValueParameter(raw_ostream &Out, const DITemplateValueParameter *N, AsmWriterContext &WriterCtx)
static const Value * skipMetadataWrapper(const Value *V)
Look for a value that might be wrapped as metadata, e.g.
static void writeDIMacroFile(raw_ostream &Out, const DIMacroFile *N, AsmWriterContext &WriterCtx)
Atomic ordering constants.
This file contains the simple types necessary to represent the attributes associated with functions a...
static const Function * getParent(const Value *V)
static GCRegistry::Add< ErlangGC > A("erlang", "erlang-compatible garbage collector")
static GCRegistry::Add< CoreCLRGC > E("coreclr", "CoreCLR-compatible GC")
#define LLVM_DUMP_METHOD
Mark debug helper function definitions like dump() that should not be stripped from debug builds.
This file contains the declarations for the subclasses of Constant, which represent the different fla...
dxil pretty DXIL Metadata Pretty Printer
This file defines the DenseMap class.
This file contains constants used for implementing Dwarf debug support.
This file contains the declaration of the GlobalIFunc class, which represents a single indirect funct...
GlobalValue::SanitizerMetadata SanitizerMetadata
This file provides various utilities for inspecting and working with the control flow graph in LLVM I...
This file contains an interface for creating legacy passes to print out IR in various granularities.
Module.h This file contains the declarations for the Module class.
This defines the Use class.
Machine Check Debug Module
static bool InRange(int64_t Value, unsigned short Shift, int LBound, int HBound)
ModuleSummaryIndex.h This file contains the declarations the classes that hold the module index and s...
static bool processFunction(Function &F, NVPTXTargetMachine &TM)
ConstantRange Range(APInt(BitWidth, Low), APInt(BitWidth, High))
uint64_t IntrinsicInst * II
Function const char TargetMachine * Machine
if(auto Err=PB.parsePassPipeline(MPM, Passes)) return wrap(std MPM run * Mod
static StringRef getName(Value *V)
This file provides utility classes that use RAII to save and restore values.
This file implements a set that has insertion order iteration characteristics.
This file defines the SmallPtrSet class.
This file defines the SmallString class.
This file defines the SmallVector class.
LocallyHashedType DenseMapInfo< LocallyHashedType >::Empty
static UseListOrderStack predictUseListOrder(const Module &M)
static const fltSemantics & IEEEsingle()
static const fltSemantics & BFloat()
static const fltSemantics & IEEEquad()
static const fltSemantics & IEEEdouble()
static const fltSemantics & x87DoubleExtended()
static constexpr roundingMode rmNearestTiesToEven
static const fltSemantics & IEEEhalf()
static const fltSemantics & PPCDoubleDouble()
static APFloat getSNaN(const fltSemantics &Sem, bool Negative=false, const APInt *payload=nullptr)
Factory for SNaN values.
LLVM_ABI opStatus convert(const fltSemantics &ToSemantics, roundingMode RM, bool *losesInfo)
LLVM_ABI double convertToDouble() const
Converts this APFloat to host double value.
void toString(SmallVectorImpl< char > &Str, unsigned FormatPrecision=0, unsigned FormatMaxPadding=3, bool TruncateZero=true) const
const fltSemantics & getSemantics() const
APInt bitcastToAPInt() const
Class for arbitrary precision integers.
LLVM_ABI APInt getLoBits(unsigned numBits) const
Compute an APInt containing numBits lowbits from this APInt.
uint64_t getZExtValue() const
Get zero extended value.
LLVM_ABI APInt getHiBits(unsigned numBits) const
Compute an APInt containing numBits highbits from this APInt.
Abstract interface of slot tracker storage.
virtual ~AbstractSlotTrackerStorage()
const GlobalValueSummary & getAliasee() const
This class represents an incoming formal argument to a Function.
ArrayRef - Represent a constant reference to an array (0 or more elements consecutively in memory),...
size_t size() const
size - Get the array size.
virtual void emitBasicBlockStartAnnot(const BasicBlock *, formatted_raw_ostream &)
emitBasicBlockStartAnnot - This may be implemented to emit a string right after the basic block label...
virtual void emitBasicBlockEndAnnot(const BasicBlock *, formatted_raw_ostream &)
emitBasicBlockEndAnnot - This may be implemented to emit a string right after the basic block.
virtual void emitFunctionAnnot(const Function *, formatted_raw_ostream &)
emitFunctionAnnot - This may be implemented to emit a string right before the start of a function.
virtual void emitInstructionAnnot(const Instruction *, formatted_raw_ostream &)
emitInstructionAnnot - This may be implemented to emit a string right before an instruction is emitte...
virtual void printInfoComment(const Value &, formatted_raw_ostream &)
printInfoComment - This may be implemented to emit a comment to the right of an instruction or global...
virtual ~AssemblyAnnotationWriter()
static LLVM_ABI StringRef getOperationName(BinOp Op)
This class holds the attributes for a particular argument, parameter, function, or return value.
bool hasAttributes() const
Return true if attributes exists in this set.
LLVM_ABI std::string getAsString(bool InAttrGrp=false) const
The Attribute is converted to a string of equivalent mnemonic.
LLVM_ABI Attribute::AttrKind getKindAsEnum() const
Return the attribute's kind as an enum (Attribute::AttrKind).
LLVM_ABI bool isTypeAttribute() const
Return true if the attribute is a type attribute.
LLVM_ABI Type * getValueAsType() const
Return the attribute's value as a Type.
LLVM Basic Block Representation.
const Function * getParent() const
Return the enclosing method, or null if none.
LLVM_ABI void print(raw_ostream &OS, AssemblyAnnotationWriter *AAW=nullptr, bool ShouldPreserveUseListOrder=false, bool IsForDebug=false) const
Print the basic block to an output stream with an optional AssemblyAnnotationWriter.
LLVM_ABI bool isEntryBlock() const
Return true if this is the entry block of the containing function.
LLVM_ABI const Module * getModule() const
Return the module owning the function this basic block belongs to, or nullptr if the function does no...
OperandBundleUse getOperandBundleAt(unsigned Index) const
Return the operand bundle at a specific index.
unsigned getNumOperandBundles() const
Return the number of operand bundles associated with this User.
AttributeList getAttributes() const
Return the attributes for this call.
bool hasOperandBundles() const
Return true if this User has any operand bundles.
LLVM_ABI void print(raw_ostream &OS, bool IsForDebug=false) const
LLVM_ABI void dump() const
@ Largest
The linker will choose the largest COMDAT.
@ SameSize
The data referenced by the COMDAT must be the same size.
@ Any
The linker may choose any COMDAT.
@ NoDeduplicate
No deduplication is performed.
@ ExactMatch
The data referenced by the COMDAT must be the same.
SelectionKind getSelectionKind() const
LLVM_ABI APInt getSignedMin() const
Return the smallest signed value contained in the ConstantRange.
LLVM_ABI APInt getSignedMax() const
Return the largest signed value contained in the ConstantRange.
This is an important base class in LLVM.
LLVM_ABI Constant * getSplatValue(bool AllowPoison=false) const
If all elements of the vector constant have the same value, return that value.
LLVM_ABI Constant * getAggregateElement(unsigned Elt) const
For aggregates (struct/array/vector) return the constant that corresponds to the specified element if...
List of ValueAsMetadata, to be used as an argument to a dbg.value intrinsic.
Basic type, like 'int' or 'float'.
static LLVM_ABI const char * nameTableKindString(DebugNameTableKind PK)
static LLVM_ABI const char * emissionKindString(DebugEmissionKind EK)
A lightweight wrapper around an expression operand.
static LLVM_ABI const char * fixedPointKindString(FixedPointKind)
A pair of DIGlobalVariable and DIExpression.
An imported module (C++ using directive or similar).
Macro Info DWARF-like metadata node.
Represents a module in the programming language, for example, a Clang module, or a Fortran module.
Tagged DWARF-like metadata node.
static LLVM_ABI DIFlags splitFlags(DIFlags Flags, SmallVectorImpl< DIFlags > &SplitFlags)
Split up a flags bitfield.
static LLVM_ABI StringRef getFlagString(DIFlags Flag)
Wrapper structure that holds a language name and its version.
uint32_t getVersion() const
Returns language version. Only valid for versioned language names.
bool hasVersionedName() const
uint16_t getName() const
Returns a versioned or unversioned language name.
String type, Fortran CHARACTER(n)
Subprogram description. Uses SubclassData1.
static LLVM_ABI DISPFlags splitFlags(DISPFlags Flags, SmallVectorImpl< DISPFlags > &SplitFlags)
Split up a flags bitfield for easier printing.
static LLVM_ABI StringRef getFlagString(DISPFlags Flag)
DISPFlags
Debug info subprogram flags.
Type array for a subprogram.
LLVM_ABI void print(raw_ostream &O, bool IsForDebug=false) const
Per-instruction record of debug-info.
LLVM_ABI void dump() const
Instruction * MarkedInstr
Link back to the Instruction that owns this marker.
LLVM_ABI void print(raw_ostream &O, bool IsForDebug=false) const
Implement operator<< on DbgMarker.
LLVM_ABI const BasicBlock * getParent() const
simple_ilist< DbgRecord > StoredDbgRecords
List of DbgRecords, the non-instruction equivalent of llvm.dbg.
Base class for non-instruction debug metadata records that have positions within IR.
DebugLoc getDebugLoc() const
LLVM_ABI void dump() const
DbgMarker * Marker
Marker that this DbgRecord is linked into.
Record of a variable value-assignment, aka a non instruction representation of the dbg....
LocationType getType() const
LLVM_ABI void print(raw_ostream &O, bool IsForDebug=false) const
MDNode * getRawExpression() const
MDNode * getRawAddressExpression() const
Metadata * getRawAssignID() const
MDNode * getRawVariable() const
Metadata * getRawLocation() const
Returns the metadata operand for the first location description.
Metadata * getRawAddress() const
MDNode * getAsMDNode() const
Return this as a bar MDNode.
DenseMapIterator< KeyT, ValueT, KeyInfoT, BucketT > iterator
void print(raw_ostream &OS, AssemblyAnnotationWriter *AAW=nullptr, bool ShouldPreserveUseListOrder=false, bool IsForDebug=false) const
Print the function to an output stream with an optional AssemblyAnnotationWriter.
const Function & getFunction() const
const Argument * const_arg_iterator
LLVM_ABI Value * getBasePtr() const
LLVM_ABI Value * getDerivedPtr() const
Generic tagged DWARF-like metadata node.
const Constant * getAliasee() const
const Constant * getResolver() const
StringRef getSection() const
Get the custom section of this global if it has one.
LLVM_ABI void getAllMetadata(SmallVectorImpl< std::pair< unsigned, MDNode * > > &MDs) const
Appends all metadata attached to this value to MDs, sorting by KindID.
const Comdat * getComdat() const
bool hasSection() const
Check if this global has a custom object file section.
SummaryKind
Sububclass discriminator (for dyn_cast<> et al.)
bool hasPartition() const
static LLVM_ABI GUID getGUIDAssumingExternalLinkage(StringRef GlobalName)
Return a 64-bit global unique ID constructed from the name of a global symbol.
LLVM_ABI const SanitizerMetadata & getSanitizerMetadata() const
bool hasExternalLinkage() const
VisibilityTypes getVisibility() const
bool isImplicitDSOLocal() const
LinkageTypes getLinkage() const
uint64_t GUID
Declare a type to represent a global unique identifier for a global value.
ThreadLocalMode getThreadLocalMode() const
DLLStorageClassTypes
Storage classes of global values for PE targets.
@ DLLExportStorageClass
Function to be accessible from DLL.
@ DLLImportStorageClass
Function to be imported from DLL.
bool hasSanitizerMetadata() const
LLVM_ABI StringRef getPartition() const
Module * getParent()
Get the module that this global value is contained inside of...
PointerType * getType() const
Global values are always pointers.
VisibilityTypes
An enumeration for the kinds of visibility of global values.
@ DefaultVisibility
The GV is visible.
@ HiddenVisibility
The GV is hidden.
@ ProtectedVisibility
The GV is protected.
LLVM_ABI bool isMaterializable() const
If this function's Module is being lazily streamed in functions from disk or some other source,...
UnnamedAddr getUnnamedAddr() const
LinkageTypes
An enumeration for the kinds of linkage for global values.
@ PrivateLinkage
Like Internal, but omit from symbol table.
@ CommonLinkage
Tentative definitions.
@ InternalLinkage
Rename collisions when linking (static functions).
@ LinkOnceAnyLinkage
Keep one copy of function when linking (inline)
@ WeakODRLinkage
Same, but only replaced by something equivalent.
@ ExternalLinkage
Externally visible function.
@ WeakAnyLinkage
Keep one copy of named function when linking (weak)
@ AppendingLinkage
Special purpose, only applies to global arrays.
@ AvailableExternallyLinkage
Available for inspection, not emission.
@ ExternalWeakLinkage
ExternalWeak linkage description.
@ LinkOnceODRLinkage
Same, but only replaced by something equivalent.
DLLStorageClassTypes getDLLStorageClass() const
Type * getValueType() const
const Constant * getInitializer() const
getInitializer - Return the initializer for this global variable.
bool isExternallyInitialized() const
bool hasInitializer() const
Definitions have initializers, declarations don't.
AttributeSet getAttributes() const
Return the attribute set for this global.
std::optional< CodeModel::Model > getCodeModel() const
Get the custom code model of this global if it has one.
MaybeAlign getAlign() const
Returns the alignment of the given variable.
bool isConstant() const
If the value is a global constant, its value is immutable throughout the runtime execution of the pro...
A helper class to return the specified delimiter string after the first invocation of operator String...
LLVM_ABI void printTree(raw_ostream &OS, const Module *M=nullptr) const
Print in tree shape.
LLVM_ABI void dumpTree() const
User-friendly dump in tree shape.
This class implements a map that also provides access to all stored values in a deterministic order.
Manage lifetime of a slot tracker for printing IR.
const Module * getModule() const
ModuleSlotTracker(SlotTracker &Machine, const Module *M, const Function *F=nullptr)
Wrap a preinitialized SlotTracker.
virtual ~ModuleSlotTracker()
Destructor to clean up storage.
std::vector< std::pair< unsigned, const MDNode * > > MachineMDNodeListType
int getLocalSlot(const Value *V)
Return the slot number of the specified local value.
void collectMDNodes(MachineMDNodeListType &L, unsigned LB, unsigned UB) const
SlotTracker * getMachine()
Lazily creates a slot tracker.
void setProcessHook(std::function< void(AbstractSlotTrackerStorage *, const Module *, bool)>)
void incorporateFunction(const Function &F)
Incorporate the given function.
Class to hold module path string table and global value map, and encapsulate methods for operating on...
static constexpr const char * getRegularLTOModuleName()
LLVM_ABI void dump() const
Dump to stderr (for debugging).
LLVM_ABI void print(raw_ostream &OS, bool IsForDebug=false) const
Print to an output stream.
A Module instance is used to store all the information related to an LLVM module.
iterator_range< alias_iterator > aliases()
iterator_range< global_iterator > globals()
void print(raw_ostream &OS, AssemblyAnnotationWriter *AAW, bool ShouldPreserveUseListOrder=false, bool IsForDebug=false) const
Print the module to an output stream with an optional AssemblyAnnotationWriter.
void dump() const
Dump the module to stderr (for debugging).
LLVM_ABI void dump() const
LLVM_ABI StringRef getName() const
LLVM_ABI void print(raw_ostream &ROS, bool IsForDebug=false) const
iterator_range< op_iterator > operands()
unsigned getAddressSpace() const
Return the address space of the Pointer type.
This class provides computation of slot numbers for LLVM Assembly writing.
DenseMap< const Value *, unsigned > ValueMap
ValueMap - A mapping of Values to slot numbers.
int getMetadataSlot(const MDNode *N) override
getMetadataSlot - Get the slot number of a MDNode.
~SlotTracker() override=default
int getTypeIdCompatibleVtableSlot(StringRef Id)
int getModulePathSlot(StringRef Path)
unsigned mdn_size() const
SlotTracker(const SlotTracker &)=delete
void purgeFunction()
After calling incorporateFunction, use this method to remove the most recently incorporated function ...
int getTypeIdSlot(StringRef Id)
void initializeIfNeeded()
These functions do the actual initialization.
int getGlobalSlot(const GlobalValue *V)
getGlobalSlot - Get the slot number of a global value.
const Function * getFunction() const
unsigned getNextMetadataSlot() override
DenseMap< GlobalValue::GUID, unsigned >::iterator guid_iterator
GUID map iterators.
void incorporateFunction(const Function *F)
If you'd like to deal with a function instead of just a module, use this method to get its data into ...
int getLocalSlot(const Value *V)
Return the slot number of the specified value in it's type plane.
int getAttributeGroupSlot(AttributeSet AS)
SlotTracker(const Module *M, bool ShouldInitializeAllMetadata=false)
Construct from a module.
void createMetadataSlot(const MDNode *N) override
getMetadataSlot - Get the slot number of a MDNode.
void setProcessHook(std::function< void(AbstractSlotTrackerStorage *, const Module *, bool)>)
DenseMap< const MDNode *, unsigned >::iterator mdn_iterator
MDNode map iterators.
SlotTracker & operator=(const SlotTracker &)=delete
int getGUIDSlot(GlobalValue::GUID GUID)
int initializeIndexIfNeeded()
DenseMap< AttributeSet, unsigned >::iterator as_iterator
AttributeSet map iterators.
std::pair< iterator, bool > insert(PtrType Ptr)
Inserts Ptr if and only if there is no element in the container equal to Ptr.
SmallString - A SmallString is just a SmallVector with methods and accessors that make it work better...
reference emplace_back(ArgTypes &&... Args)
void push_back(const T &Elt)
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
StringMap - This is an unconventional map that is specialized for handling keys that are "strings",...
StringRef - Represent a constant reference to a string, i.e.
constexpr bool empty() const
empty - Check if the string is empty.
ArrayRef< Type * > elements() const
unsigned getNumElements() const
Random access to the elements.
bool isLiteral() const
Return true if this type is uniqued by structural equivalence, false if it is a struct definition.
bool isOpaque() const
Return true if this is a type with an identity that has no body specified yet.
LLVM_ABI StringRef getName() const
Return the name for this struct type if it has an identity.
ArrayRef< Type * > type_params() const
Return the type parameters for this particular target extension type.
ArrayRef< unsigned > int_params() const
Return the integer parameters for this particular target extension type.
TypeFinder - Walk over a module, identifying all of the types that are used by the module.
void run(const Module &M, bool onlyNamed)
The instances of the Type class are immutable: once they are created, they are never changed.
LLVM_ABI unsigned getPointerAddressSpace() const
Get the address space of this pointer or pointer vector type.
LLVM_ABI StringRef getTargetExtName() const
Type(LLVMContext &C, TypeID tid)
LLVM_ABI void dump() const
LLVM_ABI void print(raw_ostream &O, bool IsForDebug=false, bool NoDetails=false) const
Print the current type.
TypeID getTypeID() const
Return the type id for the type.
Type * getElementType() const
unsigned getAddressSpace() const
Return the address space of the Pointer type.
A Use represents the edge between a Value definition and its users.
LLVM Value Representation.
Type * getType() const
All values are typed, get the type of this value.
LLVM_ABI void print(raw_ostream &O, bool IsForDebug=false) const
Implement operator<< on Value.
LLVM_ABI void getAllMetadata(SmallVectorImpl< std::pair< unsigned, MDNode * > > &MDs) const
Appends all metadata attached to this value to MDs, sorting by KindID.
iterator_range< user_iterator > users()
LLVM_ABI void printAsOperand(raw_ostream &O, bool PrintType=true, const Module *M=nullptr) const
Print the name of this Value out to the specified raw_ostream.
iterator_range< use_iterator > uses()
LLVM_ABI StringRef getName() const
Return a constant reference to the value's name.
LLVM_ABI void dump() const
Support for debugging, callable in GDB: V->dump()
This class implements an extremely fast bulk output stream that can only output to a stream.
raw_ostream & indent(unsigned NumSpaces)
indent - Insert 'NumSpaces' spaces.
LLVM_ABI StringRef SourceLanguageNameString(SourceLanguageName Lang)
LLVM_ABI StringRef EnumKindString(unsigned EnumKind)
LLVM_ABI StringRef LanguageString(unsigned Language)
LLVM_ABI StringRef AttributeEncodingString(unsigned Encoding)
LLVM_ABI StringRef ConventionString(unsigned Convention)
LLVM_ABI StringRef MacinfoString(unsigned Encoding)
LLVM_ABI StringRef OperationEncodingString(unsigned Encoding)
LLVM_ABI StringRef TagString(unsigned Tag)
This provides a very simple, boring adaptor for a begin and end iterator into a range type.
This file contains the declaration of the Comdat class, which represents a single COMDAT in LLVM.
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
constexpr char Attrs[]
Key for Kernel::Metadata::mAttrs.
unsigned ID
LLVM IR allows to use arbitrary numbers as calling convention identifiers.
@ AArch64_VectorCall
Used between AArch64 Advanced SIMD functions.
@ X86_64_SysV
The C convention as specified in the x86-64 supplement to the System V ABI, used on most non-Windows ...
@ RISCV_VectorCall
Calling convention used for RISC-V V-extension.
@ AMDGPU_CS
Used for Mesa/AMDPAL compute shaders.
@ AMDGPU_VS
Used for Mesa vertex shaders, or AMDPAL last shader stage before rasterization (vertex shader if tess...
@ AVR_SIGNAL
Used for AVR signal routines.
@ Swift
Calling convention for Swift.
@ AMDGPU_KERNEL
Used for AMDGPU code object kernels.
@ AArch64_SVE_VectorCall
Used between AArch64 SVE functions.
@ ARM_APCS
ARM Procedure Calling Standard (obsolete, but still used on some targets).
@ CHERIoT_CompartmentCall
Calling convention used for CHERIoT when crossing a protection boundary.
@ CFGuard_Check
Special calling convention on Windows for calling the Control Guard Check ICall funtion.
@ AVR_INTR
Used for AVR interrupt routines.
@ PreserveMost
Used for runtime calls that preserves most registers.
@ AnyReg
OBSOLETED - Used for stack based JavaScript calls.
@ AMDGPU_Gfx
Used for AMD graphics targets.
@ DUMMY_HHVM
Placeholders for HHVM calling conventions (deprecated, removed).
@ AMDGPU_CS_ChainPreserve
Used on AMDGPUs to give the middle-end more control over argument placement.
@ AMDGPU_HS
Used for Mesa/AMDPAL hull shaders (= tessellation control shaders).
@ ARM_AAPCS
ARM Architecture Procedure Calling Standard calling convention (aka EABI).
@ CHERIoT_CompartmentCallee
Calling convention used for the callee of CHERIoT_CompartmentCall.
@ AMDGPU_GS
Used for Mesa/AMDPAL geometry shaders.
@ AArch64_SME_ABI_Support_Routines_PreserveMost_From_X2
Preserve X2-X15, X19-X29, SP, Z0-Z31, P0-P15.
@ CHERIoT_LibraryCall
Calling convention used for CHERIoT for cross-library calls to a stateless compartment.
@ CXX_FAST_TLS
Used for access functions.
@ X86_INTR
x86 hardware interrupt context.
@ AArch64_SME_ABI_Support_Routines_PreserveMost_From_X0
Preserve X0-X13, X19-X29, SP, Z0-Z31, P0-P15.
@ AMDGPU_CS_Chain
Used on AMDGPUs to give the middle-end more control over argument placement.
@ GHC
Used by the Glasgow Haskell Compiler (GHC).
@ AMDGPU_PS
Used for Mesa/AMDPAL pixel shaders.
@ Cold
Attempts to make code in the caller as efficient as possible under the assumption that the call is no...
@ AArch64_SME_ABI_Support_Routines_PreserveMost_From_X1
Preserve X1-X15, X19-X29, SP, Z0-Z31, P0-P15.
@ X86_ThisCall
Similar to X86_StdCall.
@ PTX_Device
Call to a PTX device function.
@ SPIR_KERNEL
Used for SPIR kernel functions.
@ PreserveAll
Used for runtime calls that preserves (almost) all registers.
@ X86_StdCall
stdcall is mostly used by the Win32 API.
@ SPIR_FUNC
Used for SPIR non-kernel device functions.
@ Fast
Attempts to make calls as fast as possible (e.g.
@ MSP430_INTR
Used for MSP430 interrupt routines.
@ X86_VectorCall
MSVC calling convention that passes vectors and vector aggregates in SSE registers.
@ Intel_OCL_BI
Used for Intel OpenCL built-ins.
@ PreserveNone
Used for runtime calls that preserves none general registers.
@ AMDGPU_ES
Used for AMDPAL shader stage before geometry shader if geometry is in use.
@ Tail
Attemps to make calls as fast as possible while guaranteeing that tail call optimization can always b...
@ Win64
The C convention as implemented on Windows/x86-64 and AArch64.
@ PTX_Kernel
Call to a PTX kernel. Passes all arguments in parameter space.
@ SwiftTail
This follows the Swift calling convention in how arguments are passed but guarantees tail calls will ...
@ GRAAL
Used by GraalVM. Two additional registers are reserved.
@ AMDGPU_LS
Used for AMDPAL vertex shader if tessellation is in use.
@ ARM_AAPCS_VFP
Same as ARM_AAPCS, but uses hard floating point ABI.
@ X86_RegCall
Register calling convention used for parameters transfer optimization.
@ M68k_RTD
Used for M68k rtd-based CC (similar to X86's stdcall).
@ C
The default llvm calling convention, compatible with C.
@ X86_FastCall
'fast' analog of X86_StdCall.
@ System
Synchronized with respect to all concurrently executing threads.
initializer< Ty > init(const Ty &Val)
@ DW_OP_LLVM_convert
Only used in LLVM metadata.
Context & getContext() const
This is an optimization pass for GlobalISel generic memory operations.
void dump(const SparseBitVector< ElementSize > &LHS, raw_ostream &out)
FunctionAddr VTableAddr Value
bool all_of(R &&range, UnaryPredicate P)
Provide wrappers to std::all_of which take ranges instead of having to pass begin/end explicitly.
Printable print(const GCNRegPressure &RP, const GCNSubtarget *ST=nullptr, unsigned DynamicVGPRBlockSize=0)
detail::zippy< detail::zip_first, T, U, Args... > zip_equal(T &&t, U &&u, Args &&...args)
zip iterator that assumes that all iteratees have the same length.
InterleavedRange< Range > interleaved(const Range &R, StringRef Separator=", ", StringRef Prefix="", StringRef Suffix="")
Output range R as a sequence of interleaved elements.
const char * getHotnessName(CalleeInfo::HotnessType HT)
decltype(auto) dyn_cast(const From &Val)
dyn_cast<X> - Return the argument parameter cast to the specified type.
auto dyn_cast_if_present(const Y &Val)
dyn_cast_if_present<X> - Functionally identical to dyn_cast, except that a null (or none in the case ...
iterator_range< T > make_range(T x, T y)
Convenience function for iterating over sub-ranges.
LLVM_ABI void printEscapedString(StringRef Name, raw_ostream &Out)
Print each character of the specified string, escaping it if it is not printable or if it is an escap...
const char * toIRString(AtomicOrdering ao)
String used by LLVM IR to represent atomic ordering.
auto dyn_cast_or_null(const Y &Val)
void sort(IteratorTy Start, IteratorTy End)
LLVM_ABI raw_ostream & dbgs()
dbgs() - This returns a reference to a raw_ostream for debugging messages.
char hexdigit(unsigned X, bool LowerCase=false)
hexdigit - Return the hexadecimal character for the given number X (which should be less than 16).
bool isDigit(char C)
Checks if character C is one of the 10 decimal digits.
FunctionAddr VTableAddr Count
bool is_sorted(R &&Range, Compare C)
Wrapper function around std::is_sorted to check if elements in a range R are sorted with respect to a...
class LLVM_GSL_OWNER SmallVector
Forward declaration of SmallVector so that calculateSmallVectorDefaultInlinedElements can reference s...
FormattedNumber format_hex(uint64_t N, unsigned Width, bool Upper=false)
format_hex - Output N as a fixed width hexadecimal.
FormattedNumber format_hex_no_prefix(uint64_t N, unsigned Width, bool Upper=false)
format_hex_no_prefix - Output N as a fixed width hexadecimal.
bool isa(const From &Val)
isa<X> - Return true if the parameter to the template is an instance of one of the template type argu...
constexpr int PoisonMaskElem
AtomicOrdering
Atomic ordering for LLVM's memory model.
@ Ref
The access may reference the value stored in memory.
DWARFExpression::Operation Op
ArrayRef(const T &OneElt) -> ArrayRef< T >
std::string toString(const APInt &I, unsigned Radix, bool Signed, bool formatAsCLiteral=false, bool UpperCase=true, bool InsertSeparators=false)
LLVM_ABI Printable printBasicBlock(const BasicBlock *BB)
Print BasicBlock BB as an operand or print "<nullptr>" if BB is a nullptr.
decltype(auto) cast(const From &Val)
cast<X> - Return the argument parameter cast to the specified type.
auto predecessors(const MachineBasicBlock *BB)
bool pred_empty(const BasicBlock *BB)
std::vector< TypeIdOffsetVtableInfo > TypeIdCompatibleVtableInfo
List of vtable definitions decorated by a particular type identifier, and their corresponding offsets...
@ Default
The result values are uniform if and only if all operands are uniform.
static auto filterDbgVars(iterator_range< simple_ilist< DbgRecord >::iterator > R)
Filter the DbgRecord range to DbgVariableRecord types only and downcast.
LLVM_ABI void printLLVMNameWithoutPrefix(raw_ostream &OS, StringRef Name)
Print out a name of an LLVM value without any prefixes.
A single checksum, represented by a Kind and a Value (a string).
T Value
The string value of the checksum.
StringRef getKindAsString() const
std::vector< ConstVCall > TypeCheckedLoadConstVCalls
std::vector< VFuncId > TypeCheckedLoadVCalls
std::vector< ConstVCall > TypeTestAssumeConstVCalls
List of virtual calls made by this function using (respectively) llvm.assume(llvm....
std::vector< GlobalValue::GUID > TypeTests
List of type identifiers used by this function in llvm.type.test intrinsics referenced by something o...
std::vector< VFuncId > TypeTestAssumeVCalls
List of virtual calls made by this function using (respectively) llvm.assume(llvm....
unsigned DSOLocal
Indicates that the linker resolved the symbol to a definition from within the same linkage unit.
unsigned CanAutoHide
In the per-module summary, indicates that the global value is linkonce_odr and global unnamed addr (s...
unsigned ImportType
This field is written by the ThinLTO indexing step to postlink combined summary.
unsigned NotEligibleToImport
Indicate if the global value cannot be imported (e.g.
unsigned Linkage
The linkage type of the associated global value.
unsigned Visibility
Indicates the visibility.
unsigned Live
In per-module summary, indicate that the global value must be considered a live root for index-based ...
StringRef getTagName() const
Return the tag of this operand bundle as a string.
A utility class that uses RAII to save and restore the value of a variable.
std::map< uint64_t, WholeProgramDevirtResolution > WPDRes
Mapping from byte offset to whole-program devirt resolution for that (typeid, byte offset) pair.
Kind
Specifies which kind of type check we should emit for this byte array.
@ Unknown
Unknown (analysis not performed, don't lower)
@ Single
Single element (last example in "Short Inline Bit Vectors")
@ Inline
Inlined bit vector ("Short Inline Bit Vectors")
@ Unsat
Unsatisfiable type (i.e. no global has this type metadata)
@ AllOnes
All-ones bit vector ("Eliminating Bit Vector Checks for All-Ones Bit Vectors")
@ ByteArray
Test a byte array (first example)
unsigned SizeM1BitWidth
Range of size-1 expressed as a bit width.
enum llvm::TypeTestResolution::Kind TheKind
@ UniformRetVal
Uniform return value optimization.
@ VirtualConstProp
Virtual constant propagation.
@ UniqueRetVal
Unique return value optimization.
@ Indir
Just do a regular virtual call.
enum llvm::WholeProgramDevirtResolution::Kind TheKind
std::map< std::vector< uint64_t >, ByArg > ResByArg
Resolutions for calls with all constant integer arguments (excluding the first argument,...
std::string SingleImplName
@ SingleImpl
Single implementation devirtualization.
@ Indir
Just do a regular virtual call.
@ BranchFunnel
When retpoline mitigation is enabled, use a branch funnel that is defined in the merged module.
Function object to check whether the second component of a container supported by std::get (like std:...