blob: d9c96df93b16640292fa97c3659fa1db9e4c2f04 [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 },
Shalini Salomi Bodapati4a0459d2019-01-22 10:00:15 +053041 "broadwell": []string{
42 "-march=broadwell",
43 },
44
Colin Cross6371b382015-11-23 14:53:57 -080045 "haswell": []string{
46 "-march=core-avx2",
47 },
48 "ivybridge": []string{
49 "-march=core-avx-i",
50 },
51 "sandybridge": []string{
Dan Willemsenb77bd792016-02-29 15:26:26 -080052 "-march=corei7",
Colin Cross6371b382015-11-23 14:53:57 -080053 },
54 "silvermont": []string{
55 "-march=slm",
56 },
Shalini Salomi Bodapati4a0459d2019-01-22 10:00:15 +053057 "skylake": []string{
58 "-march=skylake",
59 },
Benjamin Gordon87e7f2f2019-02-14 10:59:48 -070060 "stoneyridge": []string{
61 "-march=bdver4",
62 },
Colin Cross6371b382015-11-23 14:53:57 -080063 }
64
65 x86_64ArchFeatureCflags = map[string][]string{
66 "ssse3": []string{"-DUSE_SSSE3", "-mssse3"},
67 "sse4": []string{"-msse4"},
68 "sse4_1": []string{"-msse4.1"},
69 "sse4_2": []string{"-msse4.2"},
jaishank7e849692019-06-25 14:55:52 +053070
71 // Not all cases there is performance gain by enabling -mavx -mavx2
72 // flags so these flags are not enabled by default.
73 // if there is performance gain in individual library components,
74 // the compiler flags can be set in corresponding bp files.
75 // "avx": []string{"-mavx"},
76 // "avx2": []string{"-mavx2"},
77 // "avx512": []string{"-mavx512"}
78
Dan Willemsen4ce47032016-05-06 17:20:53 -070079 "popcnt": []string{"-mpopcnt"},
Colin Cross6371b382015-11-23 14:53:57 -080080 "aes_ni": []string{"-maes"},
81 }
82)
83
Dan Willemsen34fc3b12015-12-07 12:30:44 -080084const (
85 x86_64GccVersion = "4.9"
86)
87
Colin Cross6371b382015-11-23 14:53:57 -080088func init() {
Dan Willemsen01a3c252019-01-11 19:02:16 -080089 android.RegisterDefaultArchVariantFeatures(android.Android, android.X86_64,
Dan Willemsenb1957a52016-06-23 23:44:54 -070090 "ssse3",
91 "sse4",
92 "sse4_1",
93 "sse4_2",
94 "popcnt")
Colin Cross6371b382015-11-23 14:53:57 -080095
Dan Willemsen34fc3b12015-12-07 12:30:44 -080096 pctx.StaticVariable("x86_64GccVersion", x86_64GccVersion)
Colin Cross6371b382015-11-23 14:53:57 -080097
Colin Crossb98c8b02016-07-29 13:44:28 -070098 pctx.SourcePathVariable("X86_64GccRoot",
Dan Willemsen34fc3b12015-12-07 12:30:44 -080099 "prebuilts/gcc/${HostPrebuiltTag}/x86/x86_64-linux-android-${x86_64GccVersion}")
Colin Cross6371b382015-11-23 14:53:57 -0800100
Colin Crossb98c8b02016-07-29 13:44:28 -0700101 pctx.StaticVariable("X86_64ToolchainCflags", "-m64")
102 pctx.StaticVariable("X86_64ToolchainLdflags", "-m64")
Colin Cross6371b382015-11-23 14:53:57 -0800103
Colin Crossb98c8b02016-07-29 13:44:28 -0700104 pctx.StaticVariable("X86_64Ldflags", strings.Join(x86_64Ldflags, " "))
Chih-Hung Hsieh02b4da52018-04-03 11:33:34 -0700105 pctx.StaticVariable("X86_64Lldflags", strings.Join(x86_64Lldflags, " "))
Elliott Hughesde28deb2017-10-12 09:07:53 -0700106 pctx.StaticVariable("X86_64IncludeFlags", bionicHeaders("x86"))
Colin Cross6371b382015-11-23 14:53:57 -0800107
108 // Clang cflags
Colin Crossb98c8b02016-07-29 13:44:28 -0700109 pctx.StaticVariable("X86_64ClangCflags", strings.Join(ClangFilterUnknownCflags(x86_64Cflags), " "))
110 pctx.StaticVariable("X86_64ClangLdflags", strings.Join(ClangFilterUnknownCflags(x86_64Ldflags), " "))
Chih-Hung Hsieh02b4da52018-04-03 11:33:34 -0700111 pctx.StaticVariable("X86_64ClangLldflags", strings.Join(ClangFilterUnknownCflags(x86_64Lldflags), " "))
Colin Crossb98c8b02016-07-29 13:44:28 -0700112 pctx.StaticVariable("X86_64ClangCppflags", strings.Join(ClangFilterUnknownCflags(x86_64Cppflags), " "))
Colin Cross6371b382015-11-23 14:53:57 -0800113
Colin Cross91e90042016-12-02 17:13:24 -0800114 // Yasm flags
115 pctx.StaticVariable("X86_64YasmFlags", "-f elf64 -m amd64")
116
Colin Cross6371b382015-11-23 14:53:57 -0800117 // Extended cflags
118
119 // Architecture variant cflags
120 for variant, cflags := range x86_64ArchVariantCflags {
Colin Crossb98c8b02016-07-29 13:44:28 -0700121 pctx.StaticVariable("X86_64"+variant+"VariantClangCflags",
122 strings.Join(ClangFilterUnknownCflags(cflags), " "))
Colin Cross6371b382015-11-23 14:53:57 -0800123 }
124}
125
126type toolchainX86_64 struct {
127 toolchain64Bit
Dan Willemsenbd4abf52018-10-07 21:06:36 -0700128 toolchainClangCflags string
Colin Cross6371b382015-11-23 14:53:57 -0800129}
130
131func (t *toolchainX86_64) Name() string {
132 return "x86_64"
133}
134
135func (t *toolchainX86_64) GccRoot() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700136 return "${config.X86_64GccRoot}"
Colin Cross6371b382015-11-23 14:53:57 -0800137}
138
139func (t *toolchainX86_64) GccTriple() string {
Dan Albert84f431f2016-07-20 14:44:26 -0700140 return "x86_64-linux-android"
Colin Cross6371b382015-11-23 14:53:57 -0800141}
142
143func (t *toolchainX86_64) GccVersion() string {
Dan Willemsen34fc3b12015-12-07 12:30:44 -0800144 return x86_64GccVersion
Colin Cross6371b382015-11-23 14:53:57 -0800145}
146
Colin Cross6371b382015-11-23 14:53:57 -0800147func (t *toolchainX86_64) IncludeFlags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700148 return "${config.X86_64IncludeFlags}"
Colin Cross6371b382015-11-23 14:53:57 -0800149}
150
151func (t *toolchainX86_64) ClangTriple() string {
Dan Albert84f431f2016-07-20 14:44:26 -0700152 return t.GccTriple()
Colin Cross6371b382015-11-23 14:53:57 -0800153}
154
Dan Willemsen569b0fa2016-05-08 20:04:20 -0700155func (t *toolchainX86_64) ToolchainClangLdflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700156 return "${config.X86_64ToolchainLdflags}"
Dan Willemsen569b0fa2016-05-08 20:04:20 -0700157}
158
Colin Cross6371b382015-11-23 14:53:57 -0800159func (t *toolchainX86_64) ToolchainClangCflags() string {
160 return t.toolchainClangCflags
161}
162
163func (t *toolchainX86_64) ClangCflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700164 return "${config.X86_64ClangCflags}"
Colin Cross6371b382015-11-23 14:53:57 -0800165}
166
167func (t *toolchainX86_64) ClangCppflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700168 return "${config.X86_64ClangCppflags}"
Colin Cross6371b382015-11-23 14:53:57 -0800169}
170
171func (t *toolchainX86_64) ClangLdflags() string {
Colin Crossb98c8b02016-07-29 13:44:28 -0700172 return "${config.X86_64Ldflags}"
Colin Cross6371b382015-11-23 14:53:57 -0800173}
174
Chih-Hung Hsieh02b4da52018-04-03 11:33:34 -0700175func (t *toolchainX86_64) ClangLldflags() string {
176 return "${config.X86_64Lldflags}"
177}
178
Colin Cross91e90042016-12-02 17:13:24 -0800179func (t *toolchainX86_64) YasmFlags() string {
180 return "${config.X86_64YasmFlags}"
181}
182
Yi Kong924adc42018-08-31 14:27:44 -0700183func (toolchainX86_64) LibclangRuntimeLibraryArch() string {
Evgenii Stepanovaf36db12016-08-15 14:18:24 -0700184 return "x86_64"
185}
186
Colin Cross635c3b02016-05-18 15:37:25 -0700187func x86_64ToolchainFactory(arch android.Arch) Toolchain {
Colin Cross6371b382015-11-23 14:53:57 -0800188 toolchainClangCflags := []string{
Colin Crossb98c8b02016-07-29 13:44:28 -0700189 "${config.X86_64ToolchainCflags}",
190 "${config.X86_64" + arch.ArchVariant + "VariantClangCflags}",
Colin Cross6371b382015-11-23 14:53:57 -0800191 }
192
193 for _, feature := range arch.ArchFeatures {
Colin Cross6371b382015-11-23 14:53:57 -0800194 toolchainClangCflags = append(toolchainClangCflags, x86_64ArchFeatureCflags[feature]...)
195 }
196
197 return &toolchainX86_64{
Colin Cross6371b382015-11-23 14:53:57 -0800198 toolchainClangCflags: strings.Join(toolchainClangCflags, " "),
199 }
200}
201
202func init() {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700203 registerToolchainFactory(android.Android, android.X86_64, x86_64ToolchainFactory)
Colin Cross6371b382015-11-23 14:53:57 -0800204}