LLVM  14.0.0git
Public Member Functions | List of all members
llvm::MipsTargetObjectFile Class Reference

#include "Target/Mips/MipsTargetObjectFile.h"

Inheritance diagram for llvm::MipsTargetObjectFile:
Inheritance graph
Collaboration diagram for llvm::MipsTargetObjectFile:
Collaboration graph

Public Member Functions

void Initialize (MCContext &Ctx, const TargetMachine &TM) override
 This method must be called before any actual lowering is done. More...
bool IsGlobalInSmallSection (const GlobalObject *GO, const TargetMachine &TM) const
 Return true if this global address should be placed into small data/bss section. More...
MCSectionSelectSectionForGlobal (const GlobalObject *GO, SectionKind Kind, const TargetMachine &TM) const override
bool IsConstantInSmallSection (const DataLayout &DL, const Constant *CN, const TargetMachine &TM) const
 Return true if this constant should be placed into small data section. More...
MCSectiongetSectionForConstant (const DataLayout &DL, SectionKind Kind, const Constant *C, Align &Alignment) const override
 Return true if this constant should be placed into small data section. More...
const MCExprgetDebugThreadLocalSymbol (const MCSymbol *Sym) const override
 Describe a TLS variable address within debug info. More...
- Public Member Functions inherited from llvm::TargetLoweringObjectFileELF
 TargetLoweringObjectFileELF ()
 ~TargetLoweringObjectFileELF () override=default
void getModuleMetadata (Module &M) override
 Get the module-level metadata that the platform cares about. More...
void emitModuleMetadata (MCStreamer &Streamer, Module &M) const override
 Emit Obj-C garbage collection and linker options. More...
void emitPersonalityValue (MCStreamer &Streamer, const DataLayout &DL, const MCSymbol *Sym) const override
MCSectiongetExplicitSectionGlobal (const GlobalObject *GO, SectionKind Kind, const TargetMachine &TM) const override
 Targets should implement this method to assign a section to globals with an explicit section specfied. More...
MCSectiongetSectionForJumpTable (const Function &F, const TargetMachine &TM) const override
MCSectiongetSectionForLSDA (const Function &F, const MCSymbol &FnSym, const TargetMachine &TM) const override
MCSectiongetSectionForMachineBasicBlock (const Function &F, const MachineBasicBlock &MBB, const TargetMachine &TM) const override
 Returns a unique section for the given machine basic block. More...
MCSectiongetUniqueSectionForFunction (const Function &F, const TargetMachine &TM) const override
bool shouldPutJumpTableInFunctionSection (bool UsesLabelDifference, const Function &F) const override
const MCExprgetTTypeGlobalReference (const GlobalValue *GV, unsigned Encoding, const TargetMachine &TM, MachineModuleInfo *MMI, MCStreamer &Streamer) const override
 Return an MCExpr to use for a reference to the specified type info global variable from exception handling information. More...
MCSymbolgetCFIPersonalitySymbol (const GlobalValue *GV, const TargetMachine &TM, MachineModuleInfo *MMI) const override
void InitializeELF (bool UseInitArray_)
MCSectiongetStaticCtorSection (unsigned Priority, const MCSymbol *KeySym) const override
MCSectiongetStaticDtorSection (unsigned Priority, const MCSymbol *KeySym) const override
const MCExprlowerRelativeReference (const GlobalValue *LHS, const GlobalValue *RHS, const TargetMachine &TM) const override
const MCExprlowerDSOLocalEquivalent (const DSOLocalEquivalent *Equiv, const TargetMachine &TM) const override
MCSectiongetSectionForCommandLines () const override
 If supported, return the section to use for the llvm.commandline metadata. More...
- Public Member Functions inherited from llvm::TargetLoweringObjectFile
 TargetLoweringObjectFile ()=default
 TargetLoweringObjectFile (const TargetLoweringObjectFile &)=delete
