blob: 879ea5d8aba256bfb1399fd5a19c23f4df0e2e34 [file] [log] [blame]
bart9e4554c2009-08-02 07:46:43 +00001#
2# Suppression patterns for ld, the dynamic loader.
3#
4
5# Suppress all data races triggered by ld.
sewardjaf44c822007-11-25 14:01:38 +00006{
bart9e4554c2009-08-02 07:46:43 +00007 drd-ld
bartef1b9722008-07-04 15:34:23 +00008 drd:ConflictingAccess
sewardj8b09d4f2007-12-04 21:27:18 +00009 obj:/lib*/ld-*.so
sewardjaf44c822007-11-25 14:01:38 +000010}
bart9e4554c2009-08-02 07:46:43 +000011
12#
13# Suppression patterns for libc.
14#
15
16# Suppress all data races where the topmost frame is inside libc.so. Although
17# this could hide some real data races, unfortunately this is the only way to
18# not report any false positives on stdio functions. The glibc functions
19# manipulating FILE objects use locking primitives that cannot be intercepted
20# easily. See also the definitions of _IO_lock_lock() etc. in the file
21# nptl/sysdeps/pthread/bits/stdio-lock.h in the glibc source tree.
sewardjaf44c822007-11-25 14:01:38 +000022{
bart9e4554c2009-08-02 07:46:43 +000023 drd-libc-stdio
bart15c67b42009-01-29 09:57:22 +000024 drd:ConflictingAccess
25 obj:/lib*/libc-*
26}
bart9e4554c2009-08-02 07:46:43 +000027
28#
29# Suppression patterns for libstdc++, the implementation of the standard C++
30# library included with the gcc compiler.
31#
32# Note: several versions of the libstdc++ library (4.2.2, 4.3.2, 4.4.0, 4.5.0
33# and their predecessors) contain an implementation of the std::string class
34# that triggers conflicting memory accesses. See also
35# http://gcc.gnu.org/bugzilla/show_bug.cgi?id=40518
36#
37
38# {
39# drd-libstdc++-std::string::string()
40# drd:ConflictingAccess
41# fun:_ZNSsC1ERKSs
42# }
43
bart5478f842010-05-12 10:01:32 +000044{
45 drd-libstdc++-cxa_guard_release
46 drd:CondErr
47 fun:pthread_cond_broadcast@*
48 fun:__cxa_guard_release
49}
50
51
bart9e4554c2009-08-02 07:46:43 +000052#
53# Suppression patterns for libpthread.
54#
55
bart15c67b42009-01-29 09:57:22 +000056{
bart9e4554c2009-08-02 07:46:43 +000057 drd-libpthread-pthread_create
bartef1b9722008-07-04 15:34:23 +000058 drd:ConflictingAccess
bart00408ca2008-11-17 18:22:10 +000059 ...
bartebca7862008-03-09 19:21:14 +000060 fun:pthread_create*
61}
62{
bart0e08b102009-08-02 08:35:05 +000063 drd-libpthread-pthread_join
64 drd:ConflictingAccess
65 fun:pthread_join
66 fun:pthread_join
67}
68{
69 drd-libpthread-__deallocate_stack
bartef1b9722008-07-04 15:34:23 +000070 drd:ConflictingAccess
barta39b9a02008-11-17 17:57:15 +000071 ...
bartcea0e952008-03-01 10:50:45 +000072 fun:__deallocate_stack
bartcea0e952008-03-01 10:50:45 +000073}
74{
barta13f0222010-07-29 07:52:37 +000075 drd-libpthread-__free_stacks
76 drd:ConflictingAccess
77 fun:__free_stacks
78}
79{
bart0e08b102009-08-02 08:35:05 +000080 drd-libpthread-__free_tcb
81 drd:ConflictingAccess
82 ...
83 fun:__free_tcb
84}
85{
bart3a2bcf12010-06-08 15:00:18 +000086 drd-libpthread-__nptl_deallocate_tsd
87 drd:ConflictingAccess
88 fun:__nptl_deallocate_tsd
89}
90{
bart9e4554c2009-08-02 07:46:43 +000091 drd-libpthread-pthread_detach
bartef1b9722008-07-04 15:34:23 +000092 drd:ConflictingAccess
sewardjaf44c822007-11-25 14:01:38 +000093 fun:pthread_detach
94 fun:pthread_detach
95}
96{
bart343106c2010-08-29 16:19:45 +000097 drd-libpthread-pthread_cancel_init
98 drd:ConflictingAccess
99 fun:pthread_cancel_init
100}
101{
bart9e4554c2009-08-02 07:46:43 +0000102 drd-libpthread-_Unwind_ForcedUnwind
bart81db8d42008-09-27 12:43:52 +0000103 drd:ConflictingAccess
bartb98b2d52009-07-10 06:48:13 +0000104 ...
105 fun:_Unwind_ForcedUnwind
bart81db8d42008-09-27 12:43:52 +0000106}
107{
bartcedece12010-08-17 15:19:55 +0000108 drd-libpthread-_Unwind_GetCFA
109 drd:ConflictingAccess
110 fun:_Unwind_GetCFA
111}
112{
bart9e4554c2009-08-02 07:46:43 +0000113 drd-libpthread-_Unwind_Resume
bartf0c61c22008-09-27 13:14:06 +0000114 drd:ConflictingAccess
bartb98b2d52009-07-10 06:48:13 +0000115 ...
bart9e4554c2009-08-02 07:46:43 +0000116 fun:_Unwind_Resume
barta238ee52008-09-27 13:23:41 +0000117}
bart2f2d6792009-08-14 13:22:48 +0000118{
bartcedece12010-08-17 15:19:55 +0000119 drd-libpthread-?
120 drd:ConflictingAccess
121 obj:/lib/libgcc_s.so.1
bartcedece12010-08-17 15:19:55 +0000122}
123{
bart2f2d6792009-08-14 13:22:48 +0000124 drd-libpthread-nanosleep
125 drd:ConflictingAccess
126 fun:nanosleep
127}
bart9e4554c2009-08-02 07:46:43 +0000128
129#
130# Suppression patterns for libgomp.
131#
132
133# Unfortunately many statements in libgomp trigger conflicting accesses. It is
134# not clear to me which of these are safe and which ones not. See also
135# http://gcc.gnu.org/bugzilla/show_bug.cgi?id=40362
barta238ee52008-09-27 13:23:41 +0000136{
bart9e4554c2009-08-02 07:46:43 +0000137 drd-libgomp
bartef1b9722008-07-04 15:34:23 +0000138 drd:ConflictingAccess
bart459caeb2008-03-11 19:46:45 +0000139 obj:/usr/lib*/libgomp.so*
bart459caeb2008-03-11 19:46:45 +0000140}
bart9e4554c2009-08-02 07:46:43 +0000141
142#
143# Suppression patterns for libX11.
144#
145
bartdd7a30d2008-03-22 17:36:23 +0000146{
bart9e4554c2009-08-02 07:46:43 +0000147 drd-libX11-XCreateFontSet
bartef1b9722008-07-04 15:34:23 +0000148 drd:CondErr
bart9483fd32008-07-01 14:13:25 +0000149 fun:pthread_cond_init*
150 fun:_XReply
151 fun:XListFontsWithInfo
152 obj:/usr/lib*/libX11.so*
153 fun:XCreateOC
154 fun:XCreateFontSet
155}
bart9e4554c2009-08-02 07:46:43 +0000156
157#
158# Suppression patterns for libxcb.
159#
160
bart9483fd32008-07-01 14:13:25 +0000161{
bart9e4554c2009-08-02 07:46:43 +0000162 drd-libxcb-xcb_wait_for_reply
bartef1b9722008-07-04 15:34:23 +0000163 drd:CondErr
bartdd7a30d2008-03-22 17:36:23 +0000164 fun:pthread_cond_destroy*
165 fun:xcb_wait_for_reply
166}
bart9e4554c2009-08-02 07:46:43 +0000167
168#
169# Suppression patterns for libglib.
170#
171
barte53fb262008-07-08 09:29:19 +0000172{
bart9e4554c2009-08-02 07:46:43 +0000173 drd-libglib-access-g_threads_got_initialized
barte53fb262008-07-08 09:29:19 +0000174 drd:ConflictingAccess
barta99ab012008-12-27 09:19:01 +0000175 ...
barte53fb262008-07-08 09:29:19 +0000176 fun:g_slice_alloc
177 fun:g_ptr_array_sized_new
barte53fb262008-07-08 09:29:19 +0000178}
179{
bart9e4554c2009-08-02 07:46:43 +0000180 drd-libglib-access-g_threads_got_initialized
barte53fb262008-07-08 09:29:19 +0000181 drd:ConflictingAccess
bartcedece12010-08-17 15:19:55 +0000182 ...
barte53fb262008-07-08 09:29:19 +0000183 fun:_ZN27QEventDispatcherGlibPrivateC1EP13_GMainContext
184 fun:_ZN20QEventDispatcherGlibC1EP7QObject
185 obj:/usr/lib*/libQtCore.so.4.*
186 obj:/usr/lib*/libQtCore.so.4.*
187}
188{
bart9e4554c2009-08-02 07:46:43 +0000189 drd-libglib-access-g_mem_initialized
barte53fb262008-07-08 09:29:19 +0000190 drd:ConflictingAccess
191 fun:g_malloc0
192}
193{
bart9e4554c2009-08-02 07:46:43 +0000194 drd-libglib-g_private_get_posix_impl
barte53fb262008-07-08 09:29:19 +0000195 drd:ConflictingAccess
196 fun:g_private_get_posix_impl
197}
198{
bart9e4554c2009-08-02 07:46:43 +0000199 drd-libglib-g_private_set_posix_impl
barte53fb262008-07-08 09:29:19 +0000200 drd:ConflictingAccess
201 fun:g_private_set_posix_impl
202}
203{
bart9e4554c2009-08-02 07:46:43 +0000204 drd-libglib-g_get_language_names
barta99ab012008-12-27 09:19:01 +0000205 drd:ConflictingAccess
206 fun:g_slice_free_chain_with_offset
barta99ab012008-12-27 09:19:01 +0000207}
bart75516e52009-08-10 14:13:12 +0000208{
209 drd-libglib-g_main_context_new
210 drd:ConflictingAccess
211 fun:fcntl
212 obj:/usr/lib*/libglib-*.so*
213 fun:g_main_context_new
214}
bart9e4554c2009-08-02 07:46:43 +0000215
216#
217# Suppression patterns for libQtCore.
218#
219
barta99ab012008-12-27 09:19:01 +0000220{
bart9e4554c2009-08-02 07:46:43 +0000221 drd-libQtCore-deref-that-calls-QThreadData-destructor
bartddead322009-02-14 15:47:53 +0000222 drd:ConflictingAccess
223 fun:_ZN11QThreadDataD1Ev
bartddead322009-02-14 15:47:53 +0000224 obj:/usr/lib*/libQtCore.so.4.*
225}
226{
bart9e4554c2009-08-02 07:46:43 +0000227 drd-libQtCore-4.0/4.1-Q_GLOBAL_STATIC-connectionList
barteb339152008-07-29 13:01:16 +0000228 drd:ConflictingAccess
229 obj:/usr/lib*/libQtCore.so.4.*
230 fun:_ZN11QMetaObject8activateEP7QObjectiiPPv
231 fun:_ZN11QMetaObject8activateEP7QObjectPKS_iPPv
232}
233{
bart9e4554c2009-08-02 07:46:43 +0000234 drd-libQtCore-QObjectPrivate::clearGuards(QObject*)
barte53fb262008-07-08 09:29:19 +0000235 drd:ConflictingAccess
236 fun:_ZN14QReadWriteLock12lockForWriteEv
237 fun:_ZN14QObjectPrivate11clearGuardsEP7QObject
238 fun:_ZN7QObjectD2Ev
barte53fb262008-07-08 09:29:19 +0000239}
bartf0d65952008-08-02 10:03:37 +0000240{
bart9e4554c2009-08-02 07:46:43 +0000241 drd-libQtCore-QObjectPrivate::clearGuards(QObject*)
bartf0d65952008-08-02 10:03:37 +0000242 drd:ConflictingAccess
243 fun:_ZN14QReadWriteLock12lockForWriteEv
244 fun:_ZN12QWriteLocker6relockEv
245 fun:_ZN12QWriteLockerC1EP14QReadWriteLock
246 fun:_ZN14QObjectPrivate11clearGuardsEP7QObject
247 fun:_ZN7QObjectD2Ev
248 fun:_ZN24QAbstractEventDispatcherD2Ev
249 fun:_ZN20QEventDispatcherGlibD0Ev
250}
bart75516e52009-08-10 14:13:12 +0000251{
252 drd-libQtCore-QMutexPool::get(void const*)
253 drd:ConflictingAccess
254 fun:_ZN10QMutexPool3getEPKv
255}
barta13f0222010-07-29 07:52:37 +0000256{
257 drd-libQtCore-qt_gettime_is_monotonic()
258 drd:ConflictingAccess
259 fun:_Z23qt_gettime_is_monotonicv
260}
bart9e4554c2009-08-02 07:46:43 +0000261
262#
263# Suppression patterns for libboost.
264#
265
266# Suppress the races on boost::once_flag::epoch and on
bart271889e2010-06-05 11:57:57 +0000267# boost::detail::this_thread_epoch. See also the source file
268# boost/thread/pthread/once.hpp in the Boost source tree
269# (https://svn.boost.org/trac/boost/browser/trunk/boost/thread/pthread/once.hpp).
barta45b5722008-12-21 16:08:07 +0000270{
bart9e4554c2009-08-02 07:46:43 +0000271 drd-libboost-boost::call_once<void (*)()>(boost::once_flag&, void (*)())
barta45b5722008-12-21 16:08:07 +0000272 drd:ConflictingAccess
273 ...
274 fun:_ZN5boost9call_onceIPFvvEEEvRNS_9once_flagET_
barta45b5722008-12-21 16:08:07 +0000275}
bart35da3c42009-08-12 09:45:54 +0000276{
277 drd-libboost-boost::detail::get_once_per_thread_epoch()
278 drd:ConflictingAccess
279 fun:_ZN5boost6detail25get_once_per_thread_epochEv
280}
bart271889e2010-06-05 11:57:57 +0000281# Suppress the race reports on boost::detail::current_thread_tls_key. See also
282# https://svn.boost.org/trac/boost/ticket/3526 for more information about why
283# the access pattern of current_thread_tls_key is safe.
bart35da3c42009-08-12 09:45:54 +0000284{
285 drd-libboost-boost::detail::get_current_thread_data()
286 drd:ConflictingAccess
287 ...
288 fun:_ZN5boost6detail23get_current_thread_dataEv
289}
bart271889e2010-06-05 11:57:57 +0000290{
291 drd-libboost-boost::detail::set_current_thread_data(boost::detail::thread_data_base*)
292 drd:ConflictingAccess
293 ...
294 fun:_ZN5boost6detail23set_current_thread_dataEPNS0_16thread_data_baseE
295}