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

Side by Side Diff: cc/completion_event.h

Issue 11085054: Aura: Allow browser UI thread waiting for compositor commits. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Rebase Created 8 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 | « base/threading/thread_restrictions.h ('k') | 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 2011 The Chromium Authors. All rights reserved. 1 // Copyright 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 CCCompletionEvent_h 5 #ifndef CCCompletionEvent_h
6 #define CCCompletionEvent_h 6 #define CCCompletionEvent_h
7 7
8 #include "base/synchronization/waitable_event.h" 8 #include "base/synchronization/waitable_event.h"
9 #include "base/threading/thread_restrictions.h"
9 10
10 namespace cc { 11 namespace cc {
11 12
12 // Used for making blocking calls from one thread to another. Use only when 13 // Used for making blocking calls from one thread to another. Use only when
13 // absolutely certain that doing-so will not lead to a deadlock. 14 // absolutely certain that doing-so will not lead to a deadlock.
14 // 15 //
15 // It is safe to destroy this object as soon as wait() returns. 16 // It is safe to destroy this object as soon as wait() returns.
16 class CCCompletionEvent { 17 class CCCompletionEvent {
17 public: 18 public:
18 CCCompletionEvent() 19 CCCompletionEvent()
(...skipping 10 matching lines...) Expand all
29 ASSERT(m_waited); 30 ASSERT(m_waited);
30 ASSERT(m_signaled); 31 ASSERT(m_signaled);
31 } 32 }
32 33
33 void wait() 34 void wait()
34 { 35 {
35 ASSERT(!m_waited); 36 ASSERT(!m_waited);
36 #ifndef NDEBUG 37 #ifndef NDEBUG
37 m_waited = true; 38 m_waited = true;
38 #endif 39 #endif
40 base::ThreadRestrictions::ScopedAllowWait allow_wait;
39 m_event.Wait(); 41 m_event.Wait();
40 } 42 }
41 43
42 void signal() 44 void signal()
43 { 45 {
44 ASSERT(!m_signaled); 46 ASSERT(!m_signaled);
45 #ifndef NDEBUG 47 #ifndef NDEBUG
46 m_signaled = true; 48 m_signaled = true;
47 #endif 49 #endif
48 m_event.Signal(); 50 m_event.Signal();
49 } 51 }
50 52
51 private: 53 private:
52 base::WaitableEvent m_event; 54 base::WaitableEvent m_event;
53 #ifndef NDEBUG 55 #ifndef NDEBUG
54 // Used to assert that wait() and signal() are each called exactly once. 56 // Used to assert that wait() and signal() are each called exactly once.
55 bool m_waited; 57 bool m_waited;
56 bool m_signaled; 58 bool m_signaled;
57 #endif 59 #endif
58 }; 60 };
59 61
60 } 62 }
61 63
62 #endif 64 #endif
OLDNEW
« no previous file with comments | « base/threading/thread_restrictions.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698