diff options
author | Devtools Arcadia <arcadia-devtools@yandex-team.ru> | 2022-02-07 18:08:42 +0300 |
---|---|---|
committer | Devtools Arcadia <arcadia-devtools@mous.vla.yp-c.yandex.net> | 2022-02-07 18:08:42 +0300 |
commit | 1110808a9d39d4b808aef724c861a2e1a38d2a69 (patch) | |
tree | e26c9fed0de5d9873cce7e00bc214573dc2195b7 /library/cpp/lwtrace/perf.h | |
download | ydb-1110808a9d39d4b808aef724c861a2e1a38d2a69.tar.gz |
intermediate changes
ref:cde9a383711a11544ce7e107a78147fb96cc4029
Diffstat (limited to 'library/cpp/lwtrace/perf.h')
-rw-r--r-- | library/cpp/lwtrace/perf.h | 63 |
1 files changed, 63 insertions, 0 deletions
diff --git a/library/cpp/lwtrace/perf.h b/library/cpp/lwtrace/perf.h new file mode 100644 index 0000000000..d535247196 --- /dev/null +++ b/library/cpp/lwtrace/perf.h @@ -0,0 +1,63 @@ +#pragma once + +#include <util/system/types.h> +#include <util/thread/singleton.h> + +namespace NLWTrace { + struct TProbe; + + class TCpuTracker { + private: + const ui64 MinReportPeriod; + + // State + bool Reporting = false; + ui64 LastTs = 0; + ui64 LastReportTs = 0; + + // Statistics + ui64 MaxCycles; + const TProbe* MaxProbe; + ui64 MinCycles; + ui64 ProbeCycles; + ui64 Count; + + public: + TCpuTracker(); + void Enter(); + void Exit(const TProbe* Probe); + static TCpuTracker* TlsInstance() { + struct TCpuTrackerkHolder { + TCpuTracker Tracker; + }; + return &FastTlsSingletonWithPriority<TCpuTrackerkHolder, 4>()->Tracker; + } + + private: + void AddStats(const TProbe* probe, ui64 cycles); + void ResetStats(); + void Report(); + void ReportNotReentrant(); + static double MilliSeconds(ui64 cycles); + }; + + class TScopedThreadCpuTracker { + private: + const TProbe* Probe; + TCpuTracker* Tracker; + + public: + template <class T> + explicit TScopedThreadCpuTracker(const T& probe) + : Probe(&probe.Probe) + , Tracker(TCpuTracker::TlsInstance()) + { + Tracker->Enter(); + } + + ~TScopedThreadCpuTracker() { + Tracker->Exit(Probe); + } + }; + +} |