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 WorkerStopWatch::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 WorkerStopWatch::~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 Workerconst 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 Workernsecs_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 Workervoid 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