#pragma once #include #include #include "test/common/utils.h" namespace megdnn { namespace test { class CUTimer { public: CUTimer(cudaStream_t& stream, cudaEvent_t& evt0, cudaEvent_t& evt1) : m_stream{stream}, m_evt0{evt0}, m_evt1{evt1} { reset(); } void reset() { m_started = false; m_stopped = false; } void start() { megdnn_assert(!m_started); megdnn_assert(!m_stopped); m_started = true; cudaProfilerStart(); cudaEventRecord(m_evt0, m_stream); } void stop() { megdnn_assert(m_started); megdnn_assert(!m_stopped); m_stopped = true; cudaEventRecord(m_evt1, m_stream); cudaProfilerStop(); } size_t get_time_in_us() const { cudaStreamSynchronize(m_stream); float t = -1; cudaEventElapsedTime(&t, m_evt0, m_evt1); return static_cast(t * 1e3); } private: bool m_started, m_stopped; size_t m_start_point, m_stop_point; cudaStream_t& m_stream; cudaEvent_t &m_evt0, &m_evt1; }; } // namespace test } // namespace megdnn // vim: syntax=cpp.doxygen