Chromium Code Reviews| Index: content/browser/aura/gpu_browser_compositor_output_surface.cc |
| diff --git a/content/browser/aura/gpu_browser_compositor_output_surface.cc b/content/browser/aura/gpu_browser_compositor_output_surface.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..6fd8041ccf0e0b90c2fe8b947eafeac5b27fa2fb |
| --- /dev/null |
| +++ b/content/browser/aura/gpu_browser_compositor_output_surface.cc |
| @@ -0,0 +1,53 @@ |
| +// Copyright 2013 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#include "content/browser/aura/gpu_browser_compositor_output_surface.h" |
| + |
| +#include "cc/output/compositor_frame.h" |
| +#include "content/browser/aura/reflector_impl.h" |
| +#include "content/common/gpu/client/webgraphicscontext3d_command_buffer_impl.h" |
| + |
| +namespace content { |
| + |
| +GpuBrowserCompositorOutputSurface::GpuBrowserCompositorOutputSurface( |
| + const scoped_refptr<ContextProviderCommandBuffer>& context, |
| + int surface_id, |
| + IDMap<BrowserCompositorOutputSurface>* output_surface_map, |
| + base::MessageLoopProxy* compositor_message_loop, |
| + base::WeakPtr<ui::Compositor> compositor) |
| + : BrowserCompositorOutputSurface(context, |
| + surface_id, |
| + output_surface_map, |
| + compositor_message_loop, |
| + compositor) { |
| + DetachFromThread(); |
|
piman
2013/11/07 00:45:12
This should be mostly orthogonal to HW vs SW, modu
dnicoara
2013/11/07 15:17:41
Done.
Ozone should work just fine with the thread
|
| +} |
| + |
| +GpuBrowserCompositorOutputSurface::~GpuBrowserCompositorOutputSurface() {} |
| + |
| +void GpuBrowserCompositorOutputSurface::SwapBuffers( |
| + cc::CompositorFrame* frame) { |
| + DCHECK(frame->gl_frame_data); |
| + |
| + WebGraphicsContext3DCommandBufferImpl* command_buffer_context = |
| + static_cast<WebGraphicsContext3DCommandBufferImpl*>( |
| + context_provider_->Context3d()); |
| + CommandBufferProxyImpl* command_buffer_proxy = |
| + command_buffer_context->GetCommandBufferProxy(); |
| + DCHECK(command_buffer_proxy); |
| + context_provider_->Context3d()->shallowFlushCHROMIUM(); |
| + command_buffer_proxy->SetLatencyInfo(frame->metadata.latency_info); |
| + |
| + if (reflector_.get()) { |
| + if (frame->gl_frame_data->sub_buffer_rect == |
| + gfx::Rect(frame->gl_frame_data->size)) |
| + reflector_->OnSwapBuffers(); |
| + else |
| + reflector_->OnPostSubBuffer(frame->gl_frame_data->sub_buffer_rect); |
| + } |
| + |
| + OutputSurface::SwapBuffers(frame); |
| +} |
| + |
| +} // namespace content |