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

Side by Side Diff: content/renderer/gpu/render_widget_compositor.h

Issue 738983002: Move output surface fallback from cc to embedders (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Rebase Created 6 years 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 // Copyright (c) 2013 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2013 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 CONTENT_RENDERER_GPU_RENDER_WIDGET_COMPOSITOR_H_ 5 #ifndef CONTENT_RENDERER_GPU_RENDER_WIDGET_COMPOSITOR_H_
6 #define CONTENT_RENDERER_GPU_RENDER_WIDGET_COMPOSITOR_H_ 6 #define CONTENT_RENDERER_GPU_RENDER_WIDGET_COMPOSITOR_H_
7 7
8 #include "base/callback.h" 8 #include "base/callback.h"
9 #include "base/memory/weak_ptr.h" 9 #include "base/memory/weak_ptr.h"
10 #include "base/time/time.h" 10 #include "base/time/time.h"
(...skipping 123 matching lines...) Expand 10 before | Expand all | Expand 10 after
134 void DidBeginMainFrame() override; 134 void DidBeginMainFrame() override;
135 void BeginMainFrame(const cc::BeginFrameArgs& args) override; 135 void BeginMainFrame(const cc::BeginFrameArgs& args) override;
136 void Layout() override; 136 void Layout() override;
137 void ApplyViewportDeltas(const gfx::Vector2d& inner_delta, 137 void ApplyViewportDeltas(const gfx::Vector2d& inner_delta,
138 const gfx::Vector2d& outer_delta, 138 const gfx::Vector2d& outer_delta,
139 float page_scale, 139 float page_scale,
140 float top_controls_delta) override; 140 float top_controls_delta) override;
141 void ApplyViewportDeltas(const gfx::Vector2d& scroll_delta, 141 void ApplyViewportDeltas(const gfx::Vector2d& scroll_delta,
142 float page_scale, 142 float page_scale,
143 float top_controls_delta) override; 143 float top_controls_delta) override;
144 void RequestNewOutputSurface(bool fallback) override; 144 void RequestNewOutputSurface() override;
145 void DidInitializeOutputSurface() override; 145 void DidInitializeOutputSurface() override;
146 void DidFailToInitializeOutputSurface() override;
146 void WillCommit() override; 147 void WillCommit() override;
147 void DidCommit() override; 148 void DidCommit() override;
148 void DidCommitAndDrawFrame() override; 149 void DidCommitAndDrawFrame() override;
149 void DidCompleteSwapBuffers() override; 150 void DidCompleteSwapBuffers() override;
150 void RateLimitSharedMainThreadContext() override; 151 void RateLimitSharedMainThreadContext() override;
151 152
152 // cc::LayerTreeHostSingleThreadClient implementation. 153 // cc::LayerTreeHostSingleThreadClient implementation.
153 void ScheduleAnimation() override; 154 void ScheduleAnimation() override;
154 void DidPostSwapBuffers() override; 155 void DidPostSwapBuffers() override;
155 void DidAbortSwapBuffers() override; 156 void DidAbortSwapBuffers() override;
156 157
157 private: 158 enum {
no sievers 2014/12/02 20:38:07 nit: should it be "const int kMaxOutSurfaceRetries
enne (OOO) 2014/12/02 21:09:33 I wanted these to be accessible to tests and didn'
159 OUTPUT_SURFACE_RETRIES_BEFORE_FALLBACK = 4,
160 MAX_OUTPUT_SURFACE_RETRIES = 5,
161 };
162
163 protected:
158 RenderWidgetCompositor(RenderWidget* widget, bool threaded); 164 RenderWidgetCompositor(RenderWidget* widget, bool threaded);
159 165
160 void Initialize(cc::LayerTreeSettings settings); 166 void Initialize(const cc::LayerTreeSettings& settings);
161 167
168 cc::LayerTreeHost* layer_tree_host() { return layer_tree_host_.get(); }
169
170 private:
171 int num_failed_recreate_attempts_;
162 bool threaded_; 172 bool threaded_;
163 RenderWidget* widget_; 173 RenderWidget* widget_;
164 scoped_ptr<cc::LayerTreeHost> layer_tree_host_; 174 scoped_ptr<cc::LayerTreeHost> layer_tree_host_;
165 175
166 scoped_ptr<cc::CopyOutputRequest> temporary_copy_output_request_; 176 scoped_ptr<cc::CopyOutputRequest> temporary_copy_output_request_;
167 177
168 bool send_v8_idle_notification_after_commit_; 178 bool send_v8_idle_notification_after_commit_;
169 base::TimeTicks begin_main_frame_time_; 179 base::TimeTicks begin_main_frame_time_;
170 // The time interval between BeginMainFrame calls, provided by the scheduler. 180 // The time interval between BeginMainFrame calls, provided by the scheduler.
171 base::TimeDelta begin_main_frame_interval_; 181 base::TimeDelta begin_main_frame_interval_;
182
183 base::WeakPtrFactory<RenderWidgetCompositor> weak_factory_;
172 }; 184 };
173 185
174 } // namespace content 186 } // namespace content
175 187
176 #endif // CONTENT_RENDERER_GPU_RENDER_WIDGET_COMPOSITOR_H_ 188 #endif // CONTENT_RENDERER_GPU_RENDER_WIDGET_COMPOSITOR_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698