Index: cc/scheduler/scheduler.h |
diff --git a/cc/scheduler/scheduler.h b/cc/scheduler/scheduler.h |
index 97b17b7283aaf4e357be4fd8e5726298f80c63cf..4273e4b1f39249d86e835f5dd29dcc20d580d4bc 100644 |
--- a/cc/scheduler/scheduler.h |
+++ b/cc/scheduler/scheduler.h |
@@ -46,6 +46,7 @@ class SchedulerClient { |
virtual base::TimeDelta BeginMainFrameToCommitDurationEstimate() = 0; |
virtual base::TimeDelta CommitToActivateDurationEstimate() = 0; |
virtual void DidBeginImplFrameDeadline() = 0; |
+ virtual void SendBeginFrameToChildren(const BeginFrameArgs& args) = 0; |
protected: |
virtual ~SchedulerClient() {} |
@@ -133,6 +134,11 @@ class CC_EXPORT Scheduler { |
state_machine_.SetContinuousPainting(continuous_painting); |
} |
+ // SetChildrenNeedBeginFrames() is only used when this Scheduler is acting |
+ // as the publisher. |
+ void SetChildrenNeedBeginFrames(bool need_begin_frame); |
+ void SetAuthoritativeVSyncInterval(base::TimeDelta interval); |
+ |
protected: |
class CC_EXPORT SyntheticBeginFrameSource : public TimeSourceClient { |
public: |
@@ -174,6 +180,9 @@ class CC_EXPORT Scheduler { |
scoped_refptr<base::SingleThreadTaskRunner> task_runner_; |
base::TimeDelta vsync_interval_; |
+ base::TimeDelta authoritative_vsync_interval_; |
+ base::TimeTicks last_timebase_; |
+ |
base::TimeDelta estimated_parent_draw_time_; |
bool last_set_needs_begin_frame_; |