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

Side by Side Diff: content/browser/compositor/gpu_browser_compositor_output_surface.cc

Issue 423773002: Unified BeginFrame scheduling (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 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 | Annotate | Revision Log
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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 "content/browser/compositor/gpu_browser_compositor_output_surface.h" 5 #include "content/browser/compositor/gpu_browser_compositor_output_surface.h"
6 6
7 #include "cc/output/compositor_frame.h" 7 #include "cc/output/compositor_frame.h"
8 #include "content/browser/compositor/reflector_impl.h" 8 #include "content/browser/compositor/reflector_impl.h"
9 #include "content/common/gpu/client/context_provider_command_buffer.h" 9 #include "content/common/gpu/client/context_provider_command_buffer.h"
10 #include "gpu/command_buffer/client/gles2_interface.h" 10 #include "gpu/command_buffer/client/gles2_interface.h"
11 11
12 namespace content { 12 namespace content {
13 13
14 GpuBrowserCompositorOutputSurface::GpuBrowserCompositorOutputSurface( 14 GpuBrowserCompositorOutputSurface::GpuBrowserCompositorOutputSurface(
15 const scoped_refptr<ContextProviderCommandBuffer>& context, 15 const scoped_refptr<ContextProviderCommandBuffer>& context,
16 int surface_id, 16 int surface_id,
17 IDMap<BrowserCompositorOutputSurface>* output_surface_map, 17 IDMap<BrowserCompositorOutputSurface>* output_surface_map,
18 const scoped_refptr<ui::CompositorVSyncManager>& vsync_manager,
19 scoped_ptr<cc::OverlayCandidateValidator> overlay_candidate_validator) 18 scoped_ptr<cc::OverlayCandidateValidator> overlay_candidate_validator)
20 : BrowserCompositorOutputSurface(context, 19 : BrowserCompositorOutputSurface(context,
21 surface_id, 20 surface_id,
22 output_surface_map, 21 output_surface_map) {
23 vsync_manager) {
24 overlay_candidate_validator_ = overlay_candidate_validator.Pass(); 22 overlay_candidate_validator_ = overlay_candidate_validator.Pass();
25 } 23 }
26 24
27 GpuBrowserCompositorOutputSurface::~GpuBrowserCompositorOutputSurface() {} 25 GpuBrowserCompositorOutputSurface::~GpuBrowserCompositorOutputSurface() {}
28 26
29 void GpuBrowserCompositorOutputSurface::SwapBuffers( 27 void GpuBrowserCompositorOutputSurface::SwapBuffers(
30 cc::CompositorFrame* frame) { 28 cc::CompositorFrame* frame) {
31 DCHECK(frame->gl_frame_data); 29 DCHECK(frame->gl_frame_data);
32 30
33 ContextProviderCommandBuffer* provider_command_buffer = 31 ContextProviderCommandBuffer* provider_command_buffer =
34 static_cast<ContextProviderCommandBuffer*>(context_provider_.get()); 32 static_cast<ContextProviderCommandBuffer*>(context_provider_.get());
35 CommandBufferProxyImpl* command_buffer_proxy = 33 CommandBufferProxyImpl* command_buffer_proxy =
36 provider_command_buffer->GetCommandBufferProxy(); 34 provider_command_buffer->GetCommandBufferProxy();
37 DCHECK(command_buffer_proxy); 35 DCHECK(command_buffer_proxy);
38 context_provider_->ContextGL()->ShallowFlushCHROMIUM(); 36 context_provider_->ContextGL()->ShallowFlushCHROMIUM();
39 command_buffer_proxy->SetLatencyInfo(frame->metadata.latency_info); 37 command_buffer_proxy->SetLatencyInfo(frame->metadata.latency_info);
40 38
41 if (reflector_.get()) { 39 if (reflector_.get()) {
42 if (frame->gl_frame_data->sub_buffer_rect == 40 if (frame->gl_frame_data->sub_buffer_rect ==
43 gfx::Rect(frame->gl_frame_data->size)) 41 gfx::Rect(frame->gl_frame_data->size))
44 reflector_->OnSwapBuffers(); 42 reflector_->OnSwapBuffers();
45 else 43 else
46 reflector_->OnPostSubBuffer(frame->gl_frame_data->sub_buffer_rect); 44 reflector_->OnPostSubBuffer(frame->gl_frame_data->sub_buffer_rect);
47 } 45 }
48 46
49 OutputSurface::SwapBuffers(frame); 47 OutputSurface::SwapBuffers(frame);
50 } 48 }
51 49
52 } // namespace content 50 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698