blob: 8fd65f7acf107686e8f59d671cc5c640b77e20b8 [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 Crossb0cba6a2015-11-20 15:35:26 -080016
17import (
18 "strings"
19
Colin Cross635c3b02016-05-18 15:37:25 -070020 "android/soong/android"
Colin Crossb0cba6a2015-11-20 15:35:26 -080021)
22
23var (
24 x86Cflags = []string{
Colin Crossb0cba6a2015-11-20 15:35:26 -080025 "-finline-functions",
26 "-finline-limit=300",
Colin Crossb0cba6a2015-11-20 15:35:26 -080027 "-funswitch-loops",
Colin Crossb0cba6a2015-11-20 15:35:26 -080028 }
29
Dan Willemsen569b0fa2016-05-08 20:04:20 -070030 x86ClangCflags = append(x86Cflags, []string{
31 "-msse3",
32
33 // -mstackrealign is needed to realign stack in native code
34 // that could be called from JNI, so that movaps instruction
35 // will work on assumed stack aligned local variables.
36 "-mstackrealign",
37 }...)
38
Colin Crossb0cba6a2015-11-20 15:35:26 -080039 x86Cppflags = []string{}
40
41 x86Ldflags = []string{
Colin Crossb0cba6a2015-11-20 15:35:26 -080042 "-Wl,--hash-style=gnu",
43 }
44
45 x86ArchVariantCflags = map[string][]string{
46 "": []string{
47 "-march=prescott",
48 },
Dan Willemsen8a354052016-05-10 14:30:51 -070049 "x86_64": []string{
50 "-march=prescott",
51 },
Colin Crossb0cba6a2015-11-20 15:35:26 -080052 "atom": []string{
53 "-march=atom",
54 "-mfpmath=sse",
55 },
56 "haswell": []string{
57 "-march=core-avx2",
58 "-mfpmath=sse",
59 },
60 "ivybridge": []string{
61 "-march=core-avx-i",
62 "-mfpmath=sse",
63 },
64 "sandybridge": []string{
Dan Willemsenb77bd792016-02-29 15:26:26 -080065 "-march=corei7",
Colin Crossb0cba6a2015-11-20 15:35:26 -080066 "-mfpmath=sse",
67 },
68 "silvermont": []string{
69 "-march=slm",
70 "-mfpmath=sse",
71 },
72 }
73
74 x86ArchFeatureCflags = map[string][]string{
75 "ssse3": []string{"-DUSE_SSSE3", "-mssse3"},
76 "sse4": []string{"-msse4"},
77 "sse4_1": []string{"-msse4.1"},
78 "sse4_2": []string{"-msse4.2"},
79 "avx": []string{"-mavx"},
80 "aes_ni": []string{"-maes"},
81 }
82)
83
Dan Willemsen34fc3b12015-12-07 12:30:44 -080084const (
85 x86GccVersion = "4.9"
86)
87
Colin Crossb0cba6a2015-11-20 15:35:26 -080088func init() {
Dan Willemsenb1957a52016-06-23 23:44:54 -070089 android.RegisterArchVariants(android.X86,
90 "atom",
91 "haswell",
92 "ivybridge",
93 "sandybridge",
94 "silvermont",
95 "x86_64")
96 android.RegisterArchFeatures(android.X86,
Colin Crossb0cba6a2015-11-20 15:35:26 -080097 "ssse3",
98 "sse4",
99 "sse4_1",
100 "sse4_2",
101 "aes_ni",
102 "avx",
103 "popcnt",
104 "movbe")
Dan Willemsenb1957a52016-06-23 23:44:54 -0700105 android.RegisterArchVariantFeatures(android.X86, "x86_64",
106 "ssse3",
107 "sse4",
108 "sse4_1",
109 "sse4_2",
110 "popcnt")
111 android.RegisterArchVariantFeatures(android.X86, "atom",
112 "ssse3",
113 "movbe")
114 android.RegisterArchVariantFeatures(android.X86, "haswell",
115 "ssse3",
116 "sse4",
117 "sse4_1",
118 "sse4_2",
119 "aes_ni",
120 "avx",
121 "popcnt",
122 "movbe")
123 android.RegisterArchVariantFeatures(android.X86, "ivybridge",
Colin Crossb0cba6a2015-11-20 15:35:26 -0800124 "ssse3",
125 "sse4",
126 "sse4_1",
127 "sse4_2",
128 "aes_ni",
129 "avx",
130 "popcnt")
Dan Willemsenb1957a52016-06-23 23:44:54 -0700131 android.RegisterArchVariantFeatures(android.X86, "sandybridge",
Colin Crossb0cba6a2015-11-20 15:35:26 -0800132 "ssse3",
133 "sse4",
134 "sse4_1",
135 "sse4_2",
Colin Crossb0cba6a2015-11-20 15:35:26 -0800136 "popcnt")
Dan Willemsenb1957a52016-06-23 23:44:54 -0700137 android.RegisterArchVariantFeatures(android.X86, "silvermont",
Colin Crossb0cba6a2015-11-20 15:35:26 -0800138 "ssse3",
139 "sse4",
140 "sse4_1",
141 "sse4_2",
142 "aes_ni",
143 "popcnt",
144 "movbe")
145
Dan Willemsen34fc3b12015-12-07 12:30:44 -0800146 pctx.StaticVariable("x86GccVersion", x86GccVersion)
Colin Crossb0cba6a2015-11-20 15:35:26 -0800147
Colin Crossb98c8b02016-07-29 13:44:28 -0700148 pctx.SourcePathVariable("X86GccRoot",
Dan Willemsen34fc3b12015-12-07 12:30:44 -0800149 "prebuilts/gcc/${HostPrebuiltTag}/x86/x86_64-linux-android-${x86GccVersion}")
Colin Crossb0cba6a2015-11-20 15:35:26 -0800150
Colin Crossb98c8b02016-07-29 13:44:28 -0700151 pctx.StaticVariable("X86ToolchainCflags", "-m32")
152 pctx.StaticVariable("X86ToolchainLdflags", "-m32")
Colin Crossb0cba6a2015-11-20 15:35:26 -0800153
Colin Crossb98c8b02016-07-29 13:44:28 -0700154 pctx.StaticVariable("X86Cflags", strings.Join(x86Cflags, " "))
155 pctx.StaticVariable("X86Ldflags", strings.Join(x86Ldflags, " "))
156 pctx.StaticVariable("X86Cppflags", strings.Join(x86Cppflags, " "))
Elliott Hughesde28deb2017-10-12 09:07:53 -0700157 pctx.StaticVariable("X86IncludeFlags", bionicHeaders("x86"))
Colin Crossb0cba6a2015-11-20 15:35:26 -0800158
159 // Clang cflags
Colin Crossb98c8b02016-07-29 13:44:28 -0700160 pctx.StaticVariable("X86ClangCflags", strings.Join(ClangFilterUnknownCflags(x86ClangCflags), " "))
161 pctx.StaticVariable("X86ClangLdflags", strings.Join(ClangFilterUnknownCflags(x86Ldflags), " "))
162 pctx.StaticVariable("X86ClangCppflags", strings.Join(ClangFilterUnknownCflags(x86Cppflags), " "))
Colin Crossb0cba6a2015-11-20 15:35:26 -0800163
Colin Cross91e90042016-12-02 17:13:24 -0800164 // Yasm flags
165 pctx.StaticVariable("X86YasmFlags", "-f elf32 -m x86")
166
Colin Crossb0cba6a2015-11-20 15:35:26 -0800167 // Extended cflags
168
169 // Architecture variant cflags
170 for variant, cflags := range x86ArchVariantCflags {
Colin Crossb98c8b02016-07-29 13:44:28 -0700171 pctx.StaticVariable("X86"+variant+"VariantCflags", strings.Join(cflags, " "))
172 pctx.StaticVariable("X86"+variant+"VariantClangCflags",
173 strings.Join(ClangFilterUnknownCflags(cflags), " "))
Colin Crossb0cba6a2015-11-20 15:35:26 -0800174 }
175}
176
177type toolchainX86 struct {
178 toolchain32Bit
179 toolchainCflags, toolchainClangCflags string
180}
181
182func (t *toolchainX86) Name() string {
183 return "x86"
184}
185
186func (t *toolchainX86) GccRoot() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700187 return "${config.X86GccRoot}"
Colin Crossb0cba6a2015-11-20 15:35:26 -0800188}
189
190func (t *toolchainX86) GccTriple() string {
Dan Albert84f431f2016-07-20 14:44:26 -0700191 return "x86_64-linux-android"
Colin Crossb0cba6a2015-11-20 15:35:26 -0800192}
193
194func (t *toolchainX86) GccVersion() string {
Dan Willemsen34fc3b12015-12-07 12:30:44 -0800195 return x86GccVersion
Colin Crossb0cba6a2015-11-20 15:35:26 -0800196}
197
198func (t *toolchainX86) ToolchainLdflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700199 return "${config.X86ToolchainLdflags}"
Colin Crossb0cba6a2015-11-20 15:35:26 -0800200}
201
202func (t *toolchainX86) ToolchainCflags() string {
203 return t.toolchainCflags
204}
205
206func (t *toolchainX86) Cflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700207 return "${config.X86Cflags}"
Colin Crossb0cba6a2015-11-20 15:35:26 -0800208}
209
210func (t *toolchainX86) Cppflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700211 return "${config.X86Cppflags}"
Colin Crossb0cba6a2015-11-20 15:35:26 -0800212}
213
214func (t *toolchainX86) Ldflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700215 return "${config.X86Ldflags}"
Colin Crossb0cba6a2015-11-20 15:35:26 -0800216}
217
218func (t *toolchainX86) IncludeFlags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700219 return "${config.X86IncludeFlags}"
Colin Crossb0cba6a2015-11-20 15:35:26 -0800220}
221
222func (t *toolchainX86) ClangTriple() string {
Dan Willemsen569b0fa2016-05-08 20:04:20 -0700223 return "i686-linux-android"
224}
225
226func (t *toolchainX86) ToolchainClangLdflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700227 return "${config.X86ToolchainLdflags}"
Colin Crossb0cba6a2015-11-20 15:35:26 -0800228}
229
230func (t *toolchainX86) ToolchainClangCflags() string {
231 return t.toolchainClangCflags
232}
233
234func (t *toolchainX86) ClangCflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700235 return "${config.X86ClangCflags}"
Colin Crossb0cba6a2015-11-20 15:35:26 -0800236}
237
238func (t *toolchainX86) ClangCppflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700239 return "${config.X86ClangCppflags}"
Colin Crossb0cba6a2015-11-20 15:35:26 -0800240}
241
242func (t *toolchainX86) ClangLdflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700243 return "${config.X86Ldflags}"
Colin Crossb0cba6a2015-11-20 15:35:26 -0800244}
245
Colin Cross91e90042016-12-02 17:13:24 -0800246func (t *toolchainX86) YasmFlags() string {
247 return "${config.X86YasmFlags}"
248}
249
Evgenii Stepanovaf36db12016-08-15 14:18:24 -0700250func (toolchainX86) SanitizerRuntimeLibraryArch() string {
251 return "i686"
Colin Cross16b23492016-01-06 14:41:07 -0800252}
253
Colin Cross635c3b02016-05-18 15:37:25 -0700254func x86ToolchainFactory(arch android.Arch) Toolchain {
Colin Crossb0cba6a2015-11-20 15:35:26 -0800255 toolchainCflags := []string{
Colin Crossb98c8b02016-07-29 13:44:28 -0700256 "${config.X86ToolchainCflags}",
257 "${config.X86" + arch.ArchVariant + "VariantCflags}",
Colin Crossb0cba6a2015-11-20 15:35:26 -0800258 }
259
260 toolchainClangCflags := []string{
Colin Crossb98c8b02016-07-29 13:44:28 -0700261 "${config.X86ToolchainCflags}",
262 "${config.X86" + arch.ArchVariant + "VariantClangCflags}",
Colin Crossb0cba6a2015-11-20 15:35:26 -0800263 }
264
265 for _, feature := range arch.ArchFeatures {
266 toolchainCflags = append(toolchainCflags, x86ArchFeatureCflags[feature]...)
267 toolchainClangCflags = append(toolchainClangCflags, x86ArchFeatureCflags[feature]...)
268 }
269
270 return &toolchainX86{
271 toolchainCflags: strings.Join(toolchainCflags, " "),
272 toolchainClangCflags: strings.Join(toolchainClangCflags, " "),
273 }
274}
275
276func init() {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700277 registerToolchainFactory(android.Android, android.X86, x86ToolchainFactory)
Colin Crossb0cba6a2015-11-20 15:35:26 -0800278}