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 |