blob: ba0309450f4a3670920ee43e74f1dffbfac5d5e4 [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{
Colin Cross6371b382015-11-23 14:53:57 -080025 // Help catch common 32/64-bit errors.
Colin Cross6371b382015-11-23 14:53:57 -080026 "-Werror=implicit-function-declaration",
Colin Cross6371b382015-11-23 14:53:57 -080027 }
28
29 x86_64Cppflags = []string{}
30
31 x86_64Ldflags = []string{
Colin Cross6371b382015-11-23 14:53:57 -080032 "-Wl,--hash-style=gnu",
33 }
34
Chih-Hung Hsieh02b4da52018-04-03 11:33:34 -070035 x86_64Lldflags = ClangFilterUnknownLldflags(x86_64Ldflags)
36
Colin Cross6371b382015-11-23 14:53:57 -080037 x86_64ArchVariantCflags = map[string][]string{
38 "": []string{
39 "-march=x86-64",
40 },
41 "haswell": []string{
42 "-march=core-avx2",
43 },
44 "ivybridge": []string{
45 "-march=core-avx-i",
46 },
47 "sandybridge": []string{
Dan Willemsenb77bd792016-02-29 15:26:26 -080048 "-march=corei7",
Colin Cross6371b382015-11-23 14:53:57 -080049 },
50 "silvermont": []string{
51 "-march=slm",
52 },
53 }
54
55 x86_64ArchFeatureCflags = map[string][]string{
56 "ssse3": []string{"-DUSE_SSSE3", "-mssse3"},
57 "sse4": []string{"-msse4"},
58 "sse4_1": []string{"-msse4.1"},
59 "sse4_2": []string{"-msse4.2"},
Dan Willemsen4ce47032016-05-06 17:20:53 -070060 "popcnt": []string{"-mpopcnt"},
Colin Cross6371b382015-11-23 14:53:57 -080061 "avx": []string{"-mavx"},
62 "aes_ni": []string{"-maes"},
63 }
64)
65
Dan Willemsen34fc3b12015-12-07 12:30:44 -080066const (
67 x86_64GccVersion = "4.9"
68)
69
Colin Cross6371b382015-11-23 14:53:57 -080070func init() {
Dan Willemsenb1957a52016-06-23 23:44:54 -070071 android.RegisterArchVariants(android.X86_64,
72 "haswell",
73 "ivybridge",
74 "sandybridge",
75 "silvermont")
76 android.RegisterArchFeatures(android.X86_64,
Colin Cross6371b382015-11-23 14:53:57 -080077 "ssse3",
78 "sse4",
79 "sse4_1",
80 "sse4_2",
81 "aes_ni",
82 "avx",
83 "popcnt")
Dan Willemsenb1957a52016-06-23 23:44:54 -070084 android.RegisterArchVariantFeatures(android.X86_64, "",
85 "ssse3",
86 "sse4",
87 "sse4_1",
88 "sse4_2",
89 "popcnt")
90 android.RegisterArchVariantFeatures(android.X86_64, "haswell",
Colin Cross6371b382015-11-23 14:53:57 -080091 "ssse3",
92 "sse4",
93 "sse4_1",
94 "sse4_2",
95 "aes_ni",
96 "avx",
97 "popcnt")
Dan Willemsenb1957a52016-06-23 23:44:54 -070098 android.RegisterArchVariantFeatures(android.X86_64, "ivybridge",
99 "ssse3",
100 "sse4",
101 "sse4_1",
102 "sse4_2",
103 "aes_ni",
104 "avx",
105 "popcnt")
106 android.RegisterArchVariantFeatures(android.X86_64, "sandybridge",
Colin Cross6371b382015-11-23 14:53:57 -0800107 "ssse3",
108 "sse4",
109 "sse4_1",
110 "sse4_2",
Colin Cross6371b382015-11-23 14:53:57 -0800111 "popcnt")
Dan Willemsenb1957a52016-06-23 23:44:54 -0700112 android.RegisterArchVariantFeatures(android.X86_64, "silvermont",
Colin Cross6371b382015-11-23 14:53:57 -0800113 "ssse3",
114 "sse4",
115 "sse4_1",
116 "sse4_2",
117 "aes_ni",
118 "popcnt")
119
Dan Willemsen34fc3b12015-12-07 12:30:44 -0800120 pctx.StaticVariable("x86_64GccVersion", x86_64GccVersion)
Colin Cross6371b382015-11-23 14:53:57 -0800121
Colin Crossb98c8b02016-07-29 13:44:28 -0700122 pctx.SourcePathVariable("X86_64GccRoot",
Dan Willemsen34fc3b12015-12-07 12:30:44 -0800123 "prebuilts/gcc/${HostPrebuiltTag}/x86/x86_64-linux-android-${x86_64GccVersion}")
Colin Cross6371b382015-11-23 14:53:57 -0800124
Colin Crossb98c8b02016-07-29 13:44:28 -0700125 pctx.StaticVariable("X86_64ToolchainCflags", "-m64")
126 pctx.StaticVariable("X86_64ToolchainLdflags", "-m64")
Colin Cross6371b382015-11-23 14:53:57 -0800127
Colin Crossb98c8b02016-07-29 13:44:28 -0700128 pctx.StaticVariable("X86_64Cflags", strings.Join(x86_64Cflags, " "))
129 pctx.StaticVariable("X86_64Ldflags", strings.Join(x86_64Ldflags, " "))
Chih-Hung Hsieh02b4da52018-04-03 11:33:34 -0700130 pctx.StaticVariable("X86_64Lldflags", strings.Join(x86_64Lldflags, " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700131 pctx.StaticVariable("X86_64Cppflags", strings.Join(x86_64Cppflags, " "))
Elliott Hughesde28deb2017-10-12 09:07:53 -0700132 pctx.StaticVariable("X86_64IncludeFlags", bionicHeaders("x86"))
Colin Cross6371b382015-11-23 14:53:57 -0800133
134 // Clang cflags
Colin Crossb98c8b02016-07-29 13:44:28 -0700135 pctx.StaticVariable("X86_64ClangCflags", strings.Join(ClangFilterUnknownCflags(x86_64Cflags), " "))
136 pctx.StaticVariable("X86_64ClangLdflags", strings.Join(ClangFilterUnknownCflags(x86_64Ldflags), " "))
Chih-Hung Hsieh02b4da52018-04-03 11:33:34 -0700137 pctx.StaticVariable("X86_64ClangLldflags", strings.Join(ClangFilterUnknownCflags(x86_64Lldflags), " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700138 pctx.StaticVariable("X86_64ClangCppflags", strings.Join(ClangFilterUnknownCflags(x86_64Cppflags), " "))
Colin Cross6371b382015-11-23 14:53:57 -0800139
Colin Cross91e90042016-12-02 17:13:24 -0800140 // Yasm flags
141 pctx.StaticVariable("X86_64YasmFlags", "-f elf64 -m amd64")
142
Colin Cross6371b382015-11-23 14:53:57 -0800143 // Extended cflags
144
145 // Architecture variant cflags
146 for variant, cflags := range x86_64ArchVariantCflags {
Colin Crossb98c8b02016-07-29 13:44:28 -0700147 pctx.StaticVariable("X86_64"+variant+"VariantCflags", strings.Join(cflags, " "))
148 pctx.StaticVariable("X86_64"+variant+"VariantClangCflags",
149 strings.Join(ClangFilterUnknownCflags(cflags), " "))
Colin Cross6371b382015-11-23 14:53:57 -0800150 }
151}
152
153type toolchainX86_64 struct {
154 toolchain64Bit
155 toolchainCflags, toolchainClangCflags string
156}
157
158func (t *toolchainX86_64) Name() string {
159 return "x86_64"
160}
161
162func (t *toolchainX86_64) GccRoot() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700163 return "${config.X86_64GccRoot}"
Colin Cross6371b382015-11-23 14:53:57 -0800164}
165
166func (t *toolchainX86_64) GccTriple() string {
Dan Albert84f431f2016-07-20 14:44:26 -0700167 return "x86_64-linux-android"
Colin Cross6371b382015-11-23 14:53:57 -0800168}
169
170func (t *toolchainX86_64) GccVersion() string {
Dan Willemsen34fc3b12015-12-07 12:30:44 -0800171 return x86_64GccVersion
Colin Cross6371b382015-11-23 14:53:57 -0800172}
173
174func (t *toolchainX86_64) ToolchainLdflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700175 return "${config.X86_64ToolchainLdflags}"
Colin Cross6371b382015-11-23 14:53:57 -0800176}
177
178func (t *toolchainX86_64) ToolchainCflags() string {
179 return t.toolchainCflags
180}
181
182func (t *toolchainX86_64) Cflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700183 return "${config.X86_64Cflags}"
Colin Cross6371b382015-11-23 14:53:57 -0800184}
185
186func (t *toolchainX86_64) Cppflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700187 return "${config.X86_64Cppflags}"
Colin Cross6371b382015-11-23 14:53:57 -0800188}
189
190func (t *toolchainX86_64) Ldflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700191 return "${config.X86_64Ldflags}"
Colin Cross6371b382015-11-23 14:53:57 -0800192}
193
194func (t *toolchainX86_64) IncludeFlags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700195 return "${config.X86_64IncludeFlags}"
Colin Cross6371b382015-11-23 14:53:57 -0800196}
197
198func (t *toolchainX86_64) ClangTriple() string {
Dan Albert84f431f2016-07-20 14:44:26 -0700199 return t.GccTriple()
Colin Cross6371b382015-11-23 14:53:57 -0800200}
201
Dan Willemsen569b0fa2016-05-08 20:04:20 -0700202func (t *toolchainX86_64) ToolchainClangLdflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700203 return "${config.X86_64ToolchainLdflags}"
Dan Willemsen569b0fa2016-05-08 20:04:20 -0700204}
205
Colin Cross6371b382015-11-23 14:53:57 -0800206func (t *toolchainX86_64) ToolchainClangCflags() string {
207 return t.toolchainClangCflags
208}
209
210func (t *toolchainX86_64) ClangCflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700211 return "${config.X86_64ClangCflags}"
Colin Cross6371b382015-11-23 14:53:57 -0800212}
213
214func (t *toolchainX86_64) ClangCppflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700215 return "${config.X86_64ClangCppflags}"
Colin Cross6371b382015-11-23 14:53:57 -0800216}
217
218func (t *toolchainX86_64) ClangLdflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700219 return "${config.X86_64Ldflags}"
Colin Cross6371b382015-11-23 14:53:57 -0800220}
221
Chih-Hung Hsieh02b4da52018-04-03 11:33:34 -0700222func (t *toolchainX86_64) ClangLldflags() string {
223 return "${config.X86_64Lldflags}"
224}
225
Colin Cross91e90042016-12-02 17:13:24 -0800226func (t *toolchainX86_64) YasmFlags() string {
227 return "${config.X86_64YasmFlags}"
228}
229
Evgenii Stepanovaf36db12016-08-15 14:18:24 -0700230func (toolchainX86_64) SanitizerRuntimeLibraryArch() string {
231 return "x86_64"
232}
233
Colin Cross635c3b02016-05-18 15:37:25 -0700234func x86_64ToolchainFactory(arch android.Arch) Toolchain {
Colin Cross6371b382015-11-23 14:53:57 -0800235 toolchainCflags := []string{
Colin Crossb98c8b02016-07-29 13:44:28 -0700236 "${config.X86_64ToolchainCflags}",
237 "${config.X86_64" + arch.ArchVariant + "VariantCflags}",
Colin Cross6371b382015-11-23 14:53:57 -0800238 }
239
240 toolchainClangCflags := []string{
Colin Crossb98c8b02016-07-29 13:44:28 -0700241 "${config.X86_64ToolchainCflags}",
242 "${config.X86_64" + arch.ArchVariant + "VariantClangCflags}",
Colin Cross6371b382015-11-23 14:53:57 -0800243 }
244
245 for _, feature := range arch.ArchFeatures {
246 toolchainCflags = append(toolchainCflags, x86_64ArchFeatureCflags[feature]...)
247 toolchainClangCflags = append(toolchainClangCflags, x86_64ArchFeatureCflags[feature]...)
248 }
249
250 return &toolchainX86_64{
251 toolchainCflags: strings.Join(toolchainCflags, " "),
252 toolchainClangCflags: strings.Join(toolchainClangCflags, " "),
253 }
254}
255
256func init() {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700257 registerToolchainFactory(android.Android, android.X86_64, x86_64ToolchainFactory)
Colin Cross6371b382015-11-23 14:53:57 -0800258}