Chromium Code Reviews| OLD | NEW |
|---|---|
| 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/support/compositor/blimp_embedder_compositor.h" | 5 #include "blimp/client/support/compositor/blimp_embedder_compositor.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/lazy_instance.h" | 8 #include "base/lazy_instance.h" |
| 9 #include "base/memory/weak_ptr.h" | |
| 9 #include "base/threading/thread_task_runner_handle.h" | 10 #include "base/threading/thread_task_runner_handle.h" |
| 10 #include "blimp/client/public/compositor/compositor_dependencies.h" | 11 #include "blimp/client/public/compositor/compositor_dependencies.h" |
| 11 #include "blimp/client/support/compositor/blimp_context_provider.h" | 12 #include "blimp/client/support/compositor/blimp_context_provider.h" |
| 12 #include "cc/animation/animation_host.h" | 13 #include "cc/animation/animation_host.h" |
| 13 #include "cc/layers/layer.h" | 14 #include "cc/layers/layer.h" |
| 14 #include "cc/output/output_surface.h" | 15 #include "cc/output/output_surface.h" |
| 15 #include "cc/output/output_surface_frame.h" | 16 #include "cc/output/output_surface_frame.h" |
| 16 #include "cc/output/texture_mailbox_deleter.h" | 17 #include "cc/output/texture_mailbox_deleter.h" |
| 17 #include "cc/raster/single_thread_task_graph_runner.h" | 18 #include "cc/raster/single_thread_task_graph_runner.h" |
| 18 #include "cc/surfaces/direct_compositor_frame_sink.h" | 19 #include "cc/surfaces/direct_compositor_frame_sink.h" |
| (...skipping 15 matching lines...) Expand all Loading... | |
| 34 Start("BlimpBrowserCompositorWorker", | 35 Start("BlimpBrowserCompositorWorker", |
| 35 base::SimpleThread::Options(base::ThreadPriority::BACKGROUND)); | 36 base::SimpleThread::Options(base::ThreadPriority::BACKGROUND)); |
| 36 } | 37 } |
| 37 | 38 |
| 38 ~SimpleTaskGraphRunner() override { Shutdown(); } | 39 ~SimpleTaskGraphRunner() override { Shutdown(); } |
| 39 }; | 40 }; |
| 40 | 41 |
| 41 class DisplayOutputSurface : public cc::OutputSurface { | 42 class DisplayOutputSurface : public cc::OutputSurface { |
| 42 public: | 43 public: |
| 43 explicit DisplayOutputSurface( | 44 explicit DisplayOutputSurface( |
| 44 scoped_refptr<cc::ContextProvider> context_provider) | 45 scoped_refptr<cc::ContextProvider> context_provider, |
| 45 : cc::OutputSurface(std::move(context_provider)) {} | 46 scoped_refptr<base::SingleThreadTaskRunner> task_runner) |
| 47 : cc::OutputSurface(std::move(context_provider)), | |
| 48 task_runner_(std::move(task_runner)), | |
| 49 weak_ptr_factory_(this) {} | |
| 46 | 50 |
| 47 ~DisplayOutputSurface() override = default; | 51 ~DisplayOutputSurface() override = default; |
| 48 | 52 |
| 49 // cc::OutputSurface implementation | 53 // cc::OutputSurface implementation |
| 50 void EnsureBackbuffer() override {} | 54 void EnsureBackbuffer() override {} |
| 51 void DiscardBackbuffer() override { | 55 void DiscardBackbuffer() override { |
| 52 context_provider()->ContextGL()->DiscardBackbufferCHROMIUM(); | 56 context_provider()->ContextGL()->DiscardBackbufferCHROMIUM(); |
| 53 } | 57 } |
| 54 void BindFramebuffer() override { | 58 void BindFramebuffer() override { |
| 55 context_provider()->ContextGL()->BindFramebuffer(GL_FRAMEBUFFER, 0); | 59 context_provider()->ContextGL()->BindFramebuffer(GL_FRAMEBUFFER, 0); |
| 56 } | 60 } |
| 57 void SwapBuffers(cc::OutputSurfaceFrame frame) override { | 61 void SwapBuffers(cc::OutputSurfaceFrame frame) override { |
| 58 // See cc::OutputSurface::SwapBuffers() comment for details. | |
| 59 context_provider_->ContextSupport()->Swap(); | 62 context_provider_->ContextSupport()->Swap(); |
| 60 cc::OutputSurface::PostSwapBuffersComplete(); | 63 task_runner_->PostTask( |
|
Khushal
2016/10/10 17:40:10
Comment here that acks for submitted frames must b
danakj
2016/10/10 20:28:19
Done.
| |
| 64 FROM_HERE, base::Bind(&DisplayOutputSurface::SwapBuffersCallback, | |
| 65 weak_ptr_factory_.GetWeakPtr())); | |
| 61 } | 66 } |
| 62 cc::OverlayCandidateValidator* GetOverlayCandidateValidator() const override { | 67 cc::OverlayCandidateValidator* GetOverlayCandidateValidator() const override { |
| 63 return nullptr; | 68 return nullptr; |
| 64 } | 69 } |
| 65 bool IsDisplayedAsOverlayPlane() const override { return false; } | 70 bool IsDisplayedAsOverlayPlane() const override { return false; } |
| 66 unsigned GetOverlayTextureId() const override { return 0; } | 71 unsigned GetOverlayTextureId() const override { return 0; } |
| 67 bool SurfaceIsSuspendForRecycle() const override { return false; } | 72 bool SurfaceIsSuspendForRecycle() const override { return false; } |
| 68 uint32_t GetFramebufferCopyTextureFormat() override { | 73 uint32_t GetFramebufferCopyTextureFormat() override { |
| 69 // We assume we have an alpha channel from the BlimpContextProvider, so use | 74 // We assume we have an alpha channel from the BlimpContextProvider, so use |
| 70 // GL_RGBA here. | 75 // GL_RGBA here. |
| 71 return GL_RGBA; | 76 return GL_RGBA; |
| 72 } | 77 } |
| 73 bool HasExternalStencilTest() const override { return false; } | 78 bool HasExternalStencilTest() const override { return false; } |
| 74 void ApplyExternalStencil() override {} | 79 void ApplyExternalStencil() override {} |
| 75 | 80 |
| 76 private: | 81 private: |
| 82 void SwapBuffersCallback() { client_->DidSwapBuffersComplete(); } | |
| 83 | |
| 84 scoped_refptr<base::SingleThreadTaskRunner> task_runner_; | |
| 85 base::WeakPtrFactory<DisplayOutputSurface> weak_ptr_factory_; | |
| 86 | |
| 77 DISALLOW_COPY_AND_ASSIGN(DisplayOutputSurface); | 87 DISALLOW_COPY_AND_ASSIGN(DisplayOutputSurface); |
| 78 }; | 88 }; |
| 79 | 89 |
| 80 base::LazyInstance<SimpleTaskGraphRunner> g_task_graph_runner = | 90 base::LazyInstance<SimpleTaskGraphRunner> g_task_graph_runner = |
| 81 LAZY_INSTANCE_INITIALIZER; | 91 LAZY_INSTANCE_INITIALIZER; |
| 82 | 92 |
| 83 } // namespace | 93 } // namespace |
| 84 | 94 |
| 85 BlimpEmbedderCompositor::BlimpEmbedderCompositor( | 95 BlimpEmbedderCompositor::BlimpEmbedderCompositor( |
| 86 CompositorDependencies* compositor_dependencies) | 96 CompositorDependencies* compositor_dependencies) |
| (...skipping 85 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 172 | 182 |
| 173 // Can't handle the request right now since we don't have a widget. | 183 // Can't handle the request right now since we don't have a widget. |
| 174 if (!host_->IsVisible()) | 184 if (!host_->IsVisible()) |
| 175 return; | 185 return; |
| 176 | 186 |
| 177 DCHECK(context_provider_); | 187 DCHECK(context_provider_); |
| 178 | 188 |
| 179 gpu::GpuMemoryBufferManager* gpu_memory_buffer_manager = | 189 gpu::GpuMemoryBufferManager* gpu_memory_buffer_manager = |
| 180 compositor_dependencies_->GetGpuMemoryBufferManager(); | 190 compositor_dependencies_->GetGpuMemoryBufferManager(); |
| 181 | 191 |
| 192 auto task_runner = base::ThreadTaskRunnerHandle::Get(); | |
| 182 auto display_output_surface = | 193 auto display_output_surface = |
| 183 base::MakeUnique<DisplayOutputSurface>(context_provider_); | 194 base::MakeUnique<DisplayOutputSurface>(context_provider_, task_runner); |
| 184 | 195 |
| 185 auto* task_runner = base::ThreadTaskRunnerHandle::Get().get(); | |
| 186 std::unique_ptr<cc::SyntheticBeginFrameSource> begin_frame_source( | 196 std::unique_ptr<cc::SyntheticBeginFrameSource> begin_frame_source( |
| 187 new cc::DelayBasedBeginFrameSource( | 197 new cc::DelayBasedBeginFrameSource( |
| 188 base::MakeUnique<cc::DelayBasedTimeSource>(task_runner))); | 198 base::MakeUnique<cc::DelayBasedTimeSource>(task_runner.get()))); |
| 189 std::unique_ptr<cc::DisplayScheduler> scheduler(new cc::DisplayScheduler( | 199 std::unique_ptr<cc::DisplayScheduler> scheduler(new cc::DisplayScheduler( |
| 190 begin_frame_source.get(), task_runner, | 200 begin_frame_source.get(), task_runner.get(), |
| 191 display_output_surface->capabilities().max_frames_pending)); | 201 display_output_surface->capabilities().max_frames_pending)); |
| 192 | 202 |
| 193 display_ = base::MakeUnique<cc::Display>( | 203 display_ = base::MakeUnique<cc::Display>( |
| 194 nullptr /*shared_bitmap_manager*/, gpu_memory_buffer_manager, | 204 nullptr /*shared_bitmap_manager*/, gpu_memory_buffer_manager, |
| 195 host_->GetSettings().renderer_settings, std::move(begin_frame_source), | 205 host_->GetSettings().renderer_settings, std::move(begin_frame_source), |
| 196 std::move(display_output_surface), std::move(scheduler), | 206 std::move(display_output_surface), std::move(scheduler), |
| 197 base::MakeUnique<cc::TextureMailboxDeleter>(task_runner)); | 207 base::MakeUnique<cc::TextureMailboxDeleter>(task_runner.get())); |
| 198 display_->SetVisible(true); | 208 display_->SetVisible(true); |
| 199 display_->Resize(viewport_size_in_px_); | 209 display_->Resize(viewport_size_in_px_); |
| 200 | 210 |
| 201 // The Browser compositor and display share the same context provider. | 211 // The Browser compositor and display share the same context provider. |
| 202 auto compositor_frame_sink = base::MakeUnique<cc::DirectCompositorFrameSink>( | 212 auto compositor_frame_sink = base::MakeUnique<cc::DirectCompositorFrameSink>( |
| 203 frame_sink_id_, compositor_dependencies_->GetSurfaceManager(), | 213 frame_sink_id_, compositor_dependencies_->GetSurfaceManager(), |
| 204 display_.get(), context_provider_, nullptr); | 214 display_.get(), context_provider_, nullptr); |
| 205 | 215 |
| 206 host_->SetCompositorFrameSink(std::move(compositor_frame_sink)); | 216 host_->SetCompositorFrameSink(std::move(compositor_frame_sink)); |
| 207 } | 217 } |
| 208 | 218 |
| 209 } // namespace client | 219 } // namespace client |
| 210 } // namespace blimp | 220 } // namespace blimp |
| OLD | NEW |