xref: /aosp_15_r20/external/cronet/build/config/sanitizers/sanitizers.gni (revision 6777b5387eb2ff775bb5750e3f5d96f37fb7352b)
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