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

Side by Side Diff: components/scheduler/child/webthread_impl_for_worker_scheduler.h

Issue 1589463002: compositor worker: Use a WebThread for the compositor thread. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: self-nits Created 4 years, 11 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
« no previous file with comments | « no previous file | components/scheduler/child/webthread_impl_for_worker_scheduler.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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 #ifndef COMPONENTS_SCHEDULER_CHILD_WEBTHREAD_IMPL_FOR_WORKER_SCHEDULER_H_ 5 #ifndef COMPONENTS_SCHEDULER_CHILD_WEBTHREAD_IMPL_FOR_WORKER_SCHEDULER_H_
6 #define COMPONENTS_SCHEDULER_CHILD_WEBTHREAD_IMPL_FOR_WORKER_SCHEDULER_H_ 6 #define COMPONENTS_SCHEDULER_CHILD_WEBTHREAD_IMPL_FOR_WORKER_SCHEDULER_H_
7 7
8 #include "base/threading/thread.h" 8 #include "base/threading/thread.h"
9 #include "components/scheduler/base/task_queue_manager.h" 9 #include "components/scheduler/base/task_queue_manager.h"
10 #include "components/scheduler/child/webthread_base.h" 10 #include "components/scheduler/child/webthread_base.h"
(...skipping 15 matching lines...) Expand all
26 26
27 class SCHEDULER_EXPORT WebThreadImplForWorkerScheduler 27 class SCHEDULER_EXPORT WebThreadImplForWorkerScheduler
28 : public WebThreadBase, 28 : public WebThreadBase,
29 public base::MessageLoop::DestructionObserver { 29 public base::MessageLoop::DestructionObserver {
30 public: 30 public:
31 explicit WebThreadImplForWorkerScheduler(const char* name); 31 explicit WebThreadImplForWorkerScheduler(const char* name);
32 WebThreadImplForWorkerScheduler(const char* name, 32 WebThreadImplForWorkerScheduler(const char* name,
33 base::Thread::Options options); 33 base::Thread::Options options);
34 ~WebThreadImplForWorkerScheduler() override; 34 ~WebThreadImplForWorkerScheduler() override;
35 35
36 void Init();
37
36 // blink::WebThread implementation. 38 // blink::WebThread implementation.
37 blink::WebScheduler* scheduler() const override; 39 blink::WebScheduler* scheduler() const override;
38 blink::PlatformThreadId threadId() const override; 40 blink::PlatformThreadId threadId() const override;
39 blink::WebTaskRunner* taskRunner() override; 41 blink::WebTaskRunner* taskRunner() override;
40 42
41 // WebThreadBase implementation. 43 // WebThreadBase implementation.
42 base::SingleThreadTaskRunner* TaskRunner() const override; 44 base::SingleThreadTaskRunner* TaskRunner() const override;
43 scheduler::SingleThreadIdleTaskRunner* IdleTaskRunner() const override; 45 scheduler::SingleThreadIdleTaskRunner* IdleTaskRunner() const override;
44 46
45 // base::MessageLoop::DestructionObserver implementation. 47 // base::MessageLoop::DestructionObserver implementation.
46 void WillDestroyCurrentMessageLoop() override; 48 void WillDestroyCurrentMessageLoop() override;
47 49
48 private: 50 private:
51 // Returns whether the base::Thread's task-runner should be used as the
52 // default task runner (returns true), or the default task runner from the
53 // scheduler should be used instead (returns false). The default behaviour is
54 // to use the scheduler's default task runner.
55 virtual bool UseThreadTaskRunnerAsDefault() const;
Sami 2016/01/13 17:17:05 This is a dangerous API because tasks will run in
sadrul 2016/01/13 18:29:32 Indeed, that's what I was worried about. A differe
56
49 void AddTaskObserverInternal( 57 void AddTaskObserverInternal(
50 base::MessageLoop::TaskObserver* observer) override; 58 base::MessageLoop::TaskObserver* observer) override;
51 void RemoveTaskObserverInternal( 59 void RemoveTaskObserverInternal(
52 base::MessageLoop::TaskObserver* observer) override; 60 base::MessageLoop::TaskObserver* observer) override;
53 61
54 void InitOnThread(base::WaitableEvent* completion); 62 void InitOnThread(base::WaitableEvent* completion);
55 void RestoreTaskRunnerOnThread(base::WaitableEvent* completion); 63 void RestoreTaskRunnerOnThread(base::WaitableEvent* completion);
56 64
57 scoped_ptr<base::Thread> thread_; 65 scoped_ptr<base::Thread> thread_;
58 scoped_ptr<scheduler::WorkerScheduler> worker_scheduler_; 66 scoped_ptr<scheduler::WorkerScheduler> worker_scheduler_;
59 scoped_ptr<scheduler::WebSchedulerImpl> web_scheduler_; 67 scoped_ptr<scheduler::WebSchedulerImpl> web_scheduler_;
60 scoped_refptr<base::SingleThreadTaskRunner> thread_task_runner_; 68 scoped_refptr<base::SingleThreadTaskRunner> thread_task_runner_;
61 scoped_refptr<base::SingleThreadTaskRunner> task_runner_; 69 scoped_refptr<base::SingleThreadTaskRunner> task_runner_;
62 scoped_refptr<scheduler::SingleThreadIdleTaskRunner> idle_task_runner_; 70 scoped_refptr<scheduler::SingleThreadIdleTaskRunner> idle_task_runner_;
63 scoped_refptr<SchedulerTqmDelegate> task_runner_delegate_; 71 scoped_refptr<SchedulerTqmDelegate> task_runner_delegate_;
64 scoped_ptr<WebTaskRunnerImpl> web_task_runner_; 72 scoped_ptr<WebTaskRunnerImpl> web_task_runner_;
65 }; 73 };
66 74
67 } // namespace scheduler 75 } // namespace scheduler
68 76
69 #endif // COMPONENTS_SCHEDULER_CHILD_WEBTHREAD_IMPL_FOR_WORKER_SCHEDULER_H_ 77 #endif // COMPONENTS_SCHEDULER_CHILD_WEBTHREAD_IMPL_FOR_WORKER_SCHEDULER_H_
OLDNEW
« no previous file with comments | « no previous file | components/scheduler/child/webthread_impl_for_worker_scheduler.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698