xenia/third_party/crunch/crnlib/lzham_timer.h

100 lines
3.0 KiB
C++

// File: lzham_timer.h
// See Copyright Notice and license at the end of include/lzham.h
#pragma once
namespace lzham
{
typedef unsigned long long timer_ticks;
class lzham_timer
{
public:
lzham_timer();
lzham_timer(timer_ticks start_ticks);
void start();
void start(timer_ticks start_ticks);
void stop();
double get_elapsed_secs() const;
inline double get_elapsed_ms() const { return get_elapsed_secs() * 1000.0f; }
timer_ticks get_elapsed_us() const;
static void init();
static inline timer_ticks get_ticks_per_sec() { return g_freq; }
static timer_ticks get_init_ticks();
static timer_ticks get_ticks();
static double ticks_to_secs(timer_ticks ticks);
static inline double ticks_to_ms(timer_ticks ticks) { return ticks_to_secs(ticks) * 1000.0f; }
static inline double get_secs() { return ticks_to_secs(get_ticks()); }
static inline double get_ms() { return ticks_to_ms(get_ticks()); }
private:
static timer_ticks g_init_ticks;
static timer_ticks g_freq;
static double g_inv_freq;
timer_ticks m_start_time;
timer_ticks m_stop_time;
bool m_started : 1;
bool m_stopped : 1;
};
enum var_args_t { cVarArgs };
#if LZHAM_PERF_SECTIONS
class scoped_perf_section
{
public:
inline scoped_perf_section() :
m_start_ticks(lzham_timer::get_ticks())
{
m_name[0] = '?';
m_name[1] = '\0';
}
inline scoped_perf_section(const char *pName) :
m_start_ticks(lzham_timer::get_ticks())
{
strcpy_s(m_name, pName);
lzham_buffered_printf("Thread: 0x%08X, BEGIN Time: %3.3fms, Section: %s\n", GetCurrentThreadId(), lzham_timer::ticks_to_ms(m_start_ticks), m_name);
}
inline scoped_perf_section(var_args_t, const char *pName, ...) :
m_start_ticks(lzham_timer::get_ticks())
{
va_list args;
va_start(args, pName);
vsprintf_s(m_name, sizeof(m_name), pName, args);
va_end(args);
lzham_buffered_printf("Thread: 0x%08X, BEGIN Time: %3.3fms, Section: %s\n", GetCurrentThreadId(), lzham_timer::ticks_to_ms(m_start_ticks), m_name);
}
inline ~scoped_perf_section()
{
double end_ms = lzham_timer::get_ms();
double start_ms = lzham_timer::ticks_to_ms(m_start_ticks);
lzham_buffered_printf("Thread: 0x%08X, END Time: %3.3fms, Total: %3.3fms, Section: %s\n", GetCurrentThreadId(), end_ms, end_ms - start_ms, m_name);
}
private:
char m_name[64];
timer_ticks m_start_ticks;
};
#else
class scoped_perf_section
{
public:
inline scoped_perf_section() { }
inline scoped_perf_section(const char *pName) { (void)pName; }
inline scoped_perf_section(var_args_t, const char *pName, ...) { (void)pName; }
};
#endif // LZHAM_PERF_SECTIONS
} // namespace lzham