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

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

Issue 1163143002: Scheduler/child/TimeSource could be replaced with base/time/DefaultTickClock. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 6 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/trace_event/trace_event.h" 7 #include "base/trace_event/trace_event.h"
8 #include "base/trace_event/trace_event_argument.h" 8 #include "base/trace_event/trace_event_argument.h"
9 #include "components/scheduler/child/nestable_single_thread_task_runner.h" 9 #include "components/scheduler/child/nestable_single_thread_task_runner.h"
10 #include "components/scheduler/child/time_source.h"
11 10
12 namespace scheduler { 11 namespace scheduler {
13 12
14 SchedulerHelper::SchedulerHelper( 13 SchedulerHelper::SchedulerHelper(
15 scoped_refptr<NestableSingleThreadTaskRunner> main_task_runner, 14 scoped_refptr<NestableSingleThreadTaskRunner> main_task_runner,
16 const char* tracing_category, 15 const char* tracing_category,
17 const char* disabled_by_default_tracing_category, 16 const char* disabled_by_default_tracing_category,
18 size_t total_task_queue_count) 17 size_t total_task_queue_count)
19 : task_queue_selector_(new PrioritizingTaskQueueSelector()), 18 : task_queue_selector_(new PrioritizingTaskQueueSelector()),
20 task_queue_manager_( 19 task_queue_manager_(
21 new TaskQueueManager(total_task_queue_count, 20 new TaskQueueManager(total_task_queue_count,
22 main_task_runner, 21 main_task_runner,
23 task_queue_selector_.get(), 22 task_queue_selector_.get(),
24 disabled_by_default_tracing_category)), 23 disabled_by_default_tracing_category)),
25 quiescence_monitored_task_queue_mask_( 24 quiescence_monitored_task_queue_mask_(
26 ((1ull << total_task_queue_count) - 1ull) & 25 ((1ull << total_task_queue_count) - 1ull) &
27 ~(1ull << QueueId::CONTROL_TASK_QUEUE) & 26 ~(1ull << QueueId::CONTROL_TASK_QUEUE) &
28 ~(1ull << QueueId::CONTROL_TASK_AFTER_WAKEUP_QUEUE)), 27 ~(1ull << QueueId::CONTROL_TASK_AFTER_WAKEUP_QUEUE)),
29 control_task_runner_( 28 control_task_runner_(
30 task_queue_manager_->TaskRunnerForQueue(QueueId::CONTROL_TASK_QUEUE)), 29 task_queue_manager_->TaskRunnerForQueue(QueueId::CONTROL_TASK_QUEUE)),
31 control_after_wakeup_task_runner_(task_queue_manager_->TaskRunnerForQueue( 30 control_after_wakeup_task_runner_(task_queue_manager_->TaskRunnerForQueue(
32 QueueId::CONTROL_TASK_AFTER_WAKEUP_QUEUE)), 31 QueueId::CONTROL_TASK_AFTER_WAKEUP_QUEUE)),
33 default_task_runner_( 32 default_task_runner_(
34 task_queue_manager_->TaskRunnerForQueue(QueueId::DEFAULT_TASK_QUEUE)), 33 task_queue_manager_->TaskRunnerForQueue(QueueId::DEFAULT_TASK_QUEUE)),
35 time_source_(new TimeSource), 34 time_source_(new base::DefaultTickClock),
36 tracing_category_(tracing_category), 35 tracing_category_(tracing_category),
37 disabled_by_default_tracing_category_( 36 disabled_by_default_tracing_category_(
38 disabled_by_default_tracing_category) { 37 disabled_by_default_tracing_category) {
39 DCHECK_GE(total_task_queue_count, 38 DCHECK_GE(total_task_queue_count,
40 static_cast<size_t>(QueueId::TASK_QUEUE_COUNT)); 39 static_cast<size_t>(QueueId::TASK_QUEUE_COUNT));
41 task_queue_selector_->SetQueuePriority( 40 task_queue_selector_->SetQueuePriority(
42 QueueId::CONTROL_TASK_QUEUE, 41 QueueId::CONTROL_TASK_QUEUE,
43 PrioritizingTaskQueueSelector::CONTROL_PRIORITY); 42 PrioritizingTaskQueueSelector::CONTROL_PRIORITY);
44 task_queue_manager_->SetWakeupPolicy( 43 task_queue_manager_->SetWakeupPolicy(
45 QueueId::CONTROL_TASK_QUEUE, 44 QueueId::CONTROL_TASK_QUEUE,
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after
82 SchedulerHelper::ControlTaskRunner() { 81 SchedulerHelper::ControlTaskRunner() {
83 return control_task_runner_; 82 return control_task_runner_;
84 } 83 }
85 84
86 scoped_refptr<base::SingleThreadTaskRunner> 85 scoped_refptr<base::SingleThreadTaskRunner>
87 SchedulerHelper::ControlAfterWakeUpTaskRunner() { 86 SchedulerHelper::ControlAfterWakeUpTaskRunner() {
88 return control_after_wakeup_task_runner_; 87 return control_after_wakeup_task_runner_;
89 } 88 }
90 89
91 void SchedulerHelper::SetTimeSourceForTesting( 90 void SchedulerHelper::SetTimeSourceForTesting(
92 scoped_ptr<TimeSource> time_source) { 91 scoped_ptr<base::DefaultTickClock> time_source) {
93 CheckOnValidThread(); 92 CheckOnValidThread();
94 time_source_ = time_source.Pass(); 93 time_source_ = time_source.Pass();
95 } 94 }
96 95
97 void SchedulerHelper::SetWorkBatchSizeForTesting(size_t work_batch_size) { 96 void SchedulerHelper::SetWorkBatchSizeForTesting(size_t work_batch_size) {
98 CheckOnValidThread(); 97 CheckOnValidThread();
99 task_queue_manager_->SetWorkBatchSize(work_batch_size); 98 task_queue_manager_->SetWorkBatchSize(work_batch_size);
100 } 99 }
101 100
102 TaskQueueManager* SchedulerHelper::GetTaskQueueManagerForTesting() { 101 TaskQueueManager* SchedulerHelper::GetTaskQueueManagerForTesting() {
103 CheckOnValidThread(); 102 CheckOnValidThread();
104 return task_queue_manager_.get(); 103 return task_queue_manager_.get();
105 } 104 }
106 105
107 base::TimeTicks SchedulerHelper::Now() const { 106 base::TimeTicks SchedulerHelper::Now() const {
108 return time_source_->Now(); 107 return time_source_->NowTicks();
109 } 108 }
110 109
111 scoped_refptr<base::SingleThreadTaskRunner> SchedulerHelper::TaskRunnerForQueue( 110 scoped_refptr<base::SingleThreadTaskRunner> SchedulerHelper::TaskRunnerForQueue(
112 size_t queue_index) const { 111 size_t queue_index) const {
113 CheckOnValidThread(); 112 CheckOnValidThread();
114 return task_queue_manager_->TaskRunnerForQueue(queue_index); 113 return task_queue_manager_->TaskRunnerForQueue(queue_index);
115 } 114 }
116 115
117 base::TimeTicks SchedulerHelper::NextPendingDelayedTaskRunTime() const { 116 base::TimeTicks SchedulerHelper::NextPendingDelayedTaskRunTime() const {
118 CheckOnValidThread(); 117 CheckOnValidThread();
(...skipping 91 matching lines...) Expand 10 before | Expand all | Expand 10 after
210 } 209 }
211 210
212 void SchedulerHelper::RemoveTaskObserver( 211 void SchedulerHelper::RemoveTaskObserver(
213 base::MessageLoop::TaskObserver* task_observer) { 212 base::MessageLoop::TaskObserver* task_observer) {
214 CheckOnValidThread(); 213 CheckOnValidThread();
215 if (task_queue_manager_) 214 if (task_queue_manager_)
216 task_queue_manager_->RemoveTaskObserver(task_observer); 215 task_queue_manager_->RemoveTaskObserver(task_observer);
217 } 216 }
218 217
219 } // namespace scheduler 218 } // namespace scheduler
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698