blob: ba190a02bef1f5d23c296dd3228b4d24aa5e9b23 [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
15package cc
16
17import (
18 "strings"
19
20 "android/soong/common"
21)
22
23var (
24 x86_64Cflags = []string{
25 "-fno-exceptions", // from build/core/combo/select.mk
26 "-Wno-multichar", // from build/core/combo/select.mk
27 "-O2",
28 "-Wa,--noexecstack",
29 "-Werror=format-security",
30 "-D_FORTIFY_SOURCE=2",
31 "-Wstrict-aliasing=2",
32 "-ffunction-sections",
33 "-finline-functions",
34 "-finline-limit=300",
35 "-fno-short-enums",
36 "-fstrict-aliasing",
37 "-funswitch-loops",
38 "-funwind-tables",
39 "-fstack-protector",
40 "-no-canonical-prefixes",
41 "-fno-canonical-system-headers",
42
43 // Help catch common 32/64-bit errors.
44 "-Werror=pointer-to-int-cast",
45 "-Werror=int-to-pointer-cast",
46 "-Werror=implicit-function-declaration",
47
48 // TARGET_RELEASE_CFLAGS from build/core/combo/select.mk
49 "-O2",
50 "-g",
51 "-fno-strict-aliasing",
52 }
53
54 x86_64Cppflags = []string{}
55
56 x86_64Ldflags = []string{
57 "-Wl,-z,noexecstack",
58 "-Wl,-z,relro",
59 "-Wl,-z,now",
60 "-Wl,--build-id=md5",
61 "-Wl,--warn-shared-textrel",
62 "-Wl,--fatal-warnings",
63 "-Wl,--gc-sections",
64 "-Wl,--hash-style=gnu",
65 }
66
67 x86_64ArchVariantCflags = map[string][]string{
68 "": []string{
69 "-march=x86-64",
70 },
71 "haswell": []string{
72 "-march=core-avx2",
73 },
74 "ivybridge": []string{
75 "-march=core-avx-i",
76 },
77 "sandybridge": []string{
78 "-march=corei7-avx",
79 },
80 "silvermont": []string{
81 "-march=slm",
82 },
83 }
84
85 x86_64ArchFeatureCflags = map[string][]string{
86 "ssse3": []string{"-DUSE_SSSE3", "-mssse3"},
87 "sse4": []string{"-msse4"},
88 "sse4_1": []string{"-msse4.1"},
89 "sse4_2": []string{"-msse4.2"},
90 "avx": []string{"-mavx"},
91 "aes_ni": []string{"-maes"},
92 }
93)
94
Dan Willemsen34fc3b12015-12-07 12:30:44 -080095const (
96 x86_64GccVersion = "4.9"
97)
98
Colin Cross6371b382015-11-23 14:53:57 -080099func init() {
100 common.RegisterArchFeatures(common.X86_64, "",
101 "ssse3",
102 "sse4",
103 "sse4_1",
104 "sse4_2",
105 "popcnt")
106 common.RegisterArchFeatures(common.X86_64, "haswell",
107 "ssse3",
108 "sse4",
109 "sse4_1",
110 "sse4_2",
111 "aes_ni",
112 "avx",
113 "popcnt")
114 common.RegisterArchFeatures(common.X86_64, "ivybridge",
115 "ssse3",
116 "sse4",
117 "sse4_1",
118 "sse4_2",
119 "aes_ni",
120 "avx",
121 "popcnt")
122 common.RegisterArchFeatures(common.X86_64, "sandybridge",
123 "ssse3",
124 "sse4",
125 "sse4_1",
126 "sse4_2",
127 "aes_ni",
128 "avx",
129 "popcnt")
130 common.RegisterArchFeatures(common.X86_64, "silvermont",
131 "ssse3",
132 "sse4",
133 "sse4_1",
134 "sse4_2",
135 "aes_ni",
136 "popcnt")
137
Dan Willemsen34fc3b12015-12-07 12:30:44 -0800138 pctx.StaticVariable("x86_64GccVersion", x86_64GccVersion)
Colin Cross6371b382015-11-23 14:53:57 -0800139
140 pctx.StaticVariable("x86_64GccRoot",
Dan Willemsen34fc3b12015-12-07 12:30:44 -0800141 "prebuilts/gcc/${HostPrebuiltTag}/x86/x86_64-linux-android-${x86_64GccVersion}")
Colin Cross6371b382015-11-23 14:53:57 -0800142
143 pctx.StaticVariable("x86_64GccTriple", "x86_64-linux-android")
144
145 pctx.StaticVariable("x86_64ToolchainCflags", "-m64")
146 pctx.StaticVariable("x86_64ToolchainLdflags", "-m64")
147
148 pctx.StaticVariable("x86_64Cflags", strings.Join(x86_64Cflags, " "))
149 pctx.StaticVariable("x86_64Ldflags", strings.Join(x86_64Ldflags, " "))
150 pctx.StaticVariable("x86_64Cppflags", strings.Join(x86_64Cppflags, " "))
151 pctx.StaticVariable("x86_64IncludeFlags", strings.Join([]string{
152 "-isystem ${LibcRoot}/arch-x86_64/include",
153 "-isystem ${LibcRoot}/include",
154 "-isystem ${LibcRoot}/kernel/uapi",
155 "-isystem ${LibcRoot}/kernel/uapi/asm-x86",
156 "-isystem ${LibmRoot}/include",
157 "-isystem ${LibmRoot}/include/amd64",
158 }, " "))
159
160 // Clang cflags
161 pctx.StaticVariable("x86_64ClangCflags", strings.Join(clangFilterUnknownCflags(x86_64Cflags), " "))
162 pctx.StaticVariable("x86_64ClangLdflags", strings.Join(clangFilterUnknownCflags(x86_64Ldflags), " "))
163 pctx.StaticVariable("x86_64ClangCppflags", strings.Join(clangFilterUnknownCflags(x86_64Cppflags), " "))
164
165 // Extended cflags
166
167 // Architecture variant cflags
168 for variant, cflags := range x86_64ArchVariantCflags {
169 pctx.StaticVariable("x86_64"+variant+"VariantCflags", strings.Join(cflags, " "))
170 pctx.StaticVariable("x86_64"+variant+"VariantClangCflags",
171 strings.Join(clangFilterUnknownCflags(cflags), " "))
172 }
173}
174
175type toolchainX86_64 struct {
176 toolchain64Bit
177 toolchainCflags, toolchainClangCflags string
178}
179
180func (t *toolchainX86_64) Name() string {
181 return "x86_64"
182}
183
184func (t *toolchainX86_64) GccRoot() string {
185 return "${x86_64GccRoot}"
186}
187
188func (t *toolchainX86_64) GccTriple() string {
189 return "${x86_64GccTriple}"
190}
191
192func (t *toolchainX86_64) GccVersion() string {
Dan Willemsen34fc3b12015-12-07 12:30:44 -0800193 return x86_64GccVersion
Colin Cross6371b382015-11-23 14:53:57 -0800194}
195
196func (t *toolchainX86_64) ToolchainLdflags() string {
197 return "${x86_64ToolchainLdflags}"
198}
199
200func (t *toolchainX86_64) ToolchainCflags() string {
201 return t.toolchainCflags
202}
203
204func (t *toolchainX86_64) Cflags() string {
205 return "${x86_64Cflags}"
206}
207
208func (t *toolchainX86_64) Cppflags() string {
209 return "${x86_64Cppflags}"
210}
211
212func (t *toolchainX86_64) Ldflags() string {
213 return "${x86_64Ldflags}"
214}
215
216func (t *toolchainX86_64) IncludeFlags() string {
217 return "${x86_64IncludeFlags}"
218}
219
220func (t *toolchainX86_64) ClangTriple() string {
221 return "${x86_64GccTriple}"
222}
223
224func (t *toolchainX86_64) ToolchainClangCflags() string {
225 return t.toolchainClangCflags
226}
227
228func (t *toolchainX86_64) ClangCflags() string {
229 return "${x86_64ClangCflags}"
230}
231
232func (t *toolchainX86_64) ClangCppflags() string {
233 return "${x86_64ClangCppflags}"
234}
235
236func (t *toolchainX86_64) ClangLdflags() string {
237 return "${x86_64Ldflags}"
238}
239
240func x86_64ToolchainFactory(arch common.Arch) Toolchain {
241 toolchainCflags := []string{
242 "${x86_64ToolchainCflags}",
243 "${x86_64" + arch.ArchVariant + "VariantCflags}",
244 }
245
246 toolchainClangCflags := []string{
247 "${x86_64ToolchainCflags}",
248 "${x86_64" + arch.ArchVariant + "VariantClangCflags}",
249 }
250
251 for _, feature := range arch.ArchFeatures {
252 toolchainCflags = append(toolchainCflags, x86_64ArchFeatureCflags[feature]...)
253 toolchainClangCflags = append(toolchainClangCflags, x86_64ArchFeatureCflags[feature]...)
254 }
255
256 return &toolchainX86_64{
257 toolchainCflags: strings.Join(toolchainCflags, " "),
258 toolchainClangCflags: strings.Join(toolchainClangCflags, " "),
259 }
260}
261
262func init() {
Dan Willemsen490fd492015-11-24 17:53:15 -0800263 registerDeviceToolchainFactory(common.X86_64, x86_64ToolchainFactory)
Colin Cross6371b382015-11-23 14:53:57 -0800264}