blob: ac27c49c2779d748b1034ef3da7ebc30f7d48f61 [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
pbos@webrtc.orgb9906742014-09-11 14:59:06 +000026// Split up suppressions covered previously by thread.cc and messagequeue.cc.
27"race:rtc::MessageQueue::Quit\n"
28"race:FileVideoCapturerTest::VideoCapturerListener::OnFrameCaptured\n"
29"race:vp8cx_remove_encoder_threads\n"
kjellanderd6024e32015-09-28 21:16:48 -070030"race:third_party/libvpx_new/source/libvpx/vp9/common/vp9_scan.h\n"
pbos@webrtc.orgb9906742014-09-11 14:59:06 +000031
kjellandera96e2d72016-02-04 23:52:28 -080032// Usage of trace callback and trace level is racy in rtc_media_unittests.
andresp@webrtc.org33d110d2014-07-08 10:36:39 +000033// https://code.google.com/p/webrtc/issues/detail?id=3372
34"race:webrtc::TraceImpl::WriteToFile\n"
35"race:webrtc::VideoEngine::SetTraceFilter\n"
36"race:webrtc::VoiceEngine::SetTraceFilter\n"
andresp@webrtc.org045a9b12014-07-09 11:44:34 +000037"race:webrtc::Trace::set_level_filter\n"
38"race:webrtc::GetStaticInstance<webrtc::TraceImpl>\n"
kjellander@webrtc.org767d98e2014-06-27 09:18:51 +000039
40// Audio processing
41// https://code.google.com/p/webrtc/issues/detail?id=2521 for details.
42"race:webrtc/modules/audio_processing/aec/aec_core.c\n"
43"race:webrtc/modules/audio_processing/aec/aec_rdft.c\n"
44
Peter Boström792982b2015-11-02 13:42:39 +010045// Race in pulse initialization.
46// https://code.google.com/p/webrtc/issues/detail?id=5152
47"race:webrtc::AudioDeviceLinuxPulse::Init\n"
48
kjellandera96e2d72016-02-04 23:52:28 -080049// rtc_unittests
henrike@webrtc.orge30dab72014-10-09 15:41:40 +000050// https://code.google.com/p/webrtc/issues/detail?id=3911 for details.
Henrik Kjellander1d360032015-03-27 13:46:34 +010051"race:rtc::AsyncInvoker::OnMessage\n"
henrike@webrtc.orge30dab72014-10-09 15:41:40 +000052"race:rtc::FireAndForgetAsyncClosure<FunctorB>::Execute\n"
53"race:rtc::MessageQueueManager::Clear\n"
54"race:rtc::Thread::Clear\n"
Henrik Kjellanderaff1c842015-06-01 11:49:20 +020055// https://code.google.com/p/webrtc/issues/detail?id=3914
56"race:rtc::AsyncInvoker::~AsyncInvoker\n"
kjellander@webrtc.org24485eb2015-03-02 09:40:44 +000057// https://code.google.com/p/webrtc/issues/detail?id=2080
58"race:webrtc/base/logging.cc\n"
59"race:webrtc/base/sharedexclusivelock_unittest.cc\n"
60"race:webrtc/base/signalthread_unittest.cc\n"
Henrik Kjellander1d360032015-03-27 13:46:34 +010061// https://code.google.com/p/webrtc/issues/detail?id=4456
Henrik Kjellander819011c2015-03-27 21:42:09 +010062"deadlock:rtc::MessageQueueManager::Clear\n"
Henrik Kjellander1d360032015-03-27 13:46:34 +010063"deadlock:rtc::MessageQueueManager::ClearInternal\n"
henrike@webrtc.orge30dab72014-10-09 15:41:40 +000064
kjellander@webrtc.org767d98e2014-06-27 09:18:51 +000065// libjingle_p2p_unittest
66// https://code.google.com/p/webrtc/issues/detail?id=2079
kjellander@webrtc.org767d98e2014-06-27 09:18:51 +000067"race:webrtc/base/testclient.cc\n"
68"race:webrtc/base/virtualsocketserver.cc\n"
kjellander@webrtc.org767d98e2014-06-27 09:18:51 +000069"race:talk/p2p/base/stunserver_unittest.cc\n"
70
kjellander@webrtc.org767d98e2014-06-27 09:18:51 +000071// third_party/usrsctp
72// TODO(jiayl): https://code.google.com/p/webrtc/issues/detail?id=3492
andresp@webrtc.org045a9b12014-07-09 11:44:34 +000073"race:user_sctp_timer_iterate\n"
kjellander@webrtc.org767d98e2014-06-27 09:18:51 +000074
Peter Boström6f29a692015-11-02 13:18:22 +010075// https://code.google.com/p/webrtc/issues/detail?id=5151
76"race:sctp_close\n"
77
kjellander@webrtc.org767d98e2014-06-27 09:18:51 +000078// Potential deadlocks detected after roll in r6516.
79// https://code.google.com/p/webrtc/issues/detail?id=3509
andresp@webrtc.org33586c82014-07-02 14:19:05 +000080"deadlock:webrtc::RTCPReceiver::SetSsrcs\n"
andresp@webrtc.org33586c82014-07-02 14:19:05 +000081"deadlock:webrtc::test::UdpSocketManagerPosixImpl::RemoveSocket\n"
82"deadlock:webrtc::vcm::VideoReceiver::RegisterPacketRequestCallback\n"
andresp@webrtc.org33586c82014-07-02 14:19:05 +000083"deadlock:webrtc::ViEEncoder::OnLocalSsrcChanged\n"
kjellander@webrtc.org767d98e2014-06-27 09:18:51 +000084
pbos@webrtc.org124b9c72015-01-08 12:38:42 +000085// TODO(pbos): Trace events are racy due to lack of proper POD atomics.
86// https://code.google.com/p/webrtc/issues/detail?id=2497
87"race:*trace_event_unique_catstatic*\n"
88
henrik.lundin2e1d8bb2015-08-06 04:34:35 -070089// https://code.google.com/p/webrtc/issues/detail?id=4719
90"race:webrtc::voe::TransmitMixer::PrepareDemux\n"
91"race:webrtc::voe::TransmitMixer::EnableStereoChannelSwapping\n"
Peter Boström7ae92622015-10-20 13:37:30 +020092
93// Race between InitCpuFlags and TestCpuFlag in libyuv.
94// https://code.google.com/p/libyuv/issues/detail?id=508
Peter Boström0b8d0562015-11-02 13:04:23 +010095"race:InitCpuFlags\n"
Peter Boström7ae92622015-10-20 13:37:30 +020096
kjellander@webrtc.org767d98e2014-06-27 09:18:51 +000097// End of suppressions.
98; // Please keep this semicolon.
99
100#endif // THREAD_SANITIZER