14514f5e3Sopenharmony_ci/*
24514f5e3Sopenharmony_ci * Copyright (c) 2021-2023 Huawei Device Co., Ltd.
34514f5e3Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
44514f5e3Sopenharmony_ci * you may not use this file except in compliance with the License.
54514f5e3Sopenharmony_ci * You may obtain a copy of the License at
64514f5e3Sopenharmony_ci *
74514f5e3Sopenharmony_ci *     http://www.apache.org/licenses/LICENSE-2.0
84514f5e3Sopenharmony_ci *
94514f5e3Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software
104514f5e3Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
114514f5e3Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
124514f5e3Sopenharmony_ci * See the License for the specific language governing permissions and
134514f5e3Sopenharmony_ci * limitations under the License.
144514f5e3Sopenharmony_ci */
154514f5e3Sopenharmony_ci
164514f5e3Sopenharmony_ci#ifndef ECMASCRIPT_DFX_VMSTAT_CALLER_STAT_H
174514f5e3Sopenharmony_ci#define ECMASCRIPT_DFX_VMSTAT_CALLER_STAT_H
184514f5e3Sopenharmony_ci
194514f5e3Sopenharmony_ci#include <cstdint>
204514f5e3Sopenharmony_ci#include <cstring>
214514f5e3Sopenharmony_ci#include <ctime>
224514f5e3Sopenharmony_ci
234514f5e3Sopenharmony_ci#include "ecmascript/mem/c_string.h"
244514f5e3Sopenharmony_ci
254514f5e3Sopenharmony_ci#include "libpandabase/macros.h"
264514f5e3Sopenharmony_ci
274514f5e3Sopenharmony_cinamespace panda::ecmascript {
284514f5e3Sopenharmony_ciclass EcmaRuntimeStat;
294514f5e3Sopenharmony_ciclass PandaRuntimeCallerStat {
304514f5e3Sopenharmony_cipublic:
314514f5e3Sopenharmony_ci    // NOLINTNEXTLINE(modernize-pass-by-value)
324514f5e3Sopenharmony_ci    explicit PandaRuntimeCallerStat(const CString &name) : name_(name) {}
334514f5e3Sopenharmony_ci    PandaRuntimeCallerStat() = default;
344514f5e3Sopenharmony_ci    virtual ~PandaRuntimeCallerStat() = default;
354514f5e3Sopenharmony_ci
364514f5e3Sopenharmony_ci    DEFAULT_NOEXCEPT_MOVE_SEMANTIC(PandaRuntimeCallerStat);
374514f5e3Sopenharmony_ci    DEFAULT_COPY_SEMANTIC(PandaRuntimeCallerStat);
384514f5e3Sopenharmony_ci
394514f5e3Sopenharmony_ci    void UpdateState(uint64_t elapsed)
404514f5e3Sopenharmony_ci    {
414514f5e3Sopenharmony_ci        totalCount_++;
424514f5e3Sopenharmony_ci        totalTime_ += elapsed;
434514f5e3Sopenharmony_ci        maxTime_ = elapsed < maxTime_ ? maxTime_ : elapsed;
444514f5e3Sopenharmony_ci    }
454514f5e3Sopenharmony_ci    const char *Name() const
464514f5e3Sopenharmony_ci    {
474514f5e3Sopenharmony_ci        return name_.c_str();
484514f5e3Sopenharmony_ci    }
494514f5e3Sopenharmony_ci    CString GetHeaderOfName() const
504514f5e3Sopenharmony_ci    {
514514f5e3Sopenharmony_ci        CString::size_type index = name_.find_first_of("::");
524514f5e3Sopenharmony_ci        if (index == CString::npos) {
534514f5e3Sopenharmony_ci            return CString("");
544514f5e3Sopenharmony_ci        }
554514f5e3Sopenharmony_ci        CString header = name_.substr(0, index);
564514f5e3Sopenharmony_ci        return header;
574514f5e3Sopenharmony_ci    }
584514f5e3Sopenharmony_ci    uint64_t TotalCount() const
594514f5e3Sopenharmony_ci    {
604514f5e3Sopenharmony_ci        return totalCount_;
614514f5e3Sopenharmony_ci    }
624514f5e3Sopenharmony_ci    uint64_t TotalTime() const
634514f5e3Sopenharmony_ci    {
644514f5e3Sopenharmony_ci        return totalTime_;
654514f5e3Sopenharmony_ci    }
664514f5e3Sopenharmony_ci    uint64_t MaxTime() const
674514f5e3Sopenharmony_ci    {
684514f5e3Sopenharmony_ci        return maxTime_;
694514f5e3Sopenharmony_ci    }
704514f5e3Sopenharmony_ci
714514f5e3Sopenharmony_ci    void Reset()
724514f5e3Sopenharmony_ci    {
734514f5e3Sopenharmony_ci        totalCount_ = 0;
744514f5e3Sopenharmony_ci        totalTime_ = 0;
754514f5e3Sopenharmony_ci        maxTime_ = 0;
764514f5e3Sopenharmony_ci    }
774514f5e3Sopenharmony_ci
784514f5e3Sopenharmony_ciprivate:
794514f5e3Sopenharmony_ci    CString name_ {};
804514f5e3Sopenharmony_ci    uint64_t totalCount_ {0};
814514f5e3Sopenharmony_ci    uint64_t totalTime_ {0};
824514f5e3Sopenharmony_ci    uint64_t maxTime_ {0};
834514f5e3Sopenharmony_ci};
844514f5e3Sopenharmony_ci
854514f5e3Sopenharmony_ciclass PandaRuntimeTimer {
864514f5e3Sopenharmony_cipublic:
874514f5e3Sopenharmony_ci    void Start(PandaRuntimeCallerStat *callerStat, PandaRuntimeTimer *parent);
884514f5e3Sopenharmony_ci    inline static uint64_t Now()
894514f5e3Sopenharmony_ci    {
904514f5e3Sopenharmony_ci        struct timespec timeNow = {0, 0};
914514f5e3Sopenharmony_ci        clock_gettime(CLOCK_REALTIME, &timeNow);
924514f5e3Sopenharmony_ci        return timeNow.tv_sec * NANOSECONDSINSECOND + timeNow.tv_nsec;
934514f5e3Sopenharmony_ci    }
944514f5e3Sopenharmony_ci
954514f5e3Sopenharmony_ci    uint64_t Elapsed() const
964514f5e3Sopenharmony_ci    {
974514f5e3Sopenharmony_ci        return elapsed_;
984514f5e3Sopenharmony_ci    }
994514f5e3Sopenharmony_ci
1004514f5e3Sopenharmony_ci    inline bool IsStarted() const
1014514f5e3Sopenharmony_ci    {
1024514f5e3Sopenharmony_ci        return start_ != 0;
1034514f5e3Sopenharmony_ci    }
1044514f5e3Sopenharmony_ci
1054514f5e3Sopenharmony_ci    inline void SetParent(PandaRuntimeTimer *parent)
1064514f5e3Sopenharmony_ci    {
1074514f5e3Sopenharmony_ci        parent_ = parent;
1084514f5e3Sopenharmony_ci    }
1094514f5e3Sopenharmony_ci
1104514f5e3Sopenharmony_ci    void Snapshot();
1114514f5e3Sopenharmony_ci
1124514f5e3Sopenharmony_ci    inline void UpdateCallerState()
1134514f5e3Sopenharmony_ci    {
1144514f5e3Sopenharmony_ci        callerStat_->UpdateState(elapsed_);
1154514f5e3Sopenharmony_ci    }
1164514f5e3Sopenharmony_ci
1174514f5e3Sopenharmony_ciprivate:
1184514f5e3Sopenharmony_ci    static constexpr uint64_t NANOSECONDSINSECOND = 1000000000;
1194514f5e3Sopenharmony_ci    PandaRuntimeTimer *Stop();
1204514f5e3Sopenharmony_ci    void Pause(uint64_t now);
1214514f5e3Sopenharmony_ci    void Resume(uint64_t now);
1224514f5e3Sopenharmony_ci    PandaRuntimeCallerStat *callerStat_ {nullptr};
1234514f5e3Sopenharmony_ci    PandaRuntimeTimer *parent_ {nullptr};
1244514f5e3Sopenharmony_ci    uint64_t start_ {0};
1254514f5e3Sopenharmony_ci    uint64_t elapsed_ {0};
1264514f5e3Sopenharmony_ci
1274514f5e3Sopenharmony_ci    friend class EcmaRuntimeStat;
1284514f5e3Sopenharmony_ci    friend class FunctionCallTimer;
1294514f5e3Sopenharmony_ci};
1304514f5e3Sopenharmony_ci}  // namespace panda::ecmascript
1314514f5e3Sopenharmony_ci#endif // ECMASCRIPT_DFX_VMSTAT_CALLER_STAT_H
132