1 //===-- ARMAsmPrinter.h - ARM implementation of AsmPrinter ------*- C++ -*-===//
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
7 //===----------------------------------------------------------------------===//
9 #ifndef LLVM_LIB_TARGET_ARM_ARMASMPRINTER_H
10 #define LLVM_LIB_TARGET_ARM_ARMASMPRINTER_H
12 #include "ARMSubtarget.h"
13 #include "llvm/CodeGen/AsmPrinter.h"
14 #include "llvm/Target/TargetMachine.h"
18 class ARMFunctionInfo
;
20 class MachineConstantPool
;
31 class LLVM_LIBRARY_VISIBILITY ARMAsmPrinter
: public AsmPrinter
{
33 /// Subtarget - Keep a pointer to the ARMSubtarget around so that we can
34 /// make the right decision when printing asm code for different targets.
35 const ARMSubtarget
*Subtarget
;
37 /// AFI - Keep a pointer to ARMFunctionInfo for the current
41 /// MCP - Keep a pointer to constantpool entries of the current
43 const MachineConstantPool
*MCP
;
45 /// InConstantPool - Maintain state when emitting a sequence of constant
46 /// pool entries so we can properly mark them as data regions.
49 /// ThumbIndirectPads - These maintain a per-function list of jump pad
50 /// labels used for ARMv4t thumb code to make register indirect calls.
51 SmallVector
<std::pair
<unsigned, MCSymbol
*>, 4> ThumbIndirectPads
;
53 /// OptimizationGoals - Maintain a combined optimization goal for all
54 /// functions in a module: one of Tag_ABI_optimization_goals values,
55 /// -1 if uninitialized, 0 if conflicting goals
56 int OptimizationGoals
;
58 /// List of globals that have had their storage promoted to a constant
59 /// pool. This lives between calls to runOnMachineFunction and collects
60 /// data from every MachineFunction. It is used during doFinalization
61 /// when all non-function globals are emitted.
62 SmallPtrSet
<const GlobalVariable
*,2> PromotedGlobals
;
63 /// Set of globals in PromotedGlobals that we've emitted labels for.
64 /// We need to emit labels even for promoted globals so that DWARF
65 /// debug info can link properly.
66 SmallPtrSet
<const GlobalVariable
*,2> EmittedPromotedGlobalLabels
;
69 explicit ARMAsmPrinter(TargetMachine
&TM
,
70 std::unique_ptr
<MCStreamer
> Streamer
);
72 StringRef
getPassName() const override
{
73 return "ARM Assembly Printer";
76 void printOperand(const MachineInstr
*MI
, int OpNum
, raw_ostream
&O
);
78 bool PrintAsmOperand(const MachineInstr
*MI
, unsigned OpNum
,
79 unsigned AsmVariant
, const char *ExtraCode
,
80 raw_ostream
&O
) override
;
81 bool PrintAsmMemoryOperand(const MachineInstr
*MI
, unsigned OpNum
,
82 unsigned AsmVariant
, const char *ExtraCode
,
83 raw_ostream
&O
) override
;
85 void emitInlineAsmEnd(const MCSubtargetInfo
&StartInfo
,
86 const MCSubtargetInfo
*EndInfo
) const override
;
88 void EmitJumpTableAddrs(const MachineInstr
*MI
);
89 void EmitJumpTableInsts(const MachineInstr
*MI
);
90 void EmitJumpTableTBInst(const MachineInstr
*MI
, unsigned OffsetWidth
);
91 void EmitInstruction(const MachineInstr
*MI
) override
;
92 bool runOnMachineFunction(MachineFunction
&F
) override
;
94 void EmitConstantPool() override
{
95 // we emit constant pools customly!
97 void EmitFunctionBodyEnd() override
;
98 void EmitFunctionEntryLabel() override
;
99 void EmitStartOfAsmFile(Module
&M
) override
;
100 void EmitEndOfAsmFile(Module
&M
) override
;
101 void EmitXXStructor(const DataLayout
&DL
, const Constant
*CV
) override
;
102 void EmitGlobalVariable(const GlobalVariable
*GV
) override
;
104 MCSymbol
*GetCPISymbol(unsigned CPID
) const override
;
106 // lowerOperand - Convert a MachineOperand into the equivalent MCOperand.
107 bool lowerOperand(const MachineOperand
&MO
, MCOperand
&MCOp
);
109 //===------------------------------------------------------------------===//
110 // XRay implementation
111 //===------------------------------------------------------------------===//
113 // XRay-specific lowering for ARM.
114 void LowerPATCHABLE_FUNCTION_ENTER(const MachineInstr
&MI
);
115 void LowerPATCHABLE_FUNCTION_EXIT(const MachineInstr
&MI
);
116 void LowerPATCHABLE_TAIL_CALL(const MachineInstr
&MI
);
119 void EmitSled(const MachineInstr
&MI
, SledKind Kind
);
121 // Helpers for EmitStartOfAsmFile() and EmitEndOfAsmFile()
122 void emitAttributes();
124 // Generic helper used to emit e.g. ARMv5 mul pseudos
125 void EmitPatchedInstruction(const MachineInstr
*MI
, unsigned TargetOpc
);
127 void EmitUnwindingInstruction(const MachineInstr
*MI
);
129 // emitPseudoExpansionLowering - tblgen'erated.
130 bool emitPseudoExpansionLowering(MCStreamer
&OutStreamer
,
131 const MachineInstr
*MI
);
134 unsigned getISAEncoding() override
{
135 // ARM/Darwin adds ISA to the DWARF info for each function.
136 const Triple
&TT
= TM
.getTargetTriple();
137 if (!TT
.isOSBinFormatMachO())
139 bool isThumb
= TT
.isThumb() ||
140 TT
.getSubArch() == Triple::ARMSubArch_v7m
||
141 TT
.getSubArch() == Triple::ARMSubArch_v6m
;
142 return isThumb
? ARM::DW_ISA_ARM_thumb
: ARM::DW_ISA_ARM_arm
;
146 MCOperand
GetSymbolRef(const MachineOperand
&MO
, const MCSymbol
*Symbol
);
147 MCSymbol
*GetARMJTIPICJumpTableLabel(unsigned uid
) const;
149 MCSymbol
*GetARMGVSymbol(const GlobalValue
*GV
, unsigned char TargetFlags
);
152 /// EmitMachineConstantPoolValue - Print a machine constantpool value to
154 void EmitMachineConstantPoolValue(MachineConstantPoolValue
*MCPV
) override
;
156 } // end namespace llvm