blob: d070935040a7e21a82687cf8a3215b4e1cecc5eb [file] [log] [blame]
Colin Cross3f40fa42015-01-30 17:27:36 -08001package cc
2
3import (
4 "fmt"
5 "strings"
6
7 "android/soong/common"
8)
9
10var (
11 armCflags = []string{
12 "-fno-exceptions", // from build/core/combo/select.mk
13 "-Wno-multichar", // from build/core/combo/select.mk
14 "-fno-strict-aliasing",
15 "-fstack-protector",
16 "-ffunction-sections",
17 "-fdata-sections",
18 "-funwind-tables",
19 "-fstack-protector",
20 "-Wa,--noexecstack",
21 "-Werror=format-security",
22 "-D_FORTIFY_SOURCE=2",
23 "-fno-short-enums",
24 "-no-canonical-prefixes",
25 "-fno-canonical-system-headers",
26 "-include ${SrcDir}/build/core/combo/include/arch/linux-arm/AndroidConfig.h",
27
28 "-fno-builtin-sin",
29 "-fno-strict-volatile-bitfields",
30
31 // TARGET_RELEASE_CFLAGS
32 "-DNDEBUG",
33 "-g",
34 "-Wstrict-aliasing=2",
35 "-fgcse-after-reload",
36 "-frerun-cse-after-loop",
37 "-frename-registers",
38 }
39
40 armCppflags = []string{
41 "-fvisibility-inlines-hidden",
42 }
43
44 armLdflags = []string{
45 "-Wl,-z,noexecstack",
46 "-Wl,-z,relro",
47 "-Wl,-z,now",
48 "-Wl,--build-id=md5",
49 "-Wl,--warn-shared-textrel",
50 "-Wl,--fatal-warnings",
51 "-Wl,-icf=safe",
52 "-Wl,--hash-style=gnu",
53
54 // Disable transitive dependency library symbol resolving.
55 "-Wl,--allow-shlib-undefined",
56 }
57
58 armArmCflags = []string{
59 "-O2",
60 "-fomit-frame-pointer",
61 "-fstrict-aliasing",
62 "-funswitch-loops",
63 }
64
65 armThumbCflags = []string{
66 "-mthumb",
67 "-Os",
68 "-fomit-frame-pointer",
69 "-fno-strict-aliasing",
70 }
71
72 armArchVariantCflags = map[string][]string{
73 "armv5te": []string{
74 "-march=armv5te",
75 "-mtune=xscale",
76 "-D__ARM_ARCH_5__",
77 "-D__ARM_ARCH_5T__",
78 "-D__ARM_ARCH_5E__",
79 "-D__ARM_ARCH_5TE__",
80 },
81 "armv7-a": []string{
82 "-march=armv7-a",
83 "-mfloat-abi=softfp",
84 "-mfpu=vfpv3-d16",
85 },
86 "armv7-a-neon": []string{
87 "-mfloat-abi=softfp",
88 "-mfpu=neon",
89 },
90 }
91
92 armArchVariantLdflags = map[string][]string{
93 "armv7-a": []string{
94 "-Wl,--fix-cortex-a8",
95 },
96 }
97
98 armCpuVariantCflags = map[string][]string{
99 "cortex-a7": []string{
100 "-mcpu=cortex-a7",
101 },
102 "cortex-a8": []string{
103 "-mcpu=cortex-a8",
104 },
105 "cortex-a15": []string{
106 "-mcpu=cortex-a15",
107 // Fake an ARM compiler flag as these processors support LPAE which GCC/clang
108 // don't advertise.
109 "-D__ARM_FEATURE_LPAE=1",
110 },
111 }
112
113 armClangCpuVariantCflags = armCpuVariantCflags
114 armClangArchVariantCflags = armArchVariantCflags
115)
116
117func init() {
118 replaceFirst := func(slice []string, from, to string) {
119 if slice[0] != from {
120 panic(fmt.Errorf("Expected %q, found %q", from, to))
121 }
122
123 slice[0] = to
124 }
125
126 replaceFirst(armClangArchVariantCflags["armv5te"], "-march=armv5te", "-march=armv5t")
127 replaceFirst(armClangCpuVariantCflags["cortex-a15"], "-mcpu=cortex-a15", "-march=armv7-a")
128 armClangCpuVariantCflags["krait"] = []string{
129 "-mcpu=krait",
130 }
131
132 pctx.StaticVariable("armGccVersion", "4.9")
133
134 pctx.StaticVariable("armGccRoot",
135 "${SrcDir}/prebuilts/gcc/${HostPrebuiltTag}/arm/arm-linux-androideabi-${armGccVersion}")
136
137 pctx.StaticVariable("armGccTriple", "arm-linux-androideabi")
138
139 pctx.StaticVariable("armCflags", strings.Join(armCflags, " "))
140 pctx.StaticVariable("armLdflags", strings.Join(armLdflags, " "))
141 pctx.StaticVariable("armCppflags", strings.Join(armCppflags, " "))
142 pctx.StaticVariable("armIncludeFlags", strings.Join([]string{
143 "-isystem ${LibcRoot}/arch-arm/include",
144 "-isystem ${LibcRoot}/include",
145 "-isystem ${LibcRoot}/kernel/uapi",
146 "-isystem ${LibcRoot}/kernel/uapi/asm-arm",
147 "-isystem ${LibmRoot}/include",
148 "-isystem ${LibmRoot}/include/arm",
149 }, " "))
150
151 // Extended cflags
152
153 // ARM mode vs. Thumb mode
154 pctx.StaticVariable("armArmCflags", strings.Join(armArmCflags, " "))
155 pctx.StaticVariable("armThumbCflags", strings.Join(armThumbCflags, " "))
156
157 // Architecture variant cflags
158 pctx.StaticVariable("armArmv5TECflags", strings.Join(armArchVariantCflags["armv5te"], " "))
159 pctx.StaticVariable("armArmv7ACflags", strings.Join(armArchVariantCflags["armv7-a"], " "))
160 pctx.StaticVariable("armArmv7ANeonCflags", strings.Join(armArchVariantCflags["armv7-a-neon"], " "))
161
162 // Architecture variant ldflags
163 pctx.StaticVariable("armArmv7ALdflags", strings.Join(armArchVariantLdflags["armv7-a"], " "))
164
165 // Cpu variant cflags
166 pctx.StaticVariable("armCortexA7Cflags", strings.Join(armCpuVariantCflags["cortex-a7"], " "))
167 pctx.StaticVariable("armCortexA8Cflags", strings.Join(armCpuVariantCflags["cortex-a8"], " "))
168 pctx.StaticVariable("armCortexA15Cflags", strings.Join(armCpuVariantCflags["cortex-a15"], " "))
169
170 // Clang cflags
171 pctx.StaticVariable("armClangCflags", strings.Join(clangFilterUnknownCflags(armCflags), " "))
172 pctx.StaticVariable("armClangLdflags", strings.Join(clangFilterUnknownCflags(armLdflags), " "))
173 pctx.StaticVariable("armClangCppflags", strings.Join(clangFilterUnknownCflags(armCppflags), " "))
174
175 // Clang cpu variant cflags
176 pctx.StaticVariable("armClangArmv5TECflags",
177 strings.Join(armClangArchVariantCflags["armv5te"], " "))
178 pctx.StaticVariable("armClangArmv7ACflags",
179 strings.Join(armClangArchVariantCflags["armv7-a"], " "))
180 pctx.StaticVariable("armClangArmv7ANeonCflags",
181 strings.Join(armClangArchVariantCflags["armv7-a-neon"], " "))
182
183 // Clang cpu variant cflags
184 pctx.StaticVariable("armClangCortexA7Cflags",
185 strings.Join(armClangCpuVariantCflags["cortex-a7"], " "))
186 pctx.StaticVariable("armClangCortexA8Cflags",
187 strings.Join(armClangCpuVariantCflags["cortex-a8"], " "))
188 pctx.StaticVariable("armClangCortexA15Cflags",
189 strings.Join(armClangCpuVariantCflags["cortex-a15"], " "))
190 pctx.StaticVariable("armClangKraitCflags",
191 strings.Join(armClangCpuVariantCflags["krait"], " "))
192}
193
194var (
195 armArchVariantCflagsVar = map[string]string{
196 "armv5te": "${armArmv5TECflags}",
197 "armv7-a": "${armArmv7ACflags}",
198 "armv7-a-neon": "${armArmv7ANeonCflags}",
199 }
200
201 armArchVariantLdflagsVar = map[string]string{
202 "armv7-a": "${armArmv7ALdflags}",
203 "armv7-a-neon": "${armArmv7ALdflags}",
204 }
205
206 armCpuVariantCflagsVar = map[string]string{
207 "": "",
208 "cortex-a7": "${armCortexA7Cflags}",
209 "cortex-a8": "${armCortexA8Cflags}",
210 "cortex-a15": "${armCortexA15Cflags}",
211 "krait": "${armCortexA15Cflags}",
212 "denver": "${armCortexA15Cflags}",
213 }
214
215 armClangArchVariantCflagsVar = map[string]string{
216 "armv5te": "${armClangArmv5TECflags}",
217 "armv7-a": "${armClangArmv7ACflags}",
218 "armv7-a-neon": "${armClangArmv7ANeonCflags}",
219 }
220
221 armClangCpuVariantCflagsVar = map[string]string{
222 "": "",
223 "cortex-a7": "${armClangCortexA7Cflags}",
224 "cortex-a8": "${armClangCortexA8Cflags}",
225 "cortex-a15": "${armClangCortexA15Cflags}",
226 "krait": "${armClangKraitCflags}",
227 "denver": "${armClangCortexA15Cflags}",
228 }
229)
230
231type toolchainArm struct {
232 toolchain32Bit
233 cflags, ldflags, clangCflags string
234}
235
236func (t *toolchainArm) GccRoot() string {
237 return "${armGccRoot}"
238}
239
240func (t *toolchainArm) GccTriple() string {
241 return "${armGccTriple}"
242}
243
244func (t *toolchainArm) Cflags() string {
245 return t.cflags
246}
247
248func (t *toolchainArm) Cppflags() string {
249 return "${armCppflags}"
250}
251
252func (t *toolchainArm) Ldflags() string {
253 return t.ldflags
254}
255
256func (t *toolchainArm) IncludeFlags() string {
257 return "${armIncludeFlags}"
258}
259
260func (t *toolchainArm) ClangTriple() string {
261 return "${armGccTriple}"
262}
263
264func (t *toolchainArm) ClangCflags() string {
265 return t.clangCflags
266}
267
268func (t *toolchainArm) ClangCppflags() string {
269 return "${armClangCppflags}"
270}
271
272func (t *toolchainArm) ClangLdflags() string {
273 return t.ldflags
274}
275
276func armToolchainFactory(archVariant string, cpuVariant string) toolchain {
277 return &toolchainArm{
278 cflags: strings.Join([]string{
279 "${armCflags}",
280 "${armIncludeFlags}",
281 "${armThumbCflags}",
282 armArchVariantCflagsVar[archVariant],
283 armCpuVariantCflagsVar[cpuVariant],
284 }, " "),
285 ldflags: strings.Join([]string{
286 "${armLdflags}",
287 armArchVariantLdflagsVar[archVariant],
288 }, " "),
289 clangCflags: strings.Join([]string{
290 "${armClangCflags}",
291 "${armIncludeFlags}",
292 "${armThumbCflags}",
293 armClangArchVariantCflagsVar[archVariant],
294 armClangCpuVariantCflagsVar[cpuVariant],
295 }, " "),
296 }
297}
298
299func init() {
300 registerToolchainFactory(common.Device, common.Arm, armToolchainFactory)
301}