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

Side by Side Diff: components/scheduler/renderer/task_cost_estimator.h

Issue 1424053002: Adds a flag to support "Virtual Time" to the blink scheduler (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Rebased Created 5 years, 1 month 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
OLDNEW
1 // Copyright 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 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 COMPONENTS_SCHEDULER_RENDERER_TASK_COST_ESTIMATOR_H_ 5 #ifndef COMPONENTS_SCHEDULER_RENDERER_TASK_COST_ESTIMATOR_H_
6 #define COMPONENTS_SCHEDULER_RENDERER_TASK_COST_ESTIMATOR_H_ 6 #define COMPONENTS_SCHEDULER_RENDERER_TASK_COST_ESTIMATOR_H_
7 7
8 #include "base/message_loop/message_loop.h" 8 #include "base/message_loop/message_loop.h"
9 #include "base/time/time.h" 9 #include "base/time/time.h"
10 #include "cc/base/rolling_time_delta_history.h" 10 #include "cc/base/rolling_time_delta_history.h"
11 #include "components/scheduler/scheduler_export.h" 11 #include "components/scheduler/scheduler_export.h"
12 12
13 namespace base { 13 namespace base {
14 class TickClock; 14 class TickClock;
15 } 15 }
16 16
17 namespace scheduler { 17 namespace scheduler {
18 18
19 // Estimates the cost of running tasks based on historical timing data. 19 // Estimates the cost of running tasks based on historical timing data.
20 class SCHEDULER_EXPORT TaskCostEstimator 20 class SCHEDULER_EXPORT TaskCostEstimator
21 : public base::MessageLoop::TaskObserver { 21 : public base::MessageLoop::TaskObserver {
22 public: 22 public:
23 TaskCostEstimator(int sample_count, double estimation_percentile); 23 TaskCostEstimator(base::TickClock* time_source,
24 int sample_count,
25 double estimation_percentile);
24 ~TaskCostEstimator() override; 26 ~TaskCostEstimator() override;
25 27
26 base::TimeDelta expected_task_duration() const; 28 base::TimeDelta expected_task_duration() const;
27 29
28 // TaskObserver implementation: 30 // TaskObserver implementation:
29 void WillProcessTask(const base::PendingTask& pending_task) override; 31 void WillProcessTask(const base::PendingTask& pending_task) override;
30 void DidProcessTask(const base::PendingTask& pending_task) override; 32 void DidProcessTask(const base::PendingTask& pending_task) override;
31 33
32 void Clear(); 34 void Clear();
33 35
34 void SetTimeSourceForTesting(scoped_ptr<base::TickClock> time_source);
35
36 private: 36 private:
37 cc::RollingTimeDeltaHistory rolling_time_delta_history_; 37 cc::RollingTimeDeltaHistory rolling_time_delta_history_;
38 scoped_ptr<base::TickClock> time_source_; 38 base::TickClock* time_source_; // NOT OWNED
39 int outstanding_task_count_; 39 int outstanding_task_count_;
40 double estimation_percentile_; 40 double estimation_percentile_;
41 base::TimeTicks task_start_time_; 41 base::TimeTicks task_start_time_;
42 base::TimeDelta expected_task_duration_; 42 base::TimeDelta expected_task_duration_;
43 43
44 DISALLOW_COPY_AND_ASSIGN(TaskCostEstimator); 44 DISALLOW_COPY_AND_ASSIGN(TaskCostEstimator);
45 }; 45 };
46 46
47 } // namespace scheduler 47 } // namespace scheduler
48 48
49 #endif // COMPONENTS_SCHEDULER_RENDERER_TASK_COST_ESTIMATOR_H_ 49 #endif // COMPONENTS_SCHEDULER_RENDERER_TASK_COST_ESTIMATOR_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698