LLVM 22.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/SmallSet.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
172private:
173 MCSymbol *CurrentFnEnd = nullptr;
174
175 /// Map a basic block section ID to the exception symbol associated with that
176 /// section. Map entries are assigned and looked up via
177 /// AsmPrinter::getMBBExceptionSym.
178 DenseMap<MBBSectionID, MCSymbol *> MBBSectionExceptionSyms;
179
180 // The symbol used to represent the start of the current BB section of the
181 // function. This is used to calculate the size of the BB section.
182 MCSymbol *CurrentSectionBeginSym = nullptr;
183
184 /// This map keeps track of which symbol is being used for the specified basic
185 /// block's address of label.
186 std::unique_ptr<AddrLabelMap> AddrLabelSymbols;
187
188 /// The garbage collection metadata printer table.
190
191 /// Emit comments in assembly output if this is true.
192 bool VerboseAsm;
193
194 /// Store symbols and type identifiers used to create callgraph section
195 /// entries related to a function.
196 struct FunctionCallGraphInfo {
197 /// Numeric type identifier used in callgraph section for indirect calls
198 /// and targets.
199 using CGTypeId = uint64_t;
200
201 /// Map type identifiers to callsite labels. Labels are generated for each
202 /// indirect callsite in the function.
204 SmallSet<MCSymbol *, 4> DirectCallees;
205 };
206
207 /// Enumeration of function kinds, and their mapping to function kind values
208 /// stored in callgraph section entries.
209 enum class FunctionKind : uint64_t {
210 /// Function cannot be target to indirect calls.
211 NOT_INDIRECT_TARGET = 0,
212
213 /// Function may be target to indirect calls but its type id is unknown.
214 INDIRECT_TARGET_UNKNOWN_TID = 1,
215
216 /// Function may be target to indirect calls and its type id is known.
217 INDIRECT_TARGET_KNOWN_TID = 2,
218 };
219
220 enum CallGraphSectionFormatVersion : uint64_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).
239 // Only for EHStreamer subtypes, but some C++ compilers will incorrectly warn
240 // us if we declare that directly.
242
243 // A vector of all Debuginfo emitters we should use. Protected so that
244 // targets can add their own. This vector maintains ownership of the
245 // emitters.
247 size_t NumUserHandlers = 0;
248
250
251private:
252 /// If generated on the fly this own the instance.
253 std::unique_ptr<MachineDominatorTree> OwnedMDT;
254
255 /// If generated on the fly this own the instance.
256 std::unique_ptr<MachineLoopInfo> OwnedMLI;
257
258 /// If the target supports dwarf debug info, this pointer is non-null.
259 DwarfDebug *DD = nullptr;
260
261 /// A handler that supports pseudo probe emission with embedded inline
262 /// context.
263 std::unique_ptr<PseudoProbeHandler> PP;
264
265 /// CFISection type the module needs i.e. either .eh_frame or .debug_frame.
266 CFISection ModuleCFISection = CFISection::None;
267
268 /// True if the module contains split-stack functions. This is used to
269 /// emit .note.GNU-split-stack section as required by the linker for
270 /// special handling split-stack function calling no-split-stack function.
271 bool HasSplitStack = false;
272
273 /// True if the module contains no-split-stack functions. This is used to emit
274 /// .note.GNU-no-split-stack section when it also contains functions without a
275 /// split stack prologue.
276 bool HasNoSplitStack = false;
277
278 /// True if debugging information is available in this module.
279 bool DbgInfoAvailable = false;
280
281protected:
282 AsmPrinter(TargetMachine &TM, std::unique_ptr<MCStreamer> Streamer,
283 char &ID = AsmPrinter::ID);
284
285public:
286 ~AsmPrinter() override;
287
288 DwarfDebug *getDwarfDebug() { return DD; }
289 DwarfDebug *getDwarfDebug() const { return DD; }
290
291 uint16_t getDwarfVersion() const;
292 void setDwarfVersion(uint16_t Version);
293
294 bool isDwarf64() const;
295
296 /// Returns 4 for DWARF32 and 8 for DWARF64.
297 unsigned int getDwarfOffsetByteSize() const;
298
299 /// Returns 4 for DWARF32 and 12 for DWARF64.
300 unsigned int getUnitLengthFieldByteSize() const;
301
302 /// Returns information about the byte size of DW_FORM values.
303 dwarf::FormParams getDwarfFormParams() const;
304
305 bool isPositionIndependent() const;
306
307 /// Return true if assembly output should contain comments.
308 bool isVerbose() const { return VerboseAsm; }
309
310 /// Return a unique ID for the current function.
311 unsigned getFunctionNumber() const;
312
313 /// Return symbol for the function pseudo stack if the stack frame is not a
314 /// register based.
315 virtual const MCSymbol *getFunctionFrameSymbol() const { return nullptr; }
316
318 MCSymbol *getFunctionEnd() const { return CurrentFnEnd; }
319
320 // Return the exception symbol associated with the MBB section containing a
321 // given basic block.
322 MCSymbol *getMBBExceptionSym(const MachineBasicBlock &MBB);
323
324 /// Return the symbol to be used for the specified basic block when its
325 /// address is taken. This cannot be its normal LBB label because the block
326 /// may be accessed outside its containing function.
328 return getAddrLabelSymbolToEmit(BB).front();
329 }
330
331 /// Return the symbol to be used for the specified basic block when its
332 /// address is taken. If other blocks were RAUW'd to this one, we may have
333 /// to emit them as well, return the whole set.
334 ArrayRef<MCSymbol *> getAddrLabelSymbolToEmit(const BasicBlock *BB);
335
336 /// Creates a new symbol to be used for the end of a callsite at the specified
337 /// basic block.
338 MCSymbol *createCallsiteEndSymbol(const MachineBasicBlock &MBB);
339
340 /// If the specified function has had any references to address-taken blocks
341 /// generated, but the block got deleted, return the symbol now so we can
342 /// emit it. This prevents emitting a reference to a symbol that has no
343 /// definition.
344 void takeDeletedSymbolsForFunction(const Function *F,
345 std::vector<MCSymbol *> &Result);
346
347 /// Return information about object file lowering.
348 const TargetLoweringObjectFile &getObjFileLowering() const;
349
350 /// Return information about data layout.
351 const DataLayout &getDataLayout() const;
352
353 /// Return the pointer size from the TargetMachine
354 unsigned getPointerSize() const;
355
356 /// Return information about subtarget.
357 const MCSubtargetInfo &getSubtargetInfo() const;
358
359 void EmitToStreamer(MCStreamer &S, const MCInst &Inst);
360
361 /// Emits inital debug location directive.
362 void emitInitialRawDwarfLocDirective(const MachineFunction &MF);
363
364 /// Return the current section we are emitting to.
365 const MCSection *getCurrentSection() const;
366
367 void getNameWithPrefix(SmallVectorImpl<char> &Name,
368 const GlobalValue *GV) const;
369
370 MCSymbol *getSymbol(const GlobalValue *GV) const;
371
372 /// Similar to getSymbol() but preferred for references. On ELF, this uses a
373 /// local symbol if a reference to GV is guaranteed to be resolved to the
374 /// definition in the same module.
375 MCSymbol *getSymbolPreferLocal(const GlobalValue &GV) const;
376
378 return DwarfUsesRelocationsAcrossSections;
379 }
380
382 DwarfUsesRelocationsAcrossSections = Enable;
383 }
384
385 /// Returns a section suffix (hot or unlikely) for the constant if profiles
386 /// are available. Returns empty string otherwise.
387 StringRef getConstantSectionSuffix(const Constant *C) const;
388
389 /// Iff MI is an indirect call, generate and emit a label after the callsites
390 /// which will be used to populate the .callgraph section. For direct
391 /// callsites add the callee symbol to direct callsites list of FuncCGInfo.
392 void handleCallsiteForCallgraph(
393 FunctionCallGraphInfo &FuncCGInfo,
394 const MachineFunction::CallSiteInfoMap &CallSitesInfoMap,
395 const MachineInstr &MI);
396
397 //===------------------------------------------------------------------===//
398 // XRay instrumentation implementation.
399 //===------------------------------------------------------------------===//
400public:
401 // This describes the kind of sled we're storing in the XRay table.
410
411 // The table will contain these structs that point to the sled, the function
412 // containing the sled, and what kind of sled (and whether they should always
413 // be instrumented). We also use a version identifier that the runtime can use
414 // to decide what to do with the sled, depending on the version of the sled.
420 const class Function *Fn;
422
423 LLVM_ABI void emit(int, MCStreamer *) const;
424 };
425
426 // All the sleds to be emitted.
428
429 // Helper function to record a given XRay sled.
430 void recordSled(MCSymbol *Sled, const MachineInstr &MI, SledKind Kind,
431 uint8_t Version = 0);
432
433 /// Emit a table with all XRay instrumentation points.
434 void emitXRayTable();
435
437
438 //===------------------------------------------------------------------===//
439 // MachineFunctionPass Implementation.
440 //===------------------------------------------------------------------===//
441
442 /// Record analysis usage.
443 void getAnalysisUsage(AnalysisUsage &AU) const override;
444
445 /// Set up the AsmPrinter when we are working on a new module. If your pass
446 /// overrides this, it must make sure to explicitly call this implementation.
447 bool doInitialization(Module &M) override;
448
449 /// Shut down the asmprinter. If you override this in your pass, you must make
450 /// sure to call it explicitly.
451 bool doFinalization(Module &M) override;
452
453 /// Emit the specified function out to the OutStreamer.
457 return false;
458 }
459
460 //===------------------------------------------------------------------===//
461 // Coarse grained IR lowering routines.
462 //===------------------------------------------------------------------===//
463
464 /// This should be called when a new MachineFunction is being processed from
465 /// runOnMachineFunction.
466 virtual void SetupMachineFunction(MachineFunction &MF);
467
468 /// This method emits the body and trailer for a function.
469 void emitFunctionBody();
470
471 void emitCFIInstruction(const MachineInstr &MI);
472
473 void emitFrameAlloc(const MachineInstr &MI);
474
475 void emitStackSizeSection(const MachineFunction &MF);
476
477 void emitStackUsage(const MachineFunction &MF);
478
479 void emitBBAddrMapSection(const MachineFunction &MF);
480
481 void emitKCFITrapEntry(const MachineFunction &MF, const MCSymbol *Symbol);
482 virtual void emitKCFITypeId(const MachineFunction &MF);
483
484 void emitCallGraphSection(const MachineFunction &MF,
485 FunctionCallGraphInfo &FuncCGInfo);
486
487 void emitPseudoProbe(const MachineInstr &MI);
488
489 void emitRemarksSection(remarks::RemarkStreamer &RS);
490
491 /// Emits a label as reference for PC sections.
492 void emitPCSectionsLabel(const MachineFunction &MF, const MDNode &MD);
493
494 /// Emits the PC sections collected from instructions.
495 void emitPCSections(const MachineFunction &MF);
496
497 /// Get the CFISection type for a function.
498 CFISection getFunctionCFISectionType(const Function &F) const;
499
500 /// Get the CFISection type for a function.
501 CFISection getFunctionCFISectionType(const MachineFunction &MF) const;
502
503 /// Get the CFISection type for the module.
504 CFISection getModuleCFISectionType() const { return ModuleCFISection; }
505
506 /// Returns true if valid debug info is present.
507 bool hasDebugInfo() const { return DbgInfoAvailable; }
508
509 bool needsSEHMoves();
510
511 /// Since emitting CFI unwind information is entangled with supporting the
512 /// exceptions, this returns true for platforms which use CFI unwind
513 /// information for other purposes (debugging, sanitizers, ...) when
514 /// `MCAsmInfo::ExceptionsType == ExceptionHandling::None`.
515 bool usesCFIWithoutEH() const;
516
517 /// Print to the current output stream assembly representations of the
518 /// constants in the constant pool MCP. This is used to print out constants
519 /// which have been "spilled to memory" by the code generator.
520 virtual void emitConstantPool();
521
522 /// Print assembly representations of the jump tables used by the current
523 /// function to the current output stream.
524 virtual void emitJumpTableInfo();
525
526 /// Emit the specified global variable to the .s file.
527 virtual void emitGlobalVariable(const GlobalVariable *GV);
528
529 /// Check to see if the specified global is a special global used by LLVM. If
530 /// so, emit it and return true, otherwise do nothing and return false.
531 bool emitSpecialLLVMGlobal(const GlobalVariable *GV);
532
533 /// `llvm.global_ctors` and `llvm.global_dtors` are arrays of Structor
534 /// structs.
535 ///
536 /// Priority - init priority
537 /// Func - global initialization or global clean-up function
538 /// ComdatKey - associated data
539 struct Structor {
540 int Priority = 0;
541 Constant *Func = nullptr;
543
544 Structor() = default;
545 };
546
547 /// This method gathers an array of Structors and then sorts them out by
548 /// Priority.
549 /// @param List The initializer of `llvm.global_ctors` or `llvm.global_dtors`
550 /// array.
551 /// @param[out] Structors Sorted Structor structs by Priority.
553 SmallVector<Structor, 8> &Structors);
554
555 /// This method emits `llvm.global_ctors` or `llvm.global_dtors` list.
556 virtual void emitXXStructorList(const DataLayout &DL, const Constant *List,
557 bool IsCtor);
558
559 /// Emit an alignment directive to the specified power of two boundary. If a
560 /// global value is specified, and if that global has an explicit alignment
561 /// requested, it will override the alignment request if required for
562 /// correctness.
563 void emitAlignment(Align Alignment, const GlobalObject *GV = nullptr,
564 unsigned MaxBytesToEmit = 0) const;
565
566 /// Lower the specified LLVM Constant to an MCExpr.
567 /// When BaseCV is present, we are lowering the element at BaseCV plus Offset.
568 virtual const MCExpr *lowerConstant(const Constant *CV,
569 const Constant *BaseCV = nullptr,
570 uint64_t Offset = 0);
571
572 /// Print a general LLVM constant to the .s file.
573 /// On AIX, when an alias refers to a sub-element of a global variable, the
574 /// label of that alias needs to be emitted before the corresponding element.
576 void emitGlobalConstant(const DataLayout &DL, const Constant *CV,
577 AliasMapTy *AliasList = nullptr);
578
579 /// Unnamed constant global variables solely contaning a pointer to
580 /// another globals variable act like a global variable "proxy", or GOT
581 /// equivalents, i.e., it's only used to hold the address of the latter. One
582 /// optimization is to replace accesses to these proxies by using the GOT
583 /// entry for the final global instead. Hence, we select GOT equivalent
584 /// candidates among all the module global variables, avoid emitting them
585 /// unnecessarily and finally replace references to them by pc relative
586 /// accesses to GOT entries.
588
589 /// Constant expressions using GOT equivalent globals may not be
590 /// eligible for PC relative GOT entry conversion, in such cases we need to
591 /// emit the proxies we previously omitted in EmitGlobalVariable.
592 void emitGlobalGOTEquivs();
593
594 /// Emit the stack maps.
595 void emitStackMaps();
596
597 //===------------------------------------------------------------------===//
598 // Overridable Hooks
599 //===------------------------------------------------------------------===//
600
601 void addAsmPrinterHandler(std::unique_ptr<AsmPrinterHandler> Handler);
602
603 // Targets can, or in the case of EmitInstruction, must implement these to
604 // customize output.
605
606 /// This virtual method can be overridden by targets that want to emit
607 /// something at the start of their file.
608 virtual void emitStartOfAsmFile(Module &) {}
609
610 /// This virtual method can be overridden by targets that want to emit
611 /// something at the end of their file.
612 virtual void emitEndOfAsmFile(Module &) {}
613
614 /// Targets can override this to emit stuff before the first basic block in
615 /// the function.
616 virtual void emitFunctionBodyStart() {}
617
618 /// Targets can override this to emit stuff after the last basic block in the
619 /// function.
620 virtual void emitFunctionBodyEnd() {}
621
622 /// Targets can override this to emit stuff at the start of a basic block.
623 /// By default, this method prints the label for the specified
624 /// MachineBasicBlock, an alignment (if present) and a comment describing it
625 /// if appropriate.
626 virtual void emitBasicBlockStart(const MachineBasicBlock &MBB);
627
628 /// Targets can override this to emit stuff at the end of a basic block.
629 virtual void emitBasicBlockEnd(const MachineBasicBlock &MBB);
630
631 /// Targets should implement this to emit instructions.
632 virtual void emitInstruction(const MachineInstr *) {
633 llvm_unreachable("EmitInstruction not implemented");
634 }
635
636 /// Return the symbol for the specified constant pool entry.
637 virtual MCSymbol *GetCPISymbol(unsigned CPID) const;
638
639 virtual void emitFunctionEntryLabel();
640
641 virtual void emitFunctionDescriptor() {
642 llvm_unreachable("Function descriptor is target-specific.");
643 }
644
645 virtual void emitMachineConstantPoolValue(MachineConstantPoolValue *MCPV);
646
647 /// Targets can override this to change how global constants that are part of
648 /// a C++ static/global constructor list are emitted.
649 virtual void emitXXStructor(const DataLayout &DL, const Constant *CV) {
651 }
652
653 virtual const MCExpr *lowerConstantPtrAuth(const ConstantPtrAuth &CPA) {
654 report_fatal_error("ptrauth constant lowering not implemented");
655 }
656
657 /// Lower the specified BlockAddress to an MCExpr.
658 virtual const MCExpr *lowerBlockAddressConstant(const BlockAddress &BA);
659
660 /// Return true if the basic block has exactly one predecessor and the control
661 /// transfer mechanism between the predecessor and this block is a
662 /// fall-through.
663 virtual bool
664 isBlockOnlyReachableByFallthrough(const MachineBasicBlock *MBB) const;
665
666 /// Targets can override this to customize the output of IMPLICIT_DEF
667 /// instructions in verbose mode.
668 virtual void emitImplicitDef(const MachineInstr *MI) const;
669
670 /// getSubtargetInfo() cannot be used where this is needed because we don't
671 /// have a MachineFunction when we're lowering a GlobalIFunc, and
672 /// getSubtargetInfo requires one. Override the implementation in targets
673 /// that support the Mach-O IFunc lowering.
675 return nullptr;
676 }
677
678 virtual void emitMachOIFuncStubBody(Module &M, const GlobalIFunc &GI,
679 MCSymbol *LazyPointer) {
681 "Mach-O IFunc lowering is not yet supported on this target");
682 }
683
685 MCSymbol *LazyPointer) {
687 "Mach-O IFunc lowering is not yet supported on this target");
688 }
689
690 /// Emit N NOP instructions.
691 void emitNops(unsigned N);
692
693 //===------------------------------------------------------------------===//
694 // Symbol Lowering Routines.
695 //===------------------------------------------------------------------===//
696
697 MCSymbol *createTempSymbol(const Twine &Name) const;
698
699 /// Return the MCSymbol for a private symbol with global value name as its
700 /// base, with the specified suffix.
701 MCSymbol *getSymbolWithGlobalValueBase(const GlobalValue *GV,
702 StringRef Suffix) const;
703
704 /// Return the MCSymbol for the specified ExternalSymbol.
705 MCSymbol *GetExternalSymbolSymbol(const Twine &Sym) const;
706
707 /// Return the symbol for the specified jump table entry.
708 MCSymbol *GetJTISymbol(unsigned JTID, bool isLinkerPrivate = false) const;
709
710 /// Return the symbol for the specified jump table .set
711 /// FIXME: privatize to AsmPrinter.
712 MCSymbol *GetJTSetSymbol(unsigned UID, unsigned MBBID) const;
713
714 /// Return the MCSymbol used to satisfy BlockAddress uses of the specified
715 /// basic block.
716 MCSymbol *GetBlockAddressSymbol(const BlockAddress *BA) const;
717 MCSymbol *GetBlockAddressSymbol(const BasicBlock *BB) const;
718
719 //===------------------------------------------------------------------===//
720 // Emission Helper Routines.
721 //===------------------------------------------------------------------===//
722
723 /// This is just convenient handler for printing offsets.
724 void printOffset(int64_t Offset, raw_ostream &OS) const;
725
726 /// Emit a byte directive and value.
727 void emitInt8(int Value) const;
728
729 /// Emit a short directive and value.
730 void emitInt16(int Value) const;
731
732 /// Emit a long directive and value.
733 void emitInt32(int Value) const;
734
735 /// Emit a long long directive and value.
736 void emitInt64(uint64_t Value) const;
737
738 /// Emit the specified signed leb128 value.
739 void emitSLEB128(int64_t Value, const char *Desc = nullptr) const;
740
741 /// Emit the specified unsigned leb128 value.
742 void emitULEB128(uint64_t Value, const char *Desc = nullptr,
743 unsigned PadTo = 0) const;
744
745 /// Emit something like ".long Hi-Lo" where the size in bytes of the directive
746 /// is specified by Size and Hi/Lo specify the labels. This implicitly uses
747 /// .set if it is available.
748 void emitLabelDifference(const MCSymbol *Hi, const MCSymbol *Lo,
749 unsigned Size) const;
750
751 /// Emit something like ".uleb128 Hi-Lo".
752 void emitLabelDifferenceAsULEB128(const MCSymbol *Hi,
753 const MCSymbol *Lo) const;
754
755 /// Emit something like ".long Label+Offset" where the size in bytes of the
756 /// directive is specified by Size and Label specifies the label. This
757 /// implicitly uses .set if it is available.
758 void emitLabelPlusOffset(const MCSymbol *Label, uint64_t Offset,
759 unsigned Size, bool IsSectionRelative = false) const;
760
761 /// Emit something like ".long Label" where the size in bytes of the directive
762 /// is specified by Size and Label specifies the label.
763 void emitLabelReference(const MCSymbol *Label, unsigned Size,
764 bool IsSectionRelative = false) const {
765 emitLabelPlusOffset(Label, 0, Size, IsSectionRelative);
766 }
767
768 //===------------------------------------------------------------------===//
769 // Dwarf Emission Helper Routines
770 //===------------------------------------------------------------------===//
771
772 /// Emit a .byte 42 directive that corresponds to an encoding. If verbose
773 /// assembly output is enabled, we output comments describing the encoding.
774 /// Desc is a string saying what the encoding is specifying (e.g. "LSDA").
775 void emitEncodingByte(unsigned Val, const char *Desc = nullptr) const;
776
777 /// Return the size of the encoding in bytes.
778 unsigned GetSizeOfEncodedValue(unsigned Encoding) const;
779
780 /// Emit reference to a ttype global with a specified encoding.
781 virtual void emitTTypeReference(const GlobalValue *GV, unsigned Encoding);
782
783 /// Emit a reference to a symbol for use in dwarf. Different object formats
784 /// represent this in different ways. Some use a relocation others encode
785 /// the label offset in its section.
786 void emitDwarfSymbolReference(const MCSymbol *Label,
787 bool ForceOffset = false) const;
788
789 /// Emit the 4- or 8-byte offset of a string from the start of its section.
790 ///
791 /// When possible, emit a DwarfStringPool section offset without any
792 /// relocations, and without using the symbol. Otherwise, defers to \a
793 /// emitDwarfSymbolReference().
794 ///
795 /// The length of the emitted value depends on the DWARF format.
796 void emitDwarfStringOffset(DwarfStringPoolEntry S) const;
797
798 /// Emit the 4-or 8-byte offset of a string from the start of its section.
802
803 /// Emit something like ".long Label + Offset" or ".quad Label + Offset"
804 /// depending on the DWARF format.
805 void emitDwarfOffset(const MCSymbol *Label, uint64_t Offset) const;
806
807 /// Emit 32- or 64-bit value depending on the DWARF format.
808 void emitDwarfLengthOrOffset(uint64_t Value) const;
809
810 /// Emit a unit length field. The actual format, DWARF32 or DWARF64, is chosen
811 /// according to the settings.
812 void emitDwarfUnitLength(uint64_t Length, const Twine &Comment) const;
813
814 /// Emit a unit length field. The actual format, DWARF32 or DWARF64, is chosen
815 /// according to the settings.
816 /// Return the end symbol generated inside, the caller needs to emit it.
817 MCSymbol *emitDwarfUnitLength(const Twine &Prefix,
818 const Twine &Comment) const;
819
820 /// Emit reference to a call site with a specified encoding
821 void emitCallSiteOffset(const MCSymbol *Hi, const MCSymbol *Lo,
822 unsigned Encoding) const;
823 /// Emit an integer value corresponding to the call site encoding
824 void emitCallSiteValue(uint64_t Value, unsigned Encoding) const;
825
826 /// Get the value for DW_AT_APPLE_isa. Zero if no isa encoding specified.
827 virtual unsigned getISAEncoding() { return 0; }
828
829 /// Emit the directive and value for debug thread local expression
830 ///
831 /// \p Value - The value to emit.
832 /// \p Size - The size of the integer (in bytes) to emit.
833 virtual void emitDebugValue(const MCExpr *Value, unsigned Size) const;
834
835 //===------------------------------------------------------------------===//
836 // Dwarf Lowering Routines
837 //===------------------------------------------------------------------===//
838
839 /// Emit frame instruction to describe the layout of the frame.
840 void emitCFIInstruction(const MCCFIInstruction &Inst) const;
841
842 /// Emit Dwarf abbreviation table.
843 template <typename T> void emitDwarfAbbrevs(const T &Abbrevs) const {
844 // For each abbreviation.
845 for (const auto &Abbrev : Abbrevs)
846 emitDwarfAbbrev(*Abbrev);
847
848 // Mark end of abbreviations.
849 emitULEB128(0, "EOM(3)");
850 }
851
852 void emitDwarfAbbrev(const DIEAbbrev &Abbrev) const;
853
854 /// Recursively emit Dwarf DIE tree.
855 void emitDwarfDIE(const DIE &Die) const;
856
857 //===------------------------------------------------------------------===//
858 // CodeView Helper Routines
859 //===------------------------------------------------------------------===//
860
861 /// Gets information required to create a CodeView debug symbol for a jump
862 /// table.
863 /// Return value is <Base Address, Base Offset, Branch Address, Entry Size>
864 virtual std::tuple<const MCSymbol *, uint64_t, const MCSymbol *,
866 getCodeViewJumpTableInfo(int JTI, const MachineInstr *BranchInstr,
867 const MCSymbol *BranchLabel) const;
868
869 //===------------------------------------------------------------------===//
870 // COFF Helper Routines
871 //===------------------------------------------------------------------===//
872
873 /// Emits symbols and data to allow functions marked with the
874 /// loader-replaceable attribute to be replaceable.
875 void emitCOFFReplaceableFunctionData(Module &M);
876
877 /// Emits the @feat.00 symbol indicating the features enabled in this module.
878 void emitCOFFFeatureSymbol(Module &M);
879
880 //===------------------------------------------------------------------===//
881 // Inline Asm Support
882 //===------------------------------------------------------------------===//
883
884 // These are hooks that targets can override to implement inline asm
885 // support. These should probably be moved out of AsmPrinter someday.
886
887 /// Print information related to the specified machine instr that is
888 /// independent of the operand, and may be independent of the instr itself.
889 /// This can be useful for portably encoding the comment character or other
890 /// bits of target-specific knowledge into the asmstrings. The syntax used is
891 /// ${:comment}. Targets can override this to add support for their own
892 /// strange codes.
893 virtual void PrintSpecial(const MachineInstr *MI, raw_ostream &OS,
894 StringRef Code) const;
895
896 /// Print the MachineOperand as a symbol. Targets with complex handling of
897 /// symbol references should override the base implementation.
898 virtual void PrintSymbolOperand(const MachineOperand &MO, raw_ostream &OS);
899
900 /// Print the specified operand of MI, an INLINEASM instruction, using the
901 /// specified assembler variant. Targets should override this to format as
902 /// appropriate. This method can return true if the operand is erroneous.
903 virtual bool PrintAsmOperand(const MachineInstr *MI, unsigned OpNo,
904 const char *ExtraCode, raw_ostream &OS);
905
906 /// Print the specified operand of MI, an INLINEASM instruction, using the
907 /// specified assembler variant as an address. Targets should override this to
908 /// format as appropriate. This method can return true if the operand is
909 /// erroneous.
910 virtual bool PrintAsmMemoryOperand(const MachineInstr *MI, unsigned OpNo,
911 const char *ExtraCode, raw_ostream &OS);
912
913 /// Let the target do anything it needs to do before emitting inlineasm.
914 /// \p StartInfo - the subtarget info before parsing inline asm
915 virtual void emitInlineAsmStart() const;
916
917 /// Let the target do anything it needs to do after emitting inlineasm.
918 /// This callback can be used restore the original mode in case the
919 /// inlineasm contains directives to switch modes.
920 /// \p StartInfo - the original subtarget info before inline asm
921 /// \p EndInfo - the final subtarget info after parsing the inline asm,
922 /// or NULL if the value is unknown.
923 virtual void emitInlineAsmEnd(const MCSubtargetInfo &StartInfo,
924 const MCSubtargetInfo *EndInfo) const;
925
926 /// This emits visibility information about symbol, if this is supported by
927 /// the target.
928 void emitVisibility(MCSymbol *Sym, unsigned Visibility,
929 bool IsDefinition = true) const;
930
931 /// This emits linkage information about \p GVSym based on \p GV, if this is
932 /// supported by the target.
933 virtual void emitLinkage(const GlobalValue *GV, MCSymbol *GVSym) const;
934
935 /// Return the alignment for the specified \p GV.
936 static Align getGVAlignment(const GlobalObject *GV, const DataLayout &DL,
937 Align InAlign = Align(1));
938
939private:
940 /// Private state for PrintSpecial()
941 // Assign a unique ID to this machine instruction.
942 mutable const MachineInstr *LastMI = nullptr;
943 mutable unsigned LastFn = 0;
944 mutable unsigned Counter = ~0U;
945
946 bool DwarfUsesRelocationsAcrossSections = false;
947
948 /// This method emits the header for the current function.
949 virtual void emitFunctionHeader();
950
951 /// This method emits a comment next to header for the current function.
952 virtual void emitFunctionHeaderComment();
953
954 /// This method emits prefix-like data before the current function.
955 void emitFunctionPrefix(ArrayRef<const Constant *> Prefix);
956
957 /// Emit a blob of inline asm to the output streamer.
958 void
960 const MCTargetOptions &MCOptions,
961 const MDNode *LocMDNode = nullptr,
962 InlineAsm::AsmDialect AsmDialect = InlineAsm::AD_ATT) const;
963
964 /// This method formats and emits the specified machine instruction that is an
965 /// inline asm.
966 void emitInlineAsm(const MachineInstr *MI) const;
967
968 /// Add inline assembly info to the diagnostics machinery, so we can
969 /// emit file and position info. Returns SrcMgr memory buffer position.
970 unsigned addInlineAsmDiagBuffer(StringRef AsmStr,
971 const MDNode *LocMDNode) const;
972
973 //===------------------------------------------------------------------===//
974 // Internal Implementation Details
975 //===------------------------------------------------------------------===//
976
977 virtual void emitJumpTableImpl(const MachineJumpTableInfo &MJTI,
978 ArrayRef<unsigned> JumpTableIndices);
979
980 void emitJumpTableSizesSection(const MachineJumpTableInfo &MJTI,
981 const Function &F) const;
982
983 void emitLLVMUsedList(const ConstantArray *InitList);
984 /// Emit llvm.ident metadata in an '.ident' directive.
985 void emitModuleIdents(Module &M);
986 /// Emit bytes for llvm.commandline metadata.
987 virtual void emitModuleCommandLines(Module &M);
988
989 GCMetadataPrinter *getOrCreateGCPrinter(GCStrategy &S);
990 void emitGlobalIFunc(Module &M, const GlobalIFunc &GI);
991
992 /// This method decides whether the specified basic block requires a label.
993 bool shouldEmitLabelForBasicBlock(const MachineBasicBlock &MBB) const;
994
995protected:
996 virtual void emitJumpTableEntry(const MachineJumpTableInfo &MJTI,
997 const MachineBasicBlock *MBB,
998 unsigned uid) const;
999 virtual void emitGlobalAlias(const Module &M, const GlobalAlias &GA);
1001 return false;
1002 }
1003};
1004
1005} // end namespace llvm
1006
1007#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:1376
#define F(x, y, z)
Definition MD5.cpp:55
This file implements a map that provides insertion order iteration.
static void emitInlineAsm(LLVMContext &C, BasicBlock *BB, StringRef AsmText)
#define T
static SDValue lowerConstant(SDValue Op, SelectionDAG &DAG, const RISCVSubtarget &Subtarget)
This file defines the SmallSet class.
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:41
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:632
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:427
MapVector< MBBSectionID, MBBSectionRange > MBBSectionRanges
Definition AsmPrinter.h:158
CFISection getModuleCFISectionType() const
Get the CFISection type for the module.
Definition AsmPrinter.h:504
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:288
virtual const MCExpr * lowerConstantPtrAuth(const ConstantPtrAuth &CPA)
Definition AsmPrinter.h:653
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
DwarfDebug * getDwarfDebug() const
Definition AsmPrinter.h:289
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:317
virtual void emitMachOIFuncStubHelperBody(Module &M, const GlobalIFunc &GI, MCSymbol *LazyPointer)
Definition AsmPrinter.h:684
MCSymbol * getAddrLabelSymbol(const BasicBlock *BB)
Return the symbol to be used for the specified basic block when its address is taken.
Definition AsmPrinter.h:327
const MCAsmInfo * MAI
Target Asm Printer information.
Definition AsmPrinter.h:97
SmallVector< std::unique_ptr< AsmPrinterHandler >, 2 > Handlers
Definition AsmPrinter.h:246
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:608
void emitStackMaps()
Emit the stack maps.
bool hasDebugInfo() const
Returns true if valid debug info is present.
Definition AsmPrinter.h:507
virtual void emitFunctionBodyStart()
Targets can override this to emit stuff before the first basic block in the function.
Definition AsmPrinter.h:616
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:612
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:678
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:575
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:315
void emitDwarfStringOffset(DwarfStringPoolEntryRef S) const
Emit the 4-or 8-byte offset of a string from the start of its section.
Definition AsmPrinter.h:799
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:843
void emitAlignment(Align Alignment, const GlobalObject *GV=nullptr, unsigned MaxBytesToEmit=0) const
Emit an alignment directive to the specified power of two boundary.
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:674
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:454
void emitDwarfAbbrev(const DIEAbbrev &Abbrev) const
void setDwarfUsesRelocationsAcrossSections(bool Enable)
Definition AsmPrinter.h:381
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
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:763
virtual void emitFunctionDescriptor()
Definition AsmPrinter.h:641
size_t NumUserHandlers
Definition AsmPrinter.h:247
MCSymbol * CurrentFnSymForSize
The symbol used to represent the start of the current function for the purpose of calculating its siz...
Definition AsmPrinter.h:137
virtual unsigned getISAEncoding()
Get the value for DW_AT_APPLE_isa. Zero if no isa encoding specified.
Definition AsmPrinter.h:827
bool isVerbose() const
Return true if assembly output should contain comments.
Definition AsmPrinter.h:308
MCSymbol * getFunctionEnd() const
Definition AsmPrinter.h:318
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:649
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.
SmallVector< std::unique_ptr< AsmPrinterHandler >, 1 > EHHandlers
A handle to the EH info emitter (if present).
Definition AsmPrinter.h:241
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:620
bool doesDwarfUseRelocationsAcrossSections() const
Definition AsmPrinter.h:377
@ 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:899
ConstantArray - Constant Array Declarations.
Definition Constants.h:433
A signed pointer, in the ptrauth sense.
Definition Constants.h:1032
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:63
Base class for debug information backends.
Collects and handles dwarf debug information.
Definition DwarfDebug.h:351
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:521
Streaming machine code generation interface.
Definition MCStreamer.h:220
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:1077
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.
SmallSet - This maintains a set of unique values, optimizing for the case when the set is small (less...
Definition SmallSet.h:133
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:477
@ Length
Definition DWP.cpp:477
Op::Description Desc
FunctionAddr VTableAddr uintptr_t uintptr_t Version
Definition InstrProf.h:302
LLVM_ABI void report_fatal_error(Error Err, bool gen_crash_diag=true)
Definition Error.cpp:167
@ 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:1101