Chromium Code Reviews| 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 "platform/scheduler/base/task_queue_impl.h" | 5 #include "platform/scheduler/base/task_queue_impl.h" |
| 6 | 6 |
| 7 #include <utility> | 7 #include <utility> |
| 8 | 8 |
| 9 #include "base/format_macros.h" | 9 #include "base/format_macros.h" |
| 10 #include "base/memory/ptr_util.h" | 10 #include "base/memory/ptr_util.h" |
| (...skipping 200 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 211 TaskType::NON_NESTABLE); | 211 TaskType::NON_NESTABLE); |
| 212 | 212 |
| 213 return PostDelayedTaskImpl(from_here, std::move(task), delay, | 213 return PostDelayedTaskImpl(from_here, std::move(task), delay, |
| 214 TaskType::NON_NESTABLE); | 214 TaskType::NON_NESTABLE); |
| 215 } | 215 } |
| 216 | 216 |
| 217 bool TaskQueueImpl::PostImmediateTaskImpl( | 217 bool TaskQueueImpl::PostImmediateTaskImpl( |
| 218 const tracked_objects::Location& from_here, | 218 const tracked_objects::Location& from_here, |
| 219 base::Closure task, | 219 base::Closure task, |
| 220 TaskType task_type) { | 220 TaskType task_type) { |
| 221 base::AutoLock lock(any_thread_lock_); | 221 base::AutoLock lock(any_thread_lock_); |
|
Sami
2017/03/31 14:08:55
I think we just need to instrument PostImmediateTa
tzik
2017/04/03 13:57:22
Done.
| |
| 222 if (!any_thread().task_queue_manager) | 222 if (!any_thread().task_queue_manager) |
| 223 return false; | 223 return false; |
| 224 | 224 |
| 225 EnqueueOrder sequence_number = | 225 EnqueueOrder sequence_number = |
| 226 any_thread().task_queue_manager->GetNextSequenceNumber(); | 226 any_thread().task_queue_manager->GetNextSequenceNumber(); |
| 227 | 227 |
| 228 PushOntoImmediateIncomingQueueLocked(from_here, std::move(task), | 228 PushOntoImmediateIncomingQueueLocked(from_here, std::move(task), |
| 229 base::TimeTicks(), sequence_number, | 229 base::TimeTicks(), sequence_number, |
| 230 task_type != TaskType::NON_NESTABLE); | 230 task_type != TaskType::NON_NESTABLE); |
| 231 return true; | 231 return true; |
| (...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 267 base::TimeTicks time_domain_delayed_run_time = time_domain_now + delay; | 267 base::TimeTicks time_domain_delayed_run_time = time_domain_now + delay; |
| 268 PushOntoDelayedIncomingQueueLocked( | 268 PushOntoDelayedIncomingQueueLocked( |
| 269 Task(from_here, std::move(task), time_domain_delayed_run_time, | 269 Task(from_here, std::move(task), time_domain_delayed_run_time, |
| 270 sequence_number, task_type != TaskType::NON_NESTABLE)); | 270 sequence_number, task_type != TaskType::NON_NESTABLE)); |
| 271 } | 271 } |
| 272 return true; | 272 return true; |
| 273 } | 273 } |
| 274 | 274 |
| 275 void TaskQueueImpl::PushOntoDelayedIncomingQueueFromMainThread( | 275 void TaskQueueImpl::PushOntoDelayedIncomingQueueFromMainThread( |
| 276 Task pending_task, base::TimeTicks now) { | 276 Task pending_task, base::TimeTicks now) { |
| 277 CHECK(pending_task.task); | |
| 278 | |
| 277 base::TimeTicks delayed_run_time = pending_task.delayed_run_time; | 279 base::TimeTicks delayed_run_time = pending_task.delayed_run_time; |
| 278 main_thread_only().task_queue_manager->DidQueueTask(pending_task); | 280 main_thread_only().task_queue_manager->DidQueueTask(pending_task); |
| 279 main_thread_only().delayed_incoming_queue.push(std::move(pending_task)); | 281 main_thread_only().delayed_incoming_queue.push(std::move(pending_task)); |
| 280 | 282 |
| 281 // If |pending_task| is at the head of the queue, then make sure a wakeup | 283 // If |pending_task| is at the head of the queue, then make sure a wakeup |
| 282 // is requested if the queue is enabled. Note we still want to schedule a | 284 // is requested if the queue is enabled. Note we still want to schedule a |
| 283 // wakeup even if blocked by a fence, because we'd break throttling logic | 285 // wakeup even if blocked by a fence, because we'd break throttling logic |
| 284 // otherwise. | 286 // otherwise. |
| 285 base::TimeTicks next_delayed_task = | 287 base::TimeTicks next_delayed_task = |
| 286 main_thread_only().delayed_incoming_queue.top().delayed_run_time; | 288 main_thread_only().delayed_incoming_queue.top().delayed_run_time; |
| 287 if (next_delayed_task == delayed_run_time && IsQueueEnabled()) { | 289 if (next_delayed_task == delayed_run_time && IsQueueEnabled()) { |
| 288 main_thread_only().time_domain->ScheduleDelayedWork( | 290 main_thread_only().time_domain->ScheduleDelayedWork( |
| 289 this, {delayed_run_time, pending_task.sequence_num}, now); | 291 this, {delayed_run_time, pending_task.sequence_num}, now); |
| 290 } | 292 } |
| 291 | 293 |
| 292 TraceQueueSize(false); | 294 TraceQueueSize(false); |
| 293 } | 295 } |
| 294 | 296 |
| 295 void TaskQueueImpl::PushOntoDelayedIncomingQueueLocked(Task pending_task) { | 297 void TaskQueueImpl::PushOntoDelayedIncomingQueueLocked(Task pending_task) { |
| 298 CHECK(pending_task.task); | |
| 299 | |
| 296 any_thread().task_queue_manager->DidQueueTask(pending_task); | 300 any_thread().task_queue_manager->DidQueueTask(pending_task); |
| 297 | 301 |
| 298 int thread_hop_task_sequence_number = | 302 int thread_hop_task_sequence_number = |
| 299 any_thread().task_queue_manager->GetNextSequenceNumber(); | 303 any_thread().task_queue_manager->GetNextSequenceNumber(); |
| 300 PushOntoImmediateIncomingQueueLocked( | 304 PushOntoImmediateIncomingQueueLocked( |
| 301 FROM_HERE, | 305 FROM_HERE, |
| 302 base::Bind(&TaskQueueImpl::ScheduleDelayedWorkTask, this, | 306 base::Bind(&TaskQueueImpl::ScheduleDelayedWorkTask, this, |
| 303 base::Passed(&pending_task)), | 307 base::Passed(&pending_task)), |
| 304 base::TimeTicks(), | 308 base::TimeTicks(), |
| 305 thread_hop_task_sequence_number, | 309 thread_hop_task_sequence_number, |
| (...skipping 20 matching lines...) Expand all Loading... | |
| 326 } | 330 } |
| 327 TraceQueueSize(false); | 331 TraceQueueSize(false); |
| 328 } | 332 } |
| 329 | 333 |
| 330 void TaskQueueImpl::PushOntoImmediateIncomingQueueLocked( | 334 void TaskQueueImpl::PushOntoImmediateIncomingQueueLocked( |
| 331 const tracked_objects::Location& posted_from, | 335 const tracked_objects::Location& posted_from, |
| 332 base::Closure task, | 336 base::Closure task, |
| 333 base::TimeTicks desired_run_time, | 337 base::TimeTicks desired_run_time, |
| 334 EnqueueOrder sequence_number, | 338 EnqueueOrder sequence_number, |
| 335 bool nestable) { | 339 bool nestable) { |
| 340 CHECK(task); | |
| 341 | |
| 336 // If the |immediate_incoming_queue| is empty we need a DoWork posted to make | 342 // If the |immediate_incoming_queue| is empty we need a DoWork posted to make |
| 337 // it run. | 343 // it run. |
| 338 if (any_thread().immediate_incoming_queue.empty()) { | 344 if (any_thread().immediate_incoming_queue.empty()) { |
| 339 // However there's no point posting a DoWork for a blocked queue. NB we can | 345 // However there's no point posting a DoWork for a blocked queue. NB we can |
| 340 // only tell if it's disabled from the main thread. | 346 // only tell if it's disabled from the main thread. |
| 341 bool queue_is_blocked = | 347 bool queue_is_blocked = |
| 342 RunsTasksOnCurrentThread() && | 348 RunsTasksOnCurrentThread() && |
| 343 (!IsQueueEnabled() || main_thread_only().current_fence); | 349 (!IsQueueEnabled() || main_thread_only().current_fence); |
| 344 any_thread().task_queue_manager->OnQueueHasIncomingImmediateWork( | 350 any_thread().task_queue_manager->OnQueueHasIncomingImmediateWork( |
| 345 this, sequence_number, queue_is_blocked); | 351 this, sequence_number, queue_is_blocked); |
| (...skipping 536 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 882 | 888 |
| 883 void TaskQueueImpl::PushImmediateIncomingTaskForTest( | 889 void TaskQueueImpl::PushImmediateIncomingTaskForTest( |
| 884 TaskQueueImpl::Task&& task) { | 890 TaskQueueImpl::Task&& task) { |
| 885 base::AutoLock lock(any_thread_lock_); | 891 base::AutoLock lock(any_thread_lock_); |
| 886 any_thread().immediate_incoming_queue.push_back(std::move(task)); | 892 any_thread().immediate_incoming_queue.push_back(std::move(task)); |
| 887 } | 893 } |
| 888 | 894 |
| 889 } // namespace internal | 895 } // namespace internal |
| 890 } // namespace scheduler | 896 } // namespace scheduler |
| 891 } // namespace blink | 897 } // namespace blink |
| OLD | NEW |