blob: 0da51cb4ed658a4f4ca7724115e9efd53e576c6e [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 (
Liz Kammerf610a742022-02-10 16:56:02 -050018 "fmt"
Colin Cross6371b382015-11-23 14:53:57 -080019 "strings"
20
Colin Cross635c3b02016-05-18 15:37:25 -070021 "android/soong/android"
Colin Cross6371b382015-11-23 14:53:57 -080022)
23
24var (
25 x86_64Cflags = []string{
Colin Cross6371b382015-11-23 14:53:57 -080026 // Help catch common 32/64-bit errors.
Colin Cross6371b382015-11-23 14:53:57 -080027 "-Werror=implicit-function-declaration",
Colin Cross6371b382015-11-23 14:53:57 -080028 }
29
30 x86_64Cppflags = []string{}
31
32 x86_64Ldflags = []string{
Colin Cross6371b382015-11-23 14:53:57 -080033 "-Wl,--hash-style=gnu",
34 }
35
36 x86_64ArchVariantCflags = map[string][]string{
37 "": []string{
38 "-march=x86-64",
39 },
Liz Kammer2c2afe22022-02-11 11:35:03 -050040
Shalini Salomi Bodapati4a0459d2019-01-22 10:00:15 +053041 "broadwell": []string{
42 "-march=broadwell",
43 },
Colin Cross6371b382015-11-23 14:53:57 -080044 "haswell": []string{
45 "-march=core-avx2",
46 },
47 "ivybridge": []string{
48 "-march=core-avx-i",
49 },
50 "sandybridge": []string{
Dan Willemsenb77bd792016-02-29 15:26:26 -080051 "-march=corei7",
Colin Cross6371b382015-11-23 14:53:57 -080052 },
53 "silvermont": []string{
54 "-march=slm",
55 },
Shalini Salomi Bodapati4a0459d2019-01-22 10:00:15 +053056 "skylake": []string{
57 "-march=skylake",
58 },
Benjamin Gordon87e7f2f2019-02-14 10:59:48 -070059 "stoneyridge": []string{
60 "-march=bdver4",
61 },
Colin Cross6371b382015-11-23 14:53:57 -080062 }
63
64 x86_64ArchFeatureCflags = map[string][]string{
Elliott Hughesb22dcfe2019-07-12 22:40:45 -070065 "ssse3": []string{"-mssse3"},
Colin Cross6371b382015-11-23 14:53:57 -080066 "sse4": []string{"-msse4"},
67 "sse4_1": []string{"-msse4.1"},
68 "sse4_2": []string{"-msse4.2"},
jaishank7e849692019-06-25 14:55:52 +053069
70 // Not all cases there is performance gain by enabling -mavx -mavx2
71 // flags so these flags are not enabled by default.
72 // if there is performance gain in individual library components,
73 // the compiler flags can be set in corresponding bp files.
74 // "avx": []string{"-mavx"},
75 // "avx2": []string{"-mavx2"},
76 // "avx512": []string{"-mavx512"}
77
Dan Willemsen4ce47032016-05-06 17:20:53 -070078 "popcnt": []string{"-mpopcnt"},
Colin Cross6371b382015-11-23 14:53:57 -080079 "aes_ni": []string{"-maes"},
80 }
Liz Kammer82ad8cc2021-08-02 10:41:48 -040081
82 x86_64DefaultArchVariantFeatures = []string{
83 "ssse3",
84 "sse4",
85 "sse4_1",
86 "sse4_2",
87 "popcnt",
88 }
Colin Cross6371b382015-11-23 14:53:57 -080089)
90
Dan Willemsen34fc3b12015-12-07 12:30:44 -080091const (
92 x86_64GccVersion = "4.9"
93)
94
Colin Cross6371b382015-11-23 14:53:57 -080095func init() {
Liz Kammer82ad8cc2021-08-02 10:41:48 -040096 android.RegisterDefaultArchVariantFeatures(android.Android, android.X86_64, x86_64DefaultArchVariantFeatures...)
97 exportedStringListVars.Set("X86_64DefaultArchVariantFeatures", x86_64DefaultArchVariantFeatures)
Colin Cross6371b382015-11-23 14:53:57 -080098
Dan Willemsen34fc3b12015-12-07 12:30:44 -080099 pctx.StaticVariable("x86_64GccVersion", x86_64GccVersion)
Colin Cross6371b382015-11-23 14:53:57 -0800100
Colin Crossb98c8b02016-07-29 13:44:28 -0700101 pctx.SourcePathVariable("X86_64GccRoot",
Dan Willemsen34fc3b12015-12-07 12:30:44 -0800102 "prebuilts/gcc/${HostPrebuiltTag}/x86/x86_64-linux-android-${x86_64GccVersion}")
Colin Cross6371b382015-11-23 14:53:57 -0800103
Liz Kammer82ad8cc2021-08-02 10:41:48 -0400104 exportStringListStaticVariable("X86_64ToolchainCflags", []string{"-m64"})
105 exportStringListStaticVariable("X86_64ToolchainLdflags", []string{"-m64"})
Colin Cross6371b382015-11-23 14:53:57 -0800106
Liz Kammer82ad8cc2021-08-02 10:41:48 -0400107 exportStringListStaticVariable("X86_64Ldflags", x86_64Ldflags)
108 exportStringListStaticVariable("X86_64Lldflags", x86_64Ldflags)
Colin Cross6371b382015-11-23 14:53:57 -0800109
110 // Clang cflags
Liz Kammer82ad8cc2021-08-02 10:41:48 -0400111 exportStringListStaticVariable("X86_64Cflags", x86_64Cflags)
112 exportStringListStaticVariable("X86_64Cppflags", x86_64Cppflags)
Colin Cross6371b382015-11-23 14:53:57 -0800113
Colin Cross91e90042016-12-02 17:13:24 -0800114 // Yasm flags
Liz Kammer82ad8cc2021-08-02 10:41:48 -0400115 exportStringListStaticVariable("X86_64YasmFlags", []string{
116 "-f elf64",
117 "-m amd64",
118 })
Colin Cross91e90042016-12-02 17:13:24 -0800119
Colin Cross6371b382015-11-23 14:53:57 -0800120 // Extended cflags
121
Liz Kammer82ad8cc2021-08-02 10:41:48 -0400122 exportedStringListDictVars.Set("X86_64ArchVariantCflags", x86_64ArchVariantCflags)
123 exportedStringListDictVars.Set("X86_64ArchFeatureCflags", x86_64ArchFeatureCflags)
124
Colin Cross6371b382015-11-23 14:53:57 -0800125 // Architecture variant cflags
126 for variant, cflags := range x86_64ArchVariantCflags {
Liz Kammer82ad8cc2021-08-02 10:41:48 -0400127 pctx.StaticVariable("X86_64"+variant+"VariantCflags", strings.Join(cflags, " "))
Colin Cross6371b382015-11-23 14:53:57 -0800128 }
129}
130
131type toolchainX86_64 struct {
Colin Crosse3fee342021-06-21 17:28:25 -0700132 toolchainBionic
Colin Cross6371b382015-11-23 14:53:57 -0800133 toolchain64Bit
Colin Cross33bac242021-07-14 17:03:16 -0700134 toolchainCflags string
Colin Cross6371b382015-11-23 14:53:57 -0800135}
136
137func (t *toolchainX86_64) Name() string {
138 return "x86_64"
139}
140
141func (t *toolchainX86_64) GccRoot() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700142 return "${config.X86_64GccRoot}"
Colin Cross6371b382015-11-23 14:53:57 -0800143}
144
145func (t *toolchainX86_64) GccTriple() string {
Dan Albert84f431f2016-07-20 14:44:26 -0700146 return "x86_64-linux-android"
Colin Cross6371b382015-11-23 14:53:57 -0800147}
148
149func (t *toolchainX86_64) GccVersion() string {
Dan Willemsen34fc3b12015-12-07 12:30:44 -0800150 return x86_64GccVersion
Colin Cross6371b382015-11-23 14:53:57 -0800151}
152
Colin Cross6371b382015-11-23 14:53:57 -0800153func (t *toolchainX86_64) IncludeFlags() string {
Martin Stjernholm41ab2512020-04-08 01:06:07 +0100154 return ""
Colin Cross6371b382015-11-23 14:53:57 -0800155}
156
157func (t *toolchainX86_64) ClangTriple() string {
Dan Albert84f431f2016-07-20 14:44:26 -0700158 return t.GccTriple()
Colin Cross6371b382015-11-23 14:53:57 -0800159}
160
Colin Cross33bac242021-07-14 17:03:16 -0700161func (t *toolchainX86_64) ToolchainLdflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700162 return "${config.X86_64ToolchainLdflags}"
Dan Willemsen569b0fa2016-05-08 20:04:20 -0700163}
164
Colin Cross33bac242021-07-14 17:03:16 -0700165func (t *toolchainX86_64) ToolchainCflags() string {
166 return t.toolchainCflags
Colin Cross6371b382015-11-23 14:53:57 -0800167}
168
Colin Cross33bac242021-07-14 17:03:16 -0700169func (t *toolchainX86_64) Cflags() string {
Colin Cross0523ba22021-07-14 18:45:05 -0700170 return "${config.X86_64Cflags}"
Colin Cross6371b382015-11-23 14:53:57 -0800171}
172
Colin Cross33bac242021-07-14 17:03:16 -0700173func (t *toolchainX86_64) Cppflags() string {
Colin Cross0523ba22021-07-14 18:45:05 -0700174 return "${config.X86_64Cppflags}"
Colin Cross6371b382015-11-23 14:53:57 -0800175}
176
Colin Cross33bac242021-07-14 17:03:16 -0700177func (t *toolchainX86_64) Ldflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700178 return "${config.X86_64Ldflags}"
Colin Cross6371b382015-11-23 14:53:57 -0800179}
180
Colin Cross33bac242021-07-14 17:03:16 -0700181func (t *toolchainX86_64) Lldflags() string {
Chih-Hung Hsieh02b4da52018-04-03 11:33:34 -0700182 return "${config.X86_64Lldflags}"
183}
184
Colin Cross91e90042016-12-02 17:13:24 -0800185func (t *toolchainX86_64) YasmFlags() string {
186 return "${config.X86_64YasmFlags}"
187}
188
Yi Kong924adc42018-08-31 14:27:44 -0700189func (toolchainX86_64) LibclangRuntimeLibraryArch() string {
Evgenii Stepanovaf36db12016-08-15 14:18:24 -0700190 return "x86_64"
191}
192
Colin Cross635c3b02016-05-18 15:37:25 -0700193func x86_64ToolchainFactory(arch android.Arch) Toolchain {
Liz Kammerf610a742022-02-10 16:56:02 -0500194 // Error now rather than having a confusing Ninja error
195 if _, ok := x86_64ArchVariantCflags[arch.ArchVariant]; !ok {
196 panic(fmt.Sprintf("Unknown x86_64 architecture version: %q", arch.ArchVariant))
197 }
198
Colin Cross33bac242021-07-14 17:03:16 -0700199 toolchainCflags := []string{
Colin Crossb98c8b02016-07-29 13:44:28 -0700200 "${config.X86_64ToolchainCflags}",
Colin Cross0523ba22021-07-14 18:45:05 -0700201 "${config.X86_64" + arch.ArchVariant + "VariantCflags}",
Colin Cross6371b382015-11-23 14:53:57 -0800202 }
203
204 for _, feature := range arch.ArchFeatures {
Colin Cross33bac242021-07-14 17:03:16 -0700205 toolchainCflags = append(toolchainCflags, x86_64ArchFeatureCflags[feature]...)
Colin Cross6371b382015-11-23 14:53:57 -0800206 }
207
208 return &toolchainX86_64{
Colin Cross33bac242021-07-14 17:03:16 -0700209 toolchainCflags: strings.Join(toolchainCflags, " "),
Colin Cross6371b382015-11-23 14:53:57 -0800210 }
211}
212
213func init() {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700214 registerToolchainFactory(android.Android, android.X86_64, x86_64ToolchainFactory)
Colin Cross6371b382015-11-23 14:53:57 -0800215}