blob: 8f3485e3990fc050df6de19e965b13fea81939d9 [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
Colin Cross13af54d2015-03-16 16:12:05 -070014 "-msoft-float",
Colin Cross3f40fa42015-01-30 17:27:36 -080015 "-ffunction-sections",
16 "-fdata-sections",
17 "-funwind-tables",
18 "-fstack-protector",
19 "-Wa,--noexecstack",
20 "-Werror=format-security",
21 "-D_FORTIFY_SOURCE=2",
22 "-fno-short-enums",
23 "-no-canonical-prefixes",
24 "-fno-canonical-system-headers",
Colin Cross3f40fa42015-01-30 17:27:36 -080025
26 "-fno-builtin-sin",
27 "-fno-strict-volatile-bitfields",
28
Dan Willemsenf5a959c2015-07-13 13:28:18 -070029 "-mthumb-interwork",
30
Colin Cross3f40fa42015-01-30 17:27:36 -080031 // 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",
Colin Cross13af54d2015-03-16 16:12:05 -070051 "-Wl,--icf=safe",
Colin Cross3f40fa42015-01-30 17:27:36 -080052 "-Wl,--hash-style=gnu",
Colin Cross3f40fa42015-01-30 17:27:36 -080053 }
54
55 armArmCflags = []string{
56 "-O2",
57 "-fomit-frame-pointer",
58 "-fstrict-aliasing",
59 "-funswitch-loops",
60 }
61
62 armThumbCflags = []string{
63 "-mthumb",
64 "-Os",
65 "-fomit-frame-pointer",
66 "-fno-strict-aliasing",
67 }
68
69 armArchVariantCflags = map[string][]string{
70 "armv5te": []string{
71 "-march=armv5te",
72 "-mtune=xscale",
73 "-D__ARM_ARCH_5__",
74 "-D__ARM_ARCH_5T__",
75 "-D__ARM_ARCH_5E__",
76 "-D__ARM_ARCH_5TE__",
77 },
78 "armv7-a": []string{
79 "-march=armv7-a",
80 "-mfloat-abi=softfp",
81 "-mfpu=vfpv3-d16",
82 },
83 "armv7-a-neon": []string{
84 "-mfloat-abi=softfp",
85 "-mfpu=neon",
86 },
87 }
88
Colin Cross3f40fa42015-01-30 17:27:36 -080089 armCpuVariantCflags = map[string][]string{
90 "cortex-a7": []string{
91 "-mcpu=cortex-a7",
92 },
93 "cortex-a8": []string{
94 "-mcpu=cortex-a8",
95 },
96 "cortex-a15": []string{
97 "-mcpu=cortex-a15",
98 // Fake an ARM compiler flag as these processors support LPAE which GCC/clang
99 // don't advertise.
100 "-D__ARM_FEATURE_LPAE=1",
101 },
102 }
103
Dan Willemsenf5a959c2015-07-13 13:28:18 -0700104 armClangCpuVariantCflags = copyVariantFlags(armCpuVariantCflags)
105 armClangArchVariantCflags = copyVariantFlags(armArchVariantCflags)
Colin Cross3f40fa42015-01-30 17:27:36 -0800106)
107
Dan Willemsenf5a959c2015-07-13 13:28:18 -0700108func copyVariantFlags(m map[string][]string) map[string][]string {
109 ret := make(map[string][]string, len(m))
110 for k, v := range m {
111 l := make([]string, len(m[k]))
112 for i := range m[k] {
113 l[i] = v[i]
114 }
115 ret[k] = l
116 }
117 return ret
118}
119
Colin Cross3f40fa42015-01-30 17:27:36 -0800120func init() {
121 replaceFirst := func(slice []string, from, to string) {
122 if slice[0] != from {
123 panic(fmt.Errorf("Expected %q, found %q", from, to))
124 }
125
126 slice[0] = to
127 }
128
129 replaceFirst(armClangArchVariantCflags["armv5te"], "-march=armv5te", "-march=armv5t")
Colin Cross3f40fa42015-01-30 17:27:36 -0800130 armClangCpuVariantCflags["krait"] = []string{
131 "-mcpu=krait",
Dan Willemsen3bf6b472015-09-11 17:41:10 -0700132 "-mfpu=neon-vfpv4",
Colin Cross3f40fa42015-01-30 17:27:36 -0800133 }
134
135 pctx.StaticVariable("armGccVersion", "4.9")
136
137 pctx.StaticVariable("armGccRoot",
Dan Willemsen87b17d12015-07-14 00:39:06 -0700138 "prebuilts/gcc/${HostPrebuiltTag}/arm/arm-linux-androideabi-${armGccVersion}")
Colin Cross3f40fa42015-01-30 17:27:36 -0800139
140 pctx.StaticVariable("armGccTriple", "arm-linux-androideabi")
141
142 pctx.StaticVariable("armCflags", strings.Join(armCflags, " "))
143 pctx.StaticVariable("armLdflags", strings.Join(armLdflags, " "))
144 pctx.StaticVariable("armCppflags", strings.Join(armCppflags, " "))
145 pctx.StaticVariable("armIncludeFlags", strings.Join([]string{
146 "-isystem ${LibcRoot}/arch-arm/include",
147 "-isystem ${LibcRoot}/include",
148 "-isystem ${LibcRoot}/kernel/uapi",
149 "-isystem ${LibcRoot}/kernel/uapi/asm-arm",
150 "-isystem ${LibmRoot}/include",
151 "-isystem ${LibmRoot}/include/arm",
152 }, " "))
153
154 // Extended cflags
155
Tim Kilbourn1a9bf262015-03-18 12:28:32 -0700156 // ARM vs. Thumb instruction set flags
Colin Cross3f40fa42015-01-30 17:27:36 -0800157 pctx.StaticVariable("armArmCflags", strings.Join(armArmCflags, " "))
158 pctx.StaticVariable("armThumbCflags", strings.Join(armThumbCflags, " "))
159
160 // Architecture variant cflags
161 pctx.StaticVariable("armArmv5TECflags", strings.Join(armArchVariantCflags["armv5te"], " "))
162 pctx.StaticVariable("armArmv7ACflags", strings.Join(armArchVariantCflags["armv7-a"], " "))
163 pctx.StaticVariable("armArmv7ANeonCflags", strings.Join(armArchVariantCflags["armv7-a-neon"], " "))
164
Colin Cross3f40fa42015-01-30 17:27:36 -0800165 // 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
Dan Willemsen6d11dd82015-11-03 14:27:00 -0800175 // Clang ARM vs. Thumb instruction set cflags
176 pctx.StaticVariable("armClangArmCflags", strings.Join(clangFilterUnknownCflags(armArmCflags), " "))
177 pctx.StaticVariable("armClangThumbCflags", strings.Join(clangFilterUnknownCflags(armThumbCflags), " "))
178
Colin Cross3f40fa42015-01-30 17:27:36 -0800179 // Clang cpu variant cflags
180 pctx.StaticVariable("armClangArmv5TECflags",
181 strings.Join(armClangArchVariantCflags["armv5te"], " "))
182 pctx.StaticVariable("armClangArmv7ACflags",
183 strings.Join(armClangArchVariantCflags["armv7-a"], " "))
184 pctx.StaticVariable("armClangArmv7ANeonCflags",
185 strings.Join(armClangArchVariantCflags["armv7-a-neon"], " "))
186
187 // Clang cpu variant cflags
188 pctx.StaticVariable("armClangCortexA7Cflags",
189 strings.Join(armClangCpuVariantCflags["cortex-a7"], " "))
190 pctx.StaticVariable("armClangCortexA8Cflags",
191 strings.Join(armClangCpuVariantCflags["cortex-a8"], " "))
192 pctx.StaticVariable("armClangCortexA15Cflags",
193 strings.Join(armClangCpuVariantCflags["cortex-a15"], " "))
194 pctx.StaticVariable("armClangKraitCflags",
195 strings.Join(armClangCpuVariantCflags["krait"], " "))
196}
197
198var (
199 armArchVariantCflagsVar = map[string]string{
200 "armv5te": "${armArmv5TECflags}",
201 "armv7-a": "${armArmv7ACflags}",
202 "armv7-a-neon": "${armArmv7ANeonCflags}",
203 }
204
Colin Cross3f40fa42015-01-30 17:27:36 -0800205 armCpuVariantCflagsVar = map[string]string{
Dan Willemsene6540452015-10-20 15:21:33 -0700206 "": "",
207 "cortex-a7": "${armCortexA7Cflags}",
208 "cortex-a8": "${armCortexA8Cflags}",
209 "cortex-a15": "${armCortexA15Cflags}",
210 "cortex-a53": "${armCortexA7Cflags}",
211 "cortex-a53.a57": "${armCortexA7Cflags}",
212 "krait": "${armCortexA15Cflags}",
213 "denver": "${armCortexA15Cflags}",
Colin Cross3f40fa42015-01-30 17:27:36 -0800214 }
215
216 armClangArchVariantCflagsVar = map[string]string{
217 "armv5te": "${armClangArmv5TECflags}",
218 "armv7-a": "${armClangArmv7ACflags}",
219 "armv7-a-neon": "${armClangArmv7ANeonCflags}",
220 }
221
222 armClangCpuVariantCflagsVar = map[string]string{
Dan Willemsene6540452015-10-20 15:21:33 -0700223 "": "",
224 "cortex-a7": "${armClangCortexA7Cflags}",
225 "cortex-a8": "${armClangCortexA8Cflags}",
226 "cortex-a15": "${armClangCortexA15Cflags}",
227 "cortex-a53": "${armClangCortexA7Cflags}",
228 "cortex-a53.a57": "${armClangCortexA7Cflags}",
229 "krait": "${armClangKraitCflags}",
230 "denver": "${armClangCortexA15Cflags}",
Colin Cross3f40fa42015-01-30 17:27:36 -0800231 }
232)
233
234type toolchainArm struct {
235 toolchain32Bit
236 cflags, ldflags, clangCflags string
237}
238
Dan Albertbe961682015-03-18 23:38:50 -0700239func (t *toolchainArm) Name() string {
240 return "arm"
241}
242
Colin Cross3f40fa42015-01-30 17:27:36 -0800243func (t *toolchainArm) GccRoot() string {
244 return "${armGccRoot}"
245}
246
247func (t *toolchainArm) GccTriple() string {
248 return "${armGccTriple}"
249}
250
Dan Albertbe961682015-03-18 23:38:50 -0700251func (t *toolchainArm) GccVersion() string {
252 return "${armGccVersion}"
253}
254
Colin Cross3f40fa42015-01-30 17:27:36 -0800255func (t *toolchainArm) Cflags() string {
256 return t.cflags
257}
258
259func (t *toolchainArm) Cppflags() string {
260 return "${armCppflags}"
261}
262
263func (t *toolchainArm) Ldflags() string {
264 return t.ldflags
265}
266
267func (t *toolchainArm) IncludeFlags() string {
268 return "${armIncludeFlags}"
269}
270
Tim Kilbourn1a9bf262015-03-18 12:28:32 -0700271func (t *toolchainArm) InstructionSetFlags(isa string) (string, error) {
272 switch isa {
273 case "arm":
274 return "${armArmCflags}", nil
275 case "thumb", "":
276 return "${armThumbCflags}", nil
277 default:
278 return t.toolchainBase.InstructionSetFlags(isa)
279 }
280}
281
Colin Cross3f40fa42015-01-30 17:27:36 -0800282func (t *toolchainArm) ClangTriple() string {
283 return "${armGccTriple}"
284}
285
286func (t *toolchainArm) ClangCflags() string {
287 return t.clangCflags
288}
289
290func (t *toolchainArm) ClangCppflags() string {
291 return "${armClangCppflags}"
292}
293
294func (t *toolchainArm) ClangLdflags() string {
295 return t.ldflags
296}
297
Dan Willemsen6d11dd82015-11-03 14:27:00 -0800298func (t *toolchainArm) ClangInstructionSetFlags(isa string) (string, error) {
299 switch isa {
300 case "arm":
301 return "${armClangArmCflags}", nil
302 case "thumb", "":
303 return "${armClangThumbCflags}", nil
304 default:
305 return t.toolchainBase.ClangInstructionSetFlags(isa)
306 }
307}
308
Colin Cross97ba0732015-03-23 17:50:24 -0700309func armToolchainFactory(archVariant string, cpuVariant string) Toolchain {
Colin Crossc1e814d2015-04-28 13:15:59 -0700310 var fixCortexA8 string
311 switch cpuVariant {
312 case "cortex-a8", "":
313 // Generic ARM might be a Cortex A8 -- better safe than sorry
314 fixCortexA8 = "-Wl,--fix-cortex-a8"
315 default:
316 fixCortexA8 = "-Wl,--no-fix-cortex-a8"
317 }
318
Colin Cross3f40fa42015-01-30 17:27:36 -0800319 return &toolchainArm{
320 cflags: strings.Join([]string{
321 "${armCflags}",
Colin Cross3f40fa42015-01-30 17:27:36 -0800322 armArchVariantCflagsVar[archVariant],
323 armCpuVariantCflagsVar[cpuVariant],
324 }, " "),
325 ldflags: strings.Join([]string{
326 "${armLdflags}",
Colin Crossc1e814d2015-04-28 13:15:59 -0700327 fixCortexA8,
Colin Cross3f40fa42015-01-30 17:27:36 -0800328 }, " "),
329 clangCflags: strings.Join([]string{
330 "${armClangCflags}",
Colin Cross3f40fa42015-01-30 17:27:36 -0800331 armClangArchVariantCflagsVar[archVariant],
332 armClangCpuVariantCflagsVar[cpuVariant],
333 }, " "),
334 }
335}
336
337func init() {
338 registerToolchainFactory(common.Device, common.Arm, armToolchainFactory)
339}