blob: 2a6fe2a99fd862ea915cce44240921002a0d7743 [file] [log] [blame]
Colin Cross6371b382015-11-23 14:53:57 -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 Cross6371b382015-11-23 14:53:57 -080016
17import (
18 "strings"
19
Colin Cross635c3b02016-05-18 15:37:25 -070020 "android/soong/android"
Colin Cross6371b382015-11-23 14:53:57 -080021)
22
23var (
24 x86_64Cflags = []string{
25 "-fno-exceptions", // from build/core/combo/select.mk
26 "-Wno-multichar", // from build/core/combo/select.mk
27 "-O2",
28 "-Wa,--noexecstack",
29 "-Werror=format-security",
30 "-D_FORTIFY_SOURCE=2",
31 "-Wstrict-aliasing=2",
32 "-ffunction-sections",
33 "-finline-functions",
34 "-finline-limit=300",
35 "-fno-short-enums",
36 "-fstrict-aliasing",
37 "-funswitch-loops",
38 "-funwind-tables",
Dan Willemsen7a0f8482016-01-12 16:22:40 -080039 "-fstack-protector-strong",
Colin Cross6371b382015-11-23 14:53:57 -080040 "-no-canonical-prefixes",
41 "-fno-canonical-system-headers",
42
43 // Help catch common 32/64-bit errors.
44 "-Werror=pointer-to-int-cast",
45 "-Werror=int-to-pointer-cast",
46 "-Werror=implicit-function-declaration",
47
48 // TARGET_RELEASE_CFLAGS from build/core/combo/select.mk
49 "-O2",
50 "-g",
51 "-fno-strict-aliasing",
52 }
53
54 x86_64Cppflags = []string{}
55
56 x86_64Ldflags = []string{
57 "-Wl,-z,noexecstack",
58 "-Wl,-z,relro",
59 "-Wl,-z,now",
60 "-Wl,--build-id=md5",
61 "-Wl,--warn-shared-textrel",
62 "-Wl,--fatal-warnings",
63 "-Wl,--gc-sections",
64 "-Wl,--hash-style=gnu",
Dan Willemsenc7e45972015-12-09 13:05:28 -080065 "-Wl,--no-undefined-version",
Colin Cross6371b382015-11-23 14:53:57 -080066 }
67
68 x86_64ArchVariantCflags = map[string][]string{
69 "": []string{
70 "-march=x86-64",
71 },
72 "haswell": []string{
73 "-march=core-avx2",
74 },
75 "ivybridge": []string{
76 "-march=core-avx-i",
77 },
78 "sandybridge": []string{
Dan Willemsenb77bd792016-02-29 15:26:26 -080079 "-march=corei7",
Colin Cross6371b382015-11-23 14:53:57 -080080 },
81 "silvermont": []string{
82 "-march=slm",
83 },
84 }
85
86 x86_64ArchFeatureCflags = map[string][]string{
87 "ssse3": []string{"-DUSE_SSSE3", "-mssse3"},
88 "sse4": []string{"-msse4"},
89 "sse4_1": []string{"-msse4.1"},
90 "sse4_2": []string{"-msse4.2"},
Dan Willemsen4ce47032016-05-06 17:20:53 -070091 "popcnt": []string{"-mpopcnt"},
Colin Cross6371b382015-11-23 14:53:57 -080092 "avx": []string{"-mavx"},
93 "aes_ni": []string{"-maes"},
94 }
95)
96
Dan Willemsen34fc3b12015-12-07 12:30:44 -080097const (
98 x86_64GccVersion = "4.9"
99)
100
Colin Cross6371b382015-11-23 14:53:57 -0800101func init() {
Dan Willemsenb1957a52016-06-23 23:44:54 -0700102 android.RegisterArchVariants(android.X86_64,
103 "haswell",
104 "ivybridge",
105 "sandybridge",
106 "silvermont")
107 android.RegisterArchFeatures(android.X86_64,
Colin Cross6371b382015-11-23 14:53:57 -0800108 "ssse3",
109 "sse4",
110 "sse4_1",
111 "sse4_2",
112 "aes_ni",
113 "avx",
114 "popcnt")
Dan Willemsenb1957a52016-06-23 23:44:54 -0700115 android.RegisterArchVariantFeatures(android.X86_64, "",
116 "ssse3",
117 "sse4",
118 "sse4_1",
119 "sse4_2",
120 "popcnt")
121 android.RegisterArchVariantFeatures(android.X86_64, "haswell",
Colin Cross6371b382015-11-23 14:53:57 -0800122 "ssse3",
123 "sse4",
124 "sse4_1",
125 "sse4_2",
126 "aes_ni",
127 "avx",
128 "popcnt")
Dan Willemsenb1957a52016-06-23 23:44:54 -0700129 android.RegisterArchVariantFeatures(android.X86_64, "ivybridge",
130 "ssse3",
131 "sse4",
132 "sse4_1",
133 "sse4_2",
134 "aes_ni",
135 "avx",
136 "popcnt")
137 android.RegisterArchVariantFeatures(android.X86_64, "sandybridge",
Colin Cross6371b382015-11-23 14:53:57 -0800138 "ssse3",
139 "sse4",
140 "sse4_1",
141 "sse4_2",
Colin Cross6371b382015-11-23 14:53:57 -0800142 "popcnt")
Dan Willemsenb1957a52016-06-23 23:44:54 -0700143 android.RegisterArchVariantFeatures(android.X86_64, "silvermont",
Colin Cross6371b382015-11-23 14:53:57 -0800144 "ssse3",
145 "sse4",
146 "sse4_1",
147 "sse4_2",
148 "aes_ni",
149 "popcnt")
150
Dan Willemsen34fc3b12015-12-07 12:30:44 -0800151 pctx.StaticVariable("x86_64GccVersion", x86_64GccVersion)
Colin Cross6371b382015-11-23 14:53:57 -0800152
Colin Crossb98c8b02016-07-29 13:44:28 -0700153 pctx.SourcePathVariable("X86_64GccRoot",
Dan Willemsen34fc3b12015-12-07 12:30:44 -0800154 "prebuilts/gcc/${HostPrebuiltTag}/x86/x86_64-linux-android-${x86_64GccVersion}")
Colin Cross6371b382015-11-23 14:53:57 -0800155
Colin Crossb98c8b02016-07-29 13:44:28 -0700156 pctx.StaticVariable("X86_64ToolchainCflags", "-m64")
157 pctx.StaticVariable("X86_64ToolchainLdflags", "-m64")
Colin Cross6371b382015-11-23 14:53:57 -0800158
Colin Crossb98c8b02016-07-29 13:44:28 -0700159 pctx.StaticVariable("X86_64Cflags", strings.Join(x86_64Cflags, " "))
160 pctx.StaticVariable("X86_64Ldflags", strings.Join(x86_64Ldflags, " "))
161 pctx.StaticVariable("X86_64Cppflags", strings.Join(x86_64Cppflags, " "))
162 pctx.StaticVariable("X86_64IncludeFlags", bionicHeaders("x86_64", "x86"))
Colin Cross6371b382015-11-23 14:53:57 -0800163
164 // Clang cflags
Colin Crossb98c8b02016-07-29 13:44:28 -0700165 pctx.StaticVariable("X86_64ClangCflags", strings.Join(ClangFilterUnknownCflags(x86_64Cflags), " "))
166 pctx.StaticVariable("X86_64ClangLdflags", strings.Join(ClangFilterUnknownCflags(x86_64Ldflags), " "))
167 pctx.StaticVariable("X86_64ClangCppflags", strings.Join(ClangFilterUnknownCflags(x86_64Cppflags), " "))
Colin Cross6371b382015-11-23 14:53:57 -0800168
Colin Cross91e90042016-12-02 17:13:24 -0800169 // Yasm flags
170 pctx.StaticVariable("X86_64YasmFlags", "-f elf64 -m amd64")
171
Colin Cross6371b382015-11-23 14:53:57 -0800172 // Extended cflags
173
174 // Architecture variant cflags
175 for variant, cflags := range x86_64ArchVariantCflags {
Colin Crossb98c8b02016-07-29 13:44:28 -0700176 pctx.StaticVariable("X86_64"+variant+"VariantCflags", strings.Join(cflags, " "))
177 pctx.StaticVariable("X86_64"+variant+"VariantClangCflags",
178 strings.Join(ClangFilterUnknownCflags(cflags), " "))
Colin Cross6371b382015-11-23 14:53:57 -0800179 }
180}
181
182type toolchainX86_64 struct {
183 toolchain64Bit
184 toolchainCflags, toolchainClangCflags string
185}
186
187func (t *toolchainX86_64) Name() string {
188 return "x86_64"
189}
190
191func (t *toolchainX86_64) GccRoot() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700192 return "${config.X86_64GccRoot}"
Colin Cross6371b382015-11-23 14:53:57 -0800193}
194
195func (t *toolchainX86_64) GccTriple() string {
Dan Albert84f431f2016-07-20 14:44:26 -0700196 return "x86_64-linux-android"
Colin Cross6371b382015-11-23 14:53:57 -0800197}
198
199func (t *toolchainX86_64) GccVersion() string {
Dan Willemsen34fc3b12015-12-07 12:30:44 -0800200 return x86_64GccVersion
Colin Cross6371b382015-11-23 14:53:57 -0800201}
202
203func (t *toolchainX86_64) ToolchainLdflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700204 return "${config.X86_64ToolchainLdflags}"
Colin Cross6371b382015-11-23 14:53:57 -0800205}
206
207func (t *toolchainX86_64) ToolchainCflags() string {
208 return t.toolchainCflags
209}
210
211func (t *toolchainX86_64) Cflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700212 return "${config.X86_64Cflags}"
Colin Cross6371b382015-11-23 14:53:57 -0800213}
214
215func (t *toolchainX86_64) Cppflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700216 return "${config.X86_64Cppflags}"
Colin Cross6371b382015-11-23 14:53:57 -0800217}
218
219func (t *toolchainX86_64) Ldflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700220 return "${config.X86_64Ldflags}"
Colin Cross6371b382015-11-23 14:53:57 -0800221}
222
223func (t *toolchainX86_64) IncludeFlags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700224 return "${config.X86_64IncludeFlags}"
Colin Cross6371b382015-11-23 14:53:57 -0800225}
226
227func (t *toolchainX86_64) ClangTriple() string {
Dan Albert84f431f2016-07-20 14:44:26 -0700228 return t.GccTriple()
Colin Cross6371b382015-11-23 14:53:57 -0800229}
230
Dan Willemsen569b0fa2016-05-08 20:04:20 -0700231func (t *toolchainX86_64) ToolchainClangLdflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700232 return "${config.X86_64ToolchainLdflags}"
Dan Willemsen569b0fa2016-05-08 20:04:20 -0700233}
234
Colin Cross6371b382015-11-23 14:53:57 -0800235func (t *toolchainX86_64) ToolchainClangCflags() string {
236 return t.toolchainClangCflags
237}
238
239func (t *toolchainX86_64) ClangCflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700240 return "${config.X86_64ClangCflags}"
Colin Cross6371b382015-11-23 14:53:57 -0800241}
242
243func (t *toolchainX86_64) ClangCppflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700244 return "${config.X86_64ClangCppflags}"
Colin Cross6371b382015-11-23 14:53:57 -0800245}
246
247func (t *toolchainX86_64) ClangLdflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700248 return "${config.X86_64Ldflags}"
Colin Cross6371b382015-11-23 14:53:57 -0800249}
250
Colin Cross91e90042016-12-02 17:13:24 -0800251func (t *toolchainX86_64) YasmFlags() string {
252 return "${config.X86_64YasmFlags}"
253}
254
Evgenii Stepanovaf36db12016-08-15 14:18:24 -0700255func (toolchainX86_64) SanitizerRuntimeLibraryArch() string {
256 return "x86_64"
257}
258
Colin Cross635c3b02016-05-18 15:37:25 -0700259func x86_64ToolchainFactory(arch android.Arch) Toolchain {
Colin Cross6371b382015-11-23 14:53:57 -0800260 toolchainCflags := []string{
Colin Crossb98c8b02016-07-29 13:44:28 -0700261 "${config.X86_64ToolchainCflags}",
262 "${config.X86_64" + arch.ArchVariant + "VariantCflags}",
Colin Cross6371b382015-11-23 14:53:57 -0800263 }
264
265 toolchainClangCflags := []string{
Colin Crossb98c8b02016-07-29 13:44:28 -0700266 "${config.X86_64ToolchainCflags}",
267 "${config.X86_64" + arch.ArchVariant + "VariantClangCflags}",
Colin Cross6371b382015-11-23 14:53:57 -0800268 }
269
270 for _, feature := range arch.ArchFeatures {
271 toolchainCflags = append(toolchainCflags, x86_64ArchFeatureCflags[feature]...)
272 toolchainClangCflags = append(toolchainClangCflags, x86_64ArchFeatureCflags[feature]...)
273 }
274
275 return &toolchainX86_64{
276 toolchainCflags: strings.Join(toolchainCflags, " "),
277 toolchainClangCflags: strings.Join(toolchainClangCflags, " "),
278 }
279}
280
281func init() {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700282 registerToolchainFactory(android.Android, android.X86_64, x86_64ToolchainFactory)
Colin Cross6371b382015-11-23 14:53:57 -0800283}