1 //===-- tsan_flags.inc ------------------------------------------*- C++ -*-===//
3 // This file is distributed under the University of Illinois Open Source
4 // License. See LICENSE.TXT for details.
6 //===----------------------------------------------------------------------===//
10 //===----------------------------------------------------------------------===//
12 # error "Define TSAN_FLAG prior to including this file!"
15 // TSAN_FLAG(Type, Name, DefaultValue, Description)
16 // See COMMON_FLAG in sanitizer_flags.inc for more details.
18 TSAN_FLAG(bool, enable_annotations, true,
19 "Enable dynamic annotations, otherwise they are no-ops.")
20 // Suppress a race report if we've already output another race report
21 // with the same stack.
22 TSAN_FLAG(bool, suppress_equal_stacks, true,
23 "Suppress a race report if we've already output another race report "
24 "with the same stack.")
25 TSAN_FLAG(bool, suppress_equal_addresses, true,
26 "Suppress a race report if we've already output another race report "
27 "on the same address.")
29 TSAN_FLAG(bool, report_bugs, true,
30 "Turns off bug reporting entirely (useful for benchmarking).")
31 TSAN_FLAG(bool, report_thread_leaks, true, "Report thread leaks at exit?")
32 TSAN_FLAG(bool, report_destroy_locked, true,
33 "Report destruction of a locked mutex?")
34 TSAN_FLAG(bool, report_mutex_bugs, true,
35 "Report incorrect usages of mutexes and mutex annotations?")
36 TSAN_FLAG(bool, report_signal_unsafe, true,
37 "Report violations of async signal-safety "
38 "(e.g. malloc() call from a signal handler).")
39 TSAN_FLAG(bool, report_atomic_races, true,
40 "Report races between atomic and plain memory accesses.")
42 bool, force_seq_cst_atomics, false,
43 "If set, all atomics are effectively sequentially consistent (seq_cst), "
44 "regardless of what user actually specified.")
45 TSAN_FLAG(bool, print_benign, false, "Print matched \"benign\" races at exit.")
46 TSAN_FLAG(bool, halt_on_error, false, "Exit after first reported error.")
47 TSAN_FLAG(int, atexit_sleep_ms, 1000,
48 "Sleep in main thread before exiting for that many ms "
49 "(useful to catch \"at exit\" races).")
50 TSAN_FLAG(const char *, profile_memory, "",
51 "If set, periodically write memory profile to that file.")
52 TSAN_FLAG(int, flush_memory_ms, 0, "Flush shadow memory every X ms.")
53 TSAN_FLAG(int, flush_symbolizer_ms, 5000, "Flush symbolizer caches every X ms.")
55 int, memory_limit_mb, 0,
56 "Resident memory limit in MB to aim at."
57 "If the process consumes more memory, then TSan will flush shadow memory.")
58 TSAN_FLAG(bool, stop_on_start, false,
59 "Stops on start until __tsan_resume() is called (for debugging).")
60 TSAN_FLAG(bool, running_on_valgrind, false,
61 "Controls whether RunningOnValgrind() returns true or false.")
63 int, history_size, kGoMode ? 1 : 3, // There are a lot of goroutines in Go.
64 "Per-thread history size, controls how many previous memory accesses "
65 "are remembered per thread. Possible values are [0..7]. "
66 "history_size=0 amounts to 32K memory accesses. Each next value doubles "
67 "the amount of memory accesses, up to history_size=7 that amounts to "
68 "4M memory accesses. The default value is 2 (128K memory accesses).")
69 TSAN_FLAG(int, io_sync, 1,
70 "Controls level of synchronization implied by IO operations. "
71 "0 - no synchronization "
72 "1 - reasonable level of synchronization (write->read)"
73 "2 - global synchronization of all IO operations.")
74 TSAN_FLAG(bool, die_after_fork, true,
75 "Die after multi-threaded fork if the child creates new threads.")
76 TSAN_FLAG(const char *, suppressions, "", "Suppressions file name.")