OLD | NEW |
1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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/browser/initialization.h" | 5 #include "components/task_scheduler_util/browser/initialization.h" |
6 | 6 |
7 #include <map> | 7 #include <map> |
8 #include <string> | 8 #include <string> |
9 | 9 |
10 #include "base/command_line.h" | 10 #include "base/command_line.h" |
11 #include "base/logging.h" | 11 #include "base/memory/ptr_util.h" |
12 #include "base/task_scheduler/scheduler_worker_params.h" | |
13 #include "base/task_scheduler/switches.h" | 12 #include "base/task_scheduler/switches.h" |
14 #include "base/task_scheduler/task_traits.h" | |
15 #include "base/threading/platform_thread.h" | |
16 #include "base/threading/sequenced_worker_pool.h" | 13 #include "base/threading/sequenced_worker_pool.h" |
17 #include "components/task_scheduler_util/common/variations_util.h" | 14 #include "components/task_scheduler_util/common/variations_util.h" |
18 #include "components/variations/variations_associated_data.h" | 15 #include "components/variations/variations_associated_data.h" |
19 | 16 |
20 namespace task_scheduler_util { | 17 namespace task_scheduler_util { |
21 | 18 |
22 namespace { | 19 namespace { |
23 | 20 |
24 constexpr char kFieldTrialName[] = "BrowserScheduler"; | 21 constexpr char kFieldTrialName[] = "BrowserScheduler"; |
25 | 22 |
26 enum WorkerPoolType : size_t { | 23 enum WorkerPoolType : size_t { |
27 BACKGROUND = 0, | 24 BACKGROUND = 0, |
28 BACKGROUND_BLOCKING, | 25 BACKGROUND_BLOCKING, |
29 FOREGROUND, | 26 FOREGROUND, |
30 FOREGROUND_BLOCKING, | 27 FOREGROUND_BLOCKING, |
31 WORKER_POOL_COUNT // Always last. | 28 WORKER_POOL_COUNT // Always last. |
32 }; | 29 }; |
33 | 30 |
34 } // namespace | 31 } // namespace |
35 | 32 |
| 33 std::unique_ptr<base::TaskScheduler::InitParams> |
| 34 GetBrowserTaskSchedulerInitParamsFromVariations() { |
| 35 std::map<std::string, std::string> variation_params; |
| 36 if (!::variations::GetVariationParams(kFieldTrialName, &variation_params)) |
| 37 return nullptr; |
| 38 |
| 39 const auto background_worker_pool_params = |
| 40 StringToWorkerPoolParams(variation_params["Background"]); |
| 41 const auto background_blocking_worker_pool_params = |
| 42 StringToWorkerPoolParams(variation_params["BackgroundBlocking"]); |
| 43 const auto foreground_worker_pool_params = |
| 44 StringToWorkerPoolParams(variation_params["Foreground"]); |
| 45 const auto foreground_blocking_worker_pool_params = |
| 46 StringToWorkerPoolParams(variation_params["ForegroundBlocking"]); |
| 47 |
| 48 if (!background_worker_pool_params || |
| 49 !background_blocking_worker_pool_params || |
| 50 !foreground_worker_pool_params || |
| 51 !foreground_blocking_worker_pool_params) { |
| 52 return nullptr; |
| 53 } |
| 54 |
| 55 return base::MakeUnique<base::TaskScheduler::InitParams>( |
| 56 *background_worker_pool_params, *background_blocking_worker_pool_params, |
| 57 *foreground_worker_pool_params, *foreground_blocking_worker_pool_params); |
| 58 } |
| 59 |
36 std::vector<base::SchedulerWorkerPoolParams> | 60 std::vector<base::SchedulerWorkerPoolParams> |
37 GetBrowserWorkerPoolParamsFromVariations() { | 61 GetBrowserWorkerPoolParamsFromVariations() { |
38 using ThreadPriority = base::ThreadPriority; | 62 const auto init_params = GetBrowserTaskSchedulerInitParamsFromVariations(); |
39 | 63 if (!init_params) |
40 std::map<std::string, std::string> variation_params; | |
41 if (!::variations::GetVariationParams(kFieldTrialName, &variation_params)) | |
42 return std::vector<base::SchedulerWorkerPoolParams>(); | 64 return std::vector<base::SchedulerWorkerPoolParams>(); |
43 | 65 |
44 std::vector<SchedulerImmutableWorkerPoolParams> immutable_worker_pool_params; | 66 return std::vector<base::SchedulerWorkerPoolParams>{ |
45 DCHECK_EQ(BACKGROUND, immutable_worker_pool_params.size()); | 67 init_params->background_worker_pool_params, |
46 immutable_worker_pool_params.emplace_back("Background", | 68 init_params->background_blocking_worker_pool_params, |
47 ThreadPriority::BACKGROUND); | 69 init_params->foreground_worker_pool_params, |
48 DCHECK_EQ(BACKGROUND_BLOCKING, immutable_worker_pool_params.size()); | 70 init_params->foreground_blocking_worker_pool_params}; |
49 immutable_worker_pool_params.emplace_back("BackgroundBlocking", | |
50 ThreadPriority::BACKGROUND); | |
51 DCHECK_EQ(FOREGROUND, immutable_worker_pool_params.size()); | |
52 immutable_worker_pool_params.emplace_back("Foreground", | |
53 ThreadPriority::NORMAL); | |
54 // Tasks posted to SequencedWorkerPool or BrowserThreadImpl may be redirected | |
55 // to this pool. Since COM STA is initialized in these environments, it must | |
56 // also be initialized in this pool. | |
57 DCHECK_EQ(FOREGROUND_BLOCKING, immutable_worker_pool_params.size()); | |
58 immutable_worker_pool_params.emplace_back( | |
59 "ForegroundBlocking", ThreadPriority::NORMAL, | |
60 base::SchedulerBackwardCompatibility::INIT_COM_STA); | |
61 | |
62 return GetWorkerPoolParams(immutable_worker_pool_params, variation_params); | |
63 } | 71 } |
64 | 72 |
65 size_t BrowserWorkerPoolIndexForTraits(const base::TaskTraits& traits) { | 73 size_t BrowserWorkerPoolIndexForTraits(const base::TaskTraits& traits) { |
66 const bool is_background = | 74 const bool is_background = |
67 traits.priority() == base::TaskPriority::BACKGROUND; | 75 traits.priority() == base::TaskPriority::BACKGROUND; |
68 if (traits.may_block() || traits.with_base_sync_primitives()) | 76 if (traits.may_block() || traits.with_base_sync_primitives()) |
69 return is_background ? BACKGROUND_BLOCKING : FOREGROUND_BLOCKING; | 77 return is_background ? BACKGROUND_BLOCKING : FOREGROUND_BLOCKING; |
70 return is_background ? BACKGROUND : FOREGROUND; | 78 return is_background ? BACKGROUND : FOREGROUND; |
71 } | 79 } |
72 | 80 |
73 void MaybePerformBrowserTaskSchedulerRedirection() { | 81 void MaybePerformBrowserTaskSchedulerRedirection() { |
74 // TODO(gab): Remove this when http://crbug.com/622400 concludes. | 82 // TODO(gab): Remove this when http://crbug.com/622400 concludes. |
75 if (!base::CommandLine::ForCurrentProcess()->HasSwitch( | 83 if (!base::CommandLine::ForCurrentProcess()->HasSwitch( |
76 switches::kDisableBrowserTaskScheduler) && | 84 switches::kDisableBrowserTaskScheduler) && |
77 variations::GetVariationParamValue( | 85 variations::GetVariationParamValue( |
78 kFieldTrialName, "RedirectSequencedWorkerPools") == "true") { | 86 kFieldTrialName, "RedirectSequencedWorkerPools") == "true") { |
79 const base::TaskPriority max_task_priority = | 87 const base::TaskPriority max_task_priority = |
80 variations::GetVariationParamValue( | 88 variations::GetVariationParamValue( |
81 kFieldTrialName, "CapSequencedWorkerPoolsAtUserVisible") == "true" | 89 kFieldTrialName, "CapSequencedWorkerPoolsAtUserVisible") == "true" |
82 ? base::TaskPriority::USER_VISIBLE | 90 ? base::TaskPriority::USER_VISIBLE |
83 : base::TaskPriority::HIGHEST; | 91 : base::TaskPriority::HIGHEST; |
84 base::SequencedWorkerPool::EnableWithRedirectionToTaskSchedulerForProcess( | 92 base::SequencedWorkerPool::EnableWithRedirectionToTaskSchedulerForProcess( |
85 max_task_priority); | 93 max_task_priority); |
86 } | 94 } |
87 } | 95 } |
88 | 96 |
89 } // namespace task_scheduler_util | 97 } // namespace task_scheduler_util |
OLD | NEW |