blob: e985a3825f523e28522520cc22c18ec1644a6b09 [file] [log] [blame]
Colin Crossb0cba6a2015-11-20 15:35:26 -08001// Copyright 2015 Google Inc. All rights reserved.
2//
3// Licensed under the Apache License, Version 2.0 (the "License");
4// you may not use this file except in compliance with the License.
5// You may obtain a copy of the License at
6//
7// http://www.apache.org/licenses/LICENSE-2.0
8//
9// Unless required by applicable law or agreed to in writing, software
10// distributed under the License is distributed on an "AS IS" BASIS,
11// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12// See the License for the specific language governing permissions and
13// limitations under the License.
14
Colin Cross3f40fa42015-01-30 17:27:36 -080015package cc
16
17import (
18 "fmt"
19 "strings"
20
Colin Cross635c3b02016-05-18 15:37:25 -070021 "android/soong/android"
Colin Cross3f40fa42015-01-30 17:27:36 -080022)
23
24var (
Colin Crossc4bde762015-11-23 16:11:30 -080025 armToolchainCflags = []string{
26 "-mthumb-interwork",
Dan Willemsenc264c162016-05-18 22:52:25 -070027 "-msoft-float",
Colin Crossc4bde762015-11-23 16:11:30 -080028 }
29
Colin Cross3f40fa42015-01-30 17:27:36 -080030 armCflags = []string{
31 "-fno-exceptions", // from build/core/combo/select.mk
32 "-Wno-multichar", // from build/core/combo/select.mk
Colin Cross3f40fa42015-01-30 17:27:36 -080033 "-ffunction-sections",
34 "-fdata-sections",
35 "-funwind-tables",
Dan Willemsen7a0f8482016-01-12 16:22:40 -080036 "-fstack-protector-strong",
Colin Cross3f40fa42015-01-30 17:27:36 -080037 "-Wa,--noexecstack",
38 "-Werror=format-security",
39 "-D_FORTIFY_SOURCE=2",
40 "-fno-short-enums",
41 "-no-canonical-prefixes",
42 "-fno-canonical-system-headers",
Colin Cross3f40fa42015-01-30 17:27:36 -080043
44 "-fno-builtin-sin",
45 "-fno-strict-volatile-bitfields",
46
47 // TARGET_RELEASE_CFLAGS
48 "-DNDEBUG",
49 "-g",
50 "-Wstrict-aliasing=2",
51 "-fgcse-after-reload",
52 "-frerun-cse-after-loop",
53 "-frename-registers",
54 }
55
56 armCppflags = []string{
57 "-fvisibility-inlines-hidden",
58 }
59
60 armLdflags = []string{
61 "-Wl,-z,noexecstack",
62 "-Wl,-z,relro",
63 "-Wl,-z,now",
64 "-Wl,--build-id=md5",
65 "-Wl,--warn-shared-textrel",
66 "-Wl,--fatal-warnings",
Colin Cross13af54d2015-03-16 16:12:05 -070067 "-Wl,--icf=safe",
Colin Cross3f40fa42015-01-30 17:27:36 -080068 "-Wl,--hash-style=gnu",
Dan Willemsenc7e45972015-12-09 13:05:28 -080069 "-Wl,--no-undefined-version",
Colin Cross3f40fa42015-01-30 17:27:36 -080070 }
71
72 armArmCflags = []string{
73 "-O2",
74 "-fomit-frame-pointer",
75 "-fstrict-aliasing",
76 "-funswitch-loops",
77 }
78
79 armThumbCflags = []string{
80 "-mthumb",
81 "-Os",
82 "-fomit-frame-pointer",
83 "-fno-strict-aliasing",
84 }
85
86 armArchVariantCflags = map[string][]string{
87 "armv5te": []string{
88 "-march=armv5te",
89 "-mtune=xscale",
90 "-D__ARM_ARCH_5__",
91 "-D__ARM_ARCH_5T__",
92 "-D__ARM_ARCH_5E__",
93 "-D__ARM_ARCH_5TE__",
94 },
95 "armv7-a": []string{
96 "-march=armv7-a",
97 "-mfloat-abi=softfp",
98 "-mfpu=vfpv3-d16",
99 },
100 "armv7-a-neon": []string{
101 "-mfloat-abi=softfp",
102 "-mfpu=neon",
103 },
104 }
105
Colin Cross3f40fa42015-01-30 17:27:36 -0800106 armCpuVariantCflags = map[string][]string{
Dan Willemsen110a89d2016-01-14 15:17:19 -0800107 "": []string{
108 "-march=armv7-a",
109 },
Colin Cross3f40fa42015-01-30 17:27:36 -0800110 "cortex-a7": []string{
111 "-mcpu=cortex-a7",
Dan Willemsen8e1e3fb2016-03-29 15:47:08 -0700112 // Fake an ARM compiler flag as these processors support LPAE which GCC/clang
113 // don't advertise.
114 // TODO This is a hack and we need to add it for each processor that supports LPAE until some
115 // better solution comes around. See Bug 27340895
116 "-D__ARM_FEATURE_LPAE=1",
Colin Cross3f40fa42015-01-30 17:27:36 -0800117 },
118 "cortex-a8": []string{
119 "-mcpu=cortex-a8",
120 },
121 "cortex-a15": []string{
122 "-mcpu=cortex-a15",
123 // Fake an ARM compiler flag as these processors support LPAE which GCC/clang
124 // don't advertise.
Dan Willemsen8e1e3fb2016-03-29 15:47:08 -0700125 // TODO This is a hack and we need to add it for each processor that supports LPAE until some
126 // better solution comes around. See Bug 27340895
Colin Cross3f40fa42015-01-30 17:27:36 -0800127 "-D__ARM_FEATURE_LPAE=1",
128 },
Dan Willemsened89a7a2016-05-09 13:39:58 -0700129 "krait": []string{
130 "-mcpu=cortex-a15",
131 // Fake an ARM compiler flag as these processors support LPAE which GCC/clang
132 // don't advertise.
133 // TODO This is a hack and we need to add it for each processor that supports LPAE until some
134 // better solution comes around. See Bug 27340895
135 "-D__ARM_FEATURE_LPAE=1",
136 },
Colin Cross3f40fa42015-01-30 17:27:36 -0800137 }
138
Dan Willemsenf5a959c2015-07-13 13:28:18 -0700139 armClangCpuVariantCflags = copyVariantFlags(armCpuVariantCflags)
140 armClangArchVariantCflags = copyVariantFlags(armArchVariantCflags)
Colin Cross3f40fa42015-01-30 17:27:36 -0800141)
142
Dan Willemsen34fc3b12015-12-07 12:30:44 -0800143const (
144 armGccVersion = "4.9"
145)
146
Colin Cross3f40fa42015-01-30 17:27:36 -0800147func init() {
148 replaceFirst := func(slice []string, from, to string) {
149 if slice[0] != from {
150 panic(fmt.Errorf("Expected %q, found %q", from, to))
151 }
152
153 slice[0] = to
154 }
155
156 replaceFirst(armClangArchVariantCflags["armv5te"], "-march=armv5te", "-march=armv5t")
Dan Willemsened89a7a2016-05-09 13:39:58 -0700157 replaceFirst(armClangCpuVariantCflags["krait"], "-mcpu=cortex-a15", "-mcpu=krait")
158 armClangCpuVariantCflags["krait"] = append(armClangCpuVariantCflags["krait"], "-mfpu=neon-vfpv4")
Colin Cross3f40fa42015-01-30 17:27:36 -0800159
Dan Willemsen34fc3b12015-12-07 12:30:44 -0800160 pctx.StaticVariable("armGccVersion", armGccVersion)
Colin Cross3f40fa42015-01-30 17:27:36 -0800161
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700162 pctx.SourcePathVariable("armGccRoot",
Dan Willemsen87b17d12015-07-14 00:39:06 -0700163 "prebuilts/gcc/${HostPrebuiltTag}/arm/arm-linux-androideabi-${armGccVersion}")
Colin Cross3f40fa42015-01-30 17:27:36 -0800164
165 pctx.StaticVariable("armGccTriple", "arm-linux-androideabi")
166
Colin Crossc4bde762015-11-23 16:11:30 -0800167 pctx.StaticVariable("armToolchainCflags", strings.Join(armToolchainCflags, " "))
Colin Cross3f40fa42015-01-30 17:27:36 -0800168 pctx.StaticVariable("armCflags", strings.Join(armCflags, " "))
169 pctx.StaticVariable("armLdflags", strings.Join(armLdflags, " "))
170 pctx.StaticVariable("armCppflags", strings.Join(armCppflags, " "))
171 pctx.StaticVariable("armIncludeFlags", strings.Join([]string{
172 "-isystem ${LibcRoot}/arch-arm/include",
173 "-isystem ${LibcRoot}/include",
174 "-isystem ${LibcRoot}/kernel/uapi",
Christopher Ferrisb68ea7a2016-07-18 18:36:31 -0700175 "-isystem ${LibcRoot}/kernel/android/uapi",
Dan Willemsena2abfd62016-05-18 14:32:32 -0700176 "-isystem ${LibcRoot}/kernel/common",
Colin Cross3f40fa42015-01-30 17:27:36 -0800177 "-isystem ${LibcRoot}/kernel/uapi/asm-arm",
Colin Cross3f40fa42015-01-30 17:27:36 -0800178 }, " "))
179
180 // Extended cflags
181
Tim Kilbourn1a9bf262015-03-18 12:28:32 -0700182 // ARM vs. Thumb instruction set flags
Colin Cross3f40fa42015-01-30 17:27:36 -0800183 pctx.StaticVariable("armArmCflags", strings.Join(armArmCflags, " "))
184 pctx.StaticVariable("armThumbCflags", strings.Join(armThumbCflags, " "))
185
186 // Architecture variant cflags
187 pctx.StaticVariable("armArmv5TECflags", strings.Join(armArchVariantCflags["armv5te"], " "))
188 pctx.StaticVariable("armArmv7ACflags", strings.Join(armArchVariantCflags["armv7-a"], " "))
189 pctx.StaticVariable("armArmv7ANeonCflags", strings.Join(armArchVariantCflags["armv7-a-neon"], " "))
190
Colin Cross3f40fa42015-01-30 17:27:36 -0800191 // Cpu variant cflags
Dan Willemsen110a89d2016-01-14 15:17:19 -0800192 pctx.StaticVariable("armGenericCflags", strings.Join(armCpuVariantCflags[""], " "))
Colin Cross3f40fa42015-01-30 17:27:36 -0800193 pctx.StaticVariable("armCortexA7Cflags", strings.Join(armCpuVariantCflags["cortex-a7"], " "))
194 pctx.StaticVariable("armCortexA8Cflags", strings.Join(armCpuVariantCflags["cortex-a8"], " "))
195 pctx.StaticVariable("armCortexA15Cflags", strings.Join(armCpuVariantCflags["cortex-a15"], " "))
Dan Willemsened89a7a2016-05-09 13:39:58 -0700196 pctx.StaticVariable("armKraitCflags", strings.Join(armCpuVariantCflags["krait"], " "))
Colin Cross3f40fa42015-01-30 17:27:36 -0800197
198 // Clang cflags
Colin Crossc4bde762015-11-23 16:11:30 -0800199 pctx.StaticVariable("armToolchainClangCflags", strings.Join(clangFilterUnknownCflags(armToolchainCflags), " "))
Colin Cross3f40fa42015-01-30 17:27:36 -0800200 pctx.StaticVariable("armClangCflags", strings.Join(clangFilterUnknownCflags(armCflags), " "))
201 pctx.StaticVariable("armClangLdflags", strings.Join(clangFilterUnknownCflags(armLdflags), " "))
202 pctx.StaticVariable("armClangCppflags", strings.Join(clangFilterUnknownCflags(armCppflags), " "))
203
Dan Willemsen6d11dd82015-11-03 14:27:00 -0800204 // Clang ARM vs. Thumb instruction set cflags
205 pctx.StaticVariable("armClangArmCflags", strings.Join(clangFilterUnknownCflags(armArmCflags), " "))
206 pctx.StaticVariable("armClangThumbCflags", strings.Join(clangFilterUnknownCflags(armThumbCflags), " "))
207
Dan Willemsen110a89d2016-01-14 15:17:19 -0800208 // Clang arch variant cflags
Colin Cross3f40fa42015-01-30 17:27:36 -0800209 pctx.StaticVariable("armClangArmv5TECflags",
210 strings.Join(armClangArchVariantCflags["armv5te"], " "))
211 pctx.StaticVariable("armClangArmv7ACflags",
212 strings.Join(armClangArchVariantCflags["armv7-a"], " "))
213 pctx.StaticVariable("armClangArmv7ANeonCflags",
214 strings.Join(armClangArchVariantCflags["armv7-a-neon"], " "))
215
216 // Clang cpu variant cflags
Dan Willemsen110a89d2016-01-14 15:17:19 -0800217 pctx.StaticVariable("armClangGenericCflags",
218 strings.Join(armClangCpuVariantCflags[""], " "))
Colin Cross3f40fa42015-01-30 17:27:36 -0800219 pctx.StaticVariable("armClangCortexA7Cflags",
220 strings.Join(armClangCpuVariantCflags["cortex-a7"], " "))
221 pctx.StaticVariable("armClangCortexA8Cflags",
222 strings.Join(armClangCpuVariantCflags["cortex-a8"], " "))
223 pctx.StaticVariable("armClangCortexA15Cflags",
224 strings.Join(armClangCpuVariantCflags["cortex-a15"], " "))
225 pctx.StaticVariable("armClangKraitCflags",
226 strings.Join(armClangCpuVariantCflags["krait"], " "))
227}
228
229var (
230 armArchVariantCflagsVar = map[string]string{
231 "armv5te": "${armArmv5TECflags}",
232 "armv7-a": "${armArmv7ACflags}",
233 "armv7-a-neon": "${armArmv7ANeonCflags}",
234 }
235
Colin Cross3f40fa42015-01-30 17:27:36 -0800236 armCpuVariantCflagsVar = map[string]string{
Dan Willemsen110a89d2016-01-14 15:17:19 -0800237 "": "${armGenericCflags}",
Dan Willemsene6540452015-10-20 15:21:33 -0700238 "cortex-a7": "${armCortexA7Cflags}",
239 "cortex-a8": "${armCortexA8Cflags}",
240 "cortex-a15": "${armCortexA15Cflags}",
241 "cortex-a53": "${armCortexA7Cflags}",
242 "cortex-a53.a57": "${armCortexA7Cflags}",
Dan Willemsened89a7a2016-05-09 13:39:58 -0700243 "krait": "${armKraitCflags}",
Dan Willemsene6540452015-10-20 15:21:33 -0700244 "denver": "${armCortexA15Cflags}",
Colin Cross3f40fa42015-01-30 17:27:36 -0800245 }
246
247 armClangArchVariantCflagsVar = map[string]string{
248 "armv5te": "${armClangArmv5TECflags}",
249 "armv7-a": "${armClangArmv7ACflags}",
250 "armv7-a-neon": "${armClangArmv7ANeonCflags}",
251 }
252
253 armClangCpuVariantCflagsVar = map[string]string{
Dan Willemsen110a89d2016-01-14 15:17:19 -0800254 "": "${armClangGenericCflags}",
Dan Willemsene6540452015-10-20 15:21:33 -0700255 "cortex-a7": "${armClangCortexA7Cflags}",
256 "cortex-a8": "${armClangCortexA8Cflags}",
257 "cortex-a15": "${armClangCortexA15Cflags}",
258 "cortex-a53": "${armClangCortexA7Cflags}",
259 "cortex-a53.a57": "${armClangCortexA7Cflags}",
260 "krait": "${armClangKraitCflags}",
261 "denver": "${armClangCortexA15Cflags}",
Colin Cross3f40fa42015-01-30 17:27:36 -0800262 }
263)
264
265type toolchainArm struct {
266 toolchain32Bit
Colin Crossc4bde762015-11-23 16:11:30 -0800267 ldflags string
268 toolchainCflags, toolchainClangCflags string
Colin Cross3f40fa42015-01-30 17:27:36 -0800269}
270
Dan Albertbe961682015-03-18 23:38:50 -0700271func (t *toolchainArm) Name() string {
272 return "arm"
273}
274
Colin Cross3f40fa42015-01-30 17:27:36 -0800275func (t *toolchainArm) GccRoot() string {
276 return "${armGccRoot}"
277}
278
279func (t *toolchainArm) GccTriple() string {
280 return "${armGccTriple}"
281}
282
Dan Albertbe961682015-03-18 23:38:50 -0700283func (t *toolchainArm) GccVersion() string {
Dan Willemsen34fc3b12015-12-07 12:30:44 -0800284 return armGccVersion
Dan Albertbe961682015-03-18 23:38:50 -0700285}
286
Colin Crossc4bde762015-11-23 16:11:30 -0800287func (t *toolchainArm) ToolchainCflags() string {
288 return t.toolchainCflags
289}
290
Colin Cross3f40fa42015-01-30 17:27:36 -0800291func (t *toolchainArm) Cflags() string {
Colin Crossc4bde762015-11-23 16:11:30 -0800292 return "${armCflags}"
Colin Cross3f40fa42015-01-30 17:27:36 -0800293}
294
295func (t *toolchainArm) Cppflags() string {
296 return "${armCppflags}"
297}
298
299func (t *toolchainArm) Ldflags() string {
300 return t.ldflags
301}
302
303func (t *toolchainArm) IncludeFlags() string {
304 return "${armIncludeFlags}"
305}
306
Tim Kilbourn1a9bf262015-03-18 12:28:32 -0700307func (t *toolchainArm) InstructionSetFlags(isa string) (string, error) {
308 switch isa {
309 case "arm":
310 return "${armArmCflags}", nil
311 case "thumb", "":
312 return "${armThumbCflags}", nil
313 default:
314 return t.toolchainBase.InstructionSetFlags(isa)
315 }
316}
317
Colin Cross3f40fa42015-01-30 17:27:36 -0800318func (t *toolchainArm) ClangTriple() string {
319 return "${armGccTriple}"
320}
321
Colin Crossc4bde762015-11-23 16:11:30 -0800322func (t *toolchainArm) ToolchainClangCflags() string {
323 return t.toolchainClangCflags
324}
325
Colin Cross3f40fa42015-01-30 17:27:36 -0800326func (t *toolchainArm) ClangCflags() string {
Colin Crossc4bde762015-11-23 16:11:30 -0800327 return "${armClangCflags}"
Colin Cross3f40fa42015-01-30 17:27:36 -0800328}
329
330func (t *toolchainArm) ClangCppflags() string {
331 return "${armClangCppflags}"
332}
333
334func (t *toolchainArm) ClangLdflags() string {
335 return t.ldflags
336}
337
Dan Willemsen6d11dd82015-11-03 14:27:00 -0800338func (t *toolchainArm) ClangInstructionSetFlags(isa string) (string, error) {
339 switch isa {
340 case "arm":
341 return "${armClangArmCflags}", nil
342 case "thumb", "":
343 return "${armClangThumbCflags}", nil
344 default:
345 return t.toolchainBase.ClangInstructionSetFlags(isa)
346 }
347}
348
Colin Cross16b23492016-01-06 14:41:07 -0800349func (toolchainArm) AddressSanitizerRuntimeLibrary() string {
350 return "libclang_rt.asan-arm-android.so"
351}
352
Colin Cross635c3b02016-05-18 15:37:25 -0700353func armToolchainFactory(arch android.Arch) Toolchain {
Colin Crossc1e814d2015-04-28 13:15:59 -0700354 var fixCortexA8 string
Dan Willemsen110a89d2016-01-14 15:17:19 -0800355 toolchainCflags := make([]string, 2, 3)
356 toolchainClangCflags := make([]string, 2, 3)
357
358 toolchainCflags[0] = "${armToolchainCflags}"
359 toolchainCflags[1] = armArchVariantCflagsVar[arch.ArchVariant]
360 toolchainClangCflags[0] = "${armToolchainClangCflags}"
361 toolchainClangCflags[1] = armClangArchVariantCflagsVar[arch.ArchVariant]
362
363 switch arch.ArchVariant {
364 case "armv7-a-neon":
365 switch arch.CpuVariant {
366 case "cortex-a8", "":
367 // Generic ARM might be a Cortex A8 -- better safe than sorry
368 fixCortexA8 = "-Wl,--fix-cortex-a8"
369 default:
370 fixCortexA8 = "-Wl,--no-fix-cortex-a8"
371 }
372
373 toolchainCflags = append(toolchainCflags,
374 variantOrDefault(armCpuVariantCflagsVar, arch.CpuVariant))
375 toolchainClangCflags = append(toolchainClangCflags,
376 variantOrDefault(armClangCpuVariantCflagsVar, arch.CpuVariant))
377 case "armv7-a":
Colin Crossc1e814d2015-04-28 13:15:59 -0700378 fixCortexA8 = "-Wl,--fix-cortex-a8"
Dan Willemsen110a89d2016-01-14 15:17:19 -0800379 case "armv5te":
380 // Nothing extra for armv5te
Colin Crossc1e814d2015-04-28 13:15:59 -0700381 default:
Dan Willemsen110a89d2016-01-14 15:17:19 -0800382 panic(fmt.Sprintf("Unknown ARM architecture version: %q", arch.ArchVariant))
Colin Crossc1e814d2015-04-28 13:15:59 -0700383 }
384
Colin Cross3f40fa42015-01-30 17:27:36 -0800385 return &toolchainArm{
Dan Willemsen110a89d2016-01-14 15:17:19 -0800386 toolchainCflags: strings.Join(toolchainCflags, " "),
Colin Cross3f40fa42015-01-30 17:27:36 -0800387 ldflags: strings.Join([]string{
388 "${armLdflags}",
Colin Crossc1e814d2015-04-28 13:15:59 -0700389 fixCortexA8,
Colin Cross3f40fa42015-01-30 17:27:36 -0800390 }, " "),
Dan Willemsen110a89d2016-01-14 15:17:19 -0800391 toolchainClangCflags: strings.Join(toolchainClangCflags, " "),
Colin Cross3f40fa42015-01-30 17:27:36 -0800392 }
393}
394
395func init() {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700396 registerToolchainFactory(android.Android, android.Arm, armToolchainFactory)
Colin Cross3f40fa42015-01-30 17:27:36 -0800397}