OLD | NEW |
1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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 "base/task_scheduler/scheduler_thread_pool_impl.h" | 5 #include "base/task_scheduler/scheduler_thread_pool_impl.h" |
6 | 6 |
7 #include <utility> | 7 #include <utility> |
8 | 8 |
9 #include "base/bind.h" | 9 #include "base/bind.h" |
10 #include "base/bind_helpers.h" | 10 #include "base/bind_helpers.h" |
(...skipping 59 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
70 // so long as |thread_pool| is alive. | 70 // so long as |thread_pool| is alive. |
71 // TODO(robliao): Find a concrete way to manage |thread_pool|'s memory. | 71 // TODO(robliao): Find a concrete way to manage |thread_pool|'s memory. |
72 SchedulerSequencedTaskRunner(const TaskTraits& traits, | 72 SchedulerSequencedTaskRunner(const TaskTraits& traits, |
73 SchedulerThreadPool* thread_pool) | 73 SchedulerThreadPool* thread_pool) |
74 : traits_(traits), thread_pool_(thread_pool) {} | 74 : traits_(traits), thread_pool_(thread_pool) {} |
75 | 75 |
76 // SequencedTaskRunner: | 76 // SequencedTaskRunner: |
77 bool PostDelayedTask(const tracked_objects::Location& from_here, | 77 bool PostDelayedTask(const tracked_objects::Location& from_here, |
78 const Closure& closure, | 78 const Closure& closure, |
79 TimeDelta delay) override { | 79 TimeDelta delay) override { |
| 80 std::unique_ptr<Task> task(new Task(from_here, closure, traits_, delay)); |
| 81 task->sequenced_task_runner_ref = this; |
| 82 |
80 // Post the task as part of |sequence_|. | 83 // Post the task as part of |sequence_|. |
81 return thread_pool_->PostTaskWithSequence( | 84 return thread_pool_->PostTaskWithSequence(std::move(task), sequence_, |
82 WrapUnique(new Task(from_here, closure, traits_, delay)), sequence_, | 85 nullptr); |
83 nullptr); | |
84 } | 86 } |
85 | 87 |
86 bool PostNonNestableDelayedTask(const tracked_objects::Location& from_here, | 88 bool PostNonNestableDelayedTask(const tracked_objects::Location& from_here, |
87 const Closure& closure, | 89 const Closure& closure, |
88 base::TimeDelta delay) override { | 90 base::TimeDelta delay) override { |
89 // Tasks are never nested within the task scheduler. | 91 // Tasks are never nested within the task scheduler. |
90 return PostDelayedTask(from_here, closure, delay); | 92 return PostDelayedTask(from_here, closure, delay); |
91 } | 93 } |
92 | 94 |
93 bool RunsTasksOnCurrentThread() const override { | 95 bool RunsTasksOnCurrentThread() const override { |
(...skipping 23 matching lines...) Expand all Loading... |
117 SchedulerThreadPool* thread_pool, | 119 SchedulerThreadPool* thread_pool, |
118 SchedulerWorkerThread* worker_thread) | 120 SchedulerWorkerThread* worker_thread) |
119 : traits_(traits), | 121 : traits_(traits), |
120 thread_pool_(thread_pool), | 122 thread_pool_(thread_pool), |
121 worker_thread_(worker_thread) {} | 123 worker_thread_(worker_thread) {} |
122 | 124 |
123 // SingleThreadTaskRunner: | 125 // SingleThreadTaskRunner: |
124 bool PostDelayedTask(const tracked_objects::Location& from_here, | 126 bool PostDelayedTask(const tracked_objects::Location& from_here, |
125 const Closure& closure, | 127 const Closure& closure, |
126 TimeDelta delay) override { | 128 TimeDelta delay) override { |
| 129 std::unique_ptr<Task> task(new Task(from_here, closure, traits_, delay)); |
| 130 task->single_thread_task_runner_ref = this; |
| 131 |
127 // Post the task to be executed by |worker_thread_| as part of |sequence_|. | 132 // Post the task to be executed by |worker_thread_| as part of |sequence_|. |
128 return thread_pool_->PostTaskWithSequence( | 133 return thread_pool_->PostTaskWithSequence(std::move(task), sequence_, |
129 WrapUnique(new Task(from_here, closure, traits_, delay)), sequence_, | 134 worker_thread_); |
130 worker_thread_); | |
131 } | 135 } |
132 | 136 |
133 bool PostNonNestableDelayedTask(const tracked_objects::Location& from_here, | 137 bool PostNonNestableDelayedTask(const tracked_objects::Location& from_here, |
134 const Closure& closure, | 138 const Closure& closure, |
135 base::TimeDelta delay) override { | 139 base::TimeDelta delay) override { |
136 // Tasks are never nested within the task scheduler. | 140 // Tasks are never nested within the task scheduler. |
137 return PostDelayedTask(from_here, closure, delay); | 141 return PostDelayedTask(from_here, closure, delay); |
138 } | 142 } |
139 | 143 |
140 bool RunsTasksOnCurrentThread() const override { | 144 bool RunsTasksOnCurrentThread() const override { |
(...skipping 370 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
511 } | 515 } |
512 | 516 |
513 void SchedulerThreadPoolImpl::RemoveFromIdleWorkerThreadsStack( | 517 void SchedulerThreadPoolImpl::RemoveFromIdleWorkerThreadsStack( |
514 SchedulerWorkerThread* worker_thread) { | 518 SchedulerWorkerThread* worker_thread) { |
515 AutoSchedulerLock auto_lock(idle_worker_threads_stack_lock_); | 519 AutoSchedulerLock auto_lock(idle_worker_threads_stack_lock_); |
516 idle_worker_threads_stack_.Remove(worker_thread); | 520 idle_worker_threads_stack_.Remove(worker_thread); |
517 } | 521 } |
518 | 522 |
519 } // namespace internal | 523 } // namespace internal |
520 } // namespace base | 524 } // namespace base |
OLD | NEW |