xref: /aosp_15_r20/system/core/libutils/StopWatch.cpp (revision 00c7fec1bb09f3284aad6a6f96d2f63dfc3650ad)
1*00c7fec1SAndroid Build Coastguard Worker /*
2*00c7fec1SAndroid Build Coastguard Worker  * Copyright (C) 2005 The Android Open Source Project
3*00c7fec1SAndroid Build Coastguard Worker  *
4*00c7fec1SAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*00c7fec1SAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*00c7fec1SAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*00c7fec1SAndroid Build Coastguard Worker  *
8*00c7fec1SAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*00c7fec1SAndroid Build Coastguard Worker  *
10*00c7fec1SAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*00c7fec1SAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*00c7fec1SAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*00c7fec1SAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*00c7fec1SAndroid Build Coastguard Worker  * limitations under the License.
15*00c7fec1SAndroid Build Coastguard Worker  */
16*00c7fec1SAndroid Build Coastguard Worker 
17*00c7fec1SAndroid Build Coastguard Worker #define LOG_TAG "StopWatch"
18*00c7fec1SAndroid Build Coastguard Worker 
19*00c7fec1SAndroid Build Coastguard Worker #include <utils/StopWatch.h>
20*00c7fec1SAndroid Build Coastguard Worker 
21*00c7fec1SAndroid Build Coastguard Worker #include <inttypes.h>
22*00c7fec1SAndroid Build Coastguard Worker 
23*00c7fec1SAndroid Build Coastguard Worker #include <log/log.h>
24*00c7fec1SAndroid Build Coastguard Worker 
25*00c7fec1SAndroid Build Coastguard Worker namespace android {
26*00c7fec1SAndroid Build Coastguard Worker 
StopWatch(const char * name,int clock)27*00c7fec1SAndroid Build Coastguard Worker StopWatch::StopWatch(const char* name, int clock) : mName(name), mClock(clock) {
28*00c7fec1SAndroid Build Coastguard Worker     reset();
29*00c7fec1SAndroid Build Coastguard Worker }
30*00c7fec1SAndroid Build Coastguard Worker 
~StopWatch()31*00c7fec1SAndroid Build Coastguard Worker StopWatch::~StopWatch() {
32*00c7fec1SAndroid Build Coastguard Worker     ALOGD("StopWatch %s (us): %" PRId64 " ", name(), ns2us(elapsedTime()));
33*00c7fec1SAndroid Build Coastguard Worker }
34*00c7fec1SAndroid Build Coastguard Worker 
name() const35*00c7fec1SAndroid Build Coastguard Worker const char* StopWatch::name() const {
36*00c7fec1SAndroid Build Coastguard Worker     return mName;
37*00c7fec1SAndroid Build Coastguard Worker }
38*00c7fec1SAndroid Build Coastguard Worker 
elapsedTime() const39*00c7fec1SAndroid Build Coastguard Worker nsecs_t StopWatch::elapsedTime() const {
40*00c7fec1SAndroid Build Coastguard Worker     return systemTime(mClock) - mStartTime;
41*00c7fec1SAndroid Build Coastguard Worker }
42*00c7fec1SAndroid Build Coastguard Worker 
reset()43*00c7fec1SAndroid Build Coastguard Worker void StopWatch::reset() {
44*00c7fec1SAndroid Build Coastguard Worker     mStartTime = systemTime(mClock);
45*00c7fec1SAndroid Build Coastguard Worker }
46*00c7fec1SAndroid Build Coastguard Worker 
47*00c7fec1SAndroid Build Coastguard Worker }  // namespace android
48