blob: fc0b1d8a82f676692c7f5ae3fca734315e6f5824 [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 (
Colin Crossb37620f2017-11-06 14:05:51 -080024 x86Cflags = []string{}
Colin Crossb0cba6a2015-11-20 15:35:26 -080025
Dan Willemsen569b0fa2016-05-08 20:04:20 -070026 x86ClangCflags = append(x86Cflags, []string{
27 "-msse3",
28
29 // -mstackrealign is needed to realign stack in native code
30 // that could be called from JNI, so that movaps instruction
31 // will work on assumed stack aligned local variables.
32 "-mstackrealign",
33 }...)
34
Colin Crossb0cba6a2015-11-20 15:35:26 -080035 x86Cppflags = []string{}
36
37 x86Ldflags = []string{
Colin Crossb0cba6a2015-11-20 15:35:26 -080038 "-Wl,--hash-style=gnu",
39 }
40
Chih-Hung Hsieh02b4da52018-04-03 11:33:34 -070041 x86Lldflags = ClangFilterUnknownLldflags(x86Ldflags)
42
Colin Crossb0cba6a2015-11-20 15:35:26 -080043 x86ArchVariantCflags = map[string][]string{
44 "": []string{
45 "-march=prescott",
46 },
Dan Willemsen8a354052016-05-10 14:30:51 -070047 "x86_64": []string{
48 "-march=prescott",
49 },
Colin Crossb0cba6a2015-11-20 15:35:26 -080050 "atom": []string{
51 "-march=atom",
52 "-mfpmath=sse",
53 },
54 "haswell": []string{
55 "-march=core-avx2",
56 "-mfpmath=sse",
57 },
58 "ivybridge": []string{
59 "-march=core-avx-i",
60 "-mfpmath=sse",
61 },
62 "sandybridge": []string{
Dan Willemsenb77bd792016-02-29 15:26:26 -080063 "-march=corei7",
Colin Crossb0cba6a2015-11-20 15:35:26 -080064 "-mfpmath=sse",
65 },
66 "silvermont": []string{
67 "-march=slm",
68 "-mfpmath=sse",
69 },
70 }
71
72 x86ArchFeatureCflags = map[string][]string{
73 "ssse3": []string{"-DUSE_SSSE3", "-mssse3"},
74 "sse4": []string{"-msse4"},
75 "sse4_1": []string{"-msse4.1"},
76 "sse4_2": []string{"-msse4.2"},
77 "avx": []string{"-mavx"},
78 "aes_ni": []string{"-maes"},
79 }
80)
81
Dan Willemsen34fc3b12015-12-07 12:30:44 -080082const (
83 x86GccVersion = "4.9"
84)
85
Colin Crossb0cba6a2015-11-20 15:35:26 -080086func init() {
Dan Willemsenb1957a52016-06-23 23:44:54 -070087 android.RegisterArchVariants(android.X86,
88 "atom",
89 "haswell",
90 "ivybridge",
91 "sandybridge",
92 "silvermont",
93 "x86_64")
94 android.RegisterArchFeatures(android.X86,
Colin Crossb0cba6a2015-11-20 15:35:26 -080095 "ssse3",
96 "sse4",
97 "sse4_1",
98 "sse4_2",
99 "aes_ni",
100 "avx",
101 "popcnt",
102 "movbe")
Dan Willemsenb1957a52016-06-23 23:44:54 -0700103 android.RegisterArchVariantFeatures(android.X86, "x86_64",
104 "ssse3",
105 "sse4",
106 "sse4_1",
107 "sse4_2",
108 "popcnt")
109 android.RegisterArchVariantFeatures(android.X86, "atom",
110 "ssse3",
111 "movbe")
112 android.RegisterArchVariantFeatures(android.X86, "haswell",
113 "ssse3",
114 "sse4",
115 "sse4_1",
116 "sse4_2",
117 "aes_ni",
118 "avx",
119 "popcnt",
120 "movbe")
121 android.RegisterArchVariantFeatures(android.X86, "ivybridge",
Colin Crossb0cba6a2015-11-20 15:35:26 -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, "sandybridge",
Colin Crossb0cba6a2015-11-20 15:35:26 -0800130 "ssse3",
131 "sse4",
132 "sse4_1",
133 "sse4_2",
Colin Crossb0cba6a2015-11-20 15:35:26 -0800134 "popcnt")
Dan Willemsenb1957a52016-06-23 23:44:54 -0700135 android.RegisterArchVariantFeatures(android.X86, "silvermont",
Colin Crossb0cba6a2015-11-20 15:35:26 -0800136 "ssse3",
137 "sse4",
138 "sse4_1",
139 "sse4_2",
140 "aes_ni",
141 "popcnt",
142 "movbe")
143
Dan Willemsen34fc3b12015-12-07 12:30:44 -0800144 pctx.StaticVariable("x86GccVersion", x86GccVersion)
Colin Crossb0cba6a2015-11-20 15:35:26 -0800145
Colin Crossb98c8b02016-07-29 13:44:28 -0700146 pctx.SourcePathVariable("X86GccRoot",
Dan Willemsen34fc3b12015-12-07 12:30:44 -0800147 "prebuilts/gcc/${HostPrebuiltTag}/x86/x86_64-linux-android-${x86GccVersion}")
Colin Crossb0cba6a2015-11-20 15:35:26 -0800148
Colin Crossb98c8b02016-07-29 13:44:28 -0700149 pctx.StaticVariable("X86ToolchainCflags", "-m32")
150 pctx.StaticVariable("X86ToolchainLdflags", "-m32")
Colin Crossb0cba6a2015-11-20 15:35:26 -0800151
Colin Crossb98c8b02016-07-29 13:44:28 -0700152 pctx.StaticVariable("X86Ldflags", strings.Join(x86Ldflags, " "))
Chih-Hung Hsieh02b4da52018-04-03 11:33:34 -0700153 pctx.StaticVariable("X86Lldflags", strings.Join(x86Lldflags, " "))
Elliott Hughesde28deb2017-10-12 09:07:53 -0700154 pctx.StaticVariable("X86IncludeFlags", bionicHeaders("x86"))
Colin Crossb0cba6a2015-11-20 15:35:26 -0800155
156 // Clang cflags
Colin Crossb98c8b02016-07-29 13:44:28 -0700157 pctx.StaticVariable("X86ClangCflags", strings.Join(ClangFilterUnknownCflags(x86ClangCflags), " "))
158 pctx.StaticVariable("X86ClangLdflags", strings.Join(ClangFilterUnknownCflags(x86Ldflags), " "))
Chih-Hung Hsieh02b4da52018-04-03 11:33:34 -0700159 pctx.StaticVariable("X86ClangLldflags", strings.Join(ClangFilterUnknownCflags(x86Lldflags), " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700160 pctx.StaticVariable("X86ClangCppflags", strings.Join(ClangFilterUnknownCflags(x86Cppflags), " "))
Colin Crossb0cba6a2015-11-20 15:35:26 -0800161
Colin Cross91e90042016-12-02 17:13:24 -0800162 // Yasm flags
163 pctx.StaticVariable("X86YasmFlags", "-f elf32 -m x86")
164
Colin Crossb0cba6a2015-11-20 15:35:26 -0800165 // Extended cflags
166
167 // Architecture variant cflags
168 for variant, cflags := range x86ArchVariantCflags {
Colin Crossb98c8b02016-07-29 13:44:28 -0700169 pctx.StaticVariable("X86"+variant+"VariantClangCflags",
170 strings.Join(ClangFilterUnknownCflags(cflags), " "))
Colin Crossb0cba6a2015-11-20 15:35:26 -0800171 }
172}
173
174type toolchainX86 struct {
175 toolchain32Bit
Dan Willemsenbd4abf52018-10-07 21:06:36 -0700176 toolchainClangCflags string
Colin Crossb0cba6a2015-11-20 15:35:26 -0800177}
178
179func (t *toolchainX86) Name() string {
180 return "x86"
181}
182
183func (t *toolchainX86) GccRoot() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700184 return "${config.X86GccRoot}"
Colin Crossb0cba6a2015-11-20 15:35:26 -0800185}
186
187func (t *toolchainX86) GccTriple() string {
Dan Albert84f431f2016-07-20 14:44:26 -0700188 return "x86_64-linux-android"
Colin Crossb0cba6a2015-11-20 15:35:26 -0800189}
190
191func (t *toolchainX86) GccVersion() string {
Dan Willemsen34fc3b12015-12-07 12:30:44 -0800192 return x86GccVersion
Colin Crossb0cba6a2015-11-20 15:35:26 -0800193}
194
Colin Crossb0cba6a2015-11-20 15:35:26 -0800195func (t *toolchainX86) IncludeFlags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700196 return "${config.X86IncludeFlags}"
Colin Crossb0cba6a2015-11-20 15:35:26 -0800197}
198
199func (t *toolchainX86) ClangTriple() string {
Dan Willemsen569b0fa2016-05-08 20:04:20 -0700200 return "i686-linux-android"
201}
202
203func (t *toolchainX86) ToolchainClangLdflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700204 return "${config.X86ToolchainLdflags}"
Colin Crossb0cba6a2015-11-20 15:35:26 -0800205}
206
207func (t *toolchainX86) ToolchainClangCflags() string {
208 return t.toolchainClangCflags
209}
210
211func (t *toolchainX86) ClangCflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700212 return "${config.X86ClangCflags}"
Colin Crossb0cba6a2015-11-20 15:35:26 -0800213}
214
215func (t *toolchainX86) ClangCppflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700216 return "${config.X86ClangCppflags}"
Colin Crossb0cba6a2015-11-20 15:35:26 -0800217}
218
219func (t *toolchainX86) ClangLdflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700220 return "${config.X86Ldflags}"
Colin Crossb0cba6a2015-11-20 15:35:26 -0800221}
222
Chih-Hung Hsieh02b4da52018-04-03 11:33:34 -0700223func (t *toolchainX86) ClangLldflags() string {
224 return "${config.X86Lldflags}"
225}
226
Colin Cross91e90042016-12-02 17:13:24 -0800227func (t *toolchainX86) YasmFlags() string {
228 return "${config.X86YasmFlags}"
229}
230
Yi Kong924adc42018-08-31 14:27:44 -0700231func (toolchainX86) LibclangRuntimeLibraryArch() string {
Evgenii Stepanovaf36db12016-08-15 14:18:24 -0700232 return "i686"
Colin Cross16b23492016-01-06 14:41:07 -0800233}
234
Colin Cross635c3b02016-05-18 15:37:25 -0700235func x86ToolchainFactory(arch android.Arch) Toolchain {
Colin Crossb0cba6a2015-11-20 15:35:26 -0800236 toolchainClangCflags := []string{
Colin Crossb98c8b02016-07-29 13:44:28 -0700237 "${config.X86ToolchainCflags}",
238 "${config.X86" + arch.ArchVariant + "VariantClangCflags}",
Colin Crossb0cba6a2015-11-20 15:35:26 -0800239 }
240
241 for _, feature := range arch.ArchFeatures {
Colin Crossb0cba6a2015-11-20 15:35:26 -0800242 toolchainClangCflags = append(toolchainClangCflags, x86ArchFeatureCflags[feature]...)
243 }
244
245 return &toolchainX86{
Colin Crossb0cba6a2015-11-20 15:35:26 -0800246 toolchainClangCflags: strings.Join(toolchainClangCflags, " "),
247 }
248}
249
250func init() {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700251 registerToolchainFactory(android.Android, android.X86, x86ToolchainFactory)
Colin Crossb0cba6a2015-11-20 15:35:26 -0800252}