blob: 6703969711c140532ba66925ef306f04e05e6467 [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{
Colin Cross3f40fa42015-01-30 17:27:36 -080031 "-fdata-sections",
Colin Cross3f40fa42015-01-30 17:27:36 -080032 "-fno-short-enums",
Colin Cross3f40fa42015-01-30 17:27:36 -080033
34 "-fno-builtin-sin",
35 "-fno-strict-volatile-bitfields",
36
37 // TARGET_RELEASE_CFLAGS
Colin Cross3f40fa42015-01-30 17:27:36 -080038 "-fgcse-after-reload",
39 "-frerun-cse-after-loop",
40 "-frename-registers",
Colin Cross0f1f6792017-11-02 23:10:13 -070041
42 "-fomit-frame-pointer",
Colin Cross3f40fa42015-01-30 17:27:36 -080043 }
44
45 armCppflags = []string{
46 "-fvisibility-inlines-hidden",
47 }
48
49 armLdflags = []string{
Colin Cross13af54d2015-03-16 16:12:05 -070050 "-Wl,--icf=safe",
Colin Cross3f40fa42015-01-30 17:27:36 -080051 "-Wl,--hash-style=gnu",
Stephen Craneb3c21542017-06-26 19:22:02 -070052 "-Wl,-m,armelf",
Colin Cross3f40fa42015-01-30 17:27:36 -080053 }
54
55 armArmCflags = []string{
Colin Cross3f40fa42015-01-30 17:27:36 -080056 "-fstrict-aliasing",
57 "-funswitch-loops",
58 }
59
60 armThumbCflags = []string{
61 "-mthumb",
62 "-Os",
Colin Cross3f40fa42015-01-30 17:27:36 -080063 }
64
65 armArchVariantCflags = map[string][]string{
66 "armv5te": []string{
67 "-march=armv5te",
68 "-mtune=xscale",
69 "-D__ARM_ARCH_5__",
70 "-D__ARM_ARCH_5T__",
71 "-D__ARM_ARCH_5E__",
72 "-D__ARM_ARCH_5TE__",
73 },
74 "armv7-a": []string{
75 "-march=armv7-a",
76 "-mfloat-abi=softfp",
77 "-mfpu=vfpv3-d16",
78 },
79 "armv7-a-neon": []string{
Isaac Chen2bce8ed2017-10-05 18:28:57 +080080 "-march=armv7-a",
Colin Cross3f40fa42015-01-30 17:27:36 -080081 "-mfloat-abi=softfp",
82 "-mfpu=neon",
83 },
Isaac Chena2a58242017-08-23 10:57:17 +000084 "armv8-a": []string{
85 "-march=armv8-a",
86 "-mfloat-abi=softfp",
87 "-mfpu=neon-fp-armv8",
88 },
Colin Cross3f40fa42015-01-30 17:27:36 -080089 }
90
Colin Cross3f40fa42015-01-30 17:27:36 -080091 armCpuVariantCflags = map[string][]string{
92 "cortex-a7": []string{
93 "-mcpu=cortex-a7",
Jake Weinstein5cfd7092017-04-06 22:25:34 -040094 "-mfpu=neon-vfpv4",
Dan Willemsen8e1e3fb2016-03-29 15:47:08 -070095 // Fake an ARM compiler flag as these processors support LPAE which GCC/clang
96 // don't advertise.
97 // TODO This is a hack and we need to add it for each processor that supports LPAE until some
98 // better solution comes around. See Bug 27340895
99 "-D__ARM_FEATURE_LPAE=1",
Colin Cross3f40fa42015-01-30 17:27:36 -0800100 },
101 "cortex-a8": []string{
102 "-mcpu=cortex-a8",
103 },
104 "cortex-a15": []string{
105 "-mcpu=cortex-a15",
Jake Weinstein59166572017-04-06 20:47:23 -0400106 "-mfpu=neon-vfpv4",
Colin Cross3f40fa42015-01-30 17:27:36 -0800107 // Fake an ARM compiler flag as these processors support LPAE which GCC/clang
108 // don't advertise.
Dan Willemsen8e1e3fb2016-03-29 15:47:08 -0700109 // TODO This is a hack and we need to add it for each processor that supports LPAE until some
110 // better solution comes around. See Bug 27340895
Colin Cross3f40fa42015-01-30 17:27:36 -0800111 "-D__ARM_FEATURE_LPAE=1",
112 },
Christopher Ferris6df46f52017-05-08 12:08:40 -0700113 "cortex-a53": []string{
114 "-mcpu=cortex-a53",
115 "-mfpu=neon-fp-armv8",
116 // Fake an ARM compiler flag as these processors support LPAE which GCC/clang
117 // don't advertise.
118 // TODO This is a hack and we need to add it for each processor that supports LPAE until some
119 // better solution comes around. See Bug 27340895
120 "-D__ARM_FEATURE_LPAE=1",
121 },
Dan Willemsened89a7a2016-05-09 13:39:58 -0700122 "krait": []string{
123 "-mcpu=cortex-a15",
Jake Weinsteinfff256f2017-04-06 20:38:26 -0400124 "-mfpu=neon-vfpv4",
Dan Willemsened89a7a2016-05-09 13:39:58 -0700125 // Fake an ARM compiler flag as these processors support LPAE which GCC/clang
126 // don't advertise.
127 // TODO This is a hack and we need to add it for each processor that supports LPAE until some
128 // better solution comes around. See Bug 27340895
129 "-D__ARM_FEATURE_LPAE=1",
130 },
Alex Naidisae4fc182016-08-20 00:14:56 +0200131 "kryo": []string{
132 "-mcpu=cortex-a15",
Jake Weinstein1783a2f2017-04-06 20:28:05 -0400133 "-mfpu=neon-fp-armv8",
Alex Naidisae4fc182016-08-20 00:14:56 +0200134 // Fake an ARM compiler flag as these processors support LPAE which GCC/clang
135 // don't advertise.
136 // TODO This is a hack and we need to add it for each processor that supports LPAE until some
137 // better solution comes around. See Bug 27340895
138 "-D__ARM_FEATURE_LPAE=1",
139 },
Colin Cross3f40fa42015-01-30 17:27:36 -0800140 }
141
Dan Willemsenf5a959c2015-07-13 13:28:18 -0700142 armClangCpuVariantCflags = copyVariantFlags(armCpuVariantCflags)
143 armClangArchVariantCflags = copyVariantFlags(armArchVariantCflags)
Colin Cross3f40fa42015-01-30 17:27:36 -0800144)
145
Dan Willemsen34fc3b12015-12-07 12:30:44 -0800146const (
147 armGccVersion = "4.9"
148)
149
Colin Cross3f40fa42015-01-30 17:27:36 -0800150func init() {
Colin Cross0906f172017-04-26 14:00:43 -0700151 android.RegisterArchFeatures(android.Arm,
152 "neon")
153
Dan Willemsenb1957a52016-06-23 23:44:54 -0700154 android.RegisterArchVariants(android.Arm,
155 "armv5te",
Colin Cross0906f172017-04-26 14:00:43 -0700156 "armv7-a",
157 "armv7-a-neon",
Isaac Chena2a58242017-08-23 10:57:17 +0000158 "armv8-a",
Colin Cross0906f172017-04-26 14:00:43 -0700159 "cortex-a7",
160 "cortex-a8",
161 "cortex-a9",
162 "cortex-a15",
163 "cortex-a53",
164 "cortex-a53-a57",
Christopher Ferris6df46f52017-05-08 12:08:40 -0700165 "cortex-a73",
Dan Willemsenb1957a52016-06-23 23:44:54 -0700166 "krait",
Alex Naidisae4fc182016-08-20 00:14:56 +0200167 "kryo",
Junmo Park8ea49592017-07-24 07:14:55 +0900168 "exynos-m1",
Junmo Parkd86c9022017-07-21 09:07:47 +0900169 "exynos-m2",
Dan Willemsenb1957a52016-06-23 23:44:54 -0700170 "denver")
171
Colin Cross0906f172017-04-26 14:00:43 -0700172 android.RegisterArchVariantFeatures(android.Arm, "armv7-a-neon", "neon")
Isaac Chena2a58242017-08-23 10:57:17 +0000173 android.RegisterArchVariantFeatures(android.Arm, "armv8-a", "neon")
Colin Cross0906f172017-04-26 14:00:43 -0700174
Jake Weinsteinfff256f2017-04-06 20:38:26 -0400175 // Krait and Kryo targets are not supported by GCC, but are supported by Clang,
176 // so override the definitions when building modules with Clang.
Dan Willemsened89a7a2016-05-09 13:39:58 -0700177 replaceFirst(armClangCpuVariantCflags["krait"], "-mcpu=cortex-a15", "-mcpu=krait")
Alex Naidisae4fc182016-08-20 00:14:56 +0200178 replaceFirst(armClangCpuVariantCflags["kryo"], "-mcpu=cortex-a15", "-mcpu=krait")
Alex Naidisae4fc182016-08-20 00:14:56 +0200179
Isaac Chena2a58242017-08-23 10:57:17 +0000180 // The reason we use "-march=armv8-a+crc", instead of "-march=armv8-a", for
181 // gcc is the latter would conflict with any specified/supported -mcpu!
182 // All armv8-a cores supported by gcc 4.9 support crc, so it's safe
183 // to add +crc. Besides, the use of gcc is only for legacy code.
184 replaceFirst(armArchVariantCflags["armv8-a"], "-march=armv8-a", "-march=armv8-a+crc")
185
Dan Willemsen34fc3b12015-12-07 12:30:44 -0800186 pctx.StaticVariable("armGccVersion", armGccVersion)
Colin Cross3f40fa42015-01-30 17:27:36 -0800187
Colin Crossb98c8b02016-07-29 13:44:28 -0700188 pctx.SourcePathVariable("ArmGccRoot",
Dan Willemsen87b17d12015-07-14 00:39:06 -0700189 "prebuilts/gcc/${HostPrebuiltTag}/arm/arm-linux-androideabi-${armGccVersion}")
Colin Cross3f40fa42015-01-30 17:27:36 -0800190
Colin Crossb98c8b02016-07-29 13:44:28 -0700191 pctx.StaticVariable("ArmToolchainCflags", strings.Join(armToolchainCflags, " "))
192 pctx.StaticVariable("ArmCflags", strings.Join(armCflags, " "))
193 pctx.StaticVariable("ArmLdflags", strings.Join(armLdflags, " "))
194 pctx.StaticVariable("ArmCppflags", strings.Join(armCppflags, " "))
Elliott Hughesde28deb2017-10-12 09:07:53 -0700195 pctx.StaticVariable("ArmIncludeFlags", bionicHeaders("arm"))
Colin Cross3f40fa42015-01-30 17:27:36 -0800196
197 // Extended cflags
198
Tim Kilbourn1a9bf262015-03-18 12:28:32 -0700199 // ARM vs. Thumb instruction set flags
Colin Crossb98c8b02016-07-29 13:44:28 -0700200 pctx.StaticVariable("ArmArmCflags", strings.Join(armArmCflags, " "))
201 pctx.StaticVariable("ArmThumbCflags", strings.Join(armThumbCflags, " "))
Colin Cross3f40fa42015-01-30 17:27:36 -0800202
203 // Architecture variant cflags
Colin Crossb98c8b02016-07-29 13:44:28 -0700204 pctx.StaticVariable("ArmArmv5TECflags", strings.Join(armArchVariantCflags["armv5te"], " "))
205 pctx.StaticVariable("ArmArmv7ACflags", strings.Join(armArchVariantCflags["armv7-a"], " "))
206 pctx.StaticVariable("ArmArmv7ANeonCflags", strings.Join(armArchVariantCflags["armv7-a-neon"], " "))
Isaac Chena2a58242017-08-23 10:57:17 +0000207 pctx.StaticVariable("ArmArmv8ACflags", strings.Join(armArchVariantCflags["armv8-a"], " "))
Colin Cross3f40fa42015-01-30 17:27:36 -0800208
Colin Cross3f40fa42015-01-30 17:27:36 -0800209 // Cpu variant cflags
Colin Crossb98c8b02016-07-29 13:44:28 -0700210 pctx.StaticVariable("ArmGenericCflags", strings.Join(armCpuVariantCflags[""], " "))
211 pctx.StaticVariable("ArmCortexA7Cflags", strings.Join(armCpuVariantCflags["cortex-a7"], " "))
212 pctx.StaticVariable("ArmCortexA8Cflags", strings.Join(armCpuVariantCflags["cortex-a8"], " "))
213 pctx.StaticVariable("ArmCortexA15Cflags", strings.Join(armCpuVariantCflags["cortex-a15"], " "))
Christopher Ferris6df46f52017-05-08 12:08:40 -0700214 pctx.StaticVariable("ArmCortexA53Cflags", strings.Join(armCpuVariantCflags["cortex-a53"], " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700215 pctx.StaticVariable("ArmKraitCflags", strings.Join(armCpuVariantCflags["krait"], " "))
Alex Naidisae4fc182016-08-20 00:14:56 +0200216 pctx.StaticVariable("ArmKryoCflags", strings.Join(armCpuVariantCflags["kryo"], " "))
Colin Cross3f40fa42015-01-30 17:27:36 -0800217
218 // Clang cflags
Colin Crossb98c8b02016-07-29 13:44:28 -0700219 pctx.StaticVariable("ArmToolchainClangCflags", strings.Join(ClangFilterUnknownCflags(armToolchainCflags), " "))
220 pctx.StaticVariable("ArmClangCflags", strings.Join(ClangFilterUnknownCflags(armCflags), " "))
221 pctx.StaticVariable("ArmClangLdflags", strings.Join(ClangFilterUnknownCflags(armLdflags), " "))
222 pctx.StaticVariable("ArmClangCppflags", strings.Join(ClangFilterUnknownCflags(armCppflags), " "))
Colin Cross3f40fa42015-01-30 17:27:36 -0800223
Dan Willemsen6d11dd82015-11-03 14:27:00 -0800224 // Clang ARM vs. Thumb instruction set cflags
Colin Crossb98c8b02016-07-29 13:44:28 -0700225 pctx.StaticVariable("ArmClangArmCflags", strings.Join(ClangFilterUnknownCflags(armArmCflags), " "))
226 pctx.StaticVariable("ArmClangThumbCflags", strings.Join(ClangFilterUnknownCflags(armThumbCflags), " "))
Dan Willemsen6d11dd82015-11-03 14:27:00 -0800227
Dan Willemsen110a89d2016-01-14 15:17:19 -0800228 // Clang arch variant cflags
Colin Crossb98c8b02016-07-29 13:44:28 -0700229 pctx.StaticVariable("ArmClangArmv5TECflags",
Colin Cross3f40fa42015-01-30 17:27:36 -0800230 strings.Join(armClangArchVariantCflags["armv5te"], " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700231 pctx.StaticVariable("ArmClangArmv7ACflags",
Colin Cross3f40fa42015-01-30 17:27:36 -0800232 strings.Join(armClangArchVariantCflags["armv7-a"], " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700233 pctx.StaticVariable("ArmClangArmv7ANeonCflags",
Colin Cross3f40fa42015-01-30 17:27:36 -0800234 strings.Join(armClangArchVariantCflags["armv7-a-neon"], " "))
Isaac Chena2a58242017-08-23 10:57:17 +0000235 pctx.StaticVariable("ArmClangArmv8ACflags",
236 strings.Join(armClangArchVariantCflags["armv8-a"], " "))
Colin Cross3f40fa42015-01-30 17:27:36 -0800237
238 // Clang cpu variant cflags
Colin Crossb98c8b02016-07-29 13:44:28 -0700239 pctx.StaticVariable("ArmClangGenericCflags",
Dan Willemsen110a89d2016-01-14 15:17:19 -0800240 strings.Join(armClangCpuVariantCflags[""], " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700241 pctx.StaticVariable("ArmClangCortexA7Cflags",
Colin Cross3f40fa42015-01-30 17:27:36 -0800242 strings.Join(armClangCpuVariantCflags["cortex-a7"], " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700243 pctx.StaticVariable("ArmClangCortexA8Cflags",
Colin Cross3f40fa42015-01-30 17:27:36 -0800244 strings.Join(armClangCpuVariantCflags["cortex-a8"], " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700245 pctx.StaticVariable("ArmClangCortexA15Cflags",
Colin Cross3f40fa42015-01-30 17:27:36 -0800246 strings.Join(armClangCpuVariantCflags["cortex-a15"], " "))
Christopher Ferris6df46f52017-05-08 12:08:40 -0700247 pctx.StaticVariable("ArmClangCortexA53Cflags",
248 strings.Join(armClangCpuVariantCflags["cortex-a53"], " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700249 pctx.StaticVariable("ArmClangKraitCflags",
Colin Cross3f40fa42015-01-30 17:27:36 -0800250 strings.Join(armClangCpuVariantCflags["krait"], " "))
Alex Naidisae4fc182016-08-20 00:14:56 +0200251 pctx.StaticVariable("ArmClangKryoCflags",
252 strings.Join(armClangCpuVariantCflags["kryo"], " "))
Colin Cross3f40fa42015-01-30 17:27:36 -0800253}
254
255var (
256 armArchVariantCflagsVar = map[string]string{
Colin Crossb98c8b02016-07-29 13:44:28 -0700257 "armv5te": "${config.ArmArmv5TECflags}",
258 "armv7-a": "${config.ArmArmv7ACflags}",
259 "armv7-a-neon": "${config.ArmArmv7ANeonCflags}",
Isaac Chena2a58242017-08-23 10:57:17 +0000260 "armv8-a": "${config.ArmArmv8ACflags}",
Colin Cross3f40fa42015-01-30 17:27:36 -0800261 }
262
Colin Cross3f40fa42015-01-30 17:27:36 -0800263 armCpuVariantCflagsVar = map[string]string{
Colin Crossb98c8b02016-07-29 13:44:28 -0700264 "": "${config.ArmGenericCflags}",
265 "cortex-a7": "${config.ArmCortexA7Cflags}",
266 "cortex-a8": "${config.ArmCortexA8Cflags}",
267 "cortex-a15": "${config.ArmCortexA15Cflags}",
Christopher Ferris6df46f52017-05-08 12:08:40 -0700268 "cortex-a53": "${config.ArmCortexA53Cflags}",
269 "cortex-a53.a57": "${config.ArmCortexA53Cflags}",
270 "cortex-a73": "${config.ArmCortexA53Cflags}",
Colin Crossb98c8b02016-07-29 13:44:28 -0700271 "krait": "${config.ArmKraitCflags}",
Alex Naidisae4fc182016-08-20 00:14:56 +0200272 "kryo": "${config.ArmKryoCflags}",
Junmo Park8ea49592017-07-24 07:14:55 +0900273 "exynos-m1": "${config.ArmCortexA53Cflags}",
Junmo Parkd86c9022017-07-21 09:07:47 +0900274 "exynos-m2": "${config.ArmCortexA53Cflags}",
Colin Crossb98c8b02016-07-29 13:44:28 -0700275 "denver": "${config.ArmCortexA15Cflags}",
Colin Cross3f40fa42015-01-30 17:27:36 -0800276 }
277
278 armClangArchVariantCflagsVar = map[string]string{
Colin Crossb98c8b02016-07-29 13:44:28 -0700279 "armv5te": "${config.ArmClangArmv5TECflags}",
280 "armv7-a": "${config.ArmClangArmv7ACflags}",
281 "armv7-a-neon": "${config.ArmClangArmv7ANeonCflags}",
Isaac Chena2a58242017-08-23 10:57:17 +0000282 "armv8-a": "${config.ArmClangArmv8ACflags}",
Colin Cross3f40fa42015-01-30 17:27:36 -0800283 }
284
285 armClangCpuVariantCflagsVar = map[string]string{
Colin Crossb98c8b02016-07-29 13:44:28 -0700286 "": "${config.ArmClangGenericCflags}",
287 "cortex-a7": "${config.ArmClangCortexA7Cflags}",
288 "cortex-a8": "${config.ArmClangCortexA8Cflags}",
289 "cortex-a15": "${config.ArmClangCortexA15Cflags}",
Christopher Ferris6df46f52017-05-08 12:08:40 -0700290 "cortex-a53": "${config.ArmClangCortexA53Cflags}",
291 "cortex-a53.a57": "${config.ArmClangCortexA53Cflags}",
292 "cortex-a73": "${config.ArmClangCortexA53Cflags}",
Colin Crossb98c8b02016-07-29 13:44:28 -0700293 "krait": "${config.ArmClangKraitCflags}",
Alex Naidisae4fc182016-08-20 00:14:56 +0200294 "kryo": "${config.ArmClangKryoCflags}",
Junmo Park8ea49592017-07-24 07:14:55 +0900295 "exynos-m1": "${config.ArmClangCortexA53Cflags}",
Junmo Parkd86c9022017-07-21 09:07:47 +0900296 "exynos-m2": "${config.ArmClangCortexA53Cflags}",
Colin Crossb98c8b02016-07-29 13:44:28 -0700297 "denver": "${config.ArmClangCortexA15Cflags}",
Colin Cross3f40fa42015-01-30 17:27:36 -0800298 }
299)
300
301type toolchainArm struct {
302 toolchain32Bit
Colin Crossc4bde762015-11-23 16:11:30 -0800303 ldflags string
304 toolchainCflags, toolchainClangCflags string
Colin Cross3f40fa42015-01-30 17:27:36 -0800305}
306
Dan Albertbe961682015-03-18 23:38:50 -0700307func (t *toolchainArm) Name() string {
308 return "arm"
309}
310
Colin Cross3f40fa42015-01-30 17:27:36 -0800311func (t *toolchainArm) GccRoot() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700312 return "${config.ArmGccRoot}"
Colin Cross3f40fa42015-01-30 17:27:36 -0800313}
314
315func (t *toolchainArm) GccTriple() string {
Dan Albert84f431f2016-07-20 14:44:26 -0700316 return "arm-linux-androideabi"
Colin Cross3f40fa42015-01-30 17:27:36 -0800317}
318
Dan Albertbe961682015-03-18 23:38:50 -0700319func (t *toolchainArm) GccVersion() string {
Dan Willemsen34fc3b12015-12-07 12:30:44 -0800320 return armGccVersion
Dan Albertbe961682015-03-18 23:38:50 -0700321}
322
Colin Crossc4bde762015-11-23 16:11:30 -0800323func (t *toolchainArm) ToolchainCflags() string {
324 return t.toolchainCflags
325}
326
Colin Cross3f40fa42015-01-30 17:27:36 -0800327func (t *toolchainArm) Cflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700328 return "${config.ArmCflags}"
Colin Cross3f40fa42015-01-30 17:27:36 -0800329}
330
331func (t *toolchainArm) Cppflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700332 return "${config.ArmCppflags}"
Colin Cross3f40fa42015-01-30 17:27:36 -0800333}
334
335func (t *toolchainArm) Ldflags() string {
336 return t.ldflags
337}
338
339func (t *toolchainArm) IncludeFlags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700340 return "${config.ArmIncludeFlags}"
Colin Cross3f40fa42015-01-30 17:27:36 -0800341}
342
Tim Kilbourn1a9bf262015-03-18 12:28:32 -0700343func (t *toolchainArm) InstructionSetFlags(isa string) (string, error) {
344 switch isa {
345 case "arm":
Colin Crossb98c8b02016-07-29 13:44:28 -0700346 return "${config.ArmArmCflags}", nil
Tim Kilbourn1a9bf262015-03-18 12:28:32 -0700347 case "thumb", "":
Colin Crossb98c8b02016-07-29 13:44:28 -0700348 return "${config.ArmThumbCflags}", nil
Tim Kilbourn1a9bf262015-03-18 12:28:32 -0700349 default:
350 return t.toolchainBase.InstructionSetFlags(isa)
351 }
352}
353
Colin Cross3f40fa42015-01-30 17:27:36 -0800354func (t *toolchainArm) ClangTriple() string {
Dan Albert84f431f2016-07-20 14:44:26 -0700355 return t.GccTriple()
Colin Cross3f40fa42015-01-30 17:27:36 -0800356}
357
Colin Crossc4bde762015-11-23 16:11:30 -0800358func (t *toolchainArm) ToolchainClangCflags() string {
359 return t.toolchainClangCflags
360}
361
Colin Cross3f40fa42015-01-30 17:27:36 -0800362func (t *toolchainArm) ClangCflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700363 return "${config.ArmClangCflags}"
Colin Cross3f40fa42015-01-30 17:27:36 -0800364}
365
366func (t *toolchainArm) ClangCppflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700367 return "${config.ArmClangCppflags}"
Colin Cross3f40fa42015-01-30 17:27:36 -0800368}
369
370func (t *toolchainArm) ClangLdflags() string {
371 return t.ldflags
372}
373
Dan Willemsen6d11dd82015-11-03 14:27:00 -0800374func (t *toolchainArm) ClangInstructionSetFlags(isa string) (string, error) {
375 switch isa {
376 case "arm":
Colin Crossb98c8b02016-07-29 13:44:28 -0700377 return "${config.ArmClangArmCflags}", nil
Dan Willemsen6d11dd82015-11-03 14:27:00 -0800378 case "thumb", "":
Colin Crossb98c8b02016-07-29 13:44:28 -0700379 return "${config.ArmClangThumbCflags}", nil
Dan Willemsen6d11dd82015-11-03 14:27:00 -0800380 default:
381 return t.toolchainBase.ClangInstructionSetFlags(isa)
382 }
383}
384
Evgenii Stepanovaf36db12016-08-15 14:18:24 -0700385func (toolchainArm) SanitizerRuntimeLibraryArch() string {
386 return "arm"
Colin Cross16b23492016-01-06 14:41:07 -0800387}
388
Colin Cross635c3b02016-05-18 15:37:25 -0700389func armToolchainFactory(arch android.Arch) Toolchain {
Colin Crossc1e814d2015-04-28 13:15:59 -0700390 var fixCortexA8 string
Dan Willemsen110a89d2016-01-14 15:17:19 -0800391 toolchainCflags := make([]string, 2, 3)
392 toolchainClangCflags := make([]string, 2, 3)
393
Colin Crossb98c8b02016-07-29 13:44:28 -0700394 toolchainCflags[0] = "${config.ArmToolchainCflags}"
Dan Willemsen110a89d2016-01-14 15:17:19 -0800395 toolchainCflags[1] = armArchVariantCflagsVar[arch.ArchVariant]
Colin Crossb98c8b02016-07-29 13:44:28 -0700396 toolchainClangCflags[0] = "${config.ArmToolchainClangCflags}"
Dan Willemsen110a89d2016-01-14 15:17:19 -0800397 toolchainClangCflags[1] = armClangArchVariantCflagsVar[arch.ArchVariant]
398
Isaac Chena2a58242017-08-23 10:57:17 +0000399 toolchainCflags = append(toolchainCflags,
400 variantOrDefault(armCpuVariantCflagsVar, arch.CpuVariant))
401 toolchainClangCflags = append(toolchainClangCflags,
402 variantOrDefault(armClangCpuVariantCflagsVar, arch.CpuVariant))
403
Dan Willemsen110a89d2016-01-14 15:17:19 -0800404 switch arch.ArchVariant {
405 case "armv7-a-neon":
406 switch arch.CpuVariant {
407 case "cortex-a8", "":
408 // Generic ARM might be a Cortex A8 -- better safe than sorry
409 fixCortexA8 = "-Wl,--fix-cortex-a8"
410 default:
411 fixCortexA8 = "-Wl,--no-fix-cortex-a8"
412 }
Dan Willemsen110a89d2016-01-14 15:17:19 -0800413 case "armv7-a":
Colin Crossc1e814d2015-04-28 13:15:59 -0700414 fixCortexA8 = "-Wl,--fix-cortex-a8"
Dan Willemsen110a89d2016-01-14 15:17:19 -0800415 case "armv5te":
416 // Nothing extra for armv5te
Isaac Chena2a58242017-08-23 10:57:17 +0000417 case "armv8-a":
418 // Nothing extra for armv8-a
Colin Crossc1e814d2015-04-28 13:15:59 -0700419 default:
Dan Willemsen110a89d2016-01-14 15:17:19 -0800420 panic(fmt.Sprintf("Unknown ARM architecture version: %q", arch.ArchVariant))
Colin Crossc1e814d2015-04-28 13:15:59 -0700421 }
422
Colin Cross3f40fa42015-01-30 17:27:36 -0800423 return &toolchainArm{
Dan Willemsen110a89d2016-01-14 15:17:19 -0800424 toolchainCflags: strings.Join(toolchainCflags, " "),
Colin Cross3f40fa42015-01-30 17:27:36 -0800425 ldflags: strings.Join([]string{
Colin Crossb98c8b02016-07-29 13:44:28 -0700426 "${config.ArmLdflags}",
Colin Crossc1e814d2015-04-28 13:15:59 -0700427 fixCortexA8,
Colin Cross3f40fa42015-01-30 17:27:36 -0800428 }, " "),
Dan Willemsen110a89d2016-01-14 15:17:19 -0800429 toolchainClangCflags: strings.Join(toolchainClangCflags, " "),
Colin Cross3f40fa42015-01-30 17:27:36 -0800430 }
431}
432
433func init() {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700434 registerToolchainFactory(android.Android, android.Arm, armToolchainFactory)
Colin Cross3f40fa42015-01-30 17:27:36 -0800435}