annotate lib/Target/Lanai/LanaiTargetObjectFile.h @ 145:9987f868744e

fix CbC_llvm
author mir3636
date Tue, 05 Jun 2018 21:59:34 +0900
parents 1172e4bd9c6f
children c2174574ed3a
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
120
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
1 //===-- LanaiTargetObjectFile.h - Lanai Object Info -----------------------===//
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
2 //
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
3 // The LLVM Compiler Infrastructure
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
4 //
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
5 // This file is distributed under the University of Illinois Open Source
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
6 // License. See LICENSE.TXT for details.
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
7 //
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
8 //===----------------------------------------------------------------------===//
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
9
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
10 #ifndef LLVM_LIB_TARGET_LANAI_LANAITARGETOBJECTFILE_H
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
11 #define LLVM_LIB_TARGET_LANAI_LANAITARGETOBJECTFILE_H
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
12
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
13 #include "llvm/CodeGen/TargetLoweringObjectFileImpl.h"
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
14
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
15 namespace llvm {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
16 class LanaiTargetMachine;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
17 class LanaiTargetObjectFile : public TargetLoweringObjectFileELF {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
18 MCSection *SmallDataSection;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
19 MCSection *SmallBSSSection;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
20
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
21 bool isGlobalInSmallSection(const GlobalObject *GO, const TargetMachine &TM,
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
22 SectionKind Kind) const;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
23 bool isGlobalInSmallSectionImpl(const GlobalObject *GO,
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
24 const TargetMachine &TM) const;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
25
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
26 public:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
27 void Initialize(MCContext &Ctx, const TargetMachine &TM) override;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
28
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
29 /// Return true if this global address should be placed into small data/bss
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
30 /// section.
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
31 bool isGlobalInSmallSection(const GlobalObject *GO,
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
32 const TargetMachine &TM) const;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
33
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
34 MCSection *SelectSectionForGlobal(const GlobalObject *GO, SectionKind Kind,
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
35 const TargetMachine &TM) const override;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
36
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
37 /// Return true if this constant should be placed into small data section.
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
38 bool isConstantInSmallSection(const DataLayout &DL, const Constant *CN) const;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
39
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
40 MCSection *getSectionForConstant(const DataLayout &DL, SectionKind Kind,
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
41 const Constant *C,
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
42 unsigned &Align) const override;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
43 };
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
44 } // end namespace llvm
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
45
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
46 #endif // LLVM_LIB_TARGET_LANAI_LANAITARGETOBJECTFILE_H