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 "cc/surfaces/onscreen_display_client.h" | 5 #include "cc/surfaces/onscreen_display_client.h" |
6 | 6 |
7 #include "base/trace_event/trace_event.h" | 7 #include "base/trace_event/trace_event.h" |
8 #include "cc/output/output_surface.h" | 8 #include "cc/output/output_surface.h" |
9 #include "cc/scheduler/begin_frame_source.h" | 9 #include "cc/scheduler/begin_frame_source.h" |
10 #include "cc/surfaces/display_scheduler.h" | 10 #include "cc/surfaces/display_scheduler.h" |
(...skipping 10 matching lines...) Expand all Loading... |
21 gpu::GpuMemoryBufferManager* gpu_memory_buffer_manager, | 21 gpu::GpuMemoryBufferManager* gpu_memory_buffer_manager, |
22 const RendererSettings& settings, | 22 const RendererSettings& settings, |
23 scoped_refptr<base::SingleThreadTaskRunner> task_runner) | 23 scoped_refptr<base::SingleThreadTaskRunner> task_runner) |
24 : output_surface_(std::move(output_surface)), | 24 : output_surface_(std::move(output_surface)), |
25 task_runner_(task_runner), | 25 task_runner_(task_runner), |
26 display_(new Display(this, | 26 display_(new Display(this, |
27 manager, | 27 manager, |
28 bitmap_manager, | 28 bitmap_manager, |
29 gpu_memory_buffer_manager, | 29 gpu_memory_buffer_manager, |
30 settings)), | 30 settings)), |
31 output_surface_lost_(false), | 31 output_surface_lost_(false) {} |
32 disable_display_vsync_(settings.disable_display_vsync) {} | |
33 | 32 |
34 OnscreenDisplayClient::~OnscreenDisplayClient() { | 33 OnscreenDisplayClient::~OnscreenDisplayClient() { |
35 } | 34 } |
36 | 35 |
37 bool OnscreenDisplayClient::Initialize() { | 36 bool OnscreenDisplayClient::Initialize() { |
38 DCHECK(output_surface_); | 37 DCHECK(output_surface_); |
39 | 38 return display_->Initialize(std::move(output_surface_), task_runner_.get()); |
40 BeginFrameSource* frame_source; | |
41 if (disable_display_vsync_) { | |
42 unthrottled_frame_source_ = | |
43 BackToBackBeginFrameSource::Create(task_runner_.get()); | |
44 frame_source = unthrottled_frame_source_.get(); | |
45 } else { | |
46 synthetic_frame_source_ = SyntheticBeginFrameSource::Create( | |
47 task_runner_.get(), BeginFrameArgs::DefaultInterval()); | |
48 frame_source = synthetic_frame_source_.get(); | |
49 } | |
50 | |
51 scheduler_.reset( | |
52 new DisplayScheduler(display_.get(), frame_source, task_runner_.get(), | |
53 output_surface_->capabilities().max_frames_pending)); | |
54 | |
55 return display_->Initialize(std::move(output_surface_), scheduler_.get()); | |
56 } | |
57 | |
58 void OnscreenDisplayClient::CommitVSyncParameters(base::TimeTicks timebase, | |
59 base::TimeDelta interval) { | |
60 if (interval == base::TimeDelta()) { | |
61 // TODO(brianderson): We should not be receiving 0 intervals. | |
62 interval = BeginFrameArgs::DefaultInterval(); | |
63 } | |
64 | |
65 surface_display_output_surface_->ReceivedVSyncParameters(timebase, interval); | |
66 if (synthetic_frame_source_.get()) | |
67 synthetic_frame_source_->OnUpdateVSyncParameters(timebase, interval); | |
68 } | 39 } |
69 | 40 |
70 void OnscreenDisplayClient::OutputSurfaceLost() { | 41 void OnscreenDisplayClient::OutputSurfaceLost() { |
71 output_surface_lost_ = true; | 42 output_surface_lost_ = true; |
72 surface_display_output_surface_->DidLoseOutputSurface(); | 43 surface_display_output_surface_->DidLoseOutputSurface(); |
73 } | 44 } |
74 | 45 |
75 void OnscreenDisplayClient::SetMemoryPolicy(const ManagedMemoryPolicy& policy) { | 46 void OnscreenDisplayClient::SetMemoryPolicy(const ManagedMemoryPolicy& policy) { |
76 surface_display_output_surface_->SetMemoryPolicy(policy); | 47 surface_display_output_surface_->SetMemoryPolicy(policy); |
77 } | 48 } |
78 | 49 |
79 } // namespace cc | 50 } // namespace cc |
OLD | NEW |