# Copyright (C) 2017 The Android Open Source Project # # 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. declare_args() { # Address Sanitizer: memory bugs (e.g., UAF). is_asan = false # Leak Sanitizer: memory leaks. is_lsan = false # Memory Sanitizer: uninitialized reads. is_msan = false # Thread Sanitizer: threading bugs. is_tsan = false # Undefined Behaviour Sanitizer. is_ubsan = false # Compile for fuzzing. is_fuzzer = false # When enabled, only relevant sanitizer defines are set, but compilation # happens with no extra flags. This is useful when in component build # enabling sanitizers only in some of the components. use_sanitizer_configs_without_instrumentation = false } declare_args() { # Link in LLVM LibFuzzer. use_libfuzzer = is_fuzzer # If is_fuzzer=true and use_libfuzzer=false, add this flag to ldflags when # linking fuzzer executables. link_fuzzer = "" } declare_args() { using_sanitizer = is_asan || is_lsan || is_tsan || is_msan || is_ubsan || use_libfuzzer } assert(!using_sanitizer || is_clang || is_system_compiler, "is_*san requires is_clang=true'") assert(!is_msan || is_linux, "msan only supported on linux") assert(!is_tsan || (is_linux || is_mac), "tsan only supported on linux and mac") assert(!is_fuzzer || use_libfuzzer || link_fuzzer != "")