1*d9f75844SAndroid Build Coastguard Worker /* 2*d9f75844SAndroid Build Coastguard Worker * Copyright 2020 The WebRTC Project Authors. All rights reserved. 3*d9f75844SAndroid Build Coastguard Worker * 4*d9f75844SAndroid Build Coastguard Worker * Use of this source code is governed by a BSD-style license 5*d9f75844SAndroid Build Coastguard Worker * that can be found in the LICENSE file in the root of the source 6*d9f75844SAndroid Build Coastguard Worker * tree. An additional intellectual property rights grant can be found 7*d9f75844SAndroid Build Coastguard Worker * in the file PATENTS. All contributing project authors may 8*d9f75844SAndroid Build Coastguard Worker * be found in the AUTHORS file in the root of the source tree. 9*d9f75844SAndroid Build Coastguard Worker */ 10*d9f75844SAndroid Build Coastguard Worker 11*d9f75844SAndroid Build Coastguard Worker #ifndef RTC_BASE_SYNCHRONIZATION_MUTEX_H_ 12*d9f75844SAndroid Build Coastguard Worker #define RTC_BASE_SYNCHRONIZATION_MUTEX_H_ 13*d9f75844SAndroid Build Coastguard Worker 14*d9f75844SAndroid Build Coastguard Worker #include <atomic> 15*d9f75844SAndroid Build Coastguard Worker 16*d9f75844SAndroid Build Coastguard Worker #include "absl/base/attributes.h" 17*d9f75844SAndroid Build Coastguard Worker #include "absl/base/const_init.h" 18*d9f75844SAndroid Build Coastguard Worker #include "rtc_base/checks.h" 19*d9f75844SAndroid Build Coastguard Worker #include "rtc_base/thread_annotations.h" 20*d9f75844SAndroid Build Coastguard Worker 21*d9f75844SAndroid Build Coastguard Worker #if defined(WEBRTC_ABSL_MUTEX) 22*d9f75844SAndroid Build Coastguard Worker #include "rtc_base/synchronization/mutex_abseil.h" // nogncheck 23*d9f75844SAndroid Build Coastguard Worker #elif defined(WEBRTC_WIN) 24*d9f75844SAndroid Build Coastguard Worker #include "rtc_base/synchronization/mutex_critical_section.h" 25*d9f75844SAndroid Build Coastguard Worker #elif defined(WEBRTC_POSIX) 26*d9f75844SAndroid Build Coastguard Worker #include "rtc_base/synchronization/mutex_pthread.h" 27*d9f75844SAndroid Build Coastguard Worker #else 28*d9f75844SAndroid Build Coastguard Worker #error Unsupported platform. 29*d9f75844SAndroid Build Coastguard Worker #endif 30*d9f75844SAndroid Build Coastguard Worker 31*d9f75844SAndroid Build Coastguard Worker namespace webrtc { 32*d9f75844SAndroid Build Coastguard Worker 33*d9f75844SAndroid Build Coastguard Worker // The Mutex guarantees exclusive access and aims to follow Abseil semantics 34*d9f75844SAndroid Build Coastguard Worker // (i.e. non-reentrant etc). 35*d9f75844SAndroid Build Coastguard Worker class RTC_LOCKABLE Mutex final { 36*d9f75844SAndroid Build Coastguard Worker public: 37*d9f75844SAndroid Build Coastguard Worker Mutex() = default; 38*d9f75844SAndroid Build Coastguard Worker Mutex(const Mutex&) = delete; 39*d9f75844SAndroid Build Coastguard Worker Mutex& operator=(const Mutex&) = delete; 40*d9f75844SAndroid Build Coastguard Worker Lock()41*d9f75844SAndroid Build Coastguard Worker void Lock() RTC_EXCLUSIVE_LOCK_FUNCTION() { 42*d9f75844SAndroid Build Coastguard Worker impl_.Lock(); 43*d9f75844SAndroid Build Coastguard Worker } TryLock()44*d9f75844SAndroid Build Coastguard Worker ABSL_MUST_USE_RESULT bool TryLock() RTC_EXCLUSIVE_TRYLOCK_FUNCTION(true) { 45*d9f75844SAndroid Build Coastguard Worker return impl_.TryLock(); 46*d9f75844SAndroid Build Coastguard Worker } 47*d9f75844SAndroid Build Coastguard Worker // Return immediately if this thread holds the mutex, or RTC_DCHECK_IS_ON==0. 48*d9f75844SAndroid Build Coastguard Worker // Otherwise, may report an error (typically by crashing with a diagnostic), 49*d9f75844SAndroid Build Coastguard Worker // or may return immediately. AssertHeld()50*d9f75844SAndroid Build Coastguard Worker void AssertHeld() const RTC_ASSERT_EXCLUSIVE_LOCK() { impl_.AssertHeld(); } Unlock()51*d9f75844SAndroid Build Coastguard Worker void Unlock() RTC_UNLOCK_FUNCTION() { 52*d9f75844SAndroid Build Coastguard Worker impl_.Unlock(); 53*d9f75844SAndroid Build Coastguard Worker } 54*d9f75844SAndroid Build Coastguard Worker 55*d9f75844SAndroid Build Coastguard Worker private: 56*d9f75844SAndroid Build Coastguard Worker MutexImpl impl_; 57*d9f75844SAndroid Build Coastguard Worker }; 58*d9f75844SAndroid Build Coastguard Worker 59*d9f75844SAndroid Build Coastguard Worker // MutexLock, for serializing execution through a scope. 60*d9f75844SAndroid Build Coastguard Worker class RTC_SCOPED_LOCKABLE MutexLock final { 61*d9f75844SAndroid Build Coastguard Worker public: 62*d9f75844SAndroid Build Coastguard Worker MutexLock(const MutexLock&) = delete; 63*d9f75844SAndroid Build Coastguard Worker MutexLock& operator=(const MutexLock&) = delete; 64*d9f75844SAndroid Build Coastguard Worker MutexLock(Mutex * mutex)65*d9f75844SAndroid Build Coastguard Worker explicit MutexLock(Mutex* mutex) RTC_EXCLUSIVE_LOCK_FUNCTION(mutex) 66*d9f75844SAndroid Build Coastguard Worker : mutex_(mutex) { 67*d9f75844SAndroid Build Coastguard Worker mutex->Lock(); 68*d9f75844SAndroid Build Coastguard Worker } RTC_UNLOCK_FUNCTION()69*d9f75844SAndroid Build Coastguard Worker ~MutexLock() RTC_UNLOCK_FUNCTION() { mutex_->Unlock(); } 70*d9f75844SAndroid Build Coastguard Worker 71*d9f75844SAndroid Build Coastguard Worker private: 72*d9f75844SAndroid Build Coastguard Worker Mutex* mutex_; 73*d9f75844SAndroid Build Coastguard Worker }; 74*d9f75844SAndroid Build Coastguard Worker 75*d9f75844SAndroid Build Coastguard Worker } // namespace webrtc 76*d9f75844SAndroid Build Coastguard Worker 77*d9f75844SAndroid Build Coastguard Worker #endif // RTC_BASE_SYNCHRONIZATION_MUTEX_H_ 78