LLVM 23.0.0git
AsmPrinter.h
Go to the documentation of this file.
1//===- llvm/CodeGen/AsmPrinter.h - AsmPrinter Framework ---------*- C++ -*-===//
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 file contains a class to be used as the base class for target specific
10// asm writers. This class primarily handles common functionality used by
11// all asm writers.
12//
13//===----------------------------------------------------------------------===//
14
15#ifndef LLVM_CODEGEN_ASMPRINTER_H
16#define LLVM_CODEGEN_ASMPRINTER_H
17
18#include "llvm/ADT/DenseMap.h"
19#include "llvm/ADT/MapVector.h"
20#include "llvm/ADT/SetVector.h"
29#include "llvm/IR/InlineAsm.h"
32#include <cstdint>
33#include <memory>
34#include <utility>
35#include <vector>
36
37namespace llvm {
38
39class AddrLabelMap;
41class BasicBlock;
42class BlockAddress;
43class Constant;
44class ConstantArray;
45class ConstantPtrAuth;
46class DataLayout;
48class DIE;
49class DIEAbbrev;
50class DwarfDebug;
51class EHStreamer;
53class GCStrategy;
54class GlobalAlias;
55class GlobalObject;
56class GlobalValue;
57class GlobalVariable;
61class MachineFunction;
62class MachineInstr;
64class MachineLoopInfo;
67class MCAsmInfo;
69class MCContext;
70class MCExpr;
71class MCInst;
72class MCSection;
73class MCStreamer;
74class MCSubtargetInfo;
75class MCSymbol;
76class MCTargetOptions;
77class MDNode;
78class Module;
80class raw_ostream;
81class StringRef;
83class TargetMachine;
84class Twine;
85
86namespace remarks {
87class RemarkStreamer;
88}
89
90/// This class is intended to be used as a driving class for all asm writers.
92public:
93 /// Target machine description.
95
96 /// Target Asm Printer information.
97 const MCAsmInfo *MAI = nullptr;
98
99 /// This is the context for the output file that we are streaming. This owns
100 /// all of the global MC-related objects for the generated translation unit.
102
103 /// This is the MCStreamer object for the file we are generating. This
104 /// contains the transient state for the current translation unit that we are
105 /// generating (such as the current section etc).
106 std::unique_ptr<MCStreamer> OutStreamer;
107
108 /// The current machine function.
109 MachineFunction *MF = nullptr;
110
111 /// This is a pointer to the current MachineModuleInfo.
113
114 /// This is a pointer to the current MachineDominatorTree.
116
117 /// This is a pointer to the current MachineLoopInfo.
119
120 /// Optimization remark emitter.
122
123 /// The symbol for the entry in __patchable_function_entires.
125
126 /// The symbol for the current function. This is recalculated at the beginning
127 /// of each call to runOnMachineFunction().
129
130 /// The symbol for the current function descriptor on AIX. This is created
131 /// at the beginning of each call to SetupMachineFunction().
133
134 /// The symbol used to represent the start of the current function for the
135 /// purpose of calculating its size (e.g. using the .size directive). By
136 /// default, this is equal to CurrentFnSym.
138
139 /// Vector of symbols marking the end of the callsites in the current
140 /// function, keyed by their containing basic block.
141 /// The callsite symbols of each block are stored in the order they appear
142 /// in that block.
145
146 /// Provides the profile information for constants.
147 const StaticDataProfileInfo *SDPI = nullptr;
148
149 /// The profile summary information.
150 const ProfileSummaryInfo *PSI = nullptr;
151
152 /// Map a basic block section ID to the begin and end symbols of that section
153 /// which determine the section's range.
157
159
160 /// Map global GOT equivalent MCSymbols to GlobalVariables and keep track of
161 /// its number of uses by other globals.
162 using GOTEquivUsePair = std::pair<const GlobalVariable *, unsigned>;
164
165 // Flags representing which CFI section is required for a function/module.
166 enum class CFISection : unsigned {
167 None = 0, ///< Do not emit either .eh_frame or .debug_frame
168 EH = 1, ///< Emit .eh_frame
169 Debug = 2 ///< Emit .debug_frame
170 };
171
172 // Callbacks to get analyses to allow portability between the new and
173 // legacy pass managers.
174 // TODO(boomanaiden154): Remove these and use a more native solution once
175 // we drop support for the legacy PM.
176 std::function<MachineModuleInfo *()> GetMMI;
180 std::function<void(Module &)> BeginGCAssembly;
181 std::function<void(Module &)> FinishGCAssembly;
182 std::function<void(Module &)> EmitStackMaps;
183 std::function<void()> AssertDebugEHFinalized;
184
185private:
186 MCSymbol *CurrentFnEnd = nullptr;
187
188 /// Map a basic block section ID to the exception symbol associated with that
189 /// section. Map entries are assigned and looked up via
190 /// AsmPrinter::getMBBExceptionSym.
191 DenseMap<MBBSectionID, MCSymbol *> MBBSectionExceptionSyms;
192
193 // The symbol used to represent the start of the current BB section of the
194 // function. This is used to calculate the size of the BB section.
195 MCSymbol *CurrentSectionBeginSym = nullptr;
196
197 /// This map keeps track of which symbol is being used for the specified basic
198 /// block's address of label.
199 std::unique_ptr<AddrLabelMap> AddrLabelSymbols;
200
201 /// The garbage collection metadata printer table.
203
204 /// Emit comments in assembly output if this is true.
205 bool VerboseAsm;
206
207 /// Store symbols and type identifiers used to create callgraph section
208 /// entries related to a function.
209 struct FunctionCallGraphInfo {
210 /// Numeric type identifier used in callgraph section for indirect calls
211 /// and targets.
212 using CGTypeId = uint64_t;
213
214 /// Unique target type IDs.
215 SmallSetVector<CGTypeId, 4> IndirectCalleeTypeIDs;
216 /// Unique direct callees.
217 SmallSetVector<MCSymbol *, 4> DirectCallees;
218 };
219
220 enum CallGraphSectionFormatVersion : uint8_t {
221 V_0 = 0,
222 };
223
224 /// Output stream for the stack usage file (i.e., .su file).
225 std::unique_ptr<raw_fd_ostream> StackUsageStream;
226
227 /// List of symbols to be inserted into PC sections.
228 DenseMap<const MDNode *, SmallVector<const MCSymbol *>> PCSectionsSymbols;
229
230 static char ID;
231
232protected:
234
235 /// For dso_local functions, the current $local alias for the function.
237
238 /// A handle to the EH info emitter (if present).
240
241 // A vector of all Debuginfo emitters we should use. Protected so that
242 // targets can add their own. This vector maintains ownership of the
243 // emitters.
245 size_t NumUserHandlers = 0;
246
248
249private:
250 /// If generated on the fly this own the instance.
251 std::unique_ptr<MachineDominatorTree> OwnedMDT;
252
253 /// If generated on the fly this own the instance.
254 std::unique_ptr<MachineLoopInfo> OwnedMLI;
255
256 /// If the target supports dwarf debug info, this pointer is non-null.
257 DwarfDebug *DD = nullptr;
258
259 /// A handler that supports pseudo probe emission with embedded inline
260 /// context.
261 std::unique_ptr<PseudoProbeHandler> PP;
262
263 /// CFISection type the module needs i.e. either .eh_frame or .debug_frame.
264 CFISection ModuleCFISection = CFISection::None;
265
266 /// True if the module contains split-stack functions. This is used to
267 /// emit .note.GNU-split-stack section as required by the linker for
268 /// special handling split-stack function calling no-split-stack function.
269 bool HasSplitStack = false;
270
271 /// True if the module contains no-split-stack functions. This is used to emit
272 /// .note.GNU-no-split-stack section when it also contains functions without a
273 /// split stack prologue.
274 bool HasNoSplitStack = false;
275
276 /// True if debugging information is available in this module.
277 bool DbgInfoAvailable = false;
278
279protected:
280 AsmPrinter(TargetMachine &TM, std::unique_ptr<MCStreamer> Streamer,
281 char &ID = AsmPrinter::ID);
282
283 /// Create the DwarfDebug handler. Targets can override this to provide
284 /// custom debug information handling.
285 virtual DwarfDebug *createDwarfDebug();
286
287public:
288 ~AsmPrinter() override;
289
290 DwarfDebug *getDwarfDebug() { return DD; }
291 DwarfDebug *getDwarfDebug() const { return DD; }
292
293 uint16_t getDwarfVersion() const;
294 void setDwarfVersion(uint16_t Version);
295
296 bool isDwarf64() const;
297
298 /// Returns 4 for DWARF32 and 8 for DWARF64.
299 unsigned int getDwarfOffsetByteSize() const;
300
301 /// Returns 4 for DWARF32 and 12 for DWARF64.
302 unsigned int getUnitLengthFieldByteSize() const;
303
304 /// Returns information about the byte size of DW_FORM values.
305 dwarf::FormParams getDwarfFormParams() const;
306
307 bool isPositionIndependent() const;
308
309 /// Return true if assembly output should contain comments.
310 bool isVerbose() const { return VerboseAsm; }
311
312 /// Return a unique ID for the current function.
313 unsigned getFunctionNumber() const;
314
315 /// Return symbol for the function pseudo stack if the stack frame is not a
316 /// register based.
317 virtual const MCSymbol *getFunctionFrameSymbol() const { return nullptr; }
318
320 MCSymbol *getFunctionEnd() const { return CurrentFnEnd; }
321
322 // Return the exception symbol associated with the MBB section containing a
323 // given basic block.
324 MCSymbol *getMBBExceptionSym(const MachineBasicBlock &MBB);
325
326 /// Return the symbol to be used for the specified basic block when its
327 /// address is taken. This cannot be its normal LBB label because the block
328 /// may be accessed outside its containing function.
330 return getAddrLabelSymbolToEmit(BB).front();
331 }
332
333 /// Return the symbol to be used for the specified basic block when its
334 /// address is taken. If other blocks were RAUW'd to this one, we may have
335 /// to emit them as well, return the whole set.
336 ArrayRef<MCSymbol *> getAddrLabelSymbolToEmit(const BasicBlock *BB);
337
338 /// Creates a new symbol to be used for the end of a callsite at the specified
339 /// basic block.
340 MCSymbol *createCallsiteEndSymbol(const MachineBasicBlock &MBB);
341
342 /// If the specified function has had any references to address-taken blocks
343 /// generated, but the block got deleted, return the symbol now so we can
344 /// emit it. This prevents emitting a reference to a symbol that has no
345 /// definition.
346 void takeDeletedSymbolsForFunction(const Function *F,
347 std::vector<MCSymbol *> &Result);
348
349 /// Return information about object file lowering.
350 const TargetLoweringObjectFile &getObjFileLowering() const;
351
352 /// Return information about data layout.
353 const DataLayout &getDataLayout() const;
354
355 /// Return the pointer size from the TargetMachine
356 unsigned getPointerSize() const;
357
358 /// Return information about subtarget.
359 const MCSubtargetInfo &getSubtargetInfo() const;
360
361 void EmitToStreamer(MCStreamer &S, const MCInst &Inst);
362
363 /// Emits inital debug location directive.
364 void emitInitialRawDwarfLocDirective(const MachineFunction &MF);
365
366 /// Return the current section we are emitting to.
367 const MCSection *getCurrentSection() const;
368
369 void getNameWithPrefix(SmallVectorImpl<char> &Name,
370 const GlobalValue *GV) const;
371
372 MCSymbol *getSymbol(const GlobalValue *GV) const;
373
374 /// Similar to getSymbol() but preferred for references. On ELF, this uses a
375 /// local symbol if a reference to GV is guaranteed to be resolved to the
376 /// definition in the same module.
377 MCSymbol *getSymbolPreferLocal(const GlobalValue &GV) const;
378
380 return DwarfUsesRelocationsAcrossSections;
381 }
382
384 DwarfUsesRelocationsAcrossSections = Enable;
385 }
386
387 /// Returns a section suffix (hot or unlikely) for the constant if profiles
388 /// are available. Returns empty string otherwise.
389 StringRef getConstantSectionSuffix(const Constant *C) const;
390
391 /// If MI is an indirect call, add expected type IDs to indirect type ids
392 /// list. If MI is a direct call add the callee symbol to direct callsites
393 /// list of FuncCGInfo.
394 void handleCallsiteForCallgraph(
395 FunctionCallGraphInfo &FuncCGInfo,
396 const MachineFunction::CallSiteInfoMap &CallSitesInfoMap,
397 const MachineInstr &MI);
398
399 //===------------------------------------------------------------------===//
400 // XRay instrumentation implementation.
401 //===------------------------------------------------------------------===//
402public:
403 // This describes the kind of sled we're storing in the XRay table.
412
413 // The table will contain these structs that point to the sled, the function
414 // containing the sled, and what kind of sled (and whether they should always
415 // be instrumented). We also use a version identifier that the runtime can use
416 // to decide what to do with the sled, depending on the version of the sled.
422 const class Function *Fn;
424
425 LLVM_ABI void emit(int, MCStreamer *) const;
426 };
427
428 // All the sleds to be emitted.
430
431 // Helper function to record a given XRay sled.
432 void recordSled(MCSymbol *Sled, const MachineInstr &MI, SledKind Kind,
433 uint8_t Version = 0);
434
435 /// Emit a table with all XRay instrumentation points.
436 void emitXRayTable();
437
439
440 //===------------------------------------------------------------------===//
441 // MachineFunctionPass Implementation.
442 //===------------------------------------------------------------------===//
443
444 /// Record analysis usage.
445 void getAnalysisUsage(AnalysisUsage &AU) const override;
446
447 /// Set up the AsmPrinter when we are working on a new module. If your pass
448 /// overrides this, it must make sure to explicitly call this implementation.
449 bool doInitialization(Module &M) override;
450
451 /// Shut down the asmprinter. If you override this in your pass, you must make
452 /// sure to call it explicitly.
453 bool doFinalization(Module &M) override;
454
455 /// Emit the specified function out to the OutStreamer.
459 return false;
460 }
461
462 //===------------------------------------------------------------------===//
463 // Coarse grained IR lowering routines.
464 //===------------------------------------------------------------------===//
465
466 /// This should be called when a new MachineFunction is being processed from
467 /// runOnMachineFunction.
468 virtual void SetupMachineFunction(MachineFunction &MF);
469
470 /// This method emits the body and trailer for a function.
471 void emitFunctionBody();
472
473 void emitCFIInstruction(const MachineInstr &MI);
474
475 void emitFrameAlloc(const MachineInstr &MI);
476
477 void emitStackSizeSection(const MachineFunction &MF);
478
479 void emitStackUsage(const MachineFunction &MF);
480
481 void emitBBAddrMapSection(const MachineFunction &MF);
482
483 void emitKCFITrapEntry(const MachineFunction &MF, const MCSymbol *Symbol);
484 virtual void emitKCFITypeId(const MachineFunction &MF);
485
486 void emitCallGraphSection(const MachineFunction &MF,
487 FunctionCallGraphInfo &FuncCGInfo);
488
489 /// Helper to emit a symbol for the prefetch target associated with the given
490 /// BBID and callsite index. The symbol is emitted as a label and its linkage
491 /// is set based on the function's linkage.
492 void emitPrefetchTargetSymbol(const UniqueBBID &BBID, unsigned CallsiteIndex);
493
494 /// Emit prefetch targets that were not mapped to any basic block. These
495 /// targets are emitted at the beginning of the function body.
496 void emitDanglingPrefetchTargets();
497
498 void emitPseudoProbe(const MachineInstr &MI);
499
500 void emitRemarksSection(remarks::RemarkStreamer &RS);
501
502 /// Emits a label as reference for PC sections.
503 void emitPCSectionsLabel(const MachineFunction &MF, const MDNode &MD);
504
505 /// Emits the PC sections collected from instructions.
506 void emitPCSections(const MachineFunction &MF);
507
508 /// Get the CFISection type for a function.
509 CFISection getFunctionCFISectionType(const Function &F) const;
510
511 /// Get the CFISection type for a function.
512 CFISection getFunctionCFISectionType(const MachineFunction &MF) const;
513
514 /// Get the CFISection type for the module.
515 CFISection getModuleCFISectionType() const { return ModuleCFISection; }
516
517 /// Returns true if valid debug info is present.
518 bool hasDebugInfo() const { return DbgInfoAvailable; }
519
520 bool needsSEHMoves();
521
522 /// Since emitting CFI unwind information is entangled with supporting the
523 /// exceptions, this returns true for platforms which use CFI unwind
524 /// information for other purposes (debugging, sanitizers, ...) when
525 /// `MCAsmInfo::ExceptionsType == ExceptionHandling::None`.
526 bool usesCFIWithoutEH() const;
527
528 /// Print to the current output stream assembly representations of the
529 /// constants in the constant pool MCP. This is used to print out constants
530 /// which have been "spilled to memory" by the code generator.
531 virtual void emitConstantPool();
532
533 /// Print assembly representations of the jump tables used by the current
534 /// function to the current output stream.
535 virtual void emitJumpTableInfo();
536
537 /// Emit the specified global variable to the .s file.
538 virtual void emitGlobalVariable(const GlobalVariable *GV);
539
540 /// Check to see if the specified global is a special global used by LLVM. If
541 /// so, emit it and return true, otherwise do nothing and return false.
542 bool emitSpecialLLVMGlobal(const GlobalVariable *GV);
543
544 /// `llvm.global_ctors` and `llvm.global_dtors` are arrays of Structor
545 /// structs.
546 ///
547 /// Priority - init priority
548 /// Func - global initialization or global clean-up function
549 /// ComdatKey - associated data
550 struct Structor {
551 int Priority = 0;
552 Constant *Func = nullptr;
554
555 Structor() = default;
556 };
557
558 /// This method gathers an array of Structors and then sorts them out by
559 /// Priority.
560 /// @param List The initializer of `llvm.global_ctors` or `llvm.global_dtors`
561 /// array.
562 /// @param[out] Structors Sorted Structor structs by Priority.
564 SmallVector<Structor, 8> &Structors);
565
566 /// This method emits `llvm.global_ctors` or `llvm.global_dtors` list.
567 virtual void emitXXStructorList(const DataLayout &DL, const Constant *List,
568 bool IsCtor);
569
570 /// Emit an alignment directive to the specified power of two boundary. If a
571 /// global value is specified, and if that global has an explicit alignment
572 /// requested, it will override the alignment request if required for
573 /// correctness. Returns the effective alignment that was emitted (which may
574 /// exceed \p Alignment when \p GV has a stricter explicit alignment).
575 Align emitAlignment(Align Alignment, const GlobalObject *GV = nullptr,
576 unsigned MaxBytesToEmit = 0) const;
577
578 /// Lower the specified LLVM Constant to an MCExpr.
579 /// When BaseCV is present, we are lowering the element at BaseCV plus Offset.
580 virtual const MCExpr *lowerConstant(const Constant *CV,
581 const Constant *BaseCV = nullptr,
582 uint64_t Offset = 0);
583
584 /// Print a general LLVM constant to the .s file.
585 /// On AIX, when an alias refers to a sub-element of a global variable, the
586 /// label of that alias needs to be emitted before the corresponding element.
588 void emitGlobalConstant(const DataLayout &DL, const Constant *CV,
589 AliasMapTy *AliasList = nullptr);
590
591 /// Unnamed constant global variables solely contaning a pointer to
592 /// another globals variable act like a global variable "proxy", or GOT
593 /// equivalents, i.e., it's only used to hold the address of the latter. One
594 /// optimization is to replace accesses to these proxies by using the GOT
595 /// entry for the final global instead. Hence, we select GOT equivalent
596 /// candidates among all the module global variables, avoid emitting them
597 /// unnecessarily and finally replace references to them by pc relative
598 /// accesses to GOT entries.
600
601 /// Constant expressions using GOT equivalent globals may not be
602 /// eligible for PC relative GOT entry conversion, in such cases we need to
603 /// emit the proxies we previously omitted in EmitGlobalVariable.
604 void emitGlobalGOTEquivs();
605
606 //===------------------------------------------------------------------===//
607 // Overridable Hooks
608 //===------------------------------------------------------------------===//
609
610 void addAsmPrinterHandler(std::unique_ptr<AsmPrinterHandler> Handler);
611
612 // Targets can, or in the case of EmitInstruction, must implement these to
613 // customize output.
614
615 /// This virtual method can be overridden by targets that want to emit
616 /// something at the start of their file.
617 virtual void emitStartOfAsmFile(Module &) {}
618
619 /// This virtual method can be overridden by targets that want to emit
620 /// something at the end of their file.
621 virtual void emitEndOfAsmFile(Module &) {}
622
623 /// Targets can override this to emit stuff before the first basic block in
624 /// the function.
625 virtual void emitFunctionBodyStart() {}
626
627 /// Targets can override this to emit stuff after the last basic block in the
628 /// function.
629 virtual void emitFunctionBodyEnd() {}
630
631 /// Targets can override this to emit stuff at the start of a basic block.
632 /// By default, this method prints the label for the specified
633 /// MachineBasicBlock, an alignment (if present) and a comment describing it
634 /// if appropriate.
635 virtual void emitBasicBlockStart(const MachineBasicBlock &MBB);
636
637 /// Targets can override this to emit stuff at the end of a basic block.
638 virtual void emitBasicBlockEnd(const MachineBasicBlock &MBB);
639
640 /// Targets should implement this to emit instructions.
641 virtual void emitInstruction(const MachineInstr *) {
642 llvm_unreachable("EmitInstruction not implemented");
643 }
644
645 /// Return the symbol for the specified constant pool entry.
646 virtual MCSymbol *GetCPISymbol(unsigned CPID) const;
647
648 virtual void emitFunctionEntryLabel();
649
650 virtual void emitFunctionDescriptor() {
651 llvm_unreachable("Function descriptor is target-specific.");
652 }
653
654 virtual void emitMachineConstantPoolValue(MachineConstantPoolValue *MCPV);
655
656 /// Targets can override this to change how global constants that are part of
657 /// a C++ static/global constructor list are emitted.
658 virtual void emitXXStructor(const DataLayout &DL, const Constant *CV) {
660 }
661
662 virtual const MCExpr *lowerConstantPtrAuth(const ConstantPtrAuth &CPA) {
663 report_fatal_error("ptrauth constant lowering not implemented");
664 }
665
666 /// Lower the specified BlockAddress to an MCExpr.
667 virtual const MCExpr *lowerBlockAddressConstant(const BlockAddress &BA);
668
669 /// Return true if the basic block has exactly one predecessor and the control
670 /// transfer mechanism between the predecessor and this block is a
671 /// fall-through.
672 virtual bool
673 isBlockOnlyReachableByFallthrough(const MachineBasicBlock *MBB) const;
674
675 /// Targets can override this to customize the output of IMPLICIT_DEF
676 /// instructions in verbose mode.
677 virtual void emitImplicitDef(const MachineInstr *MI) const;
678
679 /// getSubtargetInfo() cannot be used where this is needed because we don't
680 /// have a MachineFunction when we're lowering a GlobalIFunc, and
681 /// getSubtargetInfo requires one. Override the implementation in targets
682 /// that support the Mach-O IFunc lowering.
684 return nullptr;
685 }
686
687 virtual void emitMachOIFuncStubBody(Module &M, const GlobalIFunc &GI,
688 MCSymbol *LazyPointer) {
690 "Mach-O IFunc lowering is not yet supported on this target");
691 }
692
694 MCSymbol *LazyPointer) {
696 "Mach-O IFunc lowering is not yet supported on this target");
697 }
698
699 /// Emit N NOP instructions.
700 void emitNops(unsigned N);
701
702 //===------------------------------------------------------------------===//
703 // Symbol Lowering Routines.
704 //===------------------------------------------------------------------===//
705
706 MCSymbol *createTempSymbol(const Twine &Name) const;
707
708 /// Return the MCSymbol for a private symbol with global value name as its
709 /// base, with the specified suffix.
710 MCSymbol *getSymbolWithGlobalValueBase(const GlobalValue *GV,
711 StringRef Suffix) const;
712
713 /// Return the MCSymbol for the specified ExternalSymbol.
714 MCSymbol *GetExternalSymbolSymbol(const Twine &Sym) const;
715
716 /// Return the symbol for the specified jump table entry.
717 MCSymbol *GetJTISymbol(unsigned JTID, bool isLinkerPrivate = false) const;
718
719 /// Return the symbol for the specified jump table .set
720 /// FIXME: privatize to AsmPrinter.
721 MCSymbol *GetJTSetSymbol(unsigned UID, unsigned MBBID) const;
722
723 /// Return the MCSymbol used to satisfy BlockAddress uses of the specified
724 /// basic block.
725 MCSymbol *GetBlockAddressSymbol(const BlockAddress *BA) const;
726 MCSymbol *GetBlockAddressSymbol(const BasicBlock *BB) const;
727
728 //===------------------------------------------------------------------===//
729 // Emission Helper Routines.
730 //===------------------------------------------------------------------===//
731
732 /// This is just convenient handler for printing offsets.
733 void printOffset(int64_t Offset, raw_ostream &OS) const;
734
735 /// Emit a byte directive and value.
736 void emitInt8(int Value) const;
737
738 /// Emit a short directive and value.
739 void emitInt16(int Value) const;
740
741 /// Emit a long directive and value.
742 void emitInt32(int Value) const;
743
744 /// Emit a long long directive and value.
745 void emitInt64(uint64_t Value) const;
746
747 /// Emit the specified signed leb128 value.
748 void emitSLEB128(int64_t Value, const char *Desc = nullptr) const;
749
750 /// Emit the specified unsigned leb128 value.
751 void emitULEB128(uint64_t Value, const char *Desc = nullptr,
752 unsigned PadTo = 0) const;
753
754 /// Emit something like ".long Hi-Lo" where the size in bytes of the directive
755 /// is specified by Size and Hi/Lo specify the labels. This implicitly uses
756 /// .set if it is available.
757 void emitLabelDifference(const MCSymbol *Hi, const MCSymbol *Lo,
758 unsigned Size) const;
759
760 /// Emit something like ".uleb128 Hi-Lo".
761 void emitLabelDifferenceAsULEB128(const MCSymbol *Hi,
762 const MCSymbol *Lo) const;
763
764 /// Emit something like ".long Label+Offset" where the size in bytes of the
765 /// directive is specified by Size and Label specifies the label. This
766 /// implicitly uses .set if it is available.
767 void emitLabelPlusOffset(const MCSymbol *Label, uint64_t Offset,
768 unsigned Size, bool IsSectionRelative = false) const;
769
770 /// Emit something like ".long Label" where the size in bytes of the directive
771 /// is specified by Size and Label specifies the label.
772 void emitLabelReference(const MCSymbol *Label, unsigned Size,
773 bool IsSectionRelative = false) const {
774 emitLabelPlusOffset(Label, 0, Size, IsSectionRelative);
775 }
776
777 //===------------------------------------------------------------------===//
778 // Dwarf Emission Helper Routines
779 //===------------------------------------------------------------------===//
780
781 /// Emit a .byte 42 directive that corresponds to an encoding. If verbose
782 /// assembly output is enabled, we output comments describing the encoding.
783 /// Desc is a string saying what the encoding is specifying (e.g. "LSDA").
784 void emitEncodingByte(unsigned Val, const char *Desc = nullptr) const;
785
786 /// Return the size of the encoding in bytes.
787 unsigned GetSizeOfEncodedValue(unsigned Encoding) const;
788
789 /// Emit reference to a ttype global with a specified encoding.
790 virtual void emitTTypeReference(const GlobalValue *GV, unsigned Encoding);
791
792 /// Emit a reference to a symbol for use in dwarf. Different object formats
793 /// represent this in different ways. Some use a relocation others encode
794 /// the label offset in its section.
795 void emitDwarfSymbolReference(const MCSymbol *Label,
796 bool ForceOffset = false) const;
797
798 /// Emit the 4- or 8-byte offset of a string from the start of its section.
799 ///
800 /// When possible, emit a DwarfStringPool section offset without any
801 /// relocations, and without using the symbol. Otherwise, defers to \a
802 /// emitDwarfSymbolReference().
803 ///
804 /// The length of the emitted value depends on the DWARF format.
805 void emitDwarfStringOffset(DwarfStringPoolEntry S) const;
806
807 /// Emit the 4-or 8-byte offset of a string from the start of its section.
811
812 /// Emit something like ".long Label + Offset" or ".quad Label + Offset"
813 /// depending on the DWARF format.
814 void emitDwarfOffset(const MCSymbol *Label, uint64_t Offset) const;
815
816 /// Emit 32- or 64-bit value depending on the DWARF format.
817 void emitDwarfLengthOrOffset(uint64_t Value) const;
818
819 /// Emit a unit length field. The actual format, DWARF32 or DWARF64, is chosen
820 /// according to the settings.
821 void emitDwarfUnitLength(uint64_t Length, const Twine &Comment) const;
822
823 /// Emit a unit length field. The actual format, DWARF32 or DWARF64, is chosen
824 /// according to the settings.
825 /// Return the end symbol generated inside, the caller needs to emit it.
826 MCSymbol *emitDwarfUnitLength(const Twine &Prefix,
827 const Twine &Comment) const;
828
829 /// Emit reference to a call site with a specified encoding
830 void emitCallSiteOffset(const MCSymbol *Hi, const MCSymbol *Lo,
831 unsigned Encoding) const;
832 /// Emit an integer value corresponding to the call site encoding
833 void emitCallSiteValue(uint64_t Value, unsigned Encoding) const;
834
835 /// Get the value for DW_AT_APPLE_isa. Zero if no isa encoding specified.
836 virtual unsigned getISAEncoding() { return 0; }
837
838 /// Emit the directive and value for debug thread local expression
839 ///
840 /// \p Value - The value to emit.
841 /// \p Size - The size of the integer (in bytes) to emit.
842 virtual void emitDebugValue(const MCExpr *Value, unsigned Size) const;
843
844 //===------------------------------------------------------------------===//
845 // Dwarf Lowering Routines
846 //===------------------------------------------------------------------===//
847
848 /// Emit frame instruction to describe the layout of the frame.
849 void emitCFIInstruction(const MCCFIInstruction &Inst) const;
850
851 /// Emit Dwarf abbreviation table.
852 template <typename T> void emitDwarfAbbrevs(const T &Abbrevs) const {
853 // For each abbreviation.
854 for (const auto &Abbrev : Abbrevs)
855 emitDwarfAbbrev(*Abbrev);
856
857 // Mark end of abbreviations.
858 emitULEB128(0, "EOM(3)");
859 }
860
861 void emitDwarfAbbrev(const DIEAbbrev &Abbrev) const;
862
863 /// Recursively emit Dwarf DIE tree.
864 void emitDwarfDIE(const DIE &Die) const;
865
866 //===------------------------------------------------------------------===//
867 // CodeView Helper Routines
868 //===------------------------------------------------------------------===//
869
870 /// Gets information required to create a CodeView debug symbol for a jump
871 /// table.
872 /// Return value is <Base Address, Base Offset, Branch Address, Entry Size>
873 virtual std::tuple<const MCSymbol *, uint64_t, const MCSymbol *,
875 getCodeViewJumpTableInfo(int JTI, const MachineInstr *BranchInstr,
876 const MCSymbol *BranchLabel) const;
877
878 //===------------------------------------------------------------------===//
879 // COFF Helper Routines
880 //===------------------------------------------------------------------===//
881
882 /// Emits symbols and data to allow functions marked with the
883 /// loader-replaceable attribute to be replaceable.
884 void emitCOFFReplaceableFunctionData(Module &M);
885
886 /// Emits the @feat.00 symbol indicating the features enabled in this module.
887 void emitCOFFFeatureSymbol(Module &M);
888
889 //===------------------------------------------------------------------===//
890 // Inline Asm Support
891 //===------------------------------------------------------------------===//
892
893 // These are hooks that targets can override to implement inline asm
894 // support. These should probably be moved out of AsmPrinter someday.
895
896 /// Print information related to the specified machine instr that is
897 /// independent of the operand, and may be independent of the instr itself.
898 /// This can be useful for portably encoding the comment character or other
899 /// bits of target-specific knowledge into the asmstrings. The syntax used is
900 /// ${:comment}. Targets can override this to add support for their own
901 /// strange codes.
902 virtual void PrintSpecial(const MachineInstr *MI, raw_ostream &OS,
903 StringRef Code) const;
904
905 /// Print the MachineOperand as a symbol. Targets with complex handling of
906 /// symbol references should override the base implementation.
907 virtual void PrintSymbolOperand(const MachineOperand &MO, raw_ostream &OS);
908
909 /// Print the specified operand of MI, an INLINEASM instruction, using the
910 /// specified assembler variant. Targets should override this to format as
911 /// appropriate. This method can return true if the operand is erroneous.
912 virtual bool PrintAsmOperand(const MachineInstr *MI, unsigned OpNo,
913 const char *ExtraCode, raw_ostream &OS);
914
915 /// Print the specified operand of MI, an INLINEASM instruction, using the
916 /// specified assembler variant as an address. Targets should override this to
917 /// format as appropriate. This method can return true if the operand is
918 /// erroneous.
919 virtual bool PrintAsmMemoryOperand(const MachineInstr *MI, unsigned OpNo,
920 const char *ExtraCode, raw_ostream &OS);
921
922 /// Let the target do anything it needs to do before emitting inlineasm.
923 /// \p StartInfo - the subtarget info before parsing inline asm
924 virtual void emitInlineAsmStart() const;
925
926 /// Let the target do anything it needs to do after emitting inlineasm.
927 /// This callback can be used restore the original mode in case the
928 /// inlineasm contains directives to switch modes.
929 /// \p StartInfo - the original subtarget info before inline asm
930 /// \p EndInfo - the final subtarget info after parsing the inline asm,
931 /// or NULL if the value is unknown.
932 virtual void emitInlineAsmEnd(const MCSubtargetInfo &StartInfo,
933 const MCSubtargetInfo *EndInfo,
934 const MachineInstr *MI);
935
936 /// This emits visibility information about symbol, if this is supported by
937 /// the target.
938 void emitVisibility(MCSymbol *Sym, unsigned Visibility,
939 bool IsDefinition = true) const;
940
941 /// This emits linkage information about \p GVSym based on \p GV, if this is
942 /// supported by the target.
943 virtual void emitLinkage(const GlobalValue *GV, MCSymbol *GVSym) const;
944
945 /// Return the alignment for the specified \p GV.
946 static Align getGVAlignment(const GlobalObject *GV, const DataLayout &DL,
947 Align InAlign = Align(1));
948
949private:
950 /// Private state for PrintSpecial()
951 // Assign a unique ID to this machine instruction.
952 mutable const MachineInstr *LastMI = nullptr;
953 mutable unsigned LastFn = 0;
954 mutable unsigned Counter = ~0U;
955
956 bool DwarfUsesRelocationsAcrossSections = false;
957
958 /// This method emits the header for the current function.
959 virtual void emitFunctionHeader();
960
961 /// This method emits a comment next to header for the current function.
962 virtual void emitFunctionHeaderComment();
963
964 /// This method emits prefix-like data before the current function.
965 void emitFunctionPrefix(ArrayRef<const Constant *> Prefix);
966
967 /// Emit a blob of inline asm to the output streamer.
968 virtual void
970 const MCTargetOptions &MCOptions,
971 const MDNode *LocMDNode = nullptr,
973 const MachineInstr *MI = nullptr);
974
975 /// This method formats and emits the specified machine instruction that is an
976 /// inline asm.
977 void emitInlineAsm(const MachineInstr *MI);
978
979 /// Add inline assembly info to the diagnostics machinery, so we can
980 /// emit file and position info. Returns SrcMgr memory buffer position.
981 unsigned addInlineAsmDiagBuffer(StringRef AsmStr,
982 const MDNode *LocMDNode) const;
983
984 //===------------------------------------------------------------------===//
985 // Internal Implementation Details
986 //===------------------------------------------------------------------===//
987
988 virtual void emitJumpTableImpl(const MachineJumpTableInfo &MJTI,
989 ArrayRef<unsigned> JumpTableIndices);
990
991 void emitJumpTableSizesSection(const MachineJumpTableInfo &MJTI,
992 const Function &F) const;
993
994 void emitLLVMUsedList(const ConstantArray *InitList);
995 /// Emit llvm.ident metadata in an '.ident' directive.
996 void emitModuleIdents(Module &M);
997 /// Emit bytes for llvm.commandline metadata.
998 virtual void emitModuleCommandLines(Module &M);
999
1000 GCMetadataPrinter *getOrCreateGCPrinter(GCStrategy &S);
1001 virtual void emitGlobalIFunc(Module &M, const GlobalIFunc &GI);
1002
1003 /// This method decides whether the specified basic block requires a label.
1004 bool shouldEmitLabelForBasicBlock(const MachineBasicBlock &MBB) const;
1005
1006protected:
1007 virtual void emitJumpTableEntry(const MachineJumpTableInfo &MJTI,
1008 const MachineBasicBlock *MBB,
1009 unsigned uid) const;
1010 virtual void emitGlobalAlias(const Module &M, const GlobalAlias &GA);
1012 return false;
1013 }
1014};
1015
1017 AsmPrinter &AsmPrinter);
1018
1020 MachineFunction &MF,
1021 AsmPrinter &AsmPrinter);
1022
1023} // end namespace llvm
1024
1025#endif // LLVM_CODEGEN_ASMPRINTER_H
MachineBasicBlock & MBB
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
#define LLVM_ABI
Definition Compiler.h:213
static void emitConstantPool(MCStreamer &Streamer, MCSection *Section, ConstantPool &CP)
static std::optional< TypeSize > getPointerSize(const Value *V, const DataLayout &DL, const TargetLibraryInfo &TLI, const Function *F)
This file defines the DenseMap class.
This file contains constants used for implementing Dwarf debug support.
IRTranslator LLVM IR MI
static void emitEncodingByte(MCObjectStreamer &Streamer, unsigned Encoding)
Definition MCDwarf.cpp:1386
#define F(x, y, z)
Definition MD5.cpp:54
Machine Check Debug Module
This file implements a map that provides insertion order iteration.
static void emitInlineAsm(LLVMContext &C, BasicBlock *BB, StringRef AsmText)
#define T
ModuleAnalysisManager MAM
static SDValue lowerConstant(SDValue Op, SelectionDAG &DAG, const RISCVSubtarget &Subtarget)
This file implements a set that has insertion order iteration characteristics.
This file defines the SmallVector class.
Represent the analysis usage information of a pass.
ArrayRef - Represent a constant reference to an array (0 or more elements consecutively in memory),...
Definition ArrayRef.h:40
Collects and handles AsmPrinter objects required to build debug or EH information.
virtual void emitInstruction(const MachineInstr *)
Targets should implement this to emit instructions.
Definition AsmPrinter.h:641
void emitULEB128(uint64_t Value, const char *Desc=nullptr, unsigned PadTo=0) const
Emit the specified unsigned leb128 value.
SmallVector< XRayFunctionEntry, 4 > Sleds
Definition AsmPrinter.h:429
MapVector< MBBSectionID, MBBSectionRange > MBBSectionRanges
Definition AsmPrinter.h:158
CFISection getModuleCFISectionType() const
Get the CFISection type for the module.
Definition AsmPrinter.h:515
MCSymbol * CurrentFnBegin
Definition AsmPrinter.h:233
MachineLoopInfo * MLI
This is a pointer to the current MachineLoopInfo.
Definition AsmPrinter.h:118
DwarfDebug * getDwarfDebug()
Definition AsmPrinter.h:290
std::function< MachineOptimizationRemarkEmitter *(MachineFunction &)> GetORE
Definition AsmPrinter.h:177
virtual const MCExpr * lowerConstantPtrAuth(const ConstantPtrAuth &CPA)
Definition AsmPrinter.h:662
void emitLabelPlusOffset(const MCSymbol *Label, uint64_t Offset, unsigned Size, bool IsSectionRelative=false) const
Emit something like ".long Label+Offset" where the size in bytes of the directive is specified by Siz...
TargetMachine & TM
Target machine description.
Definition AsmPrinter.h:94
void emitXRayTable()
Emit a table with all XRay instrumentation points.
DenseMap< const MachineBasicBlock *, SmallVector< MCSymbol *, 1 > > CurrentFnCallsiteEndSymbols
Vector of symbols marking the end of the callsites in the current function, keyed by their containing...
Definition AsmPrinter.h:144
Align emitAlignment(Align Alignment, const GlobalObject *GV=nullptr, unsigned MaxBytesToEmit=0) const
Emit an alignment directive to the specified power of two boundary.
DwarfDebug * getDwarfDebug() const
Definition AsmPrinter.h:291
MCSymbol * CurrentFnDescSym
The symbol for the current function descriptor on AIX.
Definition AsmPrinter.h:132
MCSymbol * CurrentFnBeginLocal
For dso_local functions, the current $local alias for the function.
Definition AsmPrinter.h:236
MapVector< const MCSymbol *, GOTEquivUsePair > GlobalGOTEquivs
Definition AsmPrinter.h:163
void emitDwarfStringOffset(DwarfStringPoolEntry S) const
Emit the 4- or 8-byte offset of a string from the start of its section.
void emitGlobalGOTEquivs()
Constant expressions using GOT equivalent globals may not be eligible for PC relative GOT entry conve...
MCSymbol * getFunctionBegin() const
Definition AsmPrinter.h:319
SmallVector< std::unique_ptr< EHStreamer >, 1 > EHHandlers
A handle to the EH info emitter (if present).
Definition AsmPrinter.h:239
virtual void emitMachOIFuncStubHelperBody(Module &M, const GlobalIFunc &GI, MCSymbol *LazyPointer)
Definition AsmPrinter.h:693
std::function< void(Module &)> EmitStackMaps
Definition AsmPrinter.h:182
MCSymbol * getAddrLabelSymbol(const BasicBlock *BB)
Return the symbol to be used for the specified basic block when its address is taken.
Definition AsmPrinter.h:329
virtual DwarfDebug * createDwarfDebug()
Create the DwarfDebug handler.
const MCAsmInfo * MAI
Target Asm Printer information.
Definition AsmPrinter.h:97
SmallVector< std::unique_ptr< AsmPrinterHandler >, 2 > Handlers
Definition AsmPrinter.h:244
MachineFunction * MF
The current machine function.
Definition AsmPrinter.h:109
void computeGlobalGOTEquivs(Module &M)
Unnamed constant global variables solely contaning a pointer to another globals variable act like a g...
virtual void SetupMachineFunction(MachineFunction &MF)
This should be called when a new MachineFunction is being processed from runOnMachineFunction.
void emitFunctionBody()
This method emits the body and trailer for a function.
MachineDominatorTree * MDT
This is a pointer to the current MachineDominatorTree.
Definition AsmPrinter.h:115
virtual void emitStartOfAsmFile(Module &)
This virtual method can be overridden by targets that want to emit something at the start of their fi...
Definition AsmPrinter.h:617
std::function< void(Module &)> FinishGCAssembly
Definition AsmPrinter.h:181
bool hasDebugInfo() const
Returns true if valid debug info is present.
Definition AsmPrinter.h:518
virtual void emitFunctionBodyStart()
Targets can override this to emit stuff before the first basic block in the function.
Definition AsmPrinter.h:625
std::function< MachineDominatorTree *(MachineFunction &)> GetMDT
Definition AsmPrinter.h:178
std::pair< const GlobalVariable *, unsigned > GOTEquivUsePair
Map global GOT equivalent MCSymbols to GlobalVariables and keep track of its number of uses by other ...
Definition AsmPrinter.h:162
void emitPatchableFunctionEntries()
void recordSled(MCSymbol *Sled, const MachineInstr &MI, SledKind Kind, uint8_t Version=0)
virtual void emitEndOfAsmFile(Module &)
This virtual method can be overridden by targets that want to emit something at the end of their file...
Definition AsmPrinter.h:621
bool doInitialization(Module &M) override
Set up the AsmPrinter when we are working on a new module.
virtual void emitMachOIFuncStubBody(Module &M, const GlobalIFunc &GI, MCSymbol *LazyPointer)
Definition AsmPrinter.h:687
void getAnalysisUsage(AnalysisUsage &AU) const override
Record analysis usage.
MachineOptimizationRemarkEmitter * ORE
Optimization remark emitter.
Definition AsmPrinter.h:121
DenseMap< uint64_t, SmallVector< const GlobalAlias *, 1 > > AliasMapTy
Print a general LLVM constant to the .s file.
Definition AsmPrinter.h:587
virtual bool shouldEmitWeakSwiftAsyncExtendedFramePointerFlags() const
AsmPrinter(TargetMachine &TM, std::unique_ptr< MCStreamer > Streamer, char &ID=AsmPrinter::ID)
void emitGlobalConstant(const DataLayout &DL, const Constant *CV, AliasMapTy *AliasList=nullptr)
EmitGlobalConstant - Print a general LLVM constant to the .s file.
virtual const MCSymbol * getFunctionFrameSymbol() const
Return symbol for the function pseudo stack if the stack frame is not a register based.
Definition AsmPrinter.h:317
void emitDwarfStringOffset(DwarfStringPoolEntryRef S) const
Emit the 4-or 8-byte offset of a string from the start of its section.
Definition AsmPrinter.h:808
std::function< void(Module &)> BeginGCAssembly
Definition AsmPrinter.h:180
MCSymbol * CurrentFnSym
The symbol for the current function.
Definition AsmPrinter.h:128
MachineModuleInfo * MMI
This is a pointer to the current MachineModuleInfo.
Definition AsmPrinter.h:112
void emitDwarfAbbrevs(const T &Abbrevs) const
Emit Dwarf abbreviation table.
Definition AsmPrinter.h:852
MCContext & OutContext
This is the context for the output file that we are streaming.
Definition AsmPrinter.h:101
const StaticDataProfileInfo * SDPI
Provides the profile information for constants.
Definition AsmPrinter.h:147
bool doFinalization(Module &M) override
Shut down the asmprinter.
virtual const MCSubtargetInfo * getIFuncMCSubtargetInfo() const
getSubtargetInfo() cannot be used where this is needed because we don't have a MachineFunction when w...
Definition AsmPrinter.h:683
virtual void emitXXStructorList(const DataLayout &DL, const Constant *List, bool IsCtor)
This method emits llvm.global_ctors or llvm.global_dtors list.
MCSymbol * CurrentPatchableFunctionEntrySym
The symbol for the entry in __patchable_function_entires.
Definition AsmPrinter.h:124
bool runOnMachineFunction(MachineFunction &MF) override
Emit the specified function out to the OutStreamer.
Definition AsmPrinter.h:456
void emitDwarfAbbrev(const DIEAbbrev &Abbrev) const
void setDwarfUsesRelocationsAcrossSections(bool Enable)
Definition AsmPrinter.h:383
std::unique_ptr< MCStreamer > OutStreamer
This is the MCStreamer object for the file we are generating.
Definition AsmPrinter.h:106
const ProfileSummaryInfo * PSI
The profile summary information.
Definition AsmPrinter.h:150
std::function< void()> AssertDebugEHFinalized
Definition AsmPrinter.h:183
void emitLabelReference(const MCSymbol *Label, unsigned Size, bool IsSectionRelative=false) const
Emit something like ".long Label" where the size in bytes of the directive is specified by Size and L...
Definition AsmPrinter.h:772
virtual void emitFunctionDescriptor()
Definition AsmPrinter.h:650
size_t NumUserHandlers
Definition AsmPrinter.h:245
MCSymbol * CurrentFnSymForSize
The symbol used to represent the start of the current function for the purpose of calculating its siz...
Definition AsmPrinter.h:137
std::function< MachineLoopInfo *(MachineFunction &)> GetMLI
Definition AsmPrinter.h:179
std::function< MachineModuleInfo *()> GetMMI
Definition AsmPrinter.h:176
virtual unsigned getISAEncoding()
Get the value for DW_AT_APPLE_isa. Zero if no isa encoding specified.
Definition AsmPrinter.h:836
bool isVerbose() const
Return true if assembly output should contain comments.
Definition AsmPrinter.h:310
MCSymbol * getFunctionEnd() const
Definition AsmPrinter.h:320
virtual void emitXXStructor(const DataLayout &DL, const Constant *CV)
Targets can override this to change how global constants that are part of a C++ static/global constru...
Definition AsmPrinter.h:658
void preprocessXXStructorList(const DataLayout &DL, const Constant *List, SmallVector< Structor, 8 > &Structors)
This method gathers an array of Structors and then sorts them out by Priority.
ArrayRef< MCSymbol * > getAddrLabelSymbolToEmit(const BasicBlock *BB)
Return the symbol to be used for the specified basic block when its address is taken.
virtual void emitFunctionBodyEnd()
Targets can override this to emit stuff after the last basic block in the function.
Definition AsmPrinter.h:629
bool doesDwarfUseRelocationsAcrossSections() const
Definition AsmPrinter.h:379
@ None
Do not emit either .eh_frame or .debug_frame.
Definition AsmPrinter.h:167
@ Debug
Emit .debug_frame.
Definition AsmPrinter.h:169
void addAsmPrinterHandler(std::unique_ptr< AsmPrinterHandler > Handler)
LLVM Basic Block Representation.
Definition BasicBlock.h:62
The address of a basic block.
Definition Constants.h:1065
ConstantArray - Constant Array Declarations.
Definition Constants.h:576
A signed pointer, in the ptrauth sense.
Definition Constants.h:1198
This is an important base class in LLVM.
Definition Constant.h:43
Dwarf abbreviation, describes the organization of a debug information object.
Definition DIE.h:80
A structured debug information entry.
Definition DIE.h:828
A parsed version of the target data layout string in and methods for querying it.
Definition DataLayout.h:64
Base class for debug information backends.
Collects and handles dwarf debug information.
Definition DwarfDebug.h:352
DwarfStringPoolEntryRef: Dwarf string pool entry reference.
const DwarfStringPoolEntry & getEntry() const
Emits exception handling directives.
Definition EHStreamer.h:30
GCMetadataPrinter - Emits GC metadata as assembly code.
GCStrategy describes a garbage collector algorithm's code generation requirements,...
Definition GCStrategy.h:64
This class is intended to be used as a base class for asm properties and features specific to the tar...
Definition MCAsmInfo.h:64
Context object for machine code objects.
Definition MCContext.h:83
Base class for the full range of assembler expressions which are needed for parsing.
Definition MCExpr.h:34
Instances of this class represent a single low-level machine instruction.
Definition MCInst.h:188
Instances of this class represent a uniqued identifier for a section in the current translation unit.
Definition MCSection.h:569
Streaming machine code generation interface.
Definition MCStreamer.h:222
Generic base class for all target subtargets.
MCSymbol - Instances of this class represent a symbol name in the MC file, and MCSymbols are created ...
Definition MCSymbol.h:42
Metadata node.
Definition Metadata.h:1080
Abstract base class for all machine specific constantpool value subclasses.
DominatorTree Class - Concrete subclass of DominatorTreeBase that is used to compute a normal dominat...
DenseMap< const MachineInstr *, CallSiteInfo > CallSiteInfoMap
Representation of each machine instruction.
This class contains meta information specific to a module.
MachineOperand class - Representation of each machine instruction operand.
This class implements a map that also provides access to all stored values in a deterministic order.
Definition MapVector.h:36
A Module instance is used to store all the information related to an LLVM module.
Definition Module.h:67
Analysis providing profile information.
A SetVector that performs no allocations if smaller than a certain size.
Definition SetVector.h:339
This class consists of common code factored out of the SmallVector class to reduce code duplication b...
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
A class that holds the constants that represent static data and their profile information and provide...
StringRef - Represent a constant reference to a string, i.e.
Definition StringRef.h:55
Primary interface to the complete machine description for the target machine.
Twine - A lightweight data structure for efficiently representing the concatenation of temporary valu...
Definition Twine.h:82
LLVM Value Representation.
Definition Value.h:75
This class implements an extremely fast bulk output stream that can only output to a stream.
Definition raw_ostream.h:53
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
@ C
The default llvm calling convention, compatible with C.
Definition CallingConv.h:34
This is an optimization pass for GlobalISel generic memory operations.
@ Offset
Definition DWP.cpp:532
@ Length
Definition DWP.cpp:532
AnalysisManager< MachineFunction > MachineFunctionAnalysisManager
Op::Description Desc
FunctionAddr VTableAddr uintptr_t uintptr_t Version
Definition InstrProf.h:334
void setupModuleAsmPrinter(Module &M, ModuleAnalysisManager &MAM, AsmPrinter &AsmPrinter)
LLVM_ABI void report_fatal_error(Error Err, bool gen_crash_diag=true)
Definition Error.cpp:163
void setupMachineFunctionAsmPrinter(MachineFunctionAnalysisManager &MFAM, MachineFunction &MF, AsmPrinter &AsmPrinter)
AnalysisManager< Module > ModuleAnalysisManager
Convenience typedef for the Module analysis manager.
Definition MIRParser.h:39
@ Enable
Enable colors.
Definition WithColor.h:47
#define N
This struct is a compact representation of a valid (non-zero power of two) alignment.
Definition Alignment.h:39
Map a basic block section ID to the begin and end symbols of that section which determine the section...
Definition AsmPrinter.h:154
LLVM_ABI void emit(int, MCStreamer *) const
Data for a string pool entry.
A helper struct providing information about the byte size of DW_FORM values that vary in size dependi...
Definition Dwarf.h:1110