OLD | NEW |
1 // Copyright 2017 The Chromium Authors. All rights reserved. | 1 // Copyright 2017 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 "components/task_scheduler_util/renderer/initialization.h" | 5 #include "components/task_scheduler_util/renderer/initialization.h" |
6 | 6 |
7 #include <map> | |
8 #include <string> | |
9 | |
10 #include "base/command_line.h" | 7 #include "base/command_line.h" |
11 #include "base/logging.h" | 8 #include "base/memory/ptr_util.h" |
12 #include "base/task_scheduler/task_traits.h" | 9 #include "base/task_scheduler/task_traits.h" |
13 #include "base/threading/platform_thread.h" | |
14 #include "components/task_scheduler_util/common/variations_util.h" | 10 #include "components/task_scheduler_util/common/variations_util.h" |
15 | 11 |
16 namespace task_scheduler_util { | 12 namespace task_scheduler_util { |
17 | 13 |
18 namespace { | 14 namespace { |
19 | 15 |
20 enum WorkerPoolType : size_t { | 16 enum WorkerPoolType : size_t { |
21 BACKGROUND = 0, | 17 BACKGROUND = 0, |
22 BACKGROUND_BLOCKING, | 18 BACKGROUND_BLOCKING, |
23 FOREGROUND, | 19 FOREGROUND, |
24 FOREGROUND_BLOCKING, | 20 FOREGROUND_BLOCKING, |
25 WORKER_POOL_COUNT // Always last. | 21 WORKER_POOL_COUNT // Always last. |
26 }; | 22 }; |
27 | 23 |
28 } // namespace | 24 } // namespace |
29 | 25 |
| 26 std::unique_ptr<base::TaskScheduler::InitParams> |
| 27 GetRendererTaskSchedulerInitParamsFromCommandLine() { |
| 28 auto variation_params = GetVariationParamsFromCommandLine( |
| 29 *base::CommandLine::ForCurrentProcess()); |
| 30 |
| 31 const auto background_worker_pool_params = |
| 32 StringToWorkerPoolParams(variation_params["RendererBackground"]); |
| 33 const auto background_blocking_worker_pool_params = |
| 34 StringToWorkerPoolParams(variation_params["RendererBackgroundBlocking"]); |
| 35 const auto foreground_worker_pool_params = |
| 36 StringToWorkerPoolParams(variation_params["RendererForeground"]); |
| 37 const auto foreground_blocking_worker_pool_params = |
| 38 StringToWorkerPoolParams(variation_params["RendererForegroundBlocking"]); |
| 39 |
| 40 if (!background_worker_pool_params || |
| 41 !background_blocking_worker_pool_params || |
| 42 !foreground_worker_pool_params || |
| 43 !foreground_blocking_worker_pool_params) { |
| 44 return nullptr; |
| 45 } |
| 46 |
| 47 return base::MakeUnique<base::TaskScheduler::InitParams>( |
| 48 *background_worker_pool_params, *background_blocking_worker_pool_params, |
| 49 *foreground_worker_pool_params, *foreground_blocking_worker_pool_params); |
| 50 } |
| 51 |
30 std::vector<base::SchedulerWorkerPoolParams> GetRendererWorkerPoolParams() { | 52 std::vector<base::SchedulerWorkerPoolParams> GetRendererWorkerPoolParams() { |
31 using ThreadPriority = base::ThreadPriority; | 53 const auto init_params = GetRendererTaskSchedulerInitParamsFromCommandLine(); |
32 std::vector<SchedulerImmutableWorkerPoolParams> immutable_worker_pool_params; | 54 if (!init_params) |
33 DCHECK_EQ(BACKGROUND, immutable_worker_pool_params.size()); | 55 return std::vector<base::SchedulerWorkerPoolParams>(); |
34 immutable_worker_pool_params.emplace_back("RendererBackground", | 56 |
35 ThreadPriority::BACKGROUND); | 57 return std::vector<base::SchedulerWorkerPoolParams>{ |
36 DCHECK_EQ(BACKGROUND_BLOCKING, immutable_worker_pool_params.size()); | 58 init_params->background_worker_pool_params, |
37 immutable_worker_pool_params.emplace_back("RendererBackgroundBlocking", | 59 init_params->background_blocking_worker_pool_params, |
38 ThreadPriority::BACKGROUND); | 60 init_params->foreground_worker_pool_params, |
39 DCHECK_EQ(FOREGROUND, immutable_worker_pool_params.size()); | 61 init_params->foreground_blocking_worker_pool_params}; |
40 immutable_worker_pool_params.emplace_back("RendererForeground", | |
41 ThreadPriority::NORMAL); | |
42 DCHECK_EQ(FOREGROUND_BLOCKING, immutable_worker_pool_params.size()); | |
43 immutable_worker_pool_params.emplace_back("RendererForegroundBlocking", | |
44 ThreadPriority::NORMAL); | |
45 return GetWorkerPoolParams(immutable_worker_pool_params, | |
46 GetVariationParamsFromCommandLine( | |
47 *base::CommandLine::ForCurrentProcess())); | |
48 } | 62 } |
49 | 63 |
50 size_t RendererWorkerPoolIndexForTraits(const base::TaskTraits& traits) { | 64 size_t RendererWorkerPoolIndexForTraits(const base::TaskTraits& traits) { |
51 const bool is_background = | 65 const bool is_background = |
52 traits.priority() == base::TaskPriority::BACKGROUND; | 66 traits.priority() == base::TaskPriority::BACKGROUND; |
53 if (traits.may_block() || traits.with_base_sync_primitives()) | 67 if (traits.may_block() || traits.with_base_sync_primitives()) |
54 return is_background ? BACKGROUND_BLOCKING : FOREGROUND_BLOCKING; | 68 return is_background ? BACKGROUND_BLOCKING : FOREGROUND_BLOCKING; |
55 return is_background ? BACKGROUND : FOREGROUND; | 69 return is_background ? BACKGROUND : FOREGROUND; |
56 } | 70 } |
57 | 71 |
58 } // namespace task_scheduler_util | 72 } // namespace task_scheduler_util |
OLD | NEW |