| 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 |