blob: 75f59621057e7d8d5552a03f4ec18359700575c0 [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 Cross13af54d2015-03-16 16:12:05 -070037 "-Wl,--icf=safe",
Colin Cross3f40fa42015-01-30 17:27:36 -080038 "-Wl,--hash-style=gnu",
Stephen Craneb3c21542017-06-26 19:22:02 -070039 "-Wl,-m,armelf",
Colin Cross3f40fa42015-01-30 17:27:36 -080040 }
41
Chih-Hung Hsieh02b4da52018-04-03 11:33:34 -070042 armLldflags = ClangFilterUnknownLldflags(armLdflags)
43
Colin Cross3f40fa42015-01-30 17:27:36 -080044 armArmCflags = []string{
Colin Cross3f40fa42015-01-30 17:27:36 -080045 "-fstrict-aliasing",
Colin Cross3f40fa42015-01-30 17:27:36 -080046 }
47
48 armThumbCflags = []string{
49 "-mthumb",
50 "-Os",
Colin Cross3f40fa42015-01-30 17:27:36 -080051 }
52
Dan Willemsenbd4abf52018-10-07 21:06:36 -070053 armClangArchVariantCflags = map[string][]string{
Colin Cross3f40fa42015-01-30 17:27:36 -080054 "armv7-a": []string{
55 "-march=armv7-a",
56 "-mfloat-abi=softfp",
57 "-mfpu=vfpv3-d16",
58 },
59 "armv7-a-neon": []string{
Isaac Chen2bce8ed2017-10-05 18:28:57 +080060 "-march=armv7-a",
Colin Cross3f40fa42015-01-30 17:27:36 -080061 "-mfloat-abi=softfp",
62 "-mfpu=neon",
63 },
Isaac Chena2a58242017-08-23 10:57:17 +000064 "armv8-a": []string{
65 "-march=armv8-a",
66 "-mfloat-abi=softfp",
67 "-mfpu=neon-fp-armv8",
68 },
Colin Cross3f40fa42015-01-30 17:27:36 -080069 }
70
Dan Willemsenbd4abf52018-10-07 21:06:36 -070071 armClangCpuVariantCflags = map[string][]string{
Colin Cross3f40fa42015-01-30 17:27:36 -080072 "cortex-a7": []string{
73 "-mcpu=cortex-a7",
Jake Weinstein5cfd7092017-04-06 22:25:34 -040074 "-mfpu=neon-vfpv4",
Dan Willemsen8e1e3fb2016-03-29 15:47:08 -070075 // Fake an ARM compiler flag as these processors support LPAE which GCC/clang
76 // don't advertise.
77 // TODO This is a hack and we need to add it for each processor that supports LPAE until some
78 // better solution comes around. See Bug 27340895
79 "-D__ARM_FEATURE_LPAE=1",
Colin Cross3f40fa42015-01-30 17:27:36 -080080 },
81 "cortex-a8": []string{
82 "-mcpu=cortex-a8",
83 },
84 "cortex-a15": []string{
85 "-mcpu=cortex-a15",
Jake Weinstein59166572017-04-06 20:47:23 -040086 "-mfpu=neon-vfpv4",
Colin Cross3f40fa42015-01-30 17:27:36 -080087 // Fake an ARM compiler flag as these processors support LPAE which GCC/clang
88 // don't advertise.
Dan Willemsen8e1e3fb2016-03-29 15:47:08 -070089 // TODO This is a hack and we need to add it for each processor that supports LPAE until some
90 // better solution comes around. See Bug 27340895
Colin Cross3f40fa42015-01-30 17:27:36 -080091 "-D__ARM_FEATURE_LPAE=1",
92 },
Christopher Ferris6df46f52017-05-08 12:08:40 -070093 "cortex-a53": []string{
94 "-mcpu=cortex-a53",
95 "-mfpu=neon-fp-armv8",
96 // Fake an ARM compiler flag as these processors support LPAE which GCC/clang
97 // don't advertise.
98 // TODO This is a hack and we need to add it for each processor that supports LPAE until some
99 // better solution comes around. See Bug 27340895
100 "-D__ARM_FEATURE_LPAE=1",
101 },
Christopher Ferrisba14a8f2018-04-23 18:15:25 -0700102 "cortex-a55": []string{
Yi Kong9c633632018-06-15 15:46:11 -0700103 "-mcpu=cortex-a55",
Christopher Ferrisba14a8f2018-04-23 18:15:25 -0700104 "-mfpu=neon-fp-armv8",
105 // Fake an ARM compiler flag as these processors support LPAE which GCC/clang
106 // don't advertise.
107 // TODO This is a hack and we need to add it for each processor that supports LPAE until some
108 // better solution comes around. See Bug 27340895
109 "-D__ARM_FEATURE_LPAE=1",
110 },
111 "cortex-a75": []string{
Yi Kong9c633632018-06-15 15:46:11 -0700112 "-mcpu=cortex-a55",
Christopher Ferrisba14a8f2018-04-23 18:15:25 -0700113 "-mfpu=neon-fp-armv8",
114 // Fake an ARM compiler flag as these processors support LPAE which GCC/clang
115 // don't advertise.
116 // TODO This is a hack and we need to add it for each processor that supports LPAE until some
117 // better solution comes around. See Bug 27340895
118 "-D__ARM_FEATURE_LPAE=1",
119 },
Haibo Huanga31e2bd2018-10-09 14:27:28 -0700120 "cortex-a76": []string{
121 "-mcpu=cortex-a55",
122 "-mfpu=neon-fp-armv8",
123 // Fake an ARM compiler flag as these processors support LPAE which GCC/clang
124 // don't advertise.
125 // 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
127 "-D__ARM_FEATURE_LPAE=1",
128 },
Dan Willemsened89a7a2016-05-09 13:39:58 -0700129 "krait": []string{
Dan Willemsenbd4abf52018-10-07 21:06:36 -0700130 "-mcpu=krait",
Jake Weinsteinfff256f2017-04-06 20:38:26 -0400131 "-mfpu=neon-vfpv4",
Dan Willemsened89a7a2016-05-09 13:39:58 -0700132 // Fake an ARM compiler flag as these processors support LPAE which GCC/clang
133 // don't advertise.
134 // TODO This is a hack and we need to add it for each processor that supports LPAE until some
135 // better solution comes around. See Bug 27340895
136 "-D__ARM_FEATURE_LPAE=1",
137 },
Alex Naidisae4fc182016-08-20 00:14:56 +0200138 "kryo": []string{
Pirama Arumuga Nainarc17b2752017-11-20 22:29:58 -0800139 // Use cortex-a53 because the GNU assembler doesn't recognize -mcpu=kryo
140 // even though clang does.
141 "-mcpu=cortex-a53",
Jake Weinstein1783a2f2017-04-06 20:28:05 -0400142 "-mfpu=neon-fp-armv8",
Alex Naidisae4fc182016-08-20 00:14:56 +0200143 // Fake an ARM compiler flag as these processors support LPAE which GCC/clang
144 // don't advertise.
145 // TODO This is a hack and we need to add it for each processor that supports LPAE until some
146 // better solution comes around. See Bug 27340895
147 "-D__ARM_FEATURE_LPAE=1",
148 },
Colin Cross3f40fa42015-01-30 17:27:36 -0800149 }
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() {
Colin Cross0906f172017-04-26 14:00:43 -0700157 android.RegisterArchFeatures(android.Arm,
158 "neon")
159
Dan Willemsenb1957a52016-06-23 23:44:54 -0700160 android.RegisterArchVariants(android.Arm,
Colin Cross0906f172017-04-26 14:00:43 -0700161 "armv7-a",
162 "armv7-a-neon",
Isaac Chena2a58242017-08-23 10:57:17 +0000163 "armv8-a",
Colin Cross0906f172017-04-26 14:00:43 -0700164 "cortex-a7",
165 "cortex-a8",
166 "cortex-a9",
167 "cortex-a15",
168 "cortex-a53",
169 "cortex-a53-a57",
Christopher Ferrisba14a8f2018-04-23 18:15:25 -0700170 "cortex-a55",
Richard Fungeb37ed32018-09-24 16:33:45 -0700171 "cortex-a72",
Christopher Ferris6df46f52017-05-08 12:08:40 -0700172 "cortex-a73",
Christopher Ferrisba14a8f2018-04-23 18:15:25 -0700173 "cortex-a75",
Haibo Huanga31e2bd2018-10-09 14:27:28 -0700174 "cortex-a76",
Dan Willemsenb1957a52016-06-23 23:44:54 -0700175 "krait",
Alex Naidisae4fc182016-08-20 00:14:56 +0200176 "kryo",
Junmo Park8ea49592017-07-24 07:14:55 +0900177 "exynos-m1",
Junmo Parkd86c9022017-07-21 09:07:47 +0900178 "exynos-m2",
Dan Willemsenb1957a52016-06-23 23:44:54 -0700179 "denver")
180
Colin Cross0906f172017-04-26 14:00:43 -0700181 android.RegisterArchVariantFeatures(android.Arm, "armv7-a-neon", "neon")
Isaac Chena2a58242017-08-23 10:57:17 +0000182 android.RegisterArchVariantFeatures(android.Arm, "armv8-a", "neon")
Colin Cross0906f172017-04-26 14:00:43 -0700183
Dan Willemsen34fc3b12015-12-07 12:30:44 -0800184 pctx.StaticVariable("armGccVersion", armGccVersion)
Colin Cross3f40fa42015-01-30 17:27:36 -0800185
Colin Crossb98c8b02016-07-29 13:44:28 -0700186 pctx.SourcePathVariable("ArmGccRoot",
Dan Willemsen87b17d12015-07-14 00:39:06 -0700187 "prebuilts/gcc/${HostPrebuiltTag}/arm/arm-linux-androideabi-${armGccVersion}")
Colin Cross3f40fa42015-01-30 17:27:36 -0800188
Colin Crossb98c8b02016-07-29 13:44:28 -0700189 pctx.StaticVariable("ArmLdflags", strings.Join(armLdflags, " "))
Chih-Hung Hsieh02b4da52018-04-03 11:33:34 -0700190 pctx.StaticVariable("ArmLldflags", strings.Join(armLldflags, " "))
Elliott Hughesde28deb2017-10-12 09:07:53 -0700191 pctx.StaticVariable("ArmIncludeFlags", bionicHeaders("arm"))
Colin Cross3f40fa42015-01-30 17:27:36 -0800192
Colin Cross3f40fa42015-01-30 17:27:36 -0800193 // Clang cflags
Colin Crossb98c8b02016-07-29 13:44:28 -0700194 pctx.StaticVariable("ArmToolchainClangCflags", strings.Join(ClangFilterUnknownCflags(armToolchainCflags), " "))
195 pctx.StaticVariable("ArmClangCflags", strings.Join(ClangFilterUnknownCflags(armCflags), " "))
196 pctx.StaticVariable("ArmClangLdflags", strings.Join(ClangFilterUnknownCflags(armLdflags), " "))
Chih-Hung Hsieh02b4da52018-04-03 11:33:34 -0700197 pctx.StaticVariable("ArmClangLldflags", strings.Join(ClangFilterUnknownCflags(armLldflags), " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700198 pctx.StaticVariable("ArmClangCppflags", strings.Join(ClangFilterUnknownCflags(armCppflags), " "))
Colin Cross3f40fa42015-01-30 17:27:36 -0800199
Dan Willemsen6d11dd82015-11-03 14:27:00 -0800200 // Clang ARM vs. Thumb instruction set cflags
Colin Crossb98c8b02016-07-29 13:44:28 -0700201 pctx.StaticVariable("ArmClangArmCflags", strings.Join(ClangFilterUnknownCflags(armArmCflags), " "))
202 pctx.StaticVariable("ArmClangThumbCflags", strings.Join(ClangFilterUnknownCflags(armThumbCflags), " "))
Dan Willemsen6d11dd82015-11-03 14:27:00 -0800203
Dan Willemsen110a89d2016-01-14 15:17:19 -0800204 // Clang arch variant cflags
Colin Crossb98c8b02016-07-29 13:44:28 -0700205 pctx.StaticVariable("ArmClangArmv7ACflags",
Colin Cross3f40fa42015-01-30 17:27:36 -0800206 strings.Join(armClangArchVariantCflags["armv7-a"], " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700207 pctx.StaticVariable("ArmClangArmv7ANeonCflags",
Colin Cross3f40fa42015-01-30 17:27:36 -0800208 strings.Join(armClangArchVariantCflags["armv7-a-neon"], " "))
Isaac Chena2a58242017-08-23 10:57:17 +0000209 pctx.StaticVariable("ArmClangArmv8ACflags",
210 strings.Join(armClangArchVariantCflags["armv8-a"], " "))
Colin Cross3f40fa42015-01-30 17:27:36 -0800211
212 // Clang cpu variant cflags
Colin Crossb98c8b02016-07-29 13:44:28 -0700213 pctx.StaticVariable("ArmClangGenericCflags",
Dan Willemsen110a89d2016-01-14 15:17:19 -0800214 strings.Join(armClangCpuVariantCflags[""], " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700215 pctx.StaticVariable("ArmClangCortexA7Cflags",
Colin Cross3f40fa42015-01-30 17:27:36 -0800216 strings.Join(armClangCpuVariantCflags["cortex-a7"], " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700217 pctx.StaticVariable("ArmClangCortexA8Cflags",
Colin Cross3f40fa42015-01-30 17:27:36 -0800218 strings.Join(armClangCpuVariantCflags["cortex-a8"], " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700219 pctx.StaticVariable("ArmClangCortexA15Cflags",
Colin Cross3f40fa42015-01-30 17:27:36 -0800220 strings.Join(armClangCpuVariantCflags["cortex-a15"], " "))
Christopher Ferris6df46f52017-05-08 12:08:40 -0700221 pctx.StaticVariable("ArmClangCortexA53Cflags",
222 strings.Join(armClangCpuVariantCflags["cortex-a53"], " "))
Christopher Ferrisba14a8f2018-04-23 18:15:25 -0700223 pctx.StaticVariable("ArmClangCortexA55Cflags",
224 strings.Join(armClangCpuVariantCflags["cortex-a55"], " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700225 pctx.StaticVariable("ArmClangKraitCflags",
Colin Cross3f40fa42015-01-30 17:27:36 -0800226 strings.Join(armClangCpuVariantCflags["krait"], " "))
Alex Naidisae4fc182016-08-20 00:14:56 +0200227 pctx.StaticVariable("ArmClangKryoCflags",
228 strings.Join(armClangCpuVariantCflags["kryo"], " "))
Colin Cross3f40fa42015-01-30 17:27:36 -0800229}
230
231var (
Colin Cross3f40fa42015-01-30 17:27:36 -0800232 armClangArchVariantCflagsVar = map[string]string{
Colin Crossb98c8b02016-07-29 13:44:28 -0700233 "armv7-a": "${config.ArmClangArmv7ACflags}",
234 "armv7-a-neon": "${config.ArmClangArmv7ANeonCflags}",
Isaac Chena2a58242017-08-23 10:57:17 +0000235 "armv8-a": "${config.ArmClangArmv8ACflags}",
Colin Cross3f40fa42015-01-30 17:27:36 -0800236 }
237
238 armClangCpuVariantCflagsVar = map[string]string{
Colin Crossb98c8b02016-07-29 13:44:28 -0700239 "": "${config.ArmClangGenericCflags}",
240 "cortex-a7": "${config.ArmClangCortexA7Cflags}",
241 "cortex-a8": "${config.ArmClangCortexA8Cflags}",
242 "cortex-a15": "${config.ArmClangCortexA15Cflags}",
Christopher Ferris6df46f52017-05-08 12:08:40 -0700243 "cortex-a53": "${config.ArmClangCortexA53Cflags}",
244 "cortex-a53.a57": "${config.ArmClangCortexA53Cflags}",
Christopher Ferrisba14a8f2018-04-23 18:15:25 -0700245 "cortex-a55": "${config.ArmClangCortexA55Cflags}",
Richard Fungeb37ed32018-09-24 16:33:45 -0700246 "cortex-a72": "${config.ArmClangCortexA53Cflags}",
Christopher Ferris6df46f52017-05-08 12:08:40 -0700247 "cortex-a73": "${config.ArmClangCortexA53Cflags}",
Christopher Ferrisba14a8f2018-04-23 18:15:25 -0700248 "cortex-a75": "${config.ArmClangCortexA55Cflags}",
Colin Crossb98c8b02016-07-29 13:44:28 -0700249 "krait": "${config.ArmClangKraitCflags}",
Alex Naidisae4fc182016-08-20 00:14:56 +0200250 "kryo": "${config.ArmClangKryoCflags}",
Junmo Park8ea49592017-07-24 07:14:55 +0900251 "exynos-m1": "${config.ArmClangCortexA53Cflags}",
Junmo Parkd86c9022017-07-21 09:07:47 +0900252 "exynos-m2": "${config.ArmClangCortexA53Cflags}",
Colin Crossb98c8b02016-07-29 13:44:28 -0700253 "denver": "${config.ArmClangCortexA15Cflags}",
Colin Cross3f40fa42015-01-30 17:27:36 -0800254 }
255)
256
257type toolchainArm struct {
258 toolchain32Bit
Dan Willemsenbd4abf52018-10-07 21:06:36 -0700259 ldflags string
260 lldflags string
261 toolchainClangCflags string
Colin Cross3f40fa42015-01-30 17:27:36 -0800262}
263
Dan Albertbe961682015-03-18 23:38:50 -0700264func (t *toolchainArm) Name() string {
265 return "arm"
266}
267
Colin Cross3f40fa42015-01-30 17:27:36 -0800268func (t *toolchainArm) GccRoot() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700269 return "${config.ArmGccRoot}"
Colin Cross3f40fa42015-01-30 17:27:36 -0800270}
271
272func (t *toolchainArm) GccTriple() string {
Dan Albert84f431f2016-07-20 14:44:26 -0700273 return "arm-linux-androideabi"
Colin Cross3f40fa42015-01-30 17:27:36 -0800274}
275
Dan Albertbe961682015-03-18 23:38:50 -0700276func (t *toolchainArm) GccVersion() string {
Dan Willemsen34fc3b12015-12-07 12:30:44 -0800277 return armGccVersion
Dan Albertbe961682015-03-18 23:38:50 -0700278}
279
Colin Cross3f40fa42015-01-30 17:27:36 -0800280func (t *toolchainArm) IncludeFlags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700281 return "${config.ArmIncludeFlags}"
Colin Cross3f40fa42015-01-30 17:27:36 -0800282}
283
284func (t *toolchainArm) ClangTriple() string {
Chih-Hung Hsieh1e7d1bf2018-03-15 18:44:57 -0700285 // http://b/72619014 work around llvm LTO bug.
286 return "armv7a-linux-androideabi"
287}
288
289func (t *toolchainArm) ndkTriple() string {
290 // Use current NDK include path, while ClangTriple is changed.
Dan Albert84f431f2016-07-20 14:44:26 -0700291 return t.GccTriple()
Colin Cross3f40fa42015-01-30 17:27:36 -0800292}
293
Colin Crossc4bde762015-11-23 16:11:30 -0800294func (t *toolchainArm) ToolchainClangCflags() string {
295 return t.toolchainClangCflags
296}
297
Colin Cross3f40fa42015-01-30 17:27:36 -0800298func (t *toolchainArm) ClangCflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700299 return "${config.ArmClangCflags}"
Colin Cross3f40fa42015-01-30 17:27:36 -0800300}
301
302func (t *toolchainArm) ClangCppflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700303 return "${config.ArmClangCppflags}"
Colin Cross3f40fa42015-01-30 17:27:36 -0800304}
305
306func (t *toolchainArm) ClangLdflags() string {
307 return t.ldflags
308}
309
Chih-Hung Hsieh02b4da52018-04-03 11:33:34 -0700310func (t *toolchainArm) ClangLldflags() string {
311 return t.lldflags // TODO: handle V8 cases
312}
313
Dan Willemsen6d11dd82015-11-03 14:27:00 -0800314func (t *toolchainArm) ClangInstructionSetFlags(isa string) (string, error) {
315 switch isa {
316 case "arm":
Colin Crossb98c8b02016-07-29 13:44:28 -0700317 return "${config.ArmClangArmCflags}", nil
Dan Willemsen6d11dd82015-11-03 14:27:00 -0800318 case "thumb", "":
Colin Crossb98c8b02016-07-29 13:44:28 -0700319 return "${config.ArmClangThumbCflags}", nil
Dan Willemsen6d11dd82015-11-03 14:27:00 -0800320 default:
321 return t.toolchainBase.ClangInstructionSetFlags(isa)
322 }
323}
324
Yi Kong924adc42018-08-31 14:27:44 -0700325func (toolchainArm) LibclangRuntimeLibraryArch() string {
Evgenii Stepanovaf36db12016-08-15 14:18:24 -0700326 return "arm"
Colin Cross16b23492016-01-06 14:41:07 -0800327}
328
Colin Cross635c3b02016-05-18 15:37:25 -0700329func armToolchainFactory(arch android.Arch) Toolchain {
Colin Crossc1e814d2015-04-28 13:15:59 -0700330 var fixCortexA8 string
Dan Willemsen110a89d2016-01-14 15:17:19 -0800331 toolchainClangCflags := make([]string, 2, 3)
332
Colin Crossb98c8b02016-07-29 13:44:28 -0700333 toolchainClangCflags[0] = "${config.ArmToolchainClangCflags}"
Dan Willemsen110a89d2016-01-14 15:17:19 -0800334 toolchainClangCflags[1] = armClangArchVariantCflagsVar[arch.ArchVariant]
335
Isaac Chena2a58242017-08-23 10:57:17 +0000336 toolchainClangCflags = append(toolchainClangCflags,
337 variantOrDefault(armClangCpuVariantCflagsVar, arch.CpuVariant))
338
Dan Willemsen110a89d2016-01-14 15:17:19 -0800339 switch arch.ArchVariant {
340 case "armv7-a-neon":
341 switch arch.CpuVariant {
342 case "cortex-a8", "":
343 // Generic ARM might be a Cortex A8 -- better safe than sorry
344 fixCortexA8 = "-Wl,--fix-cortex-a8"
345 default:
346 fixCortexA8 = "-Wl,--no-fix-cortex-a8"
347 }
Dan Willemsen110a89d2016-01-14 15:17:19 -0800348 case "armv7-a":
Colin Crossc1e814d2015-04-28 13:15:59 -0700349 fixCortexA8 = "-Wl,--fix-cortex-a8"
Isaac Chena2a58242017-08-23 10:57:17 +0000350 case "armv8-a":
351 // Nothing extra for armv8-a
Colin Crossc1e814d2015-04-28 13:15:59 -0700352 default:
Dan Willemsen110a89d2016-01-14 15:17:19 -0800353 panic(fmt.Sprintf("Unknown ARM architecture version: %q", arch.ArchVariant))
Colin Crossc1e814d2015-04-28 13:15:59 -0700354 }
355
Colin Cross3f40fa42015-01-30 17:27:36 -0800356 return &toolchainArm{
Colin Cross3f40fa42015-01-30 17:27:36 -0800357 ldflags: strings.Join([]string{
Colin Crossb98c8b02016-07-29 13:44:28 -0700358 "${config.ArmLdflags}",
Colin Crossc1e814d2015-04-28 13:15:59 -0700359 fixCortexA8,
Colin Cross3f40fa42015-01-30 17:27:36 -0800360 }, " "),
Chih-Hung Hsieh02b4da52018-04-03 11:33:34 -0700361 lldflags: "${config.ArmLldflags}",
Dan Willemsen110a89d2016-01-14 15:17:19 -0800362 toolchainClangCflags: strings.Join(toolchainClangCflags, " "),
Colin Cross3f40fa42015-01-30 17:27:36 -0800363 }
364}
365
366func init() {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700367 registerToolchainFactory(android.Android, android.Arm, armToolchainFactory)
Colin Cross3f40fa42015-01-30 17:27:36 -0800368}