Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 /* | 1 /* |
| 2 * Copyright (c) 2011 The WebRTC project authors. All Rights Reserved. | 2 * Copyright (c) 2011 The WebRTC project authors. All Rights Reserved. |
| 3 * | 3 * |
| 4 * Use of this source code is governed by a BSD-style license | 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 | 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 | 6 * tree. An additional intellectual property rights grant can be found |
| 7 * in the file PATENTS. All contributing project authors may | 7 * in the file PATENTS. All contributing project authors may |
| 8 * be found in the AUTHORS file in the root of the source tree. | 8 * be found in the AUTHORS file in the root of the source tree. |
| 9 */ | 9 */ |
| 10 | 10 |
| 11 #ifndef WEBRTC_SYSTEM_WRAPPERS_INCLUDE_CRITICAL_SECTION_WRAPPER_H_ | 11 #ifndef WEBRTC_SYSTEM_WRAPPERS_INCLUDE_CRITICAL_SECTION_WRAPPER_H_ |
| 12 #define WEBRTC_SYSTEM_WRAPPERS_INCLUDE_CRITICAL_SECTION_WRAPPER_H_ | 12 #define WEBRTC_SYSTEM_WRAPPERS_INCLUDE_CRITICAL_SECTION_WRAPPER_H_ |
| 13 | 13 |
| 14 // If the critical section is heavily contended it may be beneficial to use | 14 // If the critical section is heavily contended it may be beneficial to use |
| 15 // read/write locks instead. | 15 // read/write locks instead. |
| 16 | 16 |
| 17 #if defined (WEBRTC_WIN) | |
| 18 #include <windows.h> | |
| 19 #else | |
| 20 #include <pthread.h> | |
| 21 #endif | |
| 22 | |
| 17 #include "webrtc/base/thread_annotations.h" | 23 #include "webrtc/base/thread_annotations.h" |
| 18 #include "webrtc/common_types.h" | 24 #include "webrtc/common_types.h" |
| 19 | 25 |
| 20 namespace webrtc { | 26 namespace webrtc { |
| 27 | |
| 21 class LOCKABLE CriticalSectionWrapper { | 28 class LOCKABLE CriticalSectionWrapper { |
| 22 public: | 29 public: |
| 23 // Factory method, constructor disabled | 30 // Factory method, constructor disabled |
| 31 // TODO(tommi): Remove this method. | |
|
pbos-webrtc
2016/01/19 13:04:41
The real TODO should imo be to nuke this file and
tommi
2016/01/19 13:57:15
Right... I'll see if we can get rid of the Conditi
| |
| 24 static CriticalSectionWrapper* CreateCriticalSection(); | 32 static CriticalSectionWrapper* CreateCriticalSection(); |
| 25 | 33 |
| 26 virtual ~CriticalSectionWrapper() {} | 34 CriticalSectionWrapper(); |
| 35 ~CriticalSectionWrapper(); | |
| 27 | 36 |
| 28 // Tries to grab lock, beginning of a critical section. Will wait for the | 37 // Tries to grab lock, beginning of a critical section. Will wait for the |
| 29 // lock to become available if the grab failed. | 38 // lock to become available if the grab failed. |
| 30 virtual void Enter() EXCLUSIVE_LOCK_FUNCTION() = 0; | 39 void Enter() EXCLUSIVE_LOCK_FUNCTION(); |
| 31 | 40 |
| 32 // Returns a grabbed lock, end of critical section. | 41 // Returns a grabbed lock, end of critical section. |
| 33 virtual void Leave() UNLOCK_FUNCTION() = 0; | 42 void Leave() UNLOCK_FUNCTION(); |
| 43 | |
| 44 private: | |
| 45 #if defined (WEBRTC_WIN) | |
| 46 CRITICAL_SECTION crit_; | |
| 47 | |
| 48 // TODO(tommi): Remove friendness. | |
| 49 friend class ConditionVariableEventWin; | |
| 50 friend class ConditionVariableNativeWin; | |
| 51 #else | |
| 52 // TODO(tommi): Remove friendness. | |
| 53 pthread_mutex_t mutex_; | |
| 54 friend class ConditionVariablePosix; | |
| 55 #endif | |
| 34 }; | 56 }; |
| 35 | 57 |
| 36 // RAII extension of the critical section. Prevents Enter/Leave mismatches and | 58 // RAII extension of the critical section. Prevents Enter/Leave mismatches and |
| 37 // provides more compact critical section syntax. | 59 // provides more compact critical section syntax. |
| 38 class SCOPED_LOCKABLE CriticalSectionScoped { | 60 class SCOPED_LOCKABLE CriticalSectionScoped { |
| 39 public: | 61 public: |
| 40 explicit CriticalSectionScoped(CriticalSectionWrapper* critsec) | 62 explicit CriticalSectionScoped(CriticalSectionWrapper* critsec) |
| 41 EXCLUSIVE_LOCK_FUNCTION(critsec) | 63 EXCLUSIVE_LOCK_FUNCTION(critsec) |
| 42 : ptr_crit_sec_(critsec) { | 64 : ptr_crit_sec_(critsec) { |
| 43 ptr_crit_sec_->Enter(); | 65 ptr_crit_sec_->Enter(); |
| 44 } | 66 } |
| 45 | 67 |
| 46 ~CriticalSectionScoped() UNLOCK_FUNCTION() { ptr_crit_sec_->Leave(); } | 68 ~CriticalSectionScoped() UNLOCK_FUNCTION() { ptr_crit_sec_->Leave(); } |
| 47 | 69 |
| 48 private: | 70 private: |
| 49 CriticalSectionWrapper* ptr_crit_sec_; | 71 CriticalSectionWrapper* ptr_crit_sec_; |
| 50 }; | 72 }; |
| 51 | 73 |
| 52 } // namespace webrtc | 74 } // namespace webrtc |
| 53 | 75 |
| 54 #endif // WEBRTC_SYSTEM_WRAPPERS_INCLUDE_CRITICAL_SECTION_WRAPPER_H_ | 76 #endif // WEBRTC_SYSTEM_WRAPPERS_INCLUDE_CRITICAL_SECTION_WRAPPER_H_ |
| OLD | NEW |