TargetLoweringObjectFileoperator= (const TargetLoweringObjectFile &)=delete
virtual ~TargetLoweringObjectFile ()
ManglergetMangler () const
void emitCGProfileMetadata (MCStreamer &Streamer, Module &M) const
 Emit Call Graph Profile metadata. More...
MCSectionSectionForGlobal (const GlobalObject *GO, SectionKind Kind, const TargetMachine &TM) const
 This method computes the appropriate section to emit the specified global variable or function definition. More...
MCSectionSectionForGlobal (const GlobalObject *GO, const TargetMachine &TM) const
 This method computes the appropriate section to emit the specified global variable or function definition. More...
virtual void getNameWithPrefix (SmallVectorImpl< char > &OutName, const GlobalValue *GV, const TargetMachine &TM) const
MCSymbolgetSymbolWithGlobalValueBase (const GlobalValue *GV, StringRef Suffix, const TargetMachine &TM) const
 Return the MCSymbol for a private symbol with global value name as its base, with the specified suffix. More...
unsigned getPersonalityEncoding () const
unsigned getLSDAEncoding () const
unsigned getTTypeEncoding () const
unsigned getCallSiteEncoding () const
const MCExprgetTTypeReference (const MCSymbolRefExpr *Sym, unsigned Encoding, MCStreamer &Streamer) const
bool supportDSOLocalEquivalentLowering () const
 Target supports a native lowering of a dso_local_equivalent constant without needing to replace it with equivalent IR. More...
bool supportIndirectSymViaGOTPCRel () const
 Target supports replacing a data "PC"-relative access to a symbol through another symbol, by accessing the later via a GOT entry instead? More...
bool supportGOTPCRelWithOffset () const
 Target GOT "PC"-relative relocation supports encoding an additional binary expression with an offset? More...
bool supportDebugThreadLocalLocation () const
 Target supports TLS offset relocation in debug section? More...
virtual const MCRegister getStaticBase () const
 Returns the register used as static base in RWPI variants. More...
virtual const MCExprgetIndirectSymViaRWPI (const MCSymbol *Sym) const
 Get the target specific RWPI relocation. More...
virtual const MCExprgetIndirectSymViaGOTPCRel (const GlobalValue *GV, const MCSymbol *Sym, const MCValue &MV, int64_t Offset, MachineModuleInfo *MMI, MCStreamer &Streamer) const
 Get the target specific PC relative GOT entry relocation. More...
virtual MCSectiongetSectionForFunctionDescriptor (const Function *F, const TargetMachine &TM) const
 On targets that use separate function descriptor symbols, return a section for the descriptor given its symbol. More...
virtual MCSectiongetSectionForTOCEntry (const MCSymbol *S, const TargetMachine &TM) const
 On targets that support TOC entries, return a section for the entry given the symbol it refers to. More...
virtual MCSectiongetSectionForExternalReference (const GlobalObject *GO, const TargetMachine &TM) const
 On targets that associate external references with a section, return such a section for the given external global. More...
virtual MCSymbolgetTargetSymbol (const GlobalValue *GV, const TargetMachine &TM) const
 Targets that have a special convention for their symbols could use this hook to return a specialized symbol. More...
virtual MCSymbolgetFunctionEntryPointSymbol (const GlobalValue *Func, const TargetMachine &TM) const
 If supported, return the function entry point symbol. More...
