OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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/scheduler/renderer_scheduler_impl.h" | 5 #include "content/renderer/scheduler/renderer_scheduler_impl.h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/message_loop/message_loop_proxy.h" | 8 #include "base/message_loop/message_loop_proxy.h" |
9 #include "base/trace_event/trace_event.h" | 9 #include "base/trace_event/trace_event.h" |
10 #include "base/trace_event/trace_event_argument.h" | 10 #include "base/trace_event/trace_event_argument.h" |
11 #include "cc/output/begin_frame_args.h" | 11 #include "cc/output/begin_frame_args.h" |
| 12 #include "content/renderer/scheduler/nestable_single_thread_task_runner.h" |
12 #include "content/renderer/scheduler/renderer_task_queue_selector.h" | 13 #include "content/renderer/scheduler/renderer_task_queue_selector.h" |
13 #include "ui/gfx/frame_time.h" | 14 #include "ui/gfx/frame_time.h" |
14 | 15 |
15 namespace content { | 16 namespace content { |
16 | 17 |
17 RendererSchedulerImpl::RendererSchedulerImpl( | 18 RendererSchedulerImpl::RendererSchedulerImpl( |
18 scoped_refptr<base::SingleThreadTaskRunner> main_task_runner) | 19 scoped_refptr<NestableSingleThreadTaskRunner> main_task_runner) |
19 : renderer_task_queue_selector_(new RendererTaskQueueSelector()), | 20 : renderer_task_queue_selector_(new RendererTaskQueueSelector()), |
20 task_queue_manager_( | 21 task_queue_manager_( |
21 new TaskQueueManager(TASK_QUEUE_COUNT, | 22 new TaskQueueManager(TASK_QUEUE_COUNT, |
22 main_task_runner, | 23 main_task_runner, |
23 renderer_task_queue_selector_.get())), | 24 renderer_task_queue_selector_.get())), |
24 control_task_runner_( | 25 control_task_runner_( |
25 task_queue_manager_->TaskRunnerForQueue(CONTROL_TASK_QUEUE)), | 26 task_queue_manager_->TaskRunnerForQueue(CONTROL_TASK_QUEUE)), |
26 control_task_after_wakeup_runner_(task_queue_manager_->TaskRunnerForQueue( | 27 control_task_after_wakeup_runner_(task_queue_manager_->TaskRunnerForQueue( |
27 CONTROL_TASK_AFTER_WAKEUP_QUEUE)), | 28 CONTROL_TASK_AFTER_WAKEUP_QUEUE)), |
28 default_task_runner_( | 29 default_task_runner_( |
(...skipping 543 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
572 } | 573 } |
573 | 574 |
574 void RendererSchedulerImpl::RemoveTaskObserver( | 575 void RendererSchedulerImpl::RemoveTaskObserver( |
575 base::MessageLoop::TaskObserver* task_observer) { | 576 base::MessageLoop::TaskObserver* task_observer) { |
576 DCHECK(main_thread_checker_.CalledOnValidThread()); | 577 DCHECK(main_thread_checker_.CalledOnValidThread()); |
577 if (task_queue_manager_) | 578 if (task_queue_manager_) |
578 task_queue_manager_->RemoveTaskObserver(task_observer); | 579 task_queue_manager_->RemoveTaskObserver(task_observer); |
579 } | 580 } |
580 | 581 |
581 } // namespace content | 582 } // namespace content |
OLD | NEW |