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