- Public Member Functions inherited from llvm::MCObjectFileInfo
void initMCObjectFileInfo (MCContext &MCCtx, bool PIC, bool LargeCodeModel=false)
virtual ~MCObjectFileInfo ()
MCContextgetContext () const
bool getSupportsWeakOmittedEHFrame () const
bool getSupportsCompactUnwindWithoutEHFrame () const
bool getOmitDwarfIfHaveCompactUnwind () const
bool getCommDirectiveSupportsAlignment () const
unsigned getFDEEncoding () const
unsigned getCompactUnwindDwarfEHFrameOnly () const
virtual unsigned getTextSectionAlignment () const
MCSectiongetTextSection () const
MCSectiongetDataSection () const
MCSectiongetBSSSection () const
MCSectiongetReadOnlySection () const
MCSectiongetLSDASection () const
MCSectiongetCompactUnwindSection () const
MCSectiongetDwarfAbbrevSection () const
MCSectiongetDwarfInfoSection () const
MCSectiongetDwarfInfoSection (uint64_t Hash) const
MCSectiongetDwarfLineSection () const
MCSectiongetDwarfLineStrSection () const
MCSectiongetDwarfFrameSection () const
MCSectiongetDwarfPubNamesSection () const
MCSectiongetDwarfPubTypesSection () const
MCSectiongetDwarfGnuPubNamesSection () const
MCSectiongetDwarfGnuPubTypesSection () const
const MCSectiongetDwarfDebugInlineSection () const
MCSectiongetDwarfStrSection () const
MCSectiongetDwarfLocSection () const
MCSectiongetDwarfARangesSection () const
MCSectiongetDwarfRangesSection () const
MCSectiongetDwarfRnglistsSection () const
MCSectiongetDwarfLoclistsSection () const
MCSectiongetDwarfMacinfoSection () const
MCSectiongetDwarfMacroSection () const
MCSectiongetDwarfDebugNamesSection () const
MCSectiongetDwarfAccelNamesSection () const
MCSectiongetDwarfAccelObjCSection () const
MCSectiongetDwarfAccelNamespaceSection () const
MCSectiongetDwarfAccelTypesSection () const
MCSectiongetDwarfInfoDWOSection () const
MCSectiongetDwarfTypesSection (uint64_t Hash) const
MCSectiongetDwarfTypesDWOSection () const
MCSectiongetDwarfAbbrevDWOSection () const
MCSectiongetDwarfStrDWOSection () const
MCSectiongetDwarfLineDWOSection () const
MCSectiongetDwarfLocDWOSection () const
MCSectiongetDwarfStrOffDWOSection () const
MCSectiongetDwarfStrOffSection () const
MCSectiongetDwarfAddrSection () const
MCSectiongetDwarfRnglistsDWOSection () const
MCSectiongetDwarfLoclistsDWOSection () const
MCSectiongetDwarfMacroDWOSection () const
MCSectiongetDwarfMacinfoDWOSection () const
MCSectiongetDwarfCUIndexSection () const
MCSectiongetDwarfTUIndexSection () const
MCSectiongetDwarfSwiftASTSection () const
MCSectiongetCOFFDebugSymbolsSection () const
MCSectiongetCOFFDebugTypesSection () const
MCSectiongetCOFFGlobalTypeHashesSection () const
MCSectiongetTLSExtraDataSection () const
const MCSectiongetTLSDataSection () const
MCSectiongetTLSBSSSection () const
MCSectiongetStackMapSection () const
MCSectiongetFaultMapSection () const
MCSectiongetRemarksSection () const
MCSectiongetStackSizesSection (const MCSection &TextSec) const
MCSectiongetBBAddrMapSection (const MCSection &TextSec) const
MCSectiongetPseudoProbeSection (const MCSection *TextSec) const
MCSectiongetPseudoProbeDescSection (StringRef FuncName) const
MCSectiongetDataRelROSection () const
const MCSectiongetMergeableConst4Section () const
const MCSectiongetMergeableConst8Section () const
const MCSectiongetMergeableConst16Section () const
const MCSectiongetMergeableConst32Section () const
const MCSectiongetTLSTLVSection () const
const MCSectiongetTLSThreadInitSection () const
const MCSectiongetCStringSection () const
const MCSectiongetUStringSection () const
MCSectiongetTextCoalSection () const
const MCSectiongetConstTextCoalSection () const
const MCSectiongetConstDataSection () const
const MCSectiongetDataCoalSection () const
const MCSectiongetConstDataCoalSection () const
const MCSectiongetDataCommonSection () const
MCSectiongetDataBSSSection () const
const MCSectiongetFourByteConstantSection () const
const MCSectiongetEightByteConstantSection () const
const MCSectiongetSixteenByteConstantSection () const
MCSectiongetLazySymbolPointerSection () const
MCSectiongetNonLazySymbolPointerSection () const
MCSectiongetThreadLocalPointerSection () const
MCSectiongetDrectveSection () const
MCSectiongetPDataSection () const
MCSectiongetXDataSection () const
MCSectiongetSXDataSection () const
MCSectiongetGEHContSection () const
MCSectiongetGFIDsSection () const
MCSectiongetGIATsSection () const
MCSectiongetGLJMPSection () const
MCSectiongetTOCBaseSection () const
MCSectiongetEHFrameSection () const
bool isPositionIndependent () const
void setSDKVersion (const VersionTuple &TheSDKVersion)
const VersionTuplegetSDKVersion () const

