|  | // Copyright 2016 The Chromium Authors. All rights reserved. | 
|  | // Use of this source code is governed by a BSD-style license that can be | 
|  | // found in the LICENSE file. | 
|  |  | 
|  | #include "base/task_scheduler/task_scheduler.h" | 
|  |  | 
|  | #include <algorithm> | 
|  |  | 
|  | #include "base/logging.h" | 
|  | #include "base/memory/ptr_util.h" | 
|  | #include "base/sys_info.h" | 
|  | #include "base/task_scheduler/scheduler_worker_pool_params.h" | 
|  | #include "base/task_scheduler/task_scheduler_impl.h" | 
|  | #include "base/threading/platform_thread.h" | 
|  | #include "base/time/time.h" | 
|  |  | 
|  | namespace base { | 
|  |  | 
|  | namespace { | 
|  |  | 
|  | // |g_task_scheduler| is intentionally leaked on shutdown. | 
|  | TaskScheduler* g_task_scheduler = nullptr; | 
|  |  | 
|  | }  // namespace | 
|  |  | 
|  | TaskScheduler::InitParams::InitParams( | 
|  | const SchedulerWorkerPoolParams& background_worker_pool_params_in, | 
|  | const SchedulerWorkerPoolParams& background_blocking_worker_pool_params_in, | 
|  | const SchedulerWorkerPoolParams& foreground_worker_pool_params_in, | 
|  | const SchedulerWorkerPoolParams& foreground_blocking_worker_pool_params_in, | 
|  | SharedWorkerPoolEnvironment shared_worker_pool_environment_in) | 
|  | : background_worker_pool_params(background_worker_pool_params_in), | 
|  | background_blocking_worker_pool_params( | 
|  | background_blocking_worker_pool_params_in), | 
|  | foreground_worker_pool_params(foreground_worker_pool_params_in), | 
|  | foreground_blocking_worker_pool_params( | 
|  | foreground_blocking_worker_pool_params_in), | 
|  | shared_worker_pool_environment(shared_worker_pool_environment_in) {} | 
|  |  | 
|  | TaskScheduler::InitParams::~InitParams() = default; | 
|  |  | 
|  | #if !defined(OS_NACL) | 
|  | // static | 
|  | void TaskScheduler::CreateAndStartWithDefaultParams(StringPiece name) { | 
|  | Create(name); | 
|  | GetInstance()->StartWithDefaultParams(); | 
|  | } | 
|  |  | 
|  | void TaskScheduler::StartWithDefaultParams() { | 
|  | // Values were chosen so that: | 
|  | // * There are few background threads. | 
|  | // * Background threads never outnumber foreground threads. | 
|  | // * The system is utilized maximally by foreground threads. | 
|  | // * The main thread is assumed to be busy, cap foreground workers at | 
|  | //   |num_cores - 1|. | 
|  | const int num_cores = SysInfo::NumberOfProcessors(); | 
|  | constexpr int kBackgroundMaxThreads = 1; | 
|  | constexpr int kBackgroundBlockingMaxThreads = 2; | 
|  | const int kForegroundMaxThreads = std::max(1, num_cores - 1); | 
|  | const int kForegroundBlockingMaxThreads = std::max(2, num_cores - 1); | 
|  |  | 
|  | constexpr TimeDelta kSuggestedReclaimTime = TimeDelta::FromSeconds(30); | 
|  |  | 
|  | Start({{kBackgroundMaxThreads, kSuggestedReclaimTime}, | 
|  | {kBackgroundBlockingMaxThreads, kSuggestedReclaimTime}, | 
|  | {kForegroundMaxThreads, kSuggestedReclaimTime}, | 
|  | {kForegroundBlockingMaxThreads, kSuggestedReclaimTime}}); | 
|  | } | 
|  | #endif  // !defined(OS_NACL) | 
|  |  | 
|  | void TaskScheduler::Create(StringPiece name) { | 
|  | SetInstance(std::make_unique<internal::TaskSchedulerImpl>(name)); | 
|  | } | 
|  |  | 
|  | // static | 
|  | void TaskScheduler::SetInstance(std::unique_ptr<TaskScheduler> task_scheduler) { | 
|  | delete g_task_scheduler; | 
|  | g_task_scheduler = task_scheduler.release(); | 
|  | } | 
|  |  | 
|  | // static | 
|  | TaskScheduler* TaskScheduler::GetInstance() { | 
|  | return g_task_scheduler; | 
|  | } | 
|  |  | 
|  | }  // namespace base |