blob: e33bd01bcb9932e3fbc112279a55e9c15de1b4ba [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",
25 "-include ${SrcDir}/build/core/combo/include/arch/linux-arm/AndroidConfig.h",
26
27 "-fno-builtin-sin",
28 "-fno-strict-volatile-bitfields",
29
30 // TARGET_RELEASE_CFLAGS
31 "-DNDEBUG",
32 "-g",
33 "-Wstrict-aliasing=2",
34 "-fgcse-after-reload",
35 "-frerun-cse-after-loop",
36 "-frename-registers",
37 }
38
39 armCppflags = []string{
40 "-fvisibility-inlines-hidden",
41 }
42
43 armLdflags = []string{
44 "-Wl,-z,noexecstack",
45 "-Wl,-z,relro",
46 "-Wl,-z,now",
47 "-Wl,--build-id=md5",
48 "-Wl,--warn-shared-textrel",
49 "-Wl,--fatal-warnings",
Colin Cross13af54d2015-03-16 16:12:05 -070050 "-Wl,--icf=safe",
Colin Cross3f40fa42015-01-30 17:27:36 -080051 "-Wl,--hash-style=gnu",
52
53 // Disable transitive dependency library symbol resolving.
54 "-Wl,--allow-shlib-undefined",
55 }
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
91 armArchVariantLdflags = map[string][]string{
92 "armv7-a": []string{
93 "-Wl,--fix-cortex-a8",
94 },
95 }
96
97 armCpuVariantCflags = map[string][]string{
98 "cortex-a7": []string{
99 "-mcpu=cortex-a7",
100 },
101 "cortex-a8": []string{
102 "-mcpu=cortex-a8",
103 },
104 "cortex-a15": []string{
105 "-mcpu=cortex-a15",
106 // Fake an ARM compiler flag as these processors support LPAE which GCC/clang
107 // don't advertise.
108 "-D__ARM_FEATURE_LPAE=1",
109 },
110 }
111
112 armClangCpuVariantCflags = armCpuVariantCflags
113 armClangArchVariantCflags = armArchVariantCflags
114)
115
116func init() {
117 replaceFirst := func(slice []string, from, to string) {
118 if slice[0] != from {
119 panic(fmt.Errorf("Expected %q, found %q", from, to))
120 }
121
122 slice[0] = to
123 }
124
125 replaceFirst(armClangArchVariantCflags["armv5te"], "-march=armv5te", "-march=armv5t")
126 replaceFirst(armClangCpuVariantCflags["cortex-a15"], "-mcpu=cortex-a15", "-march=armv7-a")
127 armClangCpuVariantCflags["krait"] = []string{
128 "-mcpu=krait",
129 }
130
131 pctx.StaticVariable("armGccVersion", "4.9")
132
133 pctx.StaticVariable("armGccRoot",
134 "${SrcDir}/prebuilts/gcc/${HostPrebuiltTag}/arm/arm-linux-androideabi-${armGccVersion}")
135
136 pctx.StaticVariable("armGccTriple", "arm-linux-androideabi")
137
138 pctx.StaticVariable("armCflags", strings.Join(armCflags, " "))
139 pctx.StaticVariable("armLdflags", strings.Join(armLdflags, " "))
140 pctx.StaticVariable("armCppflags", strings.Join(armCppflags, " "))
141 pctx.StaticVariable("armIncludeFlags", strings.Join([]string{
142 "-isystem ${LibcRoot}/arch-arm/include",
143 "-isystem ${LibcRoot}/include",
144 "-isystem ${LibcRoot}/kernel/uapi",
145 "-isystem ${LibcRoot}/kernel/uapi/asm-arm",
146 "-isystem ${LibmRoot}/include",
147 "-isystem ${LibmRoot}/include/arm",
148 }, " "))
149
150 // Extended cflags
151
152 // ARM mode vs. Thumb mode
153 pctx.StaticVariable("armArmCflags", strings.Join(armArmCflags, " "))
154 pctx.StaticVariable("armThumbCflags", strings.Join(armThumbCflags, " "))
155
156 // Architecture variant cflags
157 pctx.StaticVariable("armArmv5TECflags", strings.Join(armArchVariantCflags["armv5te"], " "))
158 pctx.StaticVariable("armArmv7ACflags", strings.Join(armArchVariantCflags["armv7-a"], " "))
159 pctx.StaticVariable("armArmv7ANeonCflags", strings.Join(armArchVariantCflags["armv7-a-neon"], " "))
160
161 // Architecture variant ldflags
162 pctx.StaticVariable("armArmv7ALdflags", strings.Join(armArchVariantLdflags["armv7-a"], " "))
163
164 // Cpu variant cflags
165 pctx.StaticVariable("armCortexA7Cflags", strings.Join(armCpuVariantCflags["cortex-a7"], " "))
166 pctx.StaticVariable("armCortexA8Cflags", strings.Join(armCpuVariantCflags["cortex-a8"], " "))
167 pctx.StaticVariable("armCortexA15Cflags", strings.Join(armCpuVariantCflags["cortex-a15"], " "))
168
169 // Clang cflags
170 pctx.StaticVariable("armClangCflags", strings.Join(clangFilterUnknownCflags(armCflags), " "))
171 pctx.StaticVariable("armClangLdflags", strings.Join(clangFilterUnknownCflags(armLdflags), " "))
172 pctx.StaticVariable("armClangCppflags", strings.Join(clangFilterUnknownCflags(armCppflags), " "))
173
174 // Clang cpu variant cflags
175 pctx.StaticVariable("armClangArmv5TECflags",
176 strings.Join(armClangArchVariantCflags["armv5te"], " "))
177 pctx.StaticVariable("armClangArmv7ACflags",
178 strings.Join(armClangArchVariantCflags["armv7-a"], " "))
179 pctx.StaticVariable("armClangArmv7ANeonCflags",
180 strings.Join(armClangArchVariantCflags["armv7-a-neon"], " "))
181
182 // Clang cpu variant cflags
183 pctx.StaticVariable("armClangCortexA7Cflags",
184 strings.Join(armClangCpuVariantCflags["cortex-a7"], " "))
185 pctx.StaticVariable("armClangCortexA8Cflags",
186 strings.Join(armClangCpuVariantCflags["cortex-a8"], " "))
187 pctx.StaticVariable("armClangCortexA15Cflags",
188 strings.Join(armClangCpuVariantCflags["cortex-a15"], " "))
189 pctx.StaticVariable("armClangKraitCflags",
190 strings.Join(armClangCpuVariantCflags["krait"], " "))
191}
192
193var (
194 armArchVariantCflagsVar = map[string]string{
195 "armv5te": "${armArmv5TECflags}",
196 "armv7-a": "${armArmv7ACflags}",
197 "armv7-a-neon": "${armArmv7ANeonCflags}",
198 }
199
200 armArchVariantLdflagsVar = map[string]string{
201 "armv7-a": "${armArmv7ALdflags}",
202 "armv7-a-neon": "${armArmv7ALdflags}",
203 }
204
205 armCpuVariantCflagsVar = map[string]string{
206 "": "",
207 "cortex-a7": "${armCortexA7Cflags}",
208 "cortex-a8": "${armCortexA8Cflags}",
209 "cortex-a15": "${armCortexA15Cflags}",
210 "krait": "${armCortexA15Cflags}",
211 "denver": "${armCortexA15Cflags}",
212 }
213
214 armClangArchVariantCflagsVar = map[string]string{
215 "armv5te": "${armClangArmv5TECflags}",
216 "armv7-a": "${armClangArmv7ACflags}",
217 "armv7-a-neon": "${armClangArmv7ANeonCflags}",
218 }
219
220 armClangCpuVariantCflagsVar = map[string]string{
221 "": "",
222 "cortex-a7": "${armClangCortexA7Cflags}",
223 "cortex-a8": "${armClangCortexA8Cflags}",
224 "cortex-a15": "${armClangCortexA15Cflags}",
225 "krait": "${armClangKraitCflags}",
226 "denver": "${armClangCortexA15Cflags}",
227 }
228)
229
230type toolchainArm struct {
231 toolchain32Bit
232 cflags, ldflags, clangCflags string
233}
234
235func (t *toolchainArm) GccRoot() string {
236 return "${armGccRoot}"
237}
238
239func (t *toolchainArm) GccTriple() string {
240 return "${armGccTriple}"
241}
242
243func (t *toolchainArm) Cflags() string {
244 return t.cflags
245}
246
247func (t *toolchainArm) Cppflags() string {
248 return "${armCppflags}"
249}
250
251func (t *toolchainArm) Ldflags() string {
252 return t.ldflags
253}
254
255func (t *toolchainArm) IncludeFlags() string {
256 return "${armIncludeFlags}"
257}
258
259func (t *toolchainArm) ClangTriple() string {
260 return "${armGccTriple}"
261}
262
263func (t *toolchainArm) ClangCflags() string {
264 return t.clangCflags
265}
266
267func (t *toolchainArm) ClangCppflags() string {
268 return "${armClangCppflags}"
269}
270
271func (t *toolchainArm) ClangLdflags() string {
272 return t.ldflags
273}
274
275func armToolchainFactory(archVariant string, cpuVariant string) toolchain {
276 return &toolchainArm{
277 cflags: strings.Join([]string{
278 "${armCflags}",
279 "${armIncludeFlags}",
280 "${armThumbCflags}",
281 armArchVariantCflagsVar[archVariant],
282 armCpuVariantCflagsVar[cpuVariant],
283 }, " "),
284 ldflags: strings.Join([]string{
285 "${armLdflags}",
286 armArchVariantLdflagsVar[archVariant],
287 }, " "),
288 clangCflags: strings.Join([]string{
289 "${armClangCflags}",
290 "${armIncludeFlags}",
291 "${armThumbCflags}",
292 armClangArchVariantCflagsVar[archVariant],
293 armClangCpuVariantCflagsVar[cpuVariant],
294 }, " "),
295 }
296}
297
298func init() {
299 registerToolchainFactory(common.Device, common.Arm, armToolchainFactory)
300}