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

Side by Side Diff: components/scheduler/child/scheduler_helper.cc

Issue 1898233002: Report expected task queueing time via UMA (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Fix perf test Created 4 years, 5 months 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 #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
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
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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698