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