LLVM  8.0.0svn
MCObjectFileInfo.h
Go to the documentation of this file.
1 //===-- llvm/MC/MCObjectFileInfo.h - Object File Info -----------*- C++ -*-===//
2 //
3 // The LLVM Compiler Infrastructure
4 //
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9 //
10 // This file describes common object file formats.
11 //
12 //===----------------------------------------------------------------------===//
13 
14 #ifndef LLVM_MC_MCOBJECTFILEINFO_H
15 #define LLVM_MC_MCOBJECTFILEINFO_H
16 
17 #include "llvm/ADT/DenseMap.h"
18 #include "llvm/ADT/Triple.h"
19 #include "llvm/MC/MCSymbol.h"
20 #include "llvm/Support/CodeGen.h"
21 
22 namespace llvm {
23 class MCContext;
24 class MCSection;
25 
27 protected:
28  /// True if .comm supports alignment. This is a hack for as long as we
29  /// support 10.4 Tiger, whose assembler doesn't support alignment on comm.
31 
32  /// True if target object file supports a weak_definition of constant 0 for an
33  /// omitted EH frame.
35 
36  /// True if the target object file supports emitting a compact unwind section
37  /// without an associated EH frame section.
39 
40  /// OmitDwarfIfHaveCompactUnwind - True if the target object file
41  /// supports having some functions with compact unwind and other with
42  /// dwarf unwind.
44 
45  /// FDE CFI encoding. Controls the encoding of the begin label in the
46  /// .eh_frame section. Unlike the LSDA encoding, personality encoding, and
47  /// type encodings, this is something that the assembler just "knows" about
48  /// its target
49  unsigned FDECFIEncoding = 0;
50 
51  /// Compact unwind encoding indicating that we should emit only an EH frame.
53 
54  /// Section directive for standard text.
56 
57  /// Section directive for standard data.
59 
60  /// Section that is default initialized to zero.
62 
63  /// Section that is readonly and can contain arbitrary initialized data.
64  /// Targets are not required to have a readonly section. If they don't,
65  /// various bits of code will fall back to using the data section for
66  /// constants.
68 
69  /// If exception handling is supported by the target, this is the section the
70  /// Language Specific Data Area information is emitted to.
72 
73  /// If exception handling is supported by the target and the target can
74  /// support a compact representation of the CIE and FDE, this is the section
75  /// to emit them into.
77 
78  // Dwarf sections for debug info. If a target supports debug info, these must
79  // be set.
92  // The pubnames section is no longer generated by default. The generation
93  // can be enabled by a compiler flag.
95 
96  /// Accelerator table sections. DwarfDebugNamesSection is the DWARF v5
97  /// accelerator table, while DwarfAccelNamesSection, DwarfAccelObjCSection,
98  /// DwarfAccelNamespaceSection, DwarfAccelTypesSection are pre-DWARF v5
99  /// extensions.
105 
106  // These are used for the Fission separate debug information files.
114 
115  /// The DWARF v5 string offset and address table sections.
118  /// The DWARF v5 range list section.
120 
121  /// The DWARF v5 range list section for fission.
123 
124  // These are for Fission DWP files.
127 
128  /// Section for newer gnu pubnames.
130  /// Section for newer gnu pubtypes.
132 
133  // Section for Swift AST
135 
139 
140  /// Extra TLS Variable Data section.
141  ///
142  /// If the target needs to put additional information for a TLS variable,
143  /// it'll go here.
145 
146  /// Section directive for Thread Local data. ELF, MachO, COFF, and Wasm.
147  MCSection *TLSDataSection; // Defaults to ".tdata".
148 
149  /// Section directive for Thread Local uninitialized data.
150  ///
151  /// Null if this target doesn't support a BSS section. ELF and MachO only.
152  MCSection *TLSBSSSection; // Defaults to ".tbss".
153 
154  /// StackMap section.
156 
157  /// FaultMap section.
159 
160  /// EH frame section.
161  ///
162  /// It is initialized on demand so it can be overwritten (with uniquing).
164 
165  /// Section containing metadata on function stack sizes.
168 
169  // ELF specific sections.
175 
176  // MachO specific sections.
177 
178  /// Section for thread local structure information.
179  ///
180  /// Contains the source code name of the variable, visibility and a pointer to
181  /// the initial value (.tdata or .tbss).
182  MCSection *TLSTLVSection; // Defaults to ".tlv".
183 
184  /// Section for thread local data initialization functions.
185  const MCSection *TLSThreadInitSection; // Defaults to ".thread_init_func".
186 
202 
203  /// COFF specific sections.
209 
210 public:
211  void InitMCObjectFileInfo(const Triple &TT, bool PIC, MCContext &ctx,
212  bool LargeCodeModel = false);
213 
216  }
219  }
222  }
223 
226  }
227 
228  unsigned getFDEEncoding() const { return FDECFIEncoding; }
229 
232  }
233 
234  MCSection *getTextSection() const { return TextSection; }
235  MCSection *getDataSection() const { return DataSection; }
236  MCSection *getBSSSection() const { return BSSSection; }
238  MCSection *getLSDASection() const { return LSDASection; }
249  }
252  }
255  }
262 
264  return DwarfDebugNamesSection;
265  }
267  return DwarfAccelNamesSection;
268  }
272  }
274  return DwarfAccelTypesSection;
275  }
277  MCSection *getDwarfTypesSection(uint64_t Hash) const;
288  }
292 
295  }
297  return COFFDebugTypesSection;
298  }
301  }
302 
304  const MCSection *getTLSDataSection() const { return TLSDataSection; }
306 
309 
310  MCSection *getStackSizesSection(const MCSection &TextSec) const;
311 
312  // ELF specific sections.
315  return MergeableConst4Section;
316  }
318  return MergeableConst8Section;
319  }
322  }
325  }
326 
327  // MachO specific sections.
328  const MCSection *getTLSTLVSection() const { return TLSTLVSection; }
330  return TLSThreadInitSection;
331  }
332  const MCSection *getCStringSection() const { return CStringSection; }
333  const MCSection *getUStringSection() const { return UStringSection; }
336  return ConstTextCoalSection;
337  }
338  const MCSection *getConstDataSection() const { return ConstDataSection; }
339  const MCSection *getDataCoalSection() const { return DataCoalSection; }
341  return ConstDataCoalSection;
342  }
347  }
350  }
353  }
356  }
359  }
362  }
363 
364  // COFF specific sections.
370 
372  return EHFrameSection;
373  }
374 
376  Environment getObjectFileType() const { return Env; }
377 
378  bool isPositionIndependent() const { return PositionIndependent; }
379 
380 private:
381  Environment Env;
382  bool PositionIndependent;
383  MCContext *Ctx;
384  Triple TT;
385 
386  void initMachOMCObjectFileInfo(const Triple &T);
387  void initELFMCObjectFileInfo(const Triple &T, bool Large);
388  void initCOFFMCObjectFileInfo(const Triple &T);
389  void initWasmMCObjectFileInfo(const Triple &T);
390 
391 public:
392  const Triple &getTargetTriple() const { return TT; }
393 };
394 
395 } // end namespace llvm
396 
397 #endif
Instances of this class represent a uniqued identifier for a section in the current translation unit...
Definition: MCSection.h:39
MCSection * MergeableConst4Section
MCSection * DwarfStrOffSection
The DWARF v5 string offset and address table sections.
const MCSection * getConstDataSection() const
MCSection * getDwarfStrOffSection() const
MCSection * getDwarfTUIndexSection() const
MCSection * getDwarfAccelObjCSection() const
MCSection * getDwarfCUIndexSection() const
MCSection * getDwarfStrSection() const
Compute iterated dominance frontiers using a linear time algorithm.
Definition: AllocatorList.h:24
MCSection * getCOFFDebugTypesSection() const
const MCSection * getTLSTLVSection() const
MCSection * getDwarfLineSection() const
MCSection * getStackMapSection() const
MCSection * DwarfPubTypesSection
MCSection * getDwarfLocSection() const
MCSection * DwarfGnuPubTypesSection
Section for newer gnu pubtypes.
MCSection * getTLSBSSSection() const
const MCSection * getFourByteConstantSection() const
MCSection * StackMapSection
StackMap section.
MCSection * SixteenByteConstantSection
MCSection * DwarfRnglistsSection
The DWARF v5 range list section.
MCSection * TextSection
Section directive for standard text.
MCSection * getEHFrameSection()
MCSection * ConstTextCoalSection
MCSection * getDwarfAccelNamesSection() const
const MCSection * getConstDataCoalSection() const
MCSection * LazySymbolPointerSection
MCSection * getDwarfLineStrSection() const
MCSection * getDwarfARangesSection() const
bool getSupportsCompactUnwindWithoutEHFrame() const
MCSection * getCOFFGlobalTypeHashesSection() const
MCSection * getDwarfRnglistsDWOSection() const
MCSection * getDwarfRnglistsSection() const
MCSection * getDwarfPubNamesSection() const
MCSection * getReadOnlySection() const
MCSection * MergeableConst32Section
MCSection * DwarfDebugNamesSection
Accelerator table sections.
MCSection * getDwarfMacinfoSection() const
MCSection * getDwarfLocDWOSection() const
MCSection * COFFDebugTypesSection
const MCSection * getCStringSection() const
MCSection * MergeableConst16Section
MCSection * DwarfPubNamesSection
bool getCommDirectiveSupportsAlignment() const
MCSection * getBSSSection() const
MCSection * getDataSection() const
MCSection * EightByteConstantSection
unsigned getCompactUnwindDwarfEHFrameOnly() const
MCSection * getStackSizesSection(const MCSection &TextSec) const
MCSection * getDwarfFrameSection() const
MCSection * TLSDataSection
Section directive for Thread Local data. ELF, MachO, COFF, and Wasm.
MCSection * getDataBSSSection() const
bool getOmitDwarfIfHaveCompactUnwind() const
Context object for machine code objects.
Definition: MCContext.h:63
MCSection * getSXDataSection() const
const MCSection * DwarfDebugInlineSection
const MCSection * getDwarfDebugInlineSection() const
bool getSupportsWeakOmittedEHFrame() const
MCSection * getCOFFDebugSymbolsSection() const
MCSection * ConstDataCoalSection
MCSection * DrectveSection
COFF specific sections.
MCSection * getCompactUnwindSection() const
MCSection * getPDataSection() const
MCSection * DwarfAccelNamesSection
MCSection * getGFIDsSection() const
const MCSection * getMergeableConst16Section() const
MCSection * getDwarfAccelTypesSection() const
MCSection * getDwarfAbbrevSection() const
MCSection * DataSection
Section directive for standard data.
MCSection * getDwarfAbbrevDWOSection() const
MCSection * getTLSExtraDataSection() const
MCSection * getDwarfGnuPubTypesSection() const
MCSection * getDwarfTypesDWOSection() const
MCSection * ThreadLocalPointerSection
MCSection * DwarfLineStrSection
MCSection * getDwarfAddrSection() const
MCSection * DwarfSwiftASTSection
MCSection * TLSTLVSection
Section for thread local structure information.
MCSection * getNonLazySymbolPointerSection() const
unsigned getFDEEncoding() const
MCSection * DwarfAccelNamespaceSection
MCSection * getDwarfLineDWOSection() const
const MCSection * getMergeableConst8Section() const
Environment getObjectFileType() const
MCSection * getDwarfTypesSection(uint64_t Hash) const
bool SupportsCompactUnwindWithoutEHFrame
True if the target object file supports emitting a compact unwind section without an associated EH fr...
MCSection * getDwarfSwiftASTSection() const
bool CommDirectiveSupportsAlignment
True if .comm supports alignment.
Triple - Helper class for working with autoconf configuration names.
Definition: Triple.h:44
MCSection * getDrectveSection() const
MCSection * COFFDebugSymbolsSection
MCSection * DwarfAbbrevSection
MCSection * getThreadLocalPointerSection() const
MCSection * EHFrameSection
EH frame section.
const MCSection * getEightByteConstantSection() const
MCSection * getDataRelROSection() const
MCSection * DwarfTypesDWOSection
MCSection * DwarfRangesSection
const MCSection * getConstTextCoalSection() const
const Triple & getTargetTriple() const
MCSection * DwarfARangesSection
const MCSection * getDataCommonSection() const
MCSection * CompactUnwindSection
If exception handling is supported by the target and the target can support a compact representation ...
MCSection * getDwarfInfoSection() const
MCSection * DwarfAccelTypesSection
MCSection * getDwarfDebugNamesSection() const
MCSection * getDwarfStrOffDWOSection() const
DenseMap< const MCSymbol *, unsigned > StackSizesUniquing
MCSection * DwarfStrOffDWOSection
MCSection * DwarfGnuPubNamesSection
Section for newer gnu pubnames.
MCSection * DwarfAbbrevDWOSection
const MCSection * getMergeableConst4Section() const
MCSection * getDwarfPubTypesSection() const
MCSection * FaultMapSection
FaultMap section.
bool OmitDwarfIfHaveCompactUnwind
OmitDwarfIfHaveCompactUnwind - True if the target object file supports having some functions with com...
MCSection * FourByteConstantSection
void InitMCObjectFileInfo(const Triple &TT, bool PIC, MCContext &ctx, bool LargeCodeModel=false)
unsigned FDECFIEncoding
FDE CFI encoding.
MCSection * getDwarfStrDWOSection() const
const MCSection * getMergeableConst32Section() const
MCSection * getXDataSection() const
MCSection * LSDASection
If exception handling is supported by the target, this is the section the Language Specific Data Area...
MCSection * TLSExtraDataSection
Extra TLS Variable Data section.
MCSection * getLazySymbolPointerSection() const
unsigned CompactUnwindDwarfEHFrameOnly
Compact unwind encoding indicating that we should emit only an EH frame.
MCSection * StackSizesSection
Section containing metadata on function stack sizes.
MCSection * getDwarfGnuPubNamesSection() const
MCSection * DwarfAccelObjCSection
MCSection * getFaultMapSection() const
const MCSection * getTLSThreadInitSection() const
MCSection * getTextSection() const
MCSection * COFFGlobalTypeHashesSection
MCSection * TLSBSSSection
Section directive for Thread Local uninitialized data.
MCSection * NonLazySymbolPointerSection
MCSection * getDwarfAccelNamespaceSection() const
const MCSection * TLSThreadInitSection
Section for thread local data initialization functions.
MCSection * DwarfRnglistsDWOSection
The DWARF v5 range list section for fission.
bool SupportsWeakOmittedEHFrame
True if target object file supports a weak_definition of constant 0 for an omitted EH frame...
MCSection * getLSDASection() const
MCSection * getDwarfInfoDWOSection() const
MCSection * BSSSection
Section that is default initialized to zero.
MCSection * ReadOnlySection
Section that is readonly and can contain arbitrary initialized data.
bool isPositionIndependent() const
MCSection * DwarfMacinfoSection
MCSection * getDwarfRangesSection() const
const MCSection * getTLSDataSection() const
const MCSection * getSixteenByteConstantSection() const
const MCSection * getUStringSection() const
MCSection * getTextCoalSection() const
const MCSection * getDataCoalSection() const
MCSection * MergeableConst8Section