annotate lib/Target/X86/X86TargetObjectFile.h @ 148:63bd29f05246

merged
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Wed, 14 Aug 2019 19:46:37 +0900
parents c2174574ed3a
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
1 //===-- X86TargetObjectFile.h - X86 Object Info -----------------*- C++ -*-===//
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
2 //
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 134
diff changeset
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 134
diff changeset
4 // See https://llvm.org/LICENSE.txt for license information.
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 134
diff changeset
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
6 //
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
7 //===----------------------------------------------------------------------===//
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
8
77
54457678186b LLVM 3.6
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
9 #ifndef LLVM_LIB_TARGET_X86_X86TARGETOBJECTFILE_H
54457678186b LLVM 3.6
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
10 #define LLVM_LIB_TARGET_X86_X86TARGETOBJECTFILE_H
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
11
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
12 #include "llvm/CodeGen/TargetLoweringObjectFileImpl.h"
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 134
diff changeset
13 #include "llvm/Target/TargetLoweringObjectFile.h"
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
14
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
15 namespace llvm {
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
16
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
17 /// X86_64MachoTargetObjectFile - This TLOF implementation is used for Darwin
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
18 /// x86-64.
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
19 class X86_64MachoTargetObjectFile : public TargetLoweringObjectFileMachO {
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
20 public:
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 95
diff changeset
21 const MCExpr *getTTypeGlobalReference(const GlobalValue *GV,
1172e4bd9c6f update 4.0.0
mir3636
parents: 95
diff changeset
22 unsigned Encoding,
1172e4bd9c6f update 4.0.0
mir3636
parents: 95
diff changeset
23 const TargetMachine &TM,
1172e4bd9c6f update 4.0.0
mir3636
parents: 95
diff changeset
24 MachineModuleInfo *MMI,
1172e4bd9c6f update 4.0.0
mir3636
parents: 95
diff changeset
25 MCStreamer &Streamer) const override;
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
26
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
27 // getCFIPersonalitySymbol - The symbol that gets passed to
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
28 // .cfi_personality.
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 95
diff changeset
29 MCSymbol *getCFIPersonalitySymbol(const GlobalValue *GV,
77
54457678186b LLVM 3.6
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
30 const TargetMachine &TM,
54457678186b LLVM 3.6
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
31 MachineModuleInfo *MMI) const override;
95
afa8332a0e37 LLVM 3.8
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents: 77
diff changeset
32
afa8332a0e37 LLVM 3.8
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents: 77
diff changeset
33 const MCExpr *getIndirectSymViaGOTPCRel(const MCSymbol *Sym,
afa8332a0e37 LLVM 3.8
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents: 77
diff changeset
34 const MCValue &MV, int64_t Offset,
afa8332a0e37 LLVM 3.8
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents: 77
diff changeset
35 MachineModuleInfo *MMI,
afa8332a0e37 LLVM 3.8
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents: 77
diff changeset
36 MCStreamer &Streamer) const override;
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
37 };
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
38
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 134
diff changeset
39 /// This implemenatation is used for X86 ELF targets that don't
95
afa8332a0e37 LLVM 3.8
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents: 77
diff changeset
40 /// have a further specialization.
afa8332a0e37 LLVM 3.8
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents: 77
diff changeset
41 class X86ELFTargetObjectFile : public TargetLoweringObjectFileELF {
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 95
diff changeset
42 public:
1172e4bd9c6f update 4.0.0
mir3636
parents: 95
diff changeset
43 X86ELFTargetObjectFile() {
1172e4bd9c6f update 4.0.0
mir3636
parents: 95
diff changeset
44 PLTRelativeVariantKind = MCSymbolRefExpr::VK_PLT;
1172e4bd9c6f update 4.0.0
mir3636
parents: 95
diff changeset
45 }
1172e4bd9c6f update 4.0.0
mir3636
parents: 95
diff changeset
46
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 134
diff changeset
47 /// Describe a TLS variable address within debug info.
77
54457678186b LLVM 3.6
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
48 const MCExpr *getDebugThreadLocalSymbol(const MCSymbol *Sym) const override;
54457678186b LLVM 3.6
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
49 };
54457678186b LLVM 3.6
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
50
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 95
diff changeset
51 /// X86FreeBSDTargetObjectFile - This implementation is used for FreeBSD
1172e4bd9c6f update 4.0.0
mir3636
parents: 95
diff changeset
52 /// on x86 and x86-64.
1172e4bd9c6f update 4.0.0
mir3636
parents: 95
diff changeset
53 class X86FreeBSDTargetObjectFile : public X86ELFTargetObjectFile {
1172e4bd9c6f update 4.0.0
mir3636
parents: 95
diff changeset
54 void Initialize(MCContext &Ctx, const TargetMachine &TM) override;
1172e4bd9c6f update 4.0.0
mir3636
parents: 95
diff changeset
55 };
1172e4bd9c6f update 4.0.0
mir3636
parents: 95
diff changeset
56
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 134
diff changeset
57 /// This implementation is used for Fuchsia on x86-64.
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 95
diff changeset
58 class X86FuchsiaTargetObjectFile : public X86ELFTargetObjectFile {
1172e4bd9c6f update 4.0.0
mir3636
parents: 95
diff changeset
59 void Initialize(MCContext &Ctx, const TargetMachine &TM) override;
1172e4bd9c6f update 4.0.0
mir3636
parents: 95
diff changeset
60 };
1172e4bd9c6f update 4.0.0
mir3636
parents: 95
diff changeset
61
95
afa8332a0e37 LLVM 3.8
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents: 77
diff changeset
62 /// X86LinuxNaClTargetObjectFile - This implementation is used for linux and
afa8332a0e37 LLVM 3.8
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents: 77
diff changeset
63 /// Native Client on x86 and x86-64.
afa8332a0e37 LLVM 3.8
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents: 77
diff changeset
64 class X86LinuxNaClTargetObjectFile : public X86ELFTargetObjectFile {
afa8332a0e37 LLVM 3.8
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents: 77
diff changeset
65 void Initialize(MCContext &Ctx, const TargetMachine &TM) override;
afa8332a0e37 LLVM 3.8
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents: 77
diff changeset
66 };
afa8332a0e37 LLVM 3.8
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents: 77
diff changeset
67
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 134
diff changeset
68 /// This implementation is used for Solaris on x86/x86-64.
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
69 class X86SolarisTargetObjectFile : public X86ELFTargetObjectFile {
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
70 void Initialize(MCContext &Ctx, const TargetMachine &TM) override;
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
71 };
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
72
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
73 } // end namespace llvm
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
74
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
75 #endif