1094332d3Sopenharmony_ci/*
2094332d3Sopenharmony_ci * Copyright (c) 2024 Huawei Device Co., Ltd.
3094332d3Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
4094332d3Sopenharmony_ci * you may not use this file except in compliance with the License.
5094332d3Sopenharmony_ci * You may obtain a copy of the License at
6094332d3Sopenharmony_ci *
7094332d3Sopenharmony_ci *     http://www.apache.org/licenses/LICENSE-2.0
8094332d3Sopenharmony_ci *
9094332d3Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software
10094332d3Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
11094332d3Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12094332d3Sopenharmony_ci * See the License for the specific language governing permissions and
13094332d3Sopenharmony_ci * limitations under the License.
14094332d3Sopenharmony_ci */
15094332d3Sopenharmony_ci
16094332d3Sopenharmony_ci#include "display_buffer_dfx.h"
17094332d3Sopenharmony_ci#include <hdf_log.h>
18094332d3Sopenharmony_ci
19094332d3Sopenharmony_ci#define TIME_1000 1000
20094332d3Sopenharmony_ci#define TIME_10 10
21094332d3Sopenharmony_ci#define HICOLLIE_TIMEOUT 10
22094332d3Sopenharmony_ci
23094332d3Sopenharmony_cinamespace OHOS {
24094332d3Sopenharmony_cinamespace HDI {
25094332d3Sopenharmony_cinamespace Display {
26094332d3Sopenharmony_cinamespace Buffer {
27094332d3Sopenharmony_cinamespace V1_0 {
28094332d3Sopenharmony_ciDisplayBufferDfx::DisplayBufferDfx(const std::string& name)
29094332d3Sopenharmony_ci    : dfxName_(name),
30094332d3Sopenharmony_ci    timeId_(0),
31094332d3Sopenharmony_ci    flag_(false),
32094332d3Sopenharmony_ci    startTimeStamp({0, 0}),
33094332d3Sopenharmony_ci    stopTimeStamp({0, 0})
34094332d3Sopenharmony_ci{
35094332d3Sopenharmony_ci}
36094332d3Sopenharmony_ci
37094332d3Sopenharmony_ciDisplayBufferDfx::~DisplayBufferDfx()
38094332d3Sopenharmony_ci{
39094332d3Sopenharmony_ci    if (timeId_ != 0) {
40094332d3Sopenharmony_ci        CancelTimer();
41094332d3Sopenharmony_ci    }
42094332d3Sopenharmony_ci    if (flag_) {
43094332d3Sopenharmony_ci        StopTimeStamp();
44094332d3Sopenharmony_ci    }
45094332d3Sopenharmony_ci}
46094332d3Sopenharmony_ci
47094332d3Sopenharmony_civoid DisplayBufferDfx::SetTimer()
48094332d3Sopenharmony_ci{
49094332d3Sopenharmony_ci#ifdef DISPLAY_HICOLLIE_ENABLE
50094332d3Sopenharmony_ci    timeId_ = HiviewDFX::XCollie::GetInstance().SetTimer(dfxName_, HICOLLIE_TIMEOUT, nullptr, nullptr,
51094332d3Sopenharmony_ci        HiviewDFX::XCOLLIE_FLAG_LOG | HiviewDFX::XCOLLIE_FLAG_RECOVERY);
52094332d3Sopenharmony_ci#endif
53094332d3Sopenharmony_ci}
54094332d3Sopenharmony_ci
55094332d3Sopenharmony_civoid DisplayBufferDfx::CancelTimer()
56094332d3Sopenharmony_ci{
57094332d3Sopenharmony_ci#ifdef DISPLAY_HICOLLIE_ENABLE
58094332d3Sopenharmony_ci    HiviewDFX::XCollie::GetInstance().CancelTimer(timeId_);
59094332d3Sopenharmony_ci#endif
60094332d3Sopenharmony_ci}
61094332d3Sopenharmony_ci
62094332d3Sopenharmony_civoid DisplayBufferDfx::StartTimeStamp()
63094332d3Sopenharmony_ci{
64094332d3Sopenharmony_ci    gettimeofday(&startTimeStamp, nullptr);
65094332d3Sopenharmony_ci    flag_ = true;
66094332d3Sopenharmony_ci}
67094332d3Sopenharmony_ci
68094332d3Sopenharmony_civoid DisplayBufferDfx::StopTimeStamp()
69094332d3Sopenharmony_ci{
70094332d3Sopenharmony_ci    gettimeofday(&stopTimeStamp, nullptr);
71094332d3Sopenharmony_ci    int32_t runTime = (int32_t)((stopTimeStamp.tv_sec - startTimeStamp.tv_sec) * TIME_1000 +
72094332d3Sopenharmony_ci        (stopTimeStamp.tv_usec - startTimeStamp.tv_usec) / TIME_1000);
73094332d3Sopenharmony_ci    if (runTime > TIME_10) {
74094332d3Sopenharmony_ci        HDF_LOGW("run %{public}s over time, [%{public}d]ms", dfxName_.c_str(), runTime);
75094332d3Sopenharmony_ci    }
76094332d3Sopenharmony_ci    flag_ = false;
77094332d3Sopenharmony_ci}
78094332d3Sopenharmony_ci} // namespace V1_0
79094332d3Sopenharmony_ci} // namespace Buffer
80094332d3Sopenharmony_ci} // namespace Display
81094332d3Sopenharmony_ci} // namespace HDI
82094332d3Sopenharmony_ci} // namespace OHOS