Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(388)

Side by Side Diff: webrtc/system_wrappers/include/critical_section_wrapper.h

Issue 1601743004: Make CriticalSectionWrapper non-virtual (Closed) Base URL: https://chromium.googlesource.com/external/webrtc.git@master
Patch Set: Fix windows build Created 4 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698