LLVM 23.0.0git
AsmWriter.cpp
Go to the documentation of this file.
1//===- AsmWriter.cpp - Printing LLVM as an assembly file ------------------===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8//
9// This library implements `print` family of functions in classes like
10// Module, Function, Value, etc. In-memory representation of those classes is
11// converted to IR strings.
12//
13// Note that these routines must be extremely tolerant of various errors in the
14// LLVM code, because it can be used for debugging transformations.
15//
16//===----------------------------------------------------------------------===//
17
18#include "llvm/ADT/APFloat.h"
19#include "llvm/ADT/APInt.h"
20#include "llvm/ADT/ArrayRef.h"
21#include "llvm/ADT/DenseMap.h"
22#include "llvm/ADT/STLExtras.h"
23#include "llvm/ADT/SetVector.h"
28#include "llvm/ADT/StringRef.h"
31#include "llvm/Config/llvm-config.h"
32#include "llvm/IR/Argument.h"
34#include "llvm/IR/Attributes.h"
35#include "llvm/IR/BasicBlock.h"
36#include "llvm/IR/CFG.h"
37#include "llvm/IR/CallingConv.h"
38#include "llvm/IR/Comdat.h"
39#include "llvm/IR/Constant.h"
40#include "llvm/IR/Constants.h"
44#include "llvm/IR/Function.h"
45#include "llvm/IR/GlobalAlias.h"
46#include "llvm/IR/GlobalIFunc.h"
48#include "llvm/IR/GlobalValue.h"
51#include "llvm/IR/InlineAsm.h"
52#include "llvm/IR/InstrTypes.h"
53#include "llvm/IR/Instruction.h"
56#include "llvm/IR/Intrinsics.h"
57#include "llvm/IR/LLVMContext.h"
58#include "llvm/IR/Metadata.h"
59#include "llvm/IR/Module.h"
62#include "llvm/IR/Operator.h"
63#include "llvm/IR/Type.h"
64#include "llvm/IR/TypeFinder.h"
66#include "llvm/IR/Use.h"
67#include "llvm/IR/User.h"
68#include "llvm/IR/Value.h"
72#include "llvm/Support/Debug.h"
74#include "llvm/Support/Format.h"
78#include <cassert>
79#include <cctype>
80#include <cstddef>
81#include <cstdint>
82#include <iterator>
83#include <memory>
84#include <optional>
85#include <string>
86#include <tuple>
87#include <utility>
88#include <vector>
89
90using namespace llvm;
91
92// See https://llvm.org/docs/DebuggingLLVM.html for why these flags are useful.
93
94static cl::opt<bool>
95 PrintInstAddrs("print-inst-addrs", cl::Hidden,
96 cl::desc("Print addresses of instructions when dumping"));
97
99 "print-inst-debug-locs", cl::Hidden,
100 cl::desc("Pretty print debug locations of instructions when dumping"));
101
103 "print-prof-data", cl::Hidden,
104 cl::desc("Pretty print perf data (branch weights, etc) when dumping"));
105
107 "preserve-ll-uselistorder", cl::Hidden, cl::init(false),
108 cl::desc("Preserve use-list order when writing LLVM assembly."));
109
110static cl::opt<bool> PrintAddrspaceName("print-addrspace-name", cl::Hidden,
111 cl::init(false),
112 cl::desc("Print address space names"));
113
114// Make virtual table appear in this compilation unit.
116
117//===----------------------------------------------------------------------===//
118// Helper Functions
119//===----------------------------------------------------------------------===//
120
122
125
126/// Look for a value that might be wrapped as metadata, e.g. a value in a
127/// metadata operand. Returns the input value as-is if it is not wrapped.
128static const Value *skipMetadataWrapper(const Value *V) {
129 if (const auto *MAV = dyn_cast<MetadataAsValue>(V))
130 if (const auto *VAM = dyn_cast<ValueAsMetadata>(MAV->getMetadata()))
131 return VAM->getValue();
132 return V;
133}
134
135static void orderValue(const Value *V, OrderMap &OM) {
136 if (OM.lookup(V))
137 return;
138
139 if (const auto *C = dyn_cast<Constant>(V)) {
140 if (isa<ConstantData>(C))
141 return;
142
143 if (C->getNumOperands() && !isa<GlobalValue>(C))
144 for (const Value *Op : C->operands())
146 orderValue(Op, OM);
147 }
148
149 // Note: we cannot cache this lookup above, since inserting into the map
150 // changes the map's size, and thus affects the other IDs.
151 unsigned ID = OM.size() + 1;
152 OM[V] = ID;
153}
154
155static OrderMap orderModule(const Module *M) {
156 OrderMap OM;
157
158 auto OrderConstantValue = [&OM](const Value *V) {
159 if (isa<Constant>(V) || isa<InlineAsm>(V))
160 orderValue(V, OM);
161 };
162
163 auto OrderConstantFromMetadata = [&](Metadata *MD) {
164 if (const auto *VAM = dyn_cast<ValueAsMetadata>(MD)) {
165 OrderConstantValue(VAM->getValue());
166 } else if (const auto *AL = dyn_cast<DIArgList>(MD)) {
167 for (const auto *VAM : AL->getArgs())
168 OrderConstantValue(VAM->getValue());
169 }
170 };
171
172 for (const GlobalVariable &G : M->globals()) {
173 if (G.hasInitializer())
174 if (!isa<GlobalValue>(G.getInitializer()))
175 orderValue(G.getInitializer(), OM);
176 orderValue(&G, OM);
177 }
178 for (const GlobalAlias &A : M->aliases()) {
179 if (!isa<GlobalValue>(A.getAliasee()))
180 orderValue(A.getAliasee(), OM);
181 orderValue(&A, OM);
182 }
183 for (const GlobalIFunc &I : M->ifuncs()) {
184 if (!isa<GlobalValue>(I.getResolver()))
185 orderValue(I.getResolver(), OM);
186 orderValue(&I, OM);
187 }
188 for (const Function &F : *M) {
189 for (const Use &U : F.operands())
190 if (!isa<GlobalValue>(U.get()))
191 orderValue(U.get(), OM);
192
193 orderValue(&F, OM);
194
195 if (F.isDeclaration())
196 continue;
197
198 for (const Argument &A : F.args())
199 orderValue(&A, OM);
200 for (const BasicBlock &BB : F) {
201 orderValue(&BB, OM);
202 for (const Instruction &I : BB) {
203 // Debug records can contain Value references, that can then contain
204 // Values disconnected from the rest of the Value hierachy, if wrapped
205 // in some kind of constant-expression. Find and order any Values that
206 // are wrapped in debug-info.
207 for (DbgVariableRecord &DVR : filterDbgVars(I.getDbgRecordRange())) {
208 OrderConstantFromMetadata(DVR.getRawLocation());
209 if (DVR.isDbgAssign())
210 OrderConstantFromMetadata(DVR.getRawAddress());
211 }
212
213 for (const Value *Op : I.operands()) {
215 if ((isa<Constant>(*Op) && !isa<GlobalValue>(*Op)) ||
217 orderValue(Op, OM);
218 }
219 orderValue(&I, OM);
220 }
221 }
222 }
223 return OM;
224}
225
226static std::vector<unsigned>
227predictValueUseListOrder(const Value *V, unsigned ID, const OrderMap &OM) {
228 // Predict use-list order for this one.
229 using Entry = std::pair<const Use *, unsigned>;
231 for (const Use &U : V->uses())
232 // Check if this user will be serialized.
233 if (OM.lookup(U.getUser()))
234 List.push_back(std::make_pair(&U, List.size()));
235
236 if (List.size() < 2)
237 // We may have lost some users.
238 return {};
239
240 // When referencing a value before its declaration, a temporary value is
241 // created, which will later be RAUWed with the actual value. This reverses
242 // the use list. This happens for all values apart from basic blocks.
243 bool GetsReversed = !isa<BasicBlock>(V);
244 if (auto *BA = dyn_cast<BlockAddress>(V))
245 ID = OM.lookup(BA->getBasicBlock());
246 llvm::sort(List, [&](const Entry &L, const Entry &R) {
247 const Use *LU = L.first;
248 const Use *RU = R.first;
249 if (LU == RU)
250 return false;
251
252 auto LID = OM.lookup(LU->getUser());
253 auto RID = OM.lookup(RU->getUser());
254
255 // If ID is 4, then expect: 7 6 5 1 2 3.
256 if (LID < RID) {
257 if (GetsReversed)
258 if (RID <= ID)
259 return true;
260 return false;
261 }
262 if (RID < LID) {
263 if (GetsReversed)
264 if (LID <= ID)
265 return false;
266 return true;
267 }
268
269 // LID and RID are equal, so we have different operands of the same user.
270 // Assume operands are added in order for all instructions.
271 if (GetsReversed)
272 if (LID <= ID)
273 return LU->getOperandNo() < RU->getOperandNo();
274 return LU->getOperandNo() > RU->getOperandNo();
275 });
276
278 // Order is already correct.
279 return {};
280
281 // Store the shuffle.
282 std::vector<unsigned> Shuffle(List.size());
283 for (size_t I = 0, E = List.size(); I != E; ++I)
284 Shuffle[I] = List[I].second;
285 return Shuffle;
286}
287
289 OrderMap OM = orderModule(M);
290 UseListOrderMap ULOM;
291 for (const auto &Pair : OM) {
292 const Value *V = Pair.first;
293 if (V->use_empty() || std::next(V->use_begin()) == V->use_end())
294 continue;
295
296 std::vector<unsigned> Shuffle =
297 predictValueUseListOrder(V, Pair.second, OM);
298 if (Shuffle.empty())
299 continue;
300
301 const Function *F = nullptr;
302 if (auto *I = dyn_cast<Instruction>(V))
303 F = I->getFunction();
304 if (auto *A = dyn_cast<Argument>(V))
305 F = A->getParent();
306 if (auto *BB = dyn_cast<BasicBlock>(V))
307 F = BB->getParent();
308 ULOM[F][V] = std::move(Shuffle);
309 }
310 return ULOM;
311}
312
313static const Module *getModuleFromVal(const Value *V) {
314 if (const auto *MA = dyn_cast<Argument>(V))
315 return MA->getParent() ? MA->getParent()->getParent() : nullptr;
316
317 if (const auto *BB = dyn_cast<BasicBlock>(V))
318 return BB->getParent() ? BB->getParent()->getParent() : nullptr;
319
320 if (const auto *I = dyn_cast<Instruction>(V)) {
321 const Function *M = I->getParent() ? I->getParent()->getParent() : nullptr;
322 return M ? M->getParent() : nullptr;
323 }
324
325 if (const auto *GV = dyn_cast<GlobalValue>(V))
326 return GV->getParent();
327
328 if (const auto *MAV = dyn_cast<MetadataAsValue>(V)) {
329 for (const User *U : MAV->users())
330 if (isa<Instruction>(U))
331 if (const Module *M = getModuleFromVal(U))
332 return M;
333 return nullptr;
334 }
335
336 return nullptr;
337}
338
339static const Module *getModuleFromDPI(const DbgMarker *Marker) {
340 const Function *M =
341 Marker->getParent() ? Marker->getParent()->getParent() : nullptr;
342 return M ? M->getParent() : nullptr;
343}
344
345static const Module *getModuleFromDPI(const DbgRecord *DR) {
346 return DR->getMarker() ? getModuleFromDPI(DR->getMarker()) : nullptr;
347}
348
349static void printCallingConv(unsigned cc, raw_ostream &Out) {
350 switch (cc) {
351 default: Out << "cc" << cc; break;
352 case CallingConv::Fast: Out << "fastcc"; break;
353 case CallingConv::Cold: Out << "coldcc"; break;
354 case CallingConv::AnyReg: Out << "anyregcc"; break;
355 case CallingConv::PreserveMost: Out << "preserve_mostcc"; break;
356 case CallingConv::PreserveAll: Out << "preserve_allcc"; break;
357 case CallingConv::PreserveNone: Out << "preserve_nonecc"; break;
358 case CallingConv::CXX_FAST_TLS: Out << "cxx_fast_tlscc"; break;
359 case CallingConv::GHC: Out << "ghccc"; break;
360 case CallingConv::Tail: Out << "tailcc"; break;
361 case CallingConv::GRAAL: Out << "graalcc"; break;
362 case CallingConv::CFGuard_Check: Out << "cfguard_checkcc"; break;
363 case CallingConv::X86_StdCall: Out << "x86_stdcallcc"; break;
364 case CallingConv::X86_FastCall: Out << "x86_fastcallcc"; break;
365 case CallingConv::X86_ThisCall: Out << "x86_thiscallcc"; break;
366 case CallingConv::X86_RegCall: Out << "x86_regcallcc"; break;
367 case CallingConv::X86_VectorCall:Out << "x86_vectorcallcc"; break;
368 case CallingConv::Intel_OCL_BI: Out << "intel_ocl_bicc"; break;
369 case CallingConv::ARM_APCS: Out << "arm_apcscc"; break;
370 case CallingConv::ARM_AAPCS: Out << "arm_aapcscc"; break;
371 case CallingConv::ARM_AAPCS_VFP: Out << "arm_aapcs_vfpcc"; break;
372 case CallingConv::AArch64_VectorCall: Out << "aarch64_vector_pcs"; break;
374 Out << "aarch64_sve_vector_pcs";
375 break;
377 Out << "aarch64_sme_preservemost_from_x0";
378 break;
380 Out << "aarch64_sme_preservemost_from_x1";
381 break;
383 Out << "aarch64_sme_preservemost_from_x2";
384 break;
385 case CallingConv::MSP430_INTR: Out << "msp430_intrcc"; break;
386 case CallingConv::AVR_INTR: Out << "avr_intrcc "; break;
387 case CallingConv::AVR_SIGNAL: Out << "avr_signalcc "; break;
388 case CallingConv::PTX_Kernel: Out << "ptx_kernel"; break;
389 case CallingConv::PTX_Device: Out << "ptx_device"; break;
390 case CallingConv::X86_64_SysV: Out << "x86_64_sysvcc"; break;
391 case CallingConv::Win64: Out << "win64cc"; break;
392 case CallingConv::SPIR_FUNC: Out << "spir_func"; break;
393 case CallingConv::SPIR_KERNEL: Out << "spir_kernel"; break;
394 case CallingConv::Swift: Out << "swiftcc"; break;
395 case CallingConv::SwiftTail: Out << "swifttailcc"; break;
396 case CallingConv::X86_INTR: Out << "x86_intrcc"; break;
398 Out << "hhvmcc";
399 break;
401 Out << "hhvm_ccc";
402 break;
403 case CallingConv::AMDGPU_VS: Out << "amdgpu_vs"; break;
404 case CallingConv::AMDGPU_LS: Out << "amdgpu_ls"; break;
405 case CallingConv::AMDGPU_HS: Out << "amdgpu_hs"; break;
406 case CallingConv::AMDGPU_ES: Out << "amdgpu_es"; break;
407 case CallingConv::AMDGPU_GS: Out << "amdgpu_gs"; break;
408 case CallingConv::AMDGPU_PS: Out << "amdgpu_ps"; break;
409 case CallingConv::AMDGPU_CS: Out << "amdgpu_cs"; break;
411 Out << "amdgpu_cs_chain";
412 break;
414 Out << "amdgpu_cs_chain_preserve";
415 break;
416 case CallingConv::AMDGPU_KERNEL: Out << "amdgpu_kernel"; break;
417 case CallingConv::AMDGPU_Gfx: Out << "amdgpu_gfx"; break;
419 Out << "amdgpu_gfx_whole_wave";
420 break;
421 case CallingConv::M68k_RTD: Out << "m68k_rtdcc"; break;
423 Out << "riscv_vector_cc";
424 break;
425#define CC_VLS_CASE(ABI_VLEN) \
426 case CallingConv::RISCV_VLSCall_##ABI_VLEN: \
427 Out << "riscv_vls_cc(" #ABI_VLEN ")"; \
428 break;
429 CC_VLS_CASE(32)
430 CC_VLS_CASE(64)
431 CC_VLS_CASE(128)
432 CC_VLS_CASE(256)
433 CC_VLS_CASE(512)
434 CC_VLS_CASE(1024)
435 CC_VLS_CASE(2048)
436 CC_VLS_CASE(4096)
437 CC_VLS_CASE(8192)
438 CC_VLS_CASE(16384)
439 CC_VLS_CASE(32768)
440 CC_VLS_CASE(65536)
441#undef CC_VLS_CASE
443 Out << "cheriot_compartmentcallcc";
444 break;
446 Out << "cheriot_compartmentcalleecc";
447 break;
449 Out << "cheriot_librarycallcc";
450 break;
451 }
452}
453
461
463 assert(!Name.empty() && "Cannot get empty name!");
464
465 // Scan the name to see if it needs quotes first.
466 bool NeedsQuotes = isdigit(static_cast<unsigned char>(Name[0]));
467 if (!NeedsQuotes) {
468 for (unsigned char C : Name) {
469 // By making this unsigned, the value passed in to isalnum will always be
470 // in the range 0-255. This is important when building with MSVC because
471 // its implementation will assert. This situation can arise when dealing
472 // with UTF-8 multibyte characters.
473 if (!isalnum(C) && C != '-' && C != '.' && C != '_') {
474 NeedsQuotes = true;
475 break;
476 }
477 }
478 }
479
480 // If we didn't need any quotes, just write out the name in one blast.
481 if (!NeedsQuotes) {
482 OS << Name;
483 return;
484 }
485
486 // Okay, we need quotes. Output the quotes and escape any scary characters as
487 // needed.
488 OS << '"';
489 printEscapedString(Name, OS);
490 OS << '"';
491}
492
493/// Turn the specified name into an 'LLVM name', which is either prefixed with %
494/// (if the string only contains simple characters) or is surrounded with ""'s
495/// (if it has special chars in it). Print it out.
496static void printLLVMName(raw_ostream &OS, StringRef Name, PrefixType Prefix) {
497 switch (Prefix) {
498 case NoPrefix:
499 break;
500 case GlobalPrefix:
501 OS << '@';
502 break;
503 case ComdatPrefix:
504 OS << '$';
505 break;
506 case LabelPrefix:
507 break;
508 case LocalPrefix:
509 OS << '%';
510 break;
511 }
513}
514
515/// Turn the specified name into an 'LLVM name', which is either prefixed with %
516/// (if the string only contains simple characters) or is surrounded with ""'s
517/// (if it has special chars in it). Print it out.
518static void printLLVMName(raw_ostream &OS, const Value *V) {
519 printLLVMName(OS, V->getName(),
521}
522
523static void printShuffleMask(raw_ostream &Out, Type *Ty, ArrayRef<int> Mask) {
524 Out << ", <";
526 Out << "vscale x ";
527 Out << Mask.size() << " x i32> ";
528 if (all_of(Mask, equal_to(0))) {
529 Out << "zeroinitializer";
530 } else if (all_of(Mask, equal_to(PoisonMaskElem))) {
531 Out << "poison";
532 } else {
533 Out << "<";
534 ListSeparator LS;
535 for (int Elt : Mask) {
536 Out << LS << "i32 ";
537 if (Elt == PoisonMaskElem)
538 Out << "poison";
539 else
540 Out << Elt;
541 }
542 Out << ">";
543 }
544}
545
546namespace {
547
548class TypePrinting {
549public:
550 TypePrinting(const Module *M = nullptr)
551 : M(M), TypesIncorporated(M == nullptr) {}
552
553 TypePrinting(const TypePrinting &) = delete;
554 TypePrinting &operator=(const TypePrinting &) = delete;
555
556 /// The named types that are used by the current module.
557 TypeFinder &getNamedTypes();
558
559 /// The numbered types, number to type mapping.
560 std::vector<StructType *> &getNumberedTypes();
561
562 bool empty();
563
564 void print(Type *Ty, raw_ostream &OS);
565
566 void printStructBody(StructType *Ty, raw_ostream &OS);
567
568private:
569 void incorporateTypes();
570
571 /// A module to process lazily.
572 const Module *M;
573 bool TypesIncorporated;
574
575 TypeFinder NamedTypes;
576
577 // The numbered types, along with their value.
578 DenseMap<StructType *, unsigned> Type2Number;
579
580 std::vector<StructType *> NumberedTypes;
581};
582
583} // end anonymous namespace
584
585TypeFinder &TypePrinting::getNamedTypes() {
586 incorporateTypes();
587 return NamedTypes;
588}
589
590std::vector<StructType *> &TypePrinting::getNumberedTypes() {
591 incorporateTypes();
592
593 // We know all the numbers that each type is used and we know that it is a
594 // dense assignment. Convert the map to an index table, if it's not done
595 // already (judging from the sizes):
596 if (NumberedTypes.size() == Type2Number.size())
597 return NumberedTypes;
598
599 NumberedTypes.resize(Type2Number.size());
600 for (const auto &P : Type2Number) {
601 assert(P.second < NumberedTypes.size() && "Didn't get a dense numbering?");
602 assert(!NumberedTypes[P.second] && "Didn't get a unique numbering?");
603 NumberedTypes[P.second] = P.first;
604 }
605 return NumberedTypes;
606}
607
608bool TypePrinting::empty() {
609 incorporateTypes();
610 return NamedTypes.empty() && Type2Number.empty();
611}
612
613void TypePrinting::incorporateTypes() {
614 if (TypesIncorporated)
615 return;
616
617 NamedTypes.run(*M, false);
618 TypesIncorporated = true;
619
620 // The list of struct types we got back includes all the struct types, split
621 // the unnamed ones out to a numbering and remove the anonymous structs.
622 unsigned NextNumber = 0;
623
624 std::vector<StructType *>::iterator NextToUse = NamedTypes.begin();
625 for (StructType *STy : NamedTypes) {
626 // Ignore anonymous types.
627 if (STy->isLiteral())
628 continue;
629
630 if (STy->getName().empty())
631 Type2Number[STy] = NextNumber++;
632 else
633 *NextToUse++ = STy;
634 }
635
636 NamedTypes.erase(NextToUse, NamedTypes.end());
637}
638
639static void printAddressSpace(const Module *M, unsigned AS, raw_ostream &OS,
640 StringRef Prefix = " ", StringRef Suffix = "",
641 bool ForcePrint = false) {
642 if (AS == 0 && !ForcePrint)
643 return;
644 OS << Prefix << "addrspace(";
645 StringRef ASName =
646 PrintAddrspaceName && M ? M->getDataLayout().getAddressSpaceName(AS) : "";
647 if (!ASName.empty())
648 OS << "\"" << ASName << "\"";
649 else
650 OS << AS;
651 OS << ")" << Suffix;
652}
653
654/// Write the specified type to the specified raw_ostream, making use of type
655/// names or up references to shorten the type name where possible.
656void TypePrinting::print(Type *Ty, raw_ostream &OS) {
657 switch (Ty->getTypeID()) {
658 case Type::VoidTyID: OS << "void"; return;
659 case Type::HalfTyID: OS << "half"; return;
660 case Type::BFloatTyID: OS << "bfloat"; return;
661 case Type::FloatTyID: OS << "float"; return;
662 case Type::DoubleTyID: OS << "double"; return;
663 case Type::X86_FP80TyID: OS << "x86_fp80"; return;
664 case Type::FP128TyID: OS << "fp128"; return;
665 case Type::PPC_FP128TyID: OS << "ppc_fp128"; return;
666 case Type::LabelTyID: OS << "label"; return;
667 case Type::MetadataTyID:
668 OS << "metadata";
669 return;
670 case Type::X86_AMXTyID: OS << "x86_amx"; return;
671 case Type::TokenTyID: OS << "token"; return;
672 case Type::ByteTyID:
673 OS << 'b' << Ty->getByteBitWidth();
674 return;
675 case Type::IntegerTyID:
676 OS << 'i' << cast<IntegerType>(Ty)->getBitWidth();
677 return;
678
679 case Type::FunctionTyID: {
680 FunctionType *FTy = cast<FunctionType>(Ty);
681 print(FTy->getReturnType(), OS);
682 OS << " (";
683 ListSeparator LS;
684 for (Type *Ty : FTy->params()) {
685 OS << LS;
686 print(Ty, OS);
687 }
688 if (FTy->isVarArg())
689 OS << LS << "...";
690 OS << ')';
691 return;
692 }
693 case Type::StructTyID: {
694 StructType *STy = cast<StructType>(Ty);
695
696 if (STy->isLiteral())
697 return printStructBody(STy, OS);
698
699 if (!STy->getName().empty())
700 return printLLVMName(OS, STy->getName(), LocalPrefix);
701
702 incorporateTypes();
703 const auto I = Type2Number.find(STy);
704 if (I != Type2Number.end())
705 OS << '%' << I->second;
706 else // Not enumerated, print the hex address.
707 OS << "%\"type " << STy << '\"';
708 return;
709 }
710 case Type::PointerTyID: {
712 OS << "ptr";
713 printAddressSpace(M, PTy->getAddressSpace(), OS);
714 return;
715 }
716 case Type::ArrayTyID: {
717 ArrayType *ATy = cast<ArrayType>(Ty);
718 OS << '[' << ATy->getNumElements() << " x ";
719 print(ATy->getElementType(), OS);
720 OS << ']';
721 return;
722 }
723 case Type::FixedVectorTyID:
724 case Type::ScalableVectorTyID: {
725 VectorType *PTy = cast<VectorType>(Ty);
726 ElementCount EC = PTy->getElementCount();
727 OS << "<";
728 if (EC.isScalable())
729 OS << "vscale x ";
730 OS << EC.getKnownMinValue() << " x ";
731 print(PTy->getElementType(), OS);
732 OS << '>';
733 return;
734 }
735 case Type::TypedPointerTyID: {
736 TypedPointerType *TPTy = cast<TypedPointerType>(Ty);
737 OS << "typedptr(" << *TPTy->getElementType() << ", "
738 << TPTy->getAddressSpace() << ")";
739 return;
740 }
741 case Type::TargetExtTyID:
742 TargetExtType *TETy = cast<TargetExtType>(Ty);
743 OS << "target(\"";
745 OS << "\"";
746 for (Type *Inner : TETy->type_params()) {
747 OS << ", ";
748 Inner->print(OS, /*IsForDebug=*/false, /*NoDetails=*/true);
749 }
750 for (unsigned IntParam : TETy->int_params())
751 OS << ", " << IntParam;
752 OS << ")";
753 return;
754 }
755 llvm_unreachable("Invalid TypeID");
756}
757
758void TypePrinting::printStructBody(StructType *STy, raw_ostream &OS) {
759 if (STy->isOpaque()) {
760 OS << "opaque";
761 return;
762 }
763
764 if (STy->isPacked())
765 OS << '<';
766
767 if (STy->getNumElements() == 0) {
768 OS << "{}";
769 } else {
770 OS << "{ ";
771 ListSeparator LS;
772 for (Type *Ty : STy->elements()) {
773 OS << LS;
774 print(Ty, OS);
775 }
776
777 OS << " }";
778 }
779 if (STy->isPacked())
780 OS << '>';
781}
782
784
785//===----------------------------------------------------------------------===//
786// SlotTracker Class: Enumerate slot numbers for unnamed values
787//===----------------------------------------------------------------------===//
788/// This class provides computation of slot numbers for LLVM Assembly writing.
789///
791public:
792 /// ValueMap - A mapping of Values to slot numbers.
794
795private:
796 /// TheModule - The module for which we are holding slot numbers.
797 const Module* TheModule;
798
799 /// TheFunction - The function for which we are holding slot numbers.
800 const Function* TheFunction = nullptr;
801 bool FunctionProcessed = false;
802 bool ShouldInitializeAllMetadata;
803
804 std::function<void(AbstractSlotTrackerStorage *, const Module *, bool)>
805 ProcessModuleHookFn;
806 std::function<void(AbstractSlotTrackerStorage *, const Function *, bool)>
807 ProcessFunctionHookFn;
808
809 /// The summary index for which we are holding slot numbers.
810 const ModuleSummaryIndex *TheIndex = nullptr;
811
812 /// mMap - The slot map for the module level data.
813 ValueMap mMap;
814 unsigned mNext = 0;
815
816 /// fMap - The slot map for the function level data.
817 ValueMap fMap;
818 unsigned fNext = 0;
819
820 /// mdnMap - Map for MDNodes.
822 unsigned mdnNext = 0;
823
824 /// asMap - The slot map for attribute sets.
826 unsigned asNext = 0;
827
828 /// ModulePathMap - The slot map for Module paths used in the summary index.
829 StringMap<unsigned> ModulePathMap;
830 unsigned ModulePathNext = 0;
831
832 /// GUIDMap - The slot map for GUIDs used in the summary index.
834 unsigned GUIDNext = 0;
835
836 /// TypeIdMap - The slot map for type ids used in the summary index.
837 StringMap<unsigned> TypeIdMap;
838 unsigned TypeIdNext = 0;
839
840 /// TypeIdCompatibleVtableMap - The slot map for type compatible vtable ids
841 /// used in the summary index.
842 StringMap<unsigned> TypeIdCompatibleVtableMap;
843 unsigned TypeIdCompatibleVtableNext = 0;
844
845public:
846 /// Construct from a module.
847 ///
848 /// If \c ShouldInitializeAllMetadata, initializes all metadata in all
849 /// functions, giving correct numbering for metadata referenced only from
850 /// within a function (even if no functions have been initialized).
851 explicit SlotTracker(const Module *M,
852 bool ShouldInitializeAllMetadata = false);
853
854 /// Construct from a function, starting out in incorp state.
855 ///
856 /// If \c ShouldInitializeAllMetadata, initializes all metadata in all
857 /// functions, giving correct numbering for metadata referenced only from
858 /// within a function (even if no functions have been initialized).
859 explicit SlotTracker(const Function *F,
860 bool ShouldInitializeAllMetadata = false);
861
862 /// Construct from a module summary index.
863 explicit SlotTracker(const ModuleSummaryIndex *Index);
864
865 SlotTracker(const SlotTracker &) = delete;
867
868 ~SlotTracker() override = default;
869
870 void setProcessHook(
871 std::function<void(AbstractSlotTrackerStorage *, const Module *, bool)>);
872 void setProcessHook(std::function<void(AbstractSlotTrackerStorage *,
873 const Function *, bool)>);
874
875 unsigned getNextMetadataSlot() override { return mdnNext; }
876
877 void createMetadataSlot(const MDNode *N) override;
878
879 /// Return the slot number of the specified value in it's type
880 /// plane. If something is not in the SlotTracker, return -1.
881 int getLocalSlot(const Value *V);
882 int getGlobalSlot(const GlobalValue *V);
883 int getMetadataSlot(const MDNode *N) override;
884 int getAttributeGroupSlot(AttributeSet AS);
885 int getModulePathSlot(StringRef Path);
886 int getGUIDSlot(GlobalValue::GUID GUID);
887 int getTypeIdSlot(StringRef Id);
888 int getTypeIdCompatibleVtableSlot(StringRef Id);
889
890 /// If you'd like to deal with a function instead of just a module, use
891 /// this method to get its data into the SlotTracker.
893 TheFunction = F;
894 FunctionProcessed = false;
895 }
896
897 const Function *getFunction() const { return TheFunction; }
898
899 /// After calling incorporateFunction, use this method to remove the
900 /// most recently incorporated function from the SlotTracker. This
901 /// will reset the state of the machine back to just the module contents.
902 void purgeFunction();
903
904 /// MDNode map iterators.
906
907 mdn_iterator mdn_begin() { return mdnMap.begin(); }
908 mdn_iterator mdn_end() { return mdnMap.end(); }
909 unsigned mdn_size() const { return mdnMap.size(); }
910 bool mdn_empty() const { return mdnMap.empty(); }
911
912 /// AttributeSet map iterators.
914
915 as_iterator as_begin() { return asMap.begin(); }
916 as_iterator as_end() { return asMap.end(); }
917 unsigned as_size() const { return asMap.size(); }
918 bool as_empty() const { return asMap.empty(); }
919
920 /// GUID map iterators.
922
923 /// These functions do the actual initialization.
924 inline void initializeIfNeeded();
926
927 // Implementation Details
928private:
929 /// CreateModuleSlot - Insert the specified GlobalValue* into the slot table.
930 void CreateModuleSlot(const GlobalValue *V);
931
932 /// CreateMetadataSlot - Insert the specified MDNode* into the slot table.
933 void CreateMetadataSlot(const MDNode *N);
934
935 /// CreateFunctionSlot - Insert the specified Value* into the slot table.
936 void CreateFunctionSlot(const Value *V);
937
938 /// Insert the specified AttributeSet into the slot table.
939 void CreateAttributeSetSlot(AttributeSet AS);
940
941 inline void CreateModulePathSlot(StringRef Path);
942 void CreateGUIDSlot(GlobalValue::GUID GUID);
943 void CreateTypeIdSlot(StringRef Id);
944 void CreateTypeIdCompatibleVtableSlot(StringRef Id);
945
946 /// Add all of the module level global variables (and their initializers)
947 /// and function declarations, but not the contents of those functions.
948 void processModule();
949 // Returns number of allocated slots
950 int processIndex();
951
952 /// Add all of the functions arguments, basic blocks, and instructions.
953 void processFunction();
954
955 /// Add the metadata directly attached to a GlobalObject.
956 void processGlobalObjectMetadata(const GlobalObject &GO);
957
958 /// Add all of the metadata from a function.
959 void processFunctionMetadata(const Function &F);
960
961 /// Add all of the metadata from an instruction.
962 void processInstructionMetadata(const Instruction &I);
963
964 /// Add all of the metadata from a DbgRecord.
965 void processDbgRecordMetadata(const DbgRecord &DVR);
966};
967
969 const Function *F)
970 : M(M), F(F), Machine(&Machine) {}
971
973 bool ShouldInitializeAllMetadata)
974 : ShouldCreateStorage(M),
975 ShouldInitializeAllMetadata(ShouldInitializeAllMetadata), M(M) {}
976
978
980 if (!ShouldCreateStorage)
981 return Machine;
982
983 ShouldCreateStorage = false;
984 MachineStorage =
985 std::make_unique<SlotTracker>(M, ShouldInitializeAllMetadata);
986 Machine = MachineStorage.get();
987 if (ProcessModuleHookFn)
988 Machine->setProcessHook(ProcessModuleHookFn);
989 if (ProcessFunctionHookFn)
990 Machine->setProcessHook(ProcessFunctionHookFn);
991 return Machine;
992}
993
995 // Using getMachine() may lazily create the slot tracker.
996 if (!getMachine())
997 return;
998
999 // Nothing to do if this is the right function already.
1000 if (this->F == &F)
1001 return;
1002 if (this->F)
1003 Machine->purgeFunction();
1004 Machine->incorporateFunction(&F);
1005 this->F = &F;
1006}
1007
1009 assert(F && "No function incorporated");
1010 return Machine->getLocalSlot(V);
1011}
1012
1014 std::function<void(AbstractSlotTrackerStorage *, const Module *, bool)>
1015 Fn) {
1016 ProcessModuleHookFn = std::move(Fn);
1017}
1018
1020 std::function<void(AbstractSlotTrackerStorage *, const Function *, bool)>
1021 Fn) {
1022 ProcessFunctionHookFn = std::move(Fn);
1023}
1024
1026 if (const auto *FA = dyn_cast<Argument>(V))
1027 return new SlotTracker(FA->getParent());
1028
1029 if (const auto *I = dyn_cast<Instruction>(V))
1030 if (I->getParent())
1031 return new SlotTracker(I->getParent()->getParent());
1032
1033 if (const auto *BB = dyn_cast<BasicBlock>(V))
1034 return new SlotTracker(BB->getParent());
1035
1036 if (const auto *GV = dyn_cast<GlobalVariable>(V))
1037 return new SlotTracker(GV->getParent());
1038
1039 if (const auto *GA = dyn_cast<GlobalAlias>(V))
1040 return new SlotTracker(GA->getParent());
1041
1042 if (const auto *GIF = dyn_cast<GlobalIFunc>(V))
1043 return new SlotTracker(GIF->getParent());
1044
1045 if (const auto *Func = dyn_cast<Function>(V))
1046 return new SlotTracker(Func);
1047
1048 return nullptr;
1049}
1050
1051#if 0
1052#define ST_DEBUG(X) dbgs() << X
1053#else
1054#define ST_DEBUG(X)
1055#endif
1056
1057// Module level constructor. Causes the contents of the Module (sans functions)
1058// to be added to the slot table.
1059SlotTracker::SlotTracker(const Module *M, bool ShouldInitializeAllMetadata)
1060 : TheModule(M), ShouldInitializeAllMetadata(ShouldInitializeAllMetadata) {}
1061
1062// Function level constructor. Causes the contents of the Module and the one
1063// function provided to be added to the slot table.
1064SlotTracker::SlotTracker(const Function *F, bool ShouldInitializeAllMetadata)
1065 : TheModule(F ? F->getParent() : nullptr), TheFunction(F),
1066 ShouldInitializeAllMetadata(ShouldInitializeAllMetadata) {}
1067
1069 : TheModule(nullptr), ShouldInitializeAllMetadata(false), TheIndex(Index) {}
1070
1072 if (TheModule) {
1073 processModule();
1074 TheModule = nullptr; ///< Prevent re-processing next time we're called.
1075 }
1076
1077 if (TheFunction && !FunctionProcessed)
1078 processFunction();
1079}
1080
1082 if (!TheIndex)
1083 return 0;
1084 int NumSlots = processIndex();
1085 TheIndex = nullptr; ///< Prevent re-processing next time we're called.
1086 return NumSlots;
1087}
1088
1089// Iterate through all the global variables, functions, and global
1090// variable initializers and create slots for them.
1091void SlotTracker::processModule() {
1092 ST_DEBUG("begin processModule!\n");
1093
1094 // Add all of the unnamed global variables to the value table.
1095 for (const GlobalVariable &Var : TheModule->globals()) {
1096 if (!Var.hasName())
1097 CreateModuleSlot(&Var);
1098 processGlobalObjectMetadata(Var);
1099 auto Attrs = Var.getAttributes();
1100 if (Attrs.hasAttributes())
1101 CreateAttributeSetSlot(Attrs);
1102 }
1103
1104 for (const GlobalAlias &A : TheModule->aliases()) {
1105 if (!A.hasName())
1106 CreateModuleSlot(&A);
1107 }
1108
1109 for (const GlobalIFunc &I : TheModule->ifuncs()) {
1110 if (!I.hasName())
1111 CreateModuleSlot(&I);
1112 processGlobalObjectMetadata(I);
1113 }
1114
1115 // Add metadata used by named metadata.
1116 for (const NamedMDNode &NMD : TheModule->named_metadata()) {
1117 for (const MDNode *N : NMD.operands())
1118 CreateMetadataSlot(N);
1119 }
1120
1121 for (const Function &F : *TheModule) {
1122 if (!F.hasName())
1123 // Add all the unnamed functions to the table.
1124 CreateModuleSlot(&F);
1125
1126 if (ShouldInitializeAllMetadata)
1127 processFunctionMetadata(F);
1128
1129 // Add all the function attributes to the table.
1130 // FIXME: Add attributes of other objects?
1131 AttributeSet FnAttrs = F.getAttributes().getFnAttrs();
1132 if (FnAttrs.hasAttributes())
1133 CreateAttributeSetSlot(FnAttrs);
1134 }
1135
1136 if (ProcessModuleHookFn)
1137 ProcessModuleHookFn(this, TheModule, ShouldInitializeAllMetadata);
1138
1139 ST_DEBUG("end processModule!\n");
1140}
1141
1142// Process the arguments, basic blocks, and instructions of a function.
1143void SlotTracker::processFunction() {
1144 ST_DEBUG("begin processFunction!\n");
1145 fNext = 0;
1146
1147 // Process function metadata if it wasn't hit at the module-level.
1148 if (!ShouldInitializeAllMetadata)
1149 processFunctionMetadata(*TheFunction);
1150
1151 // Add all the function arguments with no names.
1152 for(Function::const_arg_iterator AI = TheFunction->arg_begin(),
1153 AE = TheFunction->arg_end(); AI != AE; ++AI)
1154 if (!AI->hasName())
1155 CreateFunctionSlot(&*AI);
1156
1157 ST_DEBUG("Inserting Instructions:\n");
1158
1159 // Add all of the basic blocks and instructions with no names.
1160 for (auto &BB : *TheFunction) {
1161 if (!BB.hasName())
1162 CreateFunctionSlot(&BB);
1163
1164 for (auto &I : BB) {
1165 if (!I.getType()->isVoidTy() && !I.hasName())
1166 CreateFunctionSlot(&I);
1167
1168 // We allow direct calls to any llvm.foo function here, because the
1169 // target may not be linked into the optimizer.
1170 if (const auto *Call = dyn_cast<CallBase>(&I)) {
1171 // Add all the call attributes to the table.
1172 AttributeSet Attrs = Call->getAttributes().getFnAttrs();
1173 if (Attrs.hasAttributes())
1174 CreateAttributeSetSlot(Attrs);
1175 }
1176 }
1177 }
1178
1179 if (ProcessFunctionHookFn)
1180 ProcessFunctionHookFn(this, TheFunction, ShouldInitializeAllMetadata);
1181
1182 FunctionProcessed = true;
1183
1184 ST_DEBUG("end processFunction!\n");
1185}
1186
1187// Iterate through all the GUID in the index and create slots for them.
1188int SlotTracker::processIndex() {
1189 ST_DEBUG("begin processIndex!\n");
1190 assert(TheIndex);
1191
1192 // The first block of slots are just the module ids, which start at 0 and are
1193 // assigned consecutively. Since the StringMap iteration order isn't
1194 // guaranteed, order by path string before assigning slots.
1195 std::vector<StringRef> ModulePaths;
1196 for (auto &[ModPath, _] : TheIndex->modulePaths())
1197 ModulePaths.push_back(ModPath);
1198 llvm::sort(ModulePaths);
1199 for (auto &ModPath : ModulePaths)
1200 CreateModulePathSlot(ModPath);
1201
1202 // Start numbering the GUIDs after the module ids.
1203 GUIDNext = ModulePathNext;
1204
1205 for (auto &GlobalList : *TheIndex)
1206 CreateGUIDSlot(GlobalList.first);
1207
1208 // Start numbering the TypeIdCompatibleVtables after the GUIDs.
1209 TypeIdCompatibleVtableNext = GUIDNext;
1210 for (auto &TId : TheIndex->typeIdCompatibleVtableMap())
1211 CreateTypeIdCompatibleVtableSlot(TId.first);
1212
1213 // Start numbering the TypeIds after the TypeIdCompatibleVtables.
1214 TypeIdNext = TypeIdCompatibleVtableNext;
1215 for (const auto &TID : TheIndex->typeIds())
1216 CreateTypeIdSlot(TID.second.first);
1217
1218 ST_DEBUG("end processIndex!\n");
1219 return TypeIdNext;
1220}
1221
1222void SlotTracker::processGlobalObjectMetadata(const GlobalObject &GO) {
1224 GO.getAllMetadata(MDs);
1225 for (auto &MD : MDs)
1226 CreateMetadataSlot(MD.second);
1227}
1228
1229void SlotTracker::processFunctionMetadata(const Function &F) {
1230 processGlobalObjectMetadata(F);
1231 for (auto &BB : F) {
1232 for (auto &I : BB) {
1233 for (const DbgRecord &DR : I.getDbgRecordRange())
1234 processDbgRecordMetadata(DR);
1235 processInstructionMetadata(I);
1236 }
1237 }
1238}
1239
1240void SlotTracker::processDbgRecordMetadata(const DbgRecord &DR) {
1241 // Tolerate null metadata pointers: it's a completely illegal debug record,
1242 // but we can have faulty metadata from debug-intrinsic days being
1243 // autoupgraded into debug records. This gets caught by the verifier, which
1244 // then will print the faulty IR, hitting this code path.
1245 if (const auto *DVR = dyn_cast<const DbgVariableRecord>(&DR)) {
1246 // Process metadata used by DbgRecords; we only specifically care about the
1247 // DILocalVariable, DILocation, and DIAssignID fields, as the Value and
1248 // Expression fields should only be printed inline and so do not use a slot.
1249 // Note: The above doesn't apply for empty-metadata operands.
1250 if (auto *Empty = dyn_cast_if_present<MDNode>(DVR->getRawLocation()))
1251 CreateMetadataSlot(Empty);
1252 if (DVR->getRawVariable())
1253 CreateMetadataSlot(DVR->getRawVariable());
1254 if (DVR->isDbgAssign()) {
1255 if (auto *AssignID = DVR->getRawAssignID())
1256 CreateMetadataSlot(cast<MDNode>(AssignID));
1257 if (auto *Empty = dyn_cast_if_present<MDNode>(DVR->getRawAddress()))
1258 CreateMetadataSlot(Empty);
1259 }
1260 } else if (const auto *DLR = dyn_cast<const DbgLabelRecord>(&DR)) {
1261 CreateMetadataSlot(DLR->getRawLabel());
1262 } else {
1263 llvm_unreachable("unsupported DbgRecord kind");
1264 }
1265 if (DR.getDebugLoc())
1266 CreateMetadataSlot(DR.getDebugLoc().getAsMDNode());
1267}
1268
1269void SlotTracker::processInstructionMetadata(const Instruction &I) {
1270 // Process metadata used directly by intrinsics.
1271 if (const auto *CI = dyn_cast<CallInst>(&I))
1272 if (Function *F = CI->getCalledFunction())
1273 if (F->isIntrinsic())
1274 for (auto &Op : I.operands())
1276 if (auto *N = dyn_cast<MDNode>(V->getMetadata()))
1277 CreateMetadataSlot(N);
1278
1279 // Process metadata attached to this instruction.
1281 I.getAllMetadata(MDs);
1282 for (auto &MD : MDs)
1283 CreateMetadataSlot(MD.second);
1284}
1285
1286/// Clean up after incorporating a function. This is the only way to get out of
1287/// the function incorporation state that affects get*Slot/Create*Slot. Function
1288/// incorporation state is indicated by TheFunction != 0.
1290 ST_DEBUG("begin purgeFunction!\n");
1291 fMap.clear(); // Simply discard the function level map
1292 TheFunction = nullptr;
1293 FunctionProcessed = false;
1294 ST_DEBUG("end purgeFunction!\n");
1295}
1296
1297/// getGlobalSlot - Get the slot number of a global value.
1299 // Check for uninitialized state and do lazy initialization.
1301
1302 // Find the value in the module map
1303 ValueMap::iterator MI = mMap.find(V);
1304 return MI == mMap.end() ? -1 : (int)MI->second;
1305}
1306
1308 std::function<void(AbstractSlotTrackerStorage *, const Module *, bool)>
1309 Fn) {
1310 ProcessModuleHookFn = std::move(Fn);
1311}
1312
1314 std::function<void(AbstractSlotTrackerStorage *, const Function *, bool)>
1315 Fn) {
1316 ProcessFunctionHookFn = std::move(Fn);
1317}
1318
1319/// getMetadataSlot - Get the slot number of a MDNode.
1320void SlotTracker::createMetadataSlot(const MDNode *N) { CreateMetadataSlot(N); }
1321
1322/// getMetadataSlot - Get the slot number of a MDNode.
1324 // Check for uninitialized state and do lazy initialization.
1326
1327 // Find the MDNode in the module map
1328 mdn_iterator MI = mdnMap.find(N);
1329 return MI == mdnMap.end() ? -1 : (int)MI->second;
1330}
1331
1332/// getLocalSlot - Get the slot number for a value that is local to a function.
1334 assert(!isa<Constant>(V) && "Can't get a constant or global slot with this!");
1335
1336 // Check for uninitialized state and do lazy initialization.
1338
1339 ValueMap::iterator FI = fMap.find(V);
1340 return FI == fMap.end() ? -1 : (int)FI->second;
1341}
1342
1344 // Check for uninitialized state and do lazy initialization.
1346
1347 // Find the AttributeSet in the module map.
1348 as_iterator AI = asMap.find(AS);
1349 return AI == asMap.end() ? -1 : (int)AI->second;
1350}
1351
1353 // Check for uninitialized state and do lazy initialization.
1355
1356 // Find the Module path in the map
1357 auto I = ModulePathMap.find(Path);
1358 return I == ModulePathMap.end() ? -1 : (int)I->second;
1359}
1360
1362 // Check for uninitialized state and do lazy initialization.
1364
1365 // Find the GUID in the map
1366 guid_iterator I = GUIDMap.find(GUID);
1367 return I == GUIDMap.end() ? -1 : (int)I->second;
1368}
1369
1371 // Check for uninitialized state and do lazy initialization.
1373
1374 // Find the TypeId string in the map
1375 auto I = TypeIdMap.find(Id);
1376 return I == TypeIdMap.end() ? -1 : (int)I->second;
1377}
1378
1380 // Check for uninitialized state and do lazy initialization.
1382
1383 // Find the TypeIdCompatibleVtable string in the map
1384 auto I = TypeIdCompatibleVtableMap.find(Id);
1385 return I == TypeIdCompatibleVtableMap.end() ? -1 : (int)I->second;
1386}
1387
1388/// CreateModuleSlot - Insert the specified GlobalValue* into the slot table.
1389void SlotTracker::CreateModuleSlot(const GlobalValue *V) {
1390 assert(V && "Can't insert a null Value into SlotTracker!");
1391 assert(!V->getType()->isVoidTy() && "Doesn't need a slot!");
1392 assert(!V->hasName() && "Doesn't need a slot!");
1393
1394 unsigned DestSlot = mNext++;
1395 mMap[V] = DestSlot;
1396
1397 ST_DEBUG(" Inserting value [" << V->getType() << "] = " << V << " slot=" <<
1398 DestSlot << " [");
1399 // G = Global, F = Function, A = Alias, I = IFunc, o = other
1400 ST_DEBUG((isa<GlobalVariable>(V) ? 'G' :
1401 (isa<Function>(V) ? 'F' :
1402 (isa<GlobalAlias>(V) ? 'A' :
1403 (isa<GlobalIFunc>(V) ? 'I' : 'o')))) << "]\n");
1404}
1405
1406/// CreateSlot - Create a new slot for the specified value if it has no name.
1407void SlotTracker::CreateFunctionSlot(const Value *V) {
1408 assert(!V->getType()->isVoidTy() && !V->hasName() && "Doesn't need a slot!");
1409
1410 unsigned DestSlot = fNext++;
1411 fMap[V] = DestSlot;
1412
1413 // G = Global, F = Function, o = other
1414 ST_DEBUG(" Inserting value [" << V->getType() << "] = " << V << " slot=" <<
1415 DestSlot << " [o]\n");
1416}
1417
1418/// CreateModuleSlot - Insert the specified MDNode* into the slot table.
1419void SlotTracker::CreateMetadataSlot(const MDNode *N) {
1420 assert(N && "Can't insert a null Value into SlotTracker!");
1421
1422 // Don't make slots for DIExpressions. We just print them inline everywhere.
1423 if (isa<DIExpression>(N))
1424 return;
1425
1426 unsigned DestSlot = mdnNext;
1427 if (!mdnMap.insert(std::make_pair(N, DestSlot)).second)
1428 return;
1429 ++mdnNext;
1430
1431 // Recursively add any MDNodes referenced by operands.
1432 for (unsigned i = 0, e = N->getNumOperands(); i != e; ++i)
1433 if (const auto *Op = dyn_cast_or_null<MDNode>(N->getOperand(i)))
1434 CreateMetadataSlot(Op);
1435}
1436
1437void SlotTracker::CreateAttributeSetSlot(AttributeSet AS) {
1438 assert(AS.hasAttributes() && "Doesn't need a slot!");
1439
1440 if (asMap.try_emplace(AS, asNext).second)
1441 ++asNext;
1442}
1443
1444/// Create a new slot for the specified Module
1445void SlotTracker::CreateModulePathSlot(StringRef Path) {
1446 ModulePathMap[Path] = ModulePathNext++;
1447}
1448
1449/// Create a new slot for the specified GUID
1450void SlotTracker::CreateGUIDSlot(GlobalValue::GUID GUID) {
1451 GUIDMap[GUID] = GUIDNext++;
1452}
1453
1454/// Create a new slot for the specified Id
1455void SlotTracker::CreateTypeIdSlot(StringRef Id) {
1456 TypeIdMap[Id] = TypeIdNext++;
1457}
1458
1459/// Create a new slot for the specified Id
1460void SlotTracker::CreateTypeIdCompatibleVtableSlot(StringRef Id) {
1461 TypeIdCompatibleVtableMap[Id] = TypeIdCompatibleVtableNext++;
1462}
1463
1464namespace {
1465/// Common instances used by most of the printer functions.
1466struct AsmWriterContext {
1467 TypePrinting *TypePrinter = nullptr;
1468 SlotTracker *Machine = nullptr;
1469 const Module *Context = nullptr;
1470
1471 AsmWriterContext(TypePrinting *TP, SlotTracker *ST, const Module *M = nullptr)
1472 : TypePrinter(TP), Machine(ST), Context(M) {}
1473
1474 static AsmWriterContext &getEmpty() {
1475 static AsmWriterContext EmptyCtx(nullptr, nullptr);
1476 return EmptyCtx;
1477 }
1478
1479 /// A callback that will be triggered when the underlying printer
1480 /// prints a Metadata as operand.
1481 virtual void onWriteMetadataAsOperand(const Metadata *) {}
1482
1483 virtual ~AsmWriterContext() = default;
1484};
1485} // end anonymous namespace
1486
1487//===----------------------------------------------------------------------===//
1488// AsmWriter Implementation
1489//===----------------------------------------------------------------------===//
1490
1491static void writeAsOperandInternal(raw_ostream &Out, const Value *V,
1492 AsmWriterContext &WriterCtx,
1493 bool PrintType = false);
1494
1495static void writeAsOperandInternal(raw_ostream &Out, const Metadata *MD,
1496 AsmWriterContext &WriterCtx,
1497 bool FromValue = false);
1498
1499static void writeOptimizationInfo(raw_ostream &Out, const User *U) {
1500 if (const auto *FPO = dyn_cast<const FPMathOperator>(U))
1501 Out << FPO->getFastMathFlags();
1502
1503 if (const auto *OBO = dyn_cast<OverflowingBinaryOperator>(U)) {
1504 if (OBO->hasNoUnsignedWrap())
1505 Out << " nuw";
1506 if (OBO->hasNoSignedWrap())
1507 Out << " nsw";
1508 } else if (const auto *Div = dyn_cast<PossiblyExactOperator>(U)) {
1509 if (Div->isExact())
1510 Out << " exact";
1511 } else if (const auto *PDI = dyn_cast<PossiblyDisjointInst>(U)) {
1512 if (PDI->isDisjoint())
1513 Out << " disjoint";
1514 } else if (const auto *GEP = dyn_cast<GEPOperator>(U)) {
1515 if (GEP->isInBounds())
1516 Out << " inbounds";
1517 else if (GEP->hasNoUnsignedSignedWrap())
1518 Out << " nusw";
1519 if (GEP->hasNoUnsignedWrap())
1520 Out << " nuw";
1521 if (auto InRange = GEP->getInRange()) {
1522 Out << " inrange(" << InRange->getLower() << ", " << InRange->getUpper()
1523 << ")";
1524 }
1525 } else if (const auto *NNI = dyn_cast<PossiblyNonNegInst>(U)) {
1526 if (NNI->hasNonNeg())
1527 Out << " nneg";
1528 } else if (const auto *TI = dyn_cast<TruncInst>(U)) {
1529 if (TI->hasNoUnsignedWrap())
1530 Out << " nuw";
1531 if (TI->hasNoSignedWrap())
1532 Out << " nsw";
1533 } else if (const auto *ICmp = dyn_cast<ICmpInst>(U)) {
1534 if (ICmp->hasSameSign())
1535 Out << " samesign";
1536 }
1537}
1538
1539static void writeAPFloatInternal(raw_ostream &Out, const APFloat &APF) {
1540 if (&APF.getSemantics() == &APFloat::IEEEsingle() ||
1541 &APF.getSemantics() == &APFloat::IEEEdouble()) {
1542 // We would like to output the FP constant value in exponential notation,
1543 // but we cannot do this if doing so will lose precision. Check here to
1544 // make sure that we only output it in exponential format if we can parse
1545 // the value back and get the same value.
1546 //
1547 bool ignored;
1548 bool isDouble = &APF.getSemantics() == &APFloat::IEEEdouble();
1549 bool isInf = APF.isInfinity();
1550 bool isNaN = APF.isNaN();
1551
1552 if (!isInf && !isNaN) {
1553 double Val = APF.convertToDouble();
1554 SmallString<128> StrVal;
1555 APF.toString(StrVal, 6, 0, false);
1556 // Check to make sure that the stringized number is not some string like
1557 // "Inf" or NaN, that atof will accept, but the lexer will not. Check
1558 // that the string matches the "[-+]?[0-9]" regex.
1559 //
1560 assert((isDigit(StrVal[0]) ||
1561 ((StrVal[0] == '-' || StrVal[0] == '+') && isDigit(StrVal[1]))) &&
1562 "[-+]?[0-9] regex does not match!");
1563 // Reparse stringized version!
1564 if (APFloat(APFloat::IEEEdouble(), StrVal).convertToDouble() == Val) {
1565 Out << StrVal;
1566 return;
1567 }
1568 }
1569
1570 // Otherwise we could not reparse it to exactly the same value, so we must
1571 // output the string in hexadecimal format! Note that loading and storing
1572 // floating point types changes the bits of NaNs on some hosts, notably
1573 // x86, so we must not use these types.
1574 static_assert(sizeof(double) == sizeof(uint64_t),
1575 "assuming that double is 64 bits!");
1576 APFloat apf = APF;
1577
1578 // Floats are represented in ASCII IR as double, convert.
1579 // FIXME: We should allow 32-bit hex float and remove this.
1580 if (!isDouble) {
1581 // A signaling NaN is quieted on conversion, so we need to recreate the
1582 // expected value after convert (quiet bit of the payload is clear).
1583 bool IsSNAN = apf.isSignaling();
1585 &ignored);
1586 if (IsSNAN) {
1587 APInt Payload = apf.bitcastToAPInt();
1588 apf =
1590 }
1591 }
1592
1593 Out << format_hex(apf.bitcastToAPInt().getZExtValue(), 0, /*Upper=*/true);
1594 return;
1595 }
1596
1597 // Either half, bfloat or some form of long double.
1598 // These appear as a magic letter identifying the type, then a
1599 // fixed number of hex digits.
1600 Out << "0x";
1601 APInt API = APF.bitcastToAPInt();
1602 if (&APF.getSemantics() == &APFloat::x87DoubleExtended()) {
1603 Out << 'K';
1604 Out << format_hex_no_prefix(API.getHiBits(16).getZExtValue(), 4,
1605 /*Upper=*/true);
1606 Out << format_hex_no_prefix(API.getLoBits(64).getZExtValue(), 16,
1607 /*Upper=*/true);
1608 } else if (&APF.getSemantics() == &APFloat::IEEEquad()) {
1609 Out << 'L';
1610 Out << format_hex_no_prefix(API.getLoBits(64).getZExtValue(), 16,
1611 /*Upper=*/true);
1612 Out << format_hex_no_prefix(API.getHiBits(64).getZExtValue(), 16,
1613 /*Upper=*/true);
1614 } else if (&APF.getSemantics() == &APFloat::PPCDoubleDouble()) {
1615 Out << 'M';
1616 Out << format_hex_no_prefix(API.getLoBits(64).getZExtValue(), 16,
1617 /*Upper=*/true);
1618 Out << format_hex_no_prefix(API.getHiBits(64).getZExtValue(), 16,
1619 /*Upper=*/true);
1620 } else if (&APF.getSemantics() == &APFloat::IEEEhalf()) {
1621 Out << 'H';
1622 Out << format_hex_no_prefix(API.getZExtValue(), 4,
1623 /*Upper=*/true);
1624 } else if (&APF.getSemantics() == &APFloat::BFloat()) {
1625 Out << 'R';
1626 Out << format_hex_no_prefix(API.getZExtValue(), 4,
1627 /*Upper=*/true);
1628 } else
1629 llvm_unreachable("Unsupported floating point type");
1630}
1631
1632static void writeConstantInternal(raw_ostream &Out, const Constant *CV,
1633 AsmWriterContext &WriterCtx) {
1634 if (const auto *CI = dyn_cast<ConstantInt>(CV)) {
1635 Type *Ty = CI->getType();
1636
1637 if (Ty->isVectorTy()) {
1638 Out << "splat (";
1639 WriterCtx.TypePrinter->print(Ty->getScalarType(), Out);
1640 Out << " ";
1641 }
1642
1643 if (Ty->getScalarType()->isIntegerTy(1))
1644 Out << (CI->getZExtValue() ? "true" : "false");
1645 else
1646 Out << CI->getValue();
1647
1648 if (Ty->isVectorTy())
1649 Out << ")";
1650
1651 return;
1652 }
1653
1654 if (const auto *CB = dyn_cast<ConstantByte>(CV)) {
1655 Type *Ty = CB->getType();
1656
1657 if (Ty->isVectorTy()) {
1658 Out << "splat (";
1659 WriterCtx.TypePrinter->print(Ty->getScalarType(), Out);
1660 Out << " ";
1661 }
1662
1663 Out << CB->getValue();
1664
1665 if (Ty->isVectorTy())
1666 Out << ")";
1667
1668 return;
1669 }
1670
1671 if (const auto *CFP = dyn_cast<ConstantFP>(CV)) {
1672 Type *Ty = CFP->getType();
1673
1674 if (Ty->isVectorTy()) {
1675 Out << "splat (";
1676 WriterCtx.TypePrinter->print(Ty->getScalarType(), Out);
1677 Out << " ";
1678 }
1679
1680 writeAPFloatInternal(Out, CFP->getValueAPF());
1681
1682 if (Ty->isVectorTy())
1683 Out << ")";
1684
1685 return;
1686 }
1687
1689 Out << "zeroinitializer";
1690 return;
1691 }
1692
1693 if (const auto *BA = dyn_cast<BlockAddress>(CV)) {
1694 Out << "blockaddress(";
1695 writeAsOperandInternal(Out, BA->getFunction(), WriterCtx);
1696 Out << ", ";
1697 writeAsOperandInternal(Out, BA->getBasicBlock(), WriterCtx);
1698 Out << ")";
1699 return;
1700 }
1701
1702 if (const auto *Equiv = dyn_cast<DSOLocalEquivalent>(CV)) {
1703 Out << "dso_local_equivalent ";
1704 writeAsOperandInternal(Out, Equiv->getGlobalValue(), WriterCtx);
1705 return;
1706 }
1707
1708 if (const auto *NC = dyn_cast<NoCFIValue>(CV)) {
1709 Out << "no_cfi ";
1710 writeAsOperandInternal(Out, NC->getGlobalValue(), WriterCtx);
1711 return;
1712 }
1713
1714 if (const auto *CPA = dyn_cast<ConstantPtrAuth>(CV)) {
1715 Out << "ptrauth (";
1716
1717 // ptrauth (ptr CST, i32 KEY[, i64 DISC[, ptr ADDRDISC[, ptr DS]?]?]?)
1718 unsigned NumOpsToWrite = 2;
1719 if (!CPA->getOperand(2)->isNullValue())
1720 NumOpsToWrite = 3;
1721 if (!CPA->getOperand(3)->isNullValue())
1722 NumOpsToWrite = 4;
1723 if (!CPA->getOperand(4)->isNullValue())
1724 NumOpsToWrite = 5;
1725
1726 ListSeparator LS;
1727 for (unsigned i = 0, e = NumOpsToWrite; i != e; ++i) {
1728 Out << LS;
1729 writeAsOperandInternal(Out, CPA->getOperand(i), WriterCtx,
1730 /*PrintType=*/true);
1731 }
1732 Out << ')';
1733 return;
1734 }
1735
1736 if (const auto *CA = dyn_cast<ConstantArray>(CV)) {
1737 Out << '[';
1738 ListSeparator LS;
1739 for (const Value *Op : CA->operands()) {
1740 Out << LS;
1741 writeAsOperandInternal(Out, Op, WriterCtx, /*PrintType=*/true);
1742 }
1743 Out << ']';
1744 return;
1745 }
1746
1747 if (const auto *CA = dyn_cast<ConstantDataArray>(CV)) {
1748 // As a special case, print the array as a string if it is an array of
1749 // i8 with ConstantInt values.
1750 if (CA->isString()) {
1751 Out << "c\"";
1752 printEscapedString(CA->getAsString(), Out);
1753 Out << '"';
1754 return;
1755 }
1756
1757 Out << '[';
1758 ListSeparator LS;
1759 for (uint64_t i = 0, e = CA->getNumElements(); i != e; ++i) {
1760 Out << LS;
1761 writeAsOperandInternal(Out, CA->getElementAsConstant(i), WriterCtx,
1762 /*PrintType=*/true);
1763 }
1764 Out << ']';
1765 return;
1766 }
1767
1768 if (const auto *CS = dyn_cast<ConstantStruct>(CV)) {
1769 if (CS->getType()->isPacked())
1770 Out << '<';
1771 Out << '{';
1772 if (CS->getNumOperands() != 0) {
1773 Out << ' ';
1774 ListSeparator LS;
1775 for (const Value *Op : CS->operands()) {
1776 Out << LS;
1777 writeAsOperandInternal(Out, Op, WriterCtx, /*PrintType=*/true);
1778 }
1779 Out << ' ';
1780 }
1781 Out << '}';
1782 if (CS->getType()->isPacked())
1783 Out << '>';
1784 return;
1785 }
1786
1788 auto *CVVTy = cast<FixedVectorType>(CV->getType());
1789
1790 // Use the same shorthand for splat vector (i.e. "splat(Ty val)") as is
1791 // permitted on IR input to reduce the output changes when enabling
1792 // UseConstant{Int,FP}ForFixedLengthSplat.
1793 // TODO: Remove this block when the UseConstant{Int,FP}ForFixedLengthSplat
1794 // options are removed.
1795 if (auto *SplatVal = CV->getSplatValue()) {
1796 if (isa<ConstantInt>(SplatVal) || isa<ConstantFP>(SplatVal) ||
1797 isa<ConstantByte>(SplatVal)) {
1798 Out << "splat (";
1799 writeAsOperandInternal(Out, SplatVal, WriterCtx, /*PrintType=*/true);
1800 Out << ')';
1801 return;
1802 }
1803 }
1804
1805 Out << '<';
1806 ListSeparator LS;
1807 for (unsigned i = 0, e = CVVTy->getNumElements(); i != e; ++i) {
1808 Out << LS;
1809 writeAsOperandInternal(Out, CV->getAggregateElement(i), WriterCtx,
1810 /*PrintType=*/true);
1811 }
1812 Out << '>';
1813 return;
1814 }
1815
1816 if (isa<ConstantPointerNull>(CV)) {
1817 Out << "null";
1818 return;
1819 }
1820
1821 if (isa<ConstantTokenNone>(CV)) {
1822 Out << "none";
1823 return;
1824 }
1825
1826 if (isa<PoisonValue>(CV)) {
1827 Out << "poison";
1828 return;
1829 }
1830
1831 if (isa<UndefValue>(CV)) {
1832 Out << "undef";
1833 return;
1834 }
1835
1836 if (const auto *CE = dyn_cast<ConstantExpr>(CV)) {
1837 // Use the same shorthand for splat vector (i.e. "splat(Ty val)") as is
1838 // permitted on IR input to reduce the output changes when enabling
1839 // UseConstant{Int,FP}ForScalableSplat.
1840 // TODO: Remove this block when the UseConstant{Int,FP}ForScalableSplat
1841 // options are removed.
1842 if (CE->getOpcode() == Instruction::ShuffleVector) {
1843 if (auto *SplatVal = CE->getSplatValue()) {
1844 if (isa<ConstantInt>(SplatVal) || isa<ConstantFP>(SplatVal) ||
1845 isa<ConstantByte>(SplatVal)) {
1846 Out << "splat (";
1847 writeAsOperandInternal(Out, SplatVal, WriterCtx, /*PrintType=*/true);
1848 Out << ')';
1849 return;
1850 }
1851 }
1852 }
1853
1854 Out << CE->getOpcodeName();
1855 writeOptimizationInfo(Out, CE);
1856 Out << " (";
1857
1858 if (const auto *GEP = dyn_cast<GEPOperator>(CE)) {
1859 WriterCtx.TypePrinter->print(GEP->getSourceElementType(), Out);
1860 Out << ", ";
1861 }
1862
1863 ListSeparator LS;
1864 for (const Value *Op : CE->operands()) {
1865 Out << LS;
1866 writeAsOperandInternal(Out, Op, WriterCtx, /*PrintType=*/true);
1867 }
1868
1869 if (CE->isCast()) {
1870 Out << " to ";
1871 WriterCtx.TypePrinter->print(CE->getType(), Out);
1872 }
1873
1874 if (CE->getOpcode() == Instruction::ShuffleVector)
1875 printShuffleMask(Out, CE->getType(), CE->getShuffleMask());
1876
1877 Out << ')';
1878 return;
1879 }
1880
1881 Out << "<placeholder or erroneous Constant>";
1882}
1883
1884static void writeMDTuple(raw_ostream &Out, const MDTuple *Node,
1885 AsmWriterContext &WriterCtx) {
1886 Out << "!{";
1887 ListSeparator LS;
1888 for (const Metadata *MD : Node->operands()) {
1889 Out << LS;
1890 if (!MD) {
1891 Out << "null";
1892 } else if (auto *MDV = dyn_cast<ValueAsMetadata>(MD)) {
1893 Value *V = MDV->getValue();
1894 writeAsOperandInternal(Out, V, WriterCtx, /*PrintType=*/true);
1895 } else {
1896 writeAsOperandInternal(Out, MD, WriterCtx);
1897 WriterCtx.onWriteMetadataAsOperand(MD);
1898 }
1899 }
1900
1901 Out << "}";
1902}
1903
1904namespace {
1905
1906struct MDFieldPrinter {
1907 raw_ostream &Out;
1908 ListSeparator FS;
1909 AsmWriterContext &WriterCtx;
1910
1911 explicit MDFieldPrinter(raw_ostream &Out)
1912 : Out(Out), WriterCtx(AsmWriterContext::getEmpty()) {}
1913 MDFieldPrinter(raw_ostream &Out, AsmWriterContext &Ctx)
1914 : Out(Out), WriterCtx(Ctx) {}
1915
1916 void printTag(const DINode *N);
1917 void printMacinfoType(const DIMacroNode *N);
1918 void printChecksum(const DIFile::ChecksumInfo<StringRef> &N);
1919 void printString(StringRef Name, StringRef Value,
1920 bool ShouldSkipEmpty = true);
1921 void printMetadata(StringRef Name, const Metadata *MD,
1922 bool ShouldSkipNull = true);
1923 void printMetadataOrInt(StringRef Name, const Metadata *MD, bool IsUnsigned,
1924 bool ShouldSkipZero = true);
1925 template <class IntTy>
1926 void printInt(StringRef Name, IntTy Int, bool ShouldSkipZero = true);
1927 void printAPInt(StringRef Name, const APInt &Int, bool IsUnsigned,
1928 bool ShouldSkipZero);
1929 void printBool(StringRef Name, bool Value,
1930 std::optional<bool> Default = std::nullopt);
1931 void printDIFlags(StringRef Name, DINode::DIFlags Flags);
1932 void printDISPFlags(StringRef Name, DISubprogram::DISPFlags Flags);
1933 template <class IntTy, class Stringifier>
1934 void printDwarfEnum(StringRef Name, IntTy Value, Stringifier toString,
1935 bool ShouldSkipZero = true);
1936 void printEmissionKind(StringRef Name, DICompileUnit::DebugEmissionKind EK);
1937 void printNameTableKind(StringRef Name,
1939 void printFixedPointKind(StringRef Name, DIFixedPointType::FixedPointKind V);
1940};
1941
1942} // end anonymous namespace
1943
1944void MDFieldPrinter::printTag(const DINode *N) {
1945 Out << FS << "tag: ";
1946 auto Tag = dwarf::TagString(N->getTag());
1947 if (!Tag.empty())
1948 Out << Tag;
1949 else
1950 Out << N->getTag();
1951}
1952
1953void MDFieldPrinter::printMacinfoType(const DIMacroNode *N) {
1954 Out << FS << "type: ";
1955 auto Type = dwarf::MacinfoString(N->getMacinfoType());
1956 if (!Type.empty())
1957 Out << Type;
1958 else
1959 Out << N->getMacinfoType();
1960}
1961
1962void MDFieldPrinter::printChecksum(
1963 const DIFile::ChecksumInfo<StringRef> &Checksum) {
1964 Out << FS << "checksumkind: " << Checksum.getKindAsString();
1965 printString("checksum", Checksum.Value, /* ShouldSkipEmpty */ false);
1966}
1967
1968void MDFieldPrinter::printString(StringRef Name, StringRef Value,
1969 bool ShouldSkipEmpty) {
1970 if (ShouldSkipEmpty && Value.empty())
1971 return;
1972
1973 Out << FS << Name << ": \"";
1975 Out << "\"";
1976}
1977
1978static void writeMetadataAsOperand(raw_ostream &Out, const Metadata *MD,
1979 AsmWriterContext &WriterCtx) {
1980 if (!MD) {
1981 Out << "null";
1982 return;
1983 }
1984 writeAsOperandInternal(Out, MD, WriterCtx);
1985 WriterCtx.onWriteMetadataAsOperand(MD);
1986}
1987
1988void MDFieldPrinter::printMetadata(StringRef Name, const Metadata *MD,
1989 bool ShouldSkipNull) {
1990 if (ShouldSkipNull && !MD)
1991 return;
1992
1993 Out << FS << Name << ": ";
1994 writeMetadataAsOperand(Out, MD, WriterCtx);
1995}
1996
1997void MDFieldPrinter::printMetadataOrInt(StringRef Name, const Metadata *MD,
1998 bool IsUnsigned, bool ShouldSkipZero) {
1999 if (!MD)
2000 return;
2001
2002 if (auto *CI = dyn_cast<ConstantAsMetadata>(MD)) {
2003 auto *CV = cast<ConstantInt>(CI->getValue());
2004 if (IsUnsigned)
2005 printInt(Name, CV->getZExtValue(), ShouldSkipZero);
2006 else
2007 printInt(Name, CV->getSExtValue(), ShouldSkipZero);
2008 } else
2009 printMetadata(Name, MD);
2010}
2011
2012template <class IntTy>
2013void MDFieldPrinter::printInt(StringRef Name, IntTy Int, bool ShouldSkipZero) {
2014 if (ShouldSkipZero && !Int)
2015 return;
2016
2017 Out << FS << Name << ": " << Int;
2018}
2019
2020void MDFieldPrinter::printAPInt(StringRef Name, const APInt &Int,
2021 bool IsUnsigned, bool ShouldSkipZero) {
2022 if (ShouldSkipZero && Int.isZero())
2023 return;
2024
2025 Out << FS << Name << ": ";
2026 Int.print(Out, !IsUnsigned);
2027}
2028
2029void MDFieldPrinter::printBool(StringRef Name, bool Value,
2030 std::optional<bool> Default) {
2031 if (Default && Value == *Default)
2032 return;
2033 Out << FS << Name << ": " << (Value ? "true" : "false");
2034}
2035
2036void MDFieldPrinter::printDIFlags(StringRef Name, DINode::DIFlags Flags) {
2037 if (!Flags)
2038 return;
2039
2040 Out << FS << Name << ": ";
2041
2043 auto Extra = DINode::splitFlags(Flags, SplitFlags);
2044
2045 ListSeparator FlagsFS(" | ");
2046 for (auto F : SplitFlags) {
2047 auto StringF = DINode::getFlagString(F);
2048 assert(!StringF.empty() && "Expected valid flag");
2049 Out << FlagsFS << StringF;
2050 }
2051 if (Extra || SplitFlags.empty())
2052 Out << FlagsFS << Extra;
2053}
2054
2055void MDFieldPrinter::printDISPFlags(StringRef Name,
2057 // Always print this field, because no flags in the IR at all will be
2058 // interpreted as old-style isDefinition: true.
2059 Out << FS << Name << ": ";
2060
2061 if (!Flags) {
2062 Out << 0;
2063 return;
2064 }
2065
2067 auto Extra = DISubprogram::splitFlags(Flags, SplitFlags);
2068
2069 ListSeparator FlagsFS(" | ");
2070 for (auto F : SplitFlags) {
2071 auto StringF = DISubprogram::getFlagString(F);
2072 assert(!StringF.empty() && "Expected valid flag");
2073 Out << FlagsFS << StringF;
2074 }
2075 if (Extra || SplitFlags.empty())
2076 Out << FlagsFS << Extra;
2077}
2078
2079void MDFieldPrinter::printEmissionKind(StringRef Name,
2081 Out << FS << Name << ": " << DICompileUnit::emissionKindString(EK);
2082}
2083
2084void MDFieldPrinter::printNameTableKind(StringRef Name,
2087 return;
2088 Out << FS << Name << ": " << DICompileUnit::nameTableKindString(NTK);
2089}
2090
2091void MDFieldPrinter::printFixedPointKind(StringRef Name,
2093 Out << FS << Name << ": " << DIFixedPointType::fixedPointKindString(V);
2094}
2095
2096template <class IntTy, class Stringifier>
2097void MDFieldPrinter::printDwarfEnum(StringRef Name, IntTy Value,
2098 Stringifier toString, bool ShouldSkipZero) {
2099 if (ShouldSkipZero && !Value)
2100 return;
2101
2102 Out << FS << Name << ": ";
2103 auto S = toString(Value);
2104 if (!S.empty())
2105 Out << S;
2106 else
2107 Out << Value;
2108}
2109
2111 AsmWriterContext &WriterCtx) {
2112 Out << "!GenericDINode(";
2113 MDFieldPrinter Printer(Out, WriterCtx);
2114 Printer.printTag(N);
2115 Printer.printString("header", N->getHeader());
2116 if (N->getNumDwarfOperands()) {
2117 Out << Printer.FS << "operands: {";
2118 ListSeparator IFS;
2119 for (auto &I : N->dwarf_operands()) {
2120 Out << IFS;
2121 writeMetadataAsOperand(Out, I, WriterCtx);
2122 }
2123 Out << "}";
2124 }
2125 Out << ")";
2126}
2127
2128static void writeDILocation(raw_ostream &Out, const DILocation *DL,
2129 AsmWriterContext &WriterCtx) {
2130 Out << "!DILocation(";
2131 MDFieldPrinter Printer(Out, WriterCtx);
2132 // Always output the line, since 0 is a relevant and important value for it.
2133 Printer.printInt("line", DL->getLine(), /* ShouldSkipZero */ false);
2134 Printer.printInt("column", DL->getColumn());
2135 Printer.printMetadata("scope", DL->getRawScope(), /* ShouldSkipNull */ false);
2136 Printer.printMetadata("inlinedAt", DL->getRawInlinedAt());
2137 Printer.printBool("isImplicitCode", DL->isImplicitCode(),
2138 /* Default */ false);
2139 Printer.printInt("atomGroup", DL->getAtomGroup());
2140 Printer.printInt<unsigned>("atomRank", DL->getAtomRank());
2141 Out << ")";
2142}
2143
2144static void writeDIAssignID(raw_ostream &Out, const DIAssignID *DL,
2145 AsmWriterContext &WriterCtx) {
2146 Out << "!DIAssignID()";
2147 MDFieldPrinter Printer(Out, WriterCtx);
2148}
2149
2150static void writeDISubrange(raw_ostream &Out, const DISubrange *N,
2151 AsmWriterContext &WriterCtx) {
2152 Out << "!DISubrange(";
2153 MDFieldPrinter Printer(Out, WriterCtx);
2154
2155 Printer.printMetadataOrInt("count", N->getRawCountNode(),
2156 /* IsUnsigned */ false,
2157 /* ShouldSkipZero */ false);
2158
2159 // A lowerBound of constant 0 should not be skipped, since it is different
2160 // from an unspecified lower bound (= nullptr).
2161 Printer.printMetadataOrInt("lowerBound", N->getRawLowerBound(),
2162 /* IsUnsigned */ false,
2163 /* ShouldSkipZero */ false);
2164 Printer.printMetadataOrInt("upperBound", N->getRawUpperBound(),
2165 /* IsUnsigned */ false,
2166 /* ShouldSkipZero */ false);
2167 Printer.printMetadataOrInt("stride", N->getRawStride(),
2168 /* IsUnsigned */ false,
2169 /* ShouldSkipZero */ false);
2170
2171 Out << ")";
2172}
2173
2175 AsmWriterContext &WriterCtx) {
2176 Out << "!DIGenericSubrange(";
2177 MDFieldPrinter Printer(Out, WriterCtx);
2178
2179 auto GetConstant = [&](Metadata *Bound) -> std::optional<int64_t> {
2180 auto *BE = dyn_cast_or_null<DIExpression>(Bound);
2181 if (!BE)
2182 return std::nullopt;
2183 if (BE->isConstant() &&
2185 *BE->isConstant()) {
2186 return static_cast<int64_t>(BE->getElement(1));
2187 }
2188 return std::nullopt;
2189 };
2190
2191 auto *Count = N->getRawCountNode();
2192 if (auto ConstantCount = GetConstant(Count))
2193 Printer.printInt("count", *ConstantCount,
2194 /* ShouldSkipZero */ false);
2195 else
2196 Printer.printMetadata("count", Count, /*ShouldSkipNull */ true);
2197
2198 auto *LBound = N->getRawLowerBound();
2199 if (auto ConstantLBound = GetConstant(LBound))
2200 Printer.printInt("lowerBound", *ConstantLBound,
2201 /* ShouldSkipZero */ false);
2202 else
2203 Printer.printMetadata("lowerBound", LBound, /*ShouldSkipNull */ true);
2204
2205 auto *UBound = N->getRawUpperBound();
2206 if (auto ConstantUBound = GetConstant(UBound))
2207 Printer.printInt("upperBound", *ConstantUBound,
2208 /* ShouldSkipZero */ false);
2209 else
2210 Printer.printMetadata("upperBound", UBound, /*ShouldSkipNull */ true);
2211
2212 auto *Stride = N->getRawStride();
2213 if (auto ConstantStride = GetConstant(Stride))
2214 Printer.printInt("stride", *ConstantStride,
2215 /* ShouldSkipZero */ false);
2216 else
2217 Printer.printMetadata("stride", Stride, /*ShouldSkipNull */ true);
2218
2219 Out << ")";
2220}
2221
2223 AsmWriterContext &) {
2224 Out << "!DIEnumerator(";
2225 MDFieldPrinter Printer(Out);
2226 Printer.printString("name", N->getName(), /* ShouldSkipEmpty */ false);
2227 Printer.printAPInt("value", N->getValue(), N->isUnsigned(),
2228 /*ShouldSkipZero=*/false);
2229 if (N->isUnsigned())
2230 Printer.printBool("isUnsigned", true);
2231 Out << ")";
2232}
2233
2235 AsmWriterContext &WriterCtx) {
2236 Out << "!DIBasicType(";
2237 MDFieldPrinter Printer(Out, WriterCtx);
2238 if (N->getTag() != dwarf::DW_TAG_base_type)
2239 Printer.printTag(N);
2240 Printer.printString("name", N->getName());
2241 Printer.printMetadata("scope", N->getRawScope());
2242 Printer.printMetadata("file", N->getRawFile());
2243 Printer.printInt("line", N->getLine());
2244 Printer.printMetadataOrInt("size", N->getRawSizeInBits(), true);
2245 Printer.printInt("align", N->getAlignInBits());
2246 Printer.printInt("dataSize", N->getDataSizeInBits());
2247 Printer.printDwarfEnum("encoding", N->getEncoding(),
2249 Printer.printInt("num_extra_inhabitants", N->getNumExtraInhabitants());
2250 Printer.printDIFlags("flags", N->getFlags());
2251 Out << ")";
2252}
2253
2255 AsmWriterContext &WriterCtx) {
2256 Out << "!DIFixedPointType(";
2257 MDFieldPrinter Printer(Out, WriterCtx);
2258 if (N->getTag() != dwarf::DW_TAG_base_type)
2259 Printer.printTag(N);
2260 Printer.printString("name", N->getName());
2261 Printer.printMetadata("scope", N->getRawScope());
2262 Printer.printMetadata("file", N->getRawFile());
2263 Printer.printInt("line", N->getLine());
2264 Printer.printMetadataOrInt("size", N->getRawSizeInBits(), true);
2265 Printer.printInt("align", N->getAlignInBits());
2266 Printer.printDwarfEnum("encoding", N->getEncoding(),
2268 Printer.printDIFlags("flags", N->getFlags());
2269 Printer.printFixedPointKind("kind", N->getKind());
2270 if (N->isRational()) {
2271 bool IsUnsigned = !N->isSigned();
2272 Printer.printAPInt("numerator", N->getNumerator(), IsUnsigned, false);
2273 Printer.printAPInt("denominator", N->getDenominator(), IsUnsigned, false);
2274 } else {
2275 Printer.printInt("factor", N->getFactor());
2276 }
2277 Out << ")";
2278}
2279
2281 AsmWriterContext &WriterCtx) {
2282 Out << "!DIStringType(";
2283 MDFieldPrinter Printer(Out, WriterCtx);
2284 if (N->getTag() != dwarf::DW_TAG_string_type)
2285 Printer.printTag(N);
2286 Printer.printString("name", N->getName());
2287 Printer.printMetadata("stringLength", N->getRawStringLength());
2288 Printer.printMetadata("stringLengthExpression", N->getRawStringLengthExp());
2289 Printer.printMetadata("stringLocationExpression",
2290 N->getRawStringLocationExp());
2291 Printer.printMetadataOrInt("size", N->getRawSizeInBits(), true);
2292 Printer.printInt("align", N->getAlignInBits());
2293 Printer.printDwarfEnum("encoding", N->getEncoding(),
2295 Out << ")";
2296}
2297
2299 AsmWriterContext &WriterCtx) {
2300 Out << "!DIDerivedType(";
2301 MDFieldPrinter Printer(Out, WriterCtx);
2302 Printer.printTag(N);
2303 Printer.printString("name", N->getName());
2304 Printer.printMetadata("scope", N->getRawScope());
2305 Printer.printMetadata("file", N->getRawFile());
2306 Printer.printInt("line", N->getLine());
2307 Printer.printMetadata("baseType", N->getRawBaseType(),
2308 /* ShouldSkipNull */ false);
2309 Printer.printMetadataOrInt("size", N->getRawSizeInBits(), true);
2310 Printer.printInt("align", N->getAlignInBits());
2311 Printer.printMetadataOrInt("offset", N->getRawOffsetInBits(), true);
2312 Printer.printDIFlags("flags", N->getFlags());
2313 Printer.printMetadata("extraData", N->getRawExtraData());
2314 if (const auto &DWARFAddressSpace = N->getDWARFAddressSpace())
2315 Printer.printInt("dwarfAddressSpace", *DWARFAddressSpace,
2316 /* ShouldSkipZero */ false);
2317 Printer.printMetadata("annotations", N->getRawAnnotations());
2318 if (auto PtrAuthData = N->getPtrAuthData()) {
2319 Printer.printInt("ptrAuthKey", PtrAuthData->key());
2320 Printer.printBool("ptrAuthIsAddressDiscriminated",
2321 PtrAuthData->isAddressDiscriminated());
2322 Printer.printInt("ptrAuthExtraDiscriminator",
2323 PtrAuthData->extraDiscriminator());
2324 Printer.printBool("ptrAuthIsaPointer", PtrAuthData->isaPointer());
2325 Printer.printBool("ptrAuthAuthenticatesNullValues",
2326 PtrAuthData->authenticatesNullValues());
2327 }
2328 Out << ")";
2329}
2330
2332 AsmWriterContext &WriterCtx) {
2333 Out << "!DISubrangeType(";
2334 MDFieldPrinter Printer(Out, WriterCtx);
2335 Printer.printString("name", N->getName());
2336 Printer.printMetadata("scope", N->getRawScope());
2337 Printer.printMetadata("file", N->getRawFile());
2338 Printer.printInt("line", N->getLine());
2339 Printer.printMetadataOrInt("size", N->getRawSizeInBits(), true);
2340 Printer.printInt("align", N->getAlignInBits());
2341 Printer.printDIFlags("flags", N->getFlags());
2342 Printer.printMetadata("baseType", N->getRawBaseType(),
2343 /* ShouldSkipNull */ false);
2344 Printer.printMetadata("lowerBound", N->getRawLowerBound());
2345 Printer.printMetadata("upperBound", N->getRawUpperBound());
2346 Printer.printMetadata("stride", N->getRawStride());
2347 Printer.printMetadata("bias", N->getRawBias());
2348 Out << ")";
2349}
2350
2352 AsmWriterContext &WriterCtx) {
2353 Out << "!DICompositeType(";
2354 MDFieldPrinter Printer(Out, WriterCtx);
2355 Printer.printTag(N);
2356 Printer.printString("name", N->getName());
2357 Printer.printMetadata("scope", N->getRawScope());
2358 Printer.printMetadata("file", N->getRawFile());
2359 Printer.printInt("line", N->getLine());
2360 Printer.printMetadata("baseType", N->getRawBaseType());
2361 Printer.printMetadataOrInt("size", N->getRawSizeInBits(), true);
2362 Printer.printInt("align", N->getAlignInBits());
2363 Printer.printMetadataOrInt("offset", N->getRawOffsetInBits(), true);
2364 Printer.printInt("num_extra_inhabitants", N->getNumExtraInhabitants());
2365 Printer.printDIFlags("flags", N->getFlags());
2366 Printer.printMetadata("elements", N->getRawElements());
2367 Printer.printDwarfEnum("runtimeLang", N->getRuntimeLang(),
2369 Printer.printMetadata("vtableHolder", N->getRawVTableHolder());
2370 Printer.printMetadata("templateParams", N->getRawTemplateParams());
2371 Printer.printString("identifier", N->getIdentifier());
2372 Printer.printMetadata("discriminator", N->getRawDiscriminator());
2373 Printer.printMetadata("dataLocation", N->getRawDataLocation());
2374 Printer.printMetadata("associated", N->getRawAssociated());
2375 Printer.printMetadata("allocated", N->getRawAllocated());
2376 if (auto *RankConst = N->getRankConst())
2377 Printer.printInt("rank", RankConst->getSExtValue(),
2378 /* ShouldSkipZero */ false);
2379 else
2380 Printer.printMetadata("rank", N->getRawRank(), /*ShouldSkipNull */ true);
2381 Printer.printMetadata("annotations", N->getRawAnnotations());
2382 if (auto *Specification = N->getRawSpecification())
2383 Printer.printMetadata("specification", Specification);
2384
2385 if (auto EnumKind = N->getEnumKind())
2386 Printer.printDwarfEnum("enumKind", *EnumKind, dwarf::EnumKindString,
2387 /*ShouldSkipZero=*/false);
2388
2389 Printer.printMetadata("bitStride", N->getRawBitStride());
2390 Out << ")";
2391}
2392
2394 AsmWriterContext &WriterCtx) {
2395 Out << "!DISubroutineType(";
2396 MDFieldPrinter Printer(Out, WriterCtx);
2397 Printer.printDIFlags("flags", N->getFlags());
2398 Printer.printDwarfEnum("cc", N->getCC(), dwarf::ConventionString);
2399 Printer.printMetadata("types", N->getRawTypeArray(),
2400 /* ShouldSkipNull */ false);
2401 Out << ")";
2402}
2403
2404static void writeDIFile(raw_ostream &Out, const DIFile *N, AsmWriterContext &) {
2405 Out << "!DIFile(";
2406 MDFieldPrinter Printer(Out);
2407 Printer.printString("filename", N->getFilename(),
2408 /* ShouldSkipEmpty */ false);
2409 Printer.printString("directory", N->getDirectory(),
2410 /* ShouldSkipEmpty */ false);
2411 // Print all values for checksum together, or not at all.
2412 if (N->getChecksum())
2413 Printer.printChecksum(*N->getChecksum());
2414 if (N->getSource())
2415 Printer.printString("source", *N->getSource(),
2416 /* ShouldSkipEmpty */ false);
2417 Out << ")";
2418}
2419
2421 AsmWriterContext &WriterCtx) {
2422 Out << "!DICompileUnit(";
2423 MDFieldPrinter Printer(Out, WriterCtx);
2424
2425 DISourceLanguageName Lang = N->getSourceLanguage();
2426
2427 if (Lang.hasVersionedName()) {
2428 Printer.printDwarfEnum(
2429 "sourceLanguageName",
2430 static_cast<llvm::dwarf::SourceLanguageName>(Lang.getName()),
2432 /* ShouldSkipZero */ false);
2433
2434 Printer.printInt("sourceLanguageVersion", Lang.getVersion(),
2435 /*ShouldSkipZero=*/true);
2436 } else {
2437 Printer.printDwarfEnum("language", Lang.getName(), dwarf::LanguageString,
2438 /* ShouldSkipZero */ false);
2439 }
2440
2441 Printer.printMetadata("file", N->getRawFile(), /* ShouldSkipNull */ false);
2442 Printer.printString("producer", N->getProducer());
2443 Printer.printBool("isOptimized", N->isOptimized());
2444 Printer.printString("flags", N->getFlags());
2445 Printer.printInt("runtimeVersion", N->getRuntimeVersion(),
2446 /* ShouldSkipZero */ false);
2447 Printer.printString("splitDebugFilename", N->getSplitDebugFilename());
2448 Printer.printEmissionKind("emissionKind", N->getEmissionKind());
2449 Printer.printMetadata("enums", N->getRawEnumTypes());
2450 Printer.printMetadata("retainedTypes", N->getRawRetainedTypes());
2451 Printer.printMetadata("globals", N->getRawGlobalVariables());
2452 Printer.printMetadata("imports", N->getRawImportedEntities());
2453 Printer.printMetadata("macros", N->getRawMacros());
2454 Printer.printInt("dwoId", N->getDWOId());
2455 Printer.printBool("splitDebugInlining", N->getSplitDebugInlining(), true);
2456 Printer.printBool("debugInfoForProfiling", N->getDebugInfoForProfiling(),
2457 false);
2458 Printer.printNameTableKind("nameTableKind", N->getNameTableKind());
2459 Printer.printBool("rangesBaseAddress", N->getRangesBaseAddress(), false);
2460 Printer.printString("sysroot", N->getSysRoot());
2461 Printer.printString("sdk", N->getSDK());
2462 Out << ")";
2463}
2464
2466 AsmWriterContext &WriterCtx) {
2467 Out << "!DISubprogram(";
2468 MDFieldPrinter Printer(Out, WriterCtx);
2469 Printer.printString("name", N->getName());
2470 Printer.printString("linkageName", N->getLinkageName());
2471 Printer.printMetadata("scope", N->getRawScope(), /* ShouldSkipNull */ false);
2472 Printer.printMetadata("file", N->getRawFile());
2473 Printer.printInt("line", N->getLine());
2474 Printer.printMetadata("type", N->getRawType());
2475 Printer.printInt("scopeLine", N->getScopeLine());
2476 Printer.printMetadata("containingType", N->getRawContainingType());
2477 if (N->getVirtuality() != dwarf::DW_VIRTUALITY_none ||
2478 N->getVirtualIndex() != 0)
2479 Printer.printInt("virtualIndex", N->getVirtualIndex(), false);
2480 Printer.printInt("thisAdjustment", N->getThisAdjustment());
2481 Printer.printDIFlags("flags", N->getFlags());
2482 Printer.printDISPFlags("spFlags", N->getSPFlags());
2483 Printer.printMetadata("unit", N->getRawUnit());
2484 Printer.printMetadata("templateParams", N->getRawTemplateParams());
2485 Printer.printMetadata("declaration", N->getRawDeclaration());
2486 Printer.printMetadata("retainedNodes", N->getRawRetainedNodes());
2487 Printer.printMetadata("thrownTypes", N->getRawThrownTypes());
2488 Printer.printMetadata("annotations", N->getRawAnnotations());
2489 Printer.printString("targetFuncName", N->getTargetFuncName());
2490 Printer.printBool("keyInstructions", N->getKeyInstructionsEnabled(), false);
2491 Out << ")";
2492}
2493
2495 AsmWriterContext &WriterCtx) {
2496 Out << "!DILexicalBlock(";
2497 MDFieldPrinter Printer(Out, WriterCtx);
2498 Printer.printMetadata("scope", N->getRawScope(), /* ShouldSkipNull */ false);
2499 Printer.printMetadata("file", N->getRawFile());
2500 Printer.printInt("line", N->getLine());
2501 Printer.printInt("column", N->getColumn());
2502 Out << ")";
2503}
2504
2506 const DILexicalBlockFile *N,
2507 AsmWriterContext &WriterCtx) {
2508 Out << "!DILexicalBlockFile(";
2509 MDFieldPrinter Printer(Out, WriterCtx);
2510 Printer.printMetadata("scope", N->getRawScope(), /* ShouldSkipNull */ false);
2511 Printer.printMetadata("file", N->getRawFile());
2512 Printer.printInt("discriminator", N->getDiscriminator(),
2513 /* ShouldSkipZero */ false);
2514 Out << ")";
2515}
2516
2518 AsmWriterContext &WriterCtx) {
2519 Out << "!DINamespace(";
2520 MDFieldPrinter Printer(Out, WriterCtx);
2521 Printer.printString("name", N->getName());
2522 Printer.printMetadata("scope", N->getRawScope(), /* ShouldSkipNull */ false);
2523 Printer.printBool("exportSymbols", N->getExportSymbols(), false);
2524 Out << ")";
2525}
2526
2528 AsmWriterContext &WriterCtx) {
2529 Out << "!DICommonBlock(";
2530 MDFieldPrinter Printer(Out, WriterCtx);
2531 Printer.printMetadata("scope", N->getRawScope(), false);
2532 Printer.printMetadata("declaration", N->getRawDecl(), false);
2533 Printer.printString("name", N->getName());
2534 Printer.printMetadata("file", N->getRawFile());
2535 Printer.printInt("line", N->getLineNo());
2536 Out << ")";
2537}
2538
2539static void writeDIMacro(raw_ostream &Out, const DIMacro *N,
2540 AsmWriterContext &WriterCtx) {
2541 Out << "!DIMacro(";
2542 MDFieldPrinter Printer(Out, WriterCtx);
2543 Printer.printMacinfoType(N);
2544 Printer.printInt("line", N->getLine());
2545 Printer.printString("name", N->getName());
2546 Printer.printString("value", N->getValue());
2547 Out << ")";
2548}
2549
2551 AsmWriterContext &WriterCtx) {
2552 Out << "!DIMacroFile(";
2553 MDFieldPrinter Printer(Out, WriterCtx);
2554 Printer.printInt("line", N->getLine());
2555 Printer.printMetadata("file", N->getRawFile(), /* ShouldSkipNull */ false);
2556 Printer.printMetadata("nodes", N->getRawElements());
2557 Out << ")";
2558}
2559
2560static void writeDIModule(raw_ostream &Out, const DIModule *N,
2561 AsmWriterContext &WriterCtx) {
2562 Out << "!DIModule(";
2563 MDFieldPrinter Printer(Out, WriterCtx);
2564 Printer.printMetadata("scope", N->getRawScope(), /* ShouldSkipNull */ false);
2565 Printer.printString("name", N->getName());
2566 Printer.printString("configMacros", N->getConfigurationMacros());
2567 Printer.printString("includePath", N->getIncludePath());
2568 Printer.printString("apinotes", N->getAPINotesFile());
2569 Printer.printMetadata("file", N->getRawFile());
2570 Printer.printInt("line", N->getLineNo());
2571 Printer.printBool("isDecl", N->getIsDecl(), /* Default */ false);
2572 Out << ")";
2573}
2574
2577 AsmWriterContext &WriterCtx) {
2578 Out << "!DITemplateTypeParameter(";
2579 MDFieldPrinter Printer(Out, WriterCtx);
2580 Printer.printString("name", N->getName());
2581 Printer.printMetadata("type", N->getRawType(), /* ShouldSkipNull */ false);
2582 Printer.printBool("defaulted", N->isDefault(), /* Default= */ false);
2583 Out << ")";
2584}
2585
2588 AsmWriterContext &WriterCtx) {
2589 Out << "!DITemplateValueParameter(";
2590 MDFieldPrinter Printer(Out, WriterCtx);
2591 if (N->getTag() != dwarf::DW_TAG_template_value_parameter)
2592 Printer.printTag(N);
2593 Printer.printString("name", N->getName());
2594 Printer.printMetadata("type", N->getRawType());
2595 Printer.printBool("defaulted", N->isDefault(), /* Default= */ false);
2596 Printer.printMetadata("value", N->getValue(), /* ShouldSkipNull */ false);
2597 Out << ")";
2598}
2599
2601 AsmWriterContext &WriterCtx) {
2602 Out << "!DIGlobalVariable(";
2603 MDFieldPrinter Printer(Out, WriterCtx);
2604 Printer.printString("name", N->getName());
2605 Printer.printString("linkageName", N->getLinkageName());
2606 Printer.printMetadata("scope", N->getRawScope(), /* ShouldSkipNull */ false);
2607 Printer.printMetadata("file", N->getRawFile());
2608 Printer.printInt("line", N->getLine());
2609 Printer.printMetadata("type", N->getRawType());
2610 Printer.printBool("isLocal", N->isLocalToUnit());
2611 Printer.printBool("isDefinition", N->isDefinition());
2612 Printer.printMetadata("declaration", N->getRawStaticDataMemberDeclaration());
2613 Printer.printMetadata("templateParams", N->getRawTemplateParams());
2614 Printer.printInt("align", N->getAlignInBits());
2615 Printer.printMetadata("annotations", N->getRawAnnotations());
2616 Out << ")";
2617}
2618
2620 AsmWriterContext &WriterCtx) {
2621 Out << "!DILocalVariable(";
2622 MDFieldPrinter Printer(Out, WriterCtx);
2623 Printer.printString("name", N->getName());
2624 Printer.printInt("arg", N->getArg());
2625 Printer.printMetadata("scope", N->getRawScope(), /* ShouldSkipNull */ false);
2626 Printer.printMetadata("file", N->getRawFile());
2627 Printer.printInt("line", N->getLine());
2628 Printer.printMetadata("type", N->getRawType());
2629 Printer.printDIFlags("flags", N->getFlags());
2630 Printer.printInt("align", N->getAlignInBits());
2631 Printer.printMetadata("annotations", N->getRawAnnotations());
2632 Out << ")";
2633}
2634
2635static void writeDILabel(raw_ostream &Out, const DILabel *N,
2636 AsmWriterContext &WriterCtx) {
2637 Out << "!DILabel(";
2638 MDFieldPrinter Printer(Out, WriterCtx);
2639 Printer.printMetadata("scope", N->getRawScope(), /* ShouldSkipNull */ false);
2640 Printer.printString("name", N->getName());
2641 Printer.printMetadata("file", N->getRawFile());
2642 Printer.printInt("line", N->getLine());
2643 Printer.printInt("column", N->getColumn());
2644 Printer.printBool("isArtificial", N->isArtificial(), false);
2645 if (N->getCoroSuspendIdx())
2646 Printer.printInt("coroSuspendIdx", *N->getCoroSuspendIdx(),
2647 /* ShouldSkipZero */ false);
2648 Out << ")";
2649}
2650
2652 AsmWriterContext &WriterCtx) {
2653 Out << "!DIExpression(";
2654 ListSeparator FS;
2655 if (N->isValid()) {
2656 for (const DIExpression::ExprOperand &Op : N->expr_ops()) {
2657 auto OpStr = dwarf::OperationEncodingString(Op.getOp());
2658 assert(!OpStr.empty() && "Expected valid opcode");
2659
2660 Out << FS << OpStr;
2661 if (Op.getOp() == dwarf::DW_OP_LLVM_convert) {
2662 Out << FS << Op.getArg(0);
2663 Out << FS << dwarf::AttributeEncodingString(Op.getArg(1));
2664 } else {
2665 for (unsigned A = 0, AE = Op.getNumArgs(); A != AE; ++A)
2666 Out << FS << Op.getArg(A);
2667 }
2668 }
2669 } else {
2670 for (const auto &I : N->getElements())
2671 Out << FS << I;
2672 }
2673 Out << ")";
2674}
2675
2676static void writeDIArgList(raw_ostream &Out, const DIArgList *N,
2677 AsmWriterContext &WriterCtx,
2678 bool FromValue = false) {
2679 assert(FromValue &&
2680 "Unexpected DIArgList metadata outside of value argument");
2681 Out << "!DIArgList(";
2682 ListSeparator FS;
2683 MDFieldPrinter Printer(Out, WriterCtx);
2684 for (const Metadata *Arg : N->getArgs()) {
2685 Out << FS;
2686 writeAsOperandInternal(Out, Arg, WriterCtx, true);
2687 }
2688 Out << ")";
2689}
2690
2693 AsmWriterContext &WriterCtx) {
2694 Out << "!DIGlobalVariableExpression(";
2695 MDFieldPrinter Printer(Out, WriterCtx);
2696 Printer.printMetadata("var", N->getVariable());
2697 Printer.printMetadata("expr", N->getExpression());
2698 Out << ")";
2699}
2700
2702 AsmWriterContext &WriterCtx) {
2703 Out << "!DIObjCProperty(";
2704 MDFieldPrinter Printer(Out, WriterCtx);
2705 Printer.printString("name", N->getName());
2706 Printer.printMetadata("file", N->getRawFile());
2707 Printer.printInt("line", N->getLine());
2708 Printer.printString("setter", N->getSetterName());
2709 Printer.printString("getter", N->getGetterName());
2710 Printer.printInt("attributes", N->getAttributes());
2711 Printer.printMetadata("type", N->getRawType());
2712 Out << ")";
2713}
2714
2716 AsmWriterContext &WriterCtx) {
2717 Out << "!DIImportedEntity(";
2718 MDFieldPrinter Printer(Out, WriterCtx);
2719 Printer.printTag(N);
2720 Printer.printString("name", N->getName());
2721 Printer.printMetadata("scope", N->getRawScope(), /* ShouldSkipNull */ false);
2722 Printer.printMetadata("entity", N->getRawEntity());
2723 Printer.printMetadata("file", N->getRawFile());
2724 Printer.printInt("line", N->getLine());
2725 Printer.printMetadata("elements", N->getRawElements());
2726 Out << ")";
2727}
2728
2730 AsmWriterContext &Ctx) {
2731 if (Node->isDistinct())
2732 Out << "distinct ";
2733 else if (Node->isTemporary())
2734 Out << "<temporary!> "; // Handle broken code.
2735
2736 switch (Node->getMetadataID()) {
2737 default:
2738 llvm_unreachable("Expected uniquable MDNode");
2739#define HANDLE_MDNODE_LEAF(CLASS) \
2740 case Metadata::CLASS##Kind: \
2741 write##CLASS(Out, cast<CLASS>(Node), Ctx); \
2742 break;
2743#include "llvm/IR/Metadata.def"
2744 }
2745}
2746
2747// Full implementation of printing a Value as an operand with support for
2748// TypePrinting, etc.
2749static void writeAsOperandInternal(raw_ostream &Out, const Value *V,
2750 AsmWriterContext &WriterCtx,
2751 bool PrintType) {
2752 if (PrintType) {
2753 WriterCtx.TypePrinter->print(V->getType(), Out);
2754 Out << ' ';
2755 }
2756
2757 if (V->hasName()) {
2758 printLLVMName(Out, V);
2759 return;
2760 }
2761
2762 const auto *CV = dyn_cast<Constant>(V);
2763 if (CV && !isa<GlobalValue>(CV)) {
2764 assert(WriterCtx.TypePrinter && "Constants require TypePrinting!");
2765 writeConstantInternal(Out, CV, WriterCtx);
2766 return;
2767 }
2768
2769 if (const auto *IA = dyn_cast<InlineAsm>(V)) {
2770 Out << "asm ";
2771 if (IA->hasSideEffects())
2772 Out << "sideeffect ";
2773 if (IA->isAlignStack())
2774 Out << "alignstack ";
2775 // We don't emit the AD_ATT dialect as it's the assumed default.
2776 if (IA->getDialect() == InlineAsm::AD_Intel)
2777 Out << "inteldialect ";
2778 if (IA->canThrow())
2779 Out << "unwind ";
2780 Out << '"';
2781 printEscapedString(IA->getAsmString(), Out);
2782 Out << "\", \"";
2783 printEscapedString(IA->getConstraintString(), Out);
2784 Out << '"';
2785 return;
2786 }
2787
2788 if (auto *MD = dyn_cast<MetadataAsValue>(V)) {
2789 writeAsOperandInternal(Out, MD->getMetadata(), WriterCtx,
2790 /* FromValue */ true);
2791 return;
2792 }
2793
2794 char Prefix = '%';
2795 int Slot;
2796 auto *Machine = WriterCtx.Machine;
2797 // If we have a SlotTracker, use it.
2798 if (Machine) {
2799 if (const auto *GV = dyn_cast<GlobalValue>(V)) {
2800 Slot = Machine->getGlobalSlot(GV);
2801 Prefix = '@';
2802 } else {
2803 Slot = Machine->getLocalSlot(V);
2804
2805 // If the local value didn't succeed, then we may be referring to a value
2806 // from a different function. Translate it, as this can happen when using
2807 // address of blocks.
2808 if (Slot == -1)
2809 if ((Machine = createSlotTracker(V))) {
2810 Slot = Machine->getLocalSlot(V);
2811 delete Machine;
2812 }
2813 }
2814 } else if ((Machine = createSlotTracker(V))) {
2815 // Otherwise, create one to get the # and then destroy it.
2816 if (const auto *GV = dyn_cast<GlobalValue>(V)) {
2817 Slot = Machine->getGlobalSlot(GV);
2818 Prefix = '@';
2819 } else {
2820 Slot = Machine->getLocalSlot(V);
2821 }
2822 delete Machine;
2823 Machine = nullptr;
2824 } else {
2825 Slot = -1;
2826 }
2827
2828 if (Slot != -1)
2829 Out << Prefix << Slot;
2830 else
2831 Out << "<badref>";
2832}
2833
2834static void writeAsOperandInternal(raw_ostream &Out, const Metadata *MD,
2835 AsmWriterContext &WriterCtx,
2836 bool FromValue) {
2837 // Write DIExpressions and DIArgLists inline when used as a value. Improves
2838 // readability of debug info intrinsics.
2839 if (const auto *Expr = dyn_cast<DIExpression>(MD)) {
2840 writeDIExpression(Out, Expr, WriterCtx);
2841 return;
2842 }
2843 if (const auto *ArgList = dyn_cast<DIArgList>(MD)) {
2844 writeDIArgList(Out, ArgList, WriterCtx, FromValue);
2845 return;
2846 }
2847
2848 if (const auto *N = dyn_cast<MDNode>(MD)) {
2849 std::unique_ptr<SlotTracker> MachineStorage;
2850 SaveAndRestore SARMachine(WriterCtx.Machine);
2851 if (!WriterCtx.Machine) {
2852 MachineStorage = std::make_unique<SlotTracker>(WriterCtx.Context);
2853 WriterCtx.Machine = MachineStorage.get();
2854 }
2855 int Slot = WriterCtx.Machine->getMetadataSlot(N);
2856 if (Slot == -1) {
2857 if (const auto *Loc = dyn_cast<DILocation>(N)) {
2858 writeDILocation(Out, Loc, WriterCtx);
2859 return;
2860 }
2861 // Give the pointer value instead of "badref", since this comes up all
2862 // the time when debugging.
2863 Out << "<" << N << ">";
2864 } else
2865 Out << '!' << Slot;
2866 return;
2867 }
2868
2869 if (const auto *MDS = dyn_cast<MDString>(MD)) {
2870 Out << "!\"";
2871 printEscapedString(MDS->getString(), Out);
2872 Out << '"';
2873 return;
2874 }
2875
2876 auto *V = cast<ValueAsMetadata>(MD);
2877 assert(WriterCtx.TypePrinter && "TypePrinter required for metadata values");
2878 assert((FromValue || !isa<LocalAsMetadata>(V)) &&
2879 "Unexpected function-local metadata outside of value argument");
2880
2881 writeAsOperandInternal(Out, V->getValue(), WriterCtx, /*PrintType=*/true);
2882}
2883
2884namespace {
2885
2886class AssemblyWriter {
2887 formatted_raw_ostream &Out;
2888 const Module *TheModule = nullptr;
2889 const ModuleSummaryIndex *TheIndex = nullptr;
2890 std::unique_ptr<SlotTracker> SlotTrackerStorage;
2891 SlotTracker &Machine;
2892 TypePrinting TypePrinter;
2893 AssemblyAnnotationWriter *AnnotationWriter = nullptr;
2894 SetVector<const Comdat *> Comdats;
2895 bool IsForDebug;
2896 bool ShouldPreserveUseListOrder;
2897 UseListOrderMap UseListOrders;
2899 /// Synchronization scope names registered with LLVMContext.
2901 DenseMap<const GlobalValueSummary *, GlobalValue::GUID> SummaryToGUIDMap;
2902
2903public:
2904 /// Construct an AssemblyWriter with an external SlotTracker
2905 AssemblyWriter(formatted_raw_ostream &o, SlotTracker &Mac, const Module *M,
2906 AssemblyAnnotationWriter *AAW, bool IsForDebug,
2907 bool ShouldPreserveUseListOrder = false);
2908
2909 AssemblyWriter(formatted_raw_ostream &o, SlotTracker &Mac,
2910 const ModuleSummaryIndex *Index, bool IsForDebug);
2911
2912 AsmWriterContext getContext() {
2913 return AsmWriterContext(&TypePrinter, &Machine, TheModule);
2914 }
2915
2916 void printMDNodeBody(const MDNode *MD);
2917 void printNamedMDNode(const NamedMDNode *NMD);
2918
2919 void printModule(const Module *M);
2920
2921 void writeOperand(const Value *Op, bool PrintType);
2922 void writeParamOperand(const Value *Operand, AttributeSet Attrs);
2923 void writeOperandBundles(const CallBase *Call);
2924 void writeSyncScope(const LLVMContext &Context,
2925 SyncScope::ID SSID);
2926 void writeAtomic(const LLVMContext &Context,
2927 AtomicOrdering Ordering,
2928 SyncScope::ID SSID);
2929 void writeAtomicCmpXchg(const LLVMContext &Context,
2930 AtomicOrdering SuccessOrdering,
2931 AtomicOrdering FailureOrdering,
2932 SyncScope::ID SSID);
2933
2934 void writeAllMDNodes();
2935 void writeMDNode(unsigned Slot, const MDNode *Node);
2936 void writeAttribute(const Attribute &Attr, bool InAttrGroup = false);
2937 void writeAttributeSet(const AttributeSet &AttrSet, bool InAttrGroup = false);
2938 void writeAllAttributeGroups();
2939
2940 void printTypeIdentities();
2941 void printGlobal(const GlobalVariable *GV);
2942 void printAlias(const GlobalAlias *GA);
2943 void printIFunc(const GlobalIFunc *GI);
2944 void printComdat(const Comdat *C);
2945 void printFunction(const Function *F);
2946 void printArgument(const Argument *FA, AttributeSet Attrs);
2947 void printBasicBlock(const BasicBlock *BB);
2948 void printInstructionLine(const Instruction &I);
2949 void printInstruction(const Instruction &I);
2950 void printDbgMarker(const DbgMarker &DPI);
2951 void printDbgVariableRecord(const DbgVariableRecord &DVR);
2952 void printDbgLabelRecord(const DbgLabelRecord &DLR);
2953 void printDbgRecord(const DbgRecord &DR);
2954 void printDbgRecordLine(const DbgRecord &DR);
2955
2956 void printUseListOrder(const Value *V, ArrayRef<unsigned> Shuffle);
2957 void printUseLists(const Function *F);
2958
2959 void printModuleSummaryIndex();
2960 void printSummaryInfo(unsigned Slot, const ValueInfo &VI);
2961 void printSummary(const GlobalValueSummary &Summary);
2962 void printAliasSummary(const AliasSummary *AS);
2963 void printGlobalVarSummary(const GlobalVarSummary *GS);
2964 void printFunctionSummary(const FunctionSummary *FS);
2965 void printTypeIdSummary(const TypeIdSummary &TIS);
2966 void printTypeIdCompatibleVtableSummary(const TypeIdCompatibleVtableInfo &TI);
2967 void printTypeTestResolution(const TypeTestResolution &TTRes);
2968 void printArgs(ArrayRef<uint64_t> Args);
2969 void printWPDRes(const WholeProgramDevirtResolution &WPDRes);
2970 void printTypeIdInfo(const FunctionSummary::TypeIdInfo &TIDInfo);
2971 void printVFuncId(const FunctionSummary::VFuncId VFId);
2972 void printNonConstVCalls(ArrayRef<FunctionSummary::VFuncId> VCallList,
2973 const char *Tag);
2974 void printConstVCalls(ArrayRef<FunctionSummary::ConstVCall> VCallList,
2975 const char *Tag);
2976
2977private:
2978 /// Print out metadata attachments.
2979 void printMetadataAttachments(
2980 const SmallVectorImpl<std::pair<unsigned, MDNode *>> &MDs,
2981 StringRef Separator);
2982
2983 // printInfoComment - Print a little comment after the instruction indicating
2984 // which slot it occupies.
2985 void printInfoComment(const Value &V, bool isMaterializable = false);
2986
2987 // printGCRelocateComment - print comment after call to the gc.relocate
2988 // intrinsic indicating base and derived pointer names.
2989 void printGCRelocateComment(const GCRelocateInst &Relocate);
2990};
2991
2992} // end anonymous namespace
2993
2994AssemblyWriter::AssemblyWriter(formatted_raw_ostream &o, SlotTracker &Mac,
2995 const Module *M, AssemblyAnnotationWriter *AAW,
2996 bool IsForDebug, bool ShouldPreserveUseListOrder)
2997 : Out(o), TheModule(M), Machine(Mac), TypePrinter(M), AnnotationWriter(AAW),
2998 IsForDebug(IsForDebug),
2999 ShouldPreserveUseListOrder(
3000 PreserveAssemblyUseListOrder.getNumOccurrences()
3002 : ShouldPreserveUseListOrder) {
3003 if (!TheModule)
3004 return;
3005 for (const GlobalObject &GO : TheModule->global_objects())
3006 if (const Comdat *C = GO.getComdat())
3007 Comdats.insert(C);
3008}
3009
3010AssemblyWriter::AssemblyWriter(formatted_raw_ostream &o, SlotTracker &Mac,
3011 const ModuleSummaryIndex *Index, bool IsForDebug)
3012 : Out(o), TheIndex(Index), Machine(Mac), TypePrinter(/*Module=*/nullptr),
3013 IsForDebug(IsForDebug),
3014 ShouldPreserveUseListOrder(PreserveAssemblyUseListOrder) {}
3015
3016void AssemblyWriter::writeOperand(const Value *Operand, bool PrintType) {
3017 if (!Operand) {
3018 Out << "<null operand!>";
3019 return;
3020 }
3021 auto WriteCtx = getContext();
3022 writeAsOperandInternal(Out, Operand, WriteCtx, PrintType);
3023}
3024
3025void AssemblyWriter::writeSyncScope(const LLVMContext &Context,
3026 SyncScope::ID SSID) {
3027 switch (SSID) {
3028 case SyncScope::System: {
3029 break;
3030 }
3031 default: {
3032 if (SSNs.empty())
3033 Context.getSyncScopeNames(SSNs);
3034
3035 Out << " syncscope(\"";
3036 printEscapedString(SSNs[SSID], Out);
3037 Out << "\")";
3038 break;
3039 }
3040 }
3041}
3042
3043void AssemblyWriter::writeAtomic(const LLVMContext &Context,
3044 AtomicOrdering Ordering,
3045 SyncScope::ID SSID) {
3046 if (Ordering == AtomicOrdering::NotAtomic)
3047 return;
3048
3049 writeSyncScope(Context, SSID);
3050 Out << " " << toIRString(Ordering);
3051}
3052
3053void AssemblyWriter::writeAtomicCmpXchg(const LLVMContext &Context,
3054 AtomicOrdering SuccessOrdering,
3055 AtomicOrdering FailureOrdering,
3056 SyncScope::ID SSID) {
3057 assert(SuccessOrdering != AtomicOrdering::NotAtomic &&
3058 FailureOrdering != AtomicOrdering::NotAtomic);
3059
3060 writeSyncScope(Context, SSID);
3061 Out << " " << toIRString(SuccessOrdering);
3062 Out << " " << toIRString(FailureOrdering);
3063}
3064
3065void AssemblyWriter::writeParamOperand(const Value *Operand,
3066 AttributeSet Attrs) {
3067 if (!Operand) {
3068 Out << "<null operand!>";
3069 return;
3070 }
3071
3072 // Print the type
3073 TypePrinter.print(Operand->getType(), Out);
3074 // Print parameter attributes list
3075 if (Attrs.hasAttributes()) {
3076 Out << ' ';
3077 writeAttributeSet(Attrs);
3078 }
3079 Out << ' ';
3080 // Print the operand
3081 auto WriterCtx = getContext();
3082 writeAsOperandInternal(Out, Operand, WriterCtx);
3083}
3084
3085void AssemblyWriter::writeOperandBundles(const CallBase *Call) {
3086 if (!Call->hasOperandBundles())
3087 return;
3088
3089 Out << " [ ";
3090
3091 ListSeparator LS;
3092 for (unsigned i = 0, e = Call->getNumOperandBundles(); i != e; ++i) {
3093 OperandBundleUse BU = Call->getOperandBundleAt(i);
3094
3095 Out << LS << '"';
3096 printEscapedString(BU.getTagName(), Out);
3097 Out << '"';
3098
3099 Out << '(';
3100
3101 ListSeparator InnerLS;
3102 auto WriterCtx = getContext();
3103 for (const auto &Input : BU.Inputs) {
3104 Out << InnerLS;
3105 if (Input == nullptr)
3106 Out << "<null operand bundle!>";
3107 else
3108 writeAsOperandInternal(Out, Input, WriterCtx, /*PrintType=*/true);
3109 }
3110
3111 Out << ')';
3112 }
3113
3114 Out << " ]";
3115}
3116
3117void AssemblyWriter::printModule(const Module *M) {
3118 Machine.initializeIfNeeded();
3119
3120 if (ShouldPreserveUseListOrder)
3121 UseListOrders = predictUseListOrder(M);
3122
3123 if (!M->getModuleIdentifier().empty() &&
3124 // Don't print the ID if it will start a new line (which would
3125 // require a comment char before it).
3126 M->getModuleIdentifier().find('\n') == std::string::npos)
3127 Out << "; ModuleID = '" << M->getModuleIdentifier() << "'\n";
3128
3129 if (!M->getSourceFileName().empty()) {
3130 Out << "source_filename = \"";
3131 printEscapedString(M->getSourceFileName(), Out);
3132 Out << "\"\n";
3133 }
3134
3135 const std::string &DL = M->getDataLayoutStr();
3136 if (!DL.empty())
3137 Out << "target datalayout = \"" << DL << "\"\n";
3138 if (!M->getTargetTriple().empty())
3139 Out << "target triple = \"" << M->getTargetTriple().str() << "\"\n";
3140
3141 if (!M->getModuleInlineAsm().empty()) {
3142 Out << '\n';
3143
3144 // Split the string into lines, to make it easier to read the .ll file.
3145 StringRef Asm = M->getModuleInlineAsm();
3146 do {
3147 StringRef Front;
3148 std::tie(Front, Asm) = Asm.split('\n');
3149
3150 // We found a newline, print the portion of the asm string from the
3151 // last newline up to this newline.
3152 Out << "module asm \"";
3153 printEscapedString(Front, Out);
3154 Out << "\"\n";
3155 } while (!Asm.empty());
3156 }
3157
3158 printTypeIdentities();
3159
3160 // Output all comdats.
3161 if (!Comdats.empty())
3162 Out << '\n';
3163 for (const Comdat *C : Comdats) {
3164 printComdat(C);
3165 if (C != Comdats.back())
3166 Out << '\n';
3167 }
3168
3169 // Output all globals.
3170 if (!M->global_empty()) Out << '\n';
3171 for (const GlobalVariable &GV : M->globals()) {
3172 printGlobal(&GV); Out << '\n';
3173 }
3174
3175 // Output all aliases.
3176 if (!M->alias_empty()) Out << "\n";
3177 for (const GlobalAlias &GA : M->aliases())
3178 printAlias(&GA);
3179
3180 // Output all ifuncs.
3181 if (!M->ifunc_empty()) Out << "\n";
3182 for (const GlobalIFunc &GI : M->ifuncs())
3183 printIFunc(&GI);
3184
3185 // Output all of the functions.
3186 for (const Function &F : *M) {
3187 Out << '\n';
3188 printFunction(&F);
3189 }
3190
3191 // Output global use-lists.
3192 printUseLists(nullptr);
3193
3194 // Output all attribute groups.
3195 if (!Machine.as_empty()) {
3196 Out << '\n';
3197 writeAllAttributeGroups();
3198 }
3199
3200 // Output named metadata.
3201 if (!M->named_metadata_empty()) Out << '\n';
3202
3203 for (const NamedMDNode &Node : M->named_metadata())
3204 printNamedMDNode(&Node);
3205
3206 // Output metadata.
3207 if (!Machine.mdn_empty()) {
3208 Out << '\n';
3209 writeAllMDNodes();
3210 }
3211}
3212
3213void AssemblyWriter::printModuleSummaryIndex() {
3214 assert(TheIndex);
3215 int NumSlots = Machine.initializeIndexIfNeeded();
3216
3217 Out << "\n";
3218
3219 // Print module path entries. To print in order, add paths to a vector
3220 // indexed by module slot.
3221 std::vector<std::pair<std::string, ModuleHash>> moduleVec;
3222 std::string RegularLTOModuleName =
3224 moduleVec.resize(TheIndex->modulePaths().size());
3225 for (auto &[ModPath, ModHash] : TheIndex->modulePaths())
3226 moduleVec[Machine.getModulePathSlot(ModPath)] = std::make_pair(
3227 // An empty module path is a special entry for a regular LTO module
3228 // created during the thin link.
3229 ModPath.empty() ? RegularLTOModuleName : std::string(ModPath), ModHash);
3230
3231 unsigned i = 0;
3232 for (auto &ModPair : moduleVec) {
3233 Out << "^" << i++ << " = module: (";
3234 Out << "path: \"";
3235 printEscapedString(ModPair.first, Out);
3236 Out << "\", hash: (";
3237 ListSeparator FS;
3238 for (auto Hash : ModPair.second)
3239 Out << FS << Hash;
3240 Out << "))\n";
3241 }
3242
3243 // FIXME: Change AliasSummary to hold a ValueInfo instead of summary pointer
3244 // for aliasee (then update BitcodeWriter.cpp and remove get/setAliaseeGUID).
3245 for (auto &GlobalList : *TheIndex) {
3246 auto GUID = GlobalList.first;
3247 for (auto &Summary : GlobalList.second.getSummaryList())
3248 SummaryToGUIDMap[Summary.get()] = GUID;
3249 }
3250
3251 // Print the global value summary entries.
3252 for (auto &GlobalList : *TheIndex) {
3253 auto GUID = GlobalList.first;
3254 auto VI = TheIndex->getValueInfo(GlobalList);
3255 printSummaryInfo(Machine.getGUIDSlot(GUID), VI);
3256 }
3257
3258 // Print the TypeIdMap entries.
3259 for (const auto &TID : TheIndex->typeIds()) {
3260 Out << "^" << Machine.getTypeIdSlot(TID.second.first)
3261 << " = typeid: (name: \"" << TID.second.first << "\"";
3262 printTypeIdSummary(TID.second.second);
3263 Out << ") ; guid = " << TID.first << "\n";
3264 }
3265
3266 // Print the TypeIdCompatibleVtableMap entries.
3267 for (auto &TId : TheIndex->typeIdCompatibleVtableMap()) {
3269 Out << "^" << Machine.getTypeIdCompatibleVtableSlot(TId.first)
3270 << " = typeidCompatibleVTable: (name: \"" << TId.first << "\"";
3271 printTypeIdCompatibleVtableSummary(TId.second);
3272 Out << ") ; guid = " << GUID << "\n";
3273 }
3274
3275 // Don't emit flags when it's not really needed (value is zero by default).
3276 if (TheIndex->getFlags()) {
3277 Out << "^" << NumSlots << " = flags: " << TheIndex->getFlags() << "\n";
3278 ++NumSlots;
3279 }
3280
3281 Out << "^" << NumSlots << " = blockcount: " << TheIndex->getBlockCount()
3282 << "\n";
3283}
3284
3285static const char *
3287 switch (K) {
3289 return "indir";
3291 return "singleImpl";
3293 return "branchFunnel";
3294 }
3295 llvm_unreachable("invalid WholeProgramDevirtResolution kind");
3296}
3297
3300 switch (K) {
3302 return "indir";
3304 return "uniformRetVal";
3306 return "uniqueRetVal";
3308 return "virtualConstProp";
3309 }
3310 llvm_unreachable("invalid WholeProgramDevirtResolution::ByArg kind");
3311}
3312
3314 switch (K) {
3316 return "unknown";
3318 return "unsat";
3320 return "byteArray";
3322 return "inline";
3324 return "single";
3326 return "allOnes";
3327 }
3328 llvm_unreachable("invalid TypeTestResolution kind");
3329}
3330
3331void AssemblyWriter::printTypeTestResolution(const TypeTestResolution &TTRes) {
3332 Out << "typeTestRes: (kind: " << getTTResKindName(TTRes.TheKind)
3333 << ", sizeM1BitWidth: " << TTRes.SizeM1BitWidth;
3334
3335 // The following fields are only used if the target does not support the use
3336 // of absolute symbols to store constants. Print only if non-zero.
3337 if (TTRes.AlignLog2)
3338 Out << ", alignLog2: " << TTRes.AlignLog2;
3339 if (TTRes.SizeM1)
3340 Out << ", sizeM1: " << TTRes.SizeM1;
3341 if (TTRes.BitMask)
3342 // BitMask is uint8_t which causes it to print the corresponding char.
3343 Out << ", bitMask: " << (unsigned)TTRes.BitMask;
3344 if (TTRes.InlineBits)
3345 Out << ", inlineBits: " << TTRes.InlineBits;
3346
3347 Out << ")";
3348}
3349
3350void AssemblyWriter::printTypeIdSummary(const TypeIdSummary &TIS) {
3351 Out << ", summary: (";
3352 printTypeTestResolution(TIS.TTRes);
3353 if (!TIS.WPDRes.empty()) {
3354 Out << ", wpdResolutions: (";
3355 ListSeparator FS;
3356 for (auto &WPDRes : TIS.WPDRes) {
3357 Out << FS;
3358 Out << "(offset: " << WPDRes.first << ", ";
3359 printWPDRes(WPDRes.second);
3360 Out << ")";
3361 }
3362 Out << ")";
3363 }
3364 Out << ")";
3365}
3366
3367void AssemblyWriter::printTypeIdCompatibleVtableSummary(
3368 const TypeIdCompatibleVtableInfo &TI) {
3369 Out << ", summary: (";
3370 ListSeparator FS;
3371 for (auto &P : TI) {
3372 Out << FS;
3373 Out << "(offset: " << P.AddressPointOffset << ", ";
3374 Out << "^" << Machine.getGUIDSlot(P.VTableVI.getGUID());
3375 Out << ")";
3376 }
3377 Out << ")";
3378}
3379
3380void AssemblyWriter::printArgs(ArrayRef<uint64_t> Args) {
3381 Out << "args: (" << llvm::interleaved(Args) << ')';
3382}
3383
3384void AssemblyWriter::printWPDRes(const WholeProgramDevirtResolution &WPDRes) {
3385 Out << "wpdRes: (kind: ";
3387
3389 Out << ", singleImplName: \"" << WPDRes.SingleImplName << "\"";
3390
3391 if (!WPDRes.ResByArg.empty()) {
3392 Out << ", resByArg: (";
3393 ListSeparator FS;
3394 for (auto &ResByArg : WPDRes.ResByArg) {
3395 Out << FS;
3396 printArgs(ResByArg.first);
3397 Out << ", byArg: (kind: ";
3398 Out << getWholeProgDevirtResByArgKindName(ResByArg.second.TheKind);
3399 if (ResByArg.second.TheKind ==
3401 ResByArg.second.TheKind ==
3403 Out << ", info: " << ResByArg.second.Info;
3404
3405 // The following fields are only used if the target does not support the
3406 // use of absolute symbols to store constants. Print only if non-zero.
3407 if (ResByArg.second.Byte || ResByArg.second.Bit)
3408 Out << ", byte: " << ResByArg.second.Byte
3409 << ", bit: " << ResByArg.second.Bit;
3410
3411 Out << ")";
3412 }
3413 Out << ")";
3414 }
3415 Out << ")";
3416}
3417
3419 switch (SK) {
3421 return "alias";
3423 return "function";
3425 return "variable";
3426 }
3427 llvm_unreachable("invalid summary kind");
3428}
3429
3430void AssemblyWriter::printAliasSummary(const AliasSummary *AS) {
3431 Out << ", aliasee: ";
3432 // The indexes emitted for distributed backends may not include the
3433 // aliasee summary (only if it is being imported directly). Handle
3434 // that case by just emitting "null" as the aliasee.
3435 if (AS->hasAliasee())
3436 Out << "^" << Machine.getGUIDSlot(SummaryToGUIDMap[&AS->getAliasee()]);
3437 else
3438 Out << "null";
3439}
3440
3441void AssemblyWriter::printGlobalVarSummary(const GlobalVarSummary *GS) {
3442 auto VTableFuncs = GS->vTableFuncs();
3443 Out << ", varFlags: (readonly: " << GS->VarFlags.MaybeReadOnly << ", "
3444 << "writeonly: " << GS->VarFlags.MaybeWriteOnly << ", "
3445 << "constant: " << GS->VarFlags.Constant;
3446 if (!VTableFuncs.empty())
3447 Out << ", "
3448 << "vcall_visibility: " << GS->VarFlags.VCallVisibility;
3449 Out << ")";
3450
3451 if (!VTableFuncs.empty()) {
3452 Out << ", vTableFuncs: (";
3453 ListSeparator FS;
3454 for (auto &P : VTableFuncs) {
3455 Out << FS;
3456 Out << "(virtFunc: ^" << Machine.getGUIDSlot(P.FuncVI.getGUID())
3457 << ", offset: " << P.VTableOffset;
3458 Out << ")";
3459 }
3460 Out << ")";
3461 }
3462}
3463
3465 switch (LT) {
3467 return "external";
3469 return "private";
3471 return "internal";
3473 return "linkonce";
3475 return "linkonce_odr";
3477 return "weak";
3479 return "weak_odr";
3481 return "common";
3483 return "appending";
3485 return "extern_weak";
3487 return "available_externally";
3488 }
3489 llvm_unreachable("invalid linkage");
3490}
3491
3492// When printing the linkage types in IR where the ExternalLinkage is
3493// not printed, and other linkage types are expected to be printed with
3494// a space after the name.
3497 return "";
3498 return getLinkageName(LT) + " ";
3499}
3500
3502 switch (Vis) {
3504 return "default";
3506 return "hidden";
3508 return "protected";
3509 }
3510 llvm_unreachable("invalid visibility");
3511}
3512
3514 switch (IK) {
3516 return "definition";
3518 return "declaration";
3519 }
3520 llvm_unreachable("invalid import kind");
3521}
3522
3523void AssemblyWriter::printFunctionSummary(const FunctionSummary *FS) {
3524 Out << ", insts: " << FS->instCount();
3525 if (FS->fflags().anyFlagSet())
3526 Out << ", " << FS->fflags();
3527
3528 if (!FS->calls().empty()) {
3529 Out << ", calls: (";
3530 ListSeparator IFS;
3531 for (auto &Call : FS->calls()) {
3532 Out << IFS;
3533 Out << "(callee: ^" << Machine.getGUIDSlot(Call.first.getGUID());
3534 if (Call.second.getHotness() != CalleeInfo::HotnessType::Unknown)
3535 Out << ", hotness: " << getHotnessName(Call.second.getHotness());
3536 // Follow the convention of emitting flags as a boolean value, but only
3537 // emit if true to avoid unnecessary verbosity and test churn.
3538 if (Call.second.HasTailCall)
3539 Out << ", tail: 1";
3540 Out << ")";
3541 }
3542 Out << ")";
3543 }
3544
3545 if (const auto *TIdInfo = FS->getTypeIdInfo())
3546 printTypeIdInfo(*TIdInfo);
3547
3548 // The AllocationType identifiers capture the profiled context behavior
3549 // reaching a specific static allocation site (possibly cloned).
3550 auto AllocTypeName = [](uint8_t Type) -> const char * {
3551 switch (Type) {
3552 case (uint8_t)AllocationType::None:
3553 return "none";
3554 case (uint8_t)AllocationType::NotCold:
3555 return "notcold";
3556 case (uint8_t)AllocationType::Cold:
3557 return "cold";
3558 case (uint8_t)AllocationType::Hot:
3559 return "hot";
3560 }
3561 llvm_unreachable("Unexpected alloc type");
3562 };
3563
3564 if (!FS->allocs().empty()) {
3565 Out << ", allocs: (";
3566 ListSeparator AFS;
3567 for (auto &AI : FS->allocs()) {
3568 Out << AFS;
3569 Out << "(versions: (";
3570 ListSeparator VFS;
3571 for (auto V : AI.Versions) {
3572 Out << VFS;
3573 Out << AllocTypeName(V);
3574 }
3575 Out << "), memProf: (";
3576 ListSeparator MIBFS;
3577 for (auto &MIB : AI.MIBs) {
3578 Out << MIBFS;
3579 Out << "(type: " << AllocTypeName((uint8_t)MIB.AllocType);
3580 Out << ", stackIds: (";
3581 ListSeparator SIDFS;
3582 for (auto Id : MIB.StackIdIndices) {
3583 Out << SIDFS;
3584 Out << TheIndex->getStackIdAtIndex(Id);
3585 }
3586 Out << "))";
3587 }
3588 Out << "))";
3589 }
3590 Out << ")";
3591 }
3592
3593 if (!FS->callsites().empty()) {
3594 Out << ", callsites: (";
3595 ListSeparator SNFS;
3596 for (auto &CI : FS->callsites()) {
3597 Out << SNFS;
3598 if (CI.Callee)
3599 Out << "(callee: ^" << Machine.getGUIDSlot(CI.Callee.getGUID());
3600 else
3601 Out << "(callee: null";
3602 Out << ", clones: (";
3603 ListSeparator VFS;
3604 for (auto V : CI.Clones) {
3605 Out << VFS;
3606 Out << V;
3607 }
3608 Out << "), stackIds: (";
3609 ListSeparator SIDFS;
3610 for (auto Id : CI.StackIdIndices) {
3611 Out << SIDFS;
3612 Out << TheIndex->getStackIdAtIndex(Id);
3613 }
3614 Out << "))";
3615 }
3616 Out << ")";
3617 }
3618
3619 auto PrintRange = [&](const ConstantRange &Range) {
3620 Out << "[" << Range.getSignedMin() << ", " << Range.getSignedMax() << "]";
3621 };
3622
3623 if (!FS->paramAccesses().empty()) {
3624 Out << ", params: (";
3625 ListSeparator IFS;
3626 for (auto &PS : FS->paramAccesses()) {
3627 Out << IFS;
3628 Out << "(param: " << PS.ParamNo;
3629 Out << ", offset: ";
3630 PrintRange(PS.Use);
3631 if (!PS.Calls.empty()) {
3632 Out << ", calls: (";
3633 ListSeparator IFS;
3634 for (auto &Call : PS.Calls) {
3635 Out << IFS;
3636 Out << "(callee: ^" << Machine.getGUIDSlot(Call.Callee.getGUID());
3637 Out << ", param: " << Call.ParamNo;
3638 Out << ", offset: ";
3639 PrintRange(Call.Offsets);
3640 Out << ")";
3641 }
3642 Out << ")";
3643 }
3644 Out << ")";
3645 }
3646 Out << ")";
3647 }
3648}
3649
3650void AssemblyWriter::printTypeIdInfo(
3651 const FunctionSummary::TypeIdInfo &TIDInfo) {
3652 Out << ", typeIdInfo: (";
3653 ListSeparator TIDFS;
3654 if (!TIDInfo.TypeTests.empty()) {
3655 Out << TIDFS;
3656 Out << "typeTests: (";
3657 ListSeparator FS;
3658 for (auto &GUID : TIDInfo.TypeTests) {
3659 auto TidIter = TheIndex->typeIds().equal_range(GUID);
3660 if (TidIter.first == TidIter.second) {
3661 Out << FS;
3662 Out << GUID;
3663 continue;
3664 }
3665 // Print all type id that correspond to this GUID.
3666 for (const auto &[GUID, TypeIdPair] : make_range(TidIter)) {
3667 Out << FS;
3668 auto Slot = Machine.getTypeIdSlot(TypeIdPair.first);
3669 assert(Slot != -1);
3670 Out << "^" << Slot;
3671 }
3672 }
3673 Out << ")";
3674 }
3675 if (!TIDInfo.TypeTestAssumeVCalls.empty()) {
3676 Out << TIDFS;
3677 printNonConstVCalls(TIDInfo.TypeTestAssumeVCalls, "typeTestAssumeVCalls");
3678 }
3679 if (!TIDInfo.TypeCheckedLoadVCalls.empty()) {
3680 Out << TIDFS;
3681 printNonConstVCalls(TIDInfo.TypeCheckedLoadVCalls, "typeCheckedLoadVCalls");
3682 }
3683 if (!TIDInfo.TypeTestAssumeConstVCalls.empty()) {
3684 Out << TIDFS;
3685 printConstVCalls(TIDInfo.TypeTestAssumeConstVCalls,
3686 "typeTestAssumeConstVCalls");
3687 }
3688 if (!TIDInfo.TypeCheckedLoadConstVCalls.empty()) {
3689 Out << TIDFS;
3690 printConstVCalls(TIDInfo.TypeCheckedLoadConstVCalls,
3691 "typeCheckedLoadConstVCalls");
3692 }
3693 Out << ")";
3694}
3695
3696void AssemblyWriter::printVFuncId(const FunctionSummary::VFuncId VFId) {
3697 auto TidIter = TheIndex->typeIds().equal_range(VFId.GUID);
3698 if (TidIter.first == TidIter.second) {
3699 Out << "vFuncId: (";
3700 Out << "guid: " << VFId.GUID;
3701 Out << ", offset: " << VFId.Offset;
3702 Out << ")";
3703 return;
3704 }
3705 // Print all type id that correspond to this GUID.
3706 ListSeparator FS;
3707 for (const auto &[GUID, TypeIdPair] : make_range(TidIter)) {
3708 Out << FS;
3709 Out << "vFuncId: (";
3710 auto Slot = Machine.getTypeIdSlot(TypeIdPair.first);
3711 assert(Slot != -1);
3712 Out << "^" << Slot;
3713 Out << ", offset: " << VFId.Offset;
3714 Out << ")";
3715 }
3716}
3717
3718void AssemblyWriter::printNonConstVCalls(
3719 ArrayRef<FunctionSummary::VFuncId> VCallList, const char *Tag) {
3720 Out << Tag << ": (";
3721 ListSeparator FS;
3722 for (auto &VFuncId : VCallList) {
3723 Out << FS;
3724 printVFuncId(VFuncId);
3725 }
3726 Out << ")";
3727}
3728
3729void AssemblyWriter::printConstVCalls(
3730 ArrayRef<FunctionSummary::ConstVCall> VCallList, const char *Tag) {
3731 Out << Tag << ": (";
3732 ListSeparator FS;
3733 for (auto &ConstVCall : VCallList) {
3734 Out << FS;
3735 Out << "(";
3736 printVFuncId(ConstVCall.VFunc);
3737 if (!ConstVCall.Args.empty()) {
3738 Out << ", ";
3739 printArgs(ConstVCall.Args);
3740 }
3741 Out << ")";
3742 }
3743 Out << ")";
3744}
3745
3746void AssemblyWriter::printSummary(const GlobalValueSummary &Summary) {
3747 GlobalValueSummary::GVFlags GVFlags = Summary.flags();
3749 Out << getSummaryKindName(Summary.getSummaryKind()) << ": ";
3750 Out << "(module: ^" << Machine.getModulePathSlot(Summary.modulePath())
3751 << ", flags: (";
3752 Out << "linkage: " << getLinkageName(LT);
3753 Out << ", visibility: "
3755 Out << ", notEligibleToImport: " << GVFlags.NotEligibleToImport;
3756 Out << ", live: " << GVFlags.Live;
3757 Out << ", dsoLocal: " << GVFlags.DSOLocal;
3758 Out << ", canAutoHide: " << GVFlags.CanAutoHide;
3759 Out << ", importType: "
3761 Out << ", noRenameOnPromotion: " << GVFlags.NoRenameOnPromotion;
3762 Out << ")";
3763
3764 if (Summary.getSummaryKind() == GlobalValueSummary::AliasKind)
3765 printAliasSummary(cast<AliasSummary>(&Summary));
3766 else if (Summary.getSummaryKind() == GlobalValueSummary::FunctionKind)
3767 printFunctionSummary(cast<FunctionSummary>(&Summary));
3768 else
3769 printGlobalVarSummary(cast<GlobalVarSummary>(&Summary));
3770
3771 auto RefList = Summary.refs();
3772 if (!RefList.empty()) {
3773 Out << ", refs: (";
3774 ListSeparator FS;
3775 for (auto &Ref : RefList) {
3776 Out << FS;
3777 if (Ref.isReadOnly())
3778 Out << "readonly ";
3779 else if (Ref.isWriteOnly())
3780 Out << "writeonly ";
3781 Out << "^" << Machine.getGUIDSlot(Ref.getGUID());
3782 }
3783 Out << ")";
3784 }
3785
3786 Out << ")";
3787}
3788
3789void AssemblyWriter::printSummaryInfo(unsigned Slot, const ValueInfo &VI) {
3790 Out << "^" << Slot << " = gv: (";
3791 if (VI.hasName() && !VI.name().empty())
3792 Out << "name: \"" << VI.name() << "\"";
3793 else
3794 Out << "guid: " << VI.getGUID();
3795 if (!VI.getSummaryList().empty()) {
3796 Out << ", summaries: (";
3797 ListSeparator FS;
3798 for (auto &Summary : VI.getSummaryList()) {
3799 Out << FS;
3800 printSummary(*Summary);
3801 }
3802 Out << ")";
3803 }
3804 Out << ")";
3805 if (VI.hasName() && !VI.name().empty())
3806 Out << " ; guid = " << VI.getGUID();
3807 Out << "\n";
3808}
3809
3811 formatted_raw_ostream &Out) {
3812 if (Name.empty()) {
3813 Out << "<empty name> ";
3814 } else {
3815 unsigned char FirstC = static_cast<unsigned char>(Name[0]);
3816 if (isalpha(FirstC) || FirstC == '-' || FirstC == '$' || FirstC == '.' ||
3817 FirstC == '_')
3818 Out << FirstC;
3819 else
3820 Out << '\\' << hexdigit(FirstC >> 4) << hexdigit(FirstC & 0x0F);
3821 for (unsigned i = 1, e = Name.size(); i != e; ++i) {
3822 unsigned char C = Name[i];
3823 if (isalnum(C) || C == '-' || C == '$' || C == '.' || C == '_')
3824 Out << C;
3825 else
3826 Out << '\\' << hexdigit(C >> 4) << hexdigit(C & 0x0F);
3827 }
3828 }
3829}
3830
3831void AssemblyWriter::printNamedMDNode(const NamedMDNode *NMD) {
3832 Out << '!';
3833 printMetadataIdentifier(NMD->getName(), Out);
3834 Out << " = !{";
3835 ListSeparator LS;
3836 for (const MDNode *Op : NMD->operands()) {
3837 Out << LS;
3838 // Write DIExpressions inline.
3839 // FIXME: Ban DIExpressions in NamedMDNodes, they will serve no purpose.
3840 if (auto *Expr = dyn_cast<DIExpression>(Op)) {
3841 writeDIExpression(Out, Expr, AsmWriterContext::getEmpty());
3842 continue;
3843 }
3844
3845 int Slot = Machine.getMetadataSlot(Op);
3846 if (Slot == -1)
3847 Out << "<badref>";
3848 else
3849 Out << '!' << Slot;
3850 }
3851 Out << "}\n";
3852}
3853
3855 formatted_raw_ostream &Out) {
3856 switch (Vis) {
3858 case GlobalValue::HiddenVisibility: Out << "hidden "; break;
3859 case GlobalValue::ProtectedVisibility: Out << "protected "; break;
3860 }
3861}
3862
3863static void printDSOLocation(const GlobalValue &GV,
3864 formatted_raw_ostream &Out) {
3865 if (GV.isDSOLocal() && !GV.isImplicitDSOLocal())
3866 Out << "dso_local ";
3867}
3868
3870 formatted_raw_ostream &Out) {
3871 switch (SCT) {
3873 case GlobalValue::DLLImportStorageClass: Out << "dllimport "; break;
3874 case GlobalValue::DLLExportStorageClass: Out << "dllexport "; break;
3875 }
3876}
3877
3879 formatted_raw_ostream &Out) {
3880 switch (TLM) {
3882 break;
3884 Out << "thread_local ";
3885 break;
3887 Out << "thread_local(localdynamic) ";
3888 break;
3890 Out << "thread_local(initialexec) ";
3891 break;
3893 Out << "thread_local(localexec) ";
3894 break;
3895 }
3896}
3897
3899 switch (UA) {
3901 return "";
3903 return "local_unnamed_addr";
3905 return "unnamed_addr";
3906 }
3907 llvm_unreachable("Unknown UnnamedAddr");
3908}
3909
3911 const GlobalObject &GO) {
3912 const Comdat *C = GO.getComdat();
3913 if (!C)
3914 return;
3915
3916 if (isa<GlobalVariable>(GO))
3917 Out << ',';
3918 Out << " comdat";
3919
3920 if (GO.getName() == C->getName())
3921 return;
3922
3923 Out << '(';
3924 printLLVMName(Out, C->getName(), ComdatPrefix);
3925 Out << ')';
3926}
3927
3928void AssemblyWriter::printGlobal(const GlobalVariable *GV) {
3929 if (GV->isMaterializable())
3930 Out << "; Materializable\n";
3931
3932 AsmWriterContext WriterCtx(&TypePrinter, &Machine, GV->getParent());
3933 writeAsOperandInternal(Out, GV, WriterCtx);
3934 Out << " = ";
3935
3936 if (!GV->hasInitializer() && GV->hasExternalLinkage())
3937 Out << "external ";
3938
3939 Out << getLinkageNameWithSpace(GV->getLinkage());
3940 printDSOLocation(*GV, Out);
3941 printVisibility(GV->getVisibility(), Out);
3944 StringRef UA = getUnnamedAddrEncoding(GV->getUnnamedAddr());
3945 if (!UA.empty())
3946 Out << UA << ' ';
3947
3949 /*Prefix=*/"", /*Suffix=*/" ");
3950 if (GV->isExternallyInitialized()) Out << "externally_initialized ";
3951 Out << (GV->isConstant() ? "constant " : "global ");
3952 TypePrinter.print(GV->getValueType(), Out);
3953
3954 if (GV->hasInitializer()) {
3955 Out << ' ';
3956 writeOperand(GV->getInitializer(), false);
3957 }
3958
3959 if (GV->hasSection()) {
3960 Out << ", section \"";
3961 printEscapedString(GV->getSection(), Out);
3962 Out << '"';
3963 }
3964 if (GV->hasPartition()) {
3965 Out << ", partition \"";
3966 printEscapedString(GV->getPartition(), Out);
3967 Out << '"';
3968 }
3969 if (auto CM = GV->getCodeModel()) {
3970 Out << ", code_model \"";
3971 switch (*CM) {
3972 case CodeModel::Tiny:
3973 Out << "tiny";
3974 break;
3975 case CodeModel::Small:
3976 Out << "small";
3977 break;
3978 case CodeModel::Kernel:
3979 Out << "kernel";
3980 break;
3981 case CodeModel::Medium:
3982 Out << "medium";
3983 break;
3984 case CodeModel::Large:
3985 Out << "large";
3986 break;
3987 }
3988 Out << '"';
3989 }
3990
3991 using SanitizerMetadata = llvm::GlobalValue::SanitizerMetadata;
3992 if (GV->hasSanitizerMetadata()) {
3994 if (MD.NoAddress)
3995 Out << ", no_sanitize_address";
3996 if (MD.NoHWAddress)
3997 Out << ", no_sanitize_hwaddress";
3998 if (MD.Memtag)
3999 Out << ", sanitize_memtag";
4000 if (MD.IsDynInit)
4001 Out << ", sanitize_address_dyninit";
4002 }
4003
4004 maybePrintComdat(Out, *GV);
4005 if (MaybeAlign A = GV->getAlign())
4006 Out << ", align " << A->value();
4007
4009 GV->getAllMetadata(MDs);
4010 printMetadataAttachments(MDs, ", ");
4011
4012 auto Attrs = GV->getAttributes();
4013 if (Attrs.hasAttributes())
4014 Out << " #" << Machine.getAttributeGroupSlot(Attrs);
4015
4016 printInfoComment(*GV, GV->isMaterializable());
4017}
4018
4019void AssemblyWriter::printAlias(const GlobalAlias *GA) {
4020 if (GA->isMaterializable())
4021 Out << "; Materializable\n";
4022
4023 AsmWriterContext WriterCtx(&TypePrinter, &Machine, GA->getParent());
4024 writeAsOperandInternal(Out, GA, WriterCtx);
4025 Out << " = ";
4026
4027 Out << getLinkageNameWithSpace(GA->getLinkage());
4028 printDSOLocation(*GA, Out);
4029 printVisibility(GA->getVisibility(), Out);
4032 StringRef UA = getUnnamedAddrEncoding(GA->getUnnamedAddr());
4033 if (!UA.empty())
4034 Out << UA << ' ';
4035
4036 Out << "alias ";
4037
4038 TypePrinter.print(GA->getValueType(), Out);
4039 Out << ", ";
4040
4041 if (const Constant *Aliasee = GA->getAliasee()) {
4042 writeOperand(Aliasee, !isa<ConstantExpr>(Aliasee));
4043 } else {
4044 TypePrinter.print(GA->getType(), Out);
4045 Out << " <<NULL ALIASEE>>";
4046 }
4047
4048 if (GA->hasPartition()) {
4049 Out << ", partition \"";
4050 printEscapedString(GA->getPartition(), Out);
4051 Out << '"';
4052 }
4053
4054 printInfoComment(*GA, GA->isMaterializable());
4055 Out << '\n';
4056}
4057
4058void AssemblyWriter::printIFunc(const GlobalIFunc *GI) {
4059 if (GI->isMaterializable())
4060 Out << "; Materializable\n";
4061
4062 AsmWriterContext WriterCtx(&TypePrinter, &Machine, GI->getParent());
4063 writeAsOperandInternal(Out, GI, WriterCtx);
4064 Out << " = ";
4065
4066 Out << getLinkageNameWithSpace(GI->getLinkage());
4067 printDSOLocation(*GI, Out);
4068 printVisibility(GI->getVisibility(), Out);
4069
4070 Out << "ifunc ";
4071
4072 TypePrinter.print(GI->getValueType(), Out);
4073 Out << ", ";
4074
4075 if (const Constant *Resolver = GI->getResolver()) {
4076 writeOperand(Resolver, !isa<ConstantExpr>(Resolver));
4077 } else {
4078 TypePrinter.print(GI->getType(), Out);
4079 Out << " <<NULL RESOLVER>>";
4080 }
4081
4082 if (GI->hasPartition()) {
4083 Out << ", partition \"";
4084 printEscapedString(GI->getPartition(), Out);
4085 Out << '"';
4086 }
4088 GI->getAllMetadata(MDs);
4089 if (!MDs.empty()) {
4090 printMetadataAttachments(MDs, ", ");
4091 }
4092
4093 printInfoComment(*GI, GI->isMaterializable());
4094 Out << '\n';
4095}
4096
4097void AssemblyWriter::printComdat(const Comdat *C) {
4098 C->print(Out);
4099}
4100
4101void AssemblyWriter::printTypeIdentities() {
4102 if (TypePrinter.empty())
4103 return;
4104
4105 Out << '\n';
4106
4107 // Emit all numbered types.
4108 auto &NumberedTypes = TypePrinter.getNumberedTypes();
4109 for (unsigned I = 0, E = NumberedTypes.size(); I != E; ++I) {
4110 Out << '%' << I << " = type ";
4111
4112 // Make sure we print out at least one level of the type structure, so
4113 // that we do not get %2 = type %2
4114 TypePrinter.printStructBody(NumberedTypes[I], Out);
4115 Out << '\n';
4116 }
4117
4118 auto &NamedTypes = TypePrinter.getNamedTypes();
4119 for (StructType *NamedType : NamedTypes) {
4120 printLLVMName(Out, NamedType->getName(), LocalPrefix);
4121 Out << " = type ";
4122
4123 // Make sure we print out at least one level of the type structure, so
4124 // that we do not get %FILE = type %FILE
4125 TypePrinter.printStructBody(NamedType, Out);
4126 Out << '\n';
4127 }
4128}
4129
4130/// printFunction - Print all aspects of a function.
4131void AssemblyWriter::printFunction(const Function *F) {
4132 if (F->isMaterializable())
4133 Out << "; Materializable\n";
4134 else if (AnnotationWriter)
4135 AnnotationWriter->emitFunctionAnnot(F, Out);
4136
4137 const AttributeList &Attrs = F->getAttributes();
4138 if (Attrs.hasFnAttrs()) {
4139 AttributeSet AS = Attrs.getFnAttrs();
4140 std::string AttrStr;
4141
4142 for (const Attribute &Attr : AS) {
4143 if (!Attr.isStringAttribute()) {
4144 if (!AttrStr.empty()) AttrStr += ' ';
4145 AttrStr += Attr.getAsString();
4146 }
4147 }
4148
4149 if (!AttrStr.empty())
4150 Out << "; Function Attrs: " << AttrStr << '\n';
4151 }
4152
4153 if (F->isIntrinsic() && F->getIntrinsicID() == Intrinsic::not_intrinsic)
4154 Out << "; Unknown intrinsic\n";
4155
4156 Machine.incorporateFunction(F);
4157
4158 if (F->isDeclaration()) {
4159 Out << "declare";
4161 F->getAllMetadata(MDs);
4162 printMetadataAttachments(MDs, " ");
4163 Out << ' ';
4164 } else
4165 Out << "define ";
4166
4167 Out << getLinkageNameWithSpace(F->getLinkage());
4168 printDSOLocation(*F, Out);
4169 printVisibility(F->getVisibility(), Out);
4170 printDLLStorageClass(F->getDLLStorageClass(), Out);
4171
4172 // Print the calling convention.
4173 if (F->getCallingConv() != CallingConv::C) {
4174 printCallingConv(F->getCallingConv(), Out);
4175 Out << " ";
4176 }
4177
4178 FunctionType *FT = F->getFunctionType();
4179 if (Attrs.hasRetAttrs())
4180 Out << Attrs.getAsString(AttributeList::ReturnIndex) << ' ';
4181 TypePrinter.print(F->getReturnType(), Out);
4182 AsmWriterContext WriterCtx(&TypePrinter, &Machine, F->getParent());
4183 Out << ' ';
4184 writeAsOperandInternal(Out, F, WriterCtx);
4185 Out << '(';
4186
4187 // Loop over the arguments, printing them...
4188 if (F->isDeclaration() && !IsForDebug) {
4189 // We're only interested in the type here - don't print argument names.
4190 ListSeparator LS;
4191 for (unsigned I = 0, E = FT->getNumParams(); I != E; ++I) {
4192 Out << LS;
4193 // Output type.
4194 TypePrinter.print(FT->getParamType(I), Out);
4195
4196 AttributeSet ArgAttrs = Attrs.getParamAttrs(I);
4197 if (ArgAttrs.hasAttributes()) {
4198 Out << ' ';
4199 writeAttributeSet(ArgAttrs);
4200 }
4201 }
4202 } else {
4203 // The arguments are meaningful here, print them in detail.
4204 ListSeparator LS;
4205 for (const Argument &Arg : F->args()) {
4206 Out << LS;
4207 printArgument(&Arg, Attrs.getParamAttrs(Arg.getArgNo()));
4208 }
4209 }
4210
4211 // Finish printing arguments...
4212 if (FT->isVarArg()) {
4213 if (FT->getNumParams()) Out << ", ";
4214 Out << "..."; // Output varargs portion of signature!
4215 }
4216 Out << ')';
4217 StringRef UA = getUnnamedAddrEncoding(F->getUnnamedAddr());
4218 if (!UA.empty())
4219 Out << ' ' << UA;
4220 // We print the function address space if it is non-zero or if we are writing
4221 // a module with a non-zero program address space or if there is no valid
4222 // Module* so that the file can be parsed without the datalayout string.
4223 const Module *Mod = F->getParent();
4224 bool ForcePrintAddressSpace =
4225 !Mod || Mod->getDataLayout().getProgramAddressSpace() != 0;
4226 printAddressSpace(Mod, F->getAddressSpace(), Out, /*Prefix=*/" ",
4227 /*Suffix=*/"", ForcePrintAddressSpace);
4228 if (Attrs.hasFnAttrs())
4229 Out << " #" << Machine.getAttributeGroupSlot(Attrs.getFnAttrs());
4230 if (F->hasSection()) {
4231 Out << " section \"";
4232 printEscapedString(F->getSection(), Out);
4233 Out << '"';
4234 }
4235 if (F->hasPartition()) {
4236 Out << " partition \"";
4237 printEscapedString(F->getPartition(), Out);
4238 Out << '"';
4239 }
4240 maybePrintComdat(Out, *F);
4241 if (MaybeAlign A = F->getAlign())
4242 Out << " align " << A->value();
4243 if (MaybeAlign A = F->getPreferredAlignment())
4244 Out << " prefalign(" << A->value() << ')';
4245 if (F->hasGC())
4246 Out << " gc \"" << F->getGC() << '"';
4247 if (F->hasPrefixData()) {
4248 Out << " prefix ";
4249 writeOperand(F->getPrefixData(), true);
4250 }
4251 if (F->hasPrologueData()) {
4252 Out << " prologue ";
4253 writeOperand(F->getPrologueData(), true);
4254 }
4255 if (F->hasPersonalityFn()) {
4256 Out << " personality ";
4257 writeOperand(F->getPersonalityFn(), /*PrintType=*/true);
4258 }
4259
4260 if (PrintProfData) {
4261 if (auto *MDProf = F->getMetadata(LLVMContext::MD_prof)) {
4262 Out << " ";
4263 MDProf->print(Out, TheModule, /*IsForDebug=*/true);
4264 }
4265 }
4266
4267 if (F->isDeclaration()) {
4268 Out << '\n';
4269 } else {
4271 F->getAllMetadata(MDs);
4272 printMetadataAttachments(MDs, " ");
4273
4274 Out << " {";
4275 // Output all of the function's basic blocks.
4276 for (const BasicBlock &BB : *F)
4277 printBasicBlock(&BB);
4278
4279 // Output the function's use-lists.
4280 printUseLists(F);
4281
4282 Out << "}\n";
4283 }
4284
4285 Machine.purgeFunction();
4286}
4287
4288/// printArgument - This member is called for every argument that is passed into
4289/// the function. Simply print it out
4290void AssemblyWriter::printArgument(const Argument *Arg, AttributeSet Attrs) {
4291 // Output type...
4292 TypePrinter.print(Arg->getType(), Out);
4293
4294 // Output parameter attributes list
4295 if (Attrs.hasAttributes()) {
4296 Out << ' ';
4297 writeAttributeSet(Attrs);
4298 }
4299
4300 // Output name, if available...
4301 if (Arg->hasName()) {
4302 Out << ' ';
4303 printLLVMName(Out, Arg);
4304 } else {
4305 int Slot = Machine.getLocalSlot(Arg);
4306 assert(Slot != -1 && "expect argument in function here");
4307 Out << " %" << Slot;
4308 }
4309}
4310
4311/// printBasicBlock - This member is called for each basic block in a method.
4312void AssemblyWriter::printBasicBlock(const BasicBlock *BB) {
4313 bool IsEntryBlock = BB->getParent() && BB->isEntryBlock();
4314 if (BB->hasName()) { // Print out the label if it exists...
4315 Out << "\n";
4316 printLLVMName(Out, BB->getName(), LabelPrefix);
4317 Out << ':';
4318 } else if (!IsEntryBlock) {
4319 Out << "\n";
4320 int Slot = Machine.getLocalSlot(BB);
4321 if (Slot != -1)
4322 Out << Slot << ":";
4323 else
4324 Out << "<badref>:";
4325 }
4326
4327 if (!IsEntryBlock) {
4328 // Output predecessors for the block.
4329 Out.PadToColumn(50);
4330 Out << ";";
4331 if (pred_empty(BB)) {
4332 Out << " No predecessors!";
4333 } else {
4334 Out << " preds = ";
4335 ListSeparator LS;
4336 for (const BasicBlock *Pred : predecessors(BB)) {
4337 Out << LS;
4338 writeOperand(Pred, false);
4339 }
4340 }
4341 }
4342
4343 Out << "\n";
4344
4345 if (AnnotationWriter) AnnotationWriter->emitBasicBlockStartAnnot(BB, Out);
4346
4347 // Output all of the instructions in the basic block...
4348 for (const Instruction &I : *BB) {
4349 for (const DbgRecord &DR : I.getDbgRecordRange())
4350 printDbgRecordLine(DR);
4351 printInstructionLine(I);
4352 }
4353
4354 if (AnnotationWriter) AnnotationWriter->emitBasicBlockEndAnnot(BB, Out);
4355}
4356
4357/// printInstructionLine - Print an instruction and a newline character.
4358void AssemblyWriter::printInstructionLine(const Instruction &I) {
4359 printInstruction(I);
4360 Out << '\n';
4361}
4362
4363/// printGCRelocateComment - print comment after call to the gc.relocate
4364/// intrinsic indicating base and derived pointer names.
4365void AssemblyWriter::printGCRelocateComment(const GCRelocateInst &Relocate) {
4366 Out << " ; (";
4367 writeOperand(Relocate.getBasePtr(), false);
4368 Out << ", ";
4369 writeOperand(Relocate.getDerivedPtr(), false);
4370 Out << ")";
4371}
4372
4373/// printInfoComment - Print a little comment after the instruction indicating
4374/// which slot it occupies.
4375void AssemblyWriter::printInfoComment(const Value &V, bool isMaterializable) {
4376 if (const auto *Relocate = dyn_cast<GCRelocateInst>(&V))
4377 printGCRelocateComment(*Relocate);
4378
4379 if (AnnotationWriter && !isMaterializable)
4380 AnnotationWriter->printInfoComment(V, Out);
4381
4382 if (PrintInstDebugLocs) {
4383 if (auto *I = dyn_cast<Instruction>(&V)) {
4384 if (I->getDebugLoc()) {
4385 Out << " ; ";
4386 I->getDebugLoc().print(Out);
4387 }
4388 }
4389 }
4390 if (PrintProfData) {
4391 if (auto *I = dyn_cast<Instruction>(&V)) {
4392 if (auto *MD = I->getMetadata(LLVMContext::MD_prof)) {
4393 Out << " ; ";
4394 MD->print(Out, TheModule, /*IsForDebug=*/true);
4395 }
4396 }
4397 }
4398
4399 if (PrintInstAddrs)
4400 Out << " ; " << &V;
4401}
4402
4403static void maybePrintCallAddrSpace(const Value *Operand, const Instruction *I,
4404 raw_ostream &Out) {
4405 if (Operand == nullptr) {
4406 Out << " <cannot get addrspace!>";
4407 return;
4408 }
4409
4410 // We print the address space of the call if it is non-zero.
4411 // We also print it if it is zero but not equal to the program address space
4412 // or if we can't find a valid Module* to make it possible to parse
4413 // the resulting file even without a datalayout string.
4414 unsigned CallAddrSpace = Operand->getType()->getPointerAddressSpace();
4415 const Module *Mod = getModuleFromVal(I);
4416 bool ForcePrintAddrSpace =
4417 !Mod || Mod->getDataLayout().getProgramAddressSpace() != 0;
4418 printAddressSpace(Mod, CallAddrSpace, Out, /*Prefix=*/" ", /*Suffix=*/"",
4419 ForcePrintAddrSpace);
4420}
4421
4422// This member is called for each Instruction in a function..
4423void AssemblyWriter::printInstruction(const Instruction &I) {
4424 if (AnnotationWriter) AnnotationWriter->emitInstructionAnnot(&I, Out);
4425
4426 // Print out indentation for an instruction.
4427 Out << " ";
4428
4429 // Print out name if it exists...
4430 if (I.hasName()) {
4431 printLLVMName(Out, &I);
4432 Out << " = ";
4433 } else if (!I.getType()->isVoidTy()) {
4434 // Print out the def slot taken.
4435 int SlotNum = Machine.getLocalSlot(&I);
4436 if (SlotNum == -1)
4437 Out << "<badref> = ";
4438 else
4439 Out << '%' << SlotNum << " = ";
4440 }
4441
4442 if (const auto *CI = dyn_cast<CallInst>(&I)) {
4443 if (CI->isMustTailCall())
4444 Out << "musttail ";
4445 else if (CI->isTailCall())
4446 Out << "tail ";
4447 else if (CI->isNoTailCall())
4448 Out << "notail ";
4449 }
4450
4451 // Print out the opcode...
4452 Out << I.getOpcodeName();
4453
4454 // If this is an atomic load or store, print out the atomic marker.
4455 if ((isa<LoadInst>(I) && cast<LoadInst>(I).isAtomic()) ||
4456 (isa<StoreInst>(I) && cast<StoreInst>(I).isAtomic()))
4457 Out << " atomic";
4458
4460 Out << " weak";
4461
4462 // If this is a volatile operation, print out the volatile marker.
4463 if ((isa<LoadInst>(I) && cast<LoadInst>(I).isVolatile()) ||
4464 (isa<StoreInst>(I) && cast<StoreInst>(I).isVolatile()) ||
4465 (isa<AtomicCmpXchgInst>(I) && cast<AtomicCmpXchgInst>(I).isVolatile()) ||
4466 (isa<AtomicRMWInst>(I) && cast<AtomicRMWInst>(I).isVolatile()))
4467 Out << " volatile";
4468
4469 // Print out optimization information.
4470 writeOptimizationInfo(Out, &I);
4471
4472 // Print out the compare instruction predicates
4473 if (const auto *CI = dyn_cast<CmpInst>(&I))
4474 Out << ' ' << CI->getPredicate();
4475
4476 // Print out the atomicrmw operation
4477 if (const auto *RMWI = dyn_cast<AtomicRMWInst>(&I))
4478 Out << ' ' << AtomicRMWInst::getOperationName(RMWI->getOperation());
4479
4480 // Print out the type of the operands...
4481 const Value *Operand = I.getNumOperands() ? I.getOperand(0) : nullptr;
4482
4483 // Special case conditional branches to swizzle the condition out to the front
4484 if (const auto *BI = dyn_cast<CondBrInst>(&I)) {
4485 Out << ' ';
4486 writeOperand(BI->getCondition(), true);
4487 Out << ", ";
4488 writeOperand(BI->getSuccessor(0), true);
4489 Out << ", ";
4490 writeOperand(BI->getSuccessor(1), true);
4491 } else if (isa<SwitchInst>(I)) {
4492 const SwitchInst& SI(cast<SwitchInst>(I));
4493 // Special case switch instruction to get formatting nice and correct.
4494 Out << ' ';
4495 writeOperand(SI.getCondition(), true);
4496 Out << ", ";
4497 writeOperand(SI.getDefaultDest(), true);
4498 Out << " [";
4499 for (auto Case : SI.cases()) {
4500 Out << "\n ";
4501 writeOperand(Case.getCaseValue(), true);
4502 Out << ", ";
4503 writeOperand(Case.getCaseSuccessor(), true);
4504 }
4505 Out << "\n ]";
4506 } else if (isa<IndirectBrInst>(I)) {
4507 // Special case indirectbr instruction to get formatting nice and correct.
4508 Out << ' ';
4509 writeOperand(Operand, true);
4510 Out << ", [";
4511
4512 ListSeparator LS;
4513 for (unsigned i = 1, e = I.getNumOperands(); i != e; ++i) {
4514 Out << LS;
4515 writeOperand(I.getOperand(i), true);
4516 }
4517 Out << ']';
4518 } else if (const auto *PN = dyn_cast<PHINode>(&I)) {
4519 Out << ' ';
4520 TypePrinter.print(I.getType(), Out);
4521 Out << ' ';
4522
4523 ListSeparator LS;
4524 for (const auto &[V, Block] :
4525 zip_equal(PN->incoming_values(), PN->blocks())) {
4526 Out << LS << "[ ";
4527 writeOperand(V, false);
4528 Out << ", ";
4529 writeOperand(Block, false);
4530 Out << " ]";
4531 }
4532 } else if (const auto *EVI = dyn_cast<ExtractValueInst>(&I)) {
4533 Out << ' ';
4534 writeOperand(I.getOperand(0), true);
4535 Out << ", ";
4536 Out << llvm::interleaved(EVI->indices());
4537 } else if (const auto *IVI = dyn_cast<InsertValueInst>(&I)) {
4538 Out << ' ';
4539 writeOperand(I.getOperand(0), true); Out << ", ";
4540 writeOperand(I.getOperand(1), true);
4541 Out << ", ";
4542 Out << llvm::interleaved(IVI->indices());
4543 } else if (const auto *LPI = dyn_cast<LandingPadInst>(&I)) {
4544 Out << ' ';
4545 TypePrinter.print(I.getType(), Out);
4546 if (LPI->isCleanup() || LPI->getNumClauses() != 0)
4547 Out << '\n';
4548
4549 if (LPI->isCleanup())
4550 Out << " cleanup";
4551
4552 for (unsigned i = 0, e = LPI->getNumClauses(); i != e; ++i) {
4553 if (i != 0 || LPI->isCleanup()) Out << "\n";
4554 if (LPI->isCatch(i))
4555 Out << " catch ";
4556 else
4557 Out << " filter ";
4558
4559 writeOperand(LPI->getClause(i), true);
4560 }
4561 } else if (const auto *CatchSwitch = dyn_cast<CatchSwitchInst>(&I)) {
4562 Out << " within ";
4563 writeOperand(CatchSwitch->getParentPad(), /*PrintType=*/false);
4564 Out << " [";
4565 ListSeparator LS;
4566 for (const BasicBlock *PadBB : CatchSwitch->handlers()) {
4567 Out << LS;
4568 writeOperand(PadBB, /*PrintType=*/true);
4569 }
4570 Out << "] unwind ";
4571 if (const BasicBlock *UnwindDest = CatchSwitch->getUnwindDest())
4572 writeOperand(UnwindDest, /*PrintType=*/true);
4573 else
4574 Out << "to caller";
4575 } else if (const auto *FPI = dyn_cast<FuncletPadInst>(&I)) {
4576 Out << " within ";
4577 writeOperand(FPI->getParentPad(), /*PrintType=*/false);
4578 Out << " [";
4579 ListSeparator LS;
4580 for (const Value *Op : FPI->arg_operands()) {
4581 Out << LS;
4582 writeOperand(Op, /*PrintType=*/true);
4583 }
4584 Out << ']';
4585 } else if (isa<ReturnInst>(I) && !Operand) {
4586 Out << " void";
4587 } else if (const auto *CRI = dyn_cast<CatchReturnInst>(&I)) {
4588 Out << " from ";
4589 writeOperand(CRI->getOperand(0), /*PrintType=*/false);
4590
4591 Out << " to ";
4592 writeOperand(CRI->getOperand(1), /*PrintType=*/true);
4593 } else if (const auto *CRI = dyn_cast<CleanupReturnInst>(&I)) {
4594 Out << " from ";
4595 writeOperand(CRI->getOperand(0), /*PrintType=*/false);
4596
4597 Out << " unwind ";
4598 if (CRI->hasUnwindDest())
4599 writeOperand(CRI->getOperand(1), /*PrintType=*/true);
4600 else
4601 Out << "to caller";
4602 } else if (const auto *CI = dyn_cast<CallInst>(&I)) {
4603 // Print the calling convention being used.
4604 if (CI->getCallingConv() != CallingConv::C) {
4605 Out << " ";
4606 printCallingConv(CI->getCallingConv(), Out);
4607 }
4608
4609 Operand = CI->getCalledOperand();
4610 FunctionType *FTy = CI->getFunctionType();
4611 Type *RetTy = FTy->getReturnType();
4612 const AttributeList &PAL = CI->getAttributes();
4613
4614 if (PAL.hasRetAttrs())
4615 Out << ' ' << PAL.getAsString(AttributeList::ReturnIndex);
4616
4617 // Only print addrspace(N) if necessary:
4618 maybePrintCallAddrSpace(Operand, &I, Out);
4619
4620 // If possible, print out the short form of the call instruction. We can
4621 // only do this if the first argument is a pointer to a nonvararg function,
4622 // and if the return type is not a pointer to a function.
4623 Out << ' ';
4624 TypePrinter.print(FTy->isVarArg() ? FTy : RetTy, Out);
4625 Out << ' ';
4626 writeOperand(Operand, false);
4627 Out << '(';
4628 bool HasPrettyPrintedArgs =
4629 isa<IntrinsicInst>(CI) &&
4630 Intrinsic::hasPrettyPrintedArgs(CI->getIntrinsicID());
4631
4632 ListSeparator LS;
4633 Function *CalledFunc = CI->getCalledFunction();
4634 auto PrintArgComment = [&](unsigned ArgNo) {
4635 const auto *ConstArg = dyn_cast<Constant>(CI->getArgOperand(ArgNo));
4636 if (!ConstArg)
4637 return;
4638 std::string ArgComment;
4639 raw_string_ostream ArgCommentStream(ArgComment);
4640 Intrinsic::ID IID = CalledFunc->getIntrinsicID();
4641 Intrinsic::printImmArg(IID, ArgNo, ArgCommentStream, ConstArg);
4642 if (ArgComment.empty())
4643 return;
4644 Out << "/* " << ArgComment << " */ ";
4645 };
4646 if (HasPrettyPrintedArgs) {
4647 for (unsigned ArgNo = 0, NumArgs = CI->arg_size(); ArgNo < NumArgs;
4648 ++ArgNo) {
4649 Out << LS;
4650 PrintArgComment(ArgNo);
4651 writeParamOperand(CI->getArgOperand(ArgNo), PAL.getParamAttrs(ArgNo));
4652 }
4653 } else {
4654 for (unsigned ArgNo = 0, NumArgs = CI->arg_size(); ArgNo < NumArgs;
4655 ++ArgNo) {
4656 Out << LS;
4657 writeParamOperand(CI->getArgOperand(ArgNo), PAL.getParamAttrs(ArgNo));
4658 }
4659 }
4660 // Emit an ellipsis if this is a musttail call in a vararg function. This
4661 // is only to aid readability, musttail calls forward varargs by default.
4662 if (CI->isMustTailCall() && CI->getParent() &&
4663 CI->getParent()->getParent() &&
4664 CI->getParent()->getParent()->isVarArg()) {
4665 if (CI->arg_size() > 0)
4666 Out << ", ";
4667 Out << "...";
4668 }
4669
4670 Out << ')';
4671 if (PAL.hasFnAttrs())
4672 Out << " #" << Machine.getAttributeGroupSlot(PAL.getFnAttrs());
4673
4674 writeOperandBundles(CI);
4675 } else if (const auto *II = dyn_cast<InvokeInst>(&I)) {
4676 Operand = II->getCalledOperand();
4677 FunctionType *FTy = II->getFunctionType();
4678 Type *RetTy = FTy->getReturnType();
4679 const AttributeList &PAL = II->getAttributes();
4680
4681 // Print the calling convention being used.
4682 if (II->getCallingConv() != CallingConv::C) {
4683 Out << " ";
4684 printCallingConv(II->getCallingConv(), Out);
4685 }
4686
4687 if (PAL.hasRetAttrs())
4688 Out << ' ' << PAL.getAsString(AttributeList::ReturnIndex);
4689
4690 // Only print addrspace(N) if necessary:
4691 maybePrintCallAddrSpace(Operand, &I, Out);
4692
4693 // If possible, print out the short form of the invoke instruction. We can
4694 // only do this if the first argument is a pointer to a nonvararg function,
4695 // and if the return type is not a pointer to a function.
4696 //
4697 Out << ' ';
4698 TypePrinter.print(FTy->isVarArg() ? FTy : RetTy, Out);
4699 Out << ' ';
4700 writeOperand(Operand, false);
4701 Out << '(';
4702 ListSeparator LS;
4703 for (unsigned op = 0, Eop = II->arg_size(); op < Eop; ++op) {
4704 Out << LS;
4705 writeParamOperand(II->getArgOperand(op), PAL.getParamAttrs(op));
4706 }
4707
4708 Out << ')';
4709 if (PAL.hasFnAttrs())
4710 Out << " #" << Machine.getAttributeGroupSlot(PAL.getFnAttrs());
4711
4712 writeOperandBundles(II);
4713
4714 Out << "\n to ";
4715 writeOperand(II->getNormalDest(), true);
4716 Out << " unwind ";
4717 writeOperand(II->getUnwindDest(), true);
4718 } else if (const auto *CBI = dyn_cast<CallBrInst>(&I)) {
4719 Operand = CBI->getCalledOperand();
4720 FunctionType *FTy = CBI->getFunctionType();
4721 Type *RetTy = FTy->getReturnType();
4722 const AttributeList &PAL = CBI->getAttributes();
4723
4724 // Print the calling convention being used.
4725 if (CBI->getCallingConv() != CallingConv::C) {
4726 Out << " ";
4727 printCallingConv(CBI->getCallingConv(), Out);
4728 }
4729
4730 if (PAL.hasRetAttrs())
4731 Out << ' ' << PAL.getAsString(AttributeList::ReturnIndex);
4732
4733 // If possible, print out the short form of the callbr instruction. We can
4734 // only do this if the first argument is a pointer to a nonvararg function,
4735 // and if the return type is not a pointer to a function.
4736 //
4737 Out << ' ';
4738 TypePrinter.print(FTy->isVarArg() ? FTy : RetTy, Out);
4739 Out << ' ';
4740 writeOperand(Operand, false);
4741 Out << '(';
4742 ListSeparator ArgLS;
4743 for (unsigned op = 0, Eop = CBI->arg_size(); op < Eop; ++op) {
4744 Out << ArgLS;
4745 writeParamOperand(CBI->getArgOperand(op), PAL.getParamAttrs(op));
4746 }
4747
4748 Out << ')';
4749 if (PAL.hasFnAttrs())
4750 Out << " #" << Machine.getAttributeGroupSlot(PAL.getFnAttrs());
4751
4752 writeOperandBundles(CBI);
4753
4754 Out << "\n to ";
4755 writeOperand(CBI->getDefaultDest(), true);
4756 Out << " [";
4757 ListSeparator DestLS;
4758 for (const BasicBlock *Dest : CBI->getIndirectDests()) {
4759 Out << DestLS;
4760 writeOperand(Dest, true);
4761 }
4762 Out << ']';
4763 } else if (const auto *AI = dyn_cast<AllocaInst>(&I)) {
4764 Out << ' ';
4765 if (AI->isUsedWithInAlloca())
4766 Out << "inalloca ";
4767 if (AI->isSwiftError())
4768 Out << "swifterror ";
4769 TypePrinter.print(AI->getAllocatedType(), Out);
4770
4771 // Explicitly write the array size if the code is broken, if it's an array
4772 // allocation, or if the type is not canonical for scalar allocations. The
4773 // latter case prevents the type from mutating when round-tripping through
4774 // assembly.
4775 if (!AI->getArraySize() || AI->isArrayAllocation() ||
4776 !AI->getArraySize()->getType()->isIntegerTy(32)) {
4777 Out << ", ";
4778 writeOperand(AI->getArraySize(), true);
4779 }
4780 if (MaybeAlign A = AI->getAlign()) {
4781 Out << ", align " << A->value();
4782 }
4783
4784 printAddressSpace(AI->getModule(), AI->getAddressSpace(), Out,
4785 /*Prefix=*/", ");
4786 } else if (isa<CastInst>(I)) {
4787 if (Operand) {
4788 Out << ' ';
4789 writeOperand(Operand, true); // Work with broken code
4790 }
4791 Out << " to ";
4792 TypePrinter.print(I.getType(), Out);
4793 } else if (isa<VAArgInst>(I)) {
4794 if (Operand) {
4795 Out << ' ';
4796 writeOperand(Operand, true); // Work with broken code
4797 }
4798 Out << ", ";
4799 TypePrinter.print(I.getType(), Out);
4800 } else if (Operand) { // Print the normal way.
4801 if (const auto *GEP = dyn_cast<GetElementPtrInst>(&I)) {
4802 Out << ' ';
4803 TypePrinter.print(GEP->getSourceElementType(), Out);
4804 Out << ',';
4805 } else if (const auto *LI = dyn_cast<LoadInst>(&I)) {
4806 Out << ' ';
4807 TypePrinter.print(LI->getType(), Out);
4808 Out << ',';
4809 }
4810
4811 // PrintAllTypes - Instructions who have operands of all the same type
4812 // omit the type from all but the first operand. If the instruction has
4813 // different type operands (for example br), then they are all printed.
4814 bool PrintAllTypes = false;
4815 Type *TheType = Operand->getType();
4816
4817 // Select, Store, ShuffleVector, CmpXchg and AtomicRMW always print all
4818 // types.
4822 PrintAllTypes = true;
4823 } else {
4824 for (unsigned i = 1, E = I.getNumOperands(); i != E; ++i) {
4825 Operand = I.getOperand(i);
4826 // note that Operand shouldn't be null, but the test helps make dump()
4827 // more tolerant of malformed IR
4828 if (Operand && Operand->getType() != TheType) {
4829 PrintAllTypes = true; // We have differing types! Print them all!
4830 break;
4831 }
4832 }
4833 }
4834
4835 if (!PrintAllTypes) {
4836 Out << ' ';
4837 TypePrinter.print(TheType, Out);
4838 }
4839
4840 Out << ' ';
4841 ListSeparator LS;
4842 for (const Value *Op : I.operands()) {
4843 Out << LS;
4844 writeOperand(Op, PrintAllTypes);
4845 }
4846 }
4847
4848 // Print atomic ordering/alignment for memory operations
4849 if (const auto *LI = dyn_cast<LoadInst>(&I)) {
4850 if (LI->isAtomic())
4851 writeAtomic(LI->getContext(), LI->getOrdering(), LI->getSyncScopeID());
4852 if (MaybeAlign A = LI->getAlign())
4853 Out << ", align " << A->value();
4854 } else if (const auto *SI = dyn_cast<StoreInst>(&I)) {
4855 if (SI->isAtomic())
4856 writeAtomic(SI->getContext(), SI->getOrdering(), SI->getSyncScopeID());
4857 if (MaybeAlign A = SI->getAlign())
4858 Out << ", align " << A->value();
4859 } else if (const auto *CXI = dyn_cast<AtomicCmpXchgInst>(&I)) {
4860 writeAtomicCmpXchg(CXI->getContext(), CXI->getSuccessOrdering(),
4861 CXI->getFailureOrdering(), CXI->getSyncScopeID());
4862 Out << ", align " << CXI->getAlign().value();
4863 } else if (const auto *RMWI = dyn_cast<AtomicRMWInst>(&I)) {
4864 writeAtomic(RMWI->getContext(), RMWI->getOrdering(),
4865 RMWI->getSyncScopeID());
4866 Out << ", align " << RMWI->getAlign().value();
4867 } else if (const auto *FI = dyn_cast<FenceInst>(&I)) {
4868 writeAtomic(FI->getContext(), FI->getOrdering(), FI->getSyncScopeID());
4869 } else if (const auto *SVI = dyn_cast<ShuffleVectorInst>(&I)) {
4870 printShuffleMask(Out, SVI->getType(), SVI->getShuffleMask());
4871 }
4872
4873 // Print Metadata info.
4875 I.getAllMetadata(InstMD);
4876 printMetadataAttachments(InstMD, ", ");
4877
4878 // Print a nice comment.
4879 printInfoComment(I);
4880}
4881
4882void AssemblyWriter::printDbgMarker(const DbgMarker &Marker) {
4883 // There's no formal representation of a DbgMarker -- print purely as a
4884 // debugging aid.
4885 for (const DbgRecord &DPR : Marker.StoredDbgRecords) {
4886 printDbgRecord(DPR);
4887 Out << "\n";
4888 }
4889
4890 Out << " DbgMarker -> { ";
4891 printInstruction(*Marker.MarkedInstr);
4892 Out << " }";
4893}
4894
4895void AssemblyWriter::printDbgRecord(const DbgRecord &DR) {
4896 if (auto *DVR = dyn_cast<DbgVariableRecord>(&DR))
4897 printDbgVariableRecord(*DVR);
4898 else if (auto *DLR = dyn_cast<DbgLabelRecord>(&DR))
4899 printDbgLabelRecord(*DLR);
4900 else
4901 llvm_unreachable("Unexpected DbgRecord kind");
4902}
4903
4904void AssemblyWriter::printDbgVariableRecord(const DbgVariableRecord &DVR) {
4905 auto WriterCtx = getContext();
4906 Out << "#dbg_";
4907 switch (DVR.getType()) {
4908 case DbgVariableRecord::LocationType::Value:
4909 Out << "value";
4910 break;
4911 case DbgVariableRecord::LocationType::Declare:
4912 Out << "declare";
4913 break;
4914 case DbgVariableRecord::LocationType::DeclareValue:
4915 Out << "declare_value";
4916 break;
4917 case DbgVariableRecord::LocationType::Assign:
4918 Out << "assign";
4919 break;
4920 default:
4922 "Tried to print a DbgVariableRecord with an invalid LocationType!");
4923 }
4924
4925 auto PrintOrNull = [&](Metadata *M) {
4926 if (!M)
4927 Out << "(null)";
4928 else
4929 writeAsOperandInternal(Out, M, WriterCtx, true);
4930 };
4931
4932 Out << "(";
4933 PrintOrNull(DVR.getRawLocation());
4934 Out << ", ";
4935 PrintOrNull(DVR.getRawVariable());
4936 Out << ", ";
4937 PrintOrNull(DVR.getRawExpression());
4938 Out << ", ";
4939 if (DVR.isDbgAssign()) {
4940 PrintOrNull(DVR.getRawAssignID());
4941 Out << ", ";
4942 PrintOrNull(DVR.getRawAddress());
4943 Out << ", ";
4944 PrintOrNull(DVR.getRawAddressExpression());
4945 Out << ", ";
4946 }
4947 PrintOrNull(DVR.getDebugLoc().getAsMDNode());
4948 Out << ")";
4949}
4950
4951/// printDbgRecordLine - Print a DbgRecord with indentation and a newline
4952/// character.
4953void AssemblyWriter::printDbgRecordLine(const DbgRecord &DR) {
4954 // Print lengthier indentation to bring out-of-line with instructions.
4955 Out << " ";
4956 printDbgRecord(DR);
4957 Out << '\n';
4958}
4959
4960void AssemblyWriter::printDbgLabelRecord(const DbgLabelRecord &Label) {
4961 auto WriterCtx = getContext();
4962 Out << "#dbg_label(";
4963 writeAsOperandInternal(Out, Label.getRawLabel(), WriterCtx, true);
4964 Out << ", ";
4965 writeAsOperandInternal(Out, Label.getDebugLoc(), WriterCtx, true);
4966 Out << ")";
4967}
4968
4969void AssemblyWriter::printMetadataAttachments(
4970 const SmallVectorImpl<std::pair<unsigned, MDNode *>> &MDs,
4971 StringRef Separator) {
4972 if (MDs.empty())
4973 return;
4974
4975 if (MDNames.empty())
4976 MDs[0].second->getContext().getMDKindNames(MDNames);
4977
4978 auto WriterCtx = getContext();
4979 for (const auto &I : MDs) {
4980 unsigned Kind = I.first;
4981 Out << Separator;
4982 if (Kind < MDNames.size()) {
4983 Out << "!";
4984 printMetadataIdentifier(MDNames[Kind], Out);
4985 } else
4986 Out << "!<unknown kind #" << Kind << ">";
4987 Out << ' ';
4988 writeAsOperandInternal(Out, I.second, WriterCtx);
4989 }
4990}
4991
4992void AssemblyWriter::writeMDNode(unsigned Slot, const MDNode *Node) {
4993 Out << '!' << Slot << " = ";
4994 printMDNodeBody(Node);
4995 Out << "\n";
4996}
4997
4998void AssemblyWriter::writeAllMDNodes() {
5000 Nodes.resize(Machine.mdn_size());
5001 for (auto &I : llvm::make_range(Machine.mdn_begin(), Machine.mdn_end()))
5002 Nodes[I.second] = cast<MDNode>(I.first);
5003
5004 for (unsigned i = 0, e = Nodes.size(); i != e; ++i) {
5005 writeMDNode(i, Nodes[i]);
5006 }
5007}
5008
5009void AssemblyWriter::printMDNodeBody(const MDNode *Node) {
5010 auto WriterCtx = getContext();
5011 writeMDNodeBodyInternal(Out, Node, WriterCtx);
5012}
5013
5014void AssemblyWriter::writeAttribute(const Attribute &Attr, bool InAttrGroup) {
5015 if (!Attr.isTypeAttribute()) {
5016 Out << Attr.getAsString(InAttrGroup);
5017 return;
5018 }
5019
5020 Out << Attribute::getNameFromAttrKind(Attr.getKindAsEnum());
5021 if (Type *Ty = Attr.getValueAsType()) {
5022 Out << '(';
5023 TypePrinter.print(Ty, Out);
5024 Out << ')';
5025 }
5026}
5027
5028void AssemblyWriter::writeAttributeSet(const AttributeSet &AttrSet,
5029 bool InAttrGroup) {
5030 ListSeparator LS(" ");
5031 for (const auto &Attr : AttrSet) {
5032 Out << LS;
5033 writeAttribute(Attr, InAttrGroup);
5034 }
5035}
5036
5037void AssemblyWriter::writeAllAttributeGroups() {
5038 std::vector<std::pair<AttributeSet, unsigned>> asVec;
5039 asVec.resize(Machine.as_size());
5040
5041 for (auto &I : llvm::make_range(Machine.as_begin(), Machine.as_end()))
5042 asVec[I.second] = I;
5043
5044 for (const auto &I : asVec)
5045 Out << "attributes #" << I.second << " = { "
5046 << I.first.getAsString(true) << " }\n";
5047}
5048
5049void AssemblyWriter::printUseListOrder(const Value *V,
5050 ArrayRef<unsigned> Shuffle) {
5051 bool IsInFunction = Machine.getFunction();
5052 if (IsInFunction)
5053 Out << " ";
5054
5055 Out << "uselistorder";
5056 if (const BasicBlock *BB = IsInFunction ? nullptr : dyn_cast<BasicBlock>(V)) {
5057 Out << "_bb ";
5058 writeOperand(BB->getParent(), false);
5059 Out << ", ";
5060 writeOperand(BB, false);
5061 } else {
5062 Out << " ";
5063 writeOperand(V, true);
5064 }
5065
5066 assert(Shuffle.size() >= 2 && "Shuffle too small");
5067 Out << ", { " << llvm::interleaved(Shuffle) << " }\n";
5068}
5069
5070void AssemblyWriter::printUseLists(const Function *F) {
5071 auto It = UseListOrders.find(F);
5072 if (It == UseListOrders.end())
5073 return;
5074
5075 Out << "\n; uselistorder directives\n";
5076 for (const auto &Pair : It->second)
5077 printUseListOrder(Pair.first, Pair.second);
5078}
5079
5080//===----------------------------------------------------------------------===//
5081// External Interface declarations
5082//===----------------------------------------------------------------------===//
5083
5085 bool ShouldPreserveUseListOrder, bool IsForDebug) const {
5086 SlotTracker SlotTable(this->getParent());
5087 formatted_raw_ostream OS(ROS);
5088 AssemblyWriter W(OS, SlotTable, this->getParent(), AAW, IsForDebug,
5089 ShouldPreserveUseListOrder);
5090 W.printFunction(this);
5091}
5092
5094 bool ShouldPreserveUseListOrder,
5095 bool IsForDebug) const {
5096 SlotTracker SlotTable(this->getParent());
5097 formatted_raw_ostream OS(ROS);
5098 AssemblyWriter W(OS, SlotTable, this->getModule(), AAW,
5099 IsForDebug,
5100 ShouldPreserveUseListOrder);
5101 W.printBasicBlock(this);
5102}
5103
5105 bool ShouldPreserveUseListOrder, bool IsForDebug) const {
5106 SlotTracker SlotTable(this);
5107 formatted_raw_ostream OS(ROS);
5108 AssemblyWriter W(OS, SlotTable, this, AAW, IsForDebug,
5109 ShouldPreserveUseListOrder);
5110 W.printModule(this);
5111}
5112
5113void NamedMDNode::print(raw_ostream &ROS, bool IsForDebug) const {
5114 SlotTracker SlotTable(getParent());
5115 formatted_raw_ostream OS(ROS);
5116 AssemblyWriter W(OS, SlotTable, getParent(), nullptr, IsForDebug);
5117 W.printNamedMDNode(this);
5118}
5119
5121 bool IsForDebug) const {
5122 std::optional<SlotTracker> LocalST;
5123 SlotTracker *SlotTable;
5124 if (auto *ST = MST.getMachine())
5125 SlotTable = ST;
5126 else {
5127 LocalST.emplace(getParent());
5128 SlotTable = &*LocalST;
5129 }
5130
5131 formatted_raw_ostream OS(ROS);
5132 AssemblyWriter W(OS, *SlotTable, getParent(), nullptr, IsForDebug);
5133 W.printNamedMDNode(this);
5134}
5135
5136void Comdat::print(raw_ostream &ROS, bool /*IsForDebug*/) const {
5138 ROS << " = comdat ";
5139
5140 switch (getSelectionKind()) {
5141 case Comdat::Any:
5142 ROS << "any";
5143 break;
5144 case Comdat::ExactMatch:
5145 ROS << "exactmatch";
5146 break;
5147 case Comdat::Largest:
5148 ROS << "largest";
5149 break;
5151 ROS << "nodeduplicate";
5152 break;
5153 case Comdat::SameSize:
5154 ROS << "samesize";
5155 break;
5156 }
5157
5158 ROS << '\n';
5159}
5160
5161void Type::print(raw_ostream &OS, bool /*IsForDebug*/, bool NoDetails) const {
5162 TypePrinting TP;
5163 TP.print(const_cast<Type*>(this), OS);
5164
5165 if (NoDetails)
5166 return;
5167
5168 // If the type is a named struct type, print the body as well.
5169 if (auto *STy = dyn_cast<StructType>(const_cast<Type *>(this)))
5170 if (!STy->isLiteral()) {
5171 OS << " = type ";
5172 TP.printStructBody(STy, OS);
5173 }
5174}
5175
5176static bool isReferencingMDNode(const Instruction &I) {
5177 if (const auto *CI = dyn_cast<CallInst>(&I))
5178 if (Function *F = CI->getCalledFunction())
5179 if (F->isIntrinsic())
5180 for (auto &Op : I.operands())
5182 if (isa<MDNode>(V->getMetadata()))
5183 return true;
5184 return false;
5185}
5186
5187void DbgMarker::print(raw_ostream &ROS, bool IsForDebug) const {
5188
5189 ModuleSlotTracker MST(getModuleFromDPI(this), true);
5190 print(ROS, MST, IsForDebug);
5191}
5192
5193void DbgVariableRecord::print(raw_ostream &ROS, bool IsForDebug) const {
5194
5195 ModuleSlotTracker MST(getModuleFromDPI(this), true);
5196 print(ROS, MST, IsForDebug);
5197}
5198
5200 bool IsForDebug) const {
5201 formatted_raw_ostream OS(ROS);
5202 SlotTracker EmptySlotTable(static_cast<const Module *>(nullptr));
5203 SlotTracker &SlotTable =
5204 MST.getMachine() ? *MST.getMachine() : EmptySlotTable;
5205 const Function *F = getParent() ? getParent()->getParent() : nullptr;
5206 if (F)
5207 MST.incorporateFunction(*F);
5208 AssemblyWriter W(OS, SlotTable, getModuleFromDPI(this), nullptr, IsForDebug);
5209 W.printDbgMarker(*this);
5210}
5211
5212void DbgLabelRecord::print(raw_ostream &ROS, bool IsForDebug) const {
5213
5214 ModuleSlotTracker MST(getModuleFromDPI(this), true);
5215 print(ROS, MST, IsForDebug);
5216}
5217
5219 bool IsForDebug) const {
5220 formatted_raw_ostream OS(ROS);
5221 SlotTracker EmptySlotTable(static_cast<const Module *>(nullptr));
5222 SlotTracker &SlotTable =
5223 MST.getMachine() ? *MST.getMachine() : EmptySlotTable;
5224 const Function *F = Marker && Marker->getParent()
5225 ? Marker->getParent()->getParent()
5226 : nullptr;
5227 if (F)
5228 MST.incorporateFunction(*F);
5229 AssemblyWriter W(OS, SlotTable, getModuleFromDPI(this), nullptr, IsForDebug);
5230 W.printDbgVariableRecord(*this);
5231}
5232
5234 bool IsForDebug) const {
5235 formatted_raw_ostream OS(ROS);
5236 SlotTracker EmptySlotTable(static_cast<const Module *>(nullptr));
5237 SlotTracker &SlotTable =
5238 MST.getMachine() ? *MST.getMachine() : EmptySlotTable;
5239 const Function *F =
5240 Marker->getParent() ? Marker->getParent()->getParent() : nullptr;
5241 if (F)
5242 MST.incorporateFunction(*F);
5243
5244 AssemblyWriter W(OS, SlotTable, getModuleFromDPI(this), nullptr, IsForDebug);
5245 W.printDbgLabelRecord(*this);
5246}
5247
5248void Value::print(raw_ostream &ROS, bool IsForDebug) const {
5249 bool ShouldInitializeAllMetadata = false;
5250 if (auto *I = dyn_cast<Instruction>(this))
5251 ShouldInitializeAllMetadata = isReferencingMDNode(*I);
5252 else if (isa<Function>(this) || isa<MetadataAsValue>(this))
5253 ShouldInitializeAllMetadata = true;
5254
5255 ModuleSlotTracker MST(getModuleFromVal(this), ShouldInitializeAllMetadata);
5256 print(ROS, MST, IsForDebug);
5257}
5258
5260 bool IsForDebug) const {
5261 formatted_raw_ostream OS(ROS);
5262 SlotTracker EmptySlotTable(static_cast<const Module *>(nullptr));
5263 SlotTracker &SlotTable =
5264 MST.getMachine() ? *MST.getMachine() : EmptySlotTable;
5265 auto IncorporateFunction = [&](const Function *F) {
5266 if (F)
5267 MST.incorporateFunction(*F);
5268 };
5269
5270 if (const auto *I = dyn_cast<Instruction>(this)) {
5271 IncorporateFunction(I->getParent() ? I->getParent()->getParent() : nullptr);
5272 AssemblyWriter W(OS, SlotTable, getModuleFromVal(I), nullptr, IsForDebug);
5273 W.printInstruction(*I);
5274 } else if (const auto *BB = dyn_cast<BasicBlock>(this)) {
5275 IncorporateFunction(BB->getParent());
5276 AssemblyWriter W(OS, SlotTable, getModuleFromVal(BB), nullptr, IsForDebug);
5277 W.printBasicBlock(BB);
5278 } else if (const auto *GV = dyn_cast<GlobalValue>(this)) {
5279 AssemblyWriter W(OS, SlotTable, GV->getParent(), nullptr, IsForDebug);
5280 if (const auto *V = dyn_cast<GlobalVariable>(GV))
5281 W.printGlobal(V);
5282 else if (const auto *F = dyn_cast<Function>(GV))
5283 W.printFunction(F);
5284 else if (const auto *A = dyn_cast<GlobalAlias>(GV))
5285 W.printAlias(A);
5286 else if (const auto *I = dyn_cast<GlobalIFunc>(GV))
5287 W.printIFunc(I);
5288 else
5289 llvm_unreachable("Unknown GlobalValue to print out!");
5290 } else if (const auto *V = dyn_cast<MetadataAsValue>(this)) {
5291 V->getMetadata()->print(ROS, MST, getModuleFromVal(V));
5292 } else if (const auto *C = dyn_cast<Constant>(this)) {
5293 TypePrinting TypePrinter;
5294 TypePrinter.print(C->getType(), OS);
5295 OS << ' ';
5296 AsmWriterContext WriterCtx(&TypePrinter, MST.getMachine());
5297 writeConstantInternal(OS, C, WriterCtx);
5298 } else if (isa<InlineAsm>(this) || isa<Argument>(this)) {
5299 this->printAsOperand(OS, /* PrintType */ true, MST);
5300 } else {
5301 llvm_unreachable("Unknown value to print out!");
5302 }
5303}
5304
5305/// Print without a type, skipping the TypePrinting object.
5306///
5307/// \return \c true iff printing was successful.
5308static bool printWithoutType(const Value &V, raw_ostream &O,
5309 SlotTracker *Machine, const Module *M) {
5310 if (V.hasName() || isa<GlobalValue>(V) ||
5311 (!isa<Constant>(V) && !isa<MetadataAsValue>(V))) {
5312 AsmWriterContext WriterCtx(nullptr, Machine, M);
5313 writeAsOperandInternal(O, &V, WriterCtx);
5314 return true;
5315 }
5316 return false;
5317}
5318
5319static void printAsOperandImpl(const Value &V, raw_ostream &O, bool PrintType,
5320 ModuleSlotTracker &MST) {
5321 TypePrinting TypePrinter(MST.getModule());
5322 AsmWriterContext WriterCtx(&TypePrinter, MST.getMachine(), MST.getModule());
5323 writeAsOperandInternal(O, &V, WriterCtx, PrintType);
5324}
5325
5326void Value::printAsOperand(raw_ostream &O, bool PrintType,
5327 const Module *M) const {
5328 if (!M)
5329 M = getModuleFromVal(this);
5330
5331 if (!PrintType)
5332 if (printWithoutType(*this, O, nullptr, M))
5333 return;
5334
5336 M, /* ShouldInitializeAllMetadata */ isa<MetadataAsValue>(this));
5337 ModuleSlotTracker MST(Machine, M);
5338 printAsOperandImpl(*this, O, PrintType, MST);
5339}
5340
5341void Value::printAsOperand(raw_ostream &O, bool PrintType,
5342 ModuleSlotTracker &MST) const {
5343 if (!PrintType)
5344 if (printWithoutType(*this, O, MST.getMachine(), MST.getModule()))
5345 return;
5346
5347 printAsOperandImpl(*this, O, PrintType, MST);
5348}
5349
5350/// Recursive version of printMetadataImpl.
5351static void printMetadataImplRec(raw_ostream &ROS, const Metadata &MD,
5352 AsmWriterContext &WriterCtx) {
5353 formatted_raw_ostream OS(ROS);
5354 writeAsOperandInternal(OS, &MD, WriterCtx, /* FromValue */ true);
5355
5356 auto *N = dyn_cast<MDNode>(&MD);
5357 if (!N || isa<DIExpression>(MD))
5358 return;
5359
5360 OS << " = ";
5361 writeMDNodeBodyInternal(OS, N, WriterCtx);
5362}
5363
5364namespace {
5365struct MDTreeAsmWriterContext : public AsmWriterContext {
5366 unsigned Level;
5367 // {Level, Printed string}
5368 using EntryTy = std::pair<unsigned, std::string>;
5370
5371 // Used to break the cycle in case there is any.
5372 SmallPtrSet<const Metadata *, 4> Visited;
5373
5374 raw_ostream &MainOS;
5375
5376 MDTreeAsmWriterContext(TypePrinting *TP, SlotTracker *ST, const Module *M,
5377 raw_ostream &OS, const Metadata *InitMD)
5378 : AsmWriterContext(TP, ST, M), Level(0U), Visited({InitMD}), MainOS(OS) {}
5379
5380 void onWriteMetadataAsOperand(const Metadata *MD) override {
5381 if (!Visited.insert(MD).second)
5382 return;
5383
5384 std::string Str;
5385 raw_string_ostream SS(Str);
5386 ++Level;
5387 // A placeholder entry to memorize the correct
5388 // position in buffer.
5389 Buffer.emplace_back(std::make_pair(Level, ""));
5390 unsigned InsertIdx = Buffer.size() - 1;
5391
5392 printMetadataImplRec(SS, *MD, *this);
5393 Buffer[InsertIdx].second = std::move(SS.str());
5394 --Level;
5395 }
5396
5397 ~MDTreeAsmWriterContext() override {
5398 for (const auto &Entry : Buffer) {
5399 MainOS << "\n";
5400 unsigned NumIndent = Entry.first * 2U;
5401 MainOS.indent(NumIndent) << Entry.second;
5402 }
5403 }
5404};
5405} // end anonymous namespace
5406
5407static void printMetadataImpl(raw_ostream &ROS, const Metadata &MD,
5408 ModuleSlotTracker &MST, const Module *M,
5409 bool OnlyAsOperand, bool PrintAsTree = false) {
5410 formatted_raw_ostream OS(ROS);
5411
5412 TypePrinting TypePrinter(M);
5413
5414 std::unique_ptr<AsmWriterContext> WriterCtx;
5415 if (PrintAsTree && !OnlyAsOperand)
5416 WriterCtx = std::make_unique<MDTreeAsmWriterContext>(
5417 &TypePrinter, MST.getMachine(), M, OS, &MD);
5418 else
5419 WriterCtx =
5420 std::make_unique<AsmWriterContext>(&TypePrinter, MST.getMachine(), M);
5421
5422 writeAsOperandInternal(OS, &MD, *WriterCtx, /* FromValue */ true);
5423
5424 auto *N = dyn_cast<MDNode>(&MD);
5425 if (OnlyAsOperand || !N || isa<DIExpression>(MD))
5426 return;
5427
5428 OS << " = ";
5429 writeMDNodeBodyInternal(OS, N, *WriterCtx);
5430}
5431
5433 ModuleSlotTracker MST(M, isa<MDNode>(this));
5434 printMetadataImpl(OS, *this, MST, M, /* OnlyAsOperand */ true);
5435}
5436
5438 const Module *M) const {
5439 printMetadataImpl(OS, *this, MST, M, /* OnlyAsOperand */ true);
5440}
5441
5443 bool /*IsForDebug*/) const {
5444 ModuleSlotTracker MST(M, isa<MDNode>(this));
5445 printMetadataImpl(OS, *this, MST, M, /* OnlyAsOperand */ false);
5446}
5447
5449 const Module *M, bool /*IsForDebug*/) const {
5450 printMetadataImpl(OS, *this, MST, M, /* OnlyAsOperand */ false);
5451}
5452
5453void MDNode::printTree(raw_ostream &OS, const Module *M) const {
5454 ModuleSlotTracker MST(M, true);
5455 printMetadataImpl(OS, *this, MST, M, /* OnlyAsOperand */ false,
5456 /*PrintAsTree=*/true);
5457}
5458
5460 const Module *M) const {
5461 printMetadataImpl(OS, *this, MST, M, /* OnlyAsOperand */ false,
5462 /*PrintAsTree=*/true);
5463}
5464
5465void ModuleSummaryIndex::print(raw_ostream &ROS, bool IsForDebug) const {
5466 SlotTracker SlotTable(this);
5467 formatted_raw_ostream OS(ROS);
5468 AssemblyWriter W(OS, SlotTable, this, IsForDebug);
5469 W.printModuleSummaryIndex();
5470}
5471
5473 unsigned UB) const {
5474 SlotTracker *ST = MachineStorage.get();
5475 if (!ST)
5476 return;
5477
5478 for (auto &I : llvm::make_range(ST->mdn_begin(), ST->mdn_end()))
5479 if (I.second >= LB && I.second < UB)
5480 L.push_back(std::make_pair(I.second, I.first));
5481}
5482
5483#if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP)
5484// Value::dump - allow easy printing of Values from the debugger.
5486void Value::dump() const { print(dbgs(), /*IsForDebug=*/true); dbgs() << '\n'; }
5487
5488// Value::dump - allow easy printing of Values from the debugger.
5490void DbgMarker::dump() const {
5491 print(dbgs(), /*IsForDebug=*/true);
5492 dbgs() << '\n';
5493}
5494
5495// Value::dump - allow easy printing of Values from the debugger.
5497void DbgRecord::dump() const { print(dbgs(), /*IsForDebug=*/true); dbgs() << '\n'; }
5498
5499// Type::dump - allow easy printing of Types from the debugger.
5501void Type::dump() const { print(dbgs(), /*IsForDebug=*/true); dbgs() << '\n'; }
5502
5503// Module::dump() - Allow printing of Modules from the debugger.
5505void Module::dump() const {
5506 print(dbgs(), nullptr,
5507 /*ShouldPreserveUseListOrder=*/false, /*IsForDebug=*/true);
5508}
5509
5510// Allow printing of Comdats from the debugger.
5512void Comdat::dump() const { print(dbgs(), /*IsForDebug=*/true); }
5513
5514// NamedMDNode::dump() - Allow printing of NamedMDNodes from the debugger.
5516void NamedMDNode::dump() const { print(dbgs(), /*IsForDebug=*/true); }
5517
5519void Metadata::dump() const { dump(nullptr); }
5520
5522void Metadata::dump(const Module *M) const {
5523 print(dbgs(), M, /*IsForDebug=*/true);
5524 dbgs() << '\n';
5525}
5526
5528void MDNode::dumpTree() const { dumpTree(nullptr); }
5529
5531void MDNode::dumpTree(const Module *M) const {
5532 printTree(dbgs(), M);
5533 dbgs() << '\n';
5534}
5535
5536// Allow printing of ModuleSummaryIndex from the debugger.
5538void ModuleSummaryIndex::dump() const { print(dbgs(), /*IsForDebug=*/true); }
5539#endif
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
amdgpu next use AMDGPU Next Use Analysis Printer
This file declares a class to represent arbitrary precision floating point values and provide a varie...
This file implements a class to represent arbitrary precision integral constant values and operations...
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
static void print(raw_ostream &Out, object::Archive::Kind Kind, T Val)
static void writeDIMacro(raw_ostream &Out, const DIMacro *N, AsmWriterContext &WriterCtx)
static void writeMetadataAsOperand(raw_ostream &Out, const Metadata *MD, AsmWriterContext &WriterCtx)
static void writeDIGlobalVariableExpression(raw_ostream &Out, const DIGlobalVariableExpression *N, AsmWriterContext &WriterCtx)
static void writeDICompositeType(raw_ostream &Out, const DICompositeType *N, AsmWriterContext &WriterCtx)
static void writeDIFixedPointType(raw_ostream &Out, const DIFixedPointType *N, AsmWriterContext &WriterCtx)
static void printDSOLocation(const GlobalValue &GV, formatted_raw_ostream &Out)
static const char * getWholeProgDevirtResKindName(WholeProgramDevirtResolution::Kind K)
static void writeDISubrangeType(raw_ostream &Out, const DISubrangeType *N, AsmWriterContext &WriterCtx)
static void writeAPFloatInternal(raw_ostream &Out, const APFloat &APF)
static void printMetadataImpl(raw_ostream &ROS, const Metadata &MD, ModuleSlotTracker &MST, const Module *M, bool OnlyAsOperand, bool PrintAsTree=false)
static void writeDIStringType(raw_ostream &Out, const DIStringType *N, AsmWriterContext &WriterCtx)
static std::string getLinkageNameWithSpace(GlobalValue::LinkageTypes LT)
static cl::opt< bool > PreserveAssemblyUseListOrder("preserve-ll-uselistorder", cl::Hidden, cl::init(false), cl::desc("Preserve use-list order when writing LLVM assembly."))
static std::vector< unsigned > predictValueUseListOrder(const Value *V, unsigned ID, const OrderMap &OM)
static void writeDIGlobalVariable(raw_ostream &Out, const DIGlobalVariable *N, AsmWriterContext &WriterCtx)
static void orderValue(const Value *V, OrderMap &OM)
static void writeDIBasicType(raw_ostream &Out, const DIBasicType *N, AsmWriterContext &WriterCtx)
static StringRef getUnnamedAddrEncoding(GlobalVariable::UnnamedAddr UA)
static const char * getWholeProgDevirtResByArgKindName(WholeProgramDevirtResolution::ByArg::Kind K)
static void writeMDNodeBodyInternal(raw_ostream &Out, const MDNode *Node, AsmWriterContext &Ctx)
static void writeDIModule(raw_ostream &Out, const DIModule *N, AsmWriterContext &WriterCtx)
static void writeDIFile(raw_ostream &Out, const DIFile *N, AsmWriterContext &)
static void writeDISubroutineType(raw_ostream &Out, const DISubroutineType *N, AsmWriterContext &WriterCtx)
static cl::opt< bool > PrintAddrspaceName("print-addrspace-name", cl::Hidden, cl::init(false), cl::desc("Print address space names"))
static void writeOptimizationInfo(raw_ostream &Out, const User *U)
static bool isReferencingMDNode(const Instruction &I)
#define CC_VLS_CASE(ABI_VLEN)
static void writeDILabel(raw_ostream &Out, const DILabel *N, AsmWriterContext &WriterCtx)
static void writeDIDerivedType(raw_ostream &Out, const DIDerivedType *N, AsmWriterContext &WriterCtx)
static void printMetadataIdentifier(StringRef Name, formatted_raw_ostream &Out)
static void printShuffleMask(raw_ostream &Out, Type *Ty, ArrayRef< int > Mask)
static void writeDIImportedEntity(raw_ostream &Out, const DIImportedEntity *N, AsmWriterContext &WriterCtx)
static const Module * getModuleFromDPI(const DbgMarker *Marker)
static void printAsOperandImpl(const Value &V, raw_ostream &O, bool PrintType, ModuleSlotTracker &MST)
static void writeDIObjCProperty(raw_ostream &Out, const DIObjCProperty *N, AsmWriterContext &WriterCtx)
static void writeDISubprogram(raw_ostream &Out, const DISubprogram *N, AsmWriterContext &WriterCtx)
static const char * getSummaryKindName(GlobalValueSummary::SummaryKind SK)
static OrderMap orderModule(const Module *M)
static const char * getVisibilityName(GlobalValue::VisibilityTypes Vis)
static void printCallingConv(unsigned cc, raw_ostream &Out)
static void printAddressSpace(const Module *M, unsigned AS, raw_ostream &OS, StringRef Prefix=" ", StringRef Suffix="", bool ForcePrint=false)
static cl::opt< bool > PrintInstDebugLocs("print-inst-debug-locs", cl::Hidden, cl::desc("Pretty print debug locations of instructions when dumping"))
static void printMetadataImplRec(raw_ostream &ROS, const Metadata &MD, AsmWriterContext &WriterCtx)
Recursive version of printMetadataImpl.
static SlotTracker * createSlotTracker(const Value *V)
static void writeDILocation(raw_ostream &Out, const DILocation *DL, AsmWriterContext &WriterCtx)
static void writeDINamespace(raw_ostream &Out, const DINamespace *N, AsmWriterContext &WriterCtx)
DenseMap< const Function *, MapVector< const Value *, std::vector< unsigned > > > UseListOrderMap
static void writeDICommonBlock(raw_ostream &Out, const DICommonBlock *N, AsmWriterContext &WriterCtx)
static UseListOrderMap predictUseListOrder(const Module *M)
static void printThreadLocalModel(GlobalVariable::ThreadLocalMode TLM, formatted_raw_ostream &Out)
static std::string getLinkageName(GlobalValue::LinkageTypes LT)
static void writeGenericDINode(raw_ostream &Out, const GenericDINode *N, AsmWriterContext &WriterCtx)
static void writeDILocalVariable(raw_ostream &Out, const DILocalVariable *N, AsmWriterContext &WriterCtx)
static const char * getTTResKindName(TypeTestResolution::Kind K)
static void writeDITemplateTypeParameter(raw_ostream &Out, const DITemplateTypeParameter *N, AsmWriterContext &WriterCtx)
static const char * getImportTypeName(GlobalValueSummary::ImportKind IK)
static void writeDICompileUnit(raw_ostream &Out, const DICompileUnit *N, AsmWriterContext &WriterCtx)
static const Module * getModuleFromVal(const Value *V)
static void printLLVMName(raw_ostream &OS, StringRef Name, PrefixType Prefix)
Turn the specified name into an 'LLVM name', which is either prefixed with % (if the string only cont...
static void maybePrintCallAddrSpace(const Value *Operand, const Instruction *I, raw_ostream &Out)
static void writeDIGenericSubrange(raw_ostream &Out, const DIGenericSubrange *N, AsmWriterContext &WriterCtx)
static void writeDISubrange(raw_ostream &Out, const DISubrange *N, AsmWriterContext &WriterCtx)
static void writeDILexicalBlockFile(raw_ostream &Out, const DILexicalBlockFile *N, AsmWriterContext &WriterCtx)
static void writeConstantInternal(raw_ostream &Out, const Constant *CV, AsmWriterContext &WriterCtx)
static void writeDIEnumerator(raw_ostream &Out, const DIEnumerator *N, AsmWriterContext &)
static void writeAsOperandInternal(raw_ostream &Out, const Value *V, AsmWriterContext &WriterCtx, bool PrintType=false)
static void printVisibility(GlobalValue::VisibilityTypes Vis, formatted_raw_ostream &Out)
static cl::opt< bool > PrintProfData("print-prof-data", cl::Hidden, cl::desc("Pretty print perf data (branch weights, etc) when dumping"))
static void writeMDTuple(raw_ostream &Out, const MDTuple *Node, AsmWriterContext &WriterCtx)
static void writeDIExpression(raw_ostream &Out, const DIExpression *N, AsmWriterContext &WriterCtx)
static cl::opt< bool > PrintInstAddrs("print-inst-addrs", cl::Hidden, cl::desc("Print addresses of instructions when dumping"))
static void writeDIAssignID(raw_ostream &Out, const DIAssignID *DL, AsmWriterContext &WriterCtx)
static void writeDILexicalBlock(raw_ostream &Out, const DILexicalBlock *N, AsmWriterContext &WriterCtx)
PrefixType
@ GlobalPrefix
@ LabelPrefix
@ LocalPrefix
@ NoPrefix
@ ComdatPrefix
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.
#define ST_DEBUG(X)
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.
Definition Compiler.h:661
This file contains the declarations for the subclasses of Constant, which represent the different fla...
dxil translate DXIL Translate Metadata
This file defines the DenseMap class.
@ Default
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
Definition Globals.cpp:253
#define op(i)
Hexagon Common GEP
#define _
IRTranslator LLVM IR MI
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.
#define F(x, y, z)
Definition MD5.cpp:54
#define I(x, y, z)
Definition MD5.cpp:57
#define G(x, y, z)
Definition MD5.cpp:55
Machine Check Debug Module
This file contains the declarations for metadata subclasses.
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
#define P(N)
Function const char TargetMachine * Machine
if(auto Err=PB.parsePassPipeline(MPM, Passes)) return wrap(std MPM run * Mod
if(PassOpts->AAPipeline)
static StringRef getName(Value *V)
This file contains some templates that are useful if you are working with the STL at all.
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.
This file contains some functions that are useful when dealing with strings.
LocallyHashedType DenseMapInfo< LocallyHashedType >::Empty
static UseListOrderStack predictUseListOrder(const Module &M)
static const fltSemantics & IEEEsingle()
Definition APFloat.h:296
static const fltSemantics & BFloat()
Definition APFloat.h:295
static const fltSemantics & IEEEquad()
Definition APFloat.h:298
static const fltSemantics & IEEEdouble()
Definition APFloat.h:297
static const fltSemantics & x87DoubleExtended()
Definition APFloat.h:317
static constexpr roundingMode rmNearestTiesToEven
Definition APFloat.h:344
static const fltSemantics & IEEEhalf()
Definition APFloat.h:294
static const fltSemantics & PPCDoubleDouble()
Definition APFloat.h:299
static APFloat getSNaN(const fltSemantics &Sem, bool Negative=false, const APInt *payload=nullptr)
Factory for SNaN values.
Definition APFloat.h:1183
LLVM_ABI opStatus convert(const fltSemantics &ToSemantics, roundingMode RM, bool *losesInfo)
Definition APFloat.cpp:5890
bool isNegative() const
Definition APFloat.h:1534
LLVM_ABI double convertToDouble() const
Converts this APFloat to host double value.
Definition APFloat.cpp:5949
void toString(SmallVectorImpl< char > &Str, unsigned FormatPrecision=0, unsigned FormatMaxPadding=3, bool TruncateZero=true) const
Definition APFloat.h:1563
const fltSemantics & getSemantics() const
Definition APFloat.h:1542
bool isNaN() const
Definition APFloat.h:1532
bool isSignaling() const
Definition APFloat.h:1536
APInt bitcastToAPInt() const
Definition APFloat.h:1426
bool isInfinity() const
Definition APFloat.h:1531
Class for arbitrary precision integers.
Definition APInt.h:78
LLVM_ABI APInt getLoBits(unsigned numBits) const
Compute an APInt containing numBits lowbits from this APInt.
Definition APInt.cpp:644
uint64_t getZExtValue() const
Get zero extended value.
Definition APInt.h:1563
LLVM_ABI APInt getHiBits(unsigned numBits) const
Compute an APInt containing numBits highbits from this APInt.
Definition APInt.cpp:639
Abstract interface of slot tracker storage.
const GlobalValueSummary & getAliasee() const
This class represents an incoming formal argument to a Function.
Definition Argument.h:32
ArrayRef - Represent a constant reference to an array (0 or more elements consecutively in memory),...
Definition ArrayRef.h:40
size_t size() const
size - Get the array size.
Definition ArrayRef.h:142
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...
static LLVM_ABI StringRef getOperationName(BinOp Op)
This class holds the attributes for a particular argument, parameter, function, or return value.
Definition Attributes.h:407
bool hasAttributes() const
Return true if attributes exists in this set.
Definition Attributes.h:477
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.
Definition BasicBlock.h:62
const Function * getParent() const
Return the enclosing method, or null if none.
Definition BasicBlock.h:213
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.
Definition Comdat.h:39
@ SameSize
The data referenced by the COMDAT must be the same size.
Definition Comdat.h:41
@ Any
The linker may choose any COMDAT.
Definition Comdat.h:37
@ NoDeduplicate
No deduplication is performed.
Definition Comdat.h:40
@ ExactMatch
The data referenced by the COMDAT must be the same.
Definition Comdat.h:38
SelectionKind getSelectionKind() const
Definition Comdat.h:47
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.
Definition Constant.h:43
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'.
Debug common block.
static LLVM_ABI const char * nameTableKindString(DebugNameTableKind PK)
static LLVM_ABI const char * emissionKindString(DebugEmissionKind EK)
Enumeration value.
A lightweight wrapper around an expression operand.
DWARF expression.
static LLVM_ABI const char * fixedPointKindString(FixedPointKind)
A pair of DIGlobalVariable and DIExpression.
An imported module (C++ using directive or similar).
Debug lexical block.
Macro Info DWARF-like metadata node.
Represents a module in the programming language, for example, a Clang module, or a Fortran module.
Debug lexical block.
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)
DIFlags
Debug info flags.
Wrapper structure that holds a language name and its version.
uint32_t getVersion() const
Returns language version. Only valid for versioned language names.
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.
Array subrange.
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....
LLVM_ABI void print(raw_ostream &O, bool IsForDebug=false) const
Metadata * getRawLocation() const
Returns the metadata operand for the first location description.
MDNode * getAsMDNode() const
Return this as a bar MDNode.
Definition DebugLoc.h:290
DenseMapIterator< KeyT, ValueT, KeyInfoT, BucketT > iterator
Definition DenseMap.h:74
Intrinsic::ID getIntrinsicID() const LLVM_READONLY
getIntrinsicID - This method returns the ID number of the specified function, or Intrinsic::not_intri...
Definition Function.h:246
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
Definition Function.h:166
const Argument * const_arg_iterator
Definition Function.h:74
LLVM_ABI Value * getBasePtr() const
LLVM_ABI Value * getDerivedPtr() const
Generic tagged DWARF-like metadata node.
const Constant * getAliasee() const
Definition GlobalAlias.h:87
const Constant * getResolver() const
Definition GlobalIFunc.h:73
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.
Definition Globals.cpp:80
LLVM_ABI const SanitizerMetadata & getSanitizerMetadata() const
Definition Globals.cpp:254
bool hasExternalLinkage() const
bool isDSOLocal() 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.
Definition GlobalValue.h:74
@ DLLExportStorageClass
Function to be accessible from DLL.
Definition GlobalValue.h:77
@ DLLImportStorageClass
Function to be imported from DLL.
Definition GlobalValue.h:76
bool hasSanitizerMetadata() const
LLVM_ABI StringRef getPartition() const
Definition Globals.cpp:231
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.
Definition GlobalValue.h:67
@ DefaultVisibility
The GV is visible.
Definition GlobalValue.h:68
@ HiddenVisibility
The GV is hidden.
Definition GlobalValue.h:69
@ ProtectedVisibility
The GV is protected.
Definition GlobalValue.h:70
LLVM_ABI bool isMaterializable() const
If this function's Module is being lazily streamed in functions from disk or some other source,...
Definition Globals.cpp:47
UnnamedAddr getUnnamedAddr() const
LinkageTypes
An enumeration for the kinds of linkage for global values.
Definition GlobalValue.h:52
@ PrivateLinkage
Like Internal, but omit from symbol table.
Definition GlobalValue.h:61
@ CommonLinkage
Tentative definitions.
Definition GlobalValue.h:63
@ InternalLinkage
Rename collisions when linking (static functions).
Definition GlobalValue.h:60
@ LinkOnceAnyLinkage
Keep one copy of function when linking (inline)
Definition GlobalValue.h:55
@ WeakODRLinkage
Same, but only replaced by something equivalent.
Definition GlobalValue.h:58
@ ExternalLinkage
Externally visible function.
Definition GlobalValue.h:53
@ WeakAnyLinkage
Keep one copy of named function when linking (weak)
Definition GlobalValue.h:57
@ AppendingLinkage
Special purpose, only applies to global arrays.
Definition GlobalValue.h:59
@ AvailableExternallyLinkage
Available for inspection, not emission.
Definition GlobalValue.h:54
@ ExternalWeakLinkage
ExternalWeak linkage description.
Definition GlobalValue.h:62
@ LinkOnceODRLinkage
Same, but only replaced by something equivalent.
Definition GlobalValue.h:56
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...
Metadata node.
Definition Metadata.h:1080
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.
Tuple of metadata.
Definition Metadata.h:1500
This class implements a map that also provides access to all stored values in a deterministic order.
Definition MapVector.h:36
Root of the metadata hierarchy.
Definition Metadata.h:64
LLVM_ABI void print(raw_ostream &OS, const Module *M=nullptr, bool IsForDebug=false) const
Print.
LLVM_ABI void printAsOperand(raw_ostream &OS, const Module *M=nullptr) const
Print as operand.
LLVM_ABI void dump() const
User-friendly dump.
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.
Definition Module.h:67
iterator_range< alias_iterator > aliases()
Definition Module.h:735
iterator_range< global_iterator > globals()
Definition Module.h:684
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()
Definition Metadata.h:1856
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.
bool mdn_empty() const
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)
bool as_empty() const
unsigned mdn_size() const
SlotTracker(const SlotTracker &)=delete
void purgeFunction()
After calling incorporateFunction, use this method to remove the most recently incorporated function ...
mdn_iterator mdn_end()
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.
as_iterator as_begin()
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.
as_iterator as_end()
unsigned as_size() const
SlotTracker & operator=(const SlotTracker &)=delete
int getGUIDSlot(GlobalValue::GUID GUID)
mdn_iterator mdn_begin()
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...
Definition SmallString.h:26
reference emplace_back(ArgTypes &&... Args)
void resize(size_type N)
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",...
Definition StringMap.h:133
StringRef - Represent a constant reference to a string, i.e.
Definition StringRef.h:55
constexpr bool empty() const
empty - Check if the string is empty.
Definition StringRef.h:140
ArrayRef< Type * > elements() const
bool isPacked() 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.
Definition Type.cpp:766
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.
Definition TypeFinder.h:31
void run(const Module &M, bool onlyNamed)
iterator begin()
Definition TypeFinder.h:51
bool empty() const
Definition TypeFinder.h:57
The instances of the Type class are immutable: once they are created, they are never changed.
Definition Type.h:46
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)
Definition Type.h:95
LLVM_ABI void dump() const
LLVM_ABI void print(raw_ostream &O, bool IsForDebug=false, bool NoDetails=false) const
Print the current type.
LLVM_ABI unsigned getByteBitWidth() const
TypeID getTypeID() const
Return the type id for the type.
Definition Type.h:138
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.
Definition Use.h:35
LLVM Value Representation.
Definition Value.h:75
Type * getType() const
All values are typed, get the type of this value.
Definition Value.h:255
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()
Definition Value.h:426
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()
Definition Value.h:380
bool hasName() const
Definition Value.h:261
LLVM_ABI StringRef getName() const
Return a constant reference to the value's name.
Definition Value.cpp:318
LLVM_ABI void dump() const
Support for debugging, callable in GDB: V->dump()
formatted_raw_ostream - A raw_ostream that wraps another one and keeps track of line and column posit...
formatted_raw_ostream & PadToColumn(unsigned NewCol)
PadToColumn - Align the output to some column number.
This class implements an extremely fast bulk output stream that can only output to a stream.
Definition raw_ostream.h:53
raw_ostream & indent(unsigned NumSpaces)
indent - Insert 'NumSpaces' spaces.
CallInst * Call
LLVM_ABI StringRef SourceLanguageNameString(SourceLanguageName Lang)
Definition Dwarf.cpp:587
LLVM_ABI StringRef EnumKindString(unsigned EnumKind)
Definition Dwarf.cpp:393
LLVM_ABI StringRef LanguageString(unsigned Language)
Definition Dwarf.cpp:412
LLVM_ABI StringRef AttributeEncodingString(unsigned Encoding)
Definition Dwarf.cpp:263
LLVM_ABI StringRef ConventionString(unsigned Convention)
Definition Dwarf.cpp:621
LLVM_ABI StringRef MacinfoString(unsigned Encoding)
Definition Dwarf.cpp:685
LLVM_ABI StringRef OperationEncodingString(unsigned Encoding)
Definition Dwarf.cpp:138
LLVM_ABI StringRef TagString(unsigned Tag)
Definition Dwarf.cpp:21
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.
@ Entry
Definition COFF.h:862
unsigned ID
LLVM IR allows to use arbitrary numbers as calling convention identifiers.
Definition CallingConv.h:24
@ 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.
Definition CallingConv.h:69
@ 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.
Definition CallingConv.h:82
@ AVR_INTR
Used for AVR interrupt routines.
@ PreserveMost
Used for runtime calls that preserves most registers.
Definition CallingConv.h:63
@ AnyReg
OBSOLETED - Used for stack based JavaScript calls.
Definition CallingConv.h:60
@ 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.
Definition CallingConv.h:72
@ 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).
Definition CallingConv.h:50
@ 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...
Definition CallingConv.h:47
@ 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.
Definition CallingConv.h:66
@ X86_StdCall
stdcall is mostly used by the Win32 API.
Definition CallingConv.h:99
@ SPIR_FUNC
Used for SPIR non-kernel device functions.
@ Fast
Attempts to make calls as fast as possible (e.g.
Definition CallingConv.h:41
@ 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.
Definition CallingConv.h:90
@ 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...
Definition CallingConv.h:76
@ 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 ...
Definition CallingConv.h:87
@ 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.
Definition CallingConv.h:34
@ X86_FastCall
'fast' analog of X86_StdCall.
LLVM_ABI void printImmArg(ID IID, unsigned ArgIdx, raw_ostream &OS, const Constant *ImmArgVal)
Print the argument info for the arguments with ArgInfo.
LLVM_ABI bool hasPrettyPrintedArgs(ID id)
Returns true if the intrinsic has pretty printed immediate arguments.
@ System
Synchronized with respect to all concurrently executing threads.
Definition LLVMContext.h:58
initializer< Ty > init(const Ty &Val)
SourceLanguageName
Definition Dwarf.h:223
@ DW_OP_LLVM_convert
Only used in LLVM metadata.
Definition Dwarf.h:145
bool empty() const
Definition BasicBlock.h:101
Context & getContext() const
Definition BasicBlock.h:99
This is an optimization pass for GlobalISel generic memory operations.
void dump(const SparseBitVector< ElementSize > &LHS, raw_ostream &out)
FunctionAddr VTableAddr Value
Definition InstrProf.h:137
bool all_of(R &&range, UnaryPredicate P)
Provide wrappers to std::all_of which take ranges instead of having to pass begin/end explicitly.
Definition STLExtras.h:1738
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.
Definition STLExtras.h:840
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.
Definition Casting.h:643
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 ...
Definition Casting.h:732
iterator_range< T > make_range(T x, T y)
Convenience function for iterating over sub-ranges.
LLVM_ABI void printEscapedString(StringRef Name, raw_ostream &Out)
Print each character of the specified string, escaping it if it is not printable or if it is an escap...
constexpr auto equal_to(T &&Arg)
Functor variant of std::equal_to that can be used as a UnaryPredicate in functional algorithms like a...
Definition STLExtras.h:2172
const char * toIRString(AtomicOrdering ao)
String used by LLVM IR to represent atomic ordering.
auto dyn_cast_or_null(const Y &Val)
Definition Casting.h:753
void sort(IteratorTy Start, IteratorTy End)
Definition STLExtras.h:1635
LLVM_ABI raw_ostream & dbgs()
dbgs() - This returns a reference to a raw_ostream for debugging messages.
Definition Debug.cpp:207
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
Definition InstrProf.h:139
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...
Definition STLExtras.h:1969
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.
Definition Format.h:191
FormattedNumber format_hex_no_prefix(uint64_t N, unsigned Width, bool Upper=false)
format_hex_no_prefix - Output N as a fixed width hexadecimal.
Definition Format.h:204
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...
Definition Casting.h:547
constexpr int PoisonMaskElem
AtomicOrdering
Atomic ordering for LLVM's memory model.
@ Ref
The access may reference the value stored in memory.
Definition ModRef.h:32
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.
Definition Casting.h:559
auto predecessors(const MachineBasicBlock *BB)
bool pred_empty(const BasicBlock *BB)
Definition CFG.h:119
std::vector< TypeIdOffsetVtableInfo > TypeIdCompatibleVtableInfo
List of vtable definitions decorated by a particular type identifier, and their corresponding offsets...
static auto filterDbgVars(iterator_range< simple_ilist< DbgRecord >::iterator > R)
Filter the DbgRecord range to DbgVariableRecord types only and downcast.
LLVM_ABI void printLLVMNameWithoutPrefix(raw_ostream &OS, StringRef Name)
Print out a name of an LLVM value without any prefixes.
@ Default
The result value is uniform if and only if all operands are uniform.
Definition Uniformity.h:20
#define N
#define NC
Definition regutils.h:42
A single checksum, represented by a Kind and a Value (a string).
T Value
The string value of the checksum.
StringRef getKindAsString() const
std::vector< ConstVCall > TypeCheckedLoadConstVCalls
std::vector< VFuncId > TypeCheckedLoadVCalls
std::vector< ConstVCall > TypeTestAssumeConstVCalls
List of virtual calls made by this function using (respectively) llvm.assume(llvm....
std::vector< GlobalValue::GUID > TypeTests
List of type identifiers used by this function in llvm.type.test intrinsics referenced by something o...
std::vector< VFuncId > TypeTestAssumeVCalls
List of virtual calls made by this function using (respectively) llvm.assume(llvm....
unsigned NoRenameOnPromotion
This field is written by the ThinLTO prelink stage to decide whether a particular static global value...
unsigned DSOLocal
Indicates that the linker resolved the symbol to a definition from within the same linkage unit.
unsigned CanAutoHide
In the per-module summary, indicates that the global value is linkonce_odr and global unnamed addr (s...
unsigned ImportType
This field is written by the ThinLTO indexing step to postlink combined summary.
unsigned NotEligibleToImport
Indicate if the global value cannot be imported (e.g.
unsigned Linkage
The linkage type of the associated global value.
unsigned Visibility
Indicates the visibility.
unsigned Live
In per-module summary, indicate that the global value must be considered a live root for index-based ...
StringRef getTagName() const
Return the tag of this operand bundle as a string.
ArrayRef< Use > Inputs
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.
TypeTestResolution TTRes
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,...
@ 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:...
Definition STLExtras.h:1447