blob: a402f8f7ad966108085b536331d995f87f5bb31c [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 Crossbc2c7c22017-11-18 00:10:01 +000030 armCflags = []string{
31 "-fomit-frame-pointer",
32 }
Colin Cross3f40fa42015-01-30 17:27:36 -080033
Colin Cross26f14502017-11-06 13:59:48 -080034 armCppflags = []string{}
Colin Cross3f40fa42015-01-30 17:27:36 -080035
36 armLdflags = []string{
Colin Cross3f40fa42015-01-30 17:27:36 -080037 "-Wl,--hash-style=gnu",
Stephen Craneb3c21542017-06-26 19:22:02 -070038 "-Wl,-m,armelf",
Colin Cross3f40fa42015-01-30 17:27:36 -080039 }
40
Chih-Hung Hsieh02b4da52018-04-03 11:33:34 -070041 armLldflags = ClangFilterUnknownLldflags(armLdflags)
42
Colin Cross3f40fa42015-01-30 17:27:36 -080043 armArmCflags = []string{
Colin Cross3f40fa42015-01-30 17:27:36 -080044 "-fstrict-aliasing",
Colin Cross3f40fa42015-01-30 17:27:36 -080045 }
46
47 armThumbCflags = []string{
48 "-mthumb",
49 "-Os",
Colin Cross3f40fa42015-01-30 17:27:36 -080050 }
51
Dan Willemsenbd4abf52018-10-07 21:06:36 -070052 armClangArchVariantCflags = map[string][]string{
Dan Albert8818f492019-02-19 13:53:01 -080053 "armv7-a": []string{
54 "-march=armv7-a",
55 "-mfloat-abi=softfp",
56 "-mfpu=vfpv3-d16",
57 },
Colin Cross3f40fa42015-01-30 17:27:36 -080058 "armv7-a-neon": []string{
Isaac Chen2bce8ed2017-10-05 18:28:57 +080059 "-march=armv7-a",
Colin Cross3f40fa42015-01-30 17:27:36 -080060 "-mfloat-abi=softfp",
61 "-mfpu=neon",
62 },
Isaac Chena2a58242017-08-23 10:57:17 +000063 "armv8-a": []string{
64 "-march=armv8-a",
65 "-mfloat-abi=softfp",
66 "-mfpu=neon-fp-armv8",
67 },
mtk15504270ba752018-10-31 15:26:32 +080068 "armv8-2a": []string{
69 "-march=armv8.2-a",
70 "-mfloat-abi=softfp",
71 "-mfpu=neon-fp-armv8",
72 },
Colin Cross3f40fa42015-01-30 17:27:36 -080073 }
74
Dan Willemsenbd4abf52018-10-07 21:06:36 -070075 armClangCpuVariantCflags = map[string][]string{
Colin Cross3f40fa42015-01-30 17:27:36 -080076 "cortex-a7": []string{
77 "-mcpu=cortex-a7",
Jake Weinstein5cfd7092017-04-06 22:25:34 -040078 "-mfpu=neon-vfpv4",
Dan Willemsen8e1e3fb2016-03-29 15:47:08 -070079 // Fake an ARM compiler flag as these processors support LPAE which GCC/clang
80 // don't advertise.
81 // TODO This is a hack and we need to add it for each processor that supports LPAE until some
82 // better solution comes around. See Bug 27340895
83 "-D__ARM_FEATURE_LPAE=1",
Colin Cross3f40fa42015-01-30 17:27:36 -080084 },
85 "cortex-a8": []string{
86 "-mcpu=cortex-a8",
87 },
88 "cortex-a15": []string{
89 "-mcpu=cortex-a15",
Jake Weinstein59166572017-04-06 20:47:23 -040090 "-mfpu=neon-vfpv4",
Colin Cross3f40fa42015-01-30 17:27:36 -080091 // Fake an ARM compiler flag as these processors support LPAE which GCC/clang
92 // don't advertise.
Dan Willemsen8e1e3fb2016-03-29 15:47:08 -070093 // TODO This is a hack and we need to add it for each processor that supports LPAE until some
94 // better solution comes around. See Bug 27340895
Colin Cross3f40fa42015-01-30 17:27:36 -080095 "-D__ARM_FEATURE_LPAE=1",
96 },
Christopher Ferris6df46f52017-05-08 12:08:40 -070097 "cortex-a53": []string{
98 "-mcpu=cortex-a53",
99 "-mfpu=neon-fp-armv8",
100 // Fake an ARM compiler flag as these processors support LPAE which GCC/clang
101 // don't advertise.
102 // TODO This is a hack and we need to add it for each processor that supports LPAE until some
103 // better solution comes around. See Bug 27340895
104 "-D__ARM_FEATURE_LPAE=1",
105 },
Christopher Ferrisba14a8f2018-04-23 18:15:25 -0700106 "cortex-a55": []string{
Yi Kong9c633632018-06-15 15:46:11 -0700107 "-mcpu=cortex-a55",
Christopher Ferrisba14a8f2018-04-23 18:15:25 -0700108 "-mfpu=neon-fp-armv8",
109 // Fake an ARM compiler flag as these processors support LPAE which GCC/clang
110 // don't advertise.
111 // TODO This is a hack and we need to add it for each processor that supports LPAE until some
112 // better solution comes around. See Bug 27340895
113 "-D__ARM_FEATURE_LPAE=1",
114 },
115 "cortex-a75": []string{
Yi Kong9c633632018-06-15 15:46:11 -0700116 "-mcpu=cortex-a55",
Christopher Ferrisba14a8f2018-04-23 18:15:25 -0700117 "-mfpu=neon-fp-armv8",
118 // Fake an ARM compiler flag as these processors support LPAE which GCC/clang
119 // don't advertise.
120 // TODO This is a hack and we need to add it for each processor that supports LPAE until some
121 // better solution comes around. See Bug 27340895
122 "-D__ARM_FEATURE_LPAE=1",
123 },
Haibo Huanga31e2bd2018-10-09 14:27:28 -0700124 "cortex-a76": []string{
125 "-mcpu=cortex-a55",
126 "-mfpu=neon-fp-armv8",
127 // Fake an ARM compiler flag as these processors support LPAE which GCC/clang
128 // don't advertise.
129 // TODO This is a hack and we need to add it for each processor that supports LPAE until some
130 // better solution comes around. See Bug 27340895
131 "-D__ARM_FEATURE_LPAE=1",
132 },
Dan Willemsened89a7a2016-05-09 13:39:58 -0700133 "krait": []string{
Dan Willemsenbd4abf52018-10-07 21:06:36 -0700134 "-mcpu=krait",
Jake Weinsteinfff256f2017-04-06 20:38:26 -0400135 "-mfpu=neon-vfpv4",
Dan Willemsened89a7a2016-05-09 13:39:58 -0700136 // Fake an ARM compiler flag as these processors support LPAE which GCC/clang
137 // don't advertise.
138 // TODO This is a hack and we need to add it for each processor that supports LPAE until some
139 // better solution comes around. See Bug 27340895
140 "-D__ARM_FEATURE_LPAE=1",
141 },
Alex Naidisae4fc182016-08-20 00:14:56 +0200142 "kryo": []string{
Pirama Arumuga Nainarc17b2752017-11-20 22:29:58 -0800143 // Use cortex-a53 because the GNU assembler doesn't recognize -mcpu=kryo
144 // even though clang does.
145 "-mcpu=cortex-a53",
Jake Weinstein1783a2f2017-04-06 20:28:05 -0400146 "-mfpu=neon-fp-armv8",
Alex Naidisae4fc182016-08-20 00:14:56 +0200147 // Fake an ARM compiler flag as these processors support LPAE which GCC/clang
148 // don't advertise.
149 // TODO This is a hack and we need to add it for each processor that supports LPAE until some
150 // better solution comes around. See Bug 27340895
151 "-D__ARM_FEATURE_LPAE=1",
152 },
Artem Serovd3072b02018-11-15 15:21:51 +0000153 "kryo385": []string{
154 // Use cortex-a53 because kryo385 is not supported in GCC/clang.
155 "-mcpu=cortex-a53",
156 // Fake an ARM compiler flag as these processors support LPAE which GCC/clang
157 // don't advertise.
158 // TODO This is a hack and we need to add it for each processor that supports LPAE until some
159 // better solution comes around. See Bug 27340895
160 "-D__ARM_FEATURE_LPAE=1",
161 },
Colin Cross3f40fa42015-01-30 17:27:36 -0800162 }
Colin Cross3f40fa42015-01-30 17:27:36 -0800163)
164
Dan Willemsen34fc3b12015-12-07 12:30:44 -0800165const (
166 armGccVersion = "4.9"
167)
168
Colin Cross3f40fa42015-01-30 17:27:36 -0800169func init() {
Dan Willemsen34fc3b12015-12-07 12:30:44 -0800170 pctx.StaticVariable("armGccVersion", armGccVersion)
Colin Cross3f40fa42015-01-30 17:27:36 -0800171
Colin Crossb98c8b02016-07-29 13:44:28 -0700172 pctx.SourcePathVariable("ArmGccRoot",
Dan Willemsen87b17d12015-07-14 00:39:06 -0700173 "prebuilts/gcc/${HostPrebuiltTag}/arm/arm-linux-androideabi-${armGccVersion}")
Colin Cross3f40fa42015-01-30 17:27:36 -0800174
Colin Crossb98c8b02016-07-29 13:44:28 -0700175 pctx.StaticVariable("ArmLdflags", strings.Join(armLdflags, " "))
Chih-Hung Hsieh02b4da52018-04-03 11:33:34 -0700176 pctx.StaticVariable("ArmLldflags", strings.Join(armLldflags, " "))
Colin Cross3f40fa42015-01-30 17:27:36 -0800177
Colin Cross3f40fa42015-01-30 17:27:36 -0800178 // Clang cflags
Colin Crossb98c8b02016-07-29 13:44:28 -0700179 pctx.StaticVariable("ArmToolchainClangCflags", strings.Join(ClangFilterUnknownCflags(armToolchainCflags), " "))
180 pctx.StaticVariable("ArmClangCflags", strings.Join(ClangFilterUnknownCflags(armCflags), " "))
181 pctx.StaticVariable("ArmClangLdflags", strings.Join(ClangFilterUnknownCflags(armLdflags), " "))
Chih-Hung Hsieh02b4da52018-04-03 11:33:34 -0700182 pctx.StaticVariable("ArmClangLldflags", strings.Join(ClangFilterUnknownCflags(armLldflags), " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700183 pctx.StaticVariable("ArmClangCppflags", strings.Join(ClangFilterUnknownCflags(armCppflags), " "))
Colin Cross3f40fa42015-01-30 17:27:36 -0800184
Dan Willemsen6d11dd82015-11-03 14:27:00 -0800185 // Clang ARM vs. Thumb instruction set cflags
Colin Crossb98c8b02016-07-29 13:44:28 -0700186 pctx.StaticVariable("ArmClangArmCflags", strings.Join(ClangFilterUnknownCflags(armArmCflags), " "))
187 pctx.StaticVariable("ArmClangThumbCflags", strings.Join(ClangFilterUnknownCflags(armThumbCflags), " "))
Dan Willemsen6d11dd82015-11-03 14:27:00 -0800188
Dan Willemsen110a89d2016-01-14 15:17:19 -0800189 // Clang arch variant cflags
Dan Albert8818f492019-02-19 13:53:01 -0800190 pctx.StaticVariable("ArmClangArmv7ACflags",
191 strings.Join(armClangArchVariantCflags["armv7-a"], " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700192 pctx.StaticVariable("ArmClangArmv7ANeonCflags",
Colin Cross3f40fa42015-01-30 17:27:36 -0800193 strings.Join(armClangArchVariantCflags["armv7-a-neon"], " "))
Isaac Chena2a58242017-08-23 10:57:17 +0000194 pctx.StaticVariable("ArmClangArmv8ACflags",
195 strings.Join(armClangArchVariantCflags["armv8-a"], " "))
mtk15504270ba752018-10-31 15:26:32 +0800196 pctx.StaticVariable("ArmClangArmv82ACflags",
197 strings.Join(armClangArchVariantCflags["armv8-2a"], " "))
Colin Cross3f40fa42015-01-30 17:27:36 -0800198
199 // Clang cpu variant cflags
Colin Crossb98c8b02016-07-29 13:44:28 -0700200 pctx.StaticVariable("ArmClangGenericCflags",
Dan Willemsen110a89d2016-01-14 15:17:19 -0800201 strings.Join(armClangCpuVariantCflags[""], " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700202 pctx.StaticVariable("ArmClangCortexA7Cflags",
Colin Cross3f40fa42015-01-30 17:27:36 -0800203 strings.Join(armClangCpuVariantCflags["cortex-a7"], " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700204 pctx.StaticVariable("ArmClangCortexA8Cflags",
Colin Cross3f40fa42015-01-30 17:27:36 -0800205 strings.Join(armClangCpuVariantCflags["cortex-a8"], " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700206 pctx.StaticVariable("ArmClangCortexA15Cflags",
Colin Cross3f40fa42015-01-30 17:27:36 -0800207 strings.Join(armClangCpuVariantCflags["cortex-a15"], " "))
Christopher Ferris6df46f52017-05-08 12:08:40 -0700208 pctx.StaticVariable("ArmClangCortexA53Cflags",
209 strings.Join(armClangCpuVariantCflags["cortex-a53"], " "))
Christopher Ferrisba14a8f2018-04-23 18:15:25 -0700210 pctx.StaticVariable("ArmClangCortexA55Cflags",
211 strings.Join(armClangCpuVariantCflags["cortex-a55"], " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700212 pctx.StaticVariable("ArmClangKraitCflags",
Colin Cross3f40fa42015-01-30 17:27:36 -0800213 strings.Join(armClangCpuVariantCflags["krait"], " "))
Alex Naidisae4fc182016-08-20 00:14:56 +0200214 pctx.StaticVariable("ArmClangKryoCflags",
215 strings.Join(armClangCpuVariantCflags["kryo"], " "))
Colin Cross3f40fa42015-01-30 17:27:36 -0800216}
217
218var (
Colin Cross3f40fa42015-01-30 17:27:36 -0800219 armClangArchVariantCflagsVar = map[string]string{
Dan Albert8818f492019-02-19 13:53:01 -0800220 "armv7-a": "${config.ArmClangArmv7ACflags}",
Colin Crossb98c8b02016-07-29 13:44:28 -0700221 "armv7-a-neon": "${config.ArmClangArmv7ANeonCflags}",
Isaac Chena2a58242017-08-23 10:57:17 +0000222 "armv8-a": "${config.ArmClangArmv8ACflags}",
Artem Serovd3072b02018-11-15 15:21:51 +0000223 "armv8-2a": "${config.ArmClangArmv82ACflags}",
Colin Cross3f40fa42015-01-30 17:27:36 -0800224 }
225
226 armClangCpuVariantCflagsVar = map[string]string{
Colin Crossb98c8b02016-07-29 13:44:28 -0700227 "": "${config.ArmClangGenericCflags}",
228 "cortex-a7": "${config.ArmClangCortexA7Cflags}",
229 "cortex-a8": "${config.ArmClangCortexA8Cflags}",
230 "cortex-a15": "${config.ArmClangCortexA15Cflags}",
Christopher Ferris6df46f52017-05-08 12:08:40 -0700231 "cortex-a53": "${config.ArmClangCortexA53Cflags}",
232 "cortex-a53.a57": "${config.ArmClangCortexA53Cflags}",
Christopher Ferrisba14a8f2018-04-23 18:15:25 -0700233 "cortex-a55": "${config.ArmClangCortexA55Cflags}",
Richard Fungeb37ed32018-09-24 16:33:45 -0700234 "cortex-a72": "${config.ArmClangCortexA53Cflags}",
Christopher Ferris6df46f52017-05-08 12:08:40 -0700235 "cortex-a73": "${config.ArmClangCortexA53Cflags}",
Christopher Ferrisba14a8f2018-04-23 18:15:25 -0700236 "cortex-a75": "${config.ArmClangCortexA55Cflags}",
Luca Stefani2af7d882019-09-12 18:37:45 +0200237 "cortex-a76": "${config.ArmClangCortexA55Cflags}",
Colin Crossb98c8b02016-07-29 13:44:28 -0700238 "krait": "${config.ArmClangKraitCflags}",
Alex Naidisae4fc182016-08-20 00:14:56 +0200239 "kryo": "${config.ArmClangKryoCflags}",
Artem Serovd3072b02018-11-15 15:21:51 +0000240 "kryo385": "${config.ArmClangCortexA53Cflags}",
Junmo Park8ea49592017-07-24 07:14:55 +0900241 "exynos-m1": "${config.ArmClangCortexA53Cflags}",
Junmo Parkd86c9022017-07-21 09:07:47 +0900242 "exynos-m2": "${config.ArmClangCortexA53Cflags}",
Colin Cross3f40fa42015-01-30 17:27:36 -0800243 }
244)
245
246type toolchainArm struct {
247 toolchain32Bit
Dan Willemsenbd4abf52018-10-07 21:06:36 -0700248 ldflags string
249 lldflags string
250 toolchainClangCflags string
Colin Cross3f40fa42015-01-30 17:27:36 -0800251}
252
Dan Albertbe961682015-03-18 23:38:50 -0700253func (t *toolchainArm) Name() string {
254 return "arm"
255}
256
Colin Cross3f40fa42015-01-30 17:27:36 -0800257func (t *toolchainArm) GccRoot() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700258 return "${config.ArmGccRoot}"
Colin Cross3f40fa42015-01-30 17:27:36 -0800259}
260
261func (t *toolchainArm) GccTriple() string {
Dan Albert84f431f2016-07-20 14:44:26 -0700262 return "arm-linux-androideabi"
Colin Cross3f40fa42015-01-30 17:27:36 -0800263}
264
Dan Albertbe961682015-03-18 23:38:50 -0700265func (t *toolchainArm) GccVersion() string {
Dan Willemsen34fc3b12015-12-07 12:30:44 -0800266 return armGccVersion
Dan Albertbe961682015-03-18 23:38:50 -0700267}
268
Colin Cross3f40fa42015-01-30 17:27:36 -0800269func (t *toolchainArm) IncludeFlags() string {
Martin Stjernholm41ab2512020-04-08 01:06:07 +0100270 return ""
Colin Cross3f40fa42015-01-30 17:27:36 -0800271}
272
273func (t *toolchainArm) ClangTriple() string {
Chih-Hung Hsieh1e7d1bf2018-03-15 18:44:57 -0700274 // http://b/72619014 work around llvm LTO bug.
275 return "armv7a-linux-androideabi"
276}
277
278func (t *toolchainArm) ndkTriple() string {
279 // Use current NDK include path, while ClangTriple is changed.
Dan Albert84f431f2016-07-20 14:44:26 -0700280 return t.GccTriple()
Colin Cross3f40fa42015-01-30 17:27:36 -0800281}
282
Colin Crossc4bde762015-11-23 16:11:30 -0800283func (t *toolchainArm) ToolchainClangCflags() string {
284 return t.toolchainClangCflags
285}
286
Colin Cross3f40fa42015-01-30 17:27:36 -0800287func (t *toolchainArm) ClangCflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700288 return "${config.ArmClangCflags}"
Colin Cross3f40fa42015-01-30 17:27:36 -0800289}
290
291func (t *toolchainArm) ClangCppflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700292 return "${config.ArmClangCppflags}"
Colin Cross3f40fa42015-01-30 17:27:36 -0800293}
294
295func (t *toolchainArm) ClangLdflags() string {
296 return t.ldflags
297}
298
Chih-Hung Hsieh02b4da52018-04-03 11:33:34 -0700299func (t *toolchainArm) ClangLldflags() string {
300 return t.lldflags // TODO: handle V8 cases
301}
302
Dan Willemsen6d11dd82015-11-03 14:27:00 -0800303func (t *toolchainArm) ClangInstructionSetFlags(isa string) (string, error) {
304 switch isa {
305 case "arm":
Colin Crossb98c8b02016-07-29 13:44:28 -0700306 return "${config.ArmClangArmCflags}", nil
Dan Willemsen6d11dd82015-11-03 14:27:00 -0800307 case "thumb", "":
Colin Crossb98c8b02016-07-29 13:44:28 -0700308 return "${config.ArmClangThumbCflags}", nil
Dan Willemsen6d11dd82015-11-03 14:27:00 -0800309 default:
310 return t.toolchainBase.ClangInstructionSetFlags(isa)
311 }
312}
313
Yi Kong924adc42018-08-31 14:27:44 -0700314func (toolchainArm) LibclangRuntimeLibraryArch() string {
Evgenii Stepanovaf36db12016-08-15 14:18:24 -0700315 return "arm"
Colin Cross16b23492016-01-06 14:41:07 -0800316}
317
Colin Cross635c3b02016-05-18 15:37:25 -0700318func armToolchainFactory(arch android.Arch) Toolchain {
Colin Crossc1e814d2015-04-28 13:15:59 -0700319 var fixCortexA8 string
Dan Willemsen110a89d2016-01-14 15:17:19 -0800320 toolchainClangCflags := make([]string, 2, 3)
321
Colin Crossb98c8b02016-07-29 13:44:28 -0700322 toolchainClangCflags[0] = "${config.ArmToolchainClangCflags}"
Dan Willemsen110a89d2016-01-14 15:17:19 -0800323 toolchainClangCflags[1] = armClangArchVariantCflagsVar[arch.ArchVariant]
324
Isaac Chena2a58242017-08-23 10:57:17 +0000325 toolchainClangCflags = append(toolchainClangCflags,
326 variantOrDefault(armClangCpuVariantCflagsVar, arch.CpuVariant))
327
Dan Willemsen110a89d2016-01-14 15:17:19 -0800328 switch arch.ArchVariant {
329 case "armv7-a-neon":
330 switch arch.CpuVariant {
331 case "cortex-a8", "":
332 // Generic ARM might be a Cortex A8 -- better safe than sorry
333 fixCortexA8 = "-Wl,--fix-cortex-a8"
334 default:
335 fixCortexA8 = "-Wl,--no-fix-cortex-a8"
336 }
Dan Albert8818f492019-02-19 13:53:01 -0800337 case "armv7-a":
338 fixCortexA8 = "-Wl,--fix-cortex-a8"
mtk15504270ba752018-10-31 15:26:32 +0800339 case "armv8-a", "armv8-2a":
340 // Nothing extra for armv8-a/armv8-2a
Colin Crossc1e814d2015-04-28 13:15:59 -0700341 default:
Dan Willemsen110a89d2016-01-14 15:17:19 -0800342 panic(fmt.Sprintf("Unknown ARM architecture version: %q", arch.ArchVariant))
Colin Crossc1e814d2015-04-28 13:15:59 -0700343 }
344
Colin Cross3f40fa42015-01-30 17:27:36 -0800345 return &toolchainArm{
Colin Cross3f40fa42015-01-30 17:27:36 -0800346 ldflags: strings.Join([]string{
Colin Crossb98c8b02016-07-29 13:44:28 -0700347 "${config.ArmLdflags}",
Colin Crossc1e814d2015-04-28 13:15:59 -0700348 fixCortexA8,
Colin Cross3f40fa42015-01-30 17:27:36 -0800349 }, " "),
Chih-Hung Hsieh02b4da52018-04-03 11:33:34 -0700350 lldflags: "${config.ArmLldflags}",
Dan Willemsen110a89d2016-01-14 15:17:19 -0800351 toolchainClangCflags: strings.Join(toolchainClangCflags, " "),
Colin Cross3f40fa42015-01-30 17:27:36 -0800352 }
353}
354
355func init() {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700356 registerToolchainFactory(android.Android, android.Arm, armToolchainFactory)
Colin Cross3f40fa42015-01-30 17:27:36 -0800357}