blob: ae4e64646b9273293fb459c1f7828cc3c4c79bde [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 Crossb98c8b02016-07-29 13:44:28 -070015package config
Colin Cross3f40fa42015-01-30 17:27:36 -080016
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 },
Alex Naidisae4fc182016-08-20 00:14:56 +0200137 "kryo": []string{
138 "-mcpu=cortex-a15",
Jake Weinstein1783a2f2017-04-06 20:28:05 -0400139 "-mfpu=neon-fp-armv8",
Alex Naidisae4fc182016-08-20 00:14:56 +0200140 // Fake an ARM compiler flag as these processors support LPAE which GCC/clang
141 // don't advertise.
142 // TODO This is a hack and we need to add it for each processor that supports LPAE until some
143 // better solution comes around. See Bug 27340895
144 "-D__ARM_FEATURE_LPAE=1",
145 },
Colin Cross3f40fa42015-01-30 17:27:36 -0800146 }
147
Dan Willemsenf5a959c2015-07-13 13:28:18 -0700148 armClangCpuVariantCflags = copyVariantFlags(armCpuVariantCflags)
149 armClangArchVariantCflags = copyVariantFlags(armArchVariantCflags)
Colin Cross3f40fa42015-01-30 17:27:36 -0800150)
151
Dan Willemsen34fc3b12015-12-07 12:30:44 -0800152const (
153 armGccVersion = "4.9"
154)
155
Colin Cross3f40fa42015-01-30 17:27:36 -0800156func init() {
Dan Willemsenb1957a52016-06-23 23:44:54 -0700157 android.RegisterArchVariants(android.Arm,
158 "armv5te",
159 "armv7_a",
160 "armv7_a_neon",
161 "cortex_a7",
162 "cortex_a8",
163 "cortex_a9",
164 "cortex_a15",
165 "cortex_a53",
166 "cortex_a53_a57",
167 "krait",
Alex Naidisae4fc182016-08-20 00:14:56 +0200168 "kryo",
Dan Willemsenb1957a52016-06-23 23:44:54 -0700169 "denver")
170
Dan Willemsened89a7a2016-05-09 13:39:58 -0700171 replaceFirst(armClangCpuVariantCflags["krait"], "-mcpu=cortex-a15", "-mcpu=krait")
172 armClangCpuVariantCflags["krait"] = append(armClangCpuVariantCflags["krait"], "-mfpu=neon-vfpv4")
Colin Cross3f40fa42015-01-30 17:27:36 -0800173
Alex Naidisae4fc182016-08-20 00:14:56 +0200174 replaceFirst(armClangCpuVariantCflags["kryo"], "-mcpu=cortex-a15", "-mcpu=krait")
Alex Naidisae4fc182016-08-20 00:14:56 +0200175
Dan Willemsen34fc3b12015-12-07 12:30:44 -0800176 pctx.StaticVariable("armGccVersion", armGccVersion)
Colin Cross3f40fa42015-01-30 17:27:36 -0800177
Colin Crossb98c8b02016-07-29 13:44:28 -0700178 pctx.SourcePathVariable("ArmGccRoot",
Dan Willemsen87b17d12015-07-14 00:39:06 -0700179 "prebuilts/gcc/${HostPrebuiltTag}/arm/arm-linux-androideabi-${armGccVersion}")
Colin Cross3f40fa42015-01-30 17:27:36 -0800180
Colin Crossb98c8b02016-07-29 13:44:28 -0700181 pctx.StaticVariable("ArmToolchainCflags", strings.Join(armToolchainCflags, " "))
182 pctx.StaticVariable("ArmCflags", strings.Join(armCflags, " "))
183 pctx.StaticVariable("ArmLdflags", strings.Join(armLdflags, " "))
184 pctx.StaticVariable("ArmCppflags", strings.Join(armCppflags, " "))
185 pctx.StaticVariable("ArmIncludeFlags", bionicHeaders("arm", "arm"))
Colin Cross3f40fa42015-01-30 17:27:36 -0800186
187 // Extended cflags
188
Tim Kilbourn1a9bf262015-03-18 12:28:32 -0700189 // ARM vs. Thumb instruction set flags
Colin Crossb98c8b02016-07-29 13:44:28 -0700190 pctx.StaticVariable("ArmArmCflags", strings.Join(armArmCflags, " "))
191 pctx.StaticVariable("ArmThumbCflags", strings.Join(armThumbCflags, " "))
Colin Cross3f40fa42015-01-30 17:27:36 -0800192
193 // Architecture variant cflags
Colin Crossb98c8b02016-07-29 13:44:28 -0700194 pctx.StaticVariable("ArmArmv5TECflags", strings.Join(armArchVariantCflags["armv5te"], " "))
195 pctx.StaticVariable("ArmArmv7ACflags", strings.Join(armArchVariantCflags["armv7-a"], " "))
196 pctx.StaticVariable("ArmArmv7ANeonCflags", strings.Join(armArchVariantCflags["armv7-a-neon"], " "))
Colin Cross3f40fa42015-01-30 17:27:36 -0800197
Colin Cross3f40fa42015-01-30 17:27:36 -0800198 // Cpu variant cflags
Colin Crossb98c8b02016-07-29 13:44:28 -0700199 pctx.StaticVariable("ArmGenericCflags", strings.Join(armCpuVariantCflags[""], " "))
200 pctx.StaticVariable("ArmCortexA7Cflags", strings.Join(armCpuVariantCflags["cortex-a7"], " "))
201 pctx.StaticVariable("ArmCortexA8Cflags", strings.Join(armCpuVariantCflags["cortex-a8"], " "))
202 pctx.StaticVariable("ArmCortexA15Cflags", strings.Join(armCpuVariantCflags["cortex-a15"], " "))
203 pctx.StaticVariable("ArmKraitCflags", strings.Join(armCpuVariantCflags["krait"], " "))
Alex Naidisae4fc182016-08-20 00:14:56 +0200204 pctx.StaticVariable("ArmKryoCflags", strings.Join(armCpuVariantCflags["kryo"], " "))
Colin Cross3f40fa42015-01-30 17:27:36 -0800205
206 // Clang cflags
Colin Crossb98c8b02016-07-29 13:44:28 -0700207 pctx.StaticVariable("ArmToolchainClangCflags", strings.Join(ClangFilterUnknownCflags(armToolchainCflags), " "))
208 pctx.StaticVariable("ArmClangCflags", strings.Join(ClangFilterUnknownCflags(armCflags), " "))
209 pctx.StaticVariable("ArmClangLdflags", strings.Join(ClangFilterUnknownCflags(armLdflags), " "))
210 pctx.StaticVariable("ArmClangCppflags", strings.Join(ClangFilterUnknownCflags(armCppflags), " "))
Colin Cross3f40fa42015-01-30 17:27:36 -0800211
Dan Willemsen6d11dd82015-11-03 14:27:00 -0800212 // Clang ARM vs. Thumb instruction set cflags
Colin Crossb98c8b02016-07-29 13:44:28 -0700213 pctx.StaticVariable("ArmClangArmCflags", strings.Join(ClangFilterUnknownCflags(armArmCflags), " "))
214 pctx.StaticVariable("ArmClangThumbCflags", strings.Join(ClangFilterUnknownCflags(armThumbCflags), " "))
Dan Willemsen6d11dd82015-11-03 14:27:00 -0800215
Dan Willemsen110a89d2016-01-14 15:17:19 -0800216 // Clang arch variant cflags
Colin Crossb98c8b02016-07-29 13:44:28 -0700217 pctx.StaticVariable("ArmClangArmv5TECflags",
Colin Cross3f40fa42015-01-30 17:27:36 -0800218 strings.Join(armClangArchVariantCflags["armv5te"], " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700219 pctx.StaticVariable("ArmClangArmv7ACflags",
Colin Cross3f40fa42015-01-30 17:27:36 -0800220 strings.Join(armClangArchVariantCflags["armv7-a"], " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700221 pctx.StaticVariable("ArmClangArmv7ANeonCflags",
Colin Cross3f40fa42015-01-30 17:27:36 -0800222 strings.Join(armClangArchVariantCflags["armv7-a-neon"], " "))
223
224 // Clang cpu variant cflags
Colin Crossb98c8b02016-07-29 13:44:28 -0700225 pctx.StaticVariable("ArmClangGenericCflags",
Dan Willemsen110a89d2016-01-14 15:17:19 -0800226 strings.Join(armClangCpuVariantCflags[""], " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700227 pctx.StaticVariable("ArmClangCortexA7Cflags",
Colin Cross3f40fa42015-01-30 17:27:36 -0800228 strings.Join(armClangCpuVariantCflags["cortex-a7"], " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700229 pctx.StaticVariable("ArmClangCortexA8Cflags",
Colin Cross3f40fa42015-01-30 17:27:36 -0800230 strings.Join(armClangCpuVariantCflags["cortex-a8"], " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700231 pctx.StaticVariable("ArmClangCortexA15Cflags",
Colin Cross3f40fa42015-01-30 17:27:36 -0800232 strings.Join(armClangCpuVariantCflags["cortex-a15"], " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700233 pctx.StaticVariable("ArmClangKraitCflags",
Colin Cross3f40fa42015-01-30 17:27:36 -0800234 strings.Join(armClangCpuVariantCflags["krait"], " "))
Alex Naidisae4fc182016-08-20 00:14:56 +0200235 pctx.StaticVariable("ArmClangKryoCflags",
236 strings.Join(armClangCpuVariantCflags["kryo"], " "))
Colin Cross3f40fa42015-01-30 17:27:36 -0800237}
238
239var (
240 armArchVariantCflagsVar = map[string]string{
Colin Crossb98c8b02016-07-29 13:44:28 -0700241 "armv5te": "${config.ArmArmv5TECflags}",
242 "armv7-a": "${config.ArmArmv7ACflags}",
243 "armv7-a-neon": "${config.ArmArmv7ANeonCflags}",
Colin Cross3f40fa42015-01-30 17:27:36 -0800244 }
245
Colin Cross3f40fa42015-01-30 17:27:36 -0800246 armCpuVariantCflagsVar = map[string]string{
Colin Crossb98c8b02016-07-29 13:44:28 -0700247 "": "${config.ArmGenericCflags}",
248 "cortex-a7": "${config.ArmCortexA7Cflags}",
249 "cortex-a8": "${config.ArmCortexA8Cflags}",
250 "cortex-a15": "${config.ArmCortexA15Cflags}",
251 "cortex-a53": "${config.ArmCortexA7Cflags}",
252 "cortex-a53.a57": "${config.ArmCortexA7Cflags}",
253 "krait": "${config.ArmKraitCflags}",
Alex Naidisae4fc182016-08-20 00:14:56 +0200254 "kryo": "${config.ArmKryoCflags}",
Colin Crossb98c8b02016-07-29 13:44:28 -0700255 "denver": "${config.ArmCortexA15Cflags}",
Colin Cross3f40fa42015-01-30 17:27:36 -0800256 }
257
258 armClangArchVariantCflagsVar = map[string]string{
Colin Crossb98c8b02016-07-29 13:44:28 -0700259 "armv5te": "${config.ArmClangArmv5TECflags}",
260 "armv7-a": "${config.ArmClangArmv7ACflags}",
261 "armv7-a-neon": "${config.ArmClangArmv7ANeonCflags}",
Colin Cross3f40fa42015-01-30 17:27:36 -0800262 }
263
264 armClangCpuVariantCflagsVar = map[string]string{
Colin Crossb98c8b02016-07-29 13:44:28 -0700265 "": "${config.ArmClangGenericCflags}",
266 "cortex-a7": "${config.ArmClangCortexA7Cflags}",
267 "cortex-a8": "${config.ArmClangCortexA8Cflags}",
268 "cortex-a15": "${config.ArmClangCortexA15Cflags}",
269 "cortex-a53": "${config.ArmClangCortexA7Cflags}",
270 "cortex-a53.a57": "${config.ArmClangCortexA7Cflags}",
271 "krait": "${config.ArmClangKraitCflags}",
Alex Naidisae4fc182016-08-20 00:14:56 +0200272 "kryo": "${config.ArmClangKryoCflags}",
Colin Crossb98c8b02016-07-29 13:44:28 -0700273 "denver": "${config.ArmClangCortexA15Cflags}",
Colin Cross3f40fa42015-01-30 17:27:36 -0800274 }
275)
276
277type toolchainArm struct {
278 toolchain32Bit
Colin Crossc4bde762015-11-23 16:11:30 -0800279 ldflags string
280 toolchainCflags, toolchainClangCflags string
Colin Cross3f40fa42015-01-30 17:27:36 -0800281}
282
Dan Albertbe961682015-03-18 23:38:50 -0700283func (t *toolchainArm) Name() string {
284 return "arm"
285}
286
Colin Cross3f40fa42015-01-30 17:27:36 -0800287func (t *toolchainArm) GccRoot() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700288 return "${config.ArmGccRoot}"
Colin Cross3f40fa42015-01-30 17:27:36 -0800289}
290
291func (t *toolchainArm) GccTriple() string {
Dan Albert84f431f2016-07-20 14:44:26 -0700292 return "arm-linux-androideabi"
Colin Cross3f40fa42015-01-30 17:27:36 -0800293}
294
Dan Albertbe961682015-03-18 23:38:50 -0700295func (t *toolchainArm) GccVersion() string {
Dan Willemsen34fc3b12015-12-07 12:30:44 -0800296 return armGccVersion
Dan Albertbe961682015-03-18 23:38:50 -0700297}
298
Colin Crossc4bde762015-11-23 16:11:30 -0800299func (t *toolchainArm) ToolchainCflags() string {
300 return t.toolchainCflags
301}
302
Colin Cross3f40fa42015-01-30 17:27:36 -0800303func (t *toolchainArm) Cflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700304 return "${config.ArmCflags}"
Colin Cross3f40fa42015-01-30 17:27:36 -0800305}
306
307func (t *toolchainArm) Cppflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700308 return "${config.ArmCppflags}"
Colin Cross3f40fa42015-01-30 17:27:36 -0800309}
310
311func (t *toolchainArm) Ldflags() string {
312 return t.ldflags
313}
314
315func (t *toolchainArm) IncludeFlags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700316 return "${config.ArmIncludeFlags}"
Colin Cross3f40fa42015-01-30 17:27:36 -0800317}
318
Tim Kilbourn1a9bf262015-03-18 12:28:32 -0700319func (t *toolchainArm) InstructionSetFlags(isa string) (string, error) {
320 switch isa {
321 case "arm":
Colin Crossb98c8b02016-07-29 13:44:28 -0700322 return "${config.ArmArmCflags}", nil
Tim Kilbourn1a9bf262015-03-18 12:28:32 -0700323 case "thumb", "":
Colin Crossb98c8b02016-07-29 13:44:28 -0700324 return "${config.ArmThumbCflags}", nil
Tim Kilbourn1a9bf262015-03-18 12:28:32 -0700325 default:
326 return t.toolchainBase.InstructionSetFlags(isa)
327 }
328}
329
Colin Cross3f40fa42015-01-30 17:27:36 -0800330func (t *toolchainArm) ClangTriple() string {
Dan Albert84f431f2016-07-20 14:44:26 -0700331 return t.GccTriple()
Colin Cross3f40fa42015-01-30 17:27:36 -0800332}
333
Colin Crossc4bde762015-11-23 16:11:30 -0800334func (t *toolchainArm) ToolchainClangCflags() string {
335 return t.toolchainClangCflags
336}
337
Colin Cross3f40fa42015-01-30 17:27:36 -0800338func (t *toolchainArm) ClangCflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700339 return "${config.ArmClangCflags}"
Colin Cross3f40fa42015-01-30 17:27:36 -0800340}
341
342func (t *toolchainArm) ClangCppflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700343 return "${config.ArmClangCppflags}"
Colin Cross3f40fa42015-01-30 17:27:36 -0800344}
345
346func (t *toolchainArm) ClangLdflags() string {
347 return t.ldflags
348}
349
Dan Willemsen6d11dd82015-11-03 14:27:00 -0800350func (t *toolchainArm) ClangInstructionSetFlags(isa string) (string, error) {
351 switch isa {
352 case "arm":
Colin Crossb98c8b02016-07-29 13:44:28 -0700353 return "${config.ArmClangArmCflags}", nil
Dan Willemsen6d11dd82015-11-03 14:27:00 -0800354 case "thumb", "":
Colin Crossb98c8b02016-07-29 13:44:28 -0700355 return "${config.ArmClangThumbCflags}", nil
Dan Willemsen6d11dd82015-11-03 14:27:00 -0800356 default:
357 return t.toolchainBase.ClangInstructionSetFlags(isa)
358 }
359}
360
Evgenii Stepanovaf36db12016-08-15 14:18:24 -0700361func (toolchainArm) SanitizerRuntimeLibraryArch() string {
362 return "arm"
Colin Cross16b23492016-01-06 14:41:07 -0800363}
364
Colin Cross635c3b02016-05-18 15:37:25 -0700365func armToolchainFactory(arch android.Arch) Toolchain {
Colin Crossc1e814d2015-04-28 13:15:59 -0700366 var fixCortexA8 string
Dan Willemsen110a89d2016-01-14 15:17:19 -0800367 toolchainCflags := make([]string, 2, 3)
368 toolchainClangCflags := make([]string, 2, 3)
369
Colin Crossb98c8b02016-07-29 13:44:28 -0700370 toolchainCflags[0] = "${config.ArmToolchainCflags}"
Dan Willemsen110a89d2016-01-14 15:17:19 -0800371 toolchainCflags[1] = armArchVariantCflagsVar[arch.ArchVariant]
Colin Crossb98c8b02016-07-29 13:44:28 -0700372 toolchainClangCflags[0] = "${config.ArmToolchainClangCflags}"
Dan Willemsen110a89d2016-01-14 15:17:19 -0800373 toolchainClangCflags[1] = armClangArchVariantCflagsVar[arch.ArchVariant]
374
375 switch arch.ArchVariant {
376 case "armv7-a-neon":
377 switch arch.CpuVariant {
378 case "cortex-a8", "":
379 // Generic ARM might be a Cortex A8 -- better safe than sorry
380 fixCortexA8 = "-Wl,--fix-cortex-a8"
381 default:
382 fixCortexA8 = "-Wl,--no-fix-cortex-a8"
383 }
384
385 toolchainCflags = append(toolchainCflags,
386 variantOrDefault(armCpuVariantCflagsVar, arch.CpuVariant))
387 toolchainClangCflags = append(toolchainClangCflags,
388 variantOrDefault(armClangCpuVariantCflagsVar, arch.CpuVariant))
389 case "armv7-a":
Colin Crossc1e814d2015-04-28 13:15:59 -0700390 fixCortexA8 = "-Wl,--fix-cortex-a8"
Dan Willemsen110a89d2016-01-14 15:17:19 -0800391 case "armv5te":
392 // Nothing extra for armv5te
Colin Crossc1e814d2015-04-28 13:15:59 -0700393 default:
Dan Willemsen110a89d2016-01-14 15:17:19 -0800394 panic(fmt.Sprintf("Unknown ARM architecture version: %q", arch.ArchVariant))
Colin Crossc1e814d2015-04-28 13:15:59 -0700395 }
396
Colin Cross3f40fa42015-01-30 17:27:36 -0800397 return &toolchainArm{
Dan Willemsen110a89d2016-01-14 15:17:19 -0800398 toolchainCflags: strings.Join(toolchainCflags, " "),
Colin Cross3f40fa42015-01-30 17:27:36 -0800399 ldflags: strings.Join([]string{
Colin Crossb98c8b02016-07-29 13:44:28 -0700400 "${config.ArmLdflags}",
Colin Crossc1e814d2015-04-28 13:15:59 -0700401 fixCortexA8,
Colin Cross3f40fa42015-01-30 17:27:36 -0800402 }, " "),
Dan Willemsen110a89d2016-01-14 15:17:19 -0800403 toolchainClangCflags: strings.Join(toolchainClangCflags, " "),
Colin Cross3f40fa42015-01-30 17:27:36 -0800404 }
405}
406
407func init() {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700408 registerToolchainFactory(android.Android, android.Arm, armToolchainFactory)
Colin Cross3f40fa42015-01-30 17:27:36 -0800409}