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 // Sort by GUID for deterministic slot assignment.
1206 for (const auto &GlobalList : TheIndex->sortedGlobalValueSummariesRange())
1207 CreateGUIDSlot(GlobalList.first);
1208
1209 // Start numbering the TypeIdCompatibleVtables after the GUIDs.
1210 TypeIdCompatibleVtableNext = GUIDNext;
1211 for (auto &TId : TheIndex->typeIdCompatibleVtableMap())
1212 CreateTypeIdCompatibleVtableSlot(TId.first);
1213
1214 // Start numbering the TypeIds after the TypeIdCompatibleVtables.
1215 TypeIdNext = TypeIdCompatibleVtableNext;
1216 for (const auto &TID : TheIndex->typeIds())
1217 CreateTypeIdSlot(TID.second.first);
1218
1219 ST_DEBUG("end processIndex!\n");
1220 return TypeIdNext;
1221}
1222
1223void SlotTracker::processGlobalObjectMetadata(const GlobalObject &GO) {
1225 GO.getAllMetadata(MDs);
1226 for (auto &MD : MDs)
1227 CreateMetadataSlot(MD.second);
1228}
1229
1230void SlotTracker::processFunctionMetadata(const Function &F) {
1231 processGlobalObjectMetadata(F);
1232 for (auto &BB : F) {
1233 for (auto &I : BB) {
1234 for (const DbgRecord &DR : I.getDbgRecordRange())
1235 processDbgRecordMetadata(DR);
1236 processInstructionMetadata(I);
1237 }
1238 }
1239}
1240
1241void SlotTracker::processDbgRecordMetadata(const DbgRecord &DR) {
1242 // Tolerate null metadata pointers: it's a completely illegal debug record,
1243 // but we can have faulty metadata from debug-intrinsic days being
1244 // autoupgraded into debug records. This gets caught by the verifier, which
1245 // then will print the faulty IR, hitting this code path.
1246 if (const auto *DVR = dyn_cast<const DbgVariableRecord>(&DR)) {
1247 // Process metadata used by DbgRecords; we only specifically care about the
1248 // DILocalVariable, DILocation, and DIAssignID fields, as the Value and
1249 // Expression fields should only be printed inline and so do not use a slot.
1250 // Note: The above doesn't apply for empty-metadata operands.
1251 if (auto *Empty = dyn_cast_if_present<MDNode>(DVR->getRawLocation()))
1252 CreateMetadataSlot(Empty);
1253 if (DVR->getRawVariable())
1254 CreateMetadataSlot(DVR->getRawVariable());
1255 if (DVR->isDbgAssign()) {
1256 if (auto *AssignID = DVR->getRawAssignID())
1257 CreateMetadataSlot(cast<MDNode>(AssignID));
1258 if (auto *Empty = dyn_cast_if_present<MDNode>(DVR->getRawAddress()))
1259 CreateMetadataSlot(Empty);
1260 }
1261 } else if (const auto *DLR = dyn_cast<const DbgLabelRecord>(&DR)) {
1262 CreateMetadataSlot(DLR->getRawLabel());
1263 } else {
1264 llvm_unreachable("unsupported DbgRecord kind");
1265 }
1266 if (DR.getDebugLoc())
1267 CreateMetadataSlot(DR.getDebugLoc().getAsMDNode());
1268}
1269
1270void SlotTracker::processInstructionMetadata(const Instruction &I) {
1271 // Process metadata used directly by intrinsics.
1272 if (const auto *CI = dyn_cast<CallInst>(&I))
1273 if (Function *F = CI->getCalledFunction())
1274 if (F->isIntrinsic())
1275 for (auto &Op : I.operands())
1277 if (auto *N = dyn_cast<MDNode>(V->getMetadata()))
1278 CreateMetadataSlot(N);
1279
1280 // Process metadata attached to this instruction.
1282 I.getAllMetadata(MDs);
1283 for (auto &MD : MDs)
1284 CreateMetadataSlot(MD.second);
1285}
1286
1287/// Clean up after incorporating a function. This is the only way to get out of
1288/// the function incorporation state that affects get*Slot/Create*Slot. Function
1289/// incorporation state is indicated by TheFunction != 0.
1291 ST_DEBUG("begin purgeFunction!\n");
1292 fMap.clear(); // Simply discard the function level map
1293 TheFunction = nullptr;
1294 FunctionProcessed = false;
1295 ST_DEBUG("end purgeFunction!\n");
1296}
1297
1298/// getGlobalSlot - Get the slot number of a global value.
1300 // Check for uninitialized state and do lazy initialization.
1302
1303 // Find the value in the module map
1304 ValueMap::iterator MI = mMap.find(V);
1305 return MI == mMap.end() ? -1 : (int)MI->second;
1306}
1307
1309 std::function<void(AbstractSlotTrackerStorage *, const Module *, bool)>
1310 Fn) {
1311 ProcessModuleHookFn = std::move(Fn);
1312}
1313
1315 std::function<void(AbstractSlotTrackerStorage *, const Function *, bool)>
1316 Fn) {
1317 ProcessFunctionHookFn = std::move(Fn);
1318}
1319
1320/// getMetadataSlot - Get the slot number of a MDNode.
1321void SlotTracker::createMetadataSlot(const MDNode *N) { CreateMetadataSlot(N); }
1322
1323/// getMetadataSlot - Get the slot number of a MDNode.
1325 // Check for uninitialized state and do lazy initialization.
1327
1328 // Find the MDNode in the module map
1329 mdn_iterator MI = mdnMap.find(N);
1330 return MI == mdnMap.end() ? -1 : (int)MI->second;
1331}
1332
1333/// getLocalSlot - Get the slot number for a value that is local to a function.
1335 assert(!isa<Constant>(V) && "Can't get a constant or global slot with this!");
1336
1337 // Check for uninitialized state and do lazy initialization.
1339
1340 ValueMap::iterator FI = fMap.find(V);
1341 return FI == fMap.end() ? -1 : (int)FI->second;
1342}
1343
1345 // Check for uninitialized state and do lazy initialization.
1347
1348 // Find the AttributeSet in the module map.
1349 as_iterator AI = asMap.find(AS);
1350 return AI == asMap.end() ? -1 : (int)AI->second;
1351}
1352
1354 // Check for uninitialized state and do lazy initialization.
1356
1357 // Find the Module path in the map
1358 auto I = ModulePathMap.find(Path);
1359 return I == ModulePathMap.end() ? -1 : (int)I->second;
1360}
1361
1363 // Check for uninitialized state and do lazy initialization.
1365
1366 // Find the GUID in the map
1367 guid_iterator I = GUIDMap.find(GUID);
1368 return I == GUIDMap.end() ? -1 : (int)I->second;
1369}
1370
1372 // Check for uninitialized state and do lazy initialization.
1374
1375 // Find the TypeId string in the map
1376 auto I = TypeIdMap.find(Id);
1377 return I == TypeIdMap.end() ? -1 : (int)I->second;
1378}
1379
1381 // Check for uninitialized state and do lazy initialization.
1383
1384 // Find the TypeIdCompatibleVtable string in the map
1385 auto I = TypeIdCompatibleVtableMap.find(Id);
1386 return I == TypeIdCompatibleVtableMap.end() ? -1 : (int)I->second;
1387}
1388
1389/// CreateModuleSlot - Insert the specified GlobalValue* into the slot table.
1390void SlotTracker::CreateModuleSlot(const GlobalValue *V) {
1391 assert(V && "Can't insert a null Value into SlotTracker!");
1392 assert(!V->getType()->isVoidTy() && "Doesn't need a slot!");
1393 assert(!V->hasName() && "Doesn't need a slot!");
1394
1395 unsigned DestSlot = mNext++;
1396 mMap[V] = DestSlot;
1397
1398 ST_DEBUG(" Inserting value [" << V->getType() << "] = " << V << " slot=" <<
1399 DestSlot << " [");
1400 // G = Global, F = Function, A = Alias, I = IFunc, o = other
1401 ST_DEBUG((isa<GlobalVariable>(V) ? 'G' :
1402 (isa<Function>(V) ? 'F' :
1403 (isa<GlobalAlias>(V) ? 'A' :
1404 (isa<GlobalIFunc>(V) ? 'I' : 'o')))) << "]\n");
1405}
1406
1407/// CreateSlot - Create a new slot for the specified value if it has no name.
1408void SlotTracker::CreateFunctionSlot(const Value *V) {
1409 assert(!V->getType()->isVoidTy() && !V->hasName() && "Doesn't need a slot!");
1410
1411 unsigned DestSlot = fNext++;
1412 fMap[V] = DestSlot;
1413
1414 // G = Global, F = Function, o = other
1415 ST_DEBUG(" Inserting value [" << V->getType() << "] = " << V << " slot=" <<
1416 DestSlot << " [o]\n");
1417}
1418
1419/// CreateModuleSlot - Insert the specified MDNode* into the slot table.
1420void SlotTracker::CreateMetadataSlot(const MDNode *N) {
1421 assert(N && "Can't insert a null Value into SlotTracker!");
1422
1423 // Don't make slots for DIExpressions. We just print them inline everywhere.
1424 if (isa<DIExpression>(N))
1425 return;
1426
1427 unsigned DestSlot = mdnNext;
1428 if (!mdnMap.insert(std::make_pair(N, DestSlot)).second)
1429 return;
1430 ++mdnNext;
1431
1432 // Recursively add any MDNodes referenced by operands.
1433 for (unsigned i = 0, e = N->getNumOperands(); i != e; ++i)
1434 if (const auto *Op = dyn_cast_or_null<MDNode>(N->getOperand(i)))
1435 CreateMetadataSlot(Op);
1436}
1437
1438void SlotTracker::CreateAttributeSetSlot(AttributeSet AS) {
1439 assert(AS.hasAttributes() && "Doesn't need a slot!");
1440
1441 if (asMap.try_emplace(AS, asNext).second)
1442 ++asNext;
1443}
1444
1445/// Create a new slot for the specified Module
1446void SlotTracker::CreateModulePathSlot(StringRef Path) {
1447 ModulePathMap[Path] = ModulePathNext++;
1448}
1449
1450/// Create a new slot for the specified GUID
1451void SlotTracker::CreateGUIDSlot(GlobalValue::GUID GUID) {
1452 GUIDMap[GUID] = GUIDNext++;
1453}
1454
1455/// Create a new slot for the specified Id
1456void SlotTracker::CreateTypeIdSlot(StringRef Id) {
1457 TypeIdMap[Id] = TypeIdNext++;
1458}
1459
1460/// Create a new slot for the specified Id
1461void SlotTracker::CreateTypeIdCompatibleVtableSlot(StringRef Id) {
1462 TypeIdCompatibleVtableMap[Id] = TypeIdCompatibleVtableNext++;
1463}
1464
1465namespace {
1466/// Common instances used by most of the printer functions.
1467struct AsmWriterContext {
1468 TypePrinting *TypePrinter = nullptr;
1469 SlotTracker *Machine = nullptr;
1470 const Module *Context = nullptr;
1471
1472 AsmWriterContext(TypePrinting *TP, SlotTracker *ST, const Module *M = nullptr)
1473 : TypePrinter(TP), Machine(ST), Context(M) {}
1474
1475 static AsmWriterContext &getEmpty() {
1476 static AsmWriterContext EmptyCtx(nullptr, nullptr);
1477 return EmptyCtx;
1478 }
1479
1480 /// A callback that will be triggered when the underlying printer
1481 /// prints a Metadata as operand.
1482 virtual void onWriteMetadataAsOperand(const Metadata *) {}
1483
1484 virtual ~AsmWriterContext() = default;
1485};
1486} // end anonymous namespace
1487
1488//===----------------------------------------------------------------------===//
1489// AsmWriter Implementation
1490//===----------------------------------------------------------------------===//
1491
1492static void writeAsOperandInternal(raw_ostream &Out, const Value *V,
1493 AsmWriterContext &WriterCtx,
1494 bool PrintType = false);
1495
1496static void writeAsOperandInternal(raw_ostream &Out, const Metadata *MD,
1497 AsmWriterContext &WriterCtx,
1498 bool FromValue = false);
1499
1500static void writeOptimizationInfo(raw_ostream &Out, const User *U) {
1501 if (const auto *FPO = dyn_cast<const FPMathOperator>(U))
1502 Out << FPO->getFastMathFlags();
1503
1504 if (const auto *OBO = dyn_cast<OverflowingBinaryOperator>(U)) {
1505 if (OBO->hasNoUnsignedWrap())
1506 Out << " nuw";
1507 if (OBO->hasNoSignedWrap())
1508 Out << " nsw";
1509 } else if (const auto *Div = dyn_cast<PossiblyExactOperator>(U)) {
1510 if (Div->isExact())
1511 Out << " exact";
1512 } else if (const auto *PDI = dyn_cast<PossiblyDisjointInst>(U)) {
1513 if (PDI->isDisjoint())
1514 Out << " disjoint";
1515 } else if (const auto *GEP = dyn_cast<GEPOperator>(U)) {
1516 if (GEP->isInBounds())
1517 Out << " inbounds";
1518 else if (GEP->hasNoUnsignedSignedWrap())
1519 Out << " nusw";
1520 if (GEP->hasNoUnsignedWrap())
1521 Out << " nuw";
1522 if (auto InRange = GEP->getInRange()) {
1523 Out << " inrange(" << InRange->getLower() << ", " << InRange->getUpper()
1524 << ")";
1525 }
1526 } else if (const auto *NNI = dyn_cast<PossiblyNonNegInst>(U)) {
1527 if (NNI->hasNonNeg())
1528 Out << " nneg";
1529 } else if (const auto *TI = dyn_cast<TruncInst>(U)) {
1530 if (TI->hasNoUnsignedWrap())
1531 Out << " nuw";
1532 if (TI->hasNoSignedWrap())
1533 Out << " nsw";
1534 } else if (const auto *ICmp = dyn_cast<ICmpInst>(U)) {
1535 if (ICmp->hasSameSign())
1536 Out << " samesign";
1537 }
1538}
1539
1540static void WriteFullHexAPInt(raw_ostream &Out, const APInt &Val) {
1542 Val.toStringUnsigned(Bits, 16);
1543 unsigned NumDigits = std::max((Val.getBitWidth() + 3) / 4, 1U);
1544 Out << "0x";
1545 for (unsigned i = 0; i < NumDigits - Bits.size(); i++)
1546 Out << '0';
1547 Out << Bits;
1548}
1549
1550static void writeAPFloatInternal(raw_ostream &Out, const APFloat &APF) {
1551 bool ForceBitwiseOutput = false;
1552 if (&APF.getSemantics() == &APFloat::PPCDoubleDouble()) {
1553 // ppc_fp128 types are double-double. The special cases set the second
1554 // (high) double to +0.0, so if the high word is nonzero, force the use of
1555 // bitwise output.
1556 APInt HiWord = APF.bitcastToAPInt().lshr(64);
1557 ForceBitwiseOutput = !HiWord.isZero();
1558 }
1559
1560 if (!ForceBitwiseOutput) {
1561 // Check for special values in APFloat.
1562 if (APF.isInfinity()) {
1563 Out << (APF.isNegative() ? '-' : '+') << "inf";
1564 return;
1565 }
1566
1567 if (APF.isNaN()) {
1568 Out << (APF.isNegative() ? '-' : '+');
1569 APInt Payload = APF.getNaNPayload();
1570 // The quiet bit of a NaN is the highest bit of the payload, so the
1571 // preferred QNaN value happens to be the sign mask value.
1572 if (Payload.isSignMask()) {
1573 Out << "qnan";
1574 } else {
1575 if (APF.isSignaling())
1576 Out << 's';
1577 Out << "nan(";
1578 // Clear out the signaling/quiet bit of the payload for output.
1579 Payload.clearBit(Payload.getBitWidth() - 1);
1580 // Trim the string to exclude leading 0's.
1581 WriteFullHexAPInt(Out, Payload.trunc(Payload.getActiveBits()));
1582 Out << ')';
1583 }
1584 return;
1585 }
1586 }
1587
1588 // Try for a decimal string output. If the value is convertible back to the
1589 // same APFloat value, then we know that it is safe to use it. Otherwise, fall
1590 // back onto the hexadecimal format.
1591 SmallString<128> StrVal;
1592 APF.toString(StrVal, 6, 0, false);
1593 if (APFloat(APF.getSemantics(), StrVal) == APF) {
1594 Out << StrVal;
1595 return;
1596 }
1597
1598 // Fallback to the hexadecimal format representing the bit string exactly.
1599 Out << 'f';
1600 APInt API = APF.bitcastToAPInt();
1601 WriteFullHexAPInt(Out, API);
1602}
1603
1604static void writeConstantInternal(raw_ostream &Out, const Constant *CV,
1605 AsmWriterContext &WriterCtx) {
1606 if (const auto *CI = dyn_cast<ConstantInt>(CV)) {
1607 Type *Ty = CI->getType();
1608
1609 if (Ty->isVectorTy()) {
1610 Out << "splat (";
1611 WriterCtx.TypePrinter->print(Ty->getScalarType(), Out);
1612 Out << " ";
1613 }
1614
1615 if (Ty->getScalarType()->isIntegerTy(1))
1616 Out << (CI->getZExtValue() ? "true" : "false");
1617 else
1618 Out << CI->getValue();
1619
1620 if (Ty->isVectorTy())
1621 Out << ")";
1622
1623 return;
1624 }
1625
1626 if (const auto *CB = dyn_cast<ConstantByte>(CV)) {
1627 Type *Ty = CB->getType();
1628
1629 if (Ty->isVectorTy()) {
1630 Out << "splat (";
1631 WriterCtx.TypePrinter->print(Ty->getScalarType(), Out);
1632 Out << " ";
1633 }
1634
1635 Out << CB->getValue();
1636
1637 if (Ty->isVectorTy())
1638 Out << ")";
1639
1640 return;
1641 }
1642
1643 if (const auto *CFP = dyn_cast<ConstantFP>(CV)) {
1644 Type *Ty = CFP->getType();
1645
1646 if (Ty->isVectorTy()) {
1647 if (CFP->getValue().bitcastToAPInt().isZero()) {
1648 Out << "zeroinitializer";
1649 return;
1650 }
1651
1652 Out << "splat (";
1653 WriterCtx.TypePrinter->print(Ty->getScalarType(), Out);
1654 Out << " ";
1655 }
1656
1657 writeAPFloatInternal(Out, CFP->getValueAPF());
1658
1659 if (Ty->isVectorTy())
1660 Out << ")";
1661
1662 return;
1663 }
1664
1666 Out << "zeroinitializer";
1667 return;
1668 }
1669
1670 if (const auto *BA = dyn_cast<BlockAddress>(CV)) {
1671 Out << "blockaddress(";
1672 writeAsOperandInternal(Out, BA->getFunction(), WriterCtx);
1673 Out << ", ";
1674 writeAsOperandInternal(Out, BA->getBasicBlock(), WriterCtx);
1675 Out << ")";
1676 return;
1677 }
1678
1679 if (const auto *Equiv = dyn_cast<DSOLocalEquivalent>(CV)) {
1680 Out << "dso_local_equivalent ";
1681 writeAsOperandInternal(Out, Equiv->getGlobalValue(), WriterCtx);
1682 return;
1683 }
1684
1685 if (const auto *NC = dyn_cast<NoCFIValue>(CV)) {
1686 Out << "no_cfi ";
1687 writeAsOperandInternal(Out, NC->getGlobalValue(), WriterCtx);
1688 return;
1689 }
1690
1691 if (const auto *CPA = dyn_cast<ConstantPtrAuth>(CV)) {
1692 Out << "ptrauth (";
1693
1694 // ptrauth (ptr CST, i32 KEY[, i64 DISC[, ptr ADDRDISC[, ptr DS]?]?]?)
1695 unsigned NumOpsToWrite = 2;
1696 if (!CPA->getOperand(2)->isNullValue())
1697 NumOpsToWrite = 3;
1698 if (!isa<ConstantPointerNull>(CPA->getOperand(3)))
1699 NumOpsToWrite = 4;
1700 if (!isa<ConstantPointerNull>(CPA->getOperand(4)))
1701 NumOpsToWrite = 5;
1702
1703 ListSeparator LS;
1704 for (unsigned i = 0, e = NumOpsToWrite; i != e; ++i) {
1705 Out << LS;
1706 writeAsOperandInternal(Out, CPA->getOperand(i), WriterCtx,
1707 /*PrintType=*/true);
1708 }
1709 Out << ')';
1710 return;
1711 }
1712
1713 if (const auto *CA = dyn_cast<ConstantArray>(CV)) {
1714 Out << '[';
1715 ListSeparator LS;
1716 for (const Value *Op : CA->operands()) {
1717 Out << LS;
1718 writeAsOperandInternal(Out, Op, WriterCtx, /*PrintType=*/true);
1719 }
1720 Out << ']';
1721 return;
1722 }
1723
1724 if (const auto *CA = dyn_cast<ConstantDataArray>(CV)) {
1725 // As a special case, print the array as a string if it is an array of
1726 // i8 with ConstantInt values.
1727 if (CA->isString()) {
1728 Out << "c\"";
1729 printEscapedString(CA->getAsString(), Out);
1730 Out << '"';
1731 return;
1732 }
1733
1734 Out << '[';
1735 ListSeparator LS;
1736 for (uint64_t i = 0, e = CA->getNumElements(); i != e; ++i) {
1737 Out << LS;
1738 writeAsOperandInternal(Out, CA->getElementAsConstant(i), WriterCtx,
1739 /*PrintType=*/true);
1740 }
1741 Out << ']';
1742 return;
1743 }
1744
1745 if (const auto *CS = dyn_cast<ConstantStruct>(CV)) {
1746 if (CS->getType()->isPacked())
1747 Out << '<';
1748 Out << '{';
1749 if (CS->getNumOperands() != 0) {
1750 Out << ' ';
1751 ListSeparator LS;
1752 for (const Value *Op : CS->operands()) {
1753 Out << LS;
1754 writeAsOperandInternal(Out, Op, WriterCtx, /*PrintType=*/true);
1755 }
1756 Out << ' ';
1757 }
1758 Out << '}';
1759 if (CS->getType()->isPacked())
1760 Out << '>';
1761 return;
1762 }
1763
1765 auto *CVVTy = cast<FixedVectorType>(CV->getType());
1766
1767 // Use the same shorthand for splat vector (i.e. "splat(Ty val)") as is
1768 // permitted on IR input to reduce the output changes when enabling
1769 // UseConstant{Int,FP}ForFixedLengthSplat.
1770 // TODO: Remove this block when the UseConstant{Int,FP}ForFixedLengthSplat
1771 // options are removed.
1772 if (auto *SplatVal = CV->getSplatValue()) {
1773 if (isa<ConstantInt>(SplatVal) || isa<ConstantFP>(SplatVal) ||
1774 isa<ConstantByte>(SplatVal)) {
1775 Out << "splat (";
1776 writeAsOperandInternal(Out, SplatVal, WriterCtx, /*PrintType=*/true);
1777 Out << ')';
1778 return;
1779 }
1780 }
1781
1782 Out << '<';
1783 ListSeparator LS;
1784 for (unsigned i = 0, e = CVVTy->getNumElements(); i != e; ++i) {
1785 Out << LS;
1786 writeAsOperandInternal(Out, CV->getAggregateElement(i), WriterCtx,
1787 /*PrintType=*/true);
1788 }
1789 Out << '>';
1790 return;
1791 }
1792
1793 if (const auto *CPN = dyn_cast<ConstantPointerNull>(CV)) {
1794 if (auto *VT = dyn_cast<VectorType>(CPN->getType())) {
1795 Out << "splat (";
1797 ConstantPointerNull::get(VT->getElementType()),
1798 WriterCtx, /*PrintType=*/true);
1799 Out << ')';
1800 return;
1801 }
1802
1803 Out << "null";
1804 return;
1805 }
1806
1807 if (isa<ConstantTokenNone>(CV)) {
1808 Out << "none";
1809 return;
1810 }
1811
1812 if (isa<PoisonValue>(CV)) {
1813 Out << "poison";
1814 return;
1815 }
1816
1817 if (isa<UndefValue>(CV)) {
1818 Out << "undef";
1819 return;
1820 }
1821
1822 if (const auto *CE = dyn_cast<ConstantExpr>(CV)) {
1823 // Use the same shorthand for splat vector (i.e. "splat(Ty val)") as is
1824 // permitted on IR input to reduce the output changes when enabling
1825 // UseConstant{Int,FP}ForScalableSplat.
1826 // TODO: Remove this block when the UseConstant{Int,FP}ForScalableSplat
1827 // options are removed.
1828 if (CE->getOpcode() == Instruction::ShuffleVector) {
1829 if (auto *SplatVal = CE->getSplatValue()) {
1830 if (isa<ConstantInt>(SplatVal) || isa<ConstantFP>(SplatVal) ||
1831 isa<ConstantByte>(SplatVal)) {
1832 Out << "splat (";
1833 writeAsOperandInternal(Out, SplatVal, WriterCtx, /*PrintType=*/true);
1834 Out << ')';
1835 return;
1836 }
1837 }
1838 }
1839
1840 Out << CE->getOpcodeName();
1841 writeOptimizationInfo(Out, CE);
1842 Out << " (";
1843
1844 if (const auto *GEP = dyn_cast<GEPOperator>(CE)) {
1845 WriterCtx.TypePrinter->print(GEP->getSourceElementType(), Out);
1846 Out << ", ";
1847 }
1848
1849 ListSeparator LS;
1850 for (const Value *Op : CE->operands()) {
1851 Out << LS;
1852 writeAsOperandInternal(Out, Op, WriterCtx, /*PrintType=*/true);
1853 }
1854
1855 if (CE->isCast()) {
1856 Out << " to ";
1857 WriterCtx.TypePrinter->print(CE->getType(), Out);
1858 }
1859
1860 if (CE->getOpcode() == Instruction::ShuffleVector)
1861 printShuffleMask(Out, CE->getType(), CE->getShuffleMask());
1862
1863 Out << ')';
1864 return;
1865 }
1866
1867 Out << "<placeholder or erroneous Constant>";
1868}
1869
1870static void writeMDTuple(raw_ostream &Out, const MDTuple *Node,
1871 AsmWriterContext &WriterCtx) {
1872 Out << "!{";
1873 ListSeparator LS;
1874 for (const Metadata *MD : Node->operands()) {
1875 Out << LS;
1876 if (!MD) {
1877 Out << "null";
1878 } else if (auto *MDV = dyn_cast<ValueAsMetadata>(MD)) {
1879 Value *V = MDV->getValue();
1880 writeAsOperandInternal(Out, V, WriterCtx, /*PrintType=*/true);
1881 } else {
1882 writeAsOperandInternal(Out, MD, WriterCtx);
1883 WriterCtx.onWriteMetadataAsOperand(MD);
1884 }
1885 }
1886
1887 Out << "}";
1888}
1889
1890namespace {
1891
1892struct MDFieldPrinter {
1893 raw_ostream &Out;
1894 ListSeparator FS;
1895 AsmWriterContext &WriterCtx;
1896
1897 explicit MDFieldPrinter(raw_ostream &Out)
1898 : Out(Out), WriterCtx(AsmWriterContext::getEmpty()) {}
1899 MDFieldPrinter(raw_ostream &Out, AsmWriterContext &Ctx)
1900 : Out(Out), WriterCtx(Ctx) {}
1901
1902 void printTag(const DINode *N);
1903 void printMacinfoType(const DIMacroNode *N);
1904 void printChecksum(const DIFile::ChecksumInfo<StringRef> &N);
1905 void printString(StringRef Name, StringRef Value,
1906 bool ShouldSkipEmpty = true);
1907 void printMetadata(StringRef Name, const Metadata *MD,
1908 bool ShouldSkipNull = true);
1909 void printMetadataOrInt(StringRef Name, const Metadata *MD, bool IsUnsigned,
1910 bool ShouldSkipZero = true);
1911 template <class IntTy>
1912 void printInt(StringRef Name, IntTy Int, bool ShouldSkipZero = true);
1913 void printAPInt(StringRef Name, const APInt &Int, bool IsUnsigned,
1914 bool ShouldSkipZero);
1915 void printBool(StringRef Name, bool Value,
1916 std::optional<bool> Default = std::nullopt);
1917 void printDIFlags(StringRef Name, DINode::DIFlags Flags);
1918 void printDISPFlags(StringRef Name, DISubprogram::DISPFlags Flags);
1919 template <class IntTy, class Stringifier>
1920 void printDwarfEnum(StringRef Name, IntTy Value, Stringifier toString,
1921 bool ShouldSkipZero = true);
1922 void printEmissionKind(StringRef Name, DICompileUnit::DebugEmissionKind EK);
1923 void printNameTableKind(StringRef Name,
1925 void printFixedPointKind(StringRef Name, DIFixedPointType::FixedPointKind V);
1926};
1927
1928} // end anonymous namespace
1929
1930void MDFieldPrinter::printTag(const DINode *N) {
1931 Out << FS << "tag: ";
1932 auto Tag = dwarf::TagString(N->getTag());
1933 if (!Tag.empty())
1934 Out << Tag;
1935 else
1936 Out << N->getTag();
1937}
1938
1939void MDFieldPrinter::printMacinfoType(const DIMacroNode *N) {
1940 Out << FS << "type: ";
1941 auto Type = dwarf::MacinfoString(N->getMacinfoType());
1942 if (!Type.empty())
1943 Out << Type;
1944 else
1945 Out << N->getMacinfoType();
1946}
1947
1948void MDFieldPrinter::printChecksum(
1949 const DIFile::ChecksumInfo<StringRef> &Checksum) {
1950 Out << FS << "checksumkind: " << Checksum.getKindAsString();
1951 printString("checksum", Checksum.Value, /* ShouldSkipEmpty */ false);
1952}
1953
1954void MDFieldPrinter::printString(StringRef Name, StringRef Value,
1955 bool ShouldSkipEmpty) {
1956 if (ShouldSkipEmpty && Value.empty())
1957 return;
1958
1959 Out << FS << Name << ": \"";
1961 Out << "\"";
1962}
1963
1964static void writeMetadataAsOperand(raw_ostream &Out, const Metadata *MD,
1965 AsmWriterContext &WriterCtx) {
1966 if (!MD) {
1967 Out << "null";
1968 return;
1969 }
1970 writeAsOperandInternal(Out, MD, WriterCtx);
1971 WriterCtx.onWriteMetadataAsOperand(MD);
1972}
1973
1974void MDFieldPrinter::printMetadata(StringRef Name, const Metadata *MD,
1975 bool ShouldSkipNull) {
1976 if (ShouldSkipNull && !MD)
1977 return;
1978
1979 Out << FS << Name << ": ";
1980 writeMetadataAsOperand(Out, MD, WriterCtx);
1981}
1982
1983void MDFieldPrinter::printMetadataOrInt(StringRef Name, const Metadata *MD,
1984 bool IsUnsigned, bool ShouldSkipZero) {
1985 if (!MD)
1986 return;
1987
1988 if (auto *CI = dyn_cast<ConstantAsMetadata>(MD)) {
1989 auto *CV = cast<ConstantInt>(CI->getValue());
1990 if (IsUnsigned)
1991 printInt(Name, CV->getZExtValue(), ShouldSkipZero);
1992 else
1993 printInt(Name, CV->getSExtValue(), ShouldSkipZero);
1994 } else
1995 printMetadata(Name, MD);
1996}
1997
1998template <class IntTy>
1999void MDFieldPrinter::printInt(StringRef Name, IntTy Int, bool ShouldSkipZero) {
2000 if (ShouldSkipZero && !Int)
2001 return;
2002
2003 Out << FS << Name << ": " << Int;
2004}
2005
2006void MDFieldPrinter::printAPInt(StringRef Name, const APInt &Int,
2007 bool IsUnsigned, bool ShouldSkipZero) {
2008 if (ShouldSkipZero && Int.isZero())
2009 return;
2010
2011 Out << FS << Name << ": ";
2012 Int.print(Out, !IsUnsigned);
2013}
2014
2015void MDFieldPrinter::printBool(StringRef Name, bool Value,
2016 std::optional<bool> Default) {
2017 if (Default && Value == *Default)
2018 return;
2019 Out << FS << Name << ": " << (Value ? "true" : "false");
2020}
2021
2022void MDFieldPrinter::printDIFlags(StringRef Name, DINode::DIFlags Flags) {
2023 if (!Flags)
2024 return;
2025
2026 Out << FS << Name << ": ";
2027
2029 auto Extra = DINode::splitFlags(Flags, SplitFlags);
2030
2031 ListSeparator FlagsFS(" | ");
2032 for (auto F : SplitFlags) {
2033 auto StringF = DINode::getFlagString(F);
2034 assert(!StringF.empty() && "Expected valid flag");
2035 Out << FlagsFS << StringF;
2036 }
2037 if (Extra || SplitFlags.empty())
2038 Out << FlagsFS << Extra;
2039}
2040
2041void MDFieldPrinter::printDISPFlags(StringRef Name,
2043 // Always print this field, because no flags in the IR at all will be
2044 // interpreted as old-style isDefinition: true.
2045 Out << FS << Name << ": ";
2046
2047 if (!Flags) {
2048 Out << 0;
2049 return;
2050 }
2051
2053 auto Extra = DISubprogram::splitFlags(Flags, SplitFlags);
2054
2055 ListSeparator FlagsFS(" | ");
2056 for (auto F : SplitFlags) {
2057 auto StringF = DISubprogram::getFlagString(F);
2058 assert(!StringF.empty() && "Expected valid flag");
2059 Out << FlagsFS << StringF;
2060 }
2061 if (Extra || SplitFlags.empty())
2062 Out << FlagsFS << Extra;
2063}
2064
2065void MDFieldPrinter::printEmissionKind(StringRef Name,
2067 Out << FS << Name << ": " << DICompileUnit::emissionKindString(EK);
2068}
2069
2070void MDFieldPrinter::printNameTableKind(StringRef Name,
2073 return;
2074 Out << FS << Name << ": " << DICompileUnit::nameTableKindString(NTK);
2075}
2076
2077void MDFieldPrinter::printFixedPointKind(StringRef Name,
2079 Out << FS << Name << ": " << DIFixedPointType::fixedPointKindString(V);
2080}
2081
2082template <class IntTy, class Stringifier>
2083void MDFieldPrinter::printDwarfEnum(StringRef Name, IntTy Value,
2084 Stringifier toString, bool ShouldSkipZero) {
2085 if (ShouldSkipZero && !Value)
2086 return;
2087
2088 Out << FS << Name << ": ";
2089 auto S = toString(Value);
2090 if (!S.empty())
2091 Out << S;
2092 else
2093 Out << Value;
2094}
2095
2097 AsmWriterContext &WriterCtx) {
2098 Out << "!GenericDINode(";
2099 MDFieldPrinter Printer(Out, WriterCtx);
2100 Printer.printTag(N);
2101 Printer.printString("header", N->getHeader());
2102 if (N->getNumDwarfOperands()) {
2103 Out << Printer.FS << "operands: {";
2104 ListSeparator IFS;
2105 for (auto &I : N->dwarf_operands()) {
2106 Out << IFS;
2107 writeMetadataAsOperand(Out, I, WriterCtx);
2108 }
2109 Out << "}";
2110 }
2111 Out << ")";
2112}
2113
2114static void writeDILocation(raw_ostream &Out, const DILocation *DL,
2115 AsmWriterContext &WriterCtx) {
2116 Out << "!DILocation(";
2117 MDFieldPrinter Printer(Out, WriterCtx);
2118 // Always output the line, since 0 is a relevant and important value for it.
2119 Printer.printInt("line", DL->getLine(), /* ShouldSkipZero */ false);
2120 Printer.printInt("column", DL->getColumn());
2121 Printer.printMetadata("scope", DL->getRawScope(), /* ShouldSkipNull */ false);
2122 Printer.printMetadata("inlinedAt", DL->getRawInlinedAt());
2123 Printer.printBool("isImplicitCode", DL->isImplicitCode(),
2124 /* Default */ false);
2125 Printer.printInt("atomGroup", DL->getAtomGroup());
2126 Printer.printInt<unsigned>("atomRank", DL->getAtomRank());
2127 Out << ")";
2128}
2129
2130static void writeDIAssignID(raw_ostream &Out, const DIAssignID *DL,
2131 AsmWriterContext &WriterCtx) {
2132 Out << "!DIAssignID()";
2133 MDFieldPrinter Printer(Out, WriterCtx);
2134}
2135
2136static void writeDISubrange(raw_ostream &Out, const DISubrange *N,
2137 AsmWriterContext &WriterCtx) {
2138 Out << "!DISubrange(";
2139 MDFieldPrinter Printer(Out, WriterCtx);
2140
2141 Printer.printMetadataOrInt("count", N->getRawCountNode(),
2142 /* IsUnsigned */ false,
2143 /* ShouldSkipZero */ false);
2144
2145 // A lowerBound of constant 0 should not be skipped, since it is different
2146 // from an unspecified lower bound (= nullptr).
2147 Printer.printMetadataOrInt("lowerBound", N->getRawLowerBound(),
2148 /* IsUnsigned */ false,
2149 /* ShouldSkipZero */ false);
2150 Printer.printMetadataOrInt("upperBound", N->getRawUpperBound(),
2151 /* IsUnsigned */ false,
2152 /* ShouldSkipZero */ false);
2153 Printer.printMetadataOrInt("stride", N->getRawStride(),
2154 /* IsUnsigned */ false,
2155 /* ShouldSkipZero */ false);
2156
2157 Out << ")";
2158}
2159
2161 AsmWriterContext &WriterCtx) {
2162 Out << "!DIGenericSubrange(";
2163 MDFieldPrinter Printer(Out, WriterCtx);
2164
2165 auto GetConstant = [&](Metadata *Bound) -> std::optional<int64_t> {
2166 auto *BE = dyn_cast_or_null<DIExpression>(Bound);
2167 if (!BE)
2168 return std::nullopt;
2169 if (BE->isConstant() &&
2171 *BE->isConstant()) {
2172 return static_cast<int64_t>(BE->getElement(1));
2173 }
2174 return std::nullopt;
2175 };
2176
2177 auto *Count = N->getRawCountNode();
2178 if (auto ConstantCount = GetConstant(Count))
2179 Printer.printInt("count", *ConstantCount,
2180 /* ShouldSkipZero */ false);
2181 else
2182 Printer.printMetadata("count", Count, /*ShouldSkipNull */ true);
2183
2184 auto *LBound = N->getRawLowerBound();
2185 if (auto ConstantLBound = GetConstant(LBound))
2186 Printer.printInt("lowerBound", *ConstantLBound,
2187 /* ShouldSkipZero */ false);
2188 else
2189 Printer.printMetadata("lowerBound", LBound, /*ShouldSkipNull */ true);
2190
2191 auto *UBound = N->getRawUpperBound();
2192 if (auto ConstantUBound = GetConstant(UBound))
2193 Printer.printInt("upperBound", *ConstantUBound,
2194 /* ShouldSkipZero */ false);
2195 else
2196 Printer.printMetadata("upperBound", UBound, /*ShouldSkipNull */ true);
2197
2198 auto *Stride = N->getRawStride();
2199 if (auto ConstantStride = GetConstant(Stride))
2200 Printer.printInt("stride", *ConstantStride,
2201 /* ShouldSkipZero */ false);
2202 else
2203 Printer.printMetadata("stride", Stride, /*ShouldSkipNull */ true);
2204
2205 Out << ")";
2206}
2207
2209 AsmWriterContext &) {
2210 Out << "!DIEnumerator(";
2211 MDFieldPrinter Printer(Out);
2212 Printer.printString("name", N->getName(), /* ShouldSkipEmpty */ false);
2213 Printer.printAPInt("value", N->getValue(), N->isUnsigned(),
2214 /*ShouldSkipZero=*/false);
2215 if (N->isUnsigned())
2216 Printer.printBool("isUnsigned", true);
2217 Out << ")";
2218}
2219
2221 AsmWriterContext &WriterCtx) {
2222 Out << "!DIBasicType(";
2223 MDFieldPrinter Printer(Out, WriterCtx);
2224 if (N->getTag() != dwarf::DW_TAG_base_type)
2225 Printer.printTag(N);
2226 Printer.printString("name", N->getName());
2227 Printer.printMetadata("scope", N->getRawScope());
2228 Printer.printMetadata("file", N->getRawFile());
2229 Printer.printInt("line", N->getLine());
2230 Printer.printMetadataOrInt("size", N->getRawSizeInBits(), true);
2231 Printer.printInt("align", N->getAlignInBits());
2232 Printer.printInt("dataSize", N->getDataSizeInBits());
2233 Printer.printDwarfEnum("encoding", N->getEncoding(),
2235 Printer.printInt("num_extra_inhabitants", N->getNumExtraInhabitants());
2236 Printer.printDIFlags("flags", N->getFlags());
2237 Out << ")";
2238}
2239
2241 AsmWriterContext &WriterCtx) {
2242 Out << "!DIFixedPointType(";
2243 MDFieldPrinter Printer(Out, WriterCtx);
2244 if (N->getTag() != dwarf::DW_TAG_base_type)
2245 Printer.printTag(N);
2246 Printer.printString("name", N->getName());
2247 Printer.printMetadata("scope", N->getRawScope());
2248 Printer.printMetadata("file", N->getRawFile());
2249 Printer.printInt("line", N->getLine());
2250 Printer.printMetadataOrInt("size", N->getRawSizeInBits(), true);
2251 Printer.printInt("align", N->getAlignInBits());
2252 Printer.printDwarfEnum("encoding", N->getEncoding(),
2254 Printer.printDIFlags("flags", N->getFlags());
2255 Printer.printFixedPointKind("kind", N->getKind());
2256 if (N->isRational()) {
2257 bool IsUnsigned = !N->isSigned();
2258 Printer.printAPInt("numerator", N->getNumerator(), IsUnsigned, false);
2259 Printer.printAPInt("denominator", N->getDenominator(), IsUnsigned, false);
2260 } else {
2261 Printer.printInt("factor", N->getFactor());
2262 }
2263 Out << ")";
2264}
2265
2267 AsmWriterContext &WriterCtx) {
2268 Out << "!DIStringType(";
2269 MDFieldPrinter Printer(Out, WriterCtx);
2270 if (N->getTag() != dwarf::DW_TAG_string_type)
2271 Printer.printTag(N);
2272 Printer.printString("name", N->getName());
2273 Printer.printMetadata("stringLength", N->getRawStringLength());
2274 Printer.printMetadata("stringLengthExpression", N->getRawStringLengthExp());
2275 Printer.printMetadata("stringLocationExpression",
2276 N->getRawStringLocationExp());
2277 Printer.printMetadataOrInt("size", N->getRawSizeInBits(), true);
2278 Printer.printInt("align", N->getAlignInBits());
2279 Printer.printDwarfEnum("encoding", N->getEncoding(),
2281 Out << ")";
2282}
2283
2285 AsmWriterContext &WriterCtx) {
2286 Out << "!DIDerivedType(";
2287 MDFieldPrinter Printer(Out, WriterCtx);
2288 Printer.printTag(N);
2289 Printer.printString("name", N->getName());
2290 Printer.printMetadata("scope", N->getRawScope());
2291 Printer.printMetadata("file", N->getRawFile());
2292 Printer.printInt("line", N->getLine());
2293 Printer.printMetadata("baseType", N->getRawBaseType(),
2294 /* ShouldSkipNull */ false);
2295 Printer.printMetadataOrInt("size", N->getRawSizeInBits(), true);
2296 Printer.printInt("align", N->getAlignInBits());
2297 Printer.printMetadataOrInt("offset", N->getRawOffsetInBits(), true);
2298 Printer.printDIFlags("flags", N->getFlags());
2299 Printer.printMetadata("extraData", N->getRawExtraData());
2300 if (const auto &DWARFAddressSpace = N->getDWARFAddressSpace())
2301 Printer.printInt("dwarfAddressSpace", *DWARFAddressSpace,
2302 /* ShouldSkipZero */ false);
2303 Printer.printMetadata("annotations", N->getRawAnnotations());
2304 if (auto PtrAuthData = N->getPtrAuthData()) {
2305 Printer.printInt("ptrAuthKey", PtrAuthData->key());
2306 Printer.printBool("ptrAuthIsAddressDiscriminated",
2307 PtrAuthData->isAddressDiscriminated());
2308 Printer.printInt("ptrAuthExtraDiscriminator",
2309 PtrAuthData->extraDiscriminator());
2310 Printer.printBool("ptrAuthIsaPointer", PtrAuthData->isaPointer());
2311 Printer.printBool("ptrAuthAuthenticatesNullValues",
2312 PtrAuthData->authenticatesNullValues());
2313 }
2314 Out << ")";
2315}
2316
2318 AsmWriterContext &WriterCtx) {
2319 Out << "!DISubrangeType(";
2320 MDFieldPrinter Printer(Out, WriterCtx);
2321 Printer.printString("name", N->getName());
2322 Printer.printMetadata("scope", N->getRawScope());
2323 Printer.printMetadata("file", N->getRawFile());
2324 Printer.printInt("line", N->getLine());
2325 Printer.printMetadataOrInt("size", N->getRawSizeInBits(), true);
2326 Printer.printInt("align", N->getAlignInBits());
2327 Printer.printDIFlags("flags", N->getFlags());
2328 Printer.printMetadata("baseType", N->getRawBaseType(),
2329 /* ShouldSkipNull */ false);
2330 Printer.printMetadata("lowerBound", N->getRawLowerBound());
2331 Printer.printMetadata("upperBound", N->getRawUpperBound());
2332 Printer.printMetadata("stride", N->getRawStride());
2333 Printer.printMetadata("bias", N->getRawBias());
2334 Out << ")";
2335}
2336
2338 AsmWriterContext &WriterCtx) {
2339 Out << "!DICompositeType(";
2340 MDFieldPrinter Printer(Out, WriterCtx);
2341 Printer.printTag(N);
2342 Printer.printString("name", N->getName());
2343 Printer.printMetadata("scope", N->getRawScope());
2344 Printer.printMetadata("file", N->getRawFile());
2345 Printer.printInt("line", N->getLine());
2346 Printer.printMetadata("baseType", N->getRawBaseType());
2347 Printer.printMetadataOrInt("size", N->getRawSizeInBits(), true);
2348 Printer.printInt("align", N->getAlignInBits());
2349 Printer.printMetadataOrInt("offset", N->getRawOffsetInBits(), true);
2350 Printer.printInt("num_extra_inhabitants", N->getNumExtraInhabitants());
2351 Printer.printDIFlags("flags", N->getFlags());
2352 Printer.printMetadata("elements", N->getRawElements());
2353 Printer.printDwarfEnum("runtimeLang", N->getRuntimeLang(),
2355 Printer.printMetadata("vtableHolder", N->getRawVTableHolder());
2356 Printer.printMetadata("templateParams", N->getRawTemplateParams());
2357 Printer.printString("identifier", N->getIdentifier());
2358 Printer.printMetadata("discriminator", N->getRawDiscriminator());
2359 Printer.printMetadata("dataLocation", N->getRawDataLocation());
2360 Printer.printMetadata("associated", N->getRawAssociated());
2361 Printer.printMetadata("allocated", N->getRawAllocated());
2362 if (auto *RankConst = N->getRankConst())
2363 Printer.printInt("rank", RankConst->getSExtValue(),
2364 /* ShouldSkipZero */ false);
2365 else
2366 Printer.printMetadata("rank", N->getRawRank(), /*ShouldSkipNull */ true);
2367 Printer.printMetadata("annotations", N->getRawAnnotations());
2368 if (auto *Specification = N->getRawSpecification())
2369 Printer.printMetadata("specification", Specification);
2370
2371 if (auto EnumKind = N->getEnumKind())
2372 Printer.printDwarfEnum("enumKind", *EnumKind, dwarf::EnumKindString,
2373 /*ShouldSkipZero=*/false);
2374
2375 Printer.printMetadata("bitStride", N->getRawBitStride());
2376 Out << ")";
2377}
2378
2380 AsmWriterContext &WriterCtx) {
2381 Out << "!DISubroutineType(";
2382 MDFieldPrinter Printer(Out, WriterCtx);
2383 Printer.printDIFlags("flags", N->getFlags());
2384 Printer.printDwarfEnum("cc", N->getCC(), dwarf::ConventionString);
2385 Printer.printMetadata("types", N->getRawTypeArray(),
2386 /* ShouldSkipNull */ false);
2387 Out << ")";
2388}
2389
2390static void writeDIFile(raw_ostream &Out, const DIFile *N, AsmWriterContext &) {
2391 Out << "!DIFile(";
2392 MDFieldPrinter Printer(Out);
2393 Printer.printString("filename", N->getFilename(),
2394 /* ShouldSkipEmpty */ false);
2395 Printer.printString("directory", N->getDirectory(),
2396 /* ShouldSkipEmpty */ false);
2397 // Print all values for checksum together, or not at all.
2398 if (N->getChecksum())
2399 Printer.printChecksum(*N->getChecksum());
2400 if (N->getSource())
2401 Printer.printString("source", *N->getSource(),
2402 /* ShouldSkipEmpty */ false);
2403 Out << ")";
2404}
2405
2407 AsmWriterContext &WriterCtx) {
2408 Out << "!DICompileUnit(";
2409 MDFieldPrinter Printer(Out, WriterCtx);
2410
2411 DISourceLanguageName Lang = N->getSourceLanguage();
2412
2413 if (Lang.hasVersionedName()) {
2414 Printer.printDwarfEnum(
2415 "sourceLanguageName",
2416 static_cast<llvm::dwarf::SourceLanguageName>(Lang.getName()),
2418 /* ShouldSkipZero */ false);
2419
2420 Printer.printInt("sourceLanguageVersion", Lang.getVersion(),
2421 /*ShouldSkipZero=*/true);
2422 } else {
2423 Printer.printDwarfEnum("language", Lang.getName(), dwarf::LanguageString,
2424 /* ShouldSkipZero */ false);
2425 }
2426
2427 Printer.printMetadata("file", N->getRawFile(), /* ShouldSkipNull */ false);
2428 Printer.printString("producer", N->getProducer());
2429 Printer.printBool("isOptimized", N->isOptimized());
2430 Printer.printString("flags", N->getFlags());
2431 Printer.printInt("runtimeVersion", N->getRuntimeVersion(),
2432 /* ShouldSkipZero */ false);
2433 Printer.printString("splitDebugFilename", N->getSplitDebugFilename());
2434 Printer.printEmissionKind("emissionKind", N->getEmissionKind());
2435 Printer.printMetadata("enums", N->getRawEnumTypes());
2436 Printer.printMetadata("retainedTypes", N->getRawRetainedTypes());
2437 Printer.printMetadata("globals", N->getRawGlobalVariables());
2438 Printer.printMetadata("imports", N->getRawImportedEntities());
2439 Printer.printMetadata("macros", N->getRawMacros());
2440 Printer.printInt("dwoId", N->getDWOId());
2441 Printer.printBool("splitDebugInlining", N->getSplitDebugInlining(), true);
2442 Printer.printBool("debugInfoForProfiling", N->getDebugInfoForProfiling(),
2443 false);
2444 Printer.printNameTableKind("nameTableKind", N->getNameTableKind());
2445 Printer.printBool("rangesBaseAddress", N->getRangesBaseAddress(), false);
2446 Printer.printString("sysroot", N->getSysRoot());
2447 Printer.printString("sdk", N->getSDK());
2448 Printer.printDwarfEnum("dialect", Lang.getDialect(),
2450 Out << ")";
2451}
2452
2454 AsmWriterContext &WriterCtx) {
2455 Out << "!DISubprogram(";
2456 MDFieldPrinter Printer(Out, WriterCtx);
2457 Printer.printString("name", N->getName());
2458 Printer.printString("linkageName", N->getLinkageName());
2459 Printer.printMetadata("scope", N->getRawScope(), /* ShouldSkipNull */ false);
2460 Printer.printMetadata("file", N->getRawFile());
2461 Printer.printInt("line", N->getLine());
2462 Printer.printMetadata("type", N->getRawType());
2463 Printer.printInt("scopeLine", N->getScopeLine());
2464 Printer.printMetadata("containingType", N->getRawContainingType());
2465 if (N->getVirtuality() != dwarf::DW_VIRTUALITY_none ||
2466 N->getVirtualIndex() != 0)
2467 Printer.printInt("virtualIndex", N->getVirtualIndex(), false);
2468 Printer.printInt("thisAdjustment", N->getThisAdjustment());
2469 Printer.printDIFlags("flags", N->getFlags());
2470 Printer.printDISPFlags("spFlags", N->getSPFlags());
2471 Printer.printMetadata("unit", N->getRawUnit());
2472 Printer.printMetadata("templateParams", N->getRawTemplateParams());
2473 Printer.printMetadata("declaration", N->getRawDeclaration());
2474 Printer.printMetadata("retainedNodes", N->getRawRetainedNodes());
2475 Printer.printMetadata("thrownTypes", N->getRawThrownTypes());
2476 Printer.printMetadata("annotations", N->getRawAnnotations());
2477 Printer.printString("targetFuncName", N->getTargetFuncName());
2478 Printer.printBool("keyInstructions", N->getKeyInstructionsEnabled(), false);
2479 Out << ")";
2480}
2481
2483 AsmWriterContext &WriterCtx) {
2484 Out << "!DILexicalBlock(";
2485 MDFieldPrinter Printer(Out, WriterCtx);
2486 Printer.printMetadata("scope", N->getRawScope(), /* ShouldSkipNull */ false);
2487 Printer.printMetadata("file", N->getRawFile());
2488 Printer.printInt("line", N->getLine());
2489 Printer.printInt("column", N->getColumn());
2490 Out << ")";
2491}
2492
2494 const DILexicalBlockFile *N,
2495 AsmWriterContext &WriterCtx) {
2496 Out << "!DILexicalBlockFile(";
2497 MDFieldPrinter Printer(Out, WriterCtx);
2498 Printer.printMetadata("scope", N->getRawScope(), /* ShouldSkipNull */ false);
2499 Printer.printMetadata("file", N->getRawFile());
2500 Printer.printInt("discriminator", N->getDiscriminator(),
2501 /* ShouldSkipZero */ false);
2502 Out << ")";
2503}
2504
2506 AsmWriterContext &WriterCtx) {
2507 Out << "!DINamespace(";
2508 MDFieldPrinter Printer(Out, WriterCtx);
2509 Printer.printString("name", N->getName());
2510 Printer.printMetadata("scope", N->getRawScope(), /* ShouldSkipNull */ false);
2511 Printer.printBool("exportSymbols", N->getExportSymbols(), false);
2512 Out << ")";
2513}
2514
2516 AsmWriterContext &WriterCtx) {
2517 Out << "!DICommonBlock(";
2518 MDFieldPrinter Printer(Out, WriterCtx);
2519 Printer.printMetadata("scope", N->getRawScope(), false);
2520 Printer.printMetadata("declaration", N->getRawDecl(), false);
2521 Printer.printString("name", N->getName());
2522 Printer.printMetadata("file", N->getRawFile());
2523 Printer.printInt("line", N->getLineNo());
2524 Out << ")";
2525}
2526
2527static void writeDIMacro(raw_ostream &Out, const DIMacro *N,
2528 AsmWriterContext &WriterCtx) {
2529 Out << "!DIMacro(";
2530 MDFieldPrinter Printer(Out, WriterCtx);
2531 Printer.printMacinfoType(N);
2532 Printer.printInt("line", N->getLine());
2533 Printer.printString("name", N->getName());
2534 Printer.printString("value", N->getValue());
2535 Out << ")";
2536}
2537
2539 AsmWriterContext &WriterCtx) {
2540 Out << "!DIMacroFile(";
2541 MDFieldPrinter Printer(Out, WriterCtx);
2542 Printer.printInt("line", N->getLine());
2543 Printer.printMetadata("file", N->getRawFile(), /* ShouldSkipNull */ false);
2544 Printer.printMetadata("nodes", N->getRawElements());
2545 Out << ")";
2546}
2547
2548static void writeDIModule(raw_ostream &Out, const DIModule *N,
2549 AsmWriterContext &WriterCtx) {
2550 Out << "!DIModule(";
2551 MDFieldPrinter Printer(Out, WriterCtx);
2552 Printer.printMetadata("scope", N->getRawScope(), /* ShouldSkipNull */ false);
2553 Printer.printString("name", N->getName());
2554 Printer.printString("configMacros", N->getConfigurationMacros());
2555 Printer.printString("includePath", N->getIncludePath());
2556 Printer.printString("apinotes", N->getAPINotesFile());
2557 Printer.printMetadata("file", N->getRawFile());
2558 Printer.printInt("line", N->getLineNo());
2559 Printer.printBool("isDecl", N->getIsDecl(), /* Default */ false);
2560 Out << ")";
2561}
2562
2565 AsmWriterContext &WriterCtx) {
2566 Out << "!DITemplateTypeParameter(";
2567 MDFieldPrinter Printer(Out, WriterCtx);
2568 Printer.printString("name", N->getName());
2569 Printer.printMetadata("type", N->getRawType(), /* ShouldSkipNull */ false);
2570 Printer.printBool("defaulted", N->isDefault(), /* Default= */ false);
2571 Out << ")";
2572}
2573
2576 AsmWriterContext &WriterCtx) {
2577 Out << "!DITemplateValueParameter(";
2578 MDFieldPrinter Printer(Out, WriterCtx);
2579 if (N->getTag() != dwarf::DW_TAG_template_value_parameter)
2580 Printer.printTag(N);
2581 Printer.printString("name", N->getName());
2582 Printer.printMetadata("type", N->getRawType());
2583 Printer.printBool("defaulted", N->isDefault(), /* Default= */ false);
2584 Printer.printMetadata("value", N->getValue(), /* ShouldSkipNull */ false);
2585 Out << ")";
2586}
2587
2589 AsmWriterContext &WriterCtx) {
2590 Out << "!DIGlobalVariable(";
2591 MDFieldPrinter Printer(Out, WriterCtx);
2592 Printer.printString("name", N->getName());
2593 Printer.printString("linkageName", N->getLinkageName());
2594 Printer.printMetadata("scope", N->getRawScope(), /* ShouldSkipNull */ false);
2595 Printer.printMetadata("file", N->getRawFile());
2596 Printer.printInt("line", N->getLine());
2597 Printer.printMetadata("type", N->getRawType());
2598 Printer.printBool("isLocal", N->isLocalToUnit());
2599 Printer.printBool("isDefinition", N->isDefinition());
2600 Printer.printMetadata("declaration", N->getRawStaticDataMemberDeclaration());
2601 Printer.printMetadata("templateParams", N->getRawTemplateParams());
2602 Printer.printInt("align", N->getAlignInBits());
2603 Printer.printMetadata("annotations", N->getRawAnnotations());
2604 Out << ")";
2605}
2606
2608 AsmWriterContext &WriterCtx) {
2609 Out << "!DILocalVariable(";
2610 MDFieldPrinter Printer(Out, WriterCtx);
2611 Printer.printString("name", N->getName());
2612 Printer.printInt("arg", N->getArg());
2613 Printer.printMetadata("scope", N->getRawScope(), /* ShouldSkipNull */ false);
2614 Printer.printMetadata("file", N->getRawFile());
2615 Printer.printInt("line", N->getLine());
2616 Printer.printMetadata("type", N->getRawType());
2617 Printer.printDIFlags("flags", N->getFlags());
2618 Printer.printInt("align", N->getAlignInBits());
2619 Printer.printMetadata("annotations", N->getRawAnnotations());
2620 Out << ")";
2621}
2622
2623static void writeDILabel(raw_ostream &Out, const DILabel *N,
2624 AsmWriterContext &WriterCtx) {
2625 Out << "!DILabel(";
2626 MDFieldPrinter Printer(Out, WriterCtx);
2627 Printer.printMetadata("scope", N->getRawScope(), /* ShouldSkipNull */ false);
2628 Printer.printString("name", N->getName());
2629 Printer.printMetadata("file", N->getRawFile());
2630 Printer.printInt("line", N->getLine(), /* ShouldSkipZero */ false);
2631 Printer.printInt("column", N->getColumn());
2632 Printer.printBool("isArtificial", N->isArtificial(), false);
2633 if (N->getCoroSuspendIdx())
2634 Printer.printInt("coroSuspendIdx", *N->getCoroSuspendIdx(),
2635 /* ShouldSkipZero */ false);
2636 Out << ")";
2637}
2638
2640 AsmWriterContext &WriterCtx) {
2641 Out << "!DIExpression(";
2642 ListSeparator FS;
2643 if (N->isValid()) {
2644 for (const DIExpression::ExprOperand &Op : N->expr_ops()) {
2645 auto OpStr = dwarf::OperationEncodingString(Op.getOp());
2646 assert(!OpStr.empty() && "Expected valid opcode");
2647
2648 Out << FS << OpStr;
2649 if (Op.getOp() == dwarf::DW_OP_LLVM_convert) {
2650 Out << FS << Op.getArg(0);
2651 Out << FS << dwarf::AttributeEncodingString(Op.getArg(1));
2652 } else {
2653 for (unsigned A = 0, AE = Op.getNumArgs(); A != AE; ++A)
2654 Out << FS << Op.getArg(A);
2655 }
2656 }
2657 } else {
2658 for (const auto &I : N->getElements())
2659 Out << FS << I;
2660 }
2661 Out << ")";
2662}
2663
2664static void writeDIArgList(raw_ostream &Out, const DIArgList *N,
2665 AsmWriterContext &WriterCtx,
2666 bool FromValue = false) {
2667 assert(FromValue &&
2668 "Unexpected DIArgList metadata outside of value argument");
2669 Out << "!DIArgList(";
2670 ListSeparator FS;
2671 MDFieldPrinter Printer(Out, WriterCtx);
2672 for (const Metadata *Arg : N->getArgs()) {
2673 Out << FS;
2674 writeAsOperandInternal(Out, Arg, WriterCtx, true);
2675 }
2676 Out << ")";
2677}
2678
2681 AsmWriterContext &WriterCtx) {
2682 Out << "!DIGlobalVariableExpression(";
2683 MDFieldPrinter Printer(Out, WriterCtx);
2684 Printer.printMetadata("var", N->getVariable());
2685 Printer.printMetadata("expr", N->getExpression());
2686 Out << ")";
2687}
2688
2690 AsmWriterContext &WriterCtx) {
2691 Out << "!DIObjCProperty(";
2692 MDFieldPrinter Printer(Out, WriterCtx);
2693 Printer.printString("name", N->getName());
2694 Printer.printMetadata("file", N->getRawFile());
2695 Printer.printInt("line", N->getLine());
2696 Printer.printString("setter", N->getSetterName());
2697 Printer.printString("getter", N->getGetterName());
2698 Printer.printInt("attributes", N->getAttributes());
2699 Printer.printMetadata("type", N->getRawType());
2700 Out << ")";
2701}
2702
2704 AsmWriterContext &WriterCtx) {
2705 Out << "!DIImportedEntity(";
2706 MDFieldPrinter Printer(Out, WriterCtx);
2707 Printer.printTag(N);
2708 Printer.printString("name", N->getName());
2709 Printer.printMetadata("scope", N->getRawScope(), /* ShouldSkipNull */ false);
2710 Printer.printMetadata("entity", N->getRawEntity());
2711 Printer.printMetadata("file", N->getRawFile());
2712 Printer.printInt("line", N->getLine());
2713 Printer.printMetadata("elements", N->getRawElements());
2714 Out << ")";
2715}
2716
2718 AsmWriterContext &Ctx) {
2719 if (Node->isDistinct())
2720 Out << "distinct ";
2721 else if (Node->isTemporary())
2722 Out << "<temporary!> "; // Handle broken code.
2723
2724 switch (Node->getMetadataID()) {
2725 default:
2726 llvm_unreachable("Expected uniquable MDNode");
2727#define HANDLE_MDNODE_LEAF(CLASS) \
2728 case Metadata::CLASS##Kind: \
2729 write##CLASS(Out, cast<CLASS>(Node), Ctx); \
2730 break;
2731#include "llvm/IR/Metadata.def"
2732 }
2733}
2734
2735// Full implementation of printing a Value as an operand with support for
2736// TypePrinting, etc.
2737static void writeAsOperandInternal(raw_ostream &Out, const Value *V,
2738 AsmWriterContext &WriterCtx,
2739 bool PrintType) {
2740 if (PrintType) {
2741 WriterCtx.TypePrinter->print(V->getType(), Out);
2742 Out << ' ';
2743 }
2744
2745 if (V->hasName()) {
2746 printLLVMName(Out, V);
2747 return;
2748 }
2749
2750 const auto *CV = dyn_cast<Constant>(V);
2751 if (CV && !isa<GlobalValue>(CV)) {
2752 assert(WriterCtx.TypePrinter && "Constants require TypePrinting!");
2753 writeConstantInternal(Out, CV, WriterCtx);
2754 return;
2755 }
2756
2757 if (const auto *IA = dyn_cast<InlineAsm>(V)) {
2758 Out << "asm ";
2759 if (IA->hasSideEffects())
2760 Out << "sideeffect ";
2761 if (IA->isAlignStack())
2762 Out << "alignstack ";
2763 // We don't emit the AD_ATT dialect as it's the assumed default.
2764 if (IA->getDialect() == InlineAsm::AD_Intel)
2765 Out << "inteldialect ";
2766 if (IA->canThrow())
2767 Out << "unwind ";
2768 Out << '"';
2769 printEscapedString(IA->getAsmString(), Out);
2770 Out << "\", \"";
2771 printEscapedString(IA->getConstraintString(), Out);
2772 Out << '"';
2773 return;
2774 }
2775
2776 if (auto *MD = dyn_cast<MetadataAsValue>(V)) {
2777 writeAsOperandInternal(Out, MD->getMetadata(), WriterCtx,
2778 /* FromValue */ true);
2779 return;
2780 }
2781
2782 char Prefix = '%';
2783 int Slot;
2784 auto *Machine = WriterCtx.Machine;
2785 // If we have a SlotTracker, use it.
2786 if (Machine) {
2787 if (const auto *GV = dyn_cast<GlobalValue>(V)) {
2788 Slot = Machine->getGlobalSlot(GV);
2789 Prefix = '@';
2790 } else {
2791 Slot = Machine->getLocalSlot(V);
2792
2793 // If the local value didn't succeed, then we may be referring to a value
2794 // from a different function. Translate it, as this can happen when using
2795 // address of blocks.
2796 if (Slot == -1)
2797 if ((Machine = createSlotTracker(V))) {
2798 Slot = Machine->getLocalSlot(V);
2799 delete Machine;
2800 }
2801 }
2802 } else if ((Machine = createSlotTracker(V))) {
2803 // Otherwise, create one to get the # and then destroy it.
2804 if (const auto *GV = dyn_cast<GlobalValue>(V)) {
2805 Slot = Machine->getGlobalSlot(GV);
2806 Prefix = '@';
2807 } else {
2808 Slot = Machine->getLocalSlot(V);
2809 }
2810 delete Machine;
2811 Machine = nullptr;
2812 } else {
2813 Slot = -1;
2814 }
2815
2816 if (Slot != -1)
2817 Out << Prefix << Slot;
2818 else
2819 Out << "<badref>";
2820}
2821
2822static void writeAsOperandInternal(raw_ostream &Out, const Metadata *MD,
2823 AsmWriterContext &WriterCtx,
2824 bool FromValue) {
2825 // Write DIExpressions and DIArgLists inline when used as a value. Improves
2826 // readability of debug info intrinsics.
2827 if (const auto *Expr = dyn_cast<DIExpression>(MD)) {
2828 writeDIExpression(Out, Expr, WriterCtx);
2829 return;
2830 }
2831 if (const auto *ArgList = dyn_cast<DIArgList>(MD)) {
2832 writeDIArgList(Out, ArgList, WriterCtx, FromValue);
2833 return;
2834 }
2835
2836 if (const auto *N = dyn_cast<MDNode>(MD)) {
2837 std::unique_ptr<SlotTracker> MachineStorage;
2838 SaveAndRestore SARMachine(WriterCtx.Machine);
2839 if (!WriterCtx.Machine) {
2840 MachineStorage = std::make_unique<SlotTracker>(WriterCtx.Context);
2841 WriterCtx.Machine = MachineStorage.get();
2842 }
2843 int Slot = WriterCtx.Machine->getMetadataSlot(N);
2844 if (Slot == -1) {
2845 if (const auto *Loc = dyn_cast<DILocation>(N)) {
2846 writeDILocation(Out, Loc, WriterCtx);
2847 return;
2848 }
2849 // Give the pointer value instead of "badref", since this comes up all
2850 // the time when debugging.
2851 Out << "<" << N << ">";
2852 } else
2853 Out << '!' << Slot;
2854 return;
2855 }
2856
2857 if (const auto *MDS = dyn_cast<MDString>(MD)) {
2858 Out << "!\"";
2859 printEscapedString(MDS->getString(), Out);
2860 Out << '"';
2861 return;
2862 }
2863
2864 auto *V = cast<ValueAsMetadata>(MD);
2865 assert(WriterCtx.TypePrinter && "TypePrinter required for metadata values");
2866 assert((FromValue || !isa<LocalAsMetadata>(V)) &&
2867 "Unexpected function-local metadata outside of value argument");
2868
2869 writeAsOperandInternal(Out, V->getValue(), WriterCtx, /*PrintType=*/true);
2870}
2871
2872namespace {
2873
2874class AssemblyWriter {
2875 formatted_raw_ostream &Out;
2876 const Module *TheModule = nullptr;
2877 const ModuleSummaryIndex *TheIndex = nullptr;
2878 std::unique_ptr<SlotTracker> SlotTrackerStorage;
2879 SlotTracker &Machine;
2880 TypePrinting TypePrinter;
2881 AssemblyAnnotationWriter *AnnotationWriter = nullptr;
2882 SetVector<const Comdat *> Comdats;
2883 bool IsForDebug;
2884 bool ShouldPreserveUseListOrder;
2885 UseListOrderMap UseListOrders;
2887 /// Synchronization scope names registered with LLVMContext.
2889 DenseMap<const GlobalValueSummary *, GlobalValue::GUID> SummaryToGUIDMap;
2890
2891public:
2892 /// Construct an AssemblyWriter with an external SlotTracker
2893 AssemblyWriter(formatted_raw_ostream &o, SlotTracker &Mac, const Module *M,
2894 AssemblyAnnotationWriter *AAW, bool IsForDebug,
2895 bool ShouldPreserveUseListOrder = false);
2896
2897 AssemblyWriter(formatted_raw_ostream &o, SlotTracker &Mac,
2898 const ModuleSummaryIndex *Index, bool IsForDebug);
2899
2900 AsmWriterContext getContext() {
2901 return AsmWriterContext(&TypePrinter, &Machine, TheModule);
2902 }
2903
2904 void printMDNodeBody(const MDNode *MD);
2905 void printNamedMDNode(const NamedMDNode *NMD);
2906
2907 void printModule(const Module *M);
2908
2909 void writeOperand(const Value *Op, bool PrintType);
2910 void writeParamOperand(const Value *Operand, AttributeSet Attrs);
2911 void writeOperandBundles(const CallBase *Call);
2912 void writeSyncScope(const LLVMContext &Context,
2913 SyncScope::ID SSID);
2914 void writeAtomic(const LLVMContext &Context,
2915 AtomicOrdering Ordering,
2916 SyncScope::ID SSID);
2917 void writeAtomicCmpXchg(const LLVMContext &Context,
2918 AtomicOrdering SuccessOrdering,
2919 AtomicOrdering FailureOrdering,
2920 SyncScope::ID SSID);
2921
2922 void writeAllMDNodes();
2923 void writeMDNode(unsigned Slot, const MDNode *Node);
2924 void writeAttribute(const Attribute &Attr, bool InAttrGroup = false);
2925 void writeAttributeSet(const AttributeSet &AttrSet, bool InAttrGroup = false);
2926 void writeAllAttributeGroups();
2927
2928 void printTypeIdentities();
2929 void printGlobal(const GlobalVariable *GV);
2930 void printAlias(const GlobalAlias *GA);
2931 void printIFunc(const GlobalIFunc *GI);
2932 void printComdat(const Comdat *C);
2933 void printFunction(const Function *F);
2934 void printArgument(const Argument *FA, AttributeSet Attrs);
2935 void printBasicBlock(const BasicBlock *BB);
2936 void printInstructionLine(const Instruction &I);
2937 void printInstruction(const Instruction &I);
2938 void printDbgMarker(const DbgMarker &DPI);
2939 void printDbgVariableRecord(const DbgVariableRecord &DVR);
2940 void printDbgLabelRecord(const DbgLabelRecord &DLR);
2941 void printDbgRecord(const DbgRecord &DR);
2942 void printDbgRecordLine(const DbgRecord &DR);
2943
2944 void printUseListOrder(const Value *V, ArrayRef<unsigned> Shuffle);
2945 void printUseLists(const Function *F);
2946
2947 void printModuleSummaryIndex();
2948 void printSummaryInfo(unsigned Slot, const ValueInfo &VI);
2949 void printSummary(const GlobalValueSummary &Summary);
2950 void printAliasSummary(const AliasSummary *AS);
2951 void printGlobalVarSummary(const GlobalVarSummary *GS);
2952 void printFunctionSummary(const FunctionSummary *FS);
2953 void printTypeIdSummary(const TypeIdSummary &TIS);
2954 void printTypeIdCompatibleVtableSummary(const TypeIdCompatibleVtableInfo &TI);
2955 void printTypeTestResolution(const TypeTestResolution &TTRes);
2956 void printArgs(ArrayRef<uint64_t> Args);
2957 void printWPDRes(const WholeProgramDevirtResolution &WPDRes);
2958 void printTypeIdInfo(const FunctionSummary::TypeIdInfo &TIDInfo);
2959 void printVFuncId(const FunctionSummary::VFuncId VFId);
2960 void printNonConstVCalls(ArrayRef<FunctionSummary::VFuncId> VCallList,
2961 const char *Tag);
2962 void printConstVCalls(ArrayRef<FunctionSummary::ConstVCall> VCallList,
2963 const char *Tag);
2964
2965private:
2966 /// Print out metadata attachments.
2967 void printMetadataAttachments(
2968 const SmallVectorImpl<std::pair<unsigned, MDNode *>> &MDs,
2969 StringRef Separator);
2970
2971 // printInfoComment - Print a little comment after the instruction indicating
2972 // which slot it occupies.
2973 void printInfoComment(const Value &V, bool isMaterializable = false);
2974
2975 // printGCRelocateComment - print comment after call to the gc.relocate
2976 // intrinsic indicating base and derived pointer names.
2977 void printGCRelocateComment(const GCRelocateInst &Relocate);
2978};
2979
2980} // end anonymous namespace
2981
2982AssemblyWriter::AssemblyWriter(formatted_raw_ostream &o, SlotTracker &Mac,
2983 const Module *M, AssemblyAnnotationWriter *AAW,
2984 bool IsForDebug, bool ShouldPreserveUseListOrder)
2985 : Out(o), TheModule(M), Machine(Mac), TypePrinter(M), AnnotationWriter(AAW),
2986 IsForDebug(IsForDebug),
2987 ShouldPreserveUseListOrder(
2988 PreserveAssemblyUseListOrder.getNumOccurrences()
2990 : ShouldPreserveUseListOrder) {
2991 if (!TheModule)
2992 return;
2993 for (const GlobalObject &GO : TheModule->global_objects())
2994 if (const Comdat *C = GO.getComdat())
2995 Comdats.insert(C);
2996}
2997
2998AssemblyWriter::AssemblyWriter(formatted_raw_ostream &o, SlotTracker &Mac,
2999 const ModuleSummaryIndex *Index, bool IsForDebug)
3000 : Out(o), TheIndex(Index), Machine(Mac), TypePrinter(/*Module=*/nullptr),
3001 IsForDebug(IsForDebug),
3002 ShouldPreserveUseListOrder(PreserveAssemblyUseListOrder) {}
3003
3004void AssemblyWriter::writeOperand(const Value *Operand, bool PrintType) {
3005 if (!Operand) {
3006 Out << "<null operand!>";
3007 return;
3008 }
3009 auto WriteCtx = getContext();
3010 writeAsOperandInternal(Out, Operand, WriteCtx, PrintType);
3011}
3012
3013void AssemblyWriter::writeSyncScope(const LLVMContext &Context,
3014 SyncScope::ID SSID) {
3015 switch (SSID) {
3016 case SyncScope::System: {
3017 break;
3018 }
3019 default: {
3020 if (SSNs.empty())
3021 Context.getSyncScopeNames(SSNs);
3022
3023 Out << " syncscope(\"";
3024 printEscapedString(SSNs[SSID], Out);
3025 Out << "\")";
3026 break;
3027 }
3028 }
3029}
3030
3031void AssemblyWriter::writeAtomic(const LLVMContext &Context,
3032 AtomicOrdering Ordering,
3033 SyncScope::ID SSID) {
3034 if (Ordering == AtomicOrdering::NotAtomic)
3035 return;
3036
3037 writeSyncScope(Context, SSID);
3038 Out << " " << toIRString(Ordering);
3039}
3040
3041void AssemblyWriter::writeAtomicCmpXchg(const LLVMContext &Context,
3042 AtomicOrdering SuccessOrdering,
3043 AtomicOrdering FailureOrdering,
3044 SyncScope::ID SSID) {
3045 assert(SuccessOrdering != AtomicOrdering::NotAtomic &&
3046 FailureOrdering != AtomicOrdering::NotAtomic);
3047
3048 writeSyncScope(Context, SSID);
3049 Out << " " << toIRString(SuccessOrdering);
3050 Out << " " << toIRString(FailureOrdering);
3051}
3052
3053void AssemblyWriter::writeParamOperand(const Value *Operand,
3054 AttributeSet Attrs) {
3055 if (!Operand) {
3056 Out << "<null operand!>";
3057 return;
3058 }
3059
3060 // Print the type
3061 TypePrinter.print(Operand->getType(), Out);
3062 // Print parameter attributes list
3063 if (Attrs.hasAttributes()) {
3064 Out << ' ';
3065 writeAttributeSet(Attrs);
3066 }
3067 Out << ' ';
3068 // Print the operand
3069 auto WriterCtx = getContext();
3070 writeAsOperandInternal(Out, Operand, WriterCtx);
3071}
3072
3073void AssemblyWriter::writeOperandBundles(const CallBase *Call) {
3074 if (!Call->hasOperandBundles())
3075 return;
3076
3077 Out << " [ ";
3078
3079 ListSeparator LS;
3080 for (unsigned i = 0, e = Call->getNumOperandBundles(); i != e; ++i) {
3081 OperandBundleUse BU = Call->getOperandBundleAt(i);
3082
3083 Out << LS << '"';
3084 printEscapedString(BU.getTagName(), Out);
3085 Out << '"';
3086
3087 Out << '(';
3088
3089 ListSeparator InnerLS;
3090 auto WriterCtx = getContext();
3091 for (const auto &Input : BU.Inputs) {
3092 Out << InnerLS;
3093 if (Input == nullptr)
3094 Out << "<null operand bundle!>";
3095 else
3096 writeAsOperandInternal(Out, Input, WriterCtx, /*PrintType=*/true);
3097 }
3098
3099 Out << ')';
3100 }
3101
3102 Out << " ]";
3103}
3104
3105void AssemblyWriter::printModule(const Module *M) {
3106 Machine.initializeIfNeeded();
3107
3108 if (ShouldPreserveUseListOrder)
3109 UseListOrders = predictUseListOrder(M);
3110
3111 if (!M->getModuleIdentifier().empty() &&
3112 // Don't print the ID if it will start a new line (which would
3113 // require a comment char before it).
3114 M->getModuleIdentifier().find('\n') == std::string::npos)
3115 Out << "; ModuleID = '" << M->getModuleIdentifier() << "'\n";
3116
3117 if (!M->getSourceFileName().empty()) {
3118 Out << "source_filename = \"";
3119 printEscapedString(M->getSourceFileName(), Out);
3120 Out << "\"\n";
3121 }
3122
3123 const std::string &DL = M->getDataLayoutStr();
3124 if (!DL.empty())
3125 Out << "target datalayout = \"" << DL << "\"\n";
3126 if (!M->getTargetTriple().empty())
3127 Out << "target triple = \"" << M->getTargetTriple().str() << "\"\n";
3128
3129 if (!M->getModuleInlineAsm().empty()) {
3130 Out << '\n';
3131
3132 // Split the string into lines, to make it easier to read the .ll file.
3133 StringRef Asm = M->getModuleInlineAsm();
3134 do {
3135 StringRef Front;
3136 std::tie(Front, Asm) = Asm.split('\n');
3137
3138 // We found a newline, print the portion of the asm string from the
3139 // last newline up to this newline.
3140 Out << "module asm \"";
3141 printEscapedString(Front, Out);
3142 Out << "\"\n";
3143 } while (!Asm.empty());
3144 }
3145
3146 printTypeIdentities();
3147
3148 // Output all comdats.
3149 if (!Comdats.empty())
3150 Out << '\n';
3151 for (const Comdat *C : Comdats) {
3152 printComdat(C);
3153 if (C != Comdats.back())
3154 Out << '\n';
3155 }
3156
3157 // Output all globals.
3158 if (!M->global_empty()) Out << '\n';
3159 for (const GlobalVariable &GV : M->globals()) {
3160 printGlobal(&GV); Out << '\n';
3161 }
3162
3163 // Output all aliases.
3164 if (!M->alias_empty()) Out << "\n";
3165 for (const GlobalAlias &GA : M->aliases())
3166 printAlias(&GA);
3167
3168 // Output all ifuncs.
3169 if (!M->ifunc_empty()) Out << "\n";
3170 for (const GlobalIFunc &GI : M->ifuncs())
3171 printIFunc(&GI);
3172
3173 // Output all of the functions.
3174 for (const Function &F : *M) {
3175 Out << '\n';
3176 printFunction(&F);
3177 }
3178
3179 // Output global use-lists.
3180 printUseLists(nullptr);
3181
3182 // Output all attribute groups.
3183 if (!Machine.as_empty()) {
3184 Out << '\n';
3185 writeAllAttributeGroups();
3186 }
3187
3188 // Output named metadata.
3189 if (!M->named_metadata_empty()) Out << '\n';
3190
3191 for (const NamedMDNode &Node : M->named_metadata())
3192 printNamedMDNode(&Node);
3193
3194 // Output metadata.
3195 if (!Machine.mdn_empty()) {
3196 Out << '\n';
3197 writeAllMDNodes();
3198 }
3199}
3200
3201void AssemblyWriter::printModuleSummaryIndex() {
3202 assert(TheIndex);
3203 int NumSlots = Machine.initializeIndexIfNeeded();
3204
3205 Out << "\n";
3206
3207 // Print module path entries. To print in order, add paths to a vector
3208 // indexed by module slot.
3209 std::vector<std::pair<std::string, ModuleHash>> moduleVec;
3210 std::string RegularLTOModuleName =
3212 moduleVec.resize(TheIndex->modulePaths().size());
3213 for (auto &[ModPath, ModHash] : TheIndex->modulePaths())
3214 moduleVec[Machine.getModulePathSlot(ModPath)] = std::make_pair(
3215 // An empty module path is a special entry for a regular LTO module
3216 // created during the thin link.
3217 ModPath.empty() ? RegularLTOModuleName : std::string(ModPath), ModHash);
3218
3219 unsigned i = 0;
3220 for (auto &ModPair : moduleVec) {
3221 Out << "^" << i++ << " = module: (";
3222 Out << "path: \"";
3223 printEscapedString(ModPair.first, Out);
3224 Out << "\", hash: (";
3225 ListSeparator FS;
3226 for (auto Hash : ModPair.second)
3227 Out << FS << Hash;
3228 Out << "))\n";
3229 }
3230
3231 // FIXME: Change AliasSummary to hold a ValueInfo instead of summary pointer
3232 // for aliasee (then update BitcodeWriter.cpp and remove get/setAliaseeGUID).
3233 // Sort by GUID for deterministic output matching slot assignment order.
3234 auto SortedGVS = TheIndex->sortedGlobalValueSummariesRange();
3235
3236 for (const auto &GlobalList : SortedGVS) {
3237 auto GUID = GlobalList.first;
3238 for (auto &Summary : GlobalList.second.getSummaryList())
3239 SummaryToGUIDMap[Summary.get()] = GUID;
3240 }
3241
3242 // Print the global value summary entries.
3243 for (const auto &GlobalList : SortedGVS) {
3244 auto GUID = GlobalList.first;
3245 auto VI = TheIndex->getValueInfo(GlobalList);
3246 printSummaryInfo(Machine.getGUIDSlot(GUID), VI);
3247 }
3248
3249 // Print the TypeIdMap entries.
3250 for (const auto &TID : TheIndex->typeIds()) {
3251 Out << "^" << Machine.getTypeIdSlot(TID.second.first)
3252 << " = typeid: (name: \"" << TID.second.first << "\"";
3253 printTypeIdSummary(TID.second.second);
3254 Out << ") ; guid = " << TID.first << "\n";
3255 }
3256
3257 // Print the TypeIdCompatibleVtableMap entries.
3258 for (auto &TId : TheIndex->typeIdCompatibleVtableMap()) {
3260 Out << "^" << Machine.getTypeIdCompatibleVtableSlot(TId.first)
3261 << " = typeidCompatibleVTable: (name: \"" << TId.first << "\"";
3262 printTypeIdCompatibleVtableSummary(TId.second);
3263 Out << ") ; guid = " << GUID << "\n";
3264 }
3265
3266 // Don't emit flags when it's not really needed (value is zero by default).
3267 if (TheIndex->getFlags()) {
3268 Out << "^" << NumSlots << " = flags: " << TheIndex->getFlags() << "\n";
3269 ++NumSlots;
3270 }
3271
3272 Out << "^" << NumSlots << " = blockcount: " << TheIndex->getBlockCount()
3273 << "\n";
3274}
3275
3276static const char *
3278 switch (K) {
3280 return "indir";
3282 return "singleImpl";
3284 return "branchFunnel";
3285 }
3286 llvm_unreachable("invalid WholeProgramDevirtResolution kind");
3287}
3288
3291 switch (K) {
3293 return "indir";
3295 return "uniformRetVal";
3297 return "uniqueRetVal";
3299 return "virtualConstProp";
3300 }
3301 llvm_unreachable("invalid WholeProgramDevirtResolution::ByArg kind");
3302}
3303
3305 switch (K) {
3307 return "unknown";
3309 return "unsat";
3311 return "byteArray";
3313 return "inline";
3315 return "single";
3317 return "allOnes";
3318 }
3319 llvm_unreachable("invalid TypeTestResolution kind");
3320}
3321
3322void AssemblyWriter::printTypeTestResolution(const TypeTestResolution &TTRes) {
3323 Out << "typeTestRes: (kind: " << getTTResKindName(TTRes.TheKind)
3324 << ", sizeM1BitWidth: " << TTRes.SizeM1BitWidth;
3325
3326 // The following fields are only used if the target does not support the use
3327 // of absolute symbols to store constants. Print only if non-zero.
3328 if (TTRes.AlignLog2)
3329 Out << ", alignLog2: " << TTRes.AlignLog2;
3330 if (TTRes.SizeM1)
3331 Out << ", sizeM1: " << TTRes.SizeM1;
3332 if (TTRes.BitMask)
3333 // BitMask is uint8_t which causes it to print the corresponding char.
3334 Out << ", bitMask: " << (unsigned)TTRes.BitMask;
3335 if (TTRes.InlineBits)
3336 Out << ", inlineBits: " << TTRes.InlineBits;
3337
3338 Out << ")";
3339}
3340
3341void AssemblyWriter::printTypeIdSummary(const TypeIdSummary &TIS) {
3342 Out << ", summary: (";
3343 printTypeTestResolution(TIS.TTRes);
3344 if (!TIS.WPDRes.empty()) {
3345 Out << ", wpdResolutions: (";
3346 ListSeparator FS;
3347 for (auto &WPDRes : TIS.WPDRes) {
3348 Out << FS;
3349 Out << "(offset: " << WPDRes.first << ", ";
3350 printWPDRes(WPDRes.second);
3351 Out << ")";
3352 }
3353 Out << ")";
3354 }
3355 Out << ")";
3356}
3357
3358void AssemblyWriter::printTypeIdCompatibleVtableSummary(
3359 const TypeIdCompatibleVtableInfo &TI) {
3360 Out << ", summary: (";
3361 ListSeparator FS;
3362 for (auto &P : TI) {
3363 Out << FS;
3364 Out << "(offset: " << P.AddressPointOffset << ", ";
3365 Out << "^" << Machine.getGUIDSlot(P.VTableVI.getGUID());
3366 Out << ")";
3367 }
3368 Out << ")";
3369}
3370
3371void AssemblyWriter::printArgs(ArrayRef<uint64_t> Args) {
3372 Out << "args: (" << llvm::interleaved(Args) << ')';
3373}
3374
3375void AssemblyWriter::printWPDRes(const WholeProgramDevirtResolution &WPDRes) {
3376 Out << "wpdRes: (kind: ";
3378
3380 Out << ", singleImplName: \"" << WPDRes.SingleImplName << "\"";
3381
3382 if (!WPDRes.ResByArg.empty()) {
3383 Out << ", resByArg: (";
3384 ListSeparator FS;
3385 for (auto &ResByArg : WPDRes.ResByArg) {
3386 Out << FS;
3387 printArgs(ResByArg.first);
3388 Out << ", byArg: (kind: ";
3389 Out << getWholeProgDevirtResByArgKindName(ResByArg.second.TheKind);
3390 if (ResByArg.second.TheKind ==
3392 ResByArg.second.TheKind ==
3394 Out << ", info: " << ResByArg.second.Info;
3395
3396 // The following fields are only used if the target does not support the
3397 // use of absolute symbols to store constants. Print only if non-zero.
3398 if (ResByArg.second.Byte || ResByArg.second.Bit)
3399 Out << ", byte: " << ResByArg.second.Byte
3400 << ", bit: " << ResByArg.second.Bit;
3401
3402 Out << ")";
3403 }
3404 Out << ")";
3405 }
3406 Out << ")";
3407}
3408
3410 switch (SK) {
3412 return "alias";
3414 return "function";
3416 return "variable";
3417 }
3418 llvm_unreachable("invalid summary kind");
3419}
3420
3421void AssemblyWriter::printAliasSummary(const AliasSummary *AS) {
3422 Out << ", aliasee: ";
3423 // The indexes emitted for distributed backends may not include the
3424 // aliasee summary (only if it is being imported directly). Handle
3425 // that case by just emitting "null" as the aliasee.
3426 if (AS->hasAliasee())
3427 Out << "^" << Machine.getGUIDSlot(SummaryToGUIDMap[&AS->getAliasee()]);
3428 else
3429 Out << "null";
3430}
3431
3432void AssemblyWriter::printGlobalVarSummary(const GlobalVarSummary *GS) {
3433 auto VTableFuncs = GS->vTableFuncs();
3434 Out << ", varFlags: (readonly: " << GS->VarFlags.MaybeReadOnly << ", "
3435 << "writeonly: " << GS->VarFlags.MaybeWriteOnly << ", "
3436 << "constant: " << GS->VarFlags.Constant;
3437 if (!VTableFuncs.empty())
3438 Out << ", "
3439 << "vcall_visibility: " << GS->VarFlags.VCallVisibility;
3440 Out << ")";
3441
3442 if (!VTableFuncs.empty()) {
3443 Out << ", vTableFuncs: (";
3444 ListSeparator FS;
3445 for (auto &P : VTableFuncs) {
3446 Out << FS;
3447 Out << "(virtFunc: ^" << Machine.getGUIDSlot(P.FuncVI.getGUID())
3448 << ", offset: " << P.VTableOffset;
3449 Out << ")";
3450 }
3451 Out << ")";
3452 }
3453}
3454
3456 switch (LT) {
3458 return "external";
3460 return "private";
3462 return "internal";
3464 return "linkonce";
3466 return "linkonce_odr";
3468 return "weak";
3470 return "weak_odr";
3472 return "common";
3474 return "appending";
3476 return "extern_weak";
3478 return "available_externally";
3479 }
3480 llvm_unreachable("invalid linkage");
3481}
3482
3483// When printing the linkage types in IR where the ExternalLinkage is
3484// not printed, and other linkage types are expected to be printed with
3485// a space after the name.
3488 return "";
3489 return getLinkageName(LT) + " ";
3490}
3491
3493 switch (Vis) {
3495 return "default";
3497 return "hidden";
3499 return "protected";
3500 }
3501 llvm_unreachable("invalid visibility");
3502}
3503
3505 switch (IK) {
3507 return "definition";
3509 return "declaration";
3510 }
3511 llvm_unreachable("invalid import kind");
3512}
3513
3514void AssemblyWriter::printFunctionSummary(const FunctionSummary *FS) {
3515 Out << ", insts: " << FS->instCount();
3516 if (FS->fflags().anyFlagSet())
3517 Out << ", " << FS->fflags();
3518
3519 if (!FS->calls().empty()) {
3520 Out << ", calls: (";
3521 ListSeparator IFS;
3522 for (auto &Call : FS->calls()) {
3523 Out << IFS;
3524 Out << "(callee: ^" << Machine.getGUIDSlot(Call.first.getGUID());
3525 if (Call.second.getHotness() != CalleeInfo::HotnessType::Unknown)
3526 Out << ", hotness: " << getHotnessName(Call.second.getHotness());
3527 // Follow the convention of emitting flags as a boolean value, but only
3528 // emit if true to avoid unnecessary verbosity and test churn.
3529 if (Call.second.HasTailCall)
3530 Out << ", tail: 1";
3531 Out << ")";
3532 }
3533 Out << ")";
3534 }
3535
3536 if (const auto *TIdInfo = FS->getTypeIdInfo())
3537 printTypeIdInfo(*TIdInfo);
3538
3539 // The AllocationType identifiers capture the profiled context behavior
3540 // reaching a specific static allocation site (possibly cloned).
3541 auto AllocTypeName = [](uint8_t Type) -> const char * {
3542 switch (Type) {
3543 case (uint8_t)AllocationType::None:
3544 return "none";
3545 case (uint8_t)AllocationType::NotCold:
3546 return "notcold";
3547 case (uint8_t)AllocationType::Cold:
3548 return "cold";
3549 case (uint8_t)AllocationType::Hot:
3550 return "hot";
3551 }
3552 llvm_unreachable("Unexpected alloc type");
3553 };
3554
3555 if (!FS->allocs().empty()) {
3556 Out << ", allocs: (";
3557 ListSeparator AFS;
3558 for (auto &AI : FS->allocs()) {
3559 Out << AFS;
3560 Out << "(versions: (";
3561 ListSeparator VFS;
3562 for (auto V : AI.Versions) {
3563 Out << VFS;
3564 Out << AllocTypeName(V);
3565 }
3566 Out << "), memProf: (";
3567 ListSeparator MIBFS;
3568 for (auto &MIB : AI.MIBs) {
3569 Out << MIBFS;
3570 Out << "(type: " << AllocTypeName((uint8_t)MIB.AllocType);
3571 Out << ", stackIds: (";
3572 ListSeparator SIDFS;
3573 for (auto Id : MIB.StackIdIndices) {
3574 Out << SIDFS;
3575 Out << TheIndex->getStackIdAtIndex(Id);
3576 }
3577 Out << "))";
3578 }
3579 Out << "))";
3580 }
3581 Out << ")";
3582 }
3583
3584 if (!FS->callsites().empty()) {
3585 Out << ", callsites: (";
3586 ListSeparator SNFS;
3587 for (auto &CI : FS->callsites()) {
3588 Out << SNFS;
3589 if (CI.Callee)
3590 Out << "(callee: ^" << Machine.getGUIDSlot(CI.Callee.getGUID());
3591 else
3592 Out << "(callee: null";
3593 Out << ", clones: (";
3594 ListSeparator VFS;
3595 for (auto V : CI.Clones) {
3596 Out << VFS;
3597 Out << V;
3598 }
3599 Out << "), stackIds: (";
3600 ListSeparator SIDFS;
3601 for (auto Id : CI.StackIdIndices) {
3602 Out << SIDFS;
3603 Out << TheIndex->getStackIdAtIndex(Id);
3604 }
3605 Out << "))";
3606 }
3607 Out << ")";
3608 }
3609
3610 auto PrintRange = [&](const ConstantRange &Range) {
3611 Out << "[" << Range.getSignedMin() << ", " << Range.getSignedMax() << "]";
3612 };
3613
3614 if (!FS->paramAccesses().empty()) {
3615 Out << ", params: (";
3616 ListSeparator IFS;
3617 for (auto &PS : FS->paramAccesses()) {
3618 Out << IFS;
3619 Out << "(param: " << PS.ParamNo;
3620 Out << ", offset: ";
3621 PrintRange(PS.Use);
3622 if (!PS.Calls.empty()) {
3623 Out << ", calls: (";
3624 ListSeparator IFS;
3625 for (auto &Call : PS.Calls) {
3626 Out << IFS;
3627 Out << "(callee: ^" << Machine.getGUIDSlot(Call.Callee.getGUID());
3628 Out << ", param: " << Call.ParamNo;
3629 Out << ", offset: ";
3630 PrintRange(Call.Offsets);
3631 Out << ")";
3632 }
3633 Out << ")";
3634 }
3635 Out << ")";
3636 }
3637 Out << ")";
3638 }
3639}
3640
3641void AssemblyWriter::printTypeIdInfo(
3642 const FunctionSummary::TypeIdInfo &TIDInfo) {
3643 Out << ", typeIdInfo: (";
3644 ListSeparator TIDFS;
3645 if (!TIDInfo.TypeTests.empty()) {
3646 Out << TIDFS;
3647 Out << "typeTests: (";
3648 ListSeparator FS;
3649 for (auto &GUID : TIDInfo.TypeTests) {
3650 auto TidIter = TheIndex->typeIds().equal_range(GUID);
3651 if (TidIter.first == TidIter.second) {
3652 Out << FS;
3653 Out << GUID;
3654 continue;
3655 }
3656 // Print all type id that correspond to this GUID.
3657 for (const auto &[GUID, TypeIdPair] : make_range(TidIter)) {
3658 Out << FS;
3659 auto Slot = Machine.getTypeIdSlot(TypeIdPair.first);
3660 assert(Slot != -1);
3661 Out << "^" << Slot;
3662 }
3663 }
3664 Out << ")";
3665 }
3666 if (!TIDInfo.TypeTestAssumeVCalls.empty()) {
3667 Out << TIDFS;
3668 printNonConstVCalls(TIDInfo.TypeTestAssumeVCalls, "typeTestAssumeVCalls");
3669 }
3670 if (!TIDInfo.TypeCheckedLoadVCalls.empty()) {
3671 Out << TIDFS;
3672 printNonConstVCalls(TIDInfo.TypeCheckedLoadVCalls, "typeCheckedLoadVCalls");
3673 }
3674 if (!TIDInfo.TypeTestAssumeConstVCalls.empty()) {
3675 Out << TIDFS;
3676 printConstVCalls(TIDInfo.TypeTestAssumeConstVCalls,
3677 "typeTestAssumeConstVCalls");
3678 }
3679 if (!TIDInfo.TypeCheckedLoadConstVCalls.empty()) {
3680 Out << TIDFS;
3681 printConstVCalls(TIDInfo.TypeCheckedLoadConstVCalls,
3682 "typeCheckedLoadConstVCalls");
3683 }
3684 Out << ")";
3685}
3686
3687void AssemblyWriter::printVFuncId(const FunctionSummary::VFuncId VFId) {
3688 auto TidIter = TheIndex->typeIds().equal_range(VFId.GUID);
3689 if (TidIter.first == TidIter.second) {
3690 Out << "vFuncId: (";
3691 Out << "guid: " << VFId.GUID;
3692 Out << ", offset: " << VFId.Offset;
3693 Out << ")";
3694 return;
3695 }
3696 // Print all type id that correspond to this GUID.
3697 ListSeparator FS;
3698 for (const auto &[GUID, TypeIdPair] : make_range(TidIter)) {
3699 Out << FS;
3700 Out << "vFuncId: (";
3701 auto Slot = Machine.getTypeIdSlot(TypeIdPair.first);
3702 assert(Slot != -1);
3703 Out << "^" << Slot;
3704 Out << ", offset: " << VFId.Offset;
3705 Out << ")";
3706 }
3707}
3708
3709void AssemblyWriter::printNonConstVCalls(
3710 ArrayRef<FunctionSummary::VFuncId> VCallList, const char *Tag) {
3711 Out << Tag << ": (";
3712 ListSeparator FS;
3713 for (auto &VFuncId : VCallList) {
3714 Out << FS;
3715 printVFuncId(VFuncId);
3716 }
3717 Out << ")";
3718}
3719
3720void AssemblyWriter::printConstVCalls(
3721 ArrayRef<FunctionSummary::ConstVCall> VCallList, const char *Tag) {
3722 Out << Tag << ": (";
3723 ListSeparator FS;
3724 for (auto &ConstVCall : VCallList) {
3725 Out << FS;
3726 Out << "(";
3727 printVFuncId(ConstVCall.VFunc);
3728 if (!ConstVCall.Args.empty()) {
3729 Out << ", ";
3730 printArgs(ConstVCall.Args);
3731 }
3732 Out << ")";
3733 }
3734 Out << ")";
3735}
3736
3737void AssemblyWriter::printSummary(const GlobalValueSummary &Summary) {
3738 GlobalValueSummary::GVFlags GVFlags = Summary.flags();
3740 Out << getSummaryKindName(Summary.getSummaryKind()) << ": ";
3741 Out << "(module: ^" << Machine.getModulePathSlot(Summary.modulePath())
3742 << ", flags: (";
3743 Out << "linkage: " << getLinkageName(LT);
3744 Out << ", visibility: "
3746 Out << ", notEligibleToImport: " << GVFlags.NotEligibleToImport;
3747 Out << ", live: " << GVFlags.Live;
3748 Out << ", dsoLocal: " << GVFlags.DSOLocal;
3749 Out << ", canAutoHide: " << GVFlags.CanAutoHide;
3750 Out << ", importType: "
3752 Out << ", noRenameOnPromotion: " << GVFlags.NoRenameOnPromotion;
3753 Out << ")";
3754
3755 if (Summary.getSummaryKind() == GlobalValueSummary::AliasKind)
3756 printAliasSummary(cast<AliasSummary>(&Summary));
3757 else if (Summary.getSummaryKind() == GlobalValueSummary::FunctionKind)
3758 printFunctionSummary(cast<FunctionSummary>(&Summary));
3759 else
3760 printGlobalVarSummary(cast<GlobalVarSummary>(&Summary));
3761
3762 auto RefList = Summary.refs();
3763 if (!RefList.empty()) {
3764 Out << ", refs: (";
3765 ListSeparator FS;
3766 for (auto &Ref : RefList) {
3767 Out << FS;
3768 if (Ref.isReadOnly())
3769 Out << "readonly ";
3770 else if (Ref.isWriteOnly())
3771 Out << "writeonly ";
3772 Out << "^" << Machine.getGUIDSlot(Ref.getGUID());
3773 }
3774 Out << ")";
3775 }
3776
3777 Out << ")";
3778}
3779
3780void AssemblyWriter::printSummaryInfo(unsigned Slot, const ValueInfo &VI) {
3781 Out << "^" << Slot << " = gv: (";
3782 if (VI.hasName() && !VI.name().empty())
3783 Out << "name: \"" << VI.name() << "\"";
3784 else
3785 Out << "guid: " << VI.getGUID();
3786 if (!VI.getSummaryList().empty()) {
3787 Out << ", summaries: (";
3788 ListSeparator FS;
3789 for (auto &Summary : VI.getSummaryList()) {
3790 Out << FS;
3791 printSummary(*Summary);
3792 }
3793 Out << ")";
3794 }
3795 Out << ")";
3796 if (VI.hasName() && !VI.name().empty())
3797 Out << " ; guid = " << VI.getGUID();
3798 Out << "\n";
3799}
3800
3802 formatted_raw_ostream &Out) {
3803 if (Name.empty()) {
3804 Out << "<empty name> ";
3805 } else {
3806 unsigned char FirstC = static_cast<unsigned char>(Name[0]);
3807 if (isalpha(FirstC) || FirstC == '-' || FirstC == '$' || FirstC == '.' ||
3808 FirstC == '_')
3809 Out << FirstC;
3810 else
3811 Out << '\\' << hexdigit(FirstC >> 4) << hexdigit(FirstC & 0x0F);
3812 for (unsigned i = 1, e = Name.size(); i != e; ++i) {
3813 unsigned char C = Name[i];
3814 if (isalnum(C) || C == '-' || C == '$' || C == '.' || C == '_')
3815 Out << C;
3816 else
3817 Out << '\\' << hexdigit(C >> 4) << hexdigit(C & 0x0F);
3818 }
3819 }
3820}
3821
3822void AssemblyWriter::printNamedMDNode(const NamedMDNode *NMD) {
3823 Out << '!';
3824 printMetadataIdentifier(NMD->getName(), Out);
3825 Out << " = !{";
3826 ListSeparator LS;
3827 for (const MDNode *Op : NMD->operands()) {
3828 Out << LS;
3829 // Write DIExpressions inline.
3830 // FIXME: Ban DIExpressions in NamedMDNodes, they will serve no purpose.
3831 if (auto *Expr = dyn_cast<DIExpression>(Op)) {
3832 writeDIExpression(Out, Expr, AsmWriterContext::getEmpty());
3833 continue;
3834 }
3835
3836 int Slot = Machine.getMetadataSlot(Op);
3837 if (Slot == -1)
3838 Out << "<badref>";
3839 else
3840 Out << '!' << Slot;
3841 }
3842 Out << "}\n";
3843}
3844
3846 formatted_raw_ostream &Out) {
3847 switch (Vis) {
3849 case GlobalValue::HiddenVisibility: Out << "hidden "; break;
3850 case GlobalValue::ProtectedVisibility: Out << "protected "; break;
3851 }
3852}
3853
3854static void printDSOLocation(const GlobalValue &GV,
3855 formatted_raw_ostream &Out) {
3856 if (GV.isDSOLocal() && !GV.isImplicitDSOLocal())
3857 Out << "dso_local ";
3858}
3859
3861 formatted_raw_ostream &Out) {
3862 switch (SCT) {
3864 case GlobalValue::DLLImportStorageClass: Out << "dllimport "; break;
3865 case GlobalValue::DLLExportStorageClass: Out << "dllexport "; break;
3866 }
3867}
3868
3870 formatted_raw_ostream &Out) {
3871 switch (TLM) {
3873 break;
3875 Out << "thread_local ";
3876 break;
3878 Out << "thread_local(localdynamic) ";
3879 break;
3881 Out << "thread_local(initialexec) ";
3882 break;
3884 Out << "thread_local(localexec) ";
3885 break;
3886 }
3887}
3888
3890 switch (UA) {
3892 return "";
3894 return "local_unnamed_addr";
3896 return "unnamed_addr";
3897 }
3898 llvm_unreachable("Unknown UnnamedAddr");
3899}
3900
3902 const GlobalObject &GO) {
3903 const Comdat *C = GO.getComdat();
3904 if (!C)
3905 return;
3906
3907 if (isa<GlobalVariable>(GO))
3908 Out << ',';
3909 Out << " comdat";
3910
3911 if (GO.getName() == C->getName())
3912 return;
3913
3914 Out << '(';
3915 printLLVMName(Out, C->getName(), ComdatPrefix);
3916 Out << ')';
3917}
3918
3919void AssemblyWriter::printGlobal(const GlobalVariable *GV) {
3920 if (GV->isMaterializable())
3921 Out << "; Materializable\n";
3922
3923 AsmWriterContext WriterCtx(&TypePrinter, &Machine, GV->getParent());
3924 writeAsOperandInternal(Out, GV, WriterCtx);
3925 Out << " = ";
3926
3927 if (!GV->hasInitializer() && GV->hasExternalLinkage())
3928 Out << "external ";
3929
3930 Out << getLinkageNameWithSpace(GV->getLinkage());
3931 printDSOLocation(*GV, Out);
3932 printVisibility(GV->getVisibility(), Out);
3935 StringRef UA = getUnnamedAddrEncoding(GV->getUnnamedAddr());
3936 if (!UA.empty())
3937 Out << UA << ' ';
3938
3940 /*Prefix=*/"", /*Suffix=*/" ");
3941 if (GV->isExternallyInitialized()) Out << "externally_initialized ";
3942 Out << (GV->isConstant() ? "constant " : "global ");
3943 TypePrinter.print(GV->getValueType(), Out);
3944
3945 if (GV->hasInitializer()) {
3946 Out << ' ';
3947 writeOperand(GV->getInitializer(), false);
3948 }
3949
3950 if (GV->hasSection()) {
3951 Out << ", section \"";
3952 printEscapedString(GV->getSection(), Out);
3953 Out << '"';
3954 }
3955 if (GV->hasPartition()) {
3956 Out << ", partition \"";
3957 printEscapedString(GV->getPartition(), Out);
3958 Out << '"';
3959 }
3960 if (auto CM = GV->getCodeModel()) {
3961 Out << ", code_model \"";
3962 switch (*CM) {
3963 case CodeModel::Tiny:
3964 Out << "tiny";
3965 break;
3966 case CodeModel::Small:
3967 Out << "small";
3968 break;
3969 case CodeModel::Kernel:
3970 Out << "kernel";
3971 break;
3972 case CodeModel::Medium:
3973 Out << "medium";
3974 break;
3975 case CodeModel::Large:
3976 Out << "large";
3977 break;
3978 }
3979 Out << '"';
3980 }
3981
3982 using SanitizerMetadata = llvm::GlobalValue::SanitizerMetadata;
3983 if (GV->hasSanitizerMetadata()) {
3985 if (MD.NoAddress)
3986 Out << ", no_sanitize_address";
3987 if (MD.NoHWAddress)
3988 Out << ", no_sanitize_hwaddress";
3989 if (MD.Memtag)
3990 Out << ", sanitize_memtag";
3991 if (MD.IsDynInit)
3992 Out << ", sanitize_address_dyninit";
3993 }
3994
3995 maybePrintComdat(Out, *GV);
3996 if (MaybeAlign A = GV->getAlign())
3997 Out << ", align " << A->value();
3998
4000 GV->getAllMetadata(MDs);
4001 printMetadataAttachments(MDs, ", ");
4002
4003 auto Attrs = GV->getAttributes();
4004 if (Attrs.hasAttributes())
4005 Out << " #" << Machine.getAttributeGroupSlot(Attrs);
4006
4007 printInfoComment(*GV, GV->isMaterializable());
4008}
4009
4010void AssemblyWriter::printAlias(const GlobalAlias *GA) {
4011 if (GA->isMaterializable())
4012 Out << "; Materializable\n";
4013
4014 AsmWriterContext WriterCtx(&TypePrinter, &Machine, GA->getParent());
4015 writeAsOperandInternal(Out, GA, WriterCtx);
4016 Out << " = ";
4017
4018 Out << getLinkageNameWithSpace(GA->getLinkage());
4019 printDSOLocation(*GA, Out);
4020 printVisibility(GA->getVisibility(), Out);
4023 StringRef UA = getUnnamedAddrEncoding(GA->getUnnamedAddr());
4024 if (!UA.empty())
4025 Out << UA << ' ';
4026
4027 Out << "alias ";
4028
4029 TypePrinter.print(GA->getValueType(), Out);
4030 Out << ", ";
4031
4032 if (const Constant *Aliasee = GA->getAliasee()) {
4033 writeOperand(Aliasee, !isa<ConstantExpr>(Aliasee));
4034 } else {
4035 TypePrinter.print(GA->getType(), Out);
4036 Out << " <<NULL ALIASEE>>";
4037 }
4038
4039 if (GA->hasPartition()) {
4040 Out << ", partition \"";
4041 printEscapedString(GA->getPartition(), Out);
4042 Out << '"';
4043 }
4044
4045 printInfoComment(*GA, GA->isMaterializable());
4046 Out << '\n';
4047}
4048
4049void AssemblyWriter::printIFunc(const GlobalIFunc *GI) {
4050 if (GI->isMaterializable())
4051 Out << "; Materializable\n";
4052
4053 AsmWriterContext WriterCtx(&TypePrinter, &Machine, GI->getParent());
4054 writeAsOperandInternal(Out, GI, WriterCtx);
4055 Out << " = ";
4056
4057 Out << getLinkageNameWithSpace(GI->getLinkage());
4058 printDSOLocation(*GI, Out);
4059 printVisibility(GI->getVisibility(), Out);
4060
4061 Out << "ifunc ";
4062
4063 TypePrinter.print(GI->getValueType(), Out);
4064 Out << ", ";
4065
4066 if (const Constant *Resolver = GI->getResolver()) {
4067 writeOperand(Resolver, !isa<ConstantExpr>(Resolver));
4068 } else {
4069 TypePrinter.print(GI->getType(), Out);
4070 Out << " <<NULL RESOLVER>>";
4071 }
4072
4073 if (GI->hasPartition()) {
4074 Out << ", partition \"";
4075 printEscapedString(GI->getPartition(), Out);
4076 Out << '"';
4077 }
4079 GI->getAllMetadata(MDs);
4080 if (!MDs.empty()) {
4081 printMetadataAttachments(MDs, ", ");
4082 }
4083
4084 printInfoComment(*GI, GI->isMaterializable());
4085 Out << '\n';
4086}
4087
4088void AssemblyWriter::printComdat(const Comdat *C) {
4089 C->print(Out);
4090}
4091
4092void AssemblyWriter::printTypeIdentities() {
4093 if (TypePrinter.empty())
4094 return;
4095
4096 Out << '\n';
4097
4098 // Emit all numbered types.
4099 auto &NumberedTypes = TypePrinter.getNumberedTypes();
4100 for (unsigned I = 0, E = NumberedTypes.size(); I != E; ++I) {
4101 Out << '%' << I << " = type ";
4102
4103 // Make sure we print out at least one level of the type structure, so
4104 // that we do not get %2 = type %2
4105 TypePrinter.printStructBody(NumberedTypes[I], Out);
4106 Out << '\n';
4107 }
4108
4109 auto &NamedTypes = TypePrinter.getNamedTypes();
4110 for (StructType *NamedType : NamedTypes) {
4111 printLLVMName(Out, NamedType->getName(), LocalPrefix);
4112 Out << " = type ";
4113
4114 // Make sure we print out at least one level of the type structure, so
4115 // that we do not get %FILE = type %FILE
4116 TypePrinter.printStructBody(NamedType, Out);
4117 Out << '\n';
4118 }
4119}
4120
4121/// printFunction - Print all aspects of a function.
4122void AssemblyWriter::printFunction(const Function *F) {
4123 if (F->isMaterializable())
4124 Out << "; Materializable\n";
4125 else if (AnnotationWriter)
4126 AnnotationWriter->emitFunctionAnnot(F, Out);
4127
4128 const AttributeList &Attrs = F->getAttributes();
4129 if (Attrs.hasFnAttrs()) {
4130 AttributeSet AS = Attrs.getFnAttrs();
4131 std::string AttrStr;
4132
4133 for (const Attribute &Attr : AS) {
4134 if (!Attr.isStringAttribute()) {
4135 if (!AttrStr.empty()) AttrStr += ' ';
4136 AttrStr += Attr.getAsString();
4137 }
4138 }
4139
4140 if (!AttrStr.empty())
4141 Out << "; Function Attrs: " << AttrStr << '\n';
4142 }
4143
4144 if (F->isIntrinsic() && F->getIntrinsicID() == Intrinsic::not_intrinsic)
4145 Out << "; Unknown intrinsic\n";
4146
4147 Machine.incorporateFunction(F);
4148
4149 if (F->isDeclaration()) {
4150 Out << "declare";
4152 F->getAllMetadata(MDs);
4153 printMetadataAttachments(MDs, " ");
4154 Out << ' ';
4155 } else
4156 Out << "define ";
4157
4158 Out << getLinkageNameWithSpace(F->getLinkage());
4159 printDSOLocation(*F, Out);
4160 printVisibility(F->getVisibility(), Out);
4161 printDLLStorageClass(F->getDLLStorageClass(), Out);
4162
4163 // Print the calling convention.
4164 if (F->getCallingConv() != CallingConv::C) {
4165 printCallingConv(F->getCallingConv(), Out);
4166 Out << " ";
4167 }
4168
4169 FunctionType *FT = F->getFunctionType();
4170 if (Attrs.hasRetAttrs())
4171 Out << Attrs.getAsString(AttributeList::ReturnIndex) << ' ';
4172 TypePrinter.print(F->getReturnType(), Out);
4173 AsmWriterContext WriterCtx(&TypePrinter, &Machine, F->getParent());
4174 Out << ' ';
4175 writeAsOperandInternal(Out, F, WriterCtx);
4176 Out << '(';
4177
4178 // Loop over the arguments, printing them...
4179 if (F->isDeclaration() && !IsForDebug) {
4180 // We're only interested in the type here - don't print argument names.
4181 ListSeparator LS;
4182 for (unsigned I = 0, E = FT->getNumParams(); I != E; ++I) {
4183 Out << LS;
4184 // Output type.
4185 TypePrinter.print(FT->getParamType(I), Out);
4186
4187 AttributeSet ArgAttrs = Attrs.getParamAttrs(I);
4188 if (ArgAttrs.hasAttributes()) {
4189 Out << ' ';
4190 writeAttributeSet(ArgAttrs);
4191 }
4192 }
4193 } else {
4194 // The arguments are meaningful here, print them in detail.
4195 ListSeparator LS;
4196 for (const Argument &Arg : F->args()) {
4197 Out << LS;
4198 printArgument(&Arg, Attrs.getParamAttrs(Arg.getArgNo()));
4199 }
4200 }
4201
4202 // Finish printing arguments...
4203 if (FT->isVarArg()) {
4204 if (FT->getNumParams()) Out << ", ";
4205 Out << "..."; // Output varargs portion of signature!
4206 }
4207 Out << ')';
4208 StringRef UA = getUnnamedAddrEncoding(F->getUnnamedAddr());
4209 if (!UA.empty())
4210 Out << ' ' << UA;
4211 // We print the function address space if it is non-zero or if we are writing
4212 // a module with a non-zero program address space or if there is no valid
4213 // Module* so that the file can be parsed without the datalayout string.
4214 const Module *Mod = F->getParent();
4215 bool ForcePrintAddressSpace =
4216 !Mod || Mod->getDataLayout().getProgramAddressSpace() != 0;
4217 printAddressSpace(Mod, F->getAddressSpace(), Out, /*Prefix=*/" ",
4218 /*Suffix=*/"", ForcePrintAddressSpace);
4219 if (Attrs.hasFnAttrs())
4220 Out << " #" << Machine.getAttributeGroupSlot(Attrs.getFnAttrs());
4221 if (F->hasSection()) {
4222 Out << " section \"";
4223 printEscapedString(F->getSection(), Out);
4224 Out << '"';
4225 }
4226 if (F->hasPartition()) {
4227 Out << " partition \"";
4228 printEscapedString(F->getPartition(), Out);
4229 Out << '"';
4230 }
4231 maybePrintComdat(Out, *F);
4232 if (MaybeAlign A = F->getAlign())
4233 Out << " align " << A->value();
4234 if (MaybeAlign A = F->getPreferredAlignment())
4235 Out << " prefalign(" << A->value() << ')';
4236 if (F->hasGC())
4237 Out << " gc \"" << F->getGC() << '"';
4238 if (F->hasPrefixData()) {
4239 Out << " prefix ";
4240 writeOperand(F->getPrefixData(), true);
4241 }
4242 if (F->hasPrologueData()) {
4243 Out << " prologue ";
4244 writeOperand(F->getPrologueData(), true);
4245 }
4246 if (F->hasPersonalityFn()) {
4247 Out << " personality ";
4248 writeOperand(F->getPersonalityFn(), /*PrintType=*/true);
4249 }
4250
4251 if (PrintProfData) {
4252 if (auto *MDProf = F->getMetadata(LLVMContext::MD_prof)) {
4253 Out << " ";
4254 MDProf->print(Out, TheModule, /*IsForDebug=*/true);
4255 }
4256 }
4257
4258 if (F->isDeclaration()) {
4259 Out << '\n';
4260 } else {
4262 F->getAllMetadata(MDs);
4263 printMetadataAttachments(MDs, " ");
4264
4265 Out << " {";
4266 // Output all of the function's basic blocks.
4267 for (const BasicBlock &BB : *F)
4268 printBasicBlock(&BB);
4269
4270 // Output the function's use-lists.
4271 printUseLists(F);
4272
4273 Out << "}\n";
4274 }
4275
4276 Machine.purgeFunction();
4277}
4278
4279/// printArgument - This member is called for every argument that is passed into
4280/// the function. Simply print it out
4281void AssemblyWriter::printArgument(const Argument *Arg, AttributeSet Attrs) {
4282 // Output type...
4283 TypePrinter.print(Arg->getType(), Out);
4284
4285 // Output parameter attributes list
4286 if (Attrs.hasAttributes()) {
4287 Out << ' ';
4288 writeAttributeSet(Attrs);
4289 }
4290
4291 // Output name, if available...
4292 if (Arg->hasName()) {
4293 Out << ' ';
4294 printLLVMName(Out, Arg);
4295 } else {
4296 int Slot = Machine.getLocalSlot(Arg);
4297 assert(Slot != -1 && "expect argument in function here");
4298 Out << " %" << Slot;
4299 }
4300}
4301
4302/// printBasicBlock - This member is called for each basic block in a method.
4303void AssemblyWriter::printBasicBlock(const BasicBlock *BB) {
4304 bool IsEntryBlock = BB->getParent() && BB->isEntryBlock();
4305 if (BB->hasName()) { // Print out the label if it exists...
4306 Out << "\n";
4307 printLLVMName(Out, BB->getName(), LabelPrefix);
4308 Out << ':';
4309 } else if (!IsEntryBlock) {
4310 Out << "\n";
4311 int Slot = Machine.getLocalSlot(BB);
4312 if (Slot != -1)
4313 Out << Slot << ":";
4314 else
4315 Out << "<badref>:";
4316 }
4317
4318 if (!IsEntryBlock) {
4319 // Output predecessors for the block.
4320 Out.PadToColumn(50);
4321 Out << ";";
4322 if (pred_empty(BB)) {
4323 Out << " No predecessors!";
4324 } else {
4325 Out << " preds = ";
4326 ListSeparator LS;
4327 for (const BasicBlock *Pred : predecessors(BB)) {
4328 Out << LS;
4329 writeOperand(Pred, false);
4330 }
4331 }
4332 }
4333
4334 Out << "\n";
4335
4336 if (AnnotationWriter) AnnotationWriter->emitBasicBlockStartAnnot(BB, Out);
4337
4338 // Output all of the instructions in the basic block...
4339 for (const Instruction &I : *BB) {
4340 for (const DbgRecord &DR : I.getDbgRecordRange())
4341 printDbgRecordLine(DR);
4342 printInstructionLine(I);
4343 }
4344
4345 if (AnnotationWriter) AnnotationWriter->emitBasicBlockEndAnnot(BB, Out);
4346}
4347
4348/// printInstructionLine - Print an instruction and a newline character.
4349void AssemblyWriter::printInstructionLine(const Instruction &I) {
4350 printInstruction(I);
4351 Out << '\n';
4352}
4353
4354/// printGCRelocateComment - print comment after call to the gc.relocate
4355/// intrinsic indicating base and derived pointer names.
4356void AssemblyWriter::printGCRelocateComment(const GCRelocateInst &Relocate) {
4357 Out << " ; (";
4358 writeOperand(Relocate.getBasePtr(), false);
4359 Out << ", ";
4360 writeOperand(Relocate.getDerivedPtr(), false);
4361 Out << ")";
4362}
4363
4364/// printInfoComment - Print a little comment after the instruction indicating
4365/// which slot it occupies.
4366void AssemblyWriter::printInfoComment(const Value &V, bool isMaterializable) {
4367 if (const auto *Relocate = dyn_cast<GCRelocateInst>(&V))
4368 printGCRelocateComment(*Relocate);
4369
4370 if (AnnotationWriter && !isMaterializable)
4371 AnnotationWriter->printInfoComment(V, Out);
4372
4373 if (PrintInstDebugLocs) {
4374 if (auto *I = dyn_cast<Instruction>(&V)) {
4375 if (I->getDebugLoc()) {
4376 Out << " ; ";
4377 I->getDebugLoc().print(Out);
4378 }
4379 }
4380 }
4381 if (PrintProfData) {
4382 if (auto *I = dyn_cast<Instruction>(&V)) {
4383 if (auto *MD = I->getMetadata(LLVMContext::MD_prof)) {
4384 Out << " ; ";
4385 MD->print(Out, TheModule, /*IsForDebug=*/true);
4386 }
4387 }
4388 }
4389
4390 if (PrintInstAddrs)
4391 Out << " ; " << &V;
4392}
4393
4394static void maybePrintCallAddrSpace(const Value *Operand, const Instruction *I,
4395 raw_ostream &Out) {
4396 if (Operand == nullptr) {
4397 Out << " <cannot get addrspace!>";
4398 return;
4399 }
4400
4401 // We print the address space of the call if it is non-zero.
4402 // We also print it if it is zero but not equal to the program address space
4403 // or if we can't find a valid Module* to make it possible to parse
4404 // the resulting file even without a datalayout string.
4405 unsigned CallAddrSpace = Operand->getType()->getPointerAddressSpace();
4406 const Module *Mod = getModuleFromVal(I);
4407 bool ForcePrintAddrSpace =
4408 !Mod || Mod->getDataLayout().getProgramAddressSpace() != 0;
4409 printAddressSpace(Mod, CallAddrSpace, Out, /*Prefix=*/" ", /*Suffix=*/"",
4410 ForcePrintAddrSpace);
4411}
4412
4413// This member is called for each Instruction in a function..
4414void AssemblyWriter::printInstruction(const Instruction &I) {
4415 if (AnnotationWriter) AnnotationWriter->emitInstructionAnnot(&I, Out);
4416
4417 // Print out indentation for an instruction.
4418 Out << " ";
4419
4420 // Print out name if it exists...
4421 if (I.hasName()) {
4422 printLLVMName(Out, &I);
4423 Out << " = ";
4424 } else if (!I.getType()->isVoidTy()) {
4425 // Print out the def slot taken.
4426 int SlotNum = Machine.getLocalSlot(&I);
4427 if (SlotNum == -1)
4428 Out << "<badref> = ";
4429 else
4430 Out << '%' << SlotNum << " = ";
4431 }
4432
4433 if (const auto *CI = dyn_cast<CallInst>(&I)) {
4434 if (CI->isMustTailCall())
4435 Out << "musttail ";
4436 else if (CI->isTailCall())
4437 Out << "tail ";
4438 else if (CI->isNoTailCall())
4439 Out << "notail ";
4440 }
4441
4442 // Print out the opcode...
4443 Out << I.getOpcodeName();
4444
4445 // If this is an atomic load or store, print out the atomic marker.
4446 if ((isa<LoadInst>(I) && cast<LoadInst>(I).isAtomic()) ||
4448 Out << " atomic";
4449
4451 Out << " weak";
4452
4453 // If this is a volatile operation, print out the volatile marker.
4454 if ((isa<LoadInst>(I) && cast<LoadInst>(I).isVolatile()) ||
4455 (isa<StoreInst>(I) && cast<StoreInst>(I).isVolatile()) ||
4456 (isa<AtomicCmpXchgInst>(I) && cast<AtomicCmpXchgInst>(I).isVolatile()) ||
4457 (isa<AtomicRMWInst>(I) && cast<AtomicRMWInst>(I).isVolatile()))
4458 Out << " volatile";
4459
4460 // Print out optimization information.
4461 writeOptimizationInfo(Out, &I);
4462
4463 // Print out the compare instruction predicates
4464 if (const auto *CI = dyn_cast<CmpInst>(&I))
4465 Out << ' ' << CI->getPredicate();
4466
4467 // Print out the atomicrmw operation
4468 if (const auto *RMWI = dyn_cast<AtomicRMWInst>(&I)) {
4469 if (RMWI->isElementwise())
4470 Out << " elementwise";
4471 Out << ' ' << AtomicRMWInst::getOperationName(RMWI->getOperation());
4472 }
4473
4474 // Print out the type of the operands...
4475 const Value *Operand = I.getNumOperands() ? I.getOperand(0) : nullptr;
4476
4477 // Special case conditional branches to swizzle the condition out to the front
4478 if (const auto *BI = dyn_cast<CondBrInst>(&I)) {
4479 Out << ' ';
4480 writeOperand(BI->getCondition(), true);
4481 Out << ", ";
4482 writeOperand(BI->getSuccessor(0), true);
4483 Out << ", ";
4484 writeOperand(BI->getSuccessor(1), true);
4485 } else if (isa<SwitchInst>(I)) {
4486 const SwitchInst& SI(cast<SwitchInst>(I));
4487 // Special case switch instruction to get formatting nice and correct.
4488 Out << ' ';
4489 writeOperand(SI.getCondition(), true);
4490 Out << ", ";
4491 writeOperand(SI.getDefaultDest(), true);
4492 Out << " [";
4493 for (auto Case : SI.cases()) {
4494 Out << "\n ";
4495 writeOperand(Case.getCaseValue(), true);
4496 Out << ", ";
4497 writeOperand(Case.getCaseSuccessor(), true);
4498 }
4499 Out << "\n ]";
4500 } else if (isa<IndirectBrInst>(I)) {
4501 // Special case indirectbr instruction to get formatting nice and correct.
4502 Out << ' ';
4503 writeOperand(Operand, true);
4504 Out << ", [";
4505
4506 ListSeparator LS;
4507 for (unsigned i = 1, e = I.getNumOperands(); i != e; ++i) {
4508 Out << LS;
4509 writeOperand(I.getOperand(i), true);
4510 }
4511 Out << ']';
4512 } else if (const auto *PN = dyn_cast<PHINode>(&I)) {
4513 Out << ' ';
4514 TypePrinter.print(I.getType(), Out);
4515 Out << ' ';
4516
4517 ListSeparator LS;
4518 for (const auto &[V, Block] :
4519 zip_equal(PN->incoming_values(), PN->blocks())) {
4520 Out << LS << "[ ";
4521 writeOperand(V, false);
4522 Out << ", ";
4523 writeOperand(Block, false);
4524 Out << " ]";
4525 }
4526 } else if (const auto *EVI = dyn_cast<ExtractValueInst>(&I)) {
4527 Out << ' ';
4528 writeOperand(I.getOperand(0), true);
4529 Out << ", ";
4530 Out << llvm::interleaved(EVI->indices());
4531 } else if (const auto *IVI = dyn_cast<InsertValueInst>(&I)) {
4532 Out << ' ';
4533 writeOperand(I.getOperand(0), true); Out << ", ";
4534 writeOperand(I.getOperand(1), true);
4535 Out << ", ";
4536 Out << llvm::interleaved(IVI->indices());
4537 } else if (const auto *LPI = dyn_cast<LandingPadInst>(&I)) {
4538 Out << ' ';
4539 TypePrinter.print(I.getType(), Out);
4540 if (LPI->isCleanup() || LPI->getNumClauses() != 0)
4541 Out << '\n';
4542
4543 if (LPI->isCleanup())
4544 Out << " cleanup";
4545
4546 for (unsigned i = 0, e = LPI->getNumClauses(); i != e; ++i) {
4547 if (i != 0 || LPI->isCleanup()) Out << "\n";
4548 if (LPI->isCatch(i))
4549 Out << " catch ";
4550 else
4551 Out << " filter ";
4552
4553 writeOperand(LPI->getClause(i), true);
4554 }
4555 } else if (const auto *CatchSwitch = dyn_cast<CatchSwitchInst>(&I)) {
4556 Out << " within ";
4557 writeOperand(CatchSwitch->getParentPad(), /*PrintType=*/false);
4558 Out << " [";
4559 ListSeparator LS;
4560 for (const BasicBlock *PadBB : CatchSwitch->handlers()) {
4561 Out << LS;
4562 writeOperand(PadBB, /*PrintType=*/true);
4563 }
4564 Out << "] unwind ";
4565 if (const BasicBlock *UnwindDest = CatchSwitch->getUnwindDest())
4566 writeOperand(UnwindDest, /*PrintType=*/true);
4567 else
4568 Out << "to caller";
4569 } else if (const auto *FPI = dyn_cast<FuncletPadInst>(&I)) {
4570 Out << " within ";
4571 writeOperand(FPI->getParentPad(), /*PrintType=*/false);
4572 Out << " [";
4573 ListSeparator LS;
4574 for (const Value *Op : FPI->arg_operands()) {
4575 Out << LS;
4576 writeOperand(Op, /*PrintType=*/true);
4577 }
4578 Out << ']';
4579 } else if (isa<ReturnInst>(I) && !Operand) {
4580 Out << " void";
4581 } else if (const auto *CRI = dyn_cast<CatchReturnInst>(&I)) {
4582 Out << " from ";
4583 writeOperand(CRI->getOperand(0), /*PrintType=*/false);
4584
4585 Out << " to ";
4586 writeOperand(CRI->getOperand(1), /*PrintType=*/true);
4587 } else if (const auto *CRI = dyn_cast<CleanupReturnInst>(&I)) {
4588 Out << " from ";
4589 writeOperand(CRI->getOperand(0), /*PrintType=*/false);
4590
4591 Out << " unwind ";
4592 if (CRI->hasUnwindDest())
4593 writeOperand(CRI->getOperand(1), /*PrintType=*/true);
4594 else
4595 Out << "to caller";
4596 } else if (const auto *CI = dyn_cast<CallInst>(&I)) {
4597 // Print the calling convention being used.
4598 if (CI->getCallingConv() != CallingConv::C) {
4599 Out << " ";
4600 printCallingConv(CI->getCallingConv(), Out);
4601 }
4602
4603 Operand = CI->getCalledOperand();
4604 FunctionType *FTy = CI->getFunctionType();
4605 Type *RetTy = FTy->getReturnType();
4606 const AttributeList &PAL = CI->getAttributes();
4607
4608 if (PAL.hasRetAttrs())
4609 Out << ' ' << PAL.getAsString(AttributeList::ReturnIndex);
4610
4611 // Only print addrspace(N) if necessary:
4612 maybePrintCallAddrSpace(Operand, &I, Out);
4613
4614 // If possible, print out the short form of the call instruction. We can
4615 // only do this if the first argument is a pointer to a nonvararg function,
4616 // and if the return type is not a pointer to a function.
4617 Out << ' ';
4618 TypePrinter.print(FTy->isVarArg() ? FTy : RetTy, Out);
4619 Out << ' ';
4620 writeOperand(Operand, false);
4621 Out << '(';
4622 bool HasPrettyPrintedArgs =
4623 isa<IntrinsicInst>(CI) &&
4624 Intrinsic::hasPrettyPrintedArgs(CI->getIntrinsicID());
4625
4626 ListSeparator LS;
4627 Function *CalledFunc = CI->getCalledFunction();
4628 auto PrintArgComment = [&](unsigned ArgNo) {
4629 const auto *ConstArg = dyn_cast<Constant>(CI->getArgOperand(ArgNo));
4630 if (!ConstArg)
4631 return;
4632 std::string ArgComment;
4633 raw_string_ostream ArgCommentStream(ArgComment);
4634 Intrinsic::ID IID = CalledFunc->getIntrinsicID();
4635 Intrinsic::printImmArg(IID, ArgNo, ArgCommentStream, ConstArg);
4636 if (ArgComment.empty())
4637 return;
4638 Out << "/* " << ArgComment << " */ ";
4639 };
4640 if (HasPrettyPrintedArgs) {
4641 for (unsigned ArgNo = 0, NumArgs = CI->arg_size(); ArgNo < NumArgs;
4642 ++ArgNo) {
4643 Out << LS;
4644 PrintArgComment(ArgNo);
4645 writeParamOperand(CI->getArgOperand(ArgNo), PAL.getParamAttrs(ArgNo));
4646 }
4647 } else {
4648 for (unsigned ArgNo = 0, NumArgs = CI->arg_size(); ArgNo < NumArgs;
4649 ++ArgNo) {
4650 Out << LS;
4651 writeParamOperand(CI->getArgOperand(ArgNo), PAL.getParamAttrs(ArgNo));
4652 }
4653 }
4654 // Emit an ellipsis if this is a musttail call in a vararg function. This
4655 // is only to aid readability, musttail calls forward varargs by default.
4656 if (CI->isMustTailCall() && CI->getParent() &&
4657 CI->getParent()->getParent() &&
4658 CI->getParent()->getParent()->isVarArg()) {
4659 if (CI->arg_size() > 0)
4660 Out << ", ";
4661 Out << "...";
4662 }
4663
4664 Out << ')';
4665 if (PAL.hasFnAttrs())
4666 Out << " #" << Machine.getAttributeGroupSlot(PAL.getFnAttrs());
4667
4668 writeOperandBundles(CI);
4669 } else if (const auto *II = dyn_cast<InvokeInst>(&I)) {
4670 Operand = II->getCalledOperand();
4671 FunctionType *FTy = II->getFunctionType();
4672 Type *RetTy = FTy->getReturnType();
4673 const AttributeList &PAL = II->getAttributes();
4674
4675 // Print the calling convention being used.
4676 if (II->getCallingConv() != CallingConv::C) {
4677 Out << " ";
4678 printCallingConv(II->getCallingConv(), Out);
4679 }
4680
4681 if (PAL.hasRetAttrs())
4682 Out << ' ' << PAL.getAsString(AttributeList::ReturnIndex);
4683
4684 // Only print addrspace(N) if necessary:
4685 maybePrintCallAddrSpace(Operand, &I, Out);
4686
4687 // If possible, print out the short form of the invoke instruction. We can
4688 // only do this if the first argument is a pointer to a nonvararg function,
4689 // and if the return type is not a pointer to a function.
4690 //
4691 Out << ' ';
4692 TypePrinter.print(FTy->isVarArg() ? FTy : RetTy, Out);
4693 Out << ' ';
4694 writeOperand(Operand, false);
4695 Out << '(';
4696 ListSeparator LS;
4697 for (unsigned op = 0, Eop = II->arg_size(); op < Eop; ++op) {
4698 Out << LS;
4699 writeParamOperand(II->getArgOperand(op), PAL.getParamAttrs(op));
4700 }
4701
4702 Out << ')';
4703 if (PAL.hasFnAttrs())
4704 Out << " #" << Machine.getAttributeGroupSlot(PAL.getFnAttrs());
4705
4706 writeOperandBundles(II);
4707
4708 Out << "\n to ";
4709 writeOperand(II->getNormalDest(), true);
4710 Out << " unwind ";
4711 writeOperand(II->getUnwindDest(), true);
4712 } else if (const auto *CBI = dyn_cast<CallBrInst>(&I)) {
4713 Operand = CBI->getCalledOperand();
4714 FunctionType *FTy = CBI->getFunctionType();
4715 Type *RetTy = FTy->getReturnType();
4716 const AttributeList &PAL = CBI->getAttributes();
4717
4718 // Print the calling convention being used.
4719 if (CBI->getCallingConv() != CallingConv::C) {
4720 Out << " ";
4721 printCallingConv(CBI->getCallingConv(), Out);
4722 }
4723
4724 if (PAL.hasRetAttrs())
4725 Out << ' ' << PAL.getAsString(AttributeList::ReturnIndex);
4726
4727 // If possible, print out the short form of the callbr instruction. We can
4728 // only do this if the first argument is a pointer to a nonvararg function,
4729 // and if the return type is not a pointer to a function.
4730 //
4731 Out << ' ';
4732 TypePrinter.print(FTy->isVarArg() ? FTy : RetTy, Out);
4733 Out << ' ';
4734 writeOperand(Operand, false);
4735 Out << '(';
4736 ListSeparator ArgLS;
4737 for (unsigned op = 0, Eop = CBI->arg_size(); op < Eop; ++op) {
4738 Out << ArgLS;
4739 writeParamOperand(CBI->getArgOperand(op), PAL.getParamAttrs(op));
4740 }
4741
4742 Out << ')';
4743 if (PAL.hasFnAttrs())
4744 Out << " #" << Machine.getAttributeGroupSlot(PAL.getFnAttrs());
4745
4746 writeOperandBundles(CBI);
4747
4748 Out << "\n to ";
4749 writeOperand(CBI->getDefaultDest(), true);
4750 Out << " [";
4751 ListSeparator DestLS;
4752 for (const BasicBlock *Dest : CBI->getIndirectDests()) {
4753 Out << DestLS;
4754 writeOperand(Dest, true);
4755 }
4756 Out << ']';
4757 } else if (const auto *AI = dyn_cast<AllocaInst>(&I)) {
4758 Out << ' ';
4759 if (AI->isUsedWithInAlloca())
4760 Out << "inalloca ";
4761 if (AI->isSwiftError())
4762 Out << "swifterror ";
4763 TypePrinter.print(AI->getAllocatedType(), Out);
4764
4765 // Explicitly write the array size if the code is broken, if it's an array
4766 // allocation, or if the type is not canonical for scalar allocations. The
4767 // latter case prevents the type from mutating when round-tripping through
4768 // assembly.
4769 if (!AI->getArraySize() || AI->isArrayAllocation() ||
4770 !AI->getArraySize()->getType()->isIntegerTy(32)) {
4771 Out << ", ";
4772 writeOperand(AI->getArraySize(), true);
4773 }
4774 if (MaybeAlign A = AI->getAlign()) {
4775 Out << ", align " << A->value();
4776 }
4777
4778 printAddressSpace(AI->getModule(), AI->getAddressSpace(), Out,
4779 /*Prefix=*/", ");
4780 } else if (isa<CastInst>(I)) {
4781 if (Operand) {
4782 Out << ' ';
4783 writeOperand(Operand, true); // Work with broken code
4784 }
4785 Out << " to ";
4786 TypePrinter.print(I.getType(), Out);
4787 } else if (isa<VAArgInst>(I)) {
4788 if (Operand) {
4789 Out << ' ';
4790 writeOperand(Operand, true); // Work with broken code
4791 }
4792 Out << ", ";
4793 TypePrinter.print(I.getType(), Out);
4794 } else if (Operand) { // Print the normal way.
4795 if (const auto *GEP = dyn_cast<GetElementPtrInst>(&I)) {
4796 Out << ' ';
4797 TypePrinter.print(GEP->getSourceElementType(), Out);
4798 Out << ',';
4799 } else if (const auto *LI = dyn_cast<LoadInst>(&I)) {
4800 Out << ' ';
4801 TypePrinter.print(LI->getType(), Out);
4802 Out << ',';
4803 }
4804
4805 // PrintAllTypes - Instructions who have operands of all the same type
4806 // omit the type from all but the first operand. If the instruction has
4807 // different type operands (for example br), then they are all printed.
4808 bool PrintAllTypes = false;
4809 Type *TheType = Operand->getType();
4810
4811 // Select, Store, ShuffleVector, CmpXchg and AtomicRMW always print all
4812 // types.
4816 PrintAllTypes = true;
4817 } else {
4818 for (unsigned i = 1, E = I.getNumOperands(); i != E; ++i) {
4819 Operand = I.getOperand(i);
4820 // note that Operand shouldn't be null, but the test helps make dump()
4821 // more tolerant of malformed IR
4822 if (Operand && Operand->getType() != TheType) {
4823 PrintAllTypes = true; // We have differing types! Print them all!
4824 break;
4825 }
4826 }
4827 }
4828
4829 if (!PrintAllTypes) {
4830 Out << ' ';
4831 TypePrinter.print(TheType, Out);
4832 }
4833
4834 Out << ' ';
4835 ListSeparator LS;
4836 for (const Value *Op : I.operands()) {
4837 Out << LS;
4838 writeOperand(Op, PrintAllTypes);
4839 }
4840 }
4841
4842 // Print atomic ordering/alignment for memory operations
4843 if (const auto *LI = dyn_cast<LoadInst>(&I)) {
4844 if (LI->isAtomic())
4845 writeAtomic(LI->getContext(), LI->getOrdering(), LI->getSyncScopeID());
4846 if (MaybeAlign A = LI->getAlign())
4847 Out << ", align " << A->value();
4848 } else if (const auto *SI = dyn_cast<StoreInst>(&I)) {
4849 if (SI->isAtomic())
4850 writeAtomic(SI->getContext(), SI->getOrdering(), SI->getSyncScopeID());
4851 if (MaybeAlign A = SI->getAlign())
4852 Out << ", align " << A->value();
4853 } else if (const auto *CXI = dyn_cast<AtomicCmpXchgInst>(&I)) {
4854 writeAtomicCmpXchg(CXI->getContext(), CXI->getSuccessOrdering(),
4855 CXI->getFailureOrdering(), CXI->getSyncScopeID());
4856 Out << ", align " << CXI->getAlign().value();
4857 } else if (const auto *RMWI = dyn_cast<AtomicRMWInst>(&I)) {
4858 writeAtomic(RMWI->getContext(), RMWI->getOrdering(),
4859 RMWI->getSyncScopeID());
4860 Out << ", align " << RMWI->getAlign().value();
4861 } else if (const auto *FI = dyn_cast<FenceInst>(&I)) {
4862 writeAtomic(FI->getContext(), FI->getOrdering(), FI->getSyncScopeID());
4863 } else if (const auto *SVI = dyn_cast<ShuffleVectorInst>(&I)) {
4864 printShuffleMask(Out, SVI->getType(), SVI->getShuffleMask());
4865 }
4866
4867 // Print Metadata info.
4869 I.getAllMetadata(InstMD);
4870 printMetadataAttachments(InstMD, ", ");
4871
4872 // Print a nice comment.
4873 printInfoComment(I);
4874}
4875
4876void AssemblyWriter::printDbgMarker(const DbgMarker &Marker) {
4877 // There's no formal representation of a DbgMarker -- print purely as a
4878 // debugging aid.
4879 for (const DbgRecord &DPR : Marker.StoredDbgRecords) {
4880 printDbgRecord(DPR);
4881 Out << "\n";
4882 }
4883
4884 Out << " DbgMarker -> { ";
4885 printInstruction(*Marker.MarkedInstr);
4886 Out << " }";
4887}
4888
4889void AssemblyWriter::printDbgRecord(const DbgRecord &DR) {
4890 if (auto *DVR = dyn_cast<DbgVariableRecord>(&DR))
4891 printDbgVariableRecord(*DVR);
4892 else if (auto *DLR = dyn_cast<DbgLabelRecord>(&DR))
4893 printDbgLabelRecord(*DLR);
4894 else
4895 llvm_unreachable("Unexpected DbgRecord kind");
4896}
4897
4898void AssemblyWriter::printDbgVariableRecord(const DbgVariableRecord &DVR) {
4899 auto WriterCtx = getContext();
4900 Out << "#dbg_";
4901 switch (DVR.getType()) {
4902 case DbgVariableRecord::LocationType::Value:
4903 Out << "value";
4904 break;
4905 case DbgVariableRecord::LocationType::Declare:
4906 Out << "declare";
4907 break;
4908 case DbgVariableRecord::LocationType::DeclareValue:
4909 Out << "declare_value";
4910 break;
4911 case DbgVariableRecord::LocationType::Assign:
4912 Out << "assign";
4913 break;
4914 default:
4916 "Tried to print a DbgVariableRecord with an invalid LocationType!");
4917 }
4918
4919 auto PrintOrNull = [&](Metadata *M) {
4920 if (!M)
4921 Out << "(null)";
4922 else
4923 writeAsOperandInternal(Out, M, WriterCtx, true);
4924 };
4925
4926 Out << "(";
4927 PrintOrNull(DVR.getRawLocation());
4928 Out << ", ";
4929 PrintOrNull(DVR.getRawVariable());
4930 Out << ", ";
4931 PrintOrNull(DVR.getRawExpression());
4932 Out << ", ";
4933 if (DVR.isDbgAssign()) {
4934 PrintOrNull(DVR.getRawAssignID());
4935 Out << ", ";
4936 PrintOrNull(DVR.getRawAddress());
4937 Out << ", ";
4938 PrintOrNull(DVR.getRawAddressExpression());
4939 Out << ", ";
4940 }
4941 PrintOrNull(DVR.getDebugLoc().getAsMDNode());
4942 Out << ")";
4943}
4944
4945/// printDbgRecordLine - Print a DbgRecord with indentation and a newline
4946/// character.
4947void AssemblyWriter::printDbgRecordLine(const DbgRecord &DR) {
4948 // Print lengthier indentation to bring out-of-line with instructions.
4949 Out << " ";
4950 printDbgRecord(DR);
4951 Out << '\n';
4952}
4953
4954void AssemblyWriter::printDbgLabelRecord(const DbgLabelRecord &Label) {
4955 auto WriterCtx = getContext();
4956 Out << "#dbg_label(";
4957 writeAsOperandInternal(Out, Label.getRawLabel(), WriterCtx, true);
4958 Out << ", ";
4959 writeAsOperandInternal(Out, Label.getDebugLoc(), WriterCtx, true);
4960 Out << ")";
4961}
4962
4963void AssemblyWriter::printMetadataAttachments(
4964 const SmallVectorImpl<std::pair<unsigned, MDNode *>> &MDs,
4965 StringRef Separator) {
4966 if (MDs.empty())
4967 return;
4968
4969 if (MDNames.empty())
4970 MDs[0].second->getContext().getMDKindNames(MDNames);
4971
4972 auto WriterCtx = getContext();
4973 for (const auto &I : MDs) {
4974 unsigned Kind = I.first;
4975 Out << Separator;
4976 if (Kind < MDNames.size()) {
4977 Out << "!";
4978 printMetadataIdentifier(MDNames[Kind], Out);
4979 } else
4980 Out << "!<unknown kind #" << Kind << ">";
4981 Out << ' ';
4982 writeAsOperandInternal(Out, I.second, WriterCtx);
4983 }
4984}
4985
4986void AssemblyWriter::writeMDNode(unsigned Slot, const MDNode *Node) {
4987 if (AnnotationWriter)
4988 AnnotationWriter->emitMDNodeAnnot(Node, Out);
4989
4990 Out << '!' << Slot << " = ";
4991 printMDNodeBody(Node);
4992 Out << "\n";
4993}
4994
4995void AssemblyWriter::writeAllMDNodes() {
4997 Nodes.resize(Machine.mdn_size());
4998 for (auto &I : llvm::make_range(Machine.mdn_begin(), Machine.mdn_end()))
4999 Nodes[I.second] = cast<MDNode>(I.first);
5000
5001 for (unsigned i = 0, e = Nodes.size(); i != e; ++i) {
5002 writeMDNode(i, Nodes[i]);
5003 }
5004}
5005
5006void AssemblyWriter::printMDNodeBody(const MDNode *Node) {
5007 auto WriterCtx = getContext();
5008 writeMDNodeBodyInternal(Out, Node, WriterCtx);
5009}
5010
5011void AssemblyWriter::writeAttribute(const Attribute &Attr, bool InAttrGroup) {
5012 if (!Attr.isTypeAttribute()) {
5013 Out << Attr.getAsString(InAttrGroup);
5014 return;
5015 }
5016
5017 Out << Attribute::getNameFromAttrKind(Attr.getKindAsEnum());
5018 if (Type *Ty = Attr.getValueAsType()) {
5019 Out << '(';
5020 TypePrinter.print(Ty, Out);
5021 Out << ')';
5022 }
5023}
5024
5025void AssemblyWriter::writeAttributeSet(const AttributeSet &AttrSet,
5026 bool InAttrGroup) {
5027 ListSeparator LS(" ");
5028 for (const auto &Attr : AttrSet) {
5029 Out << LS;
5030 writeAttribute(Attr, InAttrGroup);
5031 }
5032}
5033
5034void AssemblyWriter::writeAllAttributeGroups() {
5035 std::vector<std::pair<AttributeSet, unsigned>> asVec;
5036 asVec.resize(Machine.as_size());
5037
5038 for (auto &I : llvm::make_range(Machine.as_begin(), Machine.as_end()))
5039 asVec[I.second] = I;
5040
5041 for (const auto &I : asVec)
5042 Out << "attributes #" << I.second << " = { "
5043 << I.first.getAsString(true) << " }\n";
5044}
5045
5046void AssemblyWriter::printUseListOrder(const Value *V,
5047 ArrayRef<unsigned> Shuffle) {
5048 if (Machine.getFunction())
5049 Out << " ";
5050
5051 Out << "uselistorder ";
5052 writeOperand(V, true);
5053
5054 assert(Shuffle.size() >= 2 && "Shuffle too small");
5055 Out << ", { " << llvm::interleaved(Shuffle) << " }\n";
5056}
5057
5058void AssemblyWriter::printUseLists(const Function *F) {
5059 auto It = UseListOrders.find(F);
5060 if (It == UseListOrders.end())
5061 return;
5062
5063 Out << "\n; uselistorder directives\n";
5064 for (const auto &Pair : It->second)
5065 printUseListOrder(Pair.first, Pair.second);
5066}
5067
5068//===----------------------------------------------------------------------===//
5069// External Interface declarations
5070//===----------------------------------------------------------------------===//
5071
5073 bool ShouldPreserveUseListOrder, bool IsForDebug) const {
5074 SlotTracker SlotTable(this->getParent());
5075 formatted_raw_ostream OS(ROS);
5076 AssemblyWriter W(OS, SlotTable, this->getParent(), AAW, IsForDebug,
5077 ShouldPreserveUseListOrder);
5078 W.printFunction(this);
5079}
5080
5082 bool ShouldPreserveUseListOrder,
5083 bool IsForDebug) const {
5084 SlotTracker SlotTable(this->getParent());
5085 formatted_raw_ostream OS(ROS);
5086 AssemblyWriter W(OS, SlotTable, this->getModule(), AAW,
5087 IsForDebug,
5088 ShouldPreserveUseListOrder);
5089 W.printBasicBlock(this);
5090}
5091
5093 bool ShouldPreserveUseListOrder, bool IsForDebug) const {
5094 SlotTracker SlotTable(this);
5095 formatted_raw_ostream OS(ROS);
5096 AssemblyWriter W(OS, SlotTable, this, AAW, IsForDebug,
5097 ShouldPreserveUseListOrder);
5098 W.printModule(this);
5099}
5100
5101void NamedMDNode::print(raw_ostream &ROS, bool IsForDebug) const {
5102 SlotTracker SlotTable(getParent());
5103 formatted_raw_ostream OS(ROS);
5104 AssemblyWriter W(OS, SlotTable, getParent(), nullptr, IsForDebug);
5105 W.printNamedMDNode(this);
5106}
5107
5109 bool IsForDebug) const {
5110 std::optional<SlotTracker> LocalST;
5111 SlotTracker *SlotTable;
5112 if (auto *ST = MST.getMachine())
5113 SlotTable = ST;
5114 else {
5115 LocalST.emplace(getParent());
5116 SlotTable = &*LocalST;
5117 }
5118
5119 formatted_raw_ostream OS(ROS);
5120 AssemblyWriter W(OS, *SlotTable, getParent(), nullptr, IsForDebug);
5121 W.printNamedMDNode(this);
5122}
5123
5124void Comdat::print(raw_ostream &ROS, bool /*IsForDebug*/) const {
5126 ROS << " = comdat ";
5127
5128 switch (getSelectionKind()) {
5129 case Comdat::Any:
5130 ROS << "any";
5131 break;
5132 case Comdat::ExactMatch:
5133 ROS << "exactmatch";
5134 break;
5135 case Comdat::Largest:
5136 ROS << "largest";
5137 break;
5139 ROS << "nodeduplicate";
5140 break;
5141 case Comdat::SameSize:
5142 ROS << "samesize";
5143 break;
5144 }
5145
5146 ROS << '\n';
5147}
5148
5149void Type::print(raw_ostream &OS, bool /*IsForDebug*/, bool NoDetails) const {
5150 TypePrinting TP;
5151 TP.print(const_cast<Type*>(this), OS);
5152
5153 if (NoDetails)
5154 return;
5155
5156 // If the type is a named struct type, print the body as well.
5157 if (auto *STy = dyn_cast<StructType>(const_cast<Type *>(this)))
5158 if (!STy->isLiteral()) {
5159 OS << " = type ";
5160 TP.printStructBody(STy, OS);
5161 }
5162}
5163
5164static bool isReferencingMDNode(const Instruction &I) {
5165 if (const auto *CI = dyn_cast<CallInst>(&I))
5166 if (Function *F = CI->getCalledFunction())
5167 if (F->isIntrinsic())
5168 for (auto &Op : I.operands())
5170 if (isa<MDNode>(V->getMetadata()))
5171 return true;
5172 return false;
5173}
5174
5175void DbgMarker::print(raw_ostream &ROS, bool IsForDebug) const {
5176
5177 ModuleSlotTracker MST(getModuleFromDPI(this), true);
5178 print(ROS, MST, IsForDebug);
5179}
5180
5181void DbgVariableRecord::print(raw_ostream &ROS, bool IsForDebug) const {
5182
5183 ModuleSlotTracker MST(getModuleFromDPI(this), true);
5184 print(ROS, MST, IsForDebug);
5185}
5186
5188 bool IsForDebug) const {
5189 formatted_raw_ostream OS(ROS);
5190 SlotTracker EmptySlotTable(static_cast<const Module *>(nullptr));
5191 SlotTracker &SlotTable =
5192 MST.getMachine() ? *MST.getMachine() : EmptySlotTable;
5193 const Function *F = getParent() ? getParent()->getParent() : nullptr;
5194 if (F)
5195 MST.incorporateFunction(*F);
5196 AssemblyWriter W(OS, SlotTable, getModuleFromDPI(this), nullptr, IsForDebug);
5197 W.printDbgMarker(*this);
5198}
5199
5200void DbgLabelRecord::print(raw_ostream &ROS, bool IsForDebug) const {
5201
5202 ModuleSlotTracker MST(getModuleFromDPI(this), true);
5203 print(ROS, MST, IsForDebug);
5204}
5205
5207 bool IsForDebug) const {
5208 formatted_raw_ostream OS(ROS);
5209 SlotTracker EmptySlotTable(static_cast<const Module *>(nullptr));
5210 SlotTracker &SlotTable =
5211 MST.getMachine() ? *MST.getMachine() : EmptySlotTable;
5212 const Function *F = Marker && Marker->getParent()
5213 ? Marker->getParent()->getParent()
5214 : nullptr;
5215 if (F)
5216 MST.incorporateFunction(*F);
5217 AssemblyWriter W(OS, SlotTable, getModuleFromDPI(this), nullptr, IsForDebug);
5218 W.printDbgVariableRecord(*this);
5219}
5220
5222 bool IsForDebug) const {
5223 formatted_raw_ostream OS(ROS);
5224 SlotTracker EmptySlotTable(static_cast<const Module *>(nullptr));
5225 SlotTracker &SlotTable =
5226 MST.getMachine() ? *MST.getMachine() : EmptySlotTable;
5227 const Function *F =
5228 Marker->getParent() ? Marker->getParent()->getParent() : nullptr;
5229 if (F)
5230 MST.incorporateFunction(*F);
5231
5232 AssemblyWriter W(OS, SlotTable, getModuleFromDPI(this), nullptr, IsForDebug);
5233 W.printDbgLabelRecord(*this);
5234}
5235
5236void Value::print(raw_ostream &ROS, bool IsForDebug) const {
5237 bool ShouldInitializeAllMetadata = false;
5238 if (auto *I = dyn_cast<Instruction>(this))
5239 ShouldInitializeAllMetadata = isReferencingMDNode(*I);
5240 else if (isa<Function>(this) || isa<MetadataAsValue>(this))
5241 ShouldInitializeAllMetadata = true;
5242
5243 ModuleSlotTracker MST(getModuleFromVal(this), ShouldInitializeAllMetadata);
5244 print(ROS, MST, IsForDebug);
5245}
5246
5248 bool IsForDebug) const {
5249 formatted_raw_ostream OS(ROS);
5250 SlotTracker EmptySlotTable(static_cast<const Module *>(nullptr));
5251 SlotTracker &SlotTable =
5252 MST.getMachine() ? *MST.getMachine() : EmptySlotTable;
5253 auto IncorporateFunction = [&](const Function *F) {
5254 if (F)
5255 MST.incorporateFunction(*F);
5256 };
5257
5258 if (const auto *I = dyn_cast<Instruction>(this)) {
5259 IncorporateFunction(I->getParent() ? I->getParent()->getParent() : nullptr);
5260 AssemblyWriter W(OS, SlotTable, getModuleFromVal(I), nullptr, IsForDebug);
5261 W.printInstruction(*I);
5262 } else if (const auto *BB = dyn_cast<BasicBlock>(this)) {
5263 IncorporateFunction(BB->getParent());
5264 AssemblyWriter W(OS, SlotTable, getModuleFromVal(BB), nullptr, IsForDebug);
5265 W.printBasicBlock(BB);
5266 } else if (const auto *GV = dyn_cast<GlobalValue>(this)) {
5267 AssemblyWriter W(OS, SlotTable, GV->getParent(), nullptr, IsForDebug);
5268 if (const auto *V = dyn_cast<GlobalVariable>(GV))
5269 W.printGlobal(V);
5270 else if (const auto *F = dyn_cast<Function>(GV))
5271 W.printFunction(F);
5272 else if (const auto *A = dyn_cast<GlobalAlias>(GV))
5273 W.printAlias(A);
5274 else if (const auto *I = dyn_cast<GlobalIFunc>(GV))
5275 W.printIFunc(I);
5276 else
5277 llvm_unreachable("Unknown GlobalValue to print out!");
5278 } else if (const auto *V = dyn_cast<MetadataAsValue>(this)) {
5279 V->getMetadata()->print(ROS, MST, getModuleFromVal(V));
5280 } else if (const auto *C = dyn_cast<Constant>(this)) {
5281 TypePrinting TypePrinter;
5282 TypePrinter.print(C->getType(), OS);
5283 OS << ' ';
5284 AsmWriterContext WriterCtx(&TypePrinter, MST.getMachine());
5285 writeConstantInternal(OS, C, WriterCtx);
5286 } else if (isa<InlineAsm>(this) || isa<Argument>(this)) {
5287 this->printAsOperand(OS, /* PrintType */ true, MST);
5288 } else {
5289 llvm_unreachable("Unknown value to print out!");
5290 }
5291}
5292
5293/// Print without a type, skipping the TypePrinting object.
5294///
5295/// \return \c true iff printing was successful.
5296static bool printWithoutType(const Value &V, raw_ostream &O,
5297 SlotTracker *Machine, const Module *M) {
5298 if (V.hasName() || isa<GlobalValue>(V) ||
5299 (!isa<Constant>(V) && !isa<MetadataAsValue>(V))) {
5300 AsmWriterContext WriterCtx(nullptr, Machine, M);
5301 writeAsOperandInternal(O, &V, WriterCtx);
5302 return true;
5303 }
5304 return false;
5305}
5306
5307static void printAsOperandImpl(const Value &V, raw_ostream &O, bool PrintType,
5308 ModuleSlotTracker &MST) {
5309 TypePrinting TypePrinter(MST.getModule());
5310 AsmWriterContext WriterCtx(&TypePrinter, MST.getMachine(), MST.getModule());
5311 writeAsOperandInternal(O, &V, WriterCtx, PrintType);
5312}
5313
5314void Value::printAsOperand(raw_ostream &O, bool PrintType,
5315 const Module *M) const {
5316 if (!M)
5317 M = getModuleFromVal(this);
5318
5319 if (!PrintType)
5320 if (printWithoutType(*this, O, nullptr, M))
5321 return;
5322
5324 M, /* ShouldInitializeAllMetadata */ isa<MetadataAsValue>(this));
5325 ModuleSlotTracker MST(Machine, M);
5326 printAsOperandImpl(*this, O, PrintType, MST);
5327}
5328
5329void Value::printAsOperand(raw_ostream &O, bool PrintType,
5330 ModuleSlotTracker &MST) const {
5331 if (!PrintType)
5332 if (printWithoutType(*this, O, MST.getMachine(), MST.getModule()))
5333 return;
5334
5335 printAsOperandImpl(*this, O, PrintType, MST);
5336}
5337
5338/// Recursive version of printMetadataImpl.
5339static void printMetadataImplRec(raw_ostream &ROS, const Metadata &MD,
5340 AsmWriterContext &WriterCtx) {
5341 formatted_raw_ostream OS(ROS);
5342 writeAsOperandInternal(OS, &MD, WriterCtx, /* FromValue */ true);
5343
5344 auto *N = dyn_cast<MDNode>(&MD);
5345 if (!N || isa<DIExpression>(MD))
5346 return;
5347
5348 OS << " = ";
5349 writeMDNodeBodyInternal(OS, N, WriterCtx);
5350}
5351
5352namespace {
5353struct MDTreeAsmWriterContext : public AsmWriterContext {
5354 unsigned Level;
5355 // {Level, Printed string}
5356 using EntryTy = std::pair<unsigned, std::string>;
5358
5359 // Used to break the cycle in case there is any.
5360 SmallPtrSet<const Metadata *, 4> Visited;
5361
5362 raw_ostream &MainOS;
5363
5364 MDTreeAsmWriterContext(TypePrinting *TP, SlotTracker *ST, const Module *M,
5365 raw_ostream &OS, const Metadata *InitMD)
5366 : AsmWriterContext(TP, ST, M), Level(0U), Visited({InitMD}), MainOS(OS) {}
5367
5368 void onWriteMetadataAsOperand(const Metadata *MD) override {
5369 if (!Visited.insert(MD).second)
5370 return;
5371
5372 std::string Str;
5373 raw_string_ostream SS(Str);
5374 ++Level;
5375 // A placeholder entry to memorize the correct
5376 // position in buffer.
5377 Buffer.emplace_back(std::make_pair(Level, ""));
5378 unsigned InsertIdx = Buffer.size() - 1;
5379
5380 printMetadataImplRec(SS, *MD, *this);
5381 Buffer[InsertIdx].second = std::move(SS.str());
5382 --Level;
5383 }
5384
5385 ~MDTreeAsmWriterContext() override {
5386 for (const auto &Entry : Buffer) {
5387 MainOS << "\n";
5388 unsigned NumIndent = Entry.first * 2U;
5389 MainOS.indent(NumIndent) << Entry.second;
5390 }
5391 }
5392};
5393} // end anonymous namespace
5394
5395static void printMetadataImpl(raw_ostream &ROS, const Metadata &MD,
5396 ModuleSlotTracker &MST, const Module *M,
5397 bool OnlyAsOperand, bool PrintAsTree = false) {
5398 formatted_raw_ostream OS(ROS);
5399
5400 TypePrinting TypePrinter(M);
5401
5402 std::unique_ptr<AsmWriterContext> WriterCtx;
5403 if (PrintAsTree && !OnlyAsOperand)
5404 WriterCtx = std::make_unique<MDTreeAsmWriterContext>(
5405 &TypePrinter, MST.getMachine(), M, OS, &MD);
5406 else
5407 WriterCtx =
5408 std::make_unique<AsmWriterContext>(&TypePrinter, MST.getMachine(), M);
5409
5410 writeAsOperandInternal(OS, &MD, *WriterCtx, /* FromValue */ true);
5411
5412 auto *N = dyn_cast<MDNode>(&MD);
5413 if (OnlyAsOperand || !N || isa<DIExpression>(MD))
5414 return;
5415
5416 OS << " = ";
5417 writeMDNodeBodyInternal(OS, N, *WriterCtx);
5418}
5419
5421 ModuleSlotTracker MST(M, isa<MDNode>(this));
5422 printMetadataImpl(OS, *this, MST, M, /* OnlyAsOperand */ true);
5423}
5424
5426 const Module *M) const {
5427 printMetadataImpl(OS, *this, MST, M, /* OnlyAsOperand */ true);
5428}
5429
5431 bool /*IsForDebug*/) const {
5432 ModuleSlotTracker MST(M, isa<MDNode>(this));
5433 printMetadataImpl(OS, *this, MST, M, /* OnlyAsOperand */ false);
5434}
5435
5437 const Module *M, bool /*IsForDebug*/) const {
5438 printMetadataImpl(OS, *this, MST, M, /* OnlyAsOperand */ false);
5439}
5440
5441void MDNode::printTree(raw_ostream &OS, const Module *M) const {
5442 ModuleSlotTracker MST(M, true);
5443 printMetadataImpl(OS, *this, MST, M, /* OnlyAsOperand */ false,
5444 /*PrintAsTree=*/true);
5445}
5446
5448 const Module *M) const {
5449 printMetadataImpl(OS, *this, MST, M, /* OnlyAsOperand */ false,
5450 /*PrintAsTree=*/true);
5451}
5452
5453void ModuleSummaryIndex::print(raw_ostream &ROS, bool IsForDebug) const {
5454 SlotTracker SlotTable(this);
5455 formatted_raw_ostream OS(ROS);
5456 AssemblyWriter W(OS, SlotTable, this, IsForDebug);
5457 W.printModuleSummaryIndex();
5458}
5459
5461 unsigned UB) const {
5462 SlotTracker *ST = MachineStorage.get();
5463 if (!ST)
5464 return;
5465
5466 for (auto &I : llvm::make_range(ST->mdn_begin(), ST->mdn_end()))
5467 if (I.second >= LB && I.second < UB)
5468 L.push_back(std::make_pair(I.second, I.first));
5469}
5470
5471#if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP)
5472// Value::dump - allow easy printing of Values from the debugger.
5474void Value::dump() const { print(dbgs(), /*IsForDebug=*/true); dbgs() << '\n'; }
5475
5476// Value::dump - allow easy printing of Values from the debugger.
5478void DbgMarker::dump() const {
5479 print(dbgs(), /*IsForDebug=*/true);
5480 dbgs() << '\n';
5481}
5482
5483// Value::dump - allow easy printing of Values from the debugger.
5485void DbgRecord::dump() const { print(dbgs(), /*IsForDebug=*/true); dbgs() << '\n'; }
5486
5487// Type::dump - allow easy printing of Types from the debugger.
5489void Type::dump() const { print(dbgs(), /*IsForDebug=*/true); dbgs() << '\n'; }
5490
5491// Module::dump() - Allow printing of Modules from the debugger.
5493void Module::dump() const {
5494 print(dbgs(), nullptr,
5495 /*ShouldPreserveUseListOrder=*/false, /*IsForDebug=*/true);
5496}
5497
5498// Allow printing of Comdats from the debugger.
5500void Comdat::dump() const { print(dbgs(), /*IsForDebug=*/true); }
5501
5502// NamedMDNode::dump() - Allow printing of NamedMDNodes from the debugger.
5504void NamedMDNode::dump() const { print(dbgs(), /*IsForDebug=*/true); }
5505
5507void Metadata::dump() const { dump(nullptr); }
5508
5510void Metadata::dump(const Module *M) const {
5511 print(dbgs(), M, /*IsForDebug=*/true);
5512 dbgs() << '\n';
5513}
5514
5516void MDNode::dumpTree() const { dumpTree(nullptr); }
5517
5519void MDNode::dumpTree(const Module *M) const {
5520 printTree(dbgs(), M);
5521 dbgs() << '\n';
5522}
5523
5524// Allow printing of ModuleSummaryIndex from the debugger.
5526void ModuleSummaryIndex::dump() const { print(dbgs(), /*IsForDebug=*/true); }
5527#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 WriteFullHexAPInt(raw_ostream &Out, const APInt &Val)
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:663
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:255
#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 processModule(Module &M, NVPTXTargetMachine &TM)
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 & PPCDoubleDouble()
Definition APFloat.h:300
bool isNegative() const
Definition APFloat.h:1559
void toString(SmallVectorImpl< char > &Str, unsigned FormatPrecision=0, unsigned FormatMaxPadding=3, bool TruncateZero=true) const
Definition APFloat.h:1596
const fltSemantics & getSemantics() const
Definition APFloat.h:1567
bool isNaN() const
Definition APFloat.h:1557
bool isSignaling() const
Definition APFloat.h:1561
APInt bitcastToAPInt() const
Definition APFloat.h:1451
APInt getNaNPayload() const
If the value is a NaN value, return an integer containing the payload of this value.
Definition APFloat.h:1585
bool isInfinity() const
Definition APFloat.h:1556
Class for arbitrary precision integers.
Definition APInt.h:78
void clearBit(unsigned BitPosition)
Set a given bit to 0.
Definition APInt.h:1429
unsigned getActiveBits() const
Compute the number of active bits in the value.
Definition APInt.h:1535
LLVM_ABI APInt trunc(unsigned width) const
Truncate to new width.
Definition APInt.cpp:968
void toStringUnsigned(SmallVectorImpl< char > &Str, unsigned Radix=10) const
Considers the APInt to be unsigned and converts it into a string in the radix given.
Definition APInt.h:1714
bool isZero() const
Determine if this value is zero, i.e. all bits are clear.
Definition APInt.h:381
bool isSignMask() const
Check if the APInt's value is returned by getSignMask.
Definition APInt.h:467
unsigned getBitWidth() const
Return the number of bits in the APInt.
Definition APInt.h:1511
APInt lshr(unsigned shiftAmt) const
Logical right-shift function.
Definition APInt.h:858
Abstract interface of slot tracker storage.
const GlobalValueSummary & getAliasee() const
This class represents an incoming formal argument to a Function.
Definition Argument.h:32
Represent a constant reference to an array (0 or more elements consecutively in memory),...
Definition ArrayRef.h:40
size_t size() const
Get the array size.
Definition ArrayRef.h:141
virtual void emitMDNodeAnnot(const MDNode *, formatted_raw_ostream &)
emitMDNodeAnnot - This may be implemented to emit a string right before a metadata node is emitted.
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:478
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
static LLVM_ABI ConstantPointerNull * get(PointerType *T)
Static factory methods - Return objects of the specified value.
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 source language identity metadata that includes language name,...
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.
LLVM_ABI MDNode * getAsMDNode() const
Return this as a bar MDNode.
Definition DebugLoc.cpp:76
DenseMapIterator< KeyT, ValueT, KeyInfoT, BucketT > iterator
Definition DenseMap.h:133
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:256
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:233
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:1069
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:1482
This class implements a map that also provides access to all stored values in a deterministic order.
Definition MapVector.h:38
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...
const TypeIdSummaryMapTy & typeIds() const
ValueInfo getValueInfo(const GlobalValueSummaryMapTy::value_type &R) const
Return a ValueInfo for the index value_type (convenient when iterating index).
static constexpr const char * getRegularLTOModuleName()
const auto & typeIdCompatibleVtableMap() const
const StringMap< ModuleHash > & modulePaths() const
Table of modules, containing module hash and id.
LLVM_ABI void dump() const
Dump to stderr (for debugging).
GlobalValueSummaryMapTy::SortedEntriesRange sortedGlobalValueSummariesRange() const
uint64_t getStackIdAtIndex(unsigned Index) const
LLVM_ABI void print(raw_ostream &OS, bool IsForDebug=false) const
Print to an output stream.
LLVM_ABI uint64_t getFlags() const
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:737
iterator_range< global_iterator > globals()
Definition Module.h:686
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:1838
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.
unsigned size() const
Definition StringMap.h:103
StringMap - This is an unconventional map that is specialized for handling keys that are "strings",...
Definition StringMap.h:128
Represent a constant reference to a string, i.e.
Definition StringRef.h:56
constexpr bool empty() const
Check if the string is empty.
Definition StringRef.h:141
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:760
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
LLVM_ABI 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:319
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 LanguageDialectString(unsigned LanguageDialect)
Definition Dwarf.cpp:607
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:643
LLVM_ABI StringRef MacinfoString(unsigned Encoding)
Definition Dwarf.cpp:707
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.
constexpr bool isAtomic(const T &...O)
Definition SIDefines.h:383
@ System
Synchronized with respect to all concurrently executing threads.
Definition LLVMContext.h:58
initializer< Ty > init(const Ty &Val)
SourceLanguageName
Definition Dwarf.h:229
@ 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)
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:1739
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:2173
RelativeUniformCounterPtr ValuesPtrExpr VTableAddr Value
Definition InstrProf.h:143
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:1636
LLVM_ABI raw_ostream & dbgs()
dbgs() - This returns a reference to a raw_ostream for debugging messages.
Definition Debug.cpp:209
char hexdigit(unsigned X, bool LowerCase=false)
hexdigit - Return the hexadecimal character for the given number X (which should be less than 16).
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:1970
class LLVM_GSL_OWNER SmallVector
Forward declaration of SmallVector so that calculateSmallVectorDefaultInlinedElements can reference s...
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
RelativeUniformCounterPtr ValuesPtrExpr VTableAddr Count
Definition InstrProf.h:145
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:107
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:1448