blob: bce5322dbdfdb07e2b0aa0beedc8df18fe9782c0 [file] [log] [blame]
Dan Willemsen21986fb2016-07-14 15:23:56 -07001// Note that some host libraries have the same module name as the target
2// libraries. This is currently needed to build, for example, adb. But it's
3// probably something that should be changed.
4
Paul Duffincb6fdd22019-06-04 13:24:44 +01005package {
6 default_visibility: ["//visibility:private"],
7}
8
Dan Willemsen21986fb2016-07-14 15:23:56 -07009// Pull in the autogenerated sources modules
10build = ["sources.bp"]
11
12// Used by libcrypto, libssl, bssl tool, and native tests
13cc_defaults {
14 name: "boringssl_flags",
Steven Morelandf593be82017-04-14 04:51:23 -070015 vendor_available: true,
Dan Willemsen21986fb2016-07-14 15:23:56 -070016
17 cflags: [
18 "-fvisibility=hidden",
19 "-DBORINGSSL_SHARED_LIBRARY",
David Benjaminfc8a7862018-06-25 19:02:46 -040020 "-DBORINGSSL_ANDROID_SYSTEM",
Dan Willemsen21986fb2016-07-14 15:23:56 -070021 "-DOPENSSL_SMALL",
22 "-D_XOPEN_SOURCE=700",
Chih-Hung Hsieh9146d992017-09-27 10:26:03 -070023 "-Werror",
Dan Willemsen21986fb2016-07-14 15:23:56 -070024 "-Wno-unused-parameter",
25 ],
26
27 cppflags: [
28 "-Wall",
29 "-Werror",
30 ],
31
32 conlyflags: ["-std=c99"],
David Benjaminfc8a7862018-06-25 19:02:46 -040033
34 // Build BoringSSL and its tests against the same STL.
35 sdk_version: "9",
36 target: {
37 android: {
38 stl: "libc++_static",
39 },
40 },
Dan Willemsen21986fb2016-07-14 15:23:56 -070041}
42
43// Used by libcrypto + libssl
44cc_defaults {
45 name: "boringssl_defaults",
46
47 local_include_dirs: ["src/include"],
48 export_include_dirs: ["src/include"],
David Benjaminfc8a7862018-06-25 19:02:46 -040049 cflags: ["-DBORINGSSL_IMPLEMENTATION"],
Dan Willemsen21986fb2016-07-14 15:23:56 -070050}
51
52//// libcrypto
Dan Willemsen21986fb2016-07-14 15:23:56 -070053cc_defaults {
54 name: "libcrypto_defaults",
55 host_supported: true,
56
57 // Windows and Macs both have problems with assembly files
58 target: {
59 windows: {
60 enabled: true,
61 cflags: ["-DOPENSSL_NO_ASM"],
62 host_ldlibs: ["-lws2_32"],
63 },
64 darwin: {
65 cflags: ["-DOPENSSL_NO_ASM"],
66 },
Kenny Root7b550be2016-09-20 15:25:24 -070067 host: {
Dan Willemsen21986fb2016-07-14 15:23:56 -070068 host_ldlibs: ["-lpthread"],
69 },
70 },
71
72 local_include_dirs: ["src/crypto"],
73
Dan Willemsen21986fb2016-07-14 15:23:56 -070074 arch: {
Dan Willemsen21986fb2016-07-14 15:23:56 -070075 arm64: {
76 clang_asflags: ["-march=armv8-a+crypto"],
77 },
78 },
Pete Bentleye6a478a2019-08-19 22:20:24 +010079}
80
81cc_object {
82 name: "bcm_object",
83 device_supported: true,
84 recovery_available: true,
85 native_bridge_supported: true,
86 defaults: [
87 "libcrypto_bcm_sources",
88 "libcrypto_defaults",
89 "boringssl_defaults",
90 "boringssl_flags",
91 ],
Peter Collingbourne22f5f872019-09-27 15:32:38 -070092 sanitize: {
93 address: false,
94 },
Pete Bentleye6a478a2019-08-19 22:20:24 +010095 target: {
96 android: {
97 cflags: [
98 "-DBORINGSSL_FIPS",
99 "-fPIC",
Pete Bentley1d07cf82019-10-18 12:49:31 +0100100 // -fno[data|text]-sections required to ensure a
101 // single text and data section for FIPS integrity check
102 "-fno-data-sections",
103 "-fno-function-sections",
Pete Bentleye6a478a2019-08-19 22:20:24 +0100104 ],
105 linker_script: "src/crypto/fipsmodule/fips_shared.lds",
106 },
107 },
108}
109
110bootstrap_go_package {
111 name: "bssl_ar",
112 pkgPath: "boringssl.googlesource.com/boringssl/util/ar",
113 srcs: [
114 "src/util/ar/ar.go",
115 ],
116 testSrcs: [
117 "src/util/ar/ar_test.go",
118 ],
119}
120
121bootstrap_go_package {
122 name: "bssl_fipscommon",
123 pkgPath: "boringssl.googlesource.com/boringssl/util/fipstools/fipscommon",
124 srcs: [
125 "src/util/fipstools/fipscommon/const.go",
126 ],
127}
128
129blueprint_go_binary {
130 name: "bssl_inject_hash",
131 srcs: [
132 "src/util/fipstools/inject_hash/inject_hash.go",
133 ],
134 deps: [
135 "bssl_ar",
136 "bssl_fipscommon",
137 ],
Dan Willemsen21986fb2016-07-14 15:23:56 -0700138}
139
140// Target and host library
141cc_library {
142 name: "libcrypto",
Paul Duffincb6fdd22019-06-04 13:24:44 +0100143 visibility: ["//visibility:public"],
Vijay Venkatraman3caad952017-05-16 12:00:57 -0700144 vendor_available: true,
dimitry09dd3be2019-05-09 16:42:01 +0200145 native_bridge_supported: true,
Justin Yun47949c52017-07-24 15:19:43 +0900146 vndk: {
147 enabled: true,
148 },
Jooyung Hanb6b07c32019-01-18 15:31:20 +0900149 double_loadable: true,
Jiyong Parkc3463952018-04-27 21:44:32 +0900150 recovery_available: true,
Paul Duffinf6a61fd2019-06-25 12:06:25 +0100151 defaults: [
152 "libcrypto_sources",
153 "libcrypto_defaults",
154 "boringssl_defaults",
155 "boringssl_flags",
156 ],
Dan Willemsen2b2c24b2016-07-21 11:03:36 -0700157 unique_host_soname: true,
Pete Bentleye6a478a2019-08-19 22:20:24 +0100158 srcs: [
159 ":bcm_object",
160 ],
161 target: {
162 android: {
163 cflags: [
164 "-DBORINGSSL_FIPS",
165 ],
166 inject_bssl_hash: true,
Colin Cross4b979db2019-09-18 11:20:16 -0700167 static: {
168 // Disable the static version of libcrypto, as it causes
169 // problems for FIPS certification. Use libcrypto_static for
170 // modules that need static libcrypto but do not need FIPS self
171 // testing, or use dynamic libcrypto.
172 enabled: false,
173 },
Pete Bentleye6a478a2019-08-19 22:20:24 +0100174 },
175 },
Dan Willemsen21986fb2016-07-14 15:23:56 -0700176}
177
178// Static library
Colin Cross4b979db2019-09-18 11:20:16 -0700179// This version of libcrypto will not have FIPS self tests enabled, so its
180// usage is protected through visibility to ensure it doesn't end up used
181// somewhere that needs the FIPS version.
Dan Willemsen21986fb2016-07-14 15:23:56 -0700182cc_library_static {
183 name: "libcrypto_static",
Colin Cross4b979db2019-09-18 11:20:16 -0700184 visibility: [
185 "//bootable/recovery/updater",
186 "//external/conscrypt",
187 "//external/python/cpython2",
188 "//frameworks/ml/nn/runtime/test",
189 "//hardware/interfaces/confirmationui/1.0/vts/functional",
190 "//hardware/interfaces/drm/1.0/vts/functional",
191 "//hardware/interfaces/drm/1.2/vts/functional",
192 "//hardware/interfaces/keymaster/3.0/vts/functional",
193 "//hardware/interfaces/keymaster/4.0/vts/functional",
194 "//system/core/adb",
195 "//system/core/init",
196 "//system/core/fs_mgr/liblp",
197 "//system/core/fs_mgr/liblp/vts_core",
198 "//system/core/fs_mgr/libsnapshot",
199 "//system/libvintf/test",
200 "//system/security/keystore/tests",
201 "//test/vts-testcase/security/avb",
202 ],
Paul Duffinf6a61fd2019-06-25 12:06:25 +0100203 defaults: [
Pete Bentley47637342019-08-19 12:22:49 +0100204 "libcrypto_bcm_sources",
Paul Duffinf6a61fd2019-06-25 12:06:25 +0100205 "libcrypto_sources",
206 "libcrypto_defaults",
207 "boringssl_defaults",
208 "boringssl_flags",
209 ],
Dan Willemsen21986fb2016-07-14 15:23:56 -0700210}
211
Dan Willemsen21986fb2016-07-14 15:23:56 -0700212//// libssl
213
214// Target static library
Dan Willemsen21986fb2016-07-14 15:23:56 -0700215
216// Static and Shared library
217cc_library {
218 name: "libssl",
Paul Duffincb6fdd22019-06-04 13:24:44 +0100219 visibility: ["//visibility:public"],
Dan Willemsenea55e182018-10-23 13:41:19 -0700220 recovery_available: true,
Justin Yun47949c52017-07-24 15:19:43 +0900221 vendor_available: true,
dimitry09dd3be2019-05-09 16:42:01 +0200222 native_bridge_supported: true,
Justin Yun47949c52017-07-24 15:19:43 +0900223 vndk: {
224 enabled: true,
225 },
Dan Willemsen21986fb2016-07-14 15:23:56 -0700226 host_supported: true,
Paul Duffinf6a61fd2019-06-25 12:06:25 +0100227 defaults: [
228 "libssl_sources",
229 "boringssl_defaults",
230 "boringssl_flags",
231 ],
Dan Willemsen2b2c24b2016-07-21 11:03:36 -0700232 unique_host_soname: true,
Dan Willemsen21986fb2016-07-14 15:23:56 -0700233
Dan Willemsen2b2c24b2016-07-21 11:03:36 -0700234 shared_libs: ["libcrypto"],
Dan Willemsen21986fb2016-07-14 15:23:56 -0700235}
236
Dan Willemsen21986fb2016-07-14 15:23:56 -0700237// Tool
238cc_binary {
239 name: "bssl",
240 host_supported: true,
Paul Duffinf6a61fd2019-06-25 12:06:25 +0100241 defaults: [
242 "bssl_sources",
243 "boringssl_flags",
244 ],
Dan Willemsen21986fb2016-07-14 15:23:56 -0700245
Dan Willemsen2b2c24b2016-07-21 11:03:36 -0700246 shared_libs: [
247 "libcrypto",
248 "libssl",
249 ],
Dan Willemsen21986fb2016-07-14 15:23:56 -0700250 target: {
Dan Willemsen21986fb2016-07-14 15:23:56 -0700251 darwin: {
252 enabled: false,
253 },
254 },
255}
Dan Willemsen2458a412016-07-15 09:28:31 -0700256
Adam Langley7c167932018-02-02 14:44:53 -0800257cc_binary {
258 name: "cavp",
259 host_supported: true,
260 srcs: [
Pete Bentley0c61efe2019-08-13 09:32:23 +0100261 "src/util/fipstools/cavp/cavp_aes_gcm_test.cc",
262 "src/util/fipstools/cavp/cavp_aes_test.cc",
263 "src/util/fipstools/cavp/cavp_ctr_drbg_test.cc",
264 "src/util/fipstools/cavp/cavp_ecdsa2_keypair_test.cc",
265 "src/util/fipstools/cavp/cavp_ecdsa2_pkv_test.cc",
266 "src/util/fipstools/cavp/cavp_ecdsa2_siggen_test.cc",
267 "src/util/fipstools/cavp/cavp_ecdsa2_sigver_test.cc",
268 "src/util/fipstools/cavp/cavp_hmac_test.cc",
269 "src/util/fipstools/cavp/cavp_kas_test.cc",
270 "src/util/fipstools/cavp/cavp_keywrap_test.cc",
271 "src/util/fipstools/cavp/cavp_main.cc",
272 "src/util/fipstools/cavp/cavp_rsa2_keygen_test.cc",
273 "src/util/fipstools/cavp/cavp_rsa2_siggen_test.cc",
274 "src/util/fipstools/cavp/cavp_rsa2_sigver_test.cc",
275 "src/util/fipstools/cavp/cavp_sha_monte_test.cc",
276 "src/util/fipstools/cavp/cavp_sha_test.cc",
277 "src/util/fipstools/cavp/cavp_tdes_test.cc",
278 "src/util/fipstools/cavp/cavp_test_util.cc",
279 "src/util/fipstools/cavp/cavp_tlskdf_test.cc",
Adam Langley7c167932018-02-02 14:44:53 -0800280 ],
281
282 shared_libs: [
283 "libcrypto",
284 ],
285
Paul Duffinf6a61fd2019-06-25 12:06:25 +0100286 defaults: [
287 "boringssl_test_support_sources",
288 "boringssl_flags",
289 ],
Adam Langley7c167932018-02-02 14:44:53 -0800290}
291
Dan Willemsen2458a412016-07-15 09:28:31 -0700292// Test support library
293cc_library_static {
294 name: "boringssl_test_support",
295 host_supported: true,
Paul Duffinf6a61fd2019-06-25 12:06:25 +0100296 defaults: [
297 "boringssl_test_support_sources",
298 "boringssl_flags",
299 ],
Dan Willemsen2458a412016-07-15 09:28:31 -0700300
Dan Willemsen2b2c24b2016-07-21 11:03:36 -0700301 shared_libs: [
302 "libcrypto",
303 "libssl",
304 ],
Dan Willemsen2458a412016-07-15 09:28:31 -0700305}
306
307// Tests
308cc_test {
Paul Duffinf6a61fd2019-06-25 12:06:25 +0100309 name: "boringssl_crypto_test",
310 test_suites: ["device-tests"],
311 host_supported: true,
312 defaults: [
313 "boringssl_crypto_test_sources",
314 "boringssl_flags",
315 ],
316 whole_static_libs: ["boringssl_test_support"],
David Benjaminf31229b2017-01-25 14:08:15 -0500317
Paul Duffinf6a61fd2019-06-25 12:06:25 +0100318 shared_libs: ["libcrypto"],
David Benjaminf31229b2017-01-25 14:08:15 -0500319}
320
321cc_test {
Paul Duffinf6a61fd2019-06-25 12:06:25 +0100322 name: "boringssl_ssl_test",
323 test_suites: ["device-tests"],
324 host_supported: true,
325 defaults: [
326 "boringssl_ssl_test_sources",
327 "boringssl_flags",
328 ],
329 whole_static_libs: ["boringssl_test_support"],
David Benjaminf31229b2017-01-25 14:08:15 -0500330
Paul Duffinf6a61fd2019-06-25 12:06:25 +0100331 shared_libs: [
332 "libcrypto",
333 "libssl",
334 ],
David Benjaminf31229b2017-01-25 14:08:15 -0500335}