LLVM 22.0.0git
ARMTargetObjectFile.h
Go to the documentation of this file.
1//===-- llvm/Target/ARMTargetObjectFile.h - ARM Object Info -----*- 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#ifndef LLVM_LIB_TARGET_ARM_ARMTARGETOBJECTFILE_H
10#define LLVM_LIB_TARGET_ARM_ARMTARGETOBJECTFILE_H
11
13#include "llvm/MC/MCExpr.h"
14#include "llvm/MC/MCRegister.h"
15
16namespace llvm {
17
19public:
21 void Initialize(MCContext &Ctx, const TargetMachine &TM) override;
22
23 MCRegister getStaticBase() const override;
24
26 const MCSymbol *Sym,
27 const MCValue &MV, int64_t Offset,
29 MCStreamer &Streamer) const override;
30
31 const MCExpr *getIndirectSymViaRWPI(const MCSymbol *Sym) const override;
32
34 unsigned Encoding,
35 const TargetMachine &TM,
37 MCStreamer &Streamer) const override;
38
39 /// Describe a TLS variable address within debug info.
40 const MCExpr *getDebugThreadLocalSymbol(const MCSymbol *Sym) const override;
41
43 const TargetMachine &TM) const override;
44
46 const TargetMachine &TM) const override;
47};
48
49} // end namespace llvm
50
51#endif // LLVM_LIB_TARGET_ARM_ARMTARGETOBJECTFILE_H
MCSection * SelectSectionForGlobal(const GlobalObject *GO, SectionKind Kind, const TargetMachine &TM) const override
const MCExpr * getDebugThreadLocalSymbol(const MCSymbol *Sym) const override
Describe a TLS variable address within debug info.
MCRegister getStaticBase() const override
Returns the register used as static base in RWPI variants.
MCSection * getExplicitSectionGlobal(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...
const MCExpr * getIndirectSymViaGOTPCRel(const GlobalValue *GV, const MCSymbol *Sym, const MCValue &MV, int64_t Offset, MachineModuleInfo *MMI, MCStreamer &Streamer) const override
Get the target specific PC relative GOT entry relocation.
const MCExpr * getIndirectSymViaRWPI(const MCSymbol *Sym) const override
Get the target specific RWPI relocation.
const MCExpr * getTTypeGlobalReference(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 global variable from exception handling info...
void Initialize(MCContext &Ctx, const TargetMachine &TM) override
This method must be called before any actual lowering is done.
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
Wrapper class representing physical registers. Should be passed by value.
Definition MCRegister.h:33
Instances of this class represent a uniqued identifier for a section in the current translation unit.
Definition MCSection.h:496
Streaming machine code generation interface.
Definition MCStreamer.h:220
MCSymbol - Instances of this class represent a symbol name in the MC file, and MCSymbols are created ...
Definition MCSymbol.h:42
This class contains meta information specific to a module.
SectionKind - This is a simple POD value that classifies the properties of a section.
Definition SectionKind.h:22
Primary interface to the complete machine description for the target machine.
This is an optimization pass for GlobalISel generic memory operations.
@ Offset
Definition DWP.cpp:477