diff --git a/BUILD.gn b/BUILD.gn index 775264acacc621..500a23e4272a52 100644 --- a/BUILD.gn +++ b/BUILD.gn @@ -241,6 +241,13 @@ if (current_toolchain != "${dir_pw_toolchain}/default:default") { enable_host_gcc_mbedtls_crypto_tests = enable_default_builds && host_os != "win" + # Enable building chip with clang & boringssl + enable_host_clang_boringssl_build = false + + # Enable limited testing with clang & boringssl + enable_host_clang_boringssl_crypto_tests = + enable_default_builds && host_os != "win" + # Build the chip-cert tool. enable_standalone_chip_cert_build = enable_default_builds && host_os != "win" && chip_crypto == "openssl" @@ -362,6 +369,23 @@ if (current_toolchain != "${dir_pw_toolchain}/default:default") { builds += [ ":host_gcc_mbedtls_crypto_tests" ] } + if (enable_host_clang_boringssl_build) { + chip_build("host_clang_boringssl") { + toolchain = "${chip_root}/config/boringssl/toolchain:${host_os}_${host_cpu}_clang_boringssl" + } + + builds += [ ":host_clang_boringssl" ] + } + + if (enable_host_clang_boringssl_crypto_tests) { + chip_build("host_clang_boringssl_crypto_tests") { + test_group = "//src:crypto_tests" + toolchain = "${chip_root}/config/boringssl/toolchain:${host_os}_${host_cpu}_clang_boringssl" + } + + builds += [ ":host_clang_boringssl_crypto_tests" ] + } + if (enable_android_builds) { chip_build("android_arm") { toolchain = "${build_root}/toolchain/android:android_arm" diff --git a/config/boringssl/toolchain/BUILD.gn b/config/boringssl/toolchain/BUILD.gn new file mode 100644 index 00000000000000..e342311e27a4bd --- /dev/null +++ b/config/boringssl/toolchain/BUILD.gn @@ -0,0 +1,26 @@ +# Copyright (c) 2020 Project CHIP Authors +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +import("//build_overrides/build.gni") + +import("${build_root}/toolchain/gcc_toolchain.gni") + +gcc_toolchain("${host_os}_${host_cpu}_clang_boringssl") { + toolchain_args = { + current_os = host_os + current_cpu = host_cpu + is_clang = true + chip_crypto = "boringssl" + } +} diff --git a/third_party/boringssl/repo/BUILD.gn b/third_party/boringssl/repo/BUILD.gn index 726091e9e21e06..92f07d04f75065 100644 --- a/third_party/boringssl/repo/BUILD.gn +++ b/third_party/boringssl/repo/BUILD.gn @@ -26,7 +26,10 @@ all_sources = crypto_sources all_headers = crypto_headers static_library("boringssl") { - cflags = [ "-O2" ] + cflags = [ + "-O2", + "-Wno-unused-variable", + ] public = all_headers