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