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_time_tracker_(new TaskTimeTracker()), |
21 task_queue_manager_( | 22 task_queue_manager_( |
22 new TaskQueueManager(task_queue_manager_delegate, | 23 new TaskQueueManager(task_queue_manager_delegate, |
23 tracing_category, | 24 tracing_category, |
24 disabled_by_default_tracing_category, | 25 disabled_by_default_tracing_category, |
25 disabled_by_default_verbose_tracing_category)), | 26 disabled_by_default_verbose_tracing_category, |
| 27 task_time_tracker_.get())), |
26 control_task_runner_(NewTaskQueue( | 28 control_task_runner_(NewTaskQueue( |
27 TaskQueue::Spec("control_tq") | 29 TaskQueue::Spec("control_tq") |
28 .SetWakeupPolicy(TaskQueue::WakeupPolicy::DONT_WAKE_OTHER_QUEUES) | 30 .SetWakeupPolicy(TaskQueue::WakeupPolicy::DONT_WAKE_OTHER_QUEUES) |
29 .SetShouldNotifyObservers(false))), | 31 .SetShouldNotifyObservers(false))), |
30 control_after_wakeup_task_runner_(NewTaskQueue( | 32 control_after_wakeup_task_runner_(NewTaskQueue( |
31 TaskQueue::Spec("control_after_wakeup_tq") | 33 TaskQueue::Spec("control_after_wakeup_tq") |
32 .SetPumpPolicy(TaskQueue::PumpPolicy::AFTER_WAKEUP) | 34 .SetPumpPolicy(TaskQueue::PumpPolicy::AFTER_WAKEUP) |
33 .SetWakeupPolicy(TaskQueue::WakeupPolicy::DONT_WAKE_OTHER_QUEUES) | 35 .SetWakeupPolicy(TaskQueue::WakeupPolicy::DONT_WAKE_OTHER_QUEUES) |
34 .SetShouldNotifyObservers(false))), | 36 .SetShouldNotifyObservers(false))), |
35 default_task_runner_(NewTaskQueue(TaskQueue::Spec("default_tq") | 37 default_task_runner_(NewTaskQueue(TaskQueue::Spec("default_tq") |
(...skipping 78 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
114 base::MessageLoop::TaskObserver* task_observer) { | 116 base::MessageLoop::TaskObserver* task_observer) { |
115 CheckOnValidThread(); | 117 CheckOnValidThread(); |
116 if (task_queue_manager_) | 118 if (task_queue_manager_) |
117 task_queue_manager_->RemoveTaskObserver(task_observer); | 119 task_queue_manager_->RemoveTaskObserver(task_observer); |
118 } | 120 } |
119 | 121 |
120 void SchedulerHelper::SetObserver(Observer* observer) { | 122 void SchedulerHelper::SetObserver(Observer* observer) { |
121 CheckOnValidThread(); | 123 CheckOnValidThread(); |
122 observer_ = observer; | 124 observer_ = observer; |
123 DCHECK(task_queue_manager_); | 125 DCHECK(task_queue_manager_); |
| 126 DCHECK(task_time_tracker_); |
124 task_queue_manager_->SetObserver(this); | 127 task_queue_manager_->SetObserver(this); |
| 128 task_time_tracker_->SetObserver(this); |
125 } | 129 } |
126 | 130 |
127 RealTimeDomain* SchedulerHelper::real_time_domain() const { | 131 RealTimeDomain* SchedulerHelper::real_time_domain() const { |
128 CheckOnValidThread(); | 132 CheckOnValidThread(); |
129 DCHECK(task_queue_manager_); | 133 DCHECK(task_queue_manager_); |
130 return task_queue_manager_->real_time_domain(); | 134 return task_queue_manager_->real_time_domain(); |
131 } | 135 } |
132 | 136 |
133 void SchedulerHelper::RegisterTimeDomain(TimeDomain* time_domain) { | 137 void SchedulerHelper::RegisterTimeDomain(TimeDomain* time_domain) { |
134 CheckOnValidThread(); | 138 CheckOnValidThread(); |
(...skipping 19 matching lines...) Expand all Loading... |
154 if (observer_) | 158 if (observer_) |
155 observer_->OnTriedToExecuteBlockedTask(queue, task); | 159 observer_->OnTriedToExecuteBlockedTask(queue, task); |
156 } | 160 } |
157 | 161 |
158 TaskQueue* SchedulerHelper::CurrentlyExecutingTaskQueue() const { | 162 TaskQueue* SchedulerHelper::CurrentlyExecutingTaskQueue() const { |
159 if (!task_queue_manager_) | 163 if (!task_queue_manager_) |
160 return nullptr; | 164 return nullptr; |
161 return task_queue_manager_->currently_executing_task_queue(); | 165 return task_queue_manager_->currently_executing_task_queue(); |
162 } | 166 } |
163 | 167 |
| 168 // TaskTimeTracker::TaskTimeObserver implementation: |
| 169 void SchedulerHelper::OnLongTask(base::TimeDelta long_task_time) { |
| 170 // Record long task |
| 171 // will be queried from RendererSchedulerImpl in BeginMainFrame |
| 172 } |
| 173 |
164 } // namespace scheduler | 174 } // namespace scheduler |
OLD | NEW |