blob: 66b3b382951f1a91f06c3a6b5e1c2106049a7898 [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
42 armArmCflags = []string{
Colin Cross3f40fa42015-01-30 17:27:36 -080043 "-fstrict-aliasing",
Colin Cross3f40fa42015-01-30 17:27:36 -080044 }
45
46 armThumbCflags = []string{
47 "-mthumb",
48 "-Os",
Colin Cross3f40fa42015-01-30 17:27:36 -080049 }
50
51 armArchVariantCflags = map[string][]string{
Colin Cross3f40fa42015-01-30 17:27:36 -080052 "armv7-a": []string{
53 "-march=armv7-a",
54 "-mfloat-abi=softfp",
55 "-mfpu=vfpv3-d16",
56 },
57 "armv7-a-neon": []string{
Isaac Chen2bce8ed2017-10-05 18:28:57 +080058 "-march=armv7-a",
Colin Cross3f40fa42015-01-30 17:27:36 -080059 "-mfloat-abi=softfp",
60 "-mfpu=neon",
61 },
Isaac Chena2a58242017-08-23 10:57:17 +000062 "armv8-a": []string{
63 "-march=armv8-a",
64 "-mfloat-abi=softfp",
65 "-mfpu=neon-fp-armv8",
66 },
Colin Cross3f40fa42015-01-30 17:27:36 -080067 }
68
Colin Cross3f40fa42015-01-30 17:27:36 -080069 armCpuVariantCflags = map[string][]string{
70 "cortex-a7": []string{
71 "-mcpu=cortex-a7",
Jake Weinstein5cfd7092017-04-06 22:25:34 -040072 "-mfpu=neon-vfpv4",
Dan Willemsen8e1e3fb2016-03-29 15:47:08 -070073 // Fake an ARM compiler flag as these processors support LPAE which GCC/clang
74 // don't advertise.
75 // TODO This is a hack and we need to add it for each processor that supports LPAE until some
76 // better solution comes around. See Bug 27340895
77 "-D__ARM_FEATURE_LPAE=1",
Colin Cross3f40fa42015-01-30 17:27:36 -080078 },
79 "cortex-a8": []string{
80 "-mcpu=cortex-a8",
81 },
82 "cortex-a15": []string{
83 "-mcpu=cortex-a15",
Jake Weinstein59166572017-04-06 20:47:23 -040084 "-mfpu=neon-vfpv4",
Colin Cross3f40fa42015-01-30 17:27:36 -080085 // Fake an ARM compiler flag as these processors support LPAE which GCC/clang
86 // don't advertise.
Dan Willemsen8e1e3fb2016-03-29 15:47:08 -070087 // TODO This is a hack and we need to add it for each processor that supports LPAE until some
88 // better solution comes around. See Bug 27340895
Colin Cross3f40fa42015-01-30 17:27:36 -080089 "-D__ARM_FEATURE_LPAE=1",
90 },
Christopher Ferris6df46f52017-05-08 12:08:40 -070091 "cortex-a53": []string{
92 "-mcpu=cortex-a53",
93 "-mfpu=neon-fp-armv8",
94 // Fake an ARM compiler flag as these processors support LPAE which GCC/clang
95 // don't advertise.
96 // TODO This is a hack and we need to add it for each processor that supports LPAE until some
97 // better solution comes around. See Bug 27340895
98 "-D__ARM_FEATURE_LPAE=1",
99 },
Dan Willemsened89a7a2016-05-09 13:39:58 -0700100 "krait": []string{
101 "-mcpu=cortex-a15",
Jake Weinsteinfff256f2017-04-06 20:38:26 -0400102 "-mfpu=neon-vfpv4",
Dan Willemsened89a7a2016-05-09 13:39:58 -0700103 // Fake an ARM compiler flag as these processors support LPAE which GCC/clang
104 // don't advertise.
105 // TODO This is a hack and we need to add it for each processor that supports LPAE until some
106 // better solution comes around. See Bug 27340895
107 "-D__ARM_FEATURE_LPAE=1",
108 },
Alex Naidisae4fc182016-08-20 00:14:56 +0200109 "kryo": []string{
Pirama Arumuga Nainarc17b2752017-11-20 22:29:58 -0800110 // Use cortex-a53 because the GNU assembler doesn't recognize -mcpu=kryo
111 // even though clang does.
112 "-mcpu=cortex-a53",
Jake Weinstein1783a2f2017-04-06 20:28:05 -0400113 "-mfpu=neon-fp-armv8",
Alex Naidisae4fc182016-08-20 00:14:56 +0200114 // 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 },
Colin Cross3f40fa42015-01-30 17:27:36 -0800120 }
121
Dan Willemsenf5a959c2015-07-13 13:28:18 -0700122 armClangCpuVariantCflags = copyVariantFlags(armCpuVariantCflags)
123 armClangArchVariantCflags = copyVariantFlags(armArchVariantCflags)
Colin Cross3f40fa42015-01-30 17:27:36 -0800124)
125
Dan Willemsen34fc3b12015-12-07 12:30:44 -0800126const (
127 armGccVersion = "4.9"
128)
129
Colin Cross3f40fa42015-01-30 17:27:36 -0800130func init() {
Colin Cross0906f172017-04-26 14:00:43 -0700131 android.RegisterArchFeatures(android.Arm,
132 "neon")
133
Dan Willemsenb1957a52016-06-23 23:44:54 -0700134 android.RegisterArchVariants(android.Arm,
Colin Cross0906f172017-04-26 14:00:43 -0700135 "armv7-a",
136 "armv7-a-neon",
Isaac Chena2a58242017-08-23 10:57:17 +0000137 "armv8-a",
Colin Cross0906f172017-04-26 14:00:43 -0700138 "cortex-a7",
139 "cortex-a8",
140 "cortex-a9",
141 "cortex-a15",
142 "cortex-a53",
143 "cortex-a53-a57",
Christopher Ferris6df46f52017-05-08 12:08:40 -0700144 "cortex-a73",
Dan Willemsenb1957a52016-06-23 23:44:54 -0700145 "krait",
Alex Naidisae4fc182016-08-20 00:14:56 +0200146 "kryo",
Junmo Park8ea49592017-07-24 07:14:55 +0900147 "exynos-m1",
Junmo Parkd86c9022017-07-21 09:07:47 +0900148 "exynos-m2",
Dan Willemsenb1957a52016-06-23 23:44:54 -0700149 "denver")
150
Colin Cross0906f172017-04-26 14:00:43 -0700151 android.RegisterArchVariantFeatures(android.Arm, "armv7-a-neon", "neon")
Isaac Chena2a58242017-08-23 10:57:17 +0000152 android.RegisterArchVariantFeatures(android.Arm, "armv8-a", "neon")
Colin Cross0906f172017-04-26 14:00:43 -0700153
Pirama Arumuga Nainarc17b2752017-11-20 22:29:58 -0800154 // Krait is not supported by GCC, but is supported by Clang, so
155 // override the definitions when building modules with Clang.
Dan Willemsened89a7a2016-05-09 13:39:58 -0700156 replaceFirst(armClangCpuVariantCflags["krait"], "-mcpu=cortex-a15", "-mcpu=krait")
Alex Naidisae4fc182016-08-20 00:14:56 +0200157
Isaac Chena2a58242017-08-23 10:57:17 +0000158 // The reason we use "-march=armv8-a+crc", instead of "-march=armv8-a", for
159 // gcc is the latter would conflict with any specified/supported -mcpu!
160 // All armv8-a cores supported by gcc 4.9 support crc, so it's safe
161 // to add +crc. Besides, the use of gcc is only for legacy code.
162 replaceFirst(armArchVariantCflags["armv8-a"], "-march=armv8-a", "-march=armv8-a+crc")
163
Dan Willemsen34fc3b12015-12-07 12:30:44 -0800164 pctx.StaticVariable("armGccVersion", armGccVersion)
Colin Cross3f40fa42015-01-30 17:27:36 -0800165
Colin Crossb98c8b02016-07-29 13:44:28 -0700166 pctx.SourcePathVariable("ArmGccRoot",
Dan Willemsen87b17d12015-07-14 00:39:06 -0700167 "prebuilts/gcc/${HostPrebuiltTag}/arm/arm-linux-androideabi-${armGccVersion}")
Colin Cross3f40fa42015-01-30 17:27:36 -0800168
Colin Crossb98c8b02016-07-29 13:44:28 -0700169 pctx.StaticVariable("ArmToolchainCflags", strings.Join(armToolchainCflags, " "))
170 pctx.StaticVariable("ArmCflags", strings.Join(armCflags, " "))
171 pctx.StaticVariable("ArmLdflags", strings.Join(armLdflags, " "))
172 pctx.StaticVariable("ArmCppflags", strings.Join(armCppflags, " "))
Elliott Hughesde28deb2017-10-12 09:07:53 -0700173 pctx.StaticVariable("ArmIncludeFlags", bionicHeaders("arm"))
Colin Cross3f40fa42015-01-30 17:27:36 -0800174
175 // Extended cflags
176
Tim Kilbourn1a9bf262015-03-18 12:28:32 -0700177 // ARM vs. Thumb instruction set flags
Colin Crossb98c8b02016-07-29 13:44:28 -0700178 pctx.StaticVariable("ArmArmCflags", strings.Join(armArmCflags, " "))
179 pctx.StaticVariable("ArmThumbCflags", strings.Join(armThumbCflags, " "))
Colin Cross3f40fa42015-01-30 17:27:36 -0800180
181 // Architecture variant cflags
Colin Crossb98c8b02016-07-29 13:44:28 -0700182 pctx.StaticVariable("ArmArmv7ACflags", strings.Join(armArchVariantCflags["armv7-a"], " "))
183 pctx.StaticVariable("ArmArmv7ANeonCflags", strings.Join(armArchVariantCflags["armv7-a-neon"], " "))
Isaac Chena2a58242017-08-23 10:57:17 +0000184 pctx.StaticVariable("ArmArmv8ACflags", strings.Join(armArchVariantCflags["armv8-a"], " "))
Colin Cross3f40fa42015-01-30 17:27:36 -0800185
Colin Cross3f40fa42015-01-30 17:27:36 -0800186 // Cpu variant cflags
Colin Crossb98c8b02016-07-29 13:44:28 -0700187 pctx.StaticVariable("ArmGenericCflags", strings.Join(armCpuVariantCflags[""], " "))
188 pctx.StaticVariable("ArmCortexA7Cflags", strings.Join(armCpuVariantCflags["cortex-a7"], " "))
189 pctx.StaticVariable("ArmCortexA8Cflags", strings.Join(armCpuVariantCflags["cortex-a8"], " "))
190 pctx.StaticVariable("ArmCortexA15Cflags", strings.Join(armCpuVariantCflags["cortex-a15"], " "))
Christopher Ferris6df46f52017-05-08 12:08:40 -0700191 pctx.StaticVariable("ArmCortexA53Cflags", strings.Join(armCpuVariantCflags["cortex-a53"], " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700192 pctx.StaticVariable("ArmKraitCflags", strings.Join(armCpuVariantCflags["krait"], " "))
Alex Naidisae4fc182016-08-20 00:14:56 +0200193 pctx.StaticVariable("ArmKryoCflags", strings.Join(armCpuVariantCflags["kryo"], " "))
Colin Cross3f40fa42015-01-30 17:27:36 -0800194
195 // Clang cflags
Colin Crossb98c8b02016-07-29 13:44:28 -0700196 pctx.StaticVariable("ArmToolchainClangCflags", strings.Join(ClangFilterUnknownCflags(armToolchainCflags), " "))
197 pctx.StaticVariable("ArmClangCflags", strings.Join(ClangFilterUnknownCflags(armCflags), " "))
198 pctx.StaticVariable("ArmClangLdflags", strings.Join(ClangFilterUnknownCflags(armLdflags), " "))
199 pctx.StaticVariable("ArmClangCppflags", strings.Join(ClangFilterUnknownCflags(armCppflags), " "))
Colin Cross3f40fa42015-01-30 17:27:36 -0800200
Dan Willemsen6d11dd82015-11-03 14:27:00 -0800201 // Clang ARM vs. Thumb instruction set cflags
Colin Crossb98c8b02016-07-29 13:44:28 -0700202 pctx.StaticVariable("ArmClangArmCflags", strings.Join(ClangFilterUnknownCflags(armArmCflags), " "))
203 pctx.StaticVariable("ArmClangThumbCflags", strings.Join(ClangFilterUnknownCflags(armThumbCflags), " "))
Dan Willemsen6d11dd82015-11-03 14:27:00 -0800204
Dan Willemsen110a89d2016-01-14 15:17:19 -0800205 // Clang arch variant cflags
Colin Crossb98c8b02016-07-29 13:44:28 -0700206 pctx.StaticVariable("ArmClangArmv7ACflags",
Colin Cross3f40fa42015-01-30 17:27:36 -0800207 strings.Join(armClangArchVariantCflags["armv7-a"], " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700208 pctx.StaticVariable("ArmClangArmv7ANeonCflags",
Colin Cross3f40fa42015-01-30 17:27:36 -0800209 strings.Join(armClangArchVariantCflags["armv7-a-neon"], " "))
Isaac Chena2a58242017-08-23 10:57:17 +0000210 pctx.StaticVariable("ArmClangArmv8ACflags",
211 strings.Join(armClangArchVariantCflags["armv8-a"], " "))
Colin Cross3f40fa42015-01-30 17:27:36 -0800212
213 // Clang cpu variant cflags
Colin Crossb98c8b02016-07-29 13:44:28 -0700214 pctx.StaticVariable("ArmClangGenericCflags",
Dan Willemsen110a89d2016-01-14 15:17:19 -0800215 strings.Join(armClangCpuVariantCflags[""], " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700216 pctx.StaticVariable("ArmClangCortexA7Cflags",
Colin Cross3f40fa42015-01-30 17:27:36 -0800217 strings.Join(armClangCpuVariantCflags["cortex-a7"], " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700218 pctx.StaticVariable("ArmClangCortexA8Cflags",
Colin Cross3f40fa42015-01-30 17:27:36 -0800219 strings.Join(armClangCpuVariantCflags["cortex-a8"], " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700220 pctx.StaticVariable("ArmClangCortexA15Cflags",
Colin Cross3f40fa42015-01-30 17:27:36 -0800221 strings.Join(armClangCpuVariantCflags["cortex-a15"], " "))
Christopher Ferris6df46f52017-05-08 12:08:40 -0700222 pctx.StaticVariable("ArmClangCortexA53Cflags",
223 strings.Join(armClangCpuVariantCflags["cortex-a53"], " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700224 pctx.StaticVariable("ArmClangKraitCflags",
Colin Cross3f40fa42015-01-30 17:27:36 -0800225 strings.Join(armClangCpuVariantCflags["krait"], " "))
Alex Naidisae4fc182016-08-20 00:14:56 +0200226 pctx.StaticVariable("ArmClangKryoCflags",
227 strings.Join(armClangCpuVariantCflags["kryo"], " "))
Colin Cross3f40fa42015-01-30 17:27:36 -0800228}
229
230var (
231 armArchVariantCflagsVar = map[string]string{
Colin Crossb98c8b02016-07-29 13:44:28 -0700232 "armv7-a": "${config.ArmArmv7ACflags}",
233 "armv7-a-neon": "${config.ArmArmv7ANeonCflags}",
Isaac Chena2a58242017-08-23 10:57:17 +0000234 "armv8-a": "${config.ArmArmv8ACflags}",
Colin Cross3f40fa42015-01-30 17:27:36 -0800235 }
236
Colin Cross3f40fa42015-01-30 17:27:36 -0800237 armCpuVariantCflagsVar = map[string]string{
Colin Crossb98c8b02016-07-29 13:44:28 -0700238 "": "${config.ArmGenericCflags}",
239 "cortex-a7": "${config.ArmCortexA7Cflags}",
240 "cortex-a8": "${config.ArmCortexA8Cflags}",
241 "cortex-a15": "${config.ArmCortexA15Cflags}",
Christopher Ferris6df46f52017-05-08 12:08:40 -0700242 "cortex-a53": "${config.ArmCortexA53Cflags}",
243 "cortex-a53.a57": "${config.ArmCortexA53Cflags}",
244 "cortex-a73": "${config.ArmCortexA53Cflags}",
Colin Crossb98c8b02016-07-29 13:44:28 -0700245 "krait": "${config.ArmKraitCflags}",
Alex Naidisae4fc182016-08-20 00:14:56 +0200246 "kryo": "${config.ArmKryoCflags}",
Junmo Park8ea49592017-07-24 07:14:55 +0900247 "exynos-m1": "${config.ArmCortexA53Cflags}",
Junmo Parkd86c9022017-07-21 09:07:47 +0900248 "exynos-m2": "${config.ArmCortexA53Cflags}",
Colin Crossb98c8b02016-07-29 13:44:28 -0700249 "denver": "${config.ArmCortexA15Cflags}",
Colin Cross3f40fa42015-01-30 17:27:36 -0800250 }
251
252 armClangArchVariantCflagsVar = map[string]string{
Colin Crossb98c8b02016-07-29 13:44:28 -0700253 "armv7-a": "${config.ArmClangArmv7ACflags}",
254 "armv7-a-neon": "${config.ArmClangArmv7ANeonCflags}",
Isaac Chena2a58242017-08-23 10:57:17 +0000255 "armv8-a": "${config.ArmClangArmv8ACflags}",
Colin Cross3f40fa42015-01-30 17:27:36 -0800256 }
257
258 armClangCpuVariantCflagsVar = map[string]string{
Colin Crossb98c8b02016-07-29 13:44:28 -0700259 "": "${config.ArmClangGenericCflags}",
260 "cortex-a7": "${config.ArmClangCortexA7Cflags}",
261 "cortex-a8": "${config.ArmClangCortexA8Cflags}",
262 "cortex-a15": "${config.ArmClangCortexA15Cflags}",
Christopher Ferris6df46f52017-05-08 12:08:40 -0700263 "cortex-a53": "${config.ArmClangCortexA53Cflags}",
264 "cortex-a53.a57": "${config.ArmClangCortexA53Cflags}",
265 "cortex-a73": "${config.ArmClangCortexA53Cflags}",
Colin Crossb98c8b02016-07-29 13:44:28 -0700266 "krait": "${config.ArmClangKraitCflags}",
Alex Naidisae4fc182016-08-20 00:14:56 +0200267 "kryo": "${config.ArmClangKryoCflags}",
Junmo Park8ea49592017-07-24 07:14:55 +0900268 "exynos-m1": "${config.ArmClangCortexA53Cflags}",
Junmo Parkd86c9022017-07-21 09:07:47 +0900269 "exynos-m2": "${config.ArmClangCortexA53Cflags}",
Colin Crossb98c8b02016-07-29 13:44:28 -0700270 "denver": "${config.ArmClangCortexA15Cflags}",
Colin Cross3f40fa42015-01-30 17:27:36 -0800271 }
272)
273
274type toolchainArm struct {
275 toolchain32Bit
Colin Crossc4bde762015-11-23 16:11:30 -0800276 ldflags string
277 toolchainCflags, toolchainClangCflags string
Colin Cross3f40fa42015-01-30 17:27:36 -0800278}
279
Dan Albertbe961682015-03-18 23:38:50 -0700280func (t *toolchainArm) Name() string {
281 return "arm"
282}
283
Colin Cross3f40fa42015-01-30 17:27:36 -0800284func (t *toolchainArm) GccRoot() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700285 return "${config.ArmGccRoot}"
Colin Cross3f40fa42015-01-30 17:27:36 -0800286}
287
288func (t *toolchainArm) GccTriple() string {
Dan Albert84f431f2016-07-20 14:44:26 -0700289 return "arm-linux-androideabi"
Colin Cross3f40fa42015-01-30 17:27:36 -0800290}
291
Dan Albertbe961682015-03-18 23:38:50 -0700292func (t *toolchainArm) GccVersion() string {
Dan Willemsen34fc3b12015-12-07 12:30:44 -0800293 return armGccVersion
Dan Albertbe961682015-03-18 23:38:50 -0700294}
295
Colin Crossc4bde762015-11-23 16:11:30 -0800296func (t *toolchainArm) ToolchainCflags() string {
297 return t.toolchainCflags
298}
299
Colin Cross3f40fa42015-01-30 17:27:36 -0800300func (t *toolchainArm) Cflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700301 return "${config.ArmCflags}"
Colin Cross3f40fa42015-01-30 17:27:36 -0800302}
303
304func (t *toolchainArm) Cppflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700305 return "${config.ArmCppflags}"
Colin Cross3f40fa42015-01-30 17:27:36 -0800306}
307
308func (t *toolchainArm) Ldflags() string {
309 return t.ldflags
310}
311
312func (t *toolchainArm) IncludeFlags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700313 return "${config.ArmIncludeFlags}"
Colin Cross3f40fa42015-01-30 17:27:36 -0800314}
315
Tim Kilbourn1a9bf262015-03-18 12:28:32 -0700316func (t *toolchainArm) InstructionSetFlags(isa string) (string, error) {
317 switch isa {
318 case "arm":
Colin Crossb98c8b02016-07-29 13:44:28 -0700319 return "${config.ArmArmCflags}", nil
Tim Kilbourn1a9bf262015-03-18 12:28:32 -0700320 case "thumb", "":
Colin Crossb98c8b02016-07-29 13:44:28 -0700321 return "${config.ArmThumbCflags}", nil
Tim Kilbourn1a9bf262015-03-18 12:28:32 -0700322 default:
323 return t.toolchainBase.InstructionSetFlags(isa)
324 }
325}
326
Colin Cross3f40fa42015-01-30 17:27:36 -0800327func (t *toolchainArm) ClangTriple() string {
Chih-Hung Hsieh1e7d1bf2018-03-15 18:44:57 -0700328 // http://b/72619014 work around llvm LTO bug.
329 return "armv7a-linux-androideabi"
330}
331
332func (t *toolchainArm) ndkTriple() string {
333 // Use current NDK include path, while ClangTriple is changed.
Dan Albert84f431f2016-07-20 14:44:26 -0700334 return t.GccTriple()
Colin Cross3f40fa42015-01-30 17:27:36 -0800335}
336
Colin Crossc4bde762015-11-23 16:11:30 -0800337func (t *toolchainArm) ToolchainClangCflags() string {
338 return t.toolchainClangCflags
339}
340
Colin Cross3f40fa42015-01-30 17:27:36 -0800341func (t *toolchainArm) ClangCflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700342 return "${config.ArmClangCflags}"
Colin Cross3f40fa42015-01-30 17:27:36 -0800343}
344
345func (t *toolchainArm) ClangCppflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700346 return "${config.ArmClangCppflags}"
Colin Cross3f40fa42015-01-30 17:27:36 -0800347}
348
349func (t *toolchainArm) ClangLdflags() string {
350 return t.ldflags
351}
352
Dan Willemsen6d11dd82015-11-03 14:27:00 -0800353func (t *toolchainArm) ClangInstructionSetFlags(isa string) (string, error) {
354 switch isa {
355 case "arm":
Colin Crossb98c8b02016-07-29 13:44:28 -0700356 return "${config.ArmClangArmCflags}", nil
Dan Willemsen6d11dd82015-11-03 14:27:00 -0800357 case "thumb", "":
Colin Crossb98c8b02016-07-29 13:44:28 -0700358 return "${config.ArmClangThumbCflags}", nil
Dan Willemsen6d11dd82015-11-03 14:27:00 -0800359 default:
360 return t.toolchainBase.ClangInstructionSetFlags(isa)
361 }
362}
363
Evgenii Stepanovaf36db12016-08-15 14:18:24 -0700364func (toolchainArm) SanitizerRuntimeLibraryArch() string {
365 return "arm"
Colin Cross16b23492016-01-06 14:41:07 -0800366}
367
Colin Cross635c3b02016-05-18 15:37:25 -0700368func armToolchainFactory(arch android.Arch) Toolchain {
Colin Crossc1e814d2015-04-28 13:15:59 -0700369 var fixCortexA8 string
Dan Willemsen110a89d2016-01-14 15:17:19 -0800370 toolchainCflags := make([]string, 2, 3)
371 toolchainClangCflags := make([]string, 2, 3)
372
Colin Crossb98c8b02016-07-29 13:44:28 -0700373 toolchainCflags[0] = "${config.ArmToolchainCflags}"
Dan Willemsen110a89d2016-01-14 15:17:19 -0800374 toolchainCflags[1] = armArchVariantCflagsVar[arch.ArchVariant]
Colin Crossb98c8b02016-07-29 13:44:28 -0700375 toolchainClangCflags[0] = "${config.ArmToolchainClangCflags}"
Dan Willemsen110a89d2016-01-14 15:17:19 -0800376 toolchainClangCflags[1] = armClangArchVariantCflagsVar[arch.ArchVariant]
377
Isaac Chena2a58242017-08-23 10:57:17 +0000378 toolchainCflags = append(toolchainCflags,
379 variantOrDefault(armCpuVariantCflagsVar, arch.CpuVariant))
380 toolchainClangCflags = append(toolchainClangCflags,
381 variantOrDefault(armClangCpuVariantCflagsVar, arch.CpuVariant))
382
Dan Willemsen110a89d2016-01-14 15:17:19 -0800383 switch arch.ArchVariant {
384 case "armv7-a-neon":
385 switch arch.CpuVariant {
386 case "cortex-a8", "":
387 // Generic ARM might be a Cortex A8 -- better safe than sorry
388 fixCortexA8 = "-Wl,--fix-cortex-a8"
389 default:
390 fixCortexA8 = "-Wl,--no-fix-cortex-a8"
391 }
Dan Willemsen110a89d2016-01-14 15:17:19 -0800392 case "armv7-a":
Colin Crossc1e814d2015-04-28 13:15:59 -0700393 fixCortexA8 = "-Wl,--fix-cortex-a8"
Isaac Chena2a58242017-08-23 10:57:17 +0000394 case "armv8-a":
395 // Nothing extra for armv8-a
Colin Crossc1e814d2015-04-28 13:15:59 -0700396 default:
Dan Willemsen110a89d2016-01-14 15:17:19 -0800397 panic(fmt.Sprintf("Unknown ARM architecture version: %q", arch.ArchVariant))
Colin Crossc1e814d2015-04-28 13:15:59 -0700398 }
399
Colin Cross3f40fa42015-01-30 17:27:36 -0800400 return &toolchainArm{
Dan Willemsen110a89d2016-01-14 15:17:19 -0800401 toolchainCflags: strings.Join(toolchainCflags, " "),
Colin Cross3f40fa42015-01-30 17:27:36 -0800402 ldflags: strings.Join([]string{
Colin Crossb98c8b02016-07-29 13:44:28 -0700403 "${config.ArmLdflags}",
Colin Crossc1e814d2015-04-28 13:15:59 -0700404 fixCortexA8,
Colin Cross3f40fa42015-01-30 17:27:36 -0800405 }, " "),
Dan Willemsen110a89d2016-01-14 15:17:19 -0800406 toolchainClangCflags: strings.Join(toolchainClangCflags, " "),
Colin Cross3f40fa42015-01-30 17:27:36 -0800407 }
408}
409
410func init() {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700411 registerToolchainFactory(android.Android, android.Arm, armToolchainFactory)
Colin Cross3f40fa42015-01-30 17:27:36 -0800412}