2020-12-15 07:46:46 +00:00
|
|
|
// hrtimer.h - originally written and placed in the public domain by Wei Dai
|
|
|
|
|
|
|
|
/// \file hrtimer.h
|
|
|
|
/// \brief Classes for timers
|
|
|
|
|
2015-11-05 06:59:46 +00:00
|
|
|
#ifndef CRYPTOPP_HRTIMER_H
|
|
|
|
#define CRYPTOPP_HRTIMER_H
|
|
|
|
|
|
|
|
#include "config.h"
|
2016-05-03 04:23:05 +00:00
|
|
|
|
|
|
|
#if !defined(HIGHRES_TIMER_AVAILABLE) || (defined(CRYPTOPP_WIN32_AVAILABLE) && !defined(THREAD_TIMER_AVAILABLE))
|
2015-11-05 06:59:46 +00:00
|
|
|
#include <time.h>
|
|
|
|
#endif
|
|
|
|
|
|
|
|
NAMESPACE_BEGIN(CryptoPP)
|
|
|
|
|
|
|
|
#ifdef HIGHRES_TIMER_AVAILABLE
|
2020-12-15 08:03:57 +00:00
|
|
|
/// \brief TimerWord is a 64-bit word
|
2015-11-05 06:59:46 +00:00
|
|
|
typedef word64 TimerWord;
|
|
|
|
#else
|
2020-12-15 08:03:57 +00:00
|
|
|
/// \brief TimerWord is a clock_t
|
2015-11-05 06:59:46 +00:00
|
|
|
typedef clock_t TimerWord;
|
|
|
|
#endif
|
|
|
|
|
2017-11-29 15:54:33 +00:00
|
|
|
/// \brief Base class for timers
|
2020-12-15 07:46:46 +00:00
|
|
|
/// \sa ThreadUserTimer, Timer
|
2015-11-05 06:59:46 +00:00
|
|
|
class CRYPTOPP_DLL CRYPTOPP_NO_VTABLE TimerBase
|
|
|
|
{
|
|
|
|
public:
|
2020-12-15 07:46:46 +00:00
|
|
|
/// \brief Unit of measure
|
2020-12-15 08:03:57 +00:00
|
|
|
/// \details Unit selects the unit of measure as returned by functions
|
|
|
|
/// ElapsedTimeAsDouble() and ElapsedTime().
|
|
|
|
/// \sa ElapsedTimeAsDouble, ElapsedTime
|
|
|
|
enum Unit {
|
|
|
|
/// \brief Timer unit is seconds
|
|
|
|
/// \details All timers support seconds
|
|
|
|
SECONDS = 0,
|
|
|
|
/// \brief Timer unit is milliseconds
|
|
|
|
/// \details All timers support milliseconds
|
|
|
|
MILLISECONDS,
|
|
|
|
/// \brief Timer unit is microseconds
|
|
|
|
/// \details The timer requires hardware support microseconds
|
|
|
|
MICROSECONDS,
|
|
|
|
/// \brief Timer unit is nanoseconds
|
|
|
|
/// \details The timer requires hardware support nanoseconds
|
|
|
|
NANOSECONDS
|
|
|
|
};
|
2020-12-15 07:46:46 +00:00
|
|
|
|
|
|
|
/// \brief Construct a TimerBase
|
|
|
|
/// \param unit the unit of measure
|
|
|
|
/// \param stuckAtZero flag
|
2015-11-18 20:32:28 +00:00
|
|
|
TimerBase(Unit unit, bool stuckAtZero)
|
|
|
|
: m_timerUnit(unit), m_stuckAtZero(stuckAtZero), m_started(false)
|
|
|
|
, m_start(0), m_last(0) {}
|
2015-11-05 06:59:46 +00:00
|
|
|
|
2020-12-15 07:46:46 +00:00
|
|
|
/// \brief Retrieve the current timer value
|
|
|
|
/// \return the current timer value
|
|
|
|
virtual TimerWord GetCurrentTimerValue() =0;
|
2015-11-05 06:59:46 +00:00
|
|
|
|
2020-12-15 07:46:46 +00:00
|
|
|
/// \brief Retrieve ticks per second
|
|
|
|
/// \return ticks per second
|
|
|
|
/// \details TicksPerSecond() is not the timer resolution. It is a
|
|
|
|
/// conversion factor into seconds.
|
|
|
|
virtual TimerWord TicksPerSecond() =0;
|
|
|
|
|
|
|
|
/// \brief Start the timer
|
2015-11-05 06:59:46 +00:00
|
|
|
void StartTimer();
|
2020-12-15 07:46:46 +00:00
|
|
|
|
|
|
|
/// \brief Retrieve the elapsed time
|
|
|
|
/// \return the elapsed time as a double
|
2020-12-15 08:03:57 +00:00
|
|
|
/// \details The return value of ElapsedTimeAsDouble() depends upon
|
|
|
|
/// the Unit selected during construction of the timer. For example,
|
|
|
|
/// if <tt>Unit = SECONDS</tt> and ElapsedTimeAsDouble() returns 3,
|
|
|
|
/// then the timer has run for 3 seconds. If
|
|
|
|
/// <tt>Unit = MILLISECONDS</tt> and ElapsedTimeAsDouble() returns
|
|
|
|
/// 3000, then the timer has run for 3 seconds.
|
|
|
|
/// \sa Unit, ElapsedTime
|
2015-11-05 06:59:46 +00:00
|
|
|
double ElapsedTimeAsDouble();
|
2020-12-15 07:46:46 +00:00
|
|
|
|
|
|
|
/// \brief Retrieve the elapsed time
|
|
|
|
/// \return the elapsed time as an unsigned long
|
2020-12-15 08:03:57 +00:00
|
|
|
/// \details The return value of ElapsedTime() depends upon the
|
|
|
|
/// Unit selected during construction of the timer. For example, if
|
|
|
|
/// <tt>Unit = SECONDS</tt> and ElapsedTime() returns 3, then
|
|
|
|
/// the timer has run for 3 seconds. If <tt>Unit = MILLISECONDS</tt>
|
|
|
|
/// and ElapsedTime() returns 3000, then the timer has run for 3
|
|
|
|
/// seconds.
|
|
|
|
/// \sa Unit, ElapsedTimeAsDouble
|
2015-11-05 06:59:46 +00:00
|
|
|
unsigned long ElapsedTime();
|
|
|
|
|
|
|
|
private:
|
|
|
|
double ConvertTo(TimerWord t, Unit unit);
|
|
|
|
|
|
|
|
Unit m_timerUnit; // HPUX workaround: m_unit is a system macro on HPUX
|
|
|
|
bool m_stuckAtZero, m_started;
|
|
|
|
TimerWord m_start, m_last;
|
|
|
|
};
|
|
|
|
|
2020-12-15 07:46:46 +00:00
|
|
|
/// \brief Measure CPU time spent executing instructions of this thread
|
|
|
|
/// \details ThreadUserTimer requires support of the OS. On Unix-based it
|
|
|
|
/// reports process time. On Windows NT or later desktops and servers it
|
|
|
|
/// reports thread times with performance counter precision.. On Windows
|
|
|
|
/// Phone and Windows Store it reports wall clock time with performance
|
|
|
|
/// counter precision. On all others it reports wall clock time.
|
|
|
|
/// \note ThreadUserTimer only works correctly on Windows NT or later
|
|
|
|
/// desktops and servers.
|
|
|
|
/// \sa Timer
|
2015-11-05 06:59:46 +00:00
|
|
|
class ThreadUserTimer : public TimerBase
|
|
|
|
{
|
|
|
|
public:
|
2020-12-15 07:46:46 +00:00
|
|
|
/// \brief Construct a ThreadUserTimer
|
|
|
|
/// \param unit the unit of measure
|
|
|
|
/// \param stuckAtZero flag
|
2016-05-03 04:23:05 +00:00
|
|
|
ThreadUserTimer(Unit unit = TimerBase::SECONDS, bool stuckAtZero = false) : TimerBase(unit, stuckAtZero) {}
|
2015-11-05 06:59:46 +00:00
|
|
|
TimerWord GetCurrentTimerValue();
|
|
|
|
TimerWord TicksPerSecond();
|
|
|
|
};
|
|
|
|
|
2020-12-15 07:46:46 +00:00
|
|
|
/// \brief High resolution timer
|
|
|
|
/// \sa ThreadUserTimer
|
2015-11-05 06:59:46 +00:00
|
|
|
class CRYPTOPP_DLL Timer : public TimerBase
|
|
|
|
{
|
|
|
|
public:
|
2020-12-15 07:46:46 +00:00
|
|
|
/// \brief Construct a Timer
|
|
|
|
/// \param unit the unit of measure
|
|
|
|
/// \param stuckAtZero flag
|
2015-11-05 06:59:46 +00:00
|
|
|
Timer(Unit unit = TimerBase::SECONDS, bool stuckAtZero = false) : TimerBase(unit, stuckAtZero) {}
|
|
|
|
TimerWord GetCurrentTimerValue();
|
|
|
|
TimerWord TicksPerSecond();
|
|
|
|
};
|
|
|
|
|
|
|
|
NAMESPACE_END
|
|
|
|
|
|
|
|
#endif
|