aboutsummaryrefslogtreecommitdiffstats
path: root/library/cpp/actors/core/harmonizer.h
blob: bc6b938fe88d08fb6d4d5d1ad5dae08cb34af3f3 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
#pragma once

#include "defs.h"
#include "config.h"

namespace NActors {
    class IExecutorPool;

    struct TPoolHarmonizedStats {
        ui64 IncreasingThreadsByNeedyState = 0;
        ui64 DecreasingThreadsByStarvedState = 0;
        ui64 DecreasingThreadsByHoggishState = 0;
        i16 PotentialMaxThreadCount = 0;
        bool IsNeedy = false;
        bool IsStarved = false;
        bool IsHoggish = false;
    };

    // Pool cpu harmonizer
    class IHarmonizer {
    public:
        virtual ~IHarmonizer() {}
        virtual void Harmonize(ui64 ts) = 0;
        virtual void DeclareEmergency(ui64 ts) = 0;
        virtual void AddPool(IExecutorPool* pool, TSelfPingInfo *pingInfo = nullptr) = 0;
        virtual void Enable(bool enable) = 0;
        virtual TPoolHarmonizedStats GetPoolStats(i16 poolId) const = 0;
    };

    IHarmonizer* MakeHarmonizer(ui64 ts);
}