[AMDGPU] New gfx940 mfma instructions
[llvm-project.git] / llvm / lib / Target / AArch64 / AArch64TargetObjectFile.h
blob9f098230bbd78ff1b69d764be61b103930c83402
1 //===-- AArch64TargetObjectFile.h - AArch64 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 //===----------------------------------------------------------------------===//
9 #ifndef LLVM_LIB_TARGET_AARCH64_AARCH64TARGETOBJECTFILE_H
10 #define LLVM_LIB_TARGET_AARCH64_AARCH64TARGETOBJECTFILE_H
12 #include "llvm/CodeGen/TargetLoweringObjectFileImpl.h"
13 #include "llvm/Target/TargetLoweringObjectFile.h"
15 namespace llvm {
17 /// This implementation is used for AArch64 ELF targets (Linux in particular).
18 class AArch64_ELFTargetObjectFile : public TargetLoweringObjectFileELF {
19 void Initialize(MCContext &Ctx, const TargetMachine &TM) override;
21 public:
22 AArch64_ELFTargetObjectFile() {
23 PLTRelativeVariantKind = MCSymbolRefExpr::VK_PLT;
27 /// AArch64_MachoTargetObjectFile - This TLOF implementation is used for Darwin.
28 class AArch64_MachoTargetObjectFile : public TargetLoweringObjectFileMachO {
29 public:
30 AArch64_MachoTargetObjectFile();
32 const MCExpr *getTTypeGlobalReference(const GlobalValue *GV,
33 unsigned Encoding,
34 const TargetMachine &TM,
35 MachineModuleInfo *MMI,
36 MCStreamer &Streamer) const override;
38 MCSymbol *getCFIPersonalitySymbol(const GlobalValue *GV,
39 const TargetMachine &TM,
40 MachineModuleInfo *MMI) const override;
42 const MCExpr *getIndirectSymViaGOTPCRel(const GlobalValue *GV,
43 const MCSymbol *Sym,
44 const MCValue &MV, int64_t Offset,
45 MachineModuleInfo *MMI,
46 MCStreamer &Streamer) const override;
48 void getNameWithPrefix(SmallVectorImpl<char> &OutName, const GlobalValue *GV,
49 const TargetMachine &TM) const override;
52 /// This implementation is used for AArch64 COFF targets.
53 class AArch64_COFFTargetObjectFile : public TargetLoweringObjectFileCOFF {};
55 } // end namespace llvm
57 #endif