OLD | NEW |
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 #include "components/scheduler/child/scheduler_helper.h" | 5 #include "components/scheduler/child/scheduler_helper.h" |
6 | 6 |
7 #include "base/time/default_tick_clock.h" | 7 #include "base/time/default_tick_clock.h" |
8 #include "base/trace_event/trace_event.h" | 8 #include "base/trace_event/trace_event.h" |
9 #include "base/trace_event/trace_event_argument.h" | 9 #include "base/trace_event/trace_event_argument.h" |
10 #include "components/scheduler/base/task_queue_impl.h" | 10 #include "components/scheduler/base/task_queue_impl.h" |
11 #include "components/scheduler/child/scheduler_tqm_delegate.h" | 11 #include "components/scheduler/child/scheduler_tqm_delegate.h" |
12 | 12 |
13 namespace scheduler { | 13 namespace scheduler { |
14 | 14 |
15 SchedulerHelper::SchedulerHelper( | 15 SchedulerHelper::SchedulerHelper( |
16 scoped_refptr<SchedulerTqmDelegate> task_queue_manager_delegate, | 16 scoped_refptr<SchedulerTqmDelegate> task_queue_manager_delegate, |
17 const char* tracing_category, | 17 const char* tracing_category, |
18 const char* disabled_by_default_tracing_category, | 18 const char* disabled_by_default_tracing_category, |
19 const char* disabled_by_default_verbose_tracing_category) | 19 const char* disabled_by_default_verbose_tracing_category) |
20 : task_queue_manager_delegate_(task_queue_manager_delegate), | 20 : task_queue_manager_delegate_(task_queue_manager_delegate), |
21 task_queue_manager_( | 21 task_queue_manager_( |
22 new TaskQueueManager(task_queue_manager_delegate, | 22 new TaskQueueManager(task_queue_manager_delegate, |
23 tracing_category, | 23 tracing_category, |
24 disabled_by_default_tracing_category, | 24 disabled_by_default_tracing_category, |
25 disabled_by_default_verbose_tracing_category)), | 25 disabled_by_default_verbose_tracing_category, |
| 26 &task_time_tracker_)), |
26 control_task_runner_(NewTaskQueue( | 27 control_task_runner_(NewTaskQueue( |
27 TaskQueue::Spec("control_tq") | 28 TaskQueue::Spec("control_tq") |
28 .SetWakeupPolicy(TaskQueue::WakeupPolicy::DONT_WAKE_OTHER_QUEUES) | 29 .SetWakeupPolicy(TaskQueue::WakeupPolicy::DONT_WAKE_OTHER_QUEUES) |
29 .SetShouldNotifyObservers(false))), | 30 .SetShouldNotifyObservers(false))), |
30 control_after_wakeup_task_runner_(NewTaskQueue( | 31 control_after_wakeup_task_runner_(NewTaskQueue( |
31 TaskQueue::Spec("control_after_wakeup_tq") | 32 TaskQueue::Spec("control_after_wakeup_tq") |
32 .SetPumpPolicy(TaskQueue::PumpPolicy::AFTER_WAKEUP) | 33 .SetPumpPolicy(TaskQueue::PumpPolicy::AFTER_WAKEUP) |
33 .SetWakeupPolicy(TaskQueue::WakeupPolicy::DONT_WAKE_OTHER_QUEUES) | 34 .SetWakeupPolicy(TaskQueue::WakeupPolicy::DONT_WAKE_OTHER_QUEUES) |
34 .SetShouldNotifyObservers(false))), | 35 .SetShouldNotifyObservers(false))), |
35 default_task_runner_(NewTaskQueue(TaskQueue::Spec("default_tq") | 36 default_task_runner_(NewTaskQueue( |
36 .SetShouldMonitorQuiescence(true))), | 37 TaskQueue::Spec("default_tq").SetShouldMonitorQuiescence(true))), |
37 observer_(nullptr), | 38 observer_(nullptr), |
38 tracing_category_(tracing_category), | 39 tracing_category_(tracing_category), |
39 disabled_by_default_tracing_category_( | 40 disabled_by_default_tracing_category_( |
40 disabled_by_default_tracing_category) { | 41 disabled_by_default_tracing_category) { |
41 control_task_runner_->SetQueuePriority(TaskQueue::CONTROL_PRIORITY); | 42 control_task_runner_->SetQueuePriority(TaskQueue::CONTROL_PRIORITY); |
42 control_after_wakeup_task_runner_->SetQueuePriority( | 43 control_after_wakeup_task_runner_->SetQueuePriority( |
43 TaskQueue::CONTROL_PRIORITY); | 44 TaskQueue::CONTROL_PRIORITY); |
44 | 45 |
45 task_queue_manager_->SetWorkBatchSize(4); | 46 task_queue_manager_->SetWorkBatchSize(4); |
46 | 47 |
(...skipping 68 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
115 CheckOnValidThread(); | 116 CheckOnValidThread(); |
116 if (task_queue_manager_) | 117 if (task_queue_manager_) |
117 task_queue_manager_->RemoveTaskObserver(task_observer); | 118 task_queue_manager_->RemoveTaskObserver(task_observer); |
118 } | 119 } |
119 | 120 |
120 void SchedulerHelper::SetObserver(Observer* observer) { | 121 void SchedulerHelper::SetObserver(Observer* observer) { |
121 CheckOnValidThread(); | 122 CheckOnValidThread(); |
122 observer_ = observer; | 123 observer_ = observer; |
123 DCHECK(task_queue_manager_); | 124 DCHECK(task_queue_manager_); |
124 task_queue_manager_->SetObserver(this); | 125 task_queue_manager_->SetObserver(this); |
| 126 task_time_tracker_.SetObserver(this); |
125 } | 127 } |
126 | 128 |
127 RealTimeDomain* SchedulerHelper::real_time_domain() const { | 129 RealTimeDomain* SchedulerHelper::real_time_domain() const { |
128 CheckOnValidThread(); | 130 CheckOnValidThread(); |
129 DCHECK(task_queue_manager_); | 131 DCHECK(task_queue_manager_); |
130 return task_queue_manager_->real_time_domain(); | 132 return task_queue_manager_->real_time_domain(); |
131 } | 133 } |
132 | 134 |
133 void SchedulerHelper::RegisterTimeDomain(TimeDomain* time_domain) { | 135 void SchedulerHelper::RegisterTimeDomain(TimeDomain* time_domain) { |
134 CheckOnValidThread(); | 136 CheckOnValidThread(); |
(...skipping 19 matching lines...) Expand all Loading... |
154 if (observer_) | 156 if (observer_) |
155 observer_->OnTriedToExecuteBlockedTask(queue, task); | 157 observer_->OnTriedToExecuteBlockedTask(queue, task); |
156 } | 158 } |
157 | 159 |
158 TaskQueue* SchedulerHelper::CurrentlyExecutingTaskQueue() const { | 160 TaskQueue* SchedulerHelper::CurrentlyExecutingTaskQueue() const { |
159 if (!task_queue_manager_) | 161 if (!task_queue_manager_) |
160 return nullptr; | 162 return nullptr; |
161 return task_queue_manager_->currently_executing_task_queue(); | 163 return task_queue_manager_->currently_executing_task_queue(); |
162 } | 164 } |
163 | 165 |
| 166 // TaskTimeTracker::TaskTimeObserver implementation: |
| 167 void SchedulerHelper::OnQueueingTimeForWindowEstimated( |
| 168 base::TimeDelta queueing_time) {} |
| 169 |
164 } // namespace scheduler | 170 } // namespace scheduler |
OLD | NEW |