Additional Inherited Members

- Static Public Member Functions inherited from llvm::TargetLoweringObjectFile
static SectionKind getKindForGlobal (const GlobalObject *GO, const TargetMachine &TM)
 Classify the specified global variable into a set of target independent categories embodied in SectionKind. More...
- Protected Attributes inherited from llvm::TargetLoweringObjectFileELF
MCSymbolRefExpr::VariantKind PLTRelativeVariantKind
- Protected Attributes inherited from llvm::TargetLoweringObjectFile
bool SupportIndirectSymViaGOTPCRel = false
bool SupportGOTPCRelWithOffset = true
bool SupportDebugThreadLocalLocation = true
bool SupportDSOLocalEquivalentLowering = false
unsigned PersonalityEncoding = 0
 PersonalityEncoding, LSDAEncoding, TTypeEncoding - Some encoding values for EH. More...
unsigned LSDAEncoding = 0
unsigned TTypeEncoding = 0
unsigned CallSiteEncoding = 0
MCSectionStaticCtorSection = nullptr
 This section contains the static constructor pointer list. More...
MCSectionStaticDtorSection = nullptr
 This section contains the static destructor pointer list. More...
const TargetMachineTM = nullptr
- Protected Attributes inherited from llvm::MCObjectFileInfo
bool CommDirectiveSupportsAlignment = false
 True if .comm supports alignment. More...
bool SupportsWeakOmittedEHFrame = false
 True if target object file supports a weak_definition of constant 0 for an omitted EH frame. More...
bool SupportsCompactUnwindWithoutEHFrame = false
 True if the target object file supports emitting a compact unwind section without an associated EH frame section. More...
bool OmitDwarfIfHaveCompactUnwind = false
 OmitDwarfIfHaveCompactUnwind - True if the target object file supports having some functions with compact unwind and other with dwarf unwind. More...
unsigned FDECFIEncoding = 0
 FDE CFI encoding. More...
unsigned CompactUnwindDwarfEHFrameOnly = 0
 Compact unwind encoding indicating that we should emit only an EH frame. More...
MCSectionTextSection = nullptr
 Section directive for standard text. More...
MCSectionDataSection = nullptr
 Section directive for standard data. More...
MCSectionBSSSection = nullptr
 Section that is default initialized to zero. More...
MCSectionReadOnlySection = nullptr
 Section that is readonly and can contain arbitrary initialized data. More...
MCSectionLSDASection = nullptr
 If exception handling is supported by the target, this is the section the Language Specific Data Area information is emitted to. More...
MCSectionCompactUnwindSection = nullptr
 If exception handling is supported by the target and the target can support a compact representation of the CIE and FDE, this is the section to emit them into. More...
