1*6777b538SAndroid Build Coastguard Worker# Copyright 2015 The Chromium Authors 2*6777b538SAndroid Build Coastguard Worker# Use of this source code is governed by a BSD-style license that can be 3*6777b538SAndroid Build Coastguard Worker# found in the LICENSE file. 4*6777b538SAndroid Build Coastguard Worker 5*6777b538SAndroid Build Coastguard Workerimport("//build/config/cast.gni") 6*6777b538SAndroid Build Coastguard Workerimport("//build/config/chrome_build.gni") 7*6777b538SAndroid Build Coastguard Workerimport("//build/config/chromeos/args.gni") 8*6777b538SAndroid Build Coastguard Workerimport("//build/config/chromeos/ui_mode.gni") 9*6777b538SAndroid Build Coastguard Workerimport("//build/config/profiling/profiling.gni") 10*6777b538SAndroid Build Coastguard Workerimport("//build/toolchain/toolchain.gni") 11*6777b538SAndroid Build Coastguard Worker 12*6777b538SAndroid Build Coastguard Workerdeclare_args() { 13*6777b538SAndroid Build Coastguard Worker # Compile for Address Sanitizer to find memory bugs. 14*6777b538SAndroid Build Coastguard Worker is_asan = false 15*6777b538SAndroid Build Coastguard Worker 16*6777b538SAndroid Build Coastguard Worker # Compile for Hardware-Assisted Address Sanitizer to find memory bugs 17*6777b538SAndroid Build Coastguard Worker # (android/arm64 only). 18*6777b538SAndroid Build Coastguard Worker # See http://clang.llvm.org/docs/HardwareAssistedAddressSanitizerDesign.html 19*6777b538SAndroid Build Coastguard Worker is_hwasan = false 20*6777b538SAndroid Build Coastguard Worker 21*6777b538SAndroid Build Coastguard Worker # Compile for Leak Sanitizer to find leaks. 22*6777b538SAndroid Build Coastguard Worker is_lsan = false 23*6777b538SAndroid Build Coastguard Worker 24*6777b538SAndroid Build Coastguard Worker # Compile for Memory Sanitizer to find uninitialized reads. 25*6777b538SAndroid Build Coastguard Worker is_msan = false 26*6777b538SAndroid Build Coastguard Worker 27*6777b538SAndroid Build Coastguard Worker # Compile for Thread Sanitizer to find threading bugs. 28*6777b538SAndroid Build Coastguard Worker is_tsan = false 29*6777b538SAndroid Build Coastguard Worker 30*6777b538SAndroid Build Coastguard Worker # Compile for Undefined Behaviour Sanitizer to find various types of 31*6777b538SAndroid Build Coastguard Worker # undefined behaviour (excludes vptr checks). 32*6777b538SAndroid Build Coastguard Worker is_ubsan = false 33*6777b538SAndroid Build Coastguard Worker 34*6777b538SAndroid Build Coastguard Worker # Halt the program if a problem is detected. 35*6777b538SAndroid Build Coastguard Worker is_ubsan_no_recover = false 36*6777b538SAndroid Build Coastguard Worker 37*6777b538SAndroid Build Coastguard Worker # Track where uninitialized memory originates from. From fastest to slowest: 38*6777b538SAndroid Build Coastguard Worker # 0 - no tracking, 1 - track only the initial allocation site, 2 - track the 39*6777b538SAndroid Build Coastguard Worker # chain of stores leading from allocation site to use site. 40*6777b538SAndroid Build Coastguard Worker msan_track_origins = 2 41*6777b538SAndroid Build Coastguard Worker 42*6777b538SAndroid Build Coastguard Worker # Enables "param-retval" mode, which finds more uses of uninitialized data and 43*6777b538SAndroid Build Coastguard Worker # reduces code size. Behind a flag as there are a number of previously 44*6777b538SAndroid Build Coastguard Worker # undetected violations that still need to be fixed. 45*6777b538SAndroid Build Coastguard Worker # TODO(crbug.com/1369167): Default this to true and remove. 46*6777b538SAndroid Build Coastguard Worker msan_eager_checks = false 47*6777b538SAndroid Build Coastguard Worker 48*6777b538SAndroid Build Coastguard Worker # Use dynamic libraries instrumented by one of the sanitizers instead of the 49*6777b538SAndroid Build Coastguard Worker # standard system libraries. Set this flag to build the libraries from source. 50*6777b538SAndroid Build Coastguard Worker use_locally_built_instrumented_libraries = false 51*6777b538SAndroid Build Coastguard Worker 52*6777b538SAndroid Build Coastguard Worker # Compile with Control Flow Integrity to protect virtual calls and casts. 53*6777b538SAndroid Build Coastguard Worker # See http://clang.llvm.org/docs/ControlFlowIntegrity.html 54*6777b538SAndroid Build Coastguard Worker # 55*6777b538SAndroid Build Coastguard Worker # TODO(pcc): Remove this flag if/when CFI is enabled in all official builds. 56*6777b538SAndroid Build Coastguard Worker is_cfi = is_official_build && is_clang && 57*6777b538SAndroid Build Coastguard Worker ((target_os == "linux" && target_cpu == "x64") || 58*6777b538SAndroid Build Coastguard Worker (is_chromeos && is_chromeos_device)) 59*6777b538SAndroid Build Coastguard Worker 60*6777b538SAndroid Build Coastguard Worker # Enable checks for indirect function calls via a function pointer. 61*6777b538SAndroid Build Coastguard Worker # TODO(pcc): remove this when we're ready to add these checks by default. 62*6777b538SAndroid Build Coastguard Worker # https://crbug.com/701919 63*6777b538SAndroid Build Coastguard Worker use_cfi_icall = 64*6777b538SAndroid Build Coastguard Worker target_os == "linux" && target_cpu == "x64" && is_official_build 65*6777b538SAndroid Build Coastguard Worker 66*6777b538SAndroid Build Coastguard Worker # Print detailed diagnostics when Control Flow Integrity detects a violation. 67*6777b538SAndroid Build Coastguard Worker use_cfi_diag = false 68*6777b538SAndroid Build Coastguard Worker 69*6777b538SAndroid Build Coastguard Worker # Let Control Flow Integrity continue execution instead of crashing when 70*6777b538SAndroid Build Coastguard Worker # printing diagnostics (use_cfi_diag = true). 71*6777b538SAndroid Build Coastguard Worker use_cfi_recover = false 72*6777b538SAndroid Build Coastguard Worker 73*6777b538SAndroid Build Coastguard Worker # Compile for fuzzing with LLVM LibFuzzer. 74*6777b538SAndroid Build Coastguard Worker # See http://www.chromium.org/developers/testing/libfuzzer 75*6777b538SAndroid Build Coastguard Worker use_libfuzzer = false 76*6777b538SAndroid Build Coastguard Worker 77*6777b538SAndroid Build Coastguard Worker # Compile for fuzzing with centipede. 78*6777b538SAndroid Build Coastguard Worker # See https://github.com/google/centipede 79*6777b538SAndroid Build Coastguard Worker use_centipede = false 80*6777b538SAndroid Build Coastguard Worker 81*6777b538SAndroid Build Coastguard Worker # Compile for fuzzing with AFL. 82*6777b538SAndroid Build Coastguard Worker use_afl = false 83*6777b538SAndroid Build Coastguard Worker 84*6777b538SAndroid Build Coastguard Worker # Compile for fuzzing with an external engine (e.g., Grammarinator). 85*6777b538SAndroid Build Coastguard Worker use_external_fuzzing_engine = false 86*6777b538SAndroid Build Coastguard Worker 87*6777b538SAndroid Build Coastguard Worker # Enables core ubsan security features. Will later be removed once it matches 88*6777b538SAndroid Build Coastguard Worker # is_ubsan. 89*6777b538SAndroid Build Coastguard Worker is_ubsan_security = false 90*6777b538SAndroid Build Coastguard Worker 91*6777b538SAndroid Build Coastguard Worker # Helper variable for testing builds with disabled libfuzzer. 92*6777b538SAndroid Build Coastguard Worker # Not for client use. 93*6777b538SAndroid Build Coastguard Worker disable_libfuzzer = false 94*6777b538SAndroid Build Coastguard Worker 95*6777b538SAndroid Build Coastguard Worker # Value for -fsanitize-coverage flag. Setting this causes 96*6777b538SAndroid Build Coastguard Worker # use_sanitizer_coverage to be enabled. 97*6777b538SAndroid Build Coastguard Worker # This flag is not used for libFuzzer (use_libfuzzer=true). Instead, we use: 98*6777b538SAndroid Build Coastguard Worker # -fsanitize=fuzzer-no-link 99*6777b538SAndroid Build Coastguard Worker # Default value when unset and use_fuzzing_engine=true: 100*6777b538SAndroid Build Coastguard Worker # trace-pc-guard 101*6777b538SAndroid Build Coastguard Worker # Default value when unset and use_sanitizer_coverage=true: 102*6777b538SAndroid Build Coastguard Worker # trace-pc-guard,indirect-calls 103*6777b538SAndroid Build Coastguard Worker sanitizer_coverage_flags = "" 104*6777b538SAndroid Build Coastguard Worker 105*6777b538SAndroid Build Coastguard Worker # A sanitizer coverage allowlist, specifying exactly which 106*6777b538SAndroid Build Coastguard Worker # files or symbol names should be instrumented, rather than all of them. 107*6777b538SAndroid Build Coastguard Worker sanitizer_coverage_allowlist = "" 108*6777b538SAndroid Build Coastguard Worker 109*6777b538SAndroid Build Coastguard Worker # When enabled, only relevant sanitizer defines are set, but compilation 110*6777b538SAndroid Build Coastguard Worker # happens with no extra flags. This is useful when in component build 111*6777b538SAndroid Build Coastguard Worker # enabling sanitizers only in some of the components. 112*6777b538SAndroid Build Coastguard Worker use_sanitizer_configs_without_instrumentation = false 113*6777b538SAndroid Build Coastguard Worker 114*6777b538SAndroid Build Coastguard Worker # When true, seed corpora archives are built. 115*6777b538SAndroid Build Coastguard Worker archive_seed_corpus = true 116*6777b538SAndroid Build Coastguard Worker 117*6777b538SAndroid Build Coastguard Worker # When true, sanitizer warnings will cause test case failures. 118*6777b538SAndroid Build Coastguard Worker fail_on_san_warnings = false 119*6777b538SAndroid Build Coastguard Worker 120*6777b538SAndroid Build Coastguard Worker # When true, only builds fuzzer targets that require high end machines to run. 121*6777b538SAndroid Build Coastguard Worker # Otherwise, builds all the targets. 122*6777b538SAndroid Build Coastguard Worker # TODO(paulsemel): once we have everything implemented on the recipe side, we 123*6777b538SAndroid Build Coastguard Worker # can change the behaviour for the false case, and only build the non high-end 124*6777b538SAndroid Build Coastguard Worker # jobs, so that they do not appear in the zip. As for now, this behaviour 125*6777b538SAndroid Build Coastguard Worker # ensures nothing breaks. 126*6777b538SAndroid Build Coastguard Worker high_end_fuzzer_targets = false 127*6777b538SAndroid Build Coastguard Worker} 128*6777b538SAndroid Build Coastguard Worker 129*6777b538SAndroid Build Coastguard Workerdeclare_args() { 130*6777b538SAndroid Build Coastguard Worker # Enable checks for bad casts: derived cast and unrelated cast. 131*6777b538SAndroid Build Coastguard Worker # TODO(krasin): remove this, when we're ready to add these checks by default. 132*6777b538SAndroid Build Coastguard Worker # https://crbug.com/626794 133*6777b538SAndroid Build Coastguard Worker use_cfi_cast = is_cfi && is_chromeos 134*6777b538SAndroid Build Coastguard Worker 135*6777b538SAndroid Build Coastguard Worker # Compile for Undefined Behaviour Sanitizer's vptr checks. 136*6777b538SAndroid Build Coastguard Worker is_ubsan_vptr = is_ubsan_security 137*6777b538SAndroid Build Coastguard Worker} 138*6777b538SAndroid Build Coastguard Worker 139*6777b538SAndroid Build Coastguard Workerdeclare_args() { 140*6777b538SAndroid Build Coastguard Worker # Builds fuzztest test executables such that they support the 141*6777b538SAndroid Build Coastguard Worker # --fuzz= argument, which requires some sanitizer coverage. 142*6777b538SAndroid Build Coastguard Worker # We want to enable this only when we're *NOT* using a fuzzing 143*6777b538SAndroid Build Coastguard Worker # engine such as libfuzzer or centipede. It's generally a 144*6777b538SAndroid Build Coastguard Worker # useful option, but it requires sanitizer coverage, and that 145*6777b538SAndroid Build Coastguard Worker # could conceivably disrupt normal unit testing workflows, so we'll 146*6777b538SAndroid Build Coastguard Worker # enable it by default only in sanitizer builds. 147*6777b538SAndroid Build Coastguard Worker # Also be sure not to enable this on non-Chromium builds where 148*6777b538SAndroid Build Coastguard Worker # the required //third_party/fuzztest dependency may be absent. 149*6777b538SAndroid Build Coastguard Worker # TODO(crbug.com/1495713): enable on component builds 150*6777b538SAndroid Build Coastguard Worker enable_fuzztest_fuzz = 151*6777b538SAndroid Build Coastguard Worker !(use_libfuzzer || use_afl || use_centipede || 152*6777b538SAndroid Build Coastguard Worker use_external_fuzzing_engine) && 153*6777b538SAndroid Build Coastguard Worker (is_asan || is_hwasan || is_lsan || is_tsan || is_msan || is_ubsan || 154*6777b538SAndroid Build Coastguard Worker is_ubsan_vptr || is_ubsan_security) && !is_component_build && is_linux && 155*6777b538SAndroid Build Coastguard Worker build_with_chromium 156*6777b538SAndroid Build Coastguard Worker} 157*6777b538SAndroid Build Coastguard Worker 158*6777b538SAndroid Build Coastguard Workerassert(!is_hwasan || (target_os == "android" && target_cpu == "arm64"), 159*6777b538SAndroid Build Coastguard Worker "HWASan only supported on Android ARM64 builds.") 160*6777b538SAndroid Build Coastguard Worker 161*6777b538SAndroid Build Coastguard Workerassert( 162*6777b538SAndroid Build Coastguard Worker !(enable_fuzztest_fuzz && use_libfuzzer), 163*6777b538SAndroid Build Coastguard Worker "Can't specify enable_fuzztest_fuzz and use_libfuzzer. When libfuzzer is enabled, fuzztest executables automatically support --fuzz but provide output that's libfuzzer compatible.") 164*6777b538SAndroid Build Coastguard Worker 165*6777b538SAndroid Build Coastguard Workerassert( 166*6777b538SAndroid Build Coastguard Worker !(enable_fuzztest_fuzz && use_centipede), 167*6777b538SAndroid Build Coastguard Worker "Can't specify enable_fuzztest_fuzz and use_centipede. The same binaries are built in a different mode to add centipede support.") 168*6777b538SAndroid Build Coastguard Worker 169*6777b538SAndroid Build Coastguard Workerassert( 170*6777b538SAndroid Build Coastguard Worker !(enable_fuzztest_fuzz && is_component_build), 171*6777b538SAndroid Build Coastguard Worker "Can't specify enable_fuzztest_fuzz in component builds; fuzztest doesn't yet support it. Consider using use_libfuzzer=true instead which provides superficially similar functionality.") 172*6777b538SAndroid Build Coastguard Worker 173*6777b538SAndroid Build Coastguard Worker# Disable sanitizers for non-target toolchains, and for the toolchain using 174*6777b538SAndroid Build Coastguard Worker# the prebuilt Rust stdlib which has no sanitizer support with it. 175*6777b538SAndroid Build Coastguard Workerif (!is_a_target_toolchain || toolchain_for_rust_host_build_tools) { 176*6777b538SAndroid Build Coastguard Worker is_asan = false 177*6777b538SAndroid Build Coastguard Worker is_cfi = false 178*6777b538SAndroid Build Coastguard Worker is_hwasan = false 179*6777b538SAndroid Build Coastguard Worker is_lsan = false 180*6777b538SAndroid Build Coastguard Worker is_msan = false 181*6777b538SAndroid Build Coastguard Worker is_tsan = false 182*6777b538SAndroid Build Coastguard Worker is_ubsan = false 183*6777b538SAndroid Build Coastguard Worker is_ubsan_no_recover = false 184*6777b538SAndroid Build Coastguard Worker is_ubsan_security = false 185*6777b538SAndroid Build Coastguard Worker is_ubsan_vptr = false 186*6777b538SAndroid Build Coastguard Worker fail_on_san_warnings = false 187*6777b538SAndroid Build Coastguard Worker msan_track_origins = 0 188*6777b538SAndroid Build Coastguard Worker sanitizer_coverage_flags = "" 189*6777b538SAndroid Build Coastguard Worker use_afl = false 190*6777b538SAndroid Build Coastguard Worker use_centipede = false 191*6777b538SAndroid Build Coastguard Worker use_cfi_diag = false 192*6777b538SAndroid Build Coastguard Worker use_cfi_recover = false 193*6777b538SAndroid Build Coastguard Worker use_libfuzzer = false 194*6777b538SAndroid Build Coastguard Worker use_locally_built_instrumented_libraries = false 195*6777b538SAndroid Build Coastguard Worker use_sanitizer_coverage = false 196*6777b538SAndroid Build Coastguard Worker enable_fuzztest_fuzz = false 197*6777b538SAndroid Build Coastguard Worker} else if (current_cpu != "arm64") { 198*6777b538SAndroid Build Coastguard Worker is_hwasan = false 199*6777b538SAndroid Build Coastguard Worker} 200*6777b538SAndroid Build Coastguard Worker 201*6777b538SAndroid Build Coastguard Worker# Use dynamic libraries instrumented by one of the sanitizers instead of the 202*6777b538SAndroid Build Coastguard Worker# standard system libraries. We have instrumented system libraries for msan, 203*6777b538SAndroid Build Coastguard Worker# which requires them to prevent false positives. 204*6777b538SAndroid Build Coastguard Worker# TODO(thakis): Maybe remove this variable. 205*6777b538SAndroid Build Coastguard Workeruse_prebuilt_instrumented_libraries = is_msan 206*6777b538SAndroid Build Coastguard Worker 207*6777b538SAndroid Build Coastguard Worker# Whether we are doing a fuzzer build. Normally this should be checked instead 208*6777b538SAndroid Build Coastguard Worker# of checking "use_libfuzzer || use_afl" because often developers forget to 209*6777b538SAndroid Build Coastguard Worker# check for "use_afl", and "use_centipede" is new. 210*6777b538SAndroid Build Coastguard Workeruse_fuzzing_engine = 211*6777b538SAndroid Build Coastguard Worker use_libfuzzer || use_afl || use_centipede || use_external_fuzzing_engine 212*6777b538SAndroid Build Coastguard Worker 213*6777b538SAndroid Build Coastguard Worker# Whether the current fuzzing engine supports libprotobuf_mutator. 214*6777b538SAndroid Build Coastguard Workeruse_fuzzing_engine_with_lpm = use_libfuzzer || use_centipede 215*6777b538SAndroid Build Coastguard Worker 216*6777b538SAndroid Build Coastguard Worker# Whether the fuzzing engine supports fuzzers which supply their own 217*6777b538SAndroid Build Coastguard Worker# "main" function. 218*6777b538SAndroid Build Coastguard Workerfuzzing_engine_supports_custom_main = use_libfuzzer || use_centipede 219*6777b538SAndroid Build Coastguard Worker 220*6777b538SAndroid Build Coastguard Worker# Args that are in turn dependent on other args must be in a separate 221*6777b538SAndroid Build Coastguard Worker# declare_args block. User overrides are only applied at the end of a 222*6777b538SAndroid Build Coastguard Worker# declare_args block. 223*6777b538SAndroid Build Coastguard Workerdeclare_args() { 224*6777b538SAndroid Build Coastguard Worker # Generates an owners file for each fuzzer test. 225*6777b538SAndroid Build Coastguard Worker # TODO(crbug.com/1194183): Remove this arg when finding OWNERS is faster. 226*6777b538SAndroid Build Coastguard Worker generate_fuzzer_owners = use_fuzzing_engine 227*6777b538SAndroid Build Coastguard Worker 228*6777b538SAndroid Build Coastguard Worker use_sanitizer_coverage = 229*6777b538SAndroid Build Coastguard Worker !use_clang_coverage && (use_fuzzing_engine || enable_fuzztest_fuzz || 230*6777b538SAndroid Build Coastguard Worker sanitizer_coverage_flags != "") 231*6777b538SAndroid Build Coastguard Worker 232*6777b538SAndroid Build Coastguard Worker # https://crbug.com/1002058: Code coverage works inside the sandbox via the 233*6777b538SAndroid Build Coastguard Worker # help of several helper IPCs. Unfortunately, the sandbox-only path does not 234*6777b538SAndroid Build Coastguard Worker # work well for fuzzing builds. Since fuzzing builds already disable the 235*6777b538SAndroid Build Coastguard Worker # sandbox when dumping coverage, limit the sandbox-only path to non-fuzzing 236*6777b538SAndroid Build Coastguard Worker # builds. 237*6777b538SAndroid Build Coastguard Worker # Everything is IPC on Fuchsia, so this workaround for code coverage inside 238*6777b538SAndroid Build Coastguard Worker # the sandbox does not apply. 239*6777b538SAndroid Build Coastguard Worker use_clang_profiling_inside_sandbox = 240*6777b538SAndroid Build Coastguard Worker use_clang_profiling && !use_fuzzing_engine && !is_fuchsia 241*6777b538SAndroid Build Coastguard Worker} 242*6777b538SAndroid Build Coastguard Worker 243*6777b538SAndroid Build Coastguard Workerif (sanitizer_coverage_flags == "") { 244*6777b538SAndroid Build Coastguard Worker if (enable_fuzztest_fuzz) { 245*6777b538SAndroid Build Coastguard Worker # ./fuzztest_executable --fuzz= 246*6777b538SAndroid Build Coastguard Worker # requires only this single type of coverage 247*6777b538SAndroid Build Coastguard Worker sanitizer_coverage_flags = "inline-8bit-counters" 248*6777b538SAndroid Build Coastguard Worker } else if (use_fuzzing_engine) { 249*6777b538SAndroid Build Coastguard Worker sanitizer_coverage_flags = "trace-pc-guard" 250*6777b538SAndroid Build Coastguard Worker if (use_centipede) { 251*6777b538SAndroid Build Coastguard Worker # Centipede's minimal flags are listed in //third_party/fuzztest/src/centipede/clang-flags.txt. 252*6777b538SAndroid Build Coastguard Worker # But, for users like Chromium using an up-to-date clang, we can also 253*6777b538SAndroid Build Coastguard Worker # enable extra optional types of coverage which may make Centipede more 254*6777b538SAndroid Build Coastguard Worker # effective. This list is not currently documented and has been derived 255*6777b538SAndroid Build Coastguard Worker # from discussion with centipede creators (though one is warned about at 256*6777b538SAndroid Build Coastguard Worker # https://github.com/google/centipede/blob/main/centipede_callbacks.cc#L68) 257*6777b538SAndroid Build Coastguard Worker sanitizer_coverage_flags = sanitizer_coverage_flags + 258*6777b538SAndroid Build Coastguard Worker ",pc-table,trace-cmp,control-flow,trace-loads" 259*6777b538SAndroid Build Coastguard Worker } 260*6777b538SAndroid Build Coastguard Worker } else if (use_sanitizer_coverage) { 261*6777b538SAndroid Build Coastguard Worker sanitizer_coverage_flags = "trace-pc-guard,indirect-calls" 262*6777b538SAndroid Build Coastguard Worker } 263*6777b538SAndroid Build Coastguard Worker} 264*6777b538SAndroid Build Coastguard Worker 265*6777b538SAndroid Build Coastguard Worker# Whether we are linking against a sanitizer runtime library. Among other 266*6777b538SAndroid Build Coastguard Worker# things, this changes the default symbol level and other settings in order to 267*6777b538SAndroid Build Coastguard Worker# prepare to create stack traces "live" using the sanitizer runtime. 268*6777b538SAndroid Build Coastguard Workerusing_sanitizer = 269*6777b538SAndroid Build Coastguard Worker is_asan || is_hwasan || is_lsan || is_tsan || is_msan || is_ubsan || 270*6777b538SAndroid Build Coastguard Worker is_ubsan_vptr || is_ubsan_security || use_sanitizer_coverage || use_cfi_diag 271*6777b538SAndroid Build Coastguard Worker 272*6777b538SAndroid Build Coastguard Workerassert(!using_sanitizer || is_clang, 273*6777b538SAndroid Build Coastguard Worker "Sanitizers (is_*san) require setting is_clang = true in 'gn args'") 274*6777b538SAndroid Build Coastguard Worker 275*6777b538SAndroid Build Coastguard Workerassert(!is_cfi || is_clang, 276*6777b538SAndroid Build Coastguard Worker "is_cfi requires setting is_clang = true in 'gn args'") 277*6777b538SAndroid Build Coastguard Worker 278*6777b538SAndroid Build Coastguard Workerprebuilt_instrumented_libraries_available = 279*6777b538SAndroid Build Coastguard Worker is_msan && (msan_track_origins == 0 || msan_track_origins == 2) 280*6777b538SAndroid Build Coastguard Worker 281*6777b538SAndroid Build Coastguard Workerif (use_libfuzzer && (is_linux || is_chromeos)) { 282*6777b538SAndroid Build Coastguard Worker if (is_asan) { 283*6777b538SAndroid Build Coastguard Worker # We do leak checking with libFuzzer on Linux. Set is_lsan for code that 284*6777b538SAndroid Build Coastguard Worker # relies on LEAK_SANITIZER define to avoid false positives. 285*6777b538SAndroid Build Coastguard Worker is_lsan = true 286*6777b538SAndroid Build Coastguard Worker } 287*6777b538SAndroid Build Coastguard Worker} 288*6777b538SAndroid Build Coastguard Worker 289*6777b538SAndroid Build Coastguard Worker# MSan only links Chrome properly in release builds (brettw -- 9/1/2015). The 290*6777b538SAndroid Build Coastguard Worker# same is possibly true for the other non-ASan sanitizers. But regardless of 291*6777b538SAndroid Build Coastguard Worker# whether it links, one would normally never run a sanitizer in debug mode. 292*6777b538SAndroid Build Coastguard Worker# Running in debug mode probably indicates you forgot to set the "is_debug = 293*6777b538SAndroid Build Coastguard Worker# false" flag in the build args. ASan seems to run fine in debug mode. 294*6777b538SAndroid Build Coastguard Worker# 295*6777b538SAndroid Build Coastguard Worker# If you find a use-case where you want to compile a sanitizer in debug mode 296*6777b538SAndroid Build Coastguard Worker# and have verified it works, ask brettw and we can consider removing it from 297*6777b538SAndroid Build Coastguard Worker# this condition. We may also be able to find another way to enable your case 298*6777b538SAndroid Build Coastguard Worker# without having people accidentally get broken builds by compiling an 299*6777b538SAndroid Build Coastguard Worker# unsupported or unadvisable configurations. 300*6777b538SAndroid Build Coastguard Worker# 301*6777b538SAndroid Build Coastguard Worker# For one-off testing, just comment this assertion out. 302*6777b538SAndroid Build Coastguard Workerassert(!is_debug || !(is_msan || is_ubsan || is_ubsan_vptr), 303*6777b538SAndroid Build Coastguard Worker "Sanitizers should generally be used in release (set is_debug=false).") 304*6777b538SAndroid Build Coastguard Worker 305*6777b538SAndroid Build Coastguard Workerassert(!is_msan || ((is_linux || is_chromeos) && current_cpu == "x64"), 306*6777b538SAndroid Build Coastguard Worker "MSan currently only works on 64-bit Linux and ChromeOS builds.") 307*6777b538SAndroid Build Coastguard Worker 308*6777b538SAndroid Build Coastguard Workerassert(!is_lsan || is_asan, "is_lsan = true requires is_asan = true also.") 309*6777b538SAndroid Build Coastguard Worker 310*6777b538SAndroid Build Coastguard Worker# ASAN build on Windows is not working in debug mode. Intercepting memory 311*6777b538SAndroid Build Coastguard Worker# allocation functions is hard on Windows and not yet implemented in LLVM. 312*6777b538SAndroid Build Coastguard Workerassert(!is_win || !is_debug || !is_asan, 313*6777b538SAndroid Build Coastguard Worker "ASan on Windows doesn't work in debug (set is_debug=false).") 314*6777b538SAndroid Build Coastguard Worker 315*6777b538SAndroid Build Coastguard Worker# libFuzzer targets can fail to build or behave incorrectly when built without 316*6777b538SAndroid Build Coastguard Worker# ASAN on Windows. 317*6777b538SAndroid Build Coastguard Workerassert(!is_win || !use_libfuzzer || is_asan, 318*6777b538SAndroid Build Coastguard Worker "use_libfuzzer on Windows requires setting is_asan = true") 319*6777b538SAndroid Build Coastguard Worker 320*6777b538SAndroid Build Coastguard Worker# Make sure that if we recover on detection (i.e. not crash), diagnostics are 321*6777b538SAndroid Build Coastguard Worker# printed. 322*6777b538SAndroid Build Coastguard Workerassert(!use_cfi_recover || use_cfi_diag, 323*6777b538SAndroid Build Coastguard Worker "Only use CFI recovery together with diagnostics.") 324*6777b538SAndroid Build Coastguard Worker 325*6777b538SAndroid Build Coastguard Worker# TODO(crbug.com/753445): the use_sanitizer_coverage arg is currently 326*6777b538SAndroid Build Coastguard Worker# not supported by the Chromium mac_clang_x64 toolchain on iOS distribution. 327*6777b538SAndroid Build Coastguard Worker# The coverage works with iOS toolchain but it is broken when the mac 328*6777b538SAndroid Build Coastguard Worker# toolchain is used as a secondary one on iOS distribution. E.g., it should be 329*6777b538SAndroid Build Coastguard Worker# possible to build the "net" target for iOS with the sanitizer coverage 330*6777b538SAndroid Build Coastguard Worker# enabled. 331*6777b538SAndroid Build Coastguard Workerassert( 332*6777b538SAndroid Build Coastguard Worker !(use_sanitizer_coverage && is_mac && target_os == "ios"), 333*6777b538SAndroid Build Coastguard Worker "crbug.com/753445: use_sanitizer_coverage=true is not supported by the " + 334*6777b538SAndroid Build Coastguard Worker "Chromium mac_clang_x64 toolchain on iOS distribution. Please set " + 335*6777b538SAndroid Build Coastguard Worker "the argument value to false.") 336*6777b538SAndroid Build Coastguard Worker 337*6777b538SAndroid Build Coastguard Workerassert( 338*6777b538SAndroid Build Coastguard Worker sanitizer_coverage_allowlist == "" || use_sanitizer_coverage, 339*6777b538SAndroid Build Coastguard Worker "Can't specify a sanitizer coverage allowlist without using sanitizer coverage.") 340*6777b538SAndroid Build Coastguard Worker 341*6777b538SAndroid Build Coastguard Worker# Use these lists of configs to disable instrumenting code that is part of a 342*6777b538SAndroid Build Coastguard Worker# fuzzer, but which isn't being targeted (such as libprotobuf-mutator, *.pb.cc 343*6777b538SAndroid Build Coastguard Worker# and libprotobuf when they are built as part of a proto fuzzer). Adding or 344*6777b538SAndroid Build Coastguard Worker# removing these lists does not have any effect if use_libfuzzer or use_afl are 345*6777b538SAndroid Build Coastguard Worker# not passed as arguments to gn. 346*6777b538SAndroid Build Coastguard Workernot_fuzzed_remove_configs = [] 347*6777b538SAndroid Build Coastguard Workernot_fuzzed_remove_nonasan_configs = [] 348*6777b538SAndroid Build Coastguard Worker 349*6777b538SAndroid Build Coastguard Workerif (use_fuzzing_engine) { 350*6777b538SAndroid Build Coastguard Worker # Removing coverage should always just work. 351*6777b538SAndroid Build Coastguard Worker not_fuzzed_remove_configs += [ "//build/config/coverage:default_coverage" ] 352*6777b538SAndroid Build Coastguard Worker not_fuzzed_remove_nonasan_configs += 353*6777b538SAndroid Build Coastguard Worker [ "//build/config/coverage:default_coverage" ] 354*6777b538SAndroid Build Coastguard Worker 355*6777b538SAndroid Build Coastguard Worker if (!is_msan) { 356*6777b538SAndroid Build Coastguard Worker # Allow sanitizer instrumentation to be removed if we are not using MSan 357*6777b538SAndroid Build Coastguard Worker # since binaries cannot be partially instrumented with MSan. 358*6777b538SAndroid Build Coastguard Worker not_fuzzed_remove_configs += 359*6777b538SAndroid Build Coastguard Worker [ "//build/config/sanitizers:default_sanitizer_flags" ] 360*6777b538SAndroid Build Coastguard Worker 361*6777b538SAndroid Build Coastguard Worker # Certain parts of binaries must be instrumented with ASan if the rest of 362*6777b538SAndroid Build Coastguard Worker # the binary is. For these, only remove non-ASan sanitizer instrumentation. 363*6777b538SAndroid Build Coastguard Worker if (!is_asan) { 364*6777b538SAndroid Build Coastguard Worker not_fuzzed_remove_nonasan_configs += 365*6777b538SAndroid Build Coastguard Worker [ "//build/config/sanitizers:default_sanitizer_flags" ] 366*6777b538SAndroid Build Coastguard Worker 367*6777b538SAndroid Build Coastguard Worker assert(not_fuzzed_remove_nonasan_configs == not_fuzzed_remove_configs) 368*6777b538SAndroid Build Coastguard Worker } 369*6777b538SAndroid Build Coastguard Worker } 370*6777b538SAndroid Build Coastguard Worker} 371*6777b538SAndroid Build Coastguard Worker 372*6777b538SAndroid Build Coastguard Worker# Options common to different fuzzer engines. 373*6777b538SAndroid Build Coastguard Worker# Engine should be compiled without coverage (infinite loop in trace_cmp). 374*6777b538SAndroid Build Coastguard Workerfuzzing_engine_remove_configs = [ 375*6777b538SAndroid Build Coastguard Worker "//build/config/coverage:default_coverage", 376*6777b538SAndroid Build Coastguard Worker "//build/config/sanitizers:default_sanitizer_flags", 377*6777b538SAndroid Build Coastguard Worker] 378*6777b538SAndroid Build Coastguard Worker 379*6777b538SAndroid Build Coastguard Worker# Add any sanitizer flags back. In MSAN builds, instrumenting libfuzzer with 380*6777b538SAndroid Build Coastguard Worker# MSAN is necessary since all parts of the binary need to be instrumented for it 381*6777b538SAndroid Build Coastguard Worker# to work. ASAN builds are more subtle: libfuzzer depends on features from the 382*6777b538SAndroid Build Coastguard Worker# C++ STL. If it were not instrumented, templates would be insantiated without 383*6777b538SAndroid Build Coastguard Worker# ASAN from libfuzzer and with ASAN in other TUs. The linker might merge 384*6777b538SAndroid Build Coastguard Worker# instrumented template instantiations with non-instrumented ones (which could 385*6777b538SAndroid Build Coastguard Worker# have a different ABI) in the final binary, which is problematic for TUs 386*6777b538SAndroid Build Coastguard Worker# expecting one particular ABI (https://crbug.com/915422). The other sanitizers 387*6777b538SAndroid Build Coastguard Worker# are added back for the same reason. 388*6777b538SAndroid Build Coastguard Workerfuzzing_engine_add_configs = 389*6777b538SAndroid Build Coastguard Worker [ "//build/config/sanitizers:default_sanitizer_flags_but_coverage" ] 390