| OLD | NEW |
| 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/delegated_frame_host.h" | 5 #include "content/browser/compositor/delegated_frame_host.h" |
| 6 | 6 |
| 7 #include "base/callback_helpers.h" | 7 #include "base/callback_helpers.h" |
| 8 #include "base/command_line.h" | 8 #include "base/command_line.h" |
| 9 #include "cc/output/compositor_frame.h" | 9 #include "cc/output/compositor_frame.h" |
| 10 #include "cc/output/compositor_frame_ack.h" | 10 #include "cc/output/compositor_frame_ack.h" |
| (...skipping 46 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 57 | 57 |
| 58 DelegatedFrameHost::DelegatedFrameHost(DelegatedFrameHostClient* client) | 58 DelegatedFrameHost::DelegatedFrameHost(DelegatedFrameHostClient* client) |
| 59 : client_(client), | 59 : client_(client), |
| 60 compositor_(nullptr), | 60 compositor_(nullptr), |
| 61 use_surfaces_(UseSurfacesEnabled()), | 61 use_surfaces_(UseSurfacesEnabled()), |
| 62 last_output_surface_id_(0), | 62 last_output_surface_id_(0), |
| 63 pending_delegated_ack_count_(0), | 63 pending_delegated_ack_count_(0), |
| 64 skipped_frames_(false), | 64 skipped_frames_(false), |
| 65 current_scale_factor_(1.f), | 65 current_scale_factor_(1.f), |
| 66 can_lock_compositor_(YES_CAN_LOCK), | 66 can_lock_compositor_(YES_CAN_LOCK), |
| 67 frame_subscriber_copy_request_pending_(false), |
| 67 delegated_frame_evictor_(new DelegatedFrameEvictor(this)) { | 68 delegated_frame_evictor_(new DelegatedFrameEvictor(this)) { |
| 68 ImageTransportFactory::GetInstance()->AddObserver(this); | 69 ImageTransportFactory::GetInstance()->AddObserver(this); |
| 69 } | 70 } |
| 70 | 71 |
| 71 void DelegatedFrameHost::WasShown(const ui::LatencyInfo& latency_info) { | 72 void DelegatedFrameHost::WasShown(const ui::LatencyInfo& latency_info) { |
| 72 delegated_frame_evictor_->SetVisible(true); | 73 delegated_frame_evictor_->SetVisible(true); |
| 73 | 74 |
| 74 if (surface_id_.is_null() && !frame_provider_.get() && | 75 if (surface_id_.is_null() && !frame_provider_.get() && |
| 75 !released_front_lock_.get()) { | 76 !released_front_lock_.get()) { |
| 76 if (compositor_) | 77 if (compositor_) |
| (...skipping 185 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 262 present_time = now; | 263 present_time = now; |
| 263 } else { | 264 } else { |
| 264 const int64 intervals_elapsed = (now - vsync_timebase_) / vsync_interval_; | 265 const int64 intervals_elapsed = (now - vsync_timebase_) / vsync_interval_; |
| 265 present_time = vsync_timebase_ + (intervals_elapsed + 1) * vsync_interval_; | 266 present_time = vsync_timebase_ + (intervals_elapsed + 1) * vsync_interval_; |
| 266 } | 267 } |
| 267 | 268 |
| 268 scoped_refptr<media::VideoFrame> frame; | 269 scoped_refptr<media::VideoFrame> frame; |
| 269 RenderWidgetHostViewFrameSubscriber::DeliverFrameCallback callback; | 270 RenderWidgetHostViewFrameSubscriber::DeliverFrameCallback callback; |
| 270 if (frame_subscriber()->ShouldCaptureFrame(damage_rect, present_time, | 271 if (frame_subscriber()->ShouldCaptureFrame(damage_rect, present_time, |
| 271 &frame, &callback)) { | 272 &frame, &callback)) { |
| 273 if (frame_subscriber_copy_request_pending_) { |
| 274 // A copy request was made for the previous frame from the renderer, but |
| 275 // drawing never started (which executes the request). Therefore, that |
| 276 // request is still alive; and this request should be immediately aborted. |
| 277 // Note that this de-duping check must be done after the call to |
| 278 // ShouldCaptureFrame() above, since the frame subscriber makes decisions |
| 279 // based on the renderer's intentions, and not the performance of the |
| 280 // browser compositor. |
| 281 callback.Run(present_time, false); |
| 282 return; |
| 283 } |
| 284 frame_subscriber_copy_request_pending_ = true; |
| 272 CopyFromCompositingSurfaceToVideoFrame( | 285 CopyFromCompositingSurfaceToVideoFrame( |
| 273 gfx::Rect(current_frame_size_in_dip_), | 286 gfx::Rect(current_frame_size_in_dip_), |
| 274 frame, | 287 frame, |
| 275 base::Bind(callback, present_time)); | 288 base::Bind(callback, present_time)); |
| 276 } | 289 } |
| 277 } | 290 } |
| 278 | 291 |
| 279 void DelegatedFrameHost::SwapDelegatedFrame( | 292 void DelegatedFrameHost::SwapDelegatedFrame( |
| 280 uint32 output_surface_id, | 293 uint32 output_surface_id, |
| 281 scoped_ptr<cc::DelegatedFrameData> frame_data, | 294 scoped_ptr<cc::DelegatedFrameData> frame_data, |
| (...skipping 565 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 847 // We may have had a resize while we had the lock (e.g. if the lock expired, | 860 // We may have had a resize while we had the lock (e.g. if the lock expired, |
| 848 // or if the UI still gave us some resizes), so make sure we grab a new lock | 861 // or if the UI still gave us some resizes), so make sure we grab a new lock |
| 849 // if necessary. | 862 // if necessary. |
| 850 MaybeCreateResizeLock(); | 863 MaybeCreateResizeLock(); |
| 851 } | 864 } |
| 852 } | 865 } |
| 853 | 866 |
| 854 void DelegatedFrameHost::OnCompositingStarted( | 867 void DelegatedFrameHost::OnCompositingStarted( |
| 855 ui::Compositor* compositor, base::TimeTicks start_time) { | 868 ui::Compositor* compositor, base::TimeTicks start_time) { |
| 856 last_draw_ended_ = start_time; | 869 last_draw_ended_ = start_time; |
| 870 frame_subscriber_copy_request_pending_ = false; |
| 857 } | 871 } |
| 858 | 872 |
| 859 void DelegatedFrameHost::OnCompositingEnded( | 873 void DelegatedFrameHost::OnCompositingEnded( |
| 860 ui::Compositor* compositor) { | 874 ui::Compositor* compositor) { |
| 861 } | 875 } |
| 862 | 876 |
| 863 void DelegatedFrameHost::OnCompositingAborted(ui::Compositor* compositor) { | 877 void DelegatedFrameHost::OnCompositingAborted(ui::Compositor* compositor) { |
| 864 } | 878 } |
| 865 | 879 |
| 866 void DelegatedFrameHost::OnCompositingLockStateChanged( | 880 void DelegatedFrameHost::OnCompositingLockStateChanged( |
| (...skipping 128 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 995 cc::SurfaceManager* manager = factory->GetSurfaceManager(); | 1009 cc::SurfaceManager* manager = factory->GetSurfaceManager(); |
| 996 new_layer->SetShowSurface( | 1010 new_layer->SetShowSurface( |
| 997 surface_id_, base::Bind(&SatisfyCallback, base::Unretained(manager)), | 1011 surface_id_, base::Bind(&SatisfyCallback, base::Unretained(manager)), |
| 998 base::Bind(&RequireCallback, base::Unretained(manager)), | 1012 base::Bind(&RequireCallback, base::Unretained(manager)), |
| 999 current_surface_size_, current_scale_factor_, | 1013 current_surface_size_, current_scale_factor_, |
| 1000 current_frame_size_in_dip_); | 1014 current_frame_size_in_dip_); |
| 1001 } | 1015 } |
| 1002 } | 1016 } |
| 1003 | 1017 |
| 1004 } // namespace content | 1018 } // namespace content |
| OLD | NEW |