prime/include/Kyoto/Basics/CStopwatch.hpp

54 lines
1.2 KiB
C++
Raw Normal View History

#ifndef _CSTOPWATCH
#define _CSTOPWATCH
#include "types.h"
#include "dolphin/os.h"
class CStopwatch {
public:
class CSWData {
public:
CSWData() : x0_timerFreq(0), x8_timerFreqO1M(0), x10_timerPeriod(0.f) {}
2022-09-22 06:03:09 +00:00
bool Initialize();
void Wait(float) const;
s64 GetTimerFreq() const { return x0_timerFreq; }
s64 GetTimerFreqO1M() const { return x8_timerFreqO1M; }
float GetTimerPeriod() const { return x10_timerPeriod; }
2022-04-11 22:42:08 +00:00
s64 GetCPUCycles() const { return OSGetTime(); }
private:
s64 x0_timerFreq;
s64 x8_timerFreqO1M;
float x10_timerPeriod;
};
2022-04-11 22:42:08 +00:00
CStopwatch() : x0_startTime(mData.GetCPUCycles()) {}
2022-09-22 06:03:09 +00:00
static bool InitGlobalTimer();
static CStopwatch& GetGlobalTimerObj();
inline void Reset() {
if (mData.GetTimerFreq() == 0) {
mData.Initialize();
}
2022-04-11 22:42:08 +00:00
x0_startTime = mData.GetCPUCycles();
}
inline float GetElapsedTime() const {
2022-09-18 06:05:46 +00:00
return (mData.GetCPUCycles() - x0_startTime) * mData.GetTimerPeriod();
}
inline s64 GetElapsedMicros() const {
return (mData.GetCPUCycles() - x0_startTime) / mData.GetTimerFreqO1M();
}
static void Wait(float);
private:
static CSWData mData;
static CStopwatch mGlobalTimer;
s64 x0_startTime;
};
#endif // _CSTOPWATCH