blob: 746de2e36b43ff3b37f57a5b0ceaf9133b6dfacb [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
21 "android/soong/common"
22)
23
24var (
Colin Crossc4bde762015-11-23 16:11:30 -080025 armToolchainCflags = []string{
26 "-mthumb-interwork",
27 }
28
Colin Cross3f40fa42015-01-30 17:27:36 -080029 armCflags = []string{
30 "-fno-exceptions", // from build/core/combo/select.mk
31 "-Wno-multichar", // from build/core/combo/select.mk
Colin Cross13af54d2015-03-16 16:12:05 -070032 "-msoft-float",
Colin Cross3f40fa42015-01-30 17:27:36 -080033 "-ffunction-sections",
34 "-fdata-sections",
35 "-funwind-tables",
36 "-fstack-protector",
37 "-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",
Colin Cross3f40fa42015-01-30 17:27:36 -080069 }
70
71 armArmCflags = []string{
72 "-O2",
73 "-fomit-frame-pointer",
74 "-fstrict-aliasing",
75 "-funswitch-loops",
76 }
77
78 armThumbCflags = []string{
79 "-mthumb",
80 "-Os",
81 "-fomit-frame-pointer",
82 "-fno-strict-aliasing",
83 }
84
85 armArchVariantCflags = map[string][]string{
86 "armv5te": []string{
87 "-march=armv5te",
88 "-mtune=xscale",
89 "-D__ARM_ARCH_5__",
90 "-D__ARM_ARCH_5T__",
91 "-D__ARM_ARCH_5E__",
92 "-D__ARM_ARCH_5TE__",
93 },
94 "armv7-a": []string{
95 "-march=armv7-a",
96 "-mfloat-abi=softfp",
97 "-mfpu=vfpv3-d16",
98 },
99 "armv7-a-neon": []string{
100 "-mfloat-abi=softfp",
101 "-mfpu=neon",
102 },
103 }
104
Colin Cross3f40fa42015-01-30 17:27:36 -0800105 armCpuVariantCflags = map[string][]string{
106 "cortex-a7": []string{
107 "-mcpu=cortex-a7",
108 },
109 "cortex-a8": []string{
110 "-mcpu=cortex-a8",
111 },
112 "cortex-a15": []string{
113 "-mcpu=cortex-a15",
114 // Fake an ARM compiler flag as these processors support LPAE which GCC/clang
115 // don't advertise.
116 "-D__ARM_FEATURE_LPAE=1",
117 },
118 }
119
Dan Willemsenf5a959c2015-07-13 13:28:18 -0700120 armClangCpuVariantCflags = copyVariantFlags(armCpuVariantCflags)
121 armClangArchVariantCflags = copyVariantFlags(armArchVariantCflags)
Colin Cross3f40fa42015-01-30 17:27:36 -0800122)
123
Dan Willemsenf5a959c2015-07-13 13:28:18 -0700124func copyVariantFlags(m map[string][]string) map[string][]string {
125 ret := make(map[string][]string, len(m))
126 for k, v := range m {
127 l := make([]string, len(m[k]))
128 for i := range m[k] {
129 l[i] = v[i]
130 }
131 ret[k] = l
132 }
133 return ret
134}
135
Colin Cross3f40fa42015-01-30 17:27:36 -0800136func init() {
137 replaceFirst := func(slice []string, from, to string) {
138 if slice[0] != from {
139 panic(fmt.Errorf("Expected %q, found %q", from, to))
140 }
141
142 slice[0] = to
143 }
144
145 replaceFirst(armClangArchVariantCflags["armv5te"], "-march=armv5te", "-march=armv5t")
Colin Cross3f40fa42015-01-30 17:27:36 -0800146 armClangCpuVariantCflags["krait"] = []string{
147 "-mcpu=krait",
Dan Willemsen3bf6b472015-09-11 17:41:10 -0700148 "-mfpu=neon-vfpv4",
Colin Cross3f40fa42015-01-30 17:27:36 -0800149 }
150
151 pctx.StaticVariable("armGccVersion", "4.9")
152
153 pctx.StaticVariable("armGccRoot",
Dan Willemsen87b17d12015-07-14 00:39:06 -0700154 "prebuilts/gcc/${HostPrebuiltTag}/arm/arm-linux-androideabi-${armGccVersion}")
Colin Cross3f40fa42015-01-30 17:27:36 -0800155
156 pctx.StaticVariable("armGccTriple", "arm-linux-androideabi")
157
Colin Crossc4bde762015-11-23 16:11:30 -0800158 pctx.StaticVariable("armToolchainCflags", strings.Join(armToolchainCflags, " "))
Colin Cross3f40fa42015-01-30 17:27:36 -0800159 pctx.StaticVariable("armCflags", strings.Join(armCflags, " "))
160 pctx.StaticVariable("armLdflags", strings.Join(armLdflags, " "))
161 pctx.StaticVariable("armCppflags", strings.Join(armCppflags, " "))
162 pctx.StaticVariable("armIncludeFlags", strings.Join([]string{
163 "-isystem ${LibcRoot}/arch-arm/include",
164 "-isystem ${LibcRoot}/include",
165 "-isystem ${LibcRoot}/kernel/uapi",
166 "-isystem ${LibcRoot}/kernel/uapi/asm-arm",
167 "-isystem ${LibmRoot}/include",
168 "-isystem ${LibmRoot}/include/arm",
169 }, " "))
170
171 // Extended cflags
172
Tim Kilbourn1a9bf262015-03-18 12:28:32 -0700173 // ARM vs. Thumb instruction set flags
Colin Cross3f40fa42015-01-30 17:27:36 -0800174 pctx.StaticVariable("armArmCflags", strings.Join(armArmCflags, " "))
175 pctx.StaticVariable("armThumbCflags", strings.Join(armThumbCflags, " "))
176
177 // Architecture variant cflags
178 pctx.StaticVariable("armArmv5TECflags", strings.Join(armArchVariantCflags["armv5te"], " "))
179 pctx.StaticVariable("armArmv7ACflags", strings.Join(armArchVariantCflags["armv7-a"], " "))
180 pctx.StaticVariable("armArmv7ANeonCflags", strings.Join(armArchVariantCflags["armv7-a-neon"], " "))
181
Colin Cross3f40fa42015-01-30 17:27:36 -0800182 // Cpu variant cflags
183 pctx.StaticVariable("armCortexA7Cflags", strings.Join(armCpuVariantCflags["cortex-a7"], " "))
184 pctx.StaticVariable("armCortexA8Cflags", strings.Join(armCpuVariantCflags["cortex-a8"], " "))
185 pctx.StaticVariable("armCortexA15Cflags", strings.Join(armCpuVariantCflags["cortex-a15"], " "))
186
187 // Clang cflags
Colin Crossc4bde762015-11-23 16:11:30 -0800188 pctx.StaticVariable("armToolchainClangCflags", strings.Join(clangFilterUnknownCflags(armToolchainCflags), " "))
Colin Cross3f40fa42015-01-30 17:27:36 -0800189 pctx.StaticVariable("armClangCflags", strings.Join(clangFilterUnknownCflags(armCflags), " "))
190 pctx.StaticVariable("armClangLdflags", strings.Join(clangFilterUnknownCflags(armLdflags), " "))
191 pctx.StaticVariable("armClangCppflags", strings.Join(clangFilterUnknownCflags(armCppflags), " "))
192
Dan Willemsen6d11dd82015-11-03 14:27:00 -0800193 // Clang ARM vs. Thumb instruction set cflags
194 pctx.StaticVariable("armClangArmCflags", strings.Join(clangFilterUnknownCflags(armArmCflags), " "))
195 pctx.StaticVariable("armClangThumbCflags", strings.Join(clangFilterUnknownCflags(armThumbCflags), " "))
196
Colin Cross3f40fa42015-01-30 17:27:36 -0800197 // Clang cpu variant cflags
198 pctx.StaticVariable("armClangArmv5TECflags",
199 strings.Join(armClangArchVariantCflags["armv5te"], " "))
200 pctx.StaticVariable("armClangArmv7ACflags",
201 strings.Join(armClangArchVariantCflags["armv7-a"], " "))
202 pctx.StaticVariable("armClangArmv7ANeonCflags",
203 strings.Join(armClangArchVariantCflags["armv7-a-neon"], " "))
204
205 // Clang cpu variant cflags
206 pctx.StaticVariable("armClangCortexA7Cflags",
207 strings.Join(armClangCpuVariantCflags["cortex-a7"], " "))
208 pctx.StaticVariable("armClangCortexA8Cflags",
209 strings.Join(armClangCpuVariantCflags["cortex-a8"], " "))
210 pctx.StaticVariable("armClangCortexA15Cflags",
211 strings.Join(armClangCpuVariantCflags["cortex-a15"], " "))
212 pctx.StaticVariable("armClangKraitCflags",
213 strings.Join(armClangCpuVariantCflags["krait"], " "))
214}
215
216var (
217 armArchVariantCflagsVar = map[string]string{
218 "armv5te": "${armArmv5TECflags}",
219 "armv7-a": "${armArmv7ACflags}",
220 "armv7-a-neon": "${armArmv7ANeonCflags}",
221 }
222
Colin Cross3f40fa42015-01-30 17:27:36 -0800223 armCpuVariantCflagsVar = map[string]string{
Dan Willemsene6540452015-10-20 15:21:33 -0700224 "": "",
225 "cortex-a7": "${armCortexA7Cflags}",
226 "cortex-a8": "${armCortexA8Cflags}",
227 "cortex-a15": "${armCortexA15Cflags}",
228 "cortex-a53": "${armCortexA7Cflags}",
229 "cortex-a53.a57": "${armCortexA7Cflags}",
230 "krait": "${armCortexA15Cflags}",
231 "denver": "${armCortexA15Cflags}",
Colin Cross3f40fa42015-01-30 17:27:36 -0800232 }
233
234 armClangArchVariantCflagsVar = map[string]string{
235 "armv5te": "${armClangArmv5TECflags}",
236 "armv7-a": "${armClangArmv7ACflags}",
237 "armv7-a-neon": "${armClangArmv7ANeonCflags}",
238 }
239
240 armClangCpuVariantCflagsVar = map[string]string{
Dan Willemsene6540452015-10-20 15:21:33 -0700241 "": "",
242 "cortex-a7": "${armClangCortexA7Cflags}",
243 "cortex-a8": "${armClangCortexA8Cflags}",
244 "cortex-a15": "${armClangCortexA15Cflags}",
245 "cortex-a53": "${armClangCortexA7Cflags}",
246 "cortex-a53.a57": "${armClangCortexA7Cflags}",
247 "krait": "${armClangKraitCflags}",
248 "denver": "${armClangCortexA15Cflags}",
Colin Cross3f40fa42015-01-30 17:27:36 -0800249 }
250)
251
252type toolchainArm struct {
253 toolchain32Bit
Colin Crossc4bde762015-11-23 16:11:30 -0800254 ldflags string
255 toolchainCflags, toolchainClangCflags string
Colin Cross3f40fa42015-01-30 17:27:36 -0800256}
257
Dan Albertbe961682015-03-18 23:38:50 -0700258func (t *toolchainArm) Name() string {
259 return "arm"
260}
261
Colin Cross3f40fa42015-01-30 17:27:36 -0800262func (t *toolchainArm) GccRoot() string {
263 return "${armGccRoot}"
264}
265
266func (t *toolchainArm) GccTriple() string {
267 return "${armGccTriple}"
268}
269
Dan Albertbe961682015-03-18 23:38:50 -0700270func (t *toolchainArm) GccVersion() string {
271 return "${armGccVersion}"
272}
273
Colin Crossc4bde762015-11-23 16:11:30 -0800274func (t *toolchainArm) ToolchainCflags() string {
275 return t.toolchainCflags
276}
277
Colin Cross3f40fa42015-01-30 17:27:36 -0800278func (t *toolchainArm) Cflags() string {
Colin Crossc4bde762015-11-23 16:11:30 -0800279 return "${armCflags}"
Colin Cross3f40fa42015-01-30 17:27:36 -0800280}
281
282func (t *toolchainArm) Cppflags() string {
283 return "${armCppflags}"
284}
285
286func (t *toolchainArm) Ldflags() string {
287 return t.ldflags
288}
289
290func (t *toolchainArm) IncludeFlags() string {
291 return "${armIncludeFlags}"
292}
293
Tim Kilbourn1a9bf262015-03-18 12:28:32 -0700294func (t *toolchainArm) InstructionSetFlags(isa string) (string, error) {
295 switch isa {
296 case "arm":
297 return "${armArmCflags}", nil
298 case "thumb", "":
299 return "${armThumbCflags}", nil
300 default:
301 return t.toolchainBase.InstructionSetFlags(isa)
302 }
303}
304
Colin Cross3f40fa42015-01-30 17:27:36 -0800305func (t *toolchainArm) ClangTriple() string {
306 return "${armGccTriple}"
307}
308
Colin Crossc4bde762015-11-23 16:11:30 -0800309func (t *toolchainArm) ToolchainClangCflags() string {
310 return t.toolchainClangCflags
311}
312
Colin Cross3f40fa42015-01-30 17:27:36 -0800313func (t *toolchainArm) ClangCflags() string {
Colin Crossc4bde762015-11-23 16:11:30 -0800314 return "${armClangCflags}"
Colin Cross3f40fa42015-01-30 17:27:36 -0800315}
316
317func (t *toolchainArm) ClangCppflags() string {
318 return "${armClangCppflags}"
319}
320
321func (t *toolchainArm) ClangLdflags() string {
322 return t.ldflags
323}
324
Dan Willemsen6d11dd82015-11-03 14:27:00 -0800325func (t *toolchainArm) ClangInstructionSetFlags(isa string) (string, error) {
326 switch isa {
327 case "arm":
328 return "${armClangArmCflags}", nil
329 case "thumb", "":
330 return "${armClangThumbCflags}", nil
331 default:
332 return t.toolchainBase.ClangInstructionSetFlags(isa)
333 }
334}
335
Colin Crossc5c24ad2015-11-20 15:35:00 -0800336func armToolchainFactory(arch common.Arch) Toolchain {
Colin Crossc1e814d2015-04-28 13:15:59 -0700337 var fixCortexA8 string
Colin Crossc5c24ad2015-11-20 15:35:00 -0800338 switch arch.CpuVariant {
Colin Crossc1e814d2015-04-28 13:15:59 -0700339 case "cortex-a8", "":
340 // Generic ARM might be a Cortex A8 -- better safe than sorry
341 fixCortexA8 = "-Wl,--fix-cortex-a8"
342 default:
343 fixCortexA8 = "-Wl,--no-fix-cortex-a8"
344 }
345
Colin Cross3f40fa42015-01-30 17:27:36 -0800346 return &toolchainArm{
Colin Crossc4bde762015-11-23 16:11:30 -0800347 toolchainCflags: strings.Join([]string{
348 "${armToolchainCflags}",
Colin Crossc5c24ad2015-11-20 15:35:00 -0800349 armArchVariantCflagsVar[arch.ArchVariant],
350 armCpuVariantCflagsVar[arch.CpuVariant],
Colin Cross3f40fa42015-01-30 17:27:36 -0800351 }, " "),
352 ldflags: strings.Join([]string{
353 "${armLdflags}",
Colin Crossc1e814d2015-04-28 13:15:59 -0700354 fixCortexA8,
Colin Cross3f40fa42015-01-30 17:27:36 -0800355 }, " "),
Colin Crossc4bde762015-11-23 16:11:30 -0800356 toolchainClangCflags: strings.Join([]string{
357 "${armToolchainClangCflags}",
Colin Crossc5c24ad2015-11-20 15:35:00 -0800358 armClangArchVariantCflagsVar[arch.ArchVariant],
359 armClangCpuVariantCflagsVar[arch.CpuVariant],
Colin Cross3f40fa42015-01-30 17:27:36 -0800360 }, " "),
361 }
362}
363
364func init() {
365 registerToolchainFactory(common.Device, common.Arm, armToolchainFactory)
366}