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 "content/renderer/categorized_worker_pool.h" | 5 #include "content/renderer/categorized_worker_pool.h" |
6 | 6 |
7 #include <string> | 7 #include <string> |
8 #include <utility> | 8 #include <utility> |
9 #include <vector> | 9 #include <vector> |
10 | 10 |
(...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
46 class CategorizedWorkerPool::CategorizedWorkerPoolSequencedTaskRunner | 46 class CategorizedWorkerPool::CategorizedWorkerPoolSequencedTaskRunner |
47 : public base::SequencedTaskRunner { | 47 : public base::SequencedTaskRunner { |
48 public: | 48 public: |
49 explicit CategorizedWorkerPoolSequencedTaskRunner( | 49 explicit CategorizedWorkerPoolSequencedTaskRunner( |
50 cc::TaskGraphRunner* task_graph_runner) | 50 cc::TaskGraphRunner* task_graph_runner) |
51 : task_graph_runner_(task_graph_runner), | 51 : task_graph_runner_(task_graph_runner), |
52 namespace_token_(task_graph_runner->GenerateNamespaceToken()) {} | 52 namespace_token_(task_graph_runner->GenerateNamespaceToken()) {} |
53 | 53 |
54 // Overridden from base::TaskRunner: | 54 // Overridden from base::TaskRunner: |
55 bool PostDelayedTask(const tracked_objects::Location& from_here, | 55 bool PostDelayedTask(const tracked_objects::Location& from_here, |
56 const base::Closure& task, | 56 base::Closure task, |
57 base::TimeDelta delay) override { | 57 base::TimeDelta delay) override { |
58 return PostNonNestableDelayedTask(from_here, task, delay); | 58 return PostNonNestableDelayedTask(from_here, std::move(task), delay); |
59 } | 59 } |
60 bool RunsTasksOnCurrentThread() const override { return true; } | 60 bool RunsTasksOnCurrentThread() const override { return true; } |
61 | 61 |
62 // Overridden from base::SequencedTaskRunner: | 62 // Overridden from base::SequencedTaskRunner: |
63 bool PostNonNestableDelayedTask(const tracked_objects::Location& from_here, | 63 bool PostNonNestableDelayedTask(const tracked_objects::Location& from_here, |
64 const base::Closure& task, | 64 base::Closure task, |
65 base::TimeDelta delay) override { | 65 base::TimeDelta delay) override { |
66 base::AutoLock lock(lock_); | 66 base::AutoLock lock(lock_); |
67 | 67 |
68 // Remove completed tasks. | 68 // Remove completed tasks. |
69 DCHECK(completed_tasks_.empty()); | 69 DCHECK(completed_tasks_.empty()); |
70 task_graph_runner_->CollectCompletedTasks(namespace_token_, | 70 task_graph_runner_->CollectCompletedTasks(namespace_token_, |
71 &completed_tasks_); | 71 &completed_tasks_); |
72 | 72 |
73 tasks_.erase(tasks_.begin(), tasks_.begin() + completed_tasks_.size()); | 73 tasks_.erase(tasks_.begin(), tasks_.begin() + completed_tasks_.size()); |
74 | 74 |
75 tasks_.push_back(make_scoped_refptr(new ClosureTask(task))); | 75 tasks_.push_back(make_scoped_refptr(new ClosureTask(std::move(task)))); |
76 graph_.Reset(); | 76 graph_.Reset(); |
77 for (const auto& graph_task : tasks_) { | 77 for (const auto& graph_task : tasks_) { |
78 int dependencies = 0; | 78 int dependencies = 0; |
79 if (!graph_.nodes.empty()) | 79 if (!graph_.nodes.empty()) |
80 dependencies = 1; | 80 dependencies = 1; |
81 | 81 |
82 // Treat any tasks that are enqueued through the SequencedTaskRunner as | 82 // Treat any tasks that are enqueued through the SequencedTaskRunner as |
83 // FOREGROUND priority. We don't have enough information to know the | 83 // FOREGROUND priority. We don't have enough information to know the |
84 // actual priority of such tasks, so we run them as soon as possible. | 84 // actual priority of such tasks, so we run them as soon as possible. |
85 cc::TaskGraph::Node node(graph_task, cc::TASK_CATEGORY_FOREGROUND, | 85 cc::TaskGraph::Node node(graph_task, cc::TASK_CATEGORY_FOREGROUND, |
(...skipping 93 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
179 } | 179 } |
180 while (!threads_.empty()) { | 180 while (!threads_.empty()) { |
181 threads_.back()->Join(); | 181 threads_.back()->Join(); |
182 threads_.pop_back(); | 182 threads_.pop_back(); |
183 } | 183 } |
184 } | 184 } |
185 | 185 |
186 // Overridden from base::TaskRunner: | 186 // Overridden from base::TaskRunner: |
187 bool CategorizedWorkerPool::PostDelayedTask( | 187 bool CategorizedWorkerPool::PostDelayedTask( |
188 const tracked_objects::Location& from_here, | 188 const tracked_objects::Location& from_here, |
189 const base::Closure& task, | 189 base::Closure task, |
190 base::TimeDelta delay) { | 190 base::TimeDelta delay) { |
191 base::AutoLock lock(lock_); | 191 base::AutoLock lock(lock_); |
192 | 192 |
193 // Remove completed tasks. | 193 // Remove completed tasks. |
194 DCHECK(completed_tasks_.empty()); | 194 DCHECK(completed_tasks_.empty()); |
195 CollectCompletedTasksWithLockAcquired(namespace_token_, &completed_tasks_); | 195 CollectCompletedTasksWithLockAcquired(namespace_token_, &completed_tasks_); |
196 | 196 |
197 cc::Task::Vector::iterator end = std::remove_if( | 197 cc::Task::Vector::iterator end = std::remove_if( |
198 tasks_.begin(), tasks_.end(), [this](const scoped_refptr<cc::Task>& e) { | 198 tasks_.begin(), tasks_.end(), [this](const scoped_refptr<cc::Task>& e) { |
199 return std::find(this->completed_tasks_.begin(), | 199 return std::find(this->completed_tasks_.begin(), |
200 this->completed_tasks_.end(), | 200 this->completed_tasks_.end(), |
201 e) != this->completed_tasks_.end(); | 201 e) != this->completed_tasks_.end(); |
202 }); | 202 }); |
203 tasks_.erase(end, tasks_.end()); | 203 tasks_.erase(end, tasks_.end()); |
204 | 204 |
205 tasks_.push_back(make_scoped_refptr(new ClosureTask(task))); | 205 tasks_.push_back(make_scoped_refptr(new ClosureTask(std::move(task)))); |
206 graph_.Reset(); | 206 graph_.Reset(); |
207 for (const auto& graph_task : tasks_) { | 207 for (const auto& graph_task : tasks_) { |
208 // Delayed tasks are assigned FOREGROUND category, ensuring that they run as | 208 // Delayed tasks are assigned FOREGROUND category, ensuring that they run as |
209 // soon as possible once their delay has expired. | 209 // soon as possible once their delay has expired. |
210 graph_.nodes.push_back( | 210 graph_.nodes.push_back( |
211 cc::TaskGraph::Node(graph_task.get(), cc::TASK_CATEGORY_FOREGROUND, | 211 cc::TaskGraph::Node(graph_task.get(), cc::TASK_CATEGORY_FOREGROUND, |
212 0u /* priority */, 0u /* dependencies */)); | 212 0u /* priority */, 0u /* dependencies */)); |
213 } | 213 } |
214 | 214 |
215 ScheduleTasksWithLockAcquired(namespace_token_, &graph_); | 215 ScheduleTasksWithLockAcquired(namespace_token_, &graph_); |
(...skipping 191 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
407 ShouldRunTaskForCategoryWithLockAcquired( | 407 ShouldRunTaskForCategoryWithLockAcquired( |
408 cc::TASK_CATEGORY_NONCONCURRENT_FOREGROUND)) { | 408 cc::TASK_CATEGORY_NONCONCURRENT_FOREGROUND)) { |
409 has_ready_to_run_foreground_tasks_cv_.Signal(); | 409 has_ready_to_run_foreground_tasks_cv_.Signal(); |
410 } | 410 } |
411 | 411 |
412 if (ShouldRunTaskForCategoryWithLockAcquired(cc::TASK_CATEGORY_BACKGROUND)) { | 412 if (ShouldRunTaskForCategoryWithLockAcquired(cc::TASK_CATEGORY_BACKGROUND)) { |
413 has_ready_to_run_background_tasks_cv_.Signal(); | 413 has_ready_to_run_background_tasks_cv_.Signal(); |
414 } | 414 } |
415 } | 415 } |
416 | 416 |
417 CategorizedWorkerPool::ClosureTask::ClosureTask(const base::Closure& closure) | 417 CategorizedWorkerPool::ClosureTask::ClosureTask(base::Closure closure) |
418 : closure_(closure) {} | 418 : closure_(std::move(closure)) {} |
419 | 419 |
420 // Overridden from cc::Task: | 420 // Overridden from cc::Task: |
421 void CategorizedWorkerPool::ClosureTask::RunOnWorkerThread() { | 421 void CategorizedWorkerPool::ClosureTask::RunOnWorkerThread() { |
422 closure_.Run(); | 422 std::move(closure_).Run(); |
423 closure_.Reset(); | |
424 } | 423 } |
425 | 424 |
426 CategorizedWorkerPool::ClosureTask::~ClosureTask() {} | 425 CategorizedWorkerPool::ClosureTask::~ClosureTask() {} |
427 | 426 |
428 } // namespace content | 427 } // namespace content |
OLD | NEW |