1*8f0ba417SAndroid Build Coastguard Worker /* 2*8f0ba417SAndroid Build Coastguard Worker * Copyright (C) 2017 The Android Open Source Project 3*8f0ba417SAndroid Build Coastguard Worker * 4*8f0ba417SAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License"); 5*8f0ba417SAndroid Build Coastguard Worker * you may not use this file except in compliance with the License. 6*8f0ba417SAndroid Build Coastguard Worker * You may obtain a copy of the License at 7*8f0ba417SAndroid Build Coastguard Worker * 8*8f0ba417SAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0 9*8f0ba417SAndroid Build Coastguard Worker * 10*8f0ba417SAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software 11*8f0ba417SAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS, 12*8f0ba417SAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13*8f0ba417SAndroid Build Coastguard Worker * See the License for the specific language governing permissions and 14*8f0ba417SAndroid Build Coastguard Worker * limitations under the License. 15*8f0ba417SAndroid Build Coastguard Worker */ 16*8f0ba417SAndroid Build Coastguard Worker 17*8f0ba417SAndroid Build Coastguard Worker #include "android-base/chrono_utils.h" 18*8f0ba417SAndroid Build Coastguard Worker 19*8f0ba417SAndroid Build Coastguard Worker #include <time.h> 20*8f0ba417SAndroid Build Coastguard Worker 21*8f0ba417SAndroid Build Coastguard Worker namespace android { 22*8f0ba417SAndroid Build Coastguard Worker namespace base { 23*8f0ba417SAndroid Build Coastguard Worker now()24*8f0ba417SAndroid Build Coastguard Workerboot_clock::time_point boot_clock::now() { 25*8f0ba417SAndroid Build Coastguard Worker #ifdef __linux__ 26*8f0ba417SAndroid Build Coastguard Worker timespec ts; 27*8f0ba417SAndroid Build Coastguard Worker clock_gettime(CLOCK_BOOTTIME, &ts); 28*8f0ba417SAndroid Build Coastguard Worker return boot_clock::time_point(std::chrono::seconds(ts.tv_sec) + 29*8f0ba417SAndroid Build Coastguard Worker std::chrono::nanoseconds(ts.tv_nsec)); 30*8f0ba417SAndroid Build Coastguard Worker #else 31*8f0ba417SAndroid Build Coastguard Worker // Darwin and Windows do not support clock_gettime. 32*8f0ba417SAndroid Build Coastguard Worker return boot_clock::time_point(); 33*8f0ba417SAndroid Build Coastguard Worker #endif // __linux__ 34*8f0ba417SAndroid Build Coastguard Worker } 35*8f0ba417SAndroid Build Coastguard Worker operator <<(std::ostream & os,const Timer & t)36*8f0ba417SAndroid Build Coastguard Workerstd::ostream& operator<<(std::ostream& os, const Timer& t) { 37*8f0ba417SAndroid Build Coastguard Worker os << t.duration().count() << "ms"; 38*8f0ba417SAndroid Build Coastguard Worker return os; 39*8f0ba417SAndroid Build Coastguard Worker } 40*8f0ba417SAndroid Build Coastguard Worker 41*8f0ba417SAndroid Build Coastguard Worker } // namespace base 42*8f0ba417SAndroid Build Coastguard Worker } // namespace android 43