blob: 749cb7179437c8e9c0329f9c881a10fd8254834e [file] [log] [blame]
Anton Korobeynikov745e8642008-07-19 13:14:46 +00001//===-- DarwinTargetAsmInfo.cpp - Darwin asm properties ---------*- C++ -*-===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9//
10// This file defines target asm properties related what form asm statements
11// should take in general on Darwin-based targets
12//
13//===----------------------------------------------------------------------===//
14
15#include "llvm/Constants.h"
16#include "llvm/DerivedTypes.h"
17#include "llvm/Function.h"
18#include "llvm/GlobalVariable.h"
19#include "llvm/ADT/StringExtras.h"
20#include "llvm/Target/DarwinTargetAsmInfo.h"
21#include "llvm/Target/TargetMachine.h"
22#include "llvm/Target/TargetData.h"
23
24using namespace llvm;
25
26DarwinTargetAsmInfo::DarwinTargetAsmInfo(const TargetMachine &TM) {
Anton Korobeynikov18f6ed92008-07-19 13:15:21 +000027 DTM = &TM;
Anton Korobeynikov745e8642008-07-19 13:14:46 +000028
29 CStringSection_ = getUnnamedSection("\t.cstring",
30 SectionFlags::Mergeable | SectionFlags::Strings);
31 FourByteConstantSection_ = getUnnamedSection("\t.literal4\n",
32 SectionFlags::Mergeable);
33 EightByteConstantSection_ = getUnnamedSection("\t.literal8\n",
34 SectionFlags::Mergeable);
Anton Korobeynikovae408e62008-07-19 13:16:11 +000035
Anton Korobeynikovcff2ea02008-07-19 13:15:46 +000036 // Note: 16-byte constant section is subtarget specific and should be provided
37 // there.
38
Anton Korobeynikov745e8642008-07-19 13:14:46 +000039 ReadOnlySection_ = getUnnamedSection("\t.const\n", SectionFlags::None);
40
41 // FIXME: These should be named sections, really.
42 TextCoalSection =
43 getUnnamedSection(".section __TEXT,__textcoal_nt,coalesced,pure_instructions",
44 SectionFlags::Code);
45 ConstDataCoalSection =
46 getUnnamedSection(".section __DATA,__const_coal,coalesced",
47 SectionFlags::None);
48 ConstDataSection = getUnnamedSection(".const_data", SectionFlags::None);
49 DataCoalSection = getUnnamedSection(".section __DATA,__datacoal_nt,coalesced",
50 SectionFlags::Writeable);
51}
52
53const Section*
Evan Cheng42ccc212008-08-08 17:56:50 +000054DarwinTargetAsmInfo::SelectSectionForGlobal(const GlobalValue *GV) const {
Anton Korobeynikov745e8642008-07-19 13:14:46 +000055 SectionKind::Kind Kind = SectionKindForGlobal(GV);
Evan Cheng42ccc212008-08-08 17:56:50 +000056 bool isWeak = GV->isWeakForLinker();
Anton Korobeynikov18f6ed92008-07-19 13:15:21 +000057 bool isNonStatic = (DTM->getRelocationModel() != Reloc::Static);
Anton Korobeynikov745e8642008-07-19 13:14:46 +000058
59 switch (Kind) {
60 case SectionKind::Text:
Evan Cheng42ccc212008-08-08 17:56:50 +000061 if (isWeak)
Anton Korobeynikov745e8642008-07-19 13:14:46 +000062 return TextCoalSection;
63 else
64 return getTextSection_();
65 case SectionKind::Data:
66 case SectionKind::ThreadData:
67 case SectionKind::BSS:
68 case SectionKind::ThreadBSS:
69 if (cast<GlobalVariable>(GV)->isConstant())
Evan Cheng42ccc212008-08-08 17:56:50 +000070 return (isWeak ? ConstDataCoalSection : ConstDataSection);
Anton Korobeynikov745e8642008-07-19 13:14:46 +000071 else
Evan Cheng42ccc212008-08-08 17:56:50 +000072 return (isWeak ? DataCoalSection : getDataSection_());
Anton Korobeynikov745e8642008-07-19 13:14:46 +000073 case SectionKind::ROData:
Evan Cheng42ccc212008-08-08 17:56:50 +000074 return (isWeak ? ConstDataCoalSection :
Anton Korobeynikov745e8642008-07-19 13:14:46 +000075 (isNonStatic ? ConstDataSection : getReadOnlySection_()));
76 case SectionKind::RODataMergeStr:
Evan Cheng42ccc212008-08-08 17:56:50 +000077 return (isWeak ?
Anton Korobeynikov745e8642008-07-19 13:14:46 +000078 ConstDataCoalSection :
79 MergeableStringSection(cast<GlobalVariable>(GV)));
80 case SectionKind::RODataMergeConst:
Evan Cheng42ccc212008-08-08 17:56:50 +000081 return (isWeak ?
Anton Korobeynikov745e8642008-07-19 13:14:46 +000082 ConstDataCoalSection:
83 MergeableConstSection(cast<GlobalVariable>(GV)));
84 default:
85 assert(0 && "Unsuported section kind for global");
86 }
87
88 // FIXME: Do we have any extra special weird cases?
89}
90
91const Section*
92DarwinTargetAsmInfo::MergeableStringSection(const GlobalVariable *GV) const {
Anton Korobeynikov18f6ed92008-07-19 13:15:21 +000093 const TargetData *TD = DTM->getTargetData();
Anton Korobeynikov745e8642008-07-19 13:14:46 +000094 Constant *C = cast<GlobalVariable>(GV)->getInitializer();
95 const Type *Type = cast<ConstantArray>(C)->getType()->getElementType();
96
97 unsigned Size = TD->getABITypeSize(Type);
98 if (Size) {
Anton Korobeynikov18f6ed92008-07-19 13:15:21 +000099 const TargetData *TD = DTM->getTargetData();
Anton Korobeynikov745e8642008-07-19 13:14:46 +0000100 unsigned Align = TD->getPreferredAlignment(GV);
101 if (Align <= 32)
102 return getCStringSection_();
103 }
104
105 return getReadOnlySection_();
106}
107
108const Section*
109DarwinTargetAsmInfo::MergeableConstSection(const GlobalVariable *GV) const {
Anton Korobeynikov745e8642008-07-19 13:14:46 +0000110 Constant *C = cast<GlobalVariable>(GV)->getInitializer();
111
Anton Korobeynikov84e160e2008-08-07 09:51:02 +0000112 return MergeableConstSection(C->getType());
113}
114
115inline const Section*
116DarwinTargetAsmInfo::MergeableConstSection(const Type *Ty) const {
117 const TargetData *TD = DTM->getTargetData();
118
119 unsigned Size = TD->getABITypeSize(Ty);
Anton Korobeynikov745e8642008-07-19 13:14:46 +0000120 if (Size == 4)
121 return FourByteConstantSection_;
122 else if (Size == 8)
123 return EightByteConstantSection_;
Anton Korobeynikovcff2ea02008-07-19 13:15:46 +0000124 else if (Size == 16 && SixteenByteConstantSection_)
125 return SixteenByteConstantSection_;
Anton Korobeynikov745e8642008-07-19 13:14:46 +0000126
127 return getReadOnlySection_();
128}
129
Anton Korobeynikov84e160e2008-08-07 09:51:02 +0000130const Section*
131DarwinTargetAsmInfo::SelectSectionForMachineConst(const Type *Ty) const {
132 const Section* S = MergeableConstSection(Ty);
133
134 // Handle weird special case, when compiling PIC stuff.
135 if (S == getReadOnlySection_() &&
136 DTM->getRelocationModel() != Reloc::Static)
137 return ConstDataSection;
138
139 return S;
140}
141
Anton Korobeynikov745e8642008-07-19 13:14:46 +0000142std::string
143DarwinTargetAsmInfo::UniqueSectionForGlobal(const GlobalValue* GV,
144 SectionKind::Kind kind) const {
145 assert(0 && "Darwin does not use unique sections");
146 return "";
147}