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

Side by Side Diff: ppapi/shared_impl/proxy_lock.h

Issue 8233021: Export symbols for shared library build. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: merge after revert Created 9 years, 2 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 | Annotate | Revision Log
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef PPAPI_SHARED_IMPL_PROXY_LOCK_H_ 5 #ifndef PPAPI_SHARED_IMPL_PROXY_LOCK_H_
6 #define PPAPI_SHARED_IMPL_PROXY_LOCK_H_ 6 #define PPAPI_SHARED_IMPL_PROXY_LOCK_H_
7 7
8 #include "base/basictypes.h" 8 #include "base/basictypes.h"
9 9
10 #include "ppapi/shared_impl/ppapi_shared_export.h"
11
10 namespace base { 12 namespace base {
11 class Lock; 13 class Lock;
12 } 14 }
13 15
14 namespace ppapi { 16 namespace ppapi {
15 17
16 // This is the one lock to rule them all for the ppapi proxy. All PPB interface 18 // This is the one lock to rule them all for the ppapi proxy. All PPB interface
17 // functions that need to be synchronized should lock this lock on entry. This 19 // functions that need to be synchronized should lock this lock on entry. This
18 // is normally accomplished by using an appropriate Enter RAII object at the 20 // is normally accomplished by using an appropriate Enter RAII object at the
19 // beginning of each thunk function. 21 // beginning of each thunk function.
20 // 22 //
21 // TODO(dmichael): If this turns out to be too slow and contentious, we'll want 23 // TODO(dmichael): If this turns out to be too slow and contentious, we'll want
22 // to use multiple locks. E.g., one for the var tracker, one for the resource 24 // to use multiple locks. E.g., one for the var tracker, one for the resource
23 // tracker, etc. 25 // tracker, etc.
24 class ProxyLock { 26 class PPAPI_SHARED_EXPORT ProxyLock {
25 public: 27 public:
26 // Acquire the proxy lock. If it is currently held by another thread, block 28 // Acquire the proxy lock. If it is currently held by another thread, block
27 // until it is available. If the lock has not been set using the 'Set' method, 29 // until it is available. If the lock has not been set using the 'Set' method,
28 // this operation does nothing. That is the normal case for the host side; 30 // this operation does nothing. That is the normal case for the host side;
29 // see PluginResourceTracker for where the lock gets set for the out-of- 31 // see PluginResourceTracker for where the lock gets set for the out-of-
30 // process plugin case. 32 // process plugin case.
31 static void Acquire(); 33 static void Acquire();
32 // Relinquish the proxy lock. If the lock has not been set, this does nothing. 34 // Relinquish the proxy lock. If the lock has not been set, this does nothing.
33 static void Release(); 35 static void Release();
34 36
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after
71 ProxyLock::Acquire(); 73 ProxyLock::Acquire();
72 } 74 }
73 private: 75 private:
74 DISALLOW_COPY_AND_ASSIGN(ProxyAutoUnlock); 76 DISALLOW_COPY_AND_ASSIGN(ProxyAutoUnlock);
75 }; 77 };
76 78
77 79
78 } // namespace ppapi 80 } // namespace ppapi
79 81
80 #endif // PPAPI_SHARED_IMPL_PROXY_LOCK_H_ 82 #endif // PPAPI_SHARED_IMPL_PROXY_LOCK_H_
OLDNEW
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698