Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(59)

Side by Side Diff: content/renderer/scheduler/renderer_scheduler_impl.cc

Issue 970473004: [content] Add support for Non nestable idle tasks the the RendererScheduler (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Fix contentperftests Created 5 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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
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
OLDNEW
« no previous file with comments | « content/renderer/scheduler/renderer_scheduler_impl.h ('k') | content/renderer/scheduler/renderer_scheduler_impl_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698