1fa7767c5Sopenharmony_ci/* 2fa7767c5Sopenharmony_ci * Copyright (c) 2023-2023 Huawei Device Co., Ltd. 3fa7767c5Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 4fa7767c5Sopenharmony_ci * you may not use this file except in compliance with the License. 5fa7767c5Sopenharmony_ci * You may obtain a copy of the License at 6fa7767c5Sopenharmony_ci * 7fa7767c5Sopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 8fa7767c5Sopenharmony_ci * 9fa7767c5Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software 10fa7767c5Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 11fa7767c5Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12fa7767c5Sopenharmony_ci * See the License for the specific language governing permissions and 13fa7767c5Sopenharmony_ci * limitations under the License. 14fa7767c5Sopenharmony_ci */ 15fa7767c5Sopenharmony_ci 16fa7767c5Sopenharmony_ci#define HST_LOG_TAG "SteadyClock" 17fa7767c5Sopenharmony_ci 18fa7767c5Sopenharmony_ci#include "common/log.h" 19fa7767c5Sopenharmony_ci#include "osal/utils/steady_clock.h" 20fa7767c5Sopenharmony_ci 21fa7767c5Sopenharmony_cinamespace { 22fa7767c5Sopenharmony_ciconstexpr OHOS::HiviewDFX::HiLogLabel LABEL = { LOG_CORE, LOG_DOMAIN_FOUNDATION, "SteadyClock" }; 23fa7767c5Sopenharmony_ci} 24fa7767c5Sopenharmony_ci 25fa7767c5Sopenharmony_cinamespace OHOS { 26fa7767c5Sopenharmony_cinamespace Media { 27fa7767c5Sopenharmony_cinamespace { 28fa7767c5Sopenharmony_ciusing namespace std::chrono; 29fa7767c5Sopenharmony_ci} 30fa7767c5Sopenharmony_ci 31fa7767c5Sopenharmony_ciint64_t SteadyClock::GetCurrentTimeMs() 32fa7767c5Sopenharmony_ci{ 33fa7767c5Sopenharmony_ci return duration_cast<milliseconds>(high_resolution_clock::now().time_since_epoch()).count(); 34fa7767c5Sopenharmony_ci} 35fa7767c5Sopenharmony_ci 36fa7767c5Sopenharmony_ciint64_t SteadyClock::GetCurrentTimeNanoSec() 37fa7767c5Sopenharmony_ci{ 38fa7767c5Sopenharmony_ci return duration_cast<nanoseconds>(high_resolution_clock::now().time_since_epoch()).count(); 39fa7767c5Sopenharmony_ci} 40fa7767c5Sopenharmony_ciSteadyClock::SteadyClock() : begin_(high_resolution_clock::now()) 41fa7767c5Sopenharmony_ci{ 42fa7767c5Sopenharmony_ci MEDIA_LOG_D("ctor called."); 43fa7767c5Sopenharmony_ci} 44fa7767c5Sopenharmony_ci 45fa7767c5Sopenharmony_civoid SteadyClock::Reset() 46fa7767c5Sopenharmony_ci{ 47fa7767c5Sopenharmony_ci MEDIA_LOG_D("Reset timer."); 48fa7767c5Sopenharmony_ci begin_ = high_resolution_clock::now(); 49fa7767c5Sopenharmony_ci} 50fa7767c5Sopenharmony_ci 51fa7767c5Sopenharmony_ciint64_t SteadyClock::ElapsedMilliseconds() 52fa7767c5Sopenharmony_ci{ 53fa7767c5Sopenharmony_ci return duration_cast<milliseconds>(high_resolution_clock::now() - begin_).count(); 54fa7767c5Sopenharmony_ci} 55fa7767c5Sopenharmony_ci 56fa7767c5Sopenharmony_ciint64_t SteadyClock::ElapsedMicroseconds() 57fa7767c5Sopenharmony_ci{ 58fa7767c5Sopenharmony_ci return duration_cast<microseconds>(high_resolution_clock::now() - begin_).count(); 59fa7767c5Sopenharmony_ci} 60fa7767c5Sopenharmony_ci 61fa7767c5Sopenharmony_ciint64_t SteadyClock::ElapsedNanoseconds() 62fa7767c5Sopenharmony_ci{ 63fa7767c5Sopenharmony_ci return duration_cast<nanoseconds>(high_resolution_clock::now() - begin_).count(); 64fa7767c5Sopenharmony_ci} 65fa7767c5Sopenharmony_ci 66fa7767c5Sopenharmony_ciint64_t SteadyClock::ElapsedSeconds() 67fa7767c5Sopenharmony_ci{ 68fa7767c5Sopenharmony_ci return duration_cast<seconds>(high_resolution_clock::now() - begin_).count(); 69fa7767c5Sopenharmony_ci} 70fa7767c5Sopenharmony_ci} // namespace Media 71fa7767c5Sopenharmony_ci} // namespace OHOS 72