blob: 02e13af2125300316370b53ae9486f7ad0458f74 [file] [log] [blame]
kjellander@webrtc.org767d98e2014-06-27 09:18:51 +00001/*
2 * Copyright (c) 2014 The WebRTC project authors. All Rights Reserved.
3 *
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
11// This file contains the WebRTC suppressions for ThreadSanitizer.
12// Please refer to
13// http://dev.chromium.org/developers/testing/threadsanitizer-tsan-v2
14// for more info.
15
16#if defined(THREAD_SANITIZER)
17
18// Please make sure the code below declares a single string variable
19// kTSanDefaultSuppressions contains TSan suppressions delimited by newlines.
20// See http://dev.chromium.org/developers/testing/threadsanitizer-tsan-v2
21// for the instructions on writing suppressions.
22char kTSanDefaultSuppressions[] =
23
24// WebRTC specific suppressions.
25
andresp@webrtc.org33d110d2014-07-08 10:36:39 +000026// Usage of trace callback and trace level is racy in libjingle_media_unittests.
27// https://code.google.com/p/webrtc/issues/detail?id=3372
28"race:webrtc::TraceImpl::WriteToFile\n"
29"race:webrtc::VideoEngine::SetTraceFilter\n"
30"race:webrtc::VoiceEngine::SetTraceFilter\n"
kjellander@webrtc.org767d98e2014-06-27 09:18:51 +000031
32// Audio processing
33// https://code.google.com/p/webrtc/issues/detail?id=2521 for details.
34"race:webrtc/modules/audio_processing/aec/aec_core.c\n"
35"race:webrtc/modules/audio_processing/aec/aec_rdft.c\n"
36
37// libjingle_p2p_unittest
38// https://code.google.com/p/webrtc/issues/detail?id=2079
39"race:webrtc/base/messagequeue.cc\n"
40"race:webrtc/base/testclient.cc\n"
41"race:webrtc/base/virtualsocketserver.cc\n"
42"race:talk/base/messagequeue.cc\n"
43"race:talk/base/testclient.cc\n"
44"race:talk/base/virtualsocketserver.cc\n"
45"race:talk/p2p/base/stunserver_unittest.cc\n"
46
47// libjingle_unittest
48// https://code.google.com/p/webrtc/issues/detail?id=2080
49"race:webrtc/base/logging.cc\n"
50"race:webrtc/base/sharedexclusivelock_unittest.cc\n"
51"race:webrtc/base/signalthread_unittest.cc\n"
52"race:webrtc/base/thread.cc\n"
53"race:talk/base/logging.cc\n"
54"race:talk/base/sharedexclusivelock_unittest.cc\n"
55"race:talk/base/signalthread_unittest.cc\n"
56"race:talk/base/thread.cc\n"
57
58// third_party/usrsctp
59// TODO(jiayl): https://code.google.com/p/webrtc/issues/detail?id=3492
60"race:third_party/usrsctp/usrsctplib/user_sctp_timer_iterate.c\n"
61
62// Potential deadlocks detected after roll in r6516.
63// https://code.google.com/p/webrtc/issues/detail?id=3509
andresp@webrtc.org33586c82014-07-02 14:19:05 +000064"deadlock:cricket::WebRtcVideoChannel2::WebRtcVideoSendStream::InputFrame\n"
65"deadlock:cricket::WebRtcVideoChannel2::WebRtcVideoSendStream::SetCapturer\n"
66"deadlock:talk_base::AsyncResolver::~AsyncResolver\n"
67"deadlock:webrtc::ProcessThreadImpl::RegisterModule\n"
68"deadlock:webrtc::RTCPReceiver::SetSsrcs\n"
69"deadlock:webrtc::RTPSenderAudio::RegisterAudioPayload\n"
andresp@webrtc.org33586c82014-07-02 14:19:05 +000070"deadlock:webrtc::test::UdpSocketManagerPosixImpl::RemoveSocket\n"
71"deadlock:webrtc::vcm::VideoReceiver::RegisterPacketRequestCallback\n"
72"deadlock:webrtc::VideoSendStreamTest_SuspendBelowMinBitrate_Test::TestBody\n"
73"deadlock:webrtc::ViECaptureImpl::ConnectCaptureDevice\n"
74"deadlock:webrtc::ViEChannel::StartSend\n"
75"deadlock:webrtc::ViECodecImpl::GetSendSideDelay\n"
76"deadlock:webrtc::ViEEncoder::OnLocalSsrcChanged\n"
77"deadlock:webrtc::ViESender::RegisterSendTransport\n"
kjellander@webrtc.org767d98e2014-06-27 09:18:51 +000078
79// From Chromium's tsan_suppressions.cc file.
80
81// False positives in libglib.so. Since we don't instrument them, we cannot
82// reason about the synchronization in them.
83"race:libglib*.so\n"
84
85// Races in libevent, http://crbug.com/23244.
86"race:libevent/event.c\n"
87
88// http://crbug.com/84094.
89"race:sqlite3StatusSet\n"
90"race:pcache1EnforceMaxPage\n"
91"race:pcache1AllocPage\n"
92
93// http://crbug.com/157586
94"race:third_party/libvpx/source/libvpx/vp8/decoder/threading.c\n"
95
96// http://crbug.com/158922
97"race:third_party/libvpx/source/libvpx/vp8/encoder/*\n"
98
99// http://crbug.com/223352
100"race:uprv_malloc_46\n"
101"race:uprv_realloc_46\n"
102
103// http://crbug.com/244385
104"race:unixTempFileDir\n"
105
106// http://crbug.com/244774
107"race:webrtc::RTPReceiver::ProcessBitrate\n"
108"race:webrtc::RTPSender::ProcessBitrate\n"
109"race:webrtc::VideoCodingModuleImpl::Decode\n"
110"race:webrtc::RTPSender::SendOutgoingData\n"
111"race:webrtc::VP8EncoderImpl::GetEncodedPartitions\n"
112"race:webrtc::VP8EncoderImpl::Encode\n"
113"race:webrtc::ViEEncoder::DeliverFrame\n"
114"race:webrtc::vcm::VideoReceiver::Decode\n"
115"race:webrtc::VCMReceiver::FrameForDecoding\n"
116"race:*trace_event_unique_catstatic*\n"
117
118// http://crbug.com/244856
119"race:AutoPulseLock\n"
120
121// http://crbug.com/246968
122"race:webrtc::VideoCodingModuleImpl::RegisterPacketRequestCallback\n"
123
124// http://crbug.com/246970
125"race:webrtc::EventPosix::StartTimer\n"
126
127// http://crbug.com/258479
128"race:SamplingStateScope\n"
129"race:g_trace_state\n"
130
131// http://crbug.com/270037
132"race:gLibCleanupFunctions\n"
133
134// http://crbug.com/272987
135"race:webrtc::MediaStreamTrack<webrtc::AudioTrackInterface>::set_enabled\n"
136
137// http://crbug.com/345245
138"race:jingle_glue::JingleThreadWrapper::~JingleThreadWrapper\n"
139"race:webrtc::voe::Channel::UpdatePacketDelay\n"
140"race:webrtc::voe::Channel::GetDelayEstimate\n"
141"race:webrtc::VCMCodecDataBase::DeregisterReceiveCodec\n"
142"race:webrtc::GainControlImpl::set_stream_analog_level\n"
143
144// http://crbug.com/347538
145"race:sctp_timer_start\n"
146
147// http://crbug.com/347548
148"race:cricket::WebRtcVideoMediaChannel::MaybeResetVieSendCodec\n"
149"race:cricket::WebRtcVideoMediaChannel::SetSendCodec\n"
150
151// http://crbug.com/348511
152"race:webrtc::acm1::AudioCodingModuleImpl::PlayoutData10Ms\n"
153
154// http://crbug.com/348982
155"race:cricket::P2PTransportChannel::OnConnectionDestroyed\n"
156"race:cricket::P2PTransportChannel::AddConnection\n"
157
158// http://crbug.com/348984
159"race:sctp_express_handle_sack\n"
160
161// http://crbug.com/350982
162"race:libvpx/vp9/decoder/vp9_thread.c\n"
163
164// http://crbug.com/372807
165"deadlock:net::X509Certificate::CreateCertificateListFromBytes\n"
166"deadlock:net::X509Certificate::CreateFromBytes\n"
167"deadlock:net::SSLClientSocketNSS::Core::DoHandshakeLoop\n"
168
169// False positive in libc's tzset_internal, http://crbug.com/379738.
170"race:tzset_internal\n"
171
172// http://crbug.com/380554
173"deadlock:g_type_add_interface_static\n"
174
175// End of suppressions.
176; // Please keep this semicolon.
177
178#endif // THREAD_SANITIZER