1 # This file lists the functions, object files and source files 2 # which should be ignored (i.e. not instrumented) by ThreadSanitizer. 3 # See http://code.google.com/p/data-race-test/wiki/ThreadSanitizerIgnores. 4 5 # ignore these libraries 6 obj:*/libfreetype* 7 obj:*/libdbus* 8 9 # we ignore the whole NSS library for now since 10 # its instrumentation is very slow. 11 # TODO(timurrrr): investigate whether we need to instrument it 12 obj:*/libnss* 13 obj:*/nss/* 14 15 # ignore pulseaudio - We don't have symbols there and it can be slow otherwise 16 obj:*/libpulse*.so* 17 18 # ignore this standard stuff 19 fun:clone 20 fun:fork 21 fun:pthread_* 22 fun_r:_pthread_exit 23 fun_r:_pthread_free_pthread_onstack 24 fun_r:random_r 25 fun_r:random 26 fun_r:rand 27 fun_r:srand 28 fun:__new_exitfn 29 fun:_dl_* 30 fun:__dl_* 31 fun:*_setjmp* 32 33 # dark magic with 'errno' here. 34 fun:sys_* 35 36 # ignore libc's printf functions 37 fun_r:_IO_* 38 fun:fwrite 39 fun:fflush 40 41 # False reports on std::string internals, see 42 # http://code.google.com/p/data-race-test/issues/detail?id=40 43 fun:*_M_mutateE* 44 fun_r:*_M_set_length_and_sharable* 45 fun:*_M_is_leaked* 46 fun:*_M_is_shared* 47 fun:*_M_set_leaked* 48 fun:*_M_set_sharable* 49 50 # Comparison of std::strings sometimes takes a lot of time but we don't really 51 # need precise stack traces there. 52 fun_hist:_ZStltIcSt11char_traitsIcESaIcEEbRKSbIT_T0_T1_ES8_ 53 fun_hist:_ZNKSs7compareERKSs 54 55 # Don't instrument intercepts 56 src:*ts_valgrind_intercepts.c 57 58 ################################################################## 59 # Don't instrument synchronization code 60 src:*base/threading/thread_local_storage* 61 src:*base/stats_counters* 62 src:*base/synchronization/condition_variable* 63 src:*base/synchronization/lock* 64 src:*base/synchronization/waitable_event* 65 66 # Don't instrument code dealing with atomics (base::subtle) 67 fun:*base*subtle*Release_Store* 68 fun:*base*subtle*NoBarrier_CompareAndSwap* 69 fun:*base*subtle*NoBarrier_Load* 70 # Keep some mangling so we don't match NoBarrier_AtomicIncrement 71 fun:*base*subtle23Barrier_AtomicIncrement* 72 73 # MD5 computations are very slow due since sums are computed by 74 # repeatedly calling tiny functions and is unlikely to race with 75 # anything. 76 src:*base/md5* 77 78 # Don't instrument tcmalloc 79 src:*/tcmalloc/* 80 81 # This function is heavy in net_unittests 82 fun_r:*disk_cache*BackendImpl*CheckAllEntries* 83 84 # V8 is a hot-spot under ThreadSanitizer. 85 # Lots of tiny functions there... 86 # TODO(timurrrr): 87 # Can we miss data races on V8 objects due to non thread-safe API calls 88 # if we don't instrument v8::internals? 89 fun_r:*v8*internal* 90 91 # unibrow namespace contains lots of tiny unicode conversion functions. 92 fun_hist:*unibrow* 93 94 # Histogram has tiny functions that can be called frequently 95 fun_hist:*Histogram* 96 # Recursively ignore Histrogram::Add and friends, see http://crbug.com/62694. 97 fun_r:*4base*9Histogram*3Add* 98 fun_r:*4base*16HistogramSamples*3Add* 99 fun_r:*4base*13HistogramBase*7AddTime* 100 101 # TODO(timurrrr): SKIA - needs separate testing? 102 # SKIA unittest is single-threaded... 103 # SKIA uses un-annotated atomic refcount and other sync stuff 104 # some functions are HEAVY like png, jpeg decoding 105 src:*third_party/skia* 106 107 # WebKit hotspot 108 fun:*png_write* 109 110 # This function generates 25% of memory accesses in net_unittests 111 fun:*icu_4_2*UnicodeSet*add* 112 113 # SQLite has lots of tiny functions and produce too many segments on some tests. 114 # See http://crbug.com/56511 115 fun_hist:*sqlite* 116 117 # There's some weird failure test going on in this tiny test function in sqlite 118 fun_r:threadLockingTest 119 120 # Ignore accesses below GetCurrentThreadIdentifier. 121 # There is a benign race which is hard to suppress properly, 122 # see http://crbug.com/44580 123 fun_r:*BrowserThread*GetCurrentThreadIdentifier* 124 125 # BrowserThread accesses MessageLoop::current() in ::CurrentlyOn. 126 # We can't use suppressions to hide these reports since the concurrent stack 127 # is simply "base::Thread::ThreadMain" 128 # See http://crbug.com/63678 129 fun_r:*BrowserThread*CurrentlyOn* 130 131 # zlib is smarter than we are, see http://www.zlib.net/zlib_faq.html#faq36 132 fun_r:inflate 133 # zlib-related reports, not investigated yet. See http://crbug.com/70932 134 fun_r:*remoting*CompressorZlib*Process* 135 136 # X11 reads the _XErrorFunction callback in a racey way, see 137 # http://crbug.com/65278 138 fun:XSetErrorHandler 139 140 fun:*IPC*Logging*Enable* 141 fun:*IPC*Logging*Disable* 142 143 # TSan doesn't support lockf and hence shared memory locks in this function; 144 # http://crbug.com/45083 145 fun_r:*base*StatsTable*AddCounter* 146 147 # TSan doesn't understand internal libc locks, see http://crbug.com/71435 148 fun_r:mbsrtowcs 149 150 # gethostbyname2_r is thread-safe, however ThreadSanitizer reports races inside it and 151 # (sometimes) in __nss_* functions below it. 152 # This may be related to 153 # https://bugs.launchpad.net/ubuntu/+source/glibc/+bug/59449 154 fun_r:gethostbyname2_r* 155 156 # TODO(timurrrr): remove this when TSan is updated past r3232 157 fun_r:gaih_inet 158 159 # Strange reports below _IO_getline, every time in "Concurrent access". 160 # Probably the reports are there since we're missing the libc internal locks 161 fun_r:_IO_getline* 162 163 # A benign race in glib on something called "contention_counter". 164 fun:g_slice_alloc 165 166 # A benign race in glibc on "random_time_bits". 167 fun:__gen_tempname 168 169 # A probably-benign race on '__have_o_cloexec' in opendir/__alloc_dir, 170 # see http://crbug.com/125928. 171 fun_r:__alloc_dir 172 fun_r:opendir 173 174 # The sqlite cache is racing against a few different stacktraces, 175 # so let's ignore it recursively. See http://crbug.com/84094 176 fun_r:pcache1Fetch 177 178 # "Suppress" a data race in TraceLog::GetCategory which has 179 # fun:MessageLoop::RunTask at the top of the "current" stack which we don't want 180 # to suppress. See http://crbug.com/98926 181 fun:*base*debug*TraceLog*GetCategoryInternal* 182 183 # libc threading on GCC 4.6 184 fun:arena_thread_freeres 185 186 # __strncasecmp_l_ssse3 overreads the buffer causing TSan to report a data race 187 # on another object. See http://crbug.com/177074 188 fun:*strncasecmp* 189 fun:*strcasecmp* 190