blob: 8fe5ce644157096880f321cbdb274f90c5f149ad [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 (
Colin Crossc4bde762015-11-23 16:11:30 -080011 armToolchainCflags = []string{
12 "-mthumb-interwork",
13 }
14
Colin Cross3f40fa42015-01-30 17:27:36 -080015 armCflags = []string{
16 "-fno-exceptions", // from build/core/combo/select.mk
17 "-Wno-multichar", // from build/core/combo/select.mk
Colin Cross13af54d2015-03-16 16:12:05 -070018 "-msoft-float",
Colin Cross3f40fa42015-01-30 17:27:36 -080019 "-ffunction-sections",
20 "-fdata-sections",
21 "-funwind-tables",
22 "-fstack-protector",
23 "-Wa,--noexecstack",
24 "-Werror=format-security",
25 "-D_FORTIFY_SOURCE=2",
26 "-fno-short-enums",
27 "-no-canonical-prefixes",
28 "-fno-canonical-system-headers",
Colin Cross3f40fa42015-01-30 17:27:36 -080029
30 "-fno-builtin-sin",
31 "-fno-strict-volatile-bitfields",
32
33 // TARGET_RELEASE_CFLAGS
34 "-DNDEBUG",
35 "-g",
36 "-Wstrict-aliasing=2",
37 "-fgcse-after-reload",
38 "-frerun-cse-after-loop",
39 "-frename-registers",
40 }
41
42 armCppflags = []string{
43 "-fvisibility-inlines-hidden",
44 }
45
46 armLdflags = []string{
47 "-Wl,-z,noexecstack",
48 "-Wl,-z,relro",
49 "-Wl,-z,now",
50 "-Wl,--build-id=md5",
51 "-Wl,--warn-shared-textrel",
52 "-Wl,--fatal-warnings",
Colin Cross13af54d2015-03-16 16:12:05 -070053 "-Wl,--icf=safe",
Colin Cross3f40fa42015-01-30 17:27:36 -080054 "-Wl,--hash-style=gnu",
Colin Cross3f40fa42015-01-30 17:27:36 -080055 }
56
57 armArmCflags = []string{
58 "-O2",
59 "-fomit-frame-pointer",
60 "-fstrict-aliasing",
61 "-funswitch-loops",
62 }
63
64 armThumbCflags = []string{
65 "-mthumb",
66 "-Os",
67 "-fomit-frame-pointer",
68 "-fno-strict-aliasing",
69 }
70
71 armArchVariantCflags = map[string][]string{
72 "armv5te": []string{
73 "-march=armv5te",
74 "-mtune=xscale",
75 "-D__ARM_ARCH_5__",
76 "-D__ARM_ARCH_5T__",
77 "-D__ARM_ARCH_5E__",
78 "-D__ARM_ARCH_5TE__",
79 },
80 "armv7-a": []string{
81 "-march=armv7-a",
82 "-mfloat-abi=softfp",
83 "-mfpu=vfpv3-d16",
84 },
85 "armv7-a-neon": []string{
86 "-mfloat-abi=softfp",
87 "-mfpu=neon",
88 },
89 }
90
Colin Cross3f40fa42015-01-30 17:27:36 -080091 armCpuVariantCflags = map[string][]string{
92 "cortex-a7": []string{
93 "-mcpu=cortex-a7",
94 },
95 "cortex-a8": []string{
96 "-mcpu=cortex-a8",
97 },
98 "cortex-a15": []string{
99 "-mcpu=cortex-a15",
100 // Fake an ARM compiler flag as these processors support LPAE which GCC/clang
101 // don't advertise.
102 "-D__ARM_FEATURE_LPAE=1",
103 },
104 }
105
Dan Willemsenf5a959c2015-07-13 13:28:18 -0700106 armClangCpuVariantCflags = copyVariantFlags(armCpuVariantCflags)
107 armClangArchVariantCflags = copyVariantFlags(armArchVariantCflags)
Colin Cross3f40fa42015-01-30 17:27:36 -0800108)
109
Dan Willemsenf5a959c2015-07-13 13:28:18 -0700110func copyVariantFlags(m map[string][]string) map[string][]string {
111 ret := make(map[string][]string, len(m))
112 for k, v := range m {
113 l := make([]string, len(m[k]))
114 for i := range m[k] {
115 l[i] = v[i]
116 }
117 ret[k] = l
118 }
119 return ret
120}
121
Colin Cross3f40fa42015-01-30 17:27:36 -0800122func init() {
123 replaceFirst := func(slice []string, from, to string) {
124 if slice[0] != from {
125 panic(fmt.Errorf("Expected %q, found %q", from, to))
126 }
127
128 slice[0] = to
129 }
130
131 replaceFirst(armClangArchVariantCflags["armv5te"], "-march=armv5te", "-march=armv5t")
Colin Cross3f40fa42015-01-30 17:27:36 -0800132 armClangCpuVariantCflags["krait"] = []string{
133 "-mcpu=krait",
Dan Willemsen3bf6b472015-09-11 17:41:10 -0700134 "-mfpu=neon-vfpv4",
Colin Cross3f40fa42015-01-30 17:27:36 -0800135 }
136
137 pctx.StaticVariable("armGccVersion", "4.9")
138
139 pctx.StaticVariable("armGccRoot",
Dan Willemsen87b17d12015-07-14 00:39:06 -0700140 "prebuilts/gcc/${HostPrebuiltTag}/arm/arm-linux-androideabi-${armGccVersion}")
Colin Cross3f40fa42015-01-30 17:27:36 -0800141
142 pctx.StaticVariable("armGccTriple", "arm-linux-androideabi")
143
Colin Crossc4bde762015-11-23 16:11:30 -0800144 pctx.StaticVariable("armToolchainCflags", strings.Join(armToolchainCflags, " "))
Colin Cross3f40fa42015-01-30 17:27:36 -0800145 pctx.StaticVariable("armCflags", strings.Join(armCflags, " "))
146 pctx.StaticVariable("armLdflags", strings.Join(armLdflags, " "))
147 pctx.StaticVariable("armCppflags", strings.Join(armCppflags, " "))
148 pctx.StaticVariable("armIncludeFlags", strings.Join([]string{
149 "-isystem ${LibcRoot}/arch-arm/include",
150 "-isystem ${LibcRoot}/include",
151 "-isystem ${LibcRoot}/kernel/uapi",
152 "-isystem ${LibcRoot}/kernel/uapi/asm-arm",
153 "-isystem ${LibmRoot}/include",
154 "-isystem ${LibmRoot}/include/arm",
155 }, " "))
156
157 // Extended cflags
158
Tim Kilbourn1a9bf262015-03-18 12:28:32 -0700159 // ARM vs. Thumb instruction set flags
Colin Cross3f40fa42015-01-30 17:27:36 -0800160 pctx.StaticVariable("armArmCflags", strings.Join(armArmCflags, " "))
161 pctx.StaticVariable("armThumbCflags", strings.Join(armThumbCflags, " "))
162
163 // Architecture variant cflags
164 pctx.StaticVariable("armArmv5TECflags", strings.Join(armArchVariantCflags["armv5te"], " "))
165 pctx.StaticVariable("armArmv7ACflags", strings.Join(armArchVariantCflags["armv7-a"], " "))
166 pctx.StaticVariable("armArmv7ANeonCflags", strings.Join(armArchVariantCflags["armv7-a-neon"], " "))
167
Colin Cross3f40fa42015-01-30 17:27:36 -0800168 // Cpu variant cflags
169 pctx.StaticVariable("armCortexA7Cflags", strings.Join(armCpuVariantCflags["cortex-a7"], " "))
170 pctx.StaticVariable("armCortexA8Cflags", strings.Join(armCpuVariantCflags["cortex-a8"], " "))
171 pctx.StaticVariable("armCortexA15Cflags", strings.Join(armCpuVariantCflags["cortex-a15"], " "))
172
173 // Clang cflags
Colin Crossc4bde762015-11-23 16:11:30 -0800174 pctx.StaticVariable("armToolchainClangCflags", strings.Join(clangFilterUnknownCflags(armToolchainCflags), " "))
Colin Cross3f40fa42015-01-30 17:27:36 -0800175 pctx.StaticVariable("armClangCflags", strings.Join(clangFilterUnknownCflags(armCflags), " "))
176 pctx.StaticVariable("armClangLdflags", strings.Join(clangFilterUnknownCflags(armLdflags), " "))
177 pctx.StaticVariable("armClangCppflags", strings.Join(clangFilterUnknownCflags(armCppflags), " "))
178
Dan Willemsen6d11dd82015-11-03 14:27:00 -0800179 // Clang ARM vs. Thumb instruction set cflags
180 pctx.StaticVariable("armClangArmCflags", strings.Join(clangFilterUnknownCflags(armArmCflags), " "))
181 pctx.StaticVariable("armClangThumbCflags", strings.Join(clangFilterUnknownCflags(armThumbCflags), " "))
182
Colin Cross3f40fa42015-01-30 17:27:36 -0800183 // Clang cpu variant cflags
184 pctx.StaticVariable("armClangArmv5TECflags",
185 strings.Join(armClangArchVariantCflags["armv5te"], " "))
186 pctx.StaticVariable("armClangArmv7ACflags",
187 strings.Join(armClangArchVariantCflags["armv7-a"], " "))
188 pctx.StaticVariable("armClangArmv7ANeonCflags",
189 strings.Join(armClangArchVariantCflags["armv7-a-neon"], " "))
190
191 // Clang cpu variant cflags
192 pctx.StaticVariable("armClangCortexA7Cflags",
193 strings.Join(armClangCpuVariantCflags["cortex-a7"], " "))
194 pctx.StaticVariable("armClangCortexA8Cflags",
195 strings.Join(armClangCpuVariantCflags["cortex-a8"], " "))
196 pctx.StaticVariable("armClangCortexA15Cflags",
197 strings.Join(armClangCpuVariantCflags["cortex-a15"], " "))
198 pctx.StaticVariable("armClangKraitCflags",
199 strings.Join(armClangCpuVariantCflags["krait"], " "))
200}
201
202var (
203 armArchVariantCflagsVar = map[string]string{
204 "armv5te": "${armArmv5TECflags}",
205 "armv7-a": "${armArmv7ACflags}",
206 "armv7-a-neon": "${armArmv7ANeonCflags}",
207 }
208
Colin Cross3f40fa42015-01-30 17:27:36 -0800209 armCpuVariantCflagsVar = map[string]string{
Dan Willemsene6540452015-10-20 15:21:33 -0700210 "": "",
211 "cortex-a7": "${armCortexA7Cflags}",
212 "cortex-a8": "${armCortexA8Cflags}",
213 "cortex-a15": "${armCortexA15Cflags}",
214 "cortex-a53": "${armCortexA7Cflags}",
215 "cortex-a53.a57": "${armCortexA7Cflags}",
216 "krait": "${armCortexA15Cflags}",
217 "denver": "${armCortexA15Cflags}",
Colin Cross3f40fa42015-01-30 17:27:36 -0800218 }
219
220 armClangArchVariantCflagsVar = map[string]string{
221 "armv5te": "${armClangArmv5TECflags}",
222 "armv7-a": "${armClangArmv7ACflags}",
223 "armv7-a-neon": "${armClangArmv7ANeonCflags}",
224 }
225
226 armClangCpuVariantCflagsVar = map[string]string{
Dan Willemsene6540452015-10-20 15:21:33 -0700227 "": "",
228 "cortex-a7": "${armClangCortexA7Cflags}",
229 "cortex-a8": "${armClangCortexA8Cflags}",
230 "cortex-a15": "${armClangCortexA15Cflags}",
231 "cortex-a53": "${armClangCortexA7Cflags}",
232 "cortex-a53.a57": "${armClangCortexA7Cflags}",
233 "krait": "${armClangKraitCflags}",
234 "denver": "${armClangCortexA15Cflags}",
Colin Cross3f40fa42015-01-30 17:27:36 -0800235 }
236)
237
238type toolchainArm struct {
239 toolchain32Bit
Colin Crossc4bde762015-11-23 16:11:30 -0800240 ldflags string
241 toolchainCflags, toolchainClangCflags string
Colin Cross3f40fa42015-01-30 17:27:36 -0800242}
243
Dan Albertbe961682015-03-18 23:38:50 -0700244func (t *toolchainArm) Name() string {
245 return "arm"
246}
247
Colin Cross3f40fa42015-01-30 17:27:36 -0800248func (t *toolchainArm) GccRoot() string {
249 return "${armGccRoot}"
250}
251
252func (t *toolchainArm) GccTriple() string {
253 return "${armGccTriple}"
254}
255
Dan Albertbe961682015-03-18 23:38:50 -0700256func (t *toolchainArm) GccVersion() string {
257 return "${armGccVersion}"
258}
259
Colin Crossc4bde762015-11-23 16:11:30 -0800260func (t *toolchainArm) ToolchainCflags() string {
261 return t.toolchainCflags
262}
263
Colin Cross3f40fa42015-01-30 17:27:36 -0800264func (t *toolchainArm) Cflags() string {
Colin Crossc4bde762015-11-23 16:11:30 -0800265 return "${armCflags}"
Colin Cross3f40fa42015-01-30 17:27:36 -0800266}
267
268func (t *toolchainArm) Cppflags() string {
269 return "${armCppflags}"
270}
271
272func (t *toolchainArm) Ldflags() string {
273 return t.ldflags
274}
275
276func (t *toolchainArm) IncludeFlags() string {
277 return "${armIncludeFlags}"
278}
279
Tim Kilbourn1a9bf262015-03-18 12:28:32 -0700280func (t *toolchainArm) InstructionSetFlags(isa string) (string, error) {
281 switch isa {
282 case "arm":
283 return "${armArmCflags}", nil
284 case "thumb", "":
285 return "${armThumbCflags}", nil
286 default:
287 return t.toolchainBase.InstructionSetFlags(isa)
288 }
289}
290
Colin Cross3f40fa42015-01-30 17:27:36 -0800291func (t *toolchainArm) ClangTriple() string {
292 return "${armGccTriple}"
293}
294
Colin Crossc4bde762015-11-23 16:11:30 -0800295func (t *toolchainArm) ToolchainClangCflags() string {
296 return t.toolchainClangCflags
297}
298
Colin Cross3f40fa42015-01-30 17:27:36 -0800299func (t *toolchainArm) ClangCflags() string {
Colin Crossc4bde762015-11-23 16:11:30 -0800300 return "${armClangCflags}"
Colin Cross3f40fa42015-01-30 17:27:36 -0800301}
302
303func (t *toolchainArm) ClangCppflags() string {
304 return "${armClangCppflags}"
305}
306
307func (t *toolchainArm) ClangLdflags() string {
308 return t.ldflags
309}
310
Dan Willemsen6d11dd82015-11-03 14:27:00 -0800311func (t *toolchainArm) ClangInstructionSetFlags(isa string) (string, error) {
312 switch isa {
313 case "arm":
314 return "${armClangArmCflags}", nil
315 case "thumb", "":
316 return "${armClangThumbCflags}", nil
317 default:
318 return t.toolchainBase.ClangInstructionSetFlags(isa)
319 }
320}
321
Colin Crossc5c24ad2015-11-20 15:35:00 -0800322func armToolchainFactory(arch common.Arch) Toolchain {
Colin Crossc1e814d2015-04-28 13:15:59 -0700323 var fixCortexA8 string
Colin Crossc5c24ad2015-11-20 15:35:00 -0800324 switch arch.CpuVariant {
Colin Crossc1e814d2015-04-28 13:15:59 -0700325 case "cortex-a8", "":
326 // Generic ARM might be a Cortex A8 -- better safe than sorry
327 fixCortexA8 = "-Wl,--fix-cortex-a8"
328 default:
329 fixCortexA8 = "-Wl,--no-fix-cortex-a8"
330 }
331
Colin Cross3f40fa42015-01-30 17:27:36 -0800332 return &toolchainArm{
Colin Crossc4bde762015-11-23 16:11:30 -0800333 toolchainCflags: strings.Join([]string{
334 "${armToolchainCflags}",
Colin Crossc5c24ad2015-11-20 15:35:00 -0800335 armArchVariantCflagsVar[arch.ArchVariant],
336 armCpuVariantCflagsVar[arch.CpuVariant],
Colin Cross3f40fa42015-01-30 17:27:36 -0800337 }, " "),
338 ldflags: strings.Join([]string{
339 "${armLdflags}",
Colin Crossc1e814d2015-04-28 13:15:59 -0700340 fixCortexA8,
Colin Cross3f40fa42015-01-30 17:27:36 -0800341 }, " "),
Colin Crossc4bde762015-11-23 16:11:30 -0800342 toolchainClangCflags: strings.Join([]string{
343 "${armToolchainClangCflags}",
Colin Crossc5c24ad2015-11-20 15:35:00 -0800344 armClangArchVariantCflagsVar[arch.ArchVariant],
345 armClangCpuVariantCflagsVar[arch.CpuVariant],
Colin Cross3f40fa42015-01-30 17:27:36 -0800346 }, " "),
347 }
348}
349
350func init() {
351 registerToolchainFactory(common.Device, common.Arm, armToolchainFactory)
352}