| /* |
| * Copyright (C) 2015, Samsung Electronics Co. LTD |
| * |
| * Licensed under the Apache License, Version 2.0 (the "License"); |
| * you may not use this file except in compliance with the License. |
| * You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| |
| #ifndef EXYNOS_VISION_AUTO_TIMER_H |
| #define EXYNOS_VISION_AUTO_TIMER_H |
| |
| #include <stdio.h> |
| #include <string.h> |
| #include <stdlib.h> |
| |
| #include <utils/Timers.h> |
| #include <utils/threads.h> |
| |
| namespace android { |
| |
| static uint64_t convertTimeMs(struct timeval *time) |
| { |
| return ((nsecs_t)time->tv_sec) * 1000LL + ((nsecs_t)time->tv_usec) / 1000LL; |
| } |
| |
| static uint64_t convertTimeUs(struct timeval *time) |
| { |
| return ((nsecs_t)time->tv_sec) * 1000000LL + ((nsecs_t)time->tv_usec); |
| } |
| |
| class ExynosVisionDurationTimer { |
| public: |
| ExynosVisionDurationTimer() |
| { |
| memset(&m_startTime, 0x00, sizeof(struct timeval)); |
| memset(&m_stopTime, 0x00, sizeof(struct timeval)); |
| } |
| ~ExynosVisionDurationTimer() {} |
| |
| void start() |
| { |
| gettimeofday(&m_startTime, NULL); |
| }; |
| |
| void stop() |
| { |
| gettimeofday(&m_stopTime, NULL); |
| }; |
| |
| static uint64_t getTimeMs() |
| { |
| struct timeval m_Time; |
| gettimeofday(&m_Time, NULL); |
| |
| return ((nsecs_t)m_Time.tv_sec) * 1000LL + ((nsecs_t)m_Time.tv_usec) / 1000LL; |
| } |
| |
| static uint64_t getTimeUs() |
| { |
| struct timeval m_Time; |
| gettimeofday(&m_Time, NULL); |
| |
| return ((nsecs_t)m_Time.tv_sec) * 1000000LL + ((nsecs_t)m_Time.tv_usec); |
| } |
| |
| uint64_t durationMsecs() const |
| { |
| nsecs_t stop = ((nsecs_t)m_stopTime.tv_sec) * 1000LL + ((nsecs_t)m_stopTime.tv_usec) / 1000LL; |
| nsecs_t start = ((nsecs_t)m_startTime.tv_sec) * 1000LL + ((nsecs_t)m_startTime.tv_usec) / 1000LL; |
| |
| return stop - start; |
| }; |
| |
| uint64_t durationUsecs() const |
| { |
| nsecs_t stop = ((nsecs_t)m_stopTime.tv_sec) * 1000000LL + ((nsecs_t)m_stopTime.tv_usec); |
| nsecs_t start = ((nsecs_t)m_startTime.tv_sec) * 1000000LL + ((nsecs_t)m_startTime.tv_usec); |
| |
| return stop - start; |
| }; |
| |
| private: |
| struct timeval m_startTime; |
| struct timeval m_stopTime; |
| }; |
| |
| class ExynosVisionAutoTimer { |
| private: |
| ExynosVisionAutoTimer(void) |
| {} |
| |
| public: |
| inline ExynosVisionAutoTimer(char *strLog) |
| { |
| if (m_create(strLog) == false) |
| ALOGE("ERR(%s):m_create() fail", __func__); |
| } |
| |
| inline ExynosVisionAutoTimer(const char *strLog) |
| { |
| char *strTemp = (char*)strLog; |
| |
| if (m_create(strTemp) == false) |
| ALOGE("ERR(%s):m_create() fail", __func__); |
| } |
| |
| inline virtual ~ExynosVisionAutoTimer() |
| { |
| uint64_t durationTime; |
| |
| m_timer.stop(); |
| |
| durationTime = m_timer.durationMsecs(); |
| |
| if (m_logStr) { |
| ALOGD("DEBUG:duration time(%5d msec):(%s)", |
| (int)durationTime, m_logStr); |
| } else { |
| ALOGD("DEBUG:duration time(%5d msec):(NULL)", |
| (int)durationTime); |
| } |
| } |
| |
| private: |
| bool m_create(char *strLog) |
| { |
| m_logStr = strLog; |
| |
| m_timer.start(); |
| |
| return true; |
| } |
| |
| private: |
| ExynosVisionDurationTimer m_timer; |
| char *m_logStr; |
| }; |
| |
| }; /* namespace android */ |
| |
| #endif /* EXYNOS_VISION_AUTO_TIMER_H */ |