1484543d1Sopenharmony_ci/* 2484543d1Sopenharmony_ci * Copyright (c) 2023 Huawei Device Co., Ltd. 3484543d1Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 4484543d1Sopenharmony_ci * you may not use this file except in compliance with the License. 5484543d1Sopenharmony_ci * You may obtain a copy of the License at 6484543d1Sopenharmony_ci * 7484543d1Sopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 8484543d1Sopenharmony_ci * 9484543d1Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software 10484543d1Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 11484543d1Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12484543d1Sopenharmony_ci * See the License for the specific language governing permissions and 13484543d1Sopenharmony_ci * limitations under the License. 14484543d1Sopenharmony_ci */ 15484543d1Sopenharmony_ci 16484543d1Sopenharmony_ci#ifndef FFRT_WORKER_MANAGER_HPP 17484543d1Sopenharmony_ci#define FFRT_WORKER_MANAGER_HPP 18484543d1Sopenharmony_ci 19484543d1Sopenharmony_ci#include <thread> 20484543d1Sopenharmony_ci#include <list> 21484543d1Sopenharmony_ci#include <mutex> 22484543d1Sopenharmony_ci#include <shared_mutex> 23484543d1Sopenharmony_ci#include <condition_variable> 24484543d1Sopenharmony_ci#include <unordered_map> 25484543d1Sopenharmony_ci 26484543d1Sopenharmony_ci#include "eu/worker_thread.h" 27484543d1Sopenharmony_ci#include "eu/thread_group.h" 28484543d1Sopenharmony_ci#include "eu/cpu_monitor.h" 29484543d1Sopenharmony_ci#include "sync/sync.h" 30484543d1Sopenharmony_ci#include "dfx/log/ffrt_log_api.h" 31484543d1Sopenharmony_ci 32484543d1Sopenharmony_cinamespace ffrt { 33484543d1Sopenharmony_cistruct WorkerGroupCtl { 34484543d1Sopenharmony_ci std::unique_ptr<ThreadGroup> tg; 35484543d1Sopenharmony_ci uint64_t tgRefCount = 0; 36484543d1Sopenharmony_ci mutable std::shared_mutex tgMutex; 37484543d1Sopenharmony_ci size_t workerStackSize = 0; 38484543d1Sopenharmony_ci std::unordered_map<WorkerThread*, std::unique_ptr<WorkerThread>> threads; 39484543d1Sopenharmony_ci}; 40484543d1Sopenharmony_ci 41484543d1Sopenharmony_ciclass WorkerManager { 42484543d1Sopenharmony_cipublic: 43484543d1Sopenharmony_ci virtual ~WorkerManager() 44484543d1Sopenharmony_ci { 45484543d1Sopenharmony_ci }; 46484543d1Sopenharmony_ci 47484543d1Sopenharmony_ci ThreadGroup* JoinTG(QoS& qos); 48484543d1Sopenharmony_ci void LeaveTG(QoS& qos); 49484543d1Sopenharmony_ci void JoinRtg(QoS& qos); 50484543d1Sopenharmony_ci 51484543d1Sopenharmony_ci virtual bool IncWorker(const QoS& qos) = 0; 52484543d1Sopenharmony_ci virtual bool DecWorker() = 0; 53484543d1Sopenharmony_ci virtual void NotifyTaskAdded(const QoS& qos) = 0; 54484543d1Sopenharmony_ci virtual void NotifyLocalTaskAdded(const QoS& qos) = 0; 55484543d1Sopenharmony_ci virtual void NotifyWorkers(const QoS& qos, int number) = 0; 56484543d1Sopenharmony_ci virtual std::mutex* GetSleepCtl(int qos) = 0; 57484543d1Sopenharmony_ci virtual CPUMonitor* GetCPUMonitor() = 0; 58484543d1Sopenharmony_ci 59484543d1Sopenharmony_ci WorkerGroupCtl* GetGroupCtl() 60484543d1Sopenharmony_ci { 61484543d1Sopenharmony_ci return groupCtl; 62484543d1Sopenharmony_ci } 63484543d1Sopenharmony_ciprotected: 64484543d1Sopenharmony_ci ThreadGroup tg; 65484543d1Sopenharmony_ci WorkerGroupCtl groupCtl[QoS::MaxNum()]; 66484543d1Sopenharmony_ci}; 67484543d1Sopenharmony_ci} // namespace ffrt 68484543d1Sopenharmony_ci#endif 69