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

Side by Side Diff: cc/trees/single_thread_proxy.h

Issue 134623005: Make SingleThreadProxy a SchedulerClient (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Synchronous compositeAndReadbackAsync for test reliability Created 6 years, 5 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
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 CC_TREES_SINGLE_THREAD_PROXY_H_ 5 #ifndef CC_TREES_SINGLE_THREAD_PROXY_H_
6 #define CC_TREES_SINGLE_THREAD_PROXY_H_ 6 #define CC_TREES_SINGLE_THREAD_PROXY_H_
7 7
8 #include <limits> 8 #include <limits>
9 9
10 #include "base/time/time.h" 10 #include "base/time/time.h"
11 #include "cc/animation/animation_events.h" 11 #include "cc/animation/animation_events.h"
12 #include "cc/output/begin_frame_args.h" 12 #include "cc/output/begin_frame_args.h"
13 #include "cc/scheduler/scheduler.h"
13 #include "cc/trees/layer_tree_host_impl.h" 14 #include "cc/trees/layer_tree_host_impl.h"
14 #include "cc/trees/proxy.h" 15 #include "cc/trees/proxy.h"
16 #include "cc/trees/proxy_timing_history.h"
15 17
16 namespace cc { 18 namespace cc {
17 19
18 class ContextProvider; 20 class ContextProvider;
19 class LayerTreeHost; 21 class LayerTreeHost;
20 class LayerTreeHostSingleThreadClient; 22 class LayerTreeHostSingleThreadClient;
21 23
22 class CC_EXPORT SingleThreadProxy : public Proxy, 24 class CC_EXPORT SingleThreadProxy : public Proxy,
23 NON_EXPORTED_BASE(LayerTreeHostImplClient) { 25 NON_EXPORTED_BASE(LayerTreeHostImplClient),
26 SchedulerClient {
24 public: 27 public:
25 static scoped_ptr<Proxy> Create( 28 static scoped_ptr<Proxy> Create(
26 LayerTreeHost* layer_tree_host, 29 LayerTreeHost* layer_tree_host,
27 LayerTreeHostSingleThreadClient* client); 30 LayerTreeHostSingleThreadClient* client);
28 virtual ~SingleThreadProxy(); 31 virtual ~SingleThreadProxy();
29 32
30 // Proxy implementation 33 // Proxy implementation
31 virtual void FinishAllRendering() OVERRIDE; 34 virtual void FinishAllRendering() OVERRIDE;
32 virtual bool IsStarted() const OVERRIDE; 35 virtual bool IsStarted() const OVERRIDE;
33 virtual void SetLayerTreeHostClientReady() OVERRIDE; 36 virtual void SetLayerTreeHostClientReady() OVERRIDE;
34 virtual void SetVisible(bool visible) OVERRIDE; 37 virtual void SetVisible(bool visible) OVERRIDE;
35 virtual const RendererCapabilities& GetRendererCapabilities() const OVERRIDE; 38 virtual const RendererCapabilities& GetRendererCapabilities() const OVERRIDE;
36 virtual void SetNeedsAnimate() OVERRIDE; 39 virtual void SetNeedsAnimate() OVERRIDE;
37 virtual void SetNeedsUpdateLayers() OVERRIDE; 40 virtual void SetNeedsUpdateLayers() OVERRIDE;
38 virtual void SetNeedsCommit() OVERRIDE; 41 virtual void SetNeedsCommit() OVERRIDE;
39 virtual void SetNeedsRedraw(const gfx::Rect& damage_rect) OVERRIDE; 42 virtual void SetNeedsRedraw(const gfx::Rect& damage_rect) OVERRIDE;
40 virtual void SetNextCommitWaitsForActivation() OVERRIDE; 43 virtual void SetNextCommitWaitsForActivation() OVERRIDE;
41 virtual void NotifyInputThrottledUntilCommit() OVERRIDE {} 44 virtual void NotifyInputThrottledUntilCommit() OVERRIDE {}
42 virtual void SetDeferCommits(bool defer_commits) OVERRIDE; 45 virtual void SetDeferCommits(bool defer_commits) OVERRIDE;
43 virtual bool CommitRequested() const OVERRIDE; 46 virtual bool CommitRequested() const OVERRIDE;
44 virtual bool BeginMainFrameRequested() const OVERRIDE; 47 virtual bool BeginMainFrameRequested() const OVERRIDE;
45 virtual void MainThreadHasStoppedFlinging() OVERRIDE {} 48 virtual void MainThreadHasStoppedFlinging() OVERRIDE {}
46 virtual void Start() OVERRIDE; 49 virtual void Start() OVERRIDE;
47 virtual void Stop() OVERRIDE; 50 virtual void Stop() OVERRIDE;
48 virtual size_t MaxPartialTextureUpdates() const OVERRIDE; 51 virtual size_t MaxPartialTextureUpdates() const OVERRIDE;
49 virtual void ForceSerializeOnSwapBuffers() OVERRIDE; 52 virtual void ForceSerializeOnSwapBuffers() OVERRIDE;
50 virtual bool SupportsImplScrolling() const OVERRIDE; 53 virtual bool SupportsImplScrolling() const OVERRIDE;
51 virtual scoped_ptr<base::Value> AsValue() const OVERRIDE; 54 virtual scoped_ptr<base::Value> AsValue() const OVERRIDE;
52 virtual bool CommitPendingForTesting() OVERRIDE; 55 virtual bool CommitPendingForTesting() OVERRIDE;
56 virtual scoped_ptr<base::Value> SchedulerAsValueForTesting() OVERRIDE;
57
58 // SchedulerClient implementation
59 virtual void SetNeedsBeginFrame(bool enable) OVERRIDE;
60 virtual void WillBeginImplFrame(const BeginFrameArgs& args) OVERRIDE;
61 virtual void ScheduledActionSendBeginMainFrame() OVERRIDE;
62 virtual DrawResult ScheduledActionDrawAndSwapIfPossible() OVERRIDE;
63 virtual DrawResult ScheduledActionDrawAndSwapForced() OVERRIDE;
64 virtual void ScheduledActionCommit() OVERRIDE;
65 virtual void ScheduledActionAnimate() OVERRIDE;
66 virtual void ScheduledActionUpdateVisibleTiles() OVERRIDE;
67 virtual void ScheduledActionActivatePendingTree() OVERRIDE;
68 virtual void ScheduledActionBeginOutputSurfaceCreation() OVERRIDE;
69 virtual void ScheduledActionManageTiles() OVERRIDE;
70 virtual void DidAnticipatedDrawTimeChange(base::TimeTicks time) OVERRIDE;
71 virtual base::TimeDelta DrawDurationEstimate() OVERRIDE;
72 virtual base::TimeDelta BeginMainFrameToCommitDurationEstimate() OVERRIDE;
73 virtual base::TimeDelta CommitToActivateDurationEstimate() OVERRIDE;
74 virtual void DidBeginImplFrameDeadline() OVERRIDE;
53 75
54 // LayerTreeHostImplClient implementation 76 // LayerTreeHostImplClient implementation
55 virtual void UpdateRendererCapabilitiesOnImplThread() OVERRIDE; 77 virtual void UpdateRendererCapabilitiesOnImplThread() OVERRIDE;
56 virtual void DidLoseOutputSurfaceOnImplThread() OVERRIDE; 78 virtual void DidLoseOutputSurfaceOnImplThread() OVERRIDE;
57 virtual void CommitVSyncParameters(base::TimeTicks timebase, 79 virtual void CommitVSyncParameters(base::TimeTicks timebase,
58 base::TimeDelta interval) OVERRIDE {} 80 base::TimeDelta interval) OVERRIDE {}
59 virtual void SetEstimatedParentDrawTime(base::TimeDelta draw_time) OVERRIDE {} 81 virtual void SetEstimatedParentDrawTime(base::TimeDelta draw_time) OVERRIDE {}
60 virtual void SetMaxSwapsPendingOnImplThread(int max) OVERRIDE {} 82 virtual void SetMaxSwapsPendingOnImplThread(int max) OVERRIDE {}
61 virtual void DidSwapBuffersOnImplThread() OVERRIDE; 83 virtual void DidSwapBuffersOnImplThread() OVERRIDE;
62 virtual void DidSwapBuffersCompleteOnImplThread() OVERRIDE; 84 virtual void DidSwapBuffersCompleteOnImplThread() OVERRIDE;
63 virtual void BeginFrame(const BeginFrameArgs& args) OVERRIDE {} 85 virtual void BeginFrame(const BeginFrameArgs& args) OVERRIDE;
64 virtual void OnCanDrawStateChanged(bool can_draw) OVERRIDE; 86 virtual void OnCanDrawStateChanged(bool can_draw) OVERRIDE;
65 virtual void NotifyReadyToActivate() OVERRIDE; 87 virtual void NotifyReadyToActivate() OVERRIDE;
66 virtual void SetNeedsRedrawOnImplThread() OVERRIDE; 88 virtual void SetNeedsRedrawOnImplThread() OVERRIDE;
67 virtual void SetNeedsRedrawRectOnImplThread( 89 virtual void SetNeedsRedrawRectOnImplThread(
68 const gfx::Rect& dirty_rect) OVERRIDE; 90 const gfx::Rect& dirty_rect) OVERRIDE;
69 virtual void SetNeedsAnimateOnImplThread() OVERRIDE; 91 virtual void SetNeedsAnimateOnImplThread() OVERRIDE;
70 virtual void SetNeedsManageTilesOnImplThread() OVERRIDE; 92 virtual void SetNeedsManageTilesOnImplThread() OVERRIDE;
71 virtual void DidInitializeVisibleTileOnImplThread() OVERRIDE; 93 virtual void DidInitializeVisibleTileOnImplThread() OVERRIDE;
72 virtual void SetNeedsCommitOnImplThread() OVERRIDE; 94 virtual void SetNeedsCommitOnImplThread() OVERRIDE;
73 virtual void PostAnimationEventsToMainThreadOnImplThread( 95 virtual void PostAnimationEventsToMainThreadOnImplThread(
74 scoped_ptr<AnimationEventsVector> events) OVERRIDE; 96 scoped_ptr<AnimationEventsVector> events) OVERRIDE;
75 virtual bool ReduceContentsTextureMemoryOnImplThread( 97 virtual bool ReduceContentsTextureMemoryOnImplThread(
76 size_t limit_bytes, 98 size_t limit_bytes,
77 int priority_cutoff) OVERRIDE; 99 int priority_cutoff) OVERRIDE;
78 virtual bool IsInsideDraw() OVERRIDE; 100 virtual bool IsInsideDraw() OVERRIDE;
79 virtual void RenewTreePriority() OVERRIDE {} 101 virtual void RenewTreePriority() OVERRIDE {}
80 virtual void PostDelayedScrollbarFadeOnImplThread( 102 virtual void PostDelayedScrollbarFadeOnImplThread(
81 const base::Closure& start_fade, 103 const base::Closure& start_fade,
82 base::TimeDelta delay) OVERRIDE {} 104 base::TimeDelta delay) OVERRIDE {}
83 virtual void DidActivateSyncTree() OVERRIDE {} 105 virtual void DidActivateSyncTree() OVERRIDE {}
84 virtual void DidManageTiles() OVERRIDE {} 106 virtual void DidManageTiles() OVERRIDE;
85 virtual void SetDebugState(const LayerTreeDebugState& debug_state) OVERRIDE {} 107 virtual void SetDebugState(const LayerTreeDebugState& debug_state) OVERRIDE {}
86 108
87 // Attempts to create the context and renderer synchronously. Calls 109 // Attempts to create the context and renderer synchronously. Calls
88 // LayerTreeHost::OnCreateAndInitializeOutputSurfaceAttempted with the result. 110 // LayerTreeHost::OnCreateAndInitializeOutputSurfaceAttempted with the result.
89 void CreateAndInitializeOutputSurface(); 111 void CreateAndInitializeOutputSurface();
90 112
91 // Called by the legacy path where RenderWidget does the scheduling. 113 // Called by the legacy path where RenderWidget does the scheduling.
92 void CompositeImmediately(base::TimeTicks frame_begin_time); 114 void CompositeImmediately(base::TimeTicks frame_begin_time);
115 // Called by tests wanting an immediate commit/composite for accurate
116 // readback.
117 void CompositeImmediatelyNoSwap(base::TimeTicks frame_begin_time);
93 118
94 private: 119 private:
95 SingleThreadProxy(LayerTreeHost* layer_tree_host, 120 SingleThreadProxy(LayerTreeHost* layer_tree_host,
96 LayerTreeHostSingleThreadClient* client); 121 LayerTreeHostSingleThreadClient* client);
97 122
98 void DoCommit(scoped_ptr<ResourceUpdateQueue> queue); 123 void DoCommit(base::TimeTicks frame_begin_time);
99 bool DoComposite(base::TimeTicks frame_begin_time, 124 void CompositeImmediatelyInternal(base::TimeTicks frame_begin_time,
100 LayerTreeHostImpl::FrameData* frame); 125 bool do_swap);
101 void DidSwapFrame(); 126 DrawResult DoComposite(base::TimeTicks frame_begin_time,
127 LayerTreeHostImpl::FrameData* frame,
128 bool do_swap);
129 void DoSwap();
130 void DidCommitAndDrawFrame();
102 131
103 bool ShouldComposite() const; 132 bool ShouldComposite() const;
104 void UpdateBackgroundAnimateTicking(); 133 void UpdateBackgroundAnimateTicking();
105 134
106 // Accessed on main thread only. 135 // Accessed on main thread only.
107 LayerTreeHost* layer_tree_host_; 136 LayerTreeHost* layer_tree_host_;
108 LayerTreeHostSingleThreadClient* client_; 137 LayerTreeHostSingleThreadClient* client_;
109 138
110 // Used on the Thread, but checked on main thread during 139 // Used on the Thread, but checked on main thread during
111 // initialization/shutdown. 140 // initialization/shutdown.
112 scoped_ptr<LayerTreeHostImpl> layer_tree_host_impl_; 141 scoped_ptr<LayerTreeHostImpl> layer_tree_host_impl_;
113 RendererCapabilities renderer_capabilities_for_main_thread_; 142 RendererCapabilities renderer_capabilities_for_main_thread_;
114 143
144 // Accessed from both threads.
145 scoped_ptr<Scheduler> scheduler_on_impl_thread_;
146 ProxyTimingHistory timing_history_;
147
115 bool next_frame_is_newly_committed_frame_; 148 bool next_frame_is_newly_committed_frame_;
116 149
117 bool inside_draw_; 150 bool inside_draw_;
151 bool defer_commits_;
152 bool commit_was_deferred_;
153 bool commit_requested_;
154
155 base::WeakPtrFactory<SingleThreadProxy> weak_factory_;
118 156
119 DISALLOW_COPY_AND_ASSIGN(SingleThreadProxy); 157 DISALLOW_COPY_AND_ASSIGN(SingleThreadProxy);
120 }; 158 };
121 159
122 // For use in the single-threaded case. In debug builds, it pretends that the 160 // For use in the single-threaded case. In debug builds, it pretends that the
123 // code is running on the impl thread to satisfy assertion checks. 161 // code is running on the impl thread to satisfy assertion checks.
124 class DebugScopedSetImplThread { 162 class DebugScopedSetImplThread {
125 public: 163 public:
126 explicit DebugScopedSetImplThread(Proxy* proxy) : proxy_(proxy) { 164 explicit DebugScopedSetImplThread(Proxy* proxy) : proxy_(proxy) {
127 #if DCHECK_IS_ON 165 #if DCHECK_IS_ON
(...skipping 48 matching lines...) Expand 10 before | Expand all | Expand 10 after
176 private: 214 private:
177 DebugScopedSetImplThread impl_thread_; 215 DebugScopedSetImplThread impl_thread_;
178 DebugScopedSetMainThreadBlocked main_thread_blocked_; 216 DebugScopedSetMainThreadBlocked main_thread_blocked_;
179 217
180 DISALLOW_COPY_AND_ASSIGN(DebugScopedSetImplThreadAndMainThreadBlocked); 218 DISALLOW_COPY_AND_ASSIGN(DebugScopedSetImplThreadAndMainThreadBlocked);
181 }; 219 };
182 220
183 } // namespace cc 221 } // namespace cc
184 222
185 #endif // CC_TREES_SINGLE_THREAD_PROXY_H_ 223 #endif // CC_TREES_SINGLE_THREAD_PROXY_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698