xref: /aosp_15_r20/external/webrtc/rtc_base/synchronization/mutex.h (revision d9f758449e529ab9291ac668be2861e7a55c2422)
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