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

Side by Side Diff: blimp/client/app/compositor/browser_compositor.cc

Issue 2274323002: Expose Blimp dependencies to the embedder (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@khushal_baseline_1
Patch Set: Addressed Khushal's initial comments Created 4 years, 3 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 // Copyright 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 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 #include "blimp/client/app/compositor/browser_compositor.h" 5 #include "blimp/client/app/compositor/browser_compositor.h"
6 6
7 #include "base/bind.h"
7 #include "base/lazy_instance.h" 8 #include "base/lazy_instance.h"
8 #include "base/threading/thread_task_runner_handle.h" 9 #include "base/threading/thread_task_runner_handle.h"
9 #include "blimp/client/feature/compositor/blimp_context_provider.h" 10 #include "blimp/client/public/compositor/compositor_dependencies.h"
10 #include "blimp/client/feature/compositor/blimp_gpu_memory_buffer_manager.h"
11 #include "cc/animation/animation_host.h" 11 #include "cc/animation/animation_host.h"
12 #include "cc/layers/layer.h" 12 #include "cc/layers/layer.h"
13 #include "cc/output/compositor_frame.h" 13 #include "cc/output/compositor_frame.h"
14 #include "cc/output/texture_mailbox_deleter.h" 14 #include "cc/output/texture_mailbox_deleter.h"
15 #include "cc/raster/single_thread_task_graph_runner.h" 15 #include "cc/raster/single_thread_task_graph_runner.h"
16 #include "cc/surfaces/display.h" 16 #include "cc/surfaces/display.h"
17 #include "cc/surfaces/surface_display_output_surface.h" 17 #include "cc/surfaces/surface_display_output_surface.h"
18 #include "cc/surfaces/surface_id_allocator.h" 18 #include "cc/surfaces/surface_id_allocator.h"
19 #include "cc/surfaces/surface_manager.h" 19 #include "cc/surfaces/surface_manager.h"
20 #include "cc/trees/layer_tree_host.h" 20 #include "cc/trees/layer_tree_host.h"
21 #include "gpu/command_buffer/client/context_support.h" 21 #include "gpu/command_buffer/client/context_support.h"
22 #include "gpu/command_buffer/client/gles2_lib.h"
22 23
23 namespace blimp { 24 namespace blimp {
24 namespace client { 25 namespace client {
25 26
26 namespace { 27 namespace {
27 28
28 class SimpleTaskGraphRunner : public cc::SingleThreadTaskGraphRunner { 29 class SimpleTaskGraphRunner : public cc::SingleThreadTaskGraphRunner {
29 public: 30 public:
30 SimpleTaskGraphRunner() { 31 SimpleTaskGraphRunner() {
31 Start("BlimpBrowserCompositorWorker", 32 Start("BlimpBrowserCompositorWorker",
(...skipping 12 matching lines...) Expand all
44 ~DisplayOutputSurface() override {} 45 ~DisplayOutputSurface() override {}
45 46
46 // cc::OutputSurface implementation 47 // cc::OutputSurface implementation
47 void SwapBuffers(cc::CompositorFrame frame) override { 48 void SwapBuffers(cc::CompositorFrame frame) override {
48 // See cc::OutputSurface::SwapBuffers() comment for details. 49 // See cc::OutputSurface::SwapBuffers() comment for details.
49 context_provider_->ContextSupport()->Swap(); 50 context_provider_->ContextSupport()->Swap();
50 cc::OutputSurface::PostSwapBuffersComplete(); 51 cc::OutputSurface::PostSwapBuffersComplete();
51 } 52 }
52 53
53 uint32_t GetFramebufferCopyTextureFormat() override { 54 uint32_t GetFramebufferCopyTextureFormat() override {
54 auto* gl = static_cast<BlimpContextProvider*>(context_provider()); 55 // We assume we have an alpha channel from the BlimpContextProvider, so use
55 return gl->GetCopyTextureInternalFormat(); 56 // GL_RGBA here.
57 return GL_RGBA;
56 } 58 }
57 59
58 private: 60 private:
59 DISALLOW_COPY_AND_ASSIGN(DisplayOutputSurface); 61 DISALLOW_COPY_AND_ASSIGN(DisplayOutputSurface);
60 }; 62 };
61 63
62 base::LazyInstance<SimpleTaskGraphRunner> g_task_graph_runner = 64 base::LazyInstance<SimpleTaskGraphRunner> g_task_graph_runner =
63 LAZY_INSTANCE_INITIALIZER; 65 LAZY_INSTANCE_INITIALIZER;
64 66
65 base::LazyInstance<cc::SurfaceManager> g_surface_manager =
66 LAZY_INSTANCE_INITIALIZER;
67
68 base::LazyInstance<BlimpGpuMemoryBufferManager> g_gpu_memory_buffer_manager =
69 LAZY_INSTANCE_INITIALIZER;
70
71 uint32_t g_surface_id = 0;
72
73 } // namespace 67 } // namespace
74 68
75 // static 69 BrowserCompositor::BrowserCompositor(
76 cc::SurfaceManager* BrowserCompositor::GetSurfaceManager() { 70 CompositorDependencies* compositor_dependencies)
77 return g_surface_manager.Pointer(); 71 : compositor_dependencies_(compositor_dependencies),
78 } 72 surface_id_allocator_(base::MakeUnique<cc::SurfaceIdAllocator>(
79 73 compositor_dependencies->AllocateSurfaceId())),
80 // static
81 BlimpGpuMemoryBufferManager* BrowserCompositor::GetGpuMemoryBufferManager() {
82 return g_gpu_memory_buffer_manager.Pointer();
83 }
84
85 // static
86 uint32_t BrowserCompositor::AllocateSurfaceClientId() {
87 return ++g_surface_id;
88 }
89
90 BrowserCompositor::BrowserCompositor()
91 : surface_id_allocator_(base::MakeUnique<cc::SurfaceIdAllocator>(
92 BrowserCompositor::AllocateSurfaceClientId())),
93 widget_(gfx::kNullAcceleratedWidget), 74 widget_(gfx::kNullAcceleratedWidget),
94 output_surface_request_pending_(false), 75 output_surface_request_pending_(false),
95 root_layer_(cc::Layer::Create()) { 76 root_layer_(cc::Layer::Create()),
96 BrowserCompositor::GetSurfaceManager()->RegisterSurfaceClientId( 77 weak_ptr_factory_(this) {
78 compositor_dependencies_->GetSurfaceManager()->RegisterSurfaceClientId(
97 surface_id_allocator_->client_id()); 79 surface_id_allocator_->client_id());
98 80
99 cc::LayerTreeHost::InitParams params; 81 cc::LayerTreeHost::InitParams params;
100 params.client = this; 82 params.client = this;
101 params.gpu_memory_buffer_manager = 83 params.gpu_memory_buffer_manager =
102 BrowserCompositor::GetGpuMemoryBufferManager(); 84 compositor_dependencies_->GetGpuMemoryBufferManager();
103 params.task_graph_runner = g_task_graph_runner.Pointer(); 85 params.task_graph_runner = g_task_graph_runner.Pointer();
104 cc::LayerTreeSettings settings; 86 cc::LayerTreeSettings settings;
105 params.settings = &settings; 87 params.settings = &settings;
106 params.main_task_runner = base::ThreadTaskRunnerHandle::Get(); 88 params.main_task_runner = base::ThreadTaskRunnerHandle::Get();
107 params.animation_host = cc::AnimationHost::CreateMainInstance(); 89 params.animation_host = cc::AnimationHost::CreateMainInstance();
108 host_ = cc::LayerTreeHost::CreateSingleThreaded(this, &params); 90 host_ = cc::LayerTreeHost::CreateSingleThreaded(this, &params);
109 91
110 root_layer_->SetBackgroundColor(SK_ColorWHITE); 92 root_layer_->SetBackgroundColor(SK_ColorWHITE);
111 host_->GetLayerTree()->SetRootLayer(root_layer_); 93 host_->GetLayerTree()->SetRootLayer(root_layer_);
112 host_->set_surface_client_id(surface_id_allocator_->client_id()); 94 host_->set_surface_client_id(surface_id_allocator_->client_id());
113 } 95 }
114 96
115 BrowserCompositor::~BrowserCompositor() { 97 BrowserCompositor::~BrowserCompositor() {
116 BrowserCompositor::GetSurfaceManager()->InvalidateSurfaceClientId( 98 compositor_dependencies_->GetSurfaceManager()->InvalidateSurfaceClientId(
117 surface_id_allocator_->client_id()); 99 surface_id_allocator_->client_id());
118 } 100 }
119 101
120 void BrowserCompositor::SetContentLayer( 102 void BrowserCompositor::SetContentLayer(
121 scoped_refptr<cc::Layer> content_layer) { 103 scoped_refptr<cc::Layer> content_layer) {
122 root_layer_->RemoveAllChildren(); 104 root_layer_->RemoveAllChildren();
123 root_layer_->AddChild(content_layer); 105 root_layer_->AddChild(content_layer);
124 } 106 }
125 107
126 void BrowserCompositor::SetSize(const gfx::Size& size_in_px) { 108 void BrowserCompositor::SetSize(const gfx::Size& size_in_px) {
(...skipping 19 matching lines...) Expand all
146 host_->ReleaseOutputSurface(); 128 host_->ReleaseOutputSurface();
147 } 129 }
148 display_.reset(); 130 display_.reset();
149 } 131 }
150 132
151 widget_ = gfx::kNullAcceleratedWidget; 133 widget_ = gfx::kNullAcceleratedWidget;
152 134
153 if (widget != gfx::kNullAcceleratedWidget) { 135 if (widget != gfx::kNullAcceleratedWidget) {
154 widget_ = widget; 136 widget_ = widget;
155 host_->SetVisible(true); 137 host_->SetVisible(true);
156 if (output_surface_request_pending_) 138 if (output_surface_request_pending_) {
157 HandlePendingOutputSurfaceRequest(); 139 // Request a ContextProvider now that we have a valid widget.
140 compositor_dependencies_->GetContextProvider(
141 base::Bind(&BrowserCompositor::OnContextProviderCreated,
Khushal 2016/08/25 05:02:53 I didn't see this earlier, but we are creating an
David Trainor- moved to gerrit 2016/08/26 17:15:54 Hah yeah I ran into this this morning before I saw
142 weak_ptr_factory_.GetWeakPtr()));
143 }
158 } 144 }
159 } 145 }
160 146
161 void BrowserCompositor::RequestNewOutputSurface() { 147 void BrowserCompositor::OnContextProviderCreated(
162 DCHECK(!output_surface_request_pending_) 148 scoped_refptr<cc::ContextProvider> provider) {
163 << "We already have a pending request?"; 149 DCHECK(output_surface_request_pending_);
164 output_surface_request_pending_ = true;
165 HandlePendingOutputSurfaceRequest();
166 }
167 150
168 void BrowserCompositor::DidInitializeOutputSurface() { 151 // TODO(dtrainor, khushalsagar): Handle ContextProvider creation failures.
169 output_surface_request_pending_ = false; 152 LOG_IF(FATAL, !provider)
170 } 153 << "Failed ContextProvider requests are unsupported.";
171 154
172 void BrowserCompositor::DidFailToInitializeOutputSurface() { 155 // While we were waiting we state changed and we no longer require an
173 NOTREACHED() << "Can't fail to initialize the OutputSurface here"; 156 // OutputSurface. Bail out.
174 } 157 if (widget_ == gfx::kNullAcceleratedWidget)
175 158 return;
176 void BrowserCompositor::DidCompleteSwapBuffers() {
177 if (!did_complete_swap_buffers_.is_null()) {
178 did_complete_swap_buffers_.Run();
179 }
180 }
181
182 void BrowserCompositor::HandlePendingOutputSurfaceRequest() {
183 DCHECK(output_surface_request_pending_);
184 159
185 // Can't handle the request right now since we don't have a widget. 160 // Can't handle the request right now since we don't have a widget.
186 if (!host_->visible()) 161 if (!host_->visible())
187 return; 162 return;
188 163
189 DCHECK_NE(gfx::kNullAcceleratedWidget, widget_); 164 DCHECK_NE(gfx::kNullAcceleratedWidget, widget_);
190 165
191 scoped_refptr<cc::ContextProvider> context_provider = 166 gpu::GpuMemoryBufferManager* gpu_memory_buffer_manager =
192 BlimpContextProvider::Create( 167 compositor_dependencies_->GetGpuMemoryBufferManager();
193 widget_, BrowserCompositor::GetGpuMemoryBufferManager());
194 168
195 std::unique_ptr<cc::OutputSurface> display_output_surface = 169 std::unique_ptr<cc::OutputSurface> display_output_surface =
196 base::MakeUnique<DisplayOutputSurface>(context_provider); 170 base::MakeUnique<DisplayOutputSurface>(provider);
197 171
198 auto* task_runner = base::ThreadTaskRunnerHandle::Get().get(); 172 auto* task_runner = base::ThreadTaskRunnerHandle::Get().get();
199 std::unique_ptr<cc::SyntheticBeginFrameSource> begin_frame_source( 173 std::unique_ptr<cc::SyntheticBeginFrameSource> begin_frame_source(
200 new cc::DelayBasedBeginFrameSource( 174 new cc::DelayBasedBeginFrameSource(
201 base::MakeUnique<cc::DelayBasedTimeSource>(task_runner))); 175 base::MakeUnique<cc::DelayBasedTimeSource>(task_runner)));
202 std::unique_ptr<cc::DisplayScheduler> scheduler(new cc::DisplayScheduler( 176 std::unique_ptr<cc::DisplayScheduler> scheduler(new cc::DisplayScheduler(
203 begin_frame_source.get(), task_runner, 177 begin_frame_source.get(), task_runner,
204 display_output_surface->capabilities().max_frames_pending)); 178 display_output_surface->capabilities().max_frames_pending));
205 179
206 display_ = base::MakeUnique<cc::Display>( 180 display_ = base::MakeUnique<cc::Display>(
207 nullptr /*shared_bitmap_manager*/, 181 nullptr /*shared_bitmap_manager*/, gpu_memory_buffer_manager,
208 BrowserCompositor::GetGpuMemoryBufferManager(),
209 host_->settings().renderer_settings, std::move(begin_frame_source), 182 host_->settings().renderer_settings, std::move(begin_frame_source),
210 std::move(display_output_surface), std::move(scheduler), 183 std::move(display_output_surface), std::move(scheduler),
211 base::MakeUnique<cc::TextureMailboxDeleter>(task_runner)); 184 base::MakeUnique<cc::TextureMailboxDeleter>(task_runner));
212 display_->SetVisible(true); 185 display_->SetVisible(true);
213 display_->Resize(viewport_size_in_px_); 186 display_->Resize(viewport_size_in_px_);
214 187
215 // The Browser compositor and display share the same context provider. 188 // The Browser compositor and display share the same context provider.
216 std::unique_ptr<cc::OutputSurface> delegated_output_surface = 189 std::unique_ptr<cc::OutputSurface> delegated_output_surface =
217 base::MakeUnique<cc::SurfaceDisplayOutputSurface>( 190 base::MakeUnique<cc::SurfaceDisplayOutputSurface>(
218 BrowserCompositor::GetSurfaceManager(), surface_id_allocator_.get(), 191 compositor_dependencies_->GetSurfaceManager(),
219 display_.get(), context_provider, nullptr); 192 surface_id_allocator_.get(), display_.get(), provider, nullptr);
220 193
221 host_->SetOutputSurface(std::move(delegated_output_surface)); 194 host_->SetOutputSurface(std::move(delegated_output_surface));
222 } 195 }
223 196
197 void BrowserCompositor::RequestNewOutputSurface() {
198 DCHECK(!output_surface_request_pending_)
199 << "We already have a pending request?";
200 output_surface_request_pending_ = true;
201 if (widget_ != gfx::kNullAcceleratedWidget) {
202 // Request a ContextProvider if we have a valid widget.
203 compositor_dependencies_->GetContextProvider(
204 base::Bind(&BrowserCompositor::OnContextProviderCreated,
205 weak_ptr_factory_.GetWeakPtr()));
206 }
207 }
208
209 void BrowserCompositor::DidInitializeOutputSurface() {
210 output_surface_request_pending_ = false;
211 }
212
213 void BrowserCompositor::DidFailToInitializeOutputSurface() {
214 NOTREACHED() << "Can't fail to initialize the OutputSurface here";
215 }
216
217 void BrowserCompositor::DidCompleteSwapBuffers() {
218 if (!did_complete_swap_buffers_.is_null()) {
219 did_complete_swap_buffers_.Run();
220 }
221 }
222
224 } // namespace client 223 } // namespace client
225 } // namespace blimp 224 } // namespace blimp
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698