blob: f093563fbc45c2505fd16311f35fdf2d9a2536b1 [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",
Stephen Craneb3c21542017-06-26 19:22:02 -070070 "-Wl,-m,armelf",
Colin Cross3f40fa42015-01-30 17:27:36 -080071 }
72
73 armArmCflags = []string{
74 "-O2",
75 "-fomit-frame-pointer",
76 "-fstrict-aliasing",
77 "-funswitch-loops",
78 }
79
80 armThumbCflags = []string{
81 "-mthumb",
82 "-Os",
83 "-fomit-frame-pointer",
84 "-fno-strict-aliasing",
85 }
86
87 armArchVariantCflags = map[string][]string{
88 "armv5te": []string{
89 "-march=armv5te",
90 "-mtune=xscale",
91 "-D__ARM_ARCH_5__",
92 "-D__ARM_ARCH_5T__",
93 "-D__ARM_ARCH_5E__",
94 "-D__ARM_ARCH_5TE__",
95 },
96 "armv7-a": []string{
97 "-march=armv7-a",
98 "-mfloat-abi=softfp",
99 "-mfpu=vfpv3-d16",
100 },
101 "armv7-a-neon": []string{
102 "-mfloat-abi=softfp",
103 "-mfpu=neon",
104 },
Isaac Chena2a58242017-08-23 10:57:17 +0000105 "armv8-a": []string{
106 "-march=armv8-a",
107 "-mfloat-abi=softfp",
108 "-mfpu=neon-fp-armv8",
109 },
Colin Cross3f40fa42015-01-30 17:27:36 -0800110 }
111
Colin Cross3f40fa42015-01-30 17:27:36 -0800112 armCpuVariantCflags = map[string][]string{
Dan Willemsen110a89d2016-01-14 15:17:19 -0800113 "": []string{
114 "-march=armv7-a",
115 },
Colin Cross3f40fa42015-01-30 17:27:36 -0800116 "cortex-a7": []string{
117 "-mcpu=cortex-a7",
Jake Weinstein5cfd7092017-04-06 22:25:34 -0400118 "-mfpu=neon-vfpv4",
Dan Willemsen8e1e3fb2016-03-29 15:47:08 -0700119 // Fake an ARM compiler flag as these processors support LPAE which GCC/clang
120 // don't advertise.
121 // TODO This is a hack and we need to add it for each processor that supports LPAE until some
122 // better solution comes around. See Bug 27340895
123 "-D__ARM_FEATURE_LPAE=1",
Colin Cross3f40fa42015-01-30 17:27:36 -0800124 },
125 "cortex-a8": []string{
126 "-mcpu=cortex-a8",
127 },
128 "cortex-a15": []string{
129 "-mcpu=cortex-a15",
Jake Weinstein59166572017-04-06 20:47:23 -0400130 "-mfpu=neon-vfpv4",
Colin Cross3f40fa42015-01-30 17:27:36 -0800131 // Fake an ARM compiler flag as these processors support LPAE which GCC/clang
132 // don't advertise.
Dan Willemsen8e1e3fb2016-03-29 15:47:08 -0700133 // 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
Colin Cross3f40fa42015-01-30 17:27:36 -0800135 "-D__ARM_FEATURE_LPAE=1",
136 },
Christopher Ferris6df46f52017-05-08 12:08:40 -0700137 "cortex-a53": []string{
138 "-mcpu=cortex-a53",
139 "-mfpu=neon-fp-armv8",
140 // 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 },
Dan Willemsened89a7a2016-05-09 13:39:58 -0700146 "krait": []string{
147 "-mcpu=cortex-a15",
Jake Weinsteinfff256f2017-04-06 20:38:26 -0400148 "-mfpu=neon-vfpv4",
Dan Willemsened89a7a2016-05-09 13:39:58 -0700149 // Fake an ARM compiler flag as these processors support LPAE which GCC/clang
150 // don't advertise.
151 // TODO This is a hack and we need to add it for each processor that supports LPAE until some
152 // better solution comes around. See Bug 27340895
153 "-D__ARM_FEATURE_LPAE=1",
154 },
Alex Naidisae4fc182016-08-20 00:14:56 +0200155 "kryo": []string{
156 "-mcpu=cortex-a15",
Jake Weinstein1783a2f2017-04-06 20:28:05 -0400157 "-mfpu=neon-fp-armv8",
Alex Naidisae4fc182016-08-20 00:14:56 +0200158 // Fake an ARM compiler flag as these processors support LPAE which GCC/clang
159 // don't advertise.
160 // TODO This is a hack and we need to add it for each processor that supports LPAE until some
161 // better solution comes around. See Bug 27340895
162 "-D__ARM_FEATURE_LPAE=1",
163 },
Colin Cross3f40fa42015-01-30 17:27:36 -0800164 }
165
Dan Willemsenf5a959c2015-07-13 13:28:18 -0700166 armClangCpuVariantCflags = copyVariantFlags(armCpuVariantCflags)
167 armClangArchVariantCflags = copyVariantFlags(armArchVariantCflags)
Colin Cross3f40fa42015-01-30 17:27:36 -0800168)
169
Dan Willemsen34fc3b12015-12-07 12:30:44 -0800170const (
171 armGccVersion = "4.9"
172)
173
Colin Cross3f40fa42015-01-30 17:27:36 -0800174func init() {
Colin Cross0906f172017-04-26 14:00:43 -0700175 android.RegisterArchFeatures(android.Arm,
176 "neon")
177
Dan Willemsenb1957a52016-06-23 23:44:54 -0700178 android.RegisterArchVariants(android.Arm,
179 "armv5te",
Colin Cross0906f172017-04-26 14:00:43 -0700180 "armv7-a",
181 "armv7-a-neon",
Isaac Chena2a58242017-08-23 10:57:17 +0000182 "armv8-a",
Colin Cross0906f172017-04-26 14:00:43 -0700183 "cortex-a7",
184 "cortex-a8",
185 "cortex-a9",
186 "cortex-a15",
187 "cortex-a53",
188 "cortex-a53-a57",
Christopher Ferris6df46f52017-05-08 12:08:40 -0700189 "cortex-a73",
Dan Willemsenb1957a52016-06-23 23:44:54 -0700190 "krait",
Alex Naidisae4fc182016-08-20 00:14:56 +0200191 "kryo",
Junmo Park8ea49592017-07-24 07:14:55 +0900192 "exynos-m1",
Junmo Parkd86c9022017-07-21 09:07:47 +0900193 "exynos-m2",
Dan Willemsenb1957a52016-06-23 23:44:54 -0700194 "denver")
195
Colin Cross0906f172017-04-26 14:00:43 -0700196 android.RegisterArchVariantFeatures(android.Arm, "armv7-a-neon", "neon")
Isaac Chena2a58242017-08-23 10:57:17 +0000197 android.RegisterArchVariantFeatures(android.Arm, "armv8-a", "neon")
Colin Cross0906f172017-04-26 14:00:43 -0700198
Jake Weinsteinfff256f2017-04-06 20:38:26 -0400199 // Krait and Kryo targets are not supported by GCC, but are supported by Clang,
200 // so override the definitions when building modules with Clang.
Dan Willemsened89a7a2016-05-09 13:39:58 -0700201 replaceFirst(armClangCpuVariantCflags["krait"], "-mcpu=cortex-a15", "-mcpu=krait")
Alex Naidisae4fc182016-08-20 00:14:56 +0200202 replaceFirst(armClangCpuVariantCflags["kryo"], "-mcpu=cortex-a15", "-mcpu=krait")
Alex Naidisae4fc182016-08-20 00:14:56 +0200203
Isaac Chena2a58242017-08-23 10:57:17 +0000204 // The reason we use "-march=armv8-a+crc", instead of "-march=armv8-a", for
205 // gcc is the latter would conflict with any specified/supported -mcpu!
206 // All armv8-a cores supported by gcc 4.9 support crc, so it's safe
207 // to add +crc. Besides, the use of gcc is only for legacy code.
208 replaceFirst(armArchVariantCflags["armv8-a"], "-march=armv8-a", "-march=armv8-a+crc")
209
Dan Willemsen34fc3b12015-12-07 12:30:44 -0800210 pctx.StaticVariable("armGccVersion", armGccVersion)
Colin Cross3f40fa42015-01-30 17:27:36 -0800211
Colin Crossb98c8b02016-07-29 13:44:28 -0700212 pctx.SourcePathVariable("ArmGccRoot",
Dan Willemsen87b17d12015-07-14 00:39:06 -0700213 "prebuilts/gcc/${HostPrebuiltTag}/arm/arm-linux-androideabi-${armGccVersion}")
Colin Cross3f40fa42015-01-30 17:27:36 -0800214
Colin Crossb98c8b02016-07-29 13:44:28 -0700215 pctx.StaticVariable("ArmToolchainCflags", strings.Join(armToolchainCflags, " "))
216 pctx.StaticVariable("ArmCflags", strings.Join(armCflags, " "))
217 pctx.StaticVariable("ArmLdflags", strings.Join(armLdflags, " "))
218 pctx.StaticVariable("ArmCppflags", strings.Join(armCppflags, " "))
219 pctx.StaticVariable("ArmIncludeFlags", bionicHeaders("arm", "arm"))
Colin Cross3f40fa42015-01-30 17:27:36 -0800220
221 // Extended cflags
222
Tim Kilbourn1a9bf262015-03-18 12:28:32 -0700223 // ARM vs. Thumb instruction set flags
Colin Crossb98c8b02016-07-29 13:44:28 -0700224 pctx.StaticVariable("ArmArmCflags", strings.Join(armArmCflags, " "))
225 pctx.StaticVariable("ArmThumbCflags", strings.Join(armThumbCflags, " "))
Colin Cross3f40fa42015-01-30 17:27:36 -0800226
227 // Architecture variant cflags
Colin Crossb98c8b02016-07-29 13:44:28 -0700228 pctx.StaticVariable("ArmArmv5TECflags", strings.Join(armArchVariantCflags["armv5te"], " "))
229 pctx.StaticVariable("ArmArmv7ACflags", strings.Join(armArchVariantCflags["armv7-a"], " "))
230 pctx.StaticVariable("ArmArmv7ANeonCflags", strings.Join(armArchVariantCflags["armv7-a-neon"], " "))
Isaac Chena2a58242017-08-23 10:57:17 +0000231 pctx.StaticVariable("ArmArmv8ACflags", strings.Join(armArchVariantCflags["armv8-a"], " "))
Colin Cross3f40fa42015-01-30 17:27:36 -0800232
Colin Cross3f40fa42015-01-30 17:27:36 -0800233 // Cpu variant cflags
Colin Crossb98c8b02016-07-29 13:44:28 -0700234 pctx.StaticVariable("ArmGenericCflags", strings.Join(armCpuVariantCflags[""], " "))
235 pctx.StaticVariable("ArmCortexA7Cflags", strings.Join(armCpuVariantCflags["cortex-a7"], " "))
236 pctx.StaticVariable("ArmCortexA8Cflags", strings.Join(armCpuVariantCflags["cortex-a8"], " "))
237 pctx.StaticVariable("ArmCortexA15Cflags", strings.Join(armCpuVariantCflags["cortex-a15"], " "))
Christopher Ferris6df46f52017-05-08 12:08:40 -0700238 pctx.StaticVariable("ArmCortexA53Cflags", strings.Join(armCpuVariantCflags["cortex-a53"], " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700239 pctx.StaticVariable("ArmKraitCflags", strings.Join(armCpuVariantCflags["krait"], " "))
Alex Naidisae4fc182016-08-20 00:14:56 +0200240 pctx.StaticVariable("ArmKryoCflags", strings.Join(armCpuVariantCflags["kryo"], " "))
Colin Cross3f40fa42015-01-30 17:27:36 -0800241
242 // Clang cflags
Colin Crossb98c8b02016-07-29 13:44:28 -0700243 pctx.StaticVariable("ArmToolchainClangCflags", strings.Join(ClangFilterUnknownCflags(armToolchainCflags), " "))
244 pctx.StaticVariable("ArmClangCflags", strings.Join(ClangFilterUnknownCflags(armCflags), " "))
245 pctx.StaticVariable("ArmClangLdflags", strings.Join(ClangFilterUnknownCflags(armLdflags), " "))
246 pctx.StaticVariable("ArmClangCppflags", strings.Join(ClangFilterUnknownCflags(armCppflags), " "))
Colin Cross3f40fa42015-01-30 17:27:36 -0800247
Dan Willemsen6d11dd82015-11-03 14:27:00 -0800248 // Clang ARM vs. Thumb instruction set cflags
Colin Crossb98c8b02016-07-29 13:44:28 -0700249 pctx.StaticVariable("ArmClangArmCflags", strings.Join(ClangFilterUnknownCflags(armArmCflags), " "))
250 pctx.StaticVariable("ArmClangThumbCflags", strings.Join(ClangFilterUnknownCflags(armThumbCflags), " "))
Dan Willemsen6d11dd82015-11-03 14:27:00 -0800251
Dan Willemsen110a89d2016-01-14 15:17:19 -0800252 // Clang arch variant cflags
Colin Crossb98c8b02016-07-29 13:44:28 -0700253 pctx.StaticVariable("ArmClangArmv5TECflags",
Colin Cross3f40fa42015-01-30 17:27:36 -0800254 strings.Join(armClangArchVariantCflags["armv5te"], " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700255 pctx.StaticVariable("ArmClangArmv7ACflags",
Colin Cross3f40fa42015-01-30 17:27:36 -0800256 strings.Join(armClangArchVariantCflags["armv7-a"], " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700257 pctx.StaticVariable("ArmClangArmv7ANeonCflags",
Colin Cross3f40fa42015-01-30 17:27:36 -0800258 strings.Join(armClangArchVariantCflags["armv7-a-neon"], " "))
Isaac Chena2a58242017-08-23 10:57:17 +0000259 pctx.StaticVariable("ArmClangArmv8ACflags",
260 strings.Join(armClangArchVariantCflags["armv8-a"], " "))
Colin Cross3f40fa42015-01-30 17:27:36 -0800261
262 // Clang cpu variant cflags
Colin Crossb98c8b02016-07-29 13:44:28 -0700263 pctx.StaticVariable("ArmClangGenericCflags",
Dan Willemsen110a89d2016-01-14 15:17:19 -0800264 strings.Join(armClangCpuVariantCflags[""], " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700265 pctx.StaticVariable("ArmClangCortexA7Cflags",
Colin Cross3f40fa42015-01-30 17:27:36 -0800266 strings.Join(armClangCpuVariantCflags["cortex-a7"], " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700267 pctx.StaticVariable("ArmClangCortexA8Cflags",
Colin Cross3f40fa42015-01-30 17:27:36 -0800268 strings.Join(armClangCpuVariantCflags["cortex-a8"], " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700269 pctx.StaticVariable("ArmClangCortexA15Cflags",
Colin Cross3f40fa42015-01-30 17:27:36 -0800270 strings.Join(armClangCpuVariantCflags["cortex-a15"], " "))
Christopher Ferris6df46f52017-05-08 12:08:40 -0700271 pctx.StaticVariable("ArmClangCortexA53Cflags",
272 strings.Join(armClangCpuVariantCflags["cortex-a53"], " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700273 pctx.StaticVariable("ArmClangKraitCflags",
Colin Cross3f40fa42015-01-30 17:27:36 -0800274 strings.Join(armClangCpuVariantCflags["krait"], " "))
Alex Naidisae4fc182016-08-20 00:14:56 +0200275 pctx.StaticVariable("ArmClangKryoCflags",
276 strings.Join(armClangCpuVariantCflags["kryo"], " "))
Colin Cross3f40fa42015-01-30 17:27:36 -0800277}
278
279var (
280 armArchVariantCflagsVar = map[string]string{
Colin Crossb98c8b02016-07-29 13:44:28 -0700281 "armv5te": "${config.ArmArmv5TECflags}",
282 "armv7-a": "${config.ArmArmv7ACflags}",
283 "armv7-a-neon": "${config.ArmArmv7ANeonCflags}",
Isaac Chena2a58242017-08-23 10:57:17 +0000284 "armv8-a": "${config.ArmArmv8ACflags}",
Colin Cross3f40fa42015-01-30 17:27:36 -0800285 }
286
Colin Cross3f40fa42015-01-30 17:27:36 -0800287 armCpuVariantCflagsVar = map[string]string{
Colin Crossb98c8b02016-07-29 13:44:28 -0700288 "": "${config.ArmGenericCflags}",
289 "cortex-a7": "${config.ArmCortexA7Cflags}",
290 "cortex-a8": "${config.ArmCortexA8Cflags}",
291 "cortex-a15": "${config.ArmCortexA15Cflags}",
Christopher Ferris6df46f52017-05-08 12:08:40 -0700292 "cortex-a53": "${config.ArmCortexA53Cflags}",
293 "cortex-a53.a57": "${config.ArmCortexA53Cflags}",
294 "cortex-a73": "${config.ArmCortexA53Cflags}",
Colin Crossb98c8b02016-07-29 13:44:28 -0700295 "krait": "${config.ArmKraitCflags}",
Alex Naidisae4fc182016-08-20 00:14:56 +0200296 "kryo": "${config.ArmKryoCflags}",
Junmo Park8ea49592017-07-24 07:14:55 +0900297 "exynos-m1": "${config.ArmCortexA53Cflags}",
Junmo Parkd86c9022017-07-21 09:07:47 +0900298 "exynos-m2": "${config.ArmCortexA53Cflags}",
Colin Crossb98c8b02016-07-29 13:44:28 -0700299 "denver": "${config.ArmCortexA15Cflags}",
Colin Cross3f40fa42015-01-30 17:27:36 -0800300 }
301
302 armClangArchVariantCflagsVar = map[string]string{
Colin Crossb98c8b02016-07-29 13:44:28 -0700303 "armv5te": "${config.ArmClangArmv5TECflags}",
304 "armv7-a": "${config.ArmClangArmv7ACflags}",
305 "armv7-a-neon": "${config.ArmClangArmv7ANeonCflags}",
Isaac Chena2a58242017-08-23 10:57:17 +0000306 "armv8-a": "${config.ArmClangArmv8ACflags}",
Colin Cross3f40fa42015-01-30 17:27:36 -0800307 }
308
309 armClangCpuVariantCflagsVar = map[string]string{
Colin Crossb98c8b02016-07-29 13:44:28 -0700310 "": "${config.ArmClangGenericCflags}",
311 "cortex-a7": "${config.ArmClangCortexA7Cflags}",
312 "cortex-a8": "${config.ArmClangCortexA8Cflags}",
313 "cortex-a15": "${config.ArmClangCortexA15Cflags}",
Christopher Ferris6df46f52017-05-08 12:08:40 -0700314 "cortex-a53": "${config.ArmClangCortexA53Cflags}",
315 "cortex-a53.a57": "${config.ArmClangCortexA53Cflags}",
316 "cortex-a73": "${config.ArmClangCortexA53Cflags}",
Colin Crossb98c8b02016-07-29 13:44:28 -0700317 "krait": "${config.ArmClangKraitCflags}",
Alex Naidisae4fc182016-08-20 00:14:56 +0200318 "kryo": "${config.ArmClangKryoCflags}",
Junmo Park8ea49592017-07-24 07:14:55 +0900319 "exynos-m1": "${config.ArmClangCortexA53Cflags}",
Junmo Parkd86c9022017-07-21 09:07:47 +0900320 "exynos-m2": "${config.ArmClangCortexA53Cflags}",
Colin Crossb98c8b02016-07-29 13:44:28 -0700321 "denver": "${config.ArmClangCortexA15Cflags}",
Colin Cross3f40fa42015-01-30 17:27:36 -0800322 }
323)
324
325type toolchainArm struct {
326 toolchain32Bit
Colin Crossc4bde762015-11-23 16:11:30 -0800327 ldflags string
328 toolchainCflags, toolchainClangCflags string
Colin Cross3f40fa42015-01-30 17:27:36 -0800329}
330
Dan Albertbe961682015-03-18 23:38:50 -0700331func (t *toolchainArm) Name() string {
332 return "arm"
333}
334
Colin Cross3f40fa42015-01-30 17:27:36 -0800335func (t *toolchainArm) GccRoot() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700336 return "${config.ArmGccRoot}"
Colin Cross3f40fa42015-01-30 17:27:36 -0800337}
338
339func (t *toolchainArm) GccTriple() string {
Dan Albert84f431f2016-07-20 14:44:26 -0700340 return "arm-linux-androideabi"
Colin Cross3f40fa42015-01-30 17:27:36 -0800341}
342
Dan Albertbe961682015-03-18 23:38:50 -0700343func (t *toolchainArm) GccVersion() string {
Dan Willemsen34fc3b12015-12-07 12:30:44 -0800344 return armGccVersion
Dan Albertbe961682015-03-18 23:38:50 -0700345}
346
Colin Crossc4bde762015-11-23 16:11:30 -0800347func (t *toolchainArm) ToolchainCflags() string {
348 return t.toolchainCflags
349}
350
Colin Cross3f40fa42015-01-30 17:27:36 -0800351func (t *toolchainArm) Cflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700352 return "${config.ArmCflags}"
Colin Cross3f40fa42015-01-30 17:27:36 -0800353}
354
355func (t *toolchainArm) Cppflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700356 return "${config.ArmCppflags}"
Colin Cross3f40fa42015-01-30 17:27:36 -0800357}
358
359func (t *toolchainArm) Ldflags() string {
360 return t.ldflags
361}
362
363func (t *toolchainArm) IncludeFlags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700364 return "${config.ArmIncludeFlags}"
Colin Cross3f40fa42015-01-30 17:27:36 -0800365}
366
Tim Kilbourn1a9bf262015-03-18 12:28:32 -0700367func (t *toolchainArm) InstructionSetFlags(isa string) (string, error) {
368 switch isa {
369 case "arm":
Colin Crossb98c8b02016-07-29 13:44:28 -0700370 return "${config.ArmArmCflags}", nil
Tim Kilbourn1a9bf262015-03-18 12:28:32 -0700371 case "thumb", "":
Colin Crossb98c8b02016-07-29 13:44:28 -0700372 return "${config.ArmThumbCflags}", nil
Tim Kilbourn1a9bf262015-03-18 12:28:32 -0700373 default:
374 return t.toolchainBase.InstructionSetFlags(isa)
375 }
376}
377
Colin Cross3f40fa42015-01-30 17:27:36 -0800378func (t *toolchainArm) ClangTriple() string {
Dan Albert84f431f2016-07-20 14:44:26 -0700379 return t.GccTriple()
Colin Cross3f40fa42015-01-30 17:27:36 -0800380}
381
Colin Crossc4bde762015-11-23 16:11:30 -0800382func (t *toolchainArm) ToolchainClangCflags() string {
383 return t.toolchainClangCflags
384}
385
Colin Cross3f40fa42015-01-30 17:27:36 -0800386func (t *toolchainArm) ClangCflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700387 return "${config.ArmClangCflags}"
Colin Cross3f40fa42015-01-30 17:27:36 -0800388}
389
390func (t *toolchainArm) ClangCppflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700391 return "${config.ArmClangCppflags}"
Colin Cross3f40fa42015-01-30 17:27:36 -0800392}
393
394func (t *toolchainArm) ClangLdflags() string {
395 return t.ldflags
396}
397
Dan Willemsen6d11dd82015-11-03 14:27:00 -0800398func (t *toolchainArm) ClangInstructionSetFlags(isa string) (string, error) {
399 switch isa {
400 case "arm":
Colin Crossb98c8b02016-07-29 13:44:28 -0700401 return "${config.ArmClangArmCflags}", nil
Dan Willemsen6d11dd82015-11-03 14:27:00 -0800402 case "thumb", "":
Colin Crossb98c8b02016-07-29 13:44:28 -0700403 return "${config.ArmClangThumbCflags}", nil
Dan Willemsen6d11dd82015-11-03 14:27:00 -0800404 default:
405 return t.toolchainBase.ClangInstructionSetFlags(isa)
406 }
407}
408
Evgenii Stepanovaf36db12016-08-15 14:18:24 -0700409func (toolchainArm) SanitizerRuntimeLibraryArch() string {
410 return "arm"
Colin Cross16b23492016-01-06 14:41:07 -0800411}
412
Colin Cross635c3b02016-05-18 15:37:25 -0700413func armToolchainFactory(arch android.Arch) Toolchain {
Colin Crossc1e814d2015-04-28 13:15:59 -0700414 var fixCortexA8 string
Dan Willemsen110a89d2016-01-14 15:17:19 -0800415 toolchainCflags := make([]string, 2, 3)
416 toolchainClangCflags := make([]string, 2, 3)
417
Colin Crossb98c8b02016-07-29 13:44:28 -0700418 toolchainCflags[0] = "${config.ArmToolchainCflags}"
Dan Willemsen110a89d2016-01-14 15:17:19 -0800419 toolchainCflags[1] = armArchVariantCflagsVar[arch.ArchVariant]
Colin Crossb98c8b02016-07-29 13:44:28 -0700420 toolchainClangCflags[0] = "${config.ArmToolchainClangCflags}"
Dan Willemsen110a89d2016-01-14 15:17:19 -0800421 toolchainClangCflags[1] = armClangArchVariantCflagsVar[arch.ArchVariant]
422
Isaac Chena2a58242017-08-23 10:57:17 +0000423 toolchainCflags = append(toolchainCflags,
424 variantOrDefault(armCpuVariantCflagsVar, arch.CpuVariant))
425 toolchainClangCflags = append(toolchainClangCflags,
426 variantOrDefault(armClangCpuVariantCflagsVar, arch.CpuVariant))
427
Dan Willemsen110a89d2016-01-14 15:17:19 -0800428 switch arch.ArchVariant {
429 case "armv7-a-neon":
430 switch arch.CpuVariant {
431 case "cortex-a8", "":
432 // Generic ARM might be a Cortex A8 -- better safe than sorry
433 fixCortexA8 = "-Wl,--fix-cortex-a8"
434 default:
435 fixCortexA8 = "-Wl,--no-fix-cortex-a8"
436 }
Dan Willemsen110a89d2016-01-14 15:17:19 -0800437 case "armv7-a":
Colin Crossc1e814d2015-04-28 13:15:59 -0700438 fixCortexA8 = "-Wl,--fix-cortex-a8"
Dan Willemsen110a89d2016-01-14 15:17:19 -0800439 case "armv5te":
440 // Nothing extra for armv5te
Isaac Chena2a58242017-08-23 10:57:17 +0000441 case "armv8-a":
442 // Nothing extra for armv8-a
Colin Crossc1e814d2015-04-28 13:15:59 -0700443 default:
Dan Willemsen110a89d2016-01-14 15:17:19 -0800444 panic(fmt.Sprintf("Unknown ARM architecture version: %q", arch.ArchVariant))
Colin Crossc1e814d2015-04-28 13:15:59 -0700445 }
446
Colin Cross3f40fa42015-01-30 17:27:36 -0800447 return &toolchainArm{
Dan Willemsen110a89d2016-01-14 15:17:19 -0800448 toolchainCflags: strings.Join(toolchainCflags, " "),
Colin Cross3f40fa42015-01-30 17:27:36 -0800449 ldflags: strings.Join([]string{
Colin Crossb98c8b02016-07-29 13:44:28 -0700450 "${config.ArmLdflags}",
Colin Crossc1e814d2015-04-28 13:15:59 -0700451 fixCortexA8,
Colin Cross3f40fa42015-01-30 17:27:36 -0800452 }, " "),
Dan Willemsen110a89d2016-01-14 15:17:19 -0800453 toolchainClangCflags: strings.Join(toolchainClangCflags, " "),
Colin Cross3f40fa42015-01-30 17:27:36 -0800454 }
455}
456
457func init() {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700458 registerToolchainFactory(android.Android, android.Arm, armToolchainFactory)
Colin Cross3f40fa42015-01-30 17:27:36 -0800459}