MCSectionDwarfAbbrevSection = nullptr
MCSectionDwarfInfoSection = nullptr
MCSectionDwarfLineSection = nullptr
MCSectionDwarfLineStrSection = nullptr
MCSectionDwarfFrameSection = nullptr
MCSectionDwarfPubTypesSection = nullptr
const MCSectionDwarfDebugInlineSection = nullptr
MCSectionDwarfStrSection = nullptr
MCSectionDwarfLocSection = nullptr
MCSectionDwarfARangesSection = nullptr
MCSectionDwarfRangesSection = nullptr
MCSectionDwarfMacinfoSection = nullptr
MCSectionDwarfMacroSection = nullptr
MCSectionDwarfPubNamesSection = nullptr
MCSectionDwarfDebugNamesSection = nullptr
 Accelerator table sections. More...
MCSectionDwarfAccelNamesSection = nullptr
MCSectionDwarfAccelObjCSection = nullptr
MCSectionDwarfAccelNamespaceSection = nullptr
MCSectionDwarfAccelTypesSection = nullptr
MCSectionDwarfInfoDWOSection = nullptr
MCSectionDwarfTypesDWOSection = nullptr
MCSectionDwarfAbbrevDWOSection = nullptr
MCSectionDwarfStrDWOSection = nullptr
MCSectionDwarfLineDWOSection = nullptr
MCSectionDwarfLocDWOSection = nullptr
MCSectionDwarfStrOffDWOSection = nullptr
MCSectionDwarfMacinfoDWOSection = nullptr
MCSectionDwarfMacroDWOSection = nullptr
MCSectionDwarfStrOffSection = nullptr
 The DWARF v5 string offset and address table sections. More...
MCSectionDwarfAddrSection = nullptr
MCSectionDwarfRnglistsSection = nullptr
 The DWARF v5 range list section. More...
MCSectionDwarfLoclistsSection = nullptr
 The DWARF v5 locations list section. More...
MCSectionDwarfRnglistsDWOSection = nullptr
 The DWARF v5 range and location list sections for fission. More...
MCSectionDwarfLoclistsDWOSection = nullptr
MCSectionDwarfCUIndexSection = nullptr
MCSectionDwarfTUIndexSection = nullptr
MCSectionDwarfGnuPubNamesSection = nullptr
 Section for newer gnu pubnames. More...
MCSectionDwarfGnuPubTypesSection = nullptr
 Section for newer gnu pubtypes. More...
MCSectionDwarfSwiftASTSection = nullptr
MCSectionCOFFDebugSymbolsSection = nullptr
MCSectionCOFFDebugTypesSection = nullptr
MCSectionCOFFGlobalTypeHashesSection = nullptr
MCSectionTLSExtraDataSection = nullptr
 Extra TLS Variable Data section. More...
MCSectionTLSDataSection = nullptr
 Section directive for Thread Local data. ELF, MachO, COFF, and Wasm. More...
MCSectionTLSBSSSection = nullptr
 Section directive for Thread Local uninitialized data. More...
MCSectionStackMapSection = nullptr
 StackMap section. More...
MCSectionFaultMapSection = nullptr
 FaultMap section. More...
MCSectionRemarksSection = nullptr
 Remarks section. More...
MCSectionEHFrameSection = nullptr
 EH frame section. More...
MCSectionStackSizesSection = nullptr
 Section containing metadata on function stack sizes. More...
MCSectionPseudoProbeSection = nullptr
 Section for pseudo probe information used by AutoFDO. More...
MCSectionPseudoProbeDescSection = nullptr
MCSectionDataRelROSection = nullptr
MCSectionMergeableConst4Section = nullptr
MCSectionMergeableConst8Section = nullptr
MCSectionMergeableConst16Section = nullptr
MCSectionMergeableConst32Section = nullptr
MCSectionTLSTLVSection = nullptr
 Section for thread local structure information. More...
const MCSectionTLSThreadInitSection = nullptr
 Section for thread local data initialization functions. More...
MCSectionCStringSection = nullptr
MCSectionUStringSection = nullptr
MCSectionTextCoalSection = nullptr
MCSectionConstTextCoalSection = nullptr
MCSectionConstDataSection = nullptr
MCSectionDataCoalSection = nullptr
MCSectionConstDataCoalSection = nullptr
MCSectionDataCommonSection = nullptr
MCSectionDataBSSSection = nullptr
MCSectionFourByteConstantSection = nullptr
MCSectionEightByteConstantSection = nullptr
MCSectionSixteenByteConstantSection = nullptr
MCSectionLazySymbolPointerSection = nullptr
MCSectionNonLazySymbolPointerSection = nullptr
MCSectionThreadLocalPointerSection = nullptr
MCSectionDrectveSection = nullptr
 COFF specific sections. More...
MCSectionPDataSection = nullptr
MCSectionXDataSection = nullptr
MCSectionSXDataSection = nullptr
MCSectionGEHContSection = nullptr
MCSectionGFIDsSection = nullptr
MCSectionGIATsSection = nullptr
MCSectionGLJMPSection = nullptr
MCSectionTOCBaseSection = nullptr
MCSectionReadOnly8Section = nullptr
MCSectionReadOnly16Section = nullptr

Detailed Description

Definition at line 16 of file MipsTargetObjectFile.h.

Member Function Documentation

◆ getDebugThreadLocalSymbol()

const MCExpr * MipsTargetObjectFile::getDebugThreadLocalSymbol ( const MCSymbol Sym) const

◆ getSectionForConstant()

MCSection * MipsTargetObjectFile::getSectionForConstant ( const DataLayout DL,
SectionKind  Kind,
const Constant C,
Align Alignment 
) const

Return true if this constant should be placed into small data section.

Reimplemented from llvm::TargetLoweringObjectFileELF.

Definition at line 176 of file MipsTargetObjectFile.cpp.

References DL, llvm::TargetLoweringObjectFileELF::getSectionForConstant(), IsConstantInSmallSection(), and TM.

◆ Initialize()

void MipsTargetObjectFile::Initialize ( MCContext ctx,
const TargetMachine TM 

This method must be called before any actual lowering is done.

Initialize - this method must be called before any actual lowering is done.

This specifies the current context for codegen, and gives the lowering implementations a chance to set up their default sections.

Reimplemented from llvm::TargetLoweringObjectFileELF.

Definition at line 45 of file MipsTargetObjectFile.cpp.

References llvm::MCObjectFileInfo::getContext(), llvm::MCContext::getELFSection(), llvm::TargetLoweringObjectFileELF::Initialize(), llvm::ELF::SHF_ALLOC, llvm::ELF::SHF_MIPS_GPREL, llvm::ELF::SHF_WRITE, llvm::ELF::SHT_NOBITS, llvm::ELF::SHT_PROGBITS, and TM.

◆ IsConstantInSmallSection()

bool MipsTargetObjectFile::IsConstantInSmallSection ( const DataLayout DL,
const Constant CN,
const TargetMachine TM 
) const

Return true if this constant should be placed into small data section.

Definition at line 167 of file MipsTargetObjectFile.cpp.

References DL, llvm::Value::getType(), IsInSmallSection(), LocalSData, and TM.

Referenced by getSectionForConstant().

◆ IsGlobalInSmallSection()

bool MipsTargetObjectFile::IsGlobalInSmallSection ( const GlobalObject GO,
const TargetMachine TM 
) const

Return true if this global address should be placed into small data/bss section.

Definition at line 69 of file MipsTargetObjectFile.cpp.

References llvm::TargetLoweringObjectFile::getKindForGlobal(), llvm::GlobalValue::hasAvailableExternallyLinkage(), llvm::GlobalValue::isDeclaration(), and TM.

◆ SelectSectionForGlobal()

MCSection * MipsTargetObjectFile::SelectSectionForGlobal ( const GlobalObject GO,
SectionKind  Kind,
const TargetMachine TM 
) const

The documentation for this class was generated from the following files: