| OLD | NEW |
| 1 // Copyright 2011 The Chromium Authors. All rights reserved. | 1 // Copyright 2011 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 #ifndef CC_SCHEDULER_SCHEDULER_H_ | 5 #ifndef CC_SCHEDULER_SCHEDULER_H_ |
| 6 #define CC_SCHEDULER_SCHEDULER_H_ | 6 #define CC_SCHEDULER_SCHEDULER_H_ |
| 7 | 7 |
| 8 #include <deque> | 8 #include <deque> |
| 9 #include <memory> |
| 9 #include <string> | 10 #include <string> |
| 10 | 11 |
| 11 #include "base/cancelable_callback.h" | 12 #include "base/cancelable_callback.h" |
| 12 #include "base/macros.h" | 13 #include "base/macros.h" |
| 13 #include "base/memory/scoped_ptr.h" | |
| 14 #include "base/time/time.h" | 14 #include "base/time/time.h" |
| 15 #include "cc/base/cc_export.h" | 15 #include "cc/base/cc_export.h" |
| 16 #include "cc/output/begin_frame_args.h" | 16 #include "cc/output/begin_frame_args.h" |
| 17 #include "cc/scheduler/begin_frame_source.h" | 17 #include "cc/scheduler/begin_frame_source.h" |
| 18 #include "cc/scheduler/begin_frame_tracker.h" | 18 #include "cc/scheduler/begin_frame_tracker.h" |
| 19 #include "cc/scheduler/delay_based_time_source.h" | 19 #include "cc/scheduler/delay_based_time_source.h" |
| 20 #include "cc/scheduler/draw_result.h" | 20 #include "cc/scheduler/draw_result.h" |
| 21 #include "cc/scheduler/scheduler_settings.h" | 21 #include "cc/scheduler/scheduler_settings.h" |
| 22 #include "cc/scheduler/scheduler_state_machine.h" | 22 #include "cc/scheduler/scheduler_state_machine.h" |
| 23 #include "cc/tiles/tile_priority.h" | 23 #include "cc/tiles/tile_priority.h" |
| (...skipping 24 matching lines...) Expand all Loading... |
| 48 virtual void DidFinishImplFrame() = 0; | 48 virtual void DidFinishImplFrame() = 0; |
| 49 virtual void SendBeginFramesToChildren(const BeginFrameArgs& args) = 0; | 49 virtual void SendBeginFramesToChildren(const BeginFrameArgs& args) = 0; |
| 50 virtual void SendBeginMainFrameNotExpectedSoon() = 0; | 50 virtual void SendBeginMainFrameNotExpectedSoon() = 0; |
| 51 | 51 |
| 52 protected: | 52 protected: |
| 53 virtual ~SchedulerClient() {} | 53 virtual ~SchedulerClient() {} |
| 54 }; | 54 }; |
| 55 | 55 |
| 56 class CC_EXPORT Scheduler : public BeginFrameObserverBase { | 56 class CC_EXPORT Scheduler : public BeginFrameObserverBase { |
| 57 public: | 57 public: |
| 58 static scoped_ptr<Scheduler> Create( | 58 static std::unique_ptr<Scheduler> Create( |
| 59 SchedulerClient* client, | 59 SchedulerClient* client, |
| 60 const SchedulerSettings& scheduler_settings, | 60 const SchedulerSettings& scheduler_settings, |
| 61 int layer_tree_host_id, | 61 int layer_tree_host_id, |
| 62 base::SingleThreadTaskRunner* task_runner, | 62 base::SingleThreadTaskRunner* task_runner, |
| 63 BeginFrameSource* begin_frame_source, | 63 BeginFrameSource* begin_frame_source, |
| 64 scoped_ptr<CompositorTimingHistory> compositor_timing_history); | 64 std::unique_ptr<CompositorTimingHistory> compositor_timing_history); |
| 65 | 65 |
| 66 ~Scheduler() override; | 66 ~Scheduler() override; |
| 67 | 67 |
| 68 // BeginFrameObserverBase | 68 // BeginFrameObserverBase |
| 69 void OnBeginFrameSourcePausedChanged(bool paused) override; | 69 void OnBeginFrameSourcePausedChanged(bool paused) override; |
| 70 bool OnBeginFrameDerivedImpl(const BeginFrameArgs& args) override; | 70 bool OnBeginFrameDerivedImpl(const BeginFrameArgs& args) override; |
| 71 | 71 |
| 72 void OnDrawForOutputSurface(bool resourceless_software_draw); | 72 void OnDrawForOutputSurface(bool resourceless_software_draw); |
| 73 | 73 |
| 74 const SchedulerSettings& settings() const { return settings_; } | 74 const SchedulerSettings& settings() const { return settings_; } |
| (...skipping 53 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 128 // Pass in a main_thread_start_time of base::TimeTicks() if it is not | 128 // Pass in a main_thread_start_time of base::TimeTicks() if it is not |
| 129 // known or not trustworthy (e.g. blink is running on a remote channel) | 129 // known or not trustworthy (e.g. blink is running on a remote channel) |
| 130 // to signal that the start time isn't known and should not be used for | 130 // to signal that the start time isn't known and should not be used for |
| 131 // scheduling or statistics purposes. | 131 // scheduling or statistics purposes. |
| 132 void NotifyBeginMainFrameStarted(base::TimeTicks main_thread_start_time); | 132 void NotifyBeginMainFrameStarted(base::TimeTicks main_thread_start_time); |
| 133 | 133 |
| 134 base::TimeTicks LastBeginImplFrameTime(); | 134 base::TimeTicks LastBeginImplFrameTime(); |
| 135 | 135 |
| 136 void SetDeferCommits(bool defer_commits); | 136 void SetDeferCommits(bool defer_commits); |
| 137 | 137 |
| 138 scoped_ptr<base::trace_event::ConvertableToTraceFormat> AsValue() const; | 138 std::unique_ptr<base::trace_event::ConvertableToTraceFormat> AsValue() const; |
| 139 void AsValueInto(base::trace_event::TracedValue* value) const override; | 139 void AsValueInto(base::trace_event::TracedValue* value) const override; |
| 140 | 140 |
| 141 void SetChildrenNeedBeginFrames(bool children_need_begin_frames); | 141 void SetChildrenNeedBeginFrames(bool children_need_begin_frames); |
| 142 void SetVideoNeedsBeginFrames(bool video_needs_begin_frames); | 142 void SetVideoNeedsBeginFrames(bool video_needs_begin_frames); |
| 143 | 143 |
| 144 const BeginFrameSource* begin_frame_source() const { | 144 const BeginFrameSource* begin_frame_source() const { |
| 145 return begin_frame_source_; | 145 return begin_frame_source_; |
| 146 } | 146 } |
| 147 | 147 |
| 148 protected: | 148 protected: |
| 149 Scheduler(SchedulerClient* client, | 149 Scheduler(SchedulerClient* client, |
| 150 const SchedulerSettings& scheduler_settings, | 150 const SchedulerSettings& scheduler_settings, |
| 151 int layer_tree_host_id, | 151 int layer_tree_host_id, |
| 152 base::SingleThreadTaskRunner* task_runner, | 152 base::SingleThreadTaskRunner* task_runner, |
| 153 BeginFrameSource* begin_frame_source, | 153 BeginFrameSource* begin_frame_source, |
| 154 scoped_ptr<CompositorTimingHistory> compositor_timing_history); | 154 std::unique_ptr<CompositorTimingHistory> compositor_timing_history); |
| 155 | 155 |
| 156 // Virtual for testing. | 156 // Virtual for testing. |
| 157 virtual base::TimeTicks Now() const; | 157 virtual base::TimeTicks Now() const; |
| 158 | 158 |
| 159 const SchedulerSettings settings_; | 159 const SchedulerSettings settings_; |
| 160 // Not owned. | 160 // Not owned. |
| 161 SchedulerClient* client_; | 161 SchedulerClient* client_; |
| 162 int layer_tree_host_id_; | 162 int layer_tree_host_id_; |
| 163 base::SingleThreadTaskRunner* task_runner_; | 163 base::SingleThreadTaskRunner* task_runner_; |
| 164 | 164 |
| 165 // Not owned. May be null. | 165 // Not owned. May be null. |
| 166 BeginFrameSource* begin_frame_source_; | 166 BeginFrameSource* begin_frame_source_; |
| 167 bool observing_begin_frame_source_; | 167 bool observing_begin_frame_source_; |
| 168 | 168 |
| 169 scoped_ptr<CompositorTimingHistory> compositor_timing_history_; | 169 std::unique_ptr<CompositorTimingHistory> compositor_timing_history_; |
| 170 base::TimeDelta estimated_parent_draw_time_; | 170 base::TimeDelta estimated_parent_draw_time_; |
| 171 | 171 |
| 172 std::deque<BeginFrameArgs> begin_retro_frame_args_; | 172 std::deque<BeginFrameArgs> begin_retro_frame_args_; |
| 173 SchedulerStateMachine::BeginImplFrameDeadlineMode | 173 SchedulerStateMachine::BeginImplFrameDeadlineMode |
| 174 begin_impl_frame_deadline_mode_; | 174 begin_impl_frame_deadline_mode_; |
| 175 BeginFrameTracker begin_impl_frame_tracker_; | 175 BeginFrameTracker begin_impl_frame_tracker_; |
| 176 BeginFrameArgs begin_main_frame_args_; | 176 BeginFrameArgs begin_main_frame_args_; |
| 177 | 177 |
| 178 base::Closure begin_retro_frame_closure_; | 178 base::Closure begin_retro_frame_closure_; |
| 179 base::Closure begin_impl_frame_deadline_closure_; | 179 base::Closure begin_impl_frame_deadline_closure_; |
| (...skipping 40 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 220 } | 220 } |
| 221 | 221 |
| 222 base::WeakPtrFactory<Scheduler> weak_factory_; | 222 base::WeakPtrFactory<Scheduler> weak_factory_; |
| 223 | 223 |
| 224 DISALLOW_COPY_AND_ASSIGN(Scheduler); | 224 DISALLOW_COPY_AND_ASSIGN(Scheduler); |
| 225 }; | 225 }; |
| 226 | 226 |
| 227 } // namespace cc | 227 } // namespace cc |
| 228 | 228 |
| 229 #endif // CC_SCHEDULER_SCHEDULER_H_ | 229 #endif // CC_SCHEDULER_SCHEDULER_H_ |
| OLD | NEW |