blob: 2faa6709fa3d7e4530b290740d1f75a463898a19 [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 (
Liz Kammerf610a742022-02-10 16:56:02 -050018 "fmt"
Colin Crossb0cba6a2015-11-20 15:35:26 -080019 "strings"
20
Colin Cross635c3b02016-05-18 15:37:25 -070021 "android/soong/android"
Colin Crossb0cba6a2015-11-20 15:35:26 -080022)
23
24var (
Colin Cross33bac242021-07-14 17:03:16 -070025 x86Cflags = []string{
Dan Willemsen569b0fa2016-05-08 20:04:20 -070026 "-msse3",
27
28 // -mstackrealign is needed to realign stack in native code
29 // that could be called from JNI, so that movaps instruction
30 // will work on assumed stack aligned local variables.
31 "-mstackrealign",
Colin Cross33bac242021-07-14 17:03:16 -070032 }
Dan Willemsen569b0fa2016-05-08 20:04:20 -070033
Colin Crossb0cba6a2015-11-20 15:35:26 -080034 x86Cppflags = []string{}
35
36 x86Ldflags = []string{
Colin Crossb0cba6a2015-11-20 15:35:26 -080037 "-Wl,--hash-style=gnu",
38 }
39
40 x86ArchVariantCflags = map[string][]string{
41 "": []string{
42 "-march=prescott",
43 },
Dan Willemsen8a354052016-05-10 14:30:51 -070044 "x86_64": []string{
45 "-march=prescott",
46 },
Colin Crossb0cba6a2015-11-20 15:35:26 -080047 "atom": []string{
48 "-march=atom",
Colin Crossb0cba6a2015-11-20 15:35:26 -080049 },
Shalini Salomi Bodapati4a0459d2019-01-22 10:00:15 +053050 "broadwell": []string{
51 "-march=broadwell",
Shalini Salomi Bodapati4a0459d2019-01-22 10:00:15 +053052 },
Ryo Hashimotof68c18f2022-11-16 17:25:01 +090053 "goldmont": []string{
54 "-march=goldmont",
55 },
56 "goldmont-plus": []string{
57 "-march=goldmont-plus",
58 },
Satoshi Niwab6d818d2024-01-24 16:17:00 +090059 "goldmont-without-sha-xsaves": []string{
Satoshi Niwac41f2112023-12-14 17:33:36 +090060 "-march=goldmont",
Satoshi Niwab6d818d2024-01-24 16:17:00 +090061 "-mno-sha",
Satoshi Niwac41f2112023-12-14 17:33:36 +090062 "-mno-xsaves",
63 },
Colin Crossb0cba6a2015-11-20 15:35:26 -080064 "haswell": []string{
65 "-march=core-avx2",
Colin Crossb0cba6a2015-11-20 15:35:26 -080066 },
67 "ivybridge": []string{
68 "-march=core-avx-i",
Colin Crossb0cba6a2015-11-20 15:35:26 -080069 },
70 "sandybridge": []string{
Dan Willemsenb77bd792016-02-29 15:26:26 -080071 "-march=corei7",
Colin Crossb0cba6a2015-11-20 15:35:26 -080072 },
73 "silvermont": []string{
74 "-march=slm",
Colin Crossb0cba6a2015-11-20 15:35:26 -080075 },
Shalini Salomi Bodapati4a0459d2019-01-22 10:00:15 +053076 "skylake": []string{
77 "-march=skylake",
Shalini Salomi Bodapati4a0459d2019-01-22 10:00:15 +053078 },
Benjamin Gordon87e7f2f2019-02-14 10:59:48 -070079 "stoneyridge": []string{
80 "-march=bdver4",
Benjamin Gordon87e7f2f2019-02-14 10:59:48 -070081 },
Ryo Hashimotof68c18f2022-11-16 17:25:01 +090082 "tremont": []string{
83 "-march=tremont",
84 },
Colin Crossb0cba6a2015-11-20 15:35:26 -080085 }
86
87 x86ArchFeatureCflags = map[string][]string{
Elliott Hughesb22dcfe2019-07-12 22:40:45 -070088 "ssse3": []string{"-mssse3"},
Colin Crossb0cba6a2015-11-20 15:35:26 -080089 "sse4": []string{"-msse4"},
90 "sse4_1": []string{"-msse4.1"},
91 "sse4_2": []string{"-msse4.2"},
jaishank7e849692019-06-25 14:55:52 +053092
93 // Not all cases there is performance gain by enabling -mavx -mavx2
94 // flags so these flags are not enabled by default.
95 // if there is performance gain in individual library components,
96 // the compiler flags can be set in corresponding bp files.
97 // "avx": []string{"-mavx"},
98 // "avx2": []string{"-mavx2"},
99 // "avx512": []string{"-mavx512"}
100
Colin Crossb0cba6a2015-11-20 15:35:26 -0800101 "aes_ni": []string{"-maes"},
102 }
103)
104
105func init() {
Sam Delmerico7f889562022-03-25 14:55:40 +0000106 exportedVars.ExportStringListStaticVariable("X86ToolchainCflags", []string{"-m32"})
107 exportedVars.ExportStringListStaticVariable("X86ToolchainLdflags", []string{"-m32"})
Colin Crossb0cba6a2015-11-20 15:35:26 -0800108
Sam Delmerico7f889562022-03-25 14:55:40 +0000109 exportedVars.ExportStringListStaticVariable("X86Ldflags", x86Ldflags)
110 exportedVars.ExportStringListStaticVariable("X86Lldflags", x86Ldflags)
Colin Crossb0cba6a2015-11-20 15:35:26 -0800111
112 // Clang cflags
Sam Delmerico7f889562022-03-25 14:55:40 +0000113 exportedVars.ExportStringListStaticVariable("X86Cflags", x86Cflags)
114 exportedVars.ExportStringListStaticVariable("X86Cppflags", x86Cppflags)
Colin Crossb0cba6a2015-11-20 15:35:26 -0800115
Colin Cross91e90042016-12-02 17:13:24 -0800116 // Yasm flags
Sam Delmerico7f889562022-03-25 14:55:40 +0000117 exportedVars.ExportStringListStaticVariable("X86YasmFlags", []string{
Liz Kammer82ad8cc2021-08-02 10:41:48 -0400118 "-f elf32",
119 "-m x86",
120 })
Colin Cross91e90042016-12-02 17:13:24 -0800121
Colin Crossb0cba6a2015-11-20 15:35:26 -0800122 // Extended cflags
Sam Delmerico7f889562022-03-25 14:55:40 +0000123 exportedVars.ExportStringListDict("X86ArchVariantCflags", x86ArchVariantCflags)
124 exportedVars.ExportStringListDict("X86ArchFeatureCflags", x86ArchFeatureCflags)
Colin Crossb0cba6a2015-11-20 15:35:26 -0800125
126 // Architecture variant cflags
127 for variant, cflags := range x86ArchVariantCflags {
Liz Kammer82ad8cc2021-08-02 10:41:48 -0400128 pctx.StaticVariable("X86"+variant+"VariantCflags", strings.Join(cflags, " "))
Colin Crossb0cba6a2015-11-20 15:35:26 -0800129 }
130}
131
132type toolchainX86 struct {
Colin Crosse3fee342021-06-21 17:28:25 -0700133 toolchainBionic
Colin Crossb0cba6a2015-11-20 15:35:26 -0800134 toolchain32Bit
Colin Cross33bac242021-07-14 17:03:16 -0700135 toolchainCflags string
Colin Crossb0cba6a2015-11-20 15:35:26 -0800136}
137
138func (t *toolchainX86) Name() string {
139 return "x86"
140}
141
Colin Crossb0cba6a2015-11-20 15:35:26 -0800142func (t *toolchainX86) IncludeFlags() string {
Martin Stjernholm41ab2512020-04-08 01:06:07 +0100143 return ""
Colin Crossb0cba6a2015-11-20 15:35:26 -0800144}
145
146func (t *toolchainX86) ClangTriple() string {
Dan Willemsen569b0fa2016-05-08 20:04:20 -0700147 return "i686-linux-android"
148}
149
Colin Cross33bac242021-07-14 17:03:16 -0700150func (t *toolchainX86) ToolchainLdflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700151 return "${config.X86ToolchainLdflags}"
Colin Crossb0cba6a2015-11-20 15:35:26 -0800152}
153
Colin Cross33bac242021-07-14 17:03:16 -0700154func (t *toolchainX86) ToolchainCflags() string {
155 return t.toolchainCflags
Colin Crossb0cba6a2015-11-20 15:35:26 -0800156}
157
Colin Cross33bac242021-07-14 17:03:16 -0700158func (t *toolchainX86) Cflags() string {
Colin Cross0523ba22021-07-14 18:45:05 -0700159 return "${config.X86Cflags}"
Colin Crossb0cba6a2015-11-20 15:35:26 -0800160}
161
Colin Cross33bac242021-07-14 17:03:16 -0700162func (t *toolchainX86) Cppflags() string {
Colin Cross0523ba22021-07-14 18:45:05 -0700163 return "${config.X86Cppflags}"
Colin Crossb0cba6a2015-11-20 15:35:26 -0800164}
165
Colin Cross33bac242021-07-14 17:03:16 -0700166func (t *toolchainX86) Ldflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700167 return "${config.X86Ldflags}"
Colin Crossb0cba6a2015-11-20 15:35:26 -0800168}
169
Colin Cross33bac242021-07-14 17:03:16 -0700170func (t *toolchainX86) Lldflags() string {
Chih-Hung Hsieh02b4da52018-04-03 11:33:34 -0700171 return "${config.X86Lldflags}"
172}
173
Colin Cross91e90042016-12-02 17:13:24 -0800174func (t *toolchainX86) YasmFlags() string {
175 return "${config.X86YasmFlags}"
176}
177
Yi Kong924adc42018-08-31 14:27:44 -0700178func (toolchainX86) LibclangRuntimeLibraryArch() string {
Evgenii Stepanovaf36db12016-08-15 14:18:24 -0700179 return "i686"
Colin Cross16b23492016-01-06 14:41:07 -0800180}
181
Colin Cross635c3b02016-05-18 15:37:25 -0700182func x86ToolchainFactory(arch android.Arch) Toolchain {
Liz Kammerf610a742022-02-10 16:56:02 -0500183 // Error now rather than having a confusing Ninja error
184 if _, ok := x86ArchVariantCflags[arch.ArchVariant]; !ok {
185 panic(fmt.Sprintf("Unknown x86 architecture version: %q", arch.ArchVariant))
186 }
187
Colin Cross33bac242021-07-14 17:03:16 -0700188 toolchainCflags := []string{
Colin Crossb98c8b02016-07-29 13:44:28 -0700189 "${config.X86ToolchainCflags}",
Colin Cross0523ba22021-07-14 18:45:05 -0700190 "${config.X86" + arch.ArchVariant + "VariantCflags}",
Colin Crossb0cba6a2015-11-20 15:35:26 -0800191 }
192
193 for _, feature := range arch.ArchFeatures {
Colin Cross33bac242021-07-14 17:03:16 -0700194 toolchainCflags = append(toolchainCflags, x86ArchFeatureCflags[feature]...)
Colin Crossb0cba6a2015-11-20 15:35:26 -0800195 }
196
197 return &toolchainX86{
Colin Cross33bac242021-07-14 17:03:16 -0700198 toolchainCflags: strings.Join(toolchainCflags, " "),
Colin Crossb0cba6a2015-11-20 15:35:26 -0800199 }
200}
201
202func init() {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700203 registerToolchainFactory(android.Android, android.X86, x86ToolchainFactory)
Colin Crossb0cba6a2015-11-20 15:35:26 -0800204}