#include <ace/High_Res_Timer.h>
class ACE_High_Res_Timer {
public:static void global_scale_factor (ACE_UINT32 gsf);static ACE_UINT32 global_scale_factor (void);static int get_env_global_scale_factor ( const char *env = "ACE_SCALE_FACTOR" );static ACE_UINT32 calibrate ( const ACE_UINT32 usec = 500000, const u_int iterations = 10 );ACE_High_Res_Timer (void);~ACE_High_Res_Timer (void);void reset (void);void start ( const ACE_OS::ACE_HRTimer_Op = ACE_OS::ACE_HRTIMER_GETTIME );void stop ( const ACE_OS::ACE_HRTimer_Op = ACE_OS::ACE_HRTIMER_GETTIME );void elapsed_time (ACE_Time_Value &tv) const;void elapsed_time (ACE_hrtime_t &nanoseconds) const;void elapsed_time (struct timespec &) const;void elapsed_microseconds (ACE_hrtime_t &usecs) const;void start_incr ( const ACE_OS::ACE_HRTimer_Op = ACE_OS::ACE_HRTIMER_GETTIME );void stop_incr ( const ACE_OS::ACE_HRTimer_Op = ACE_OS::ACE_HRTIMER_GETTIME );void elapsed_time_incr (ACE_Time_Value &tv) const;void elapsed_time_incr (ACE_hrtime_t &nanoseconds) const;void print_total ( const char *message, const int iterations = 1, ACE_HANDLE handle = ACE_STDOUT ) const;void print_ave ( const char *message, const int iterations = 1, ACE_HANDLE handle = ACE_STDOUT ) const;void dump (void) const;ACE_ALLOC_HOOK_DECLARE;ACE_OS::ACE_HRTIMER_GETTIME);static void hrtime_to_tv ( ACE_Time_Value &tv, const ACE_hrtime_t hrt );static ACE_UINT32 get_cpuinfo (void);private:ACE_OS::ACE_HRTIMER_GETTIME);ACE_hrtime_t start_;ACE_hrtime_t end_;ACE_hrtime_t total_;ACE_hrtime_t start_incr_;static ACE_UINT32 global_scale_factor_;static int global_scale_factor_status_;};
The global scale factor is required for platforms that have high-resolution timers that return units other than microseconds, such as clock ticks. It is represented as a static u_long, can only be accessed through static methods, and is used by all instances of High Res Timer. The member functions that return or print times use the global scale factor. They divide the "time" that they get from ACE_OS::gethrtime () by global_scale_factor_ to obtain the time in microseconds. Its units are therefore 1/microsecond. On Solaris, a scale factor of 1000 should be used because its high-resolution timer returns nanoseconds. However, on Intel platforms, we use RDTSC which returns the number of clock ticks since system boot. For a 200MHz cpu, each clock tick is 1/200 of a microsecond; the global_scale_factor_ should therefore be 200.
NOTE: the elapsed time calculations in the print methods use ACE_hrtime_t values. Those methods do _not_ check for overflow!
NOTE:  Gabe begeddov@proaxis.com raises this issue
regarding ACE_OS::gethrtime ():  on multi-processors, the
processor that you query for your timer.stop () value might
not be the one you queried for timer.start ().  Its not clear
how much divergence there would be, if any.
This issue is not mentioned in the Solaris 2.5.1 gethrtime man page.
static void global_scale_factor (ACE_UINT32 gsf);
gsf.  All High_Res_Timers use
global_scale_factor_.  This allows applications to set the scale
factor just once for all High_Res_Timers.  Check
High_Res_Timer.cpp for the default global_scale_factors for
several platforms.  For many platforms (e.g., Solaris), the
global_scale_factor_ is set to 1000 so that scale_factor need
not be set.  Careful, a scale_factor of 0 will cause division
by zero exceptions.
static ACE_UINT32 global_scale_factor (void);
static int get_env_global_scale_factor (
    const char *env = "ACE_SCALE_FACTOR"
    );
env
environment variable.  Returns 0 on success, -1 on failure.  Note
if env points to string "0" (value zero), this call will fail.
This is basically a no-op on CE because there is no concept of
environment variable on CE.
static ACE_UINT32 calibrate (
    const ACE_UINT32 usec = 500000,
    const u_int iterations = 10
    );
usec and counting the number of intervening clock cycles.
Average over iterations of usec each.  On some platforms,
such as Pentiums, this is called automatically during the first
ACE_High_Res_Timer construction with the default parameter
values.  An application can override that by calling calibrate
with any desired parameter values _prior_ to constructing the
first ACE_High_Res_Timer instance.
ACE_High_Res_Timer (void);
~ACE_High_Res_Timer (void);
void reset (void);
void start (
    const ACE_OS::ACE_HRTimer_Op = ACE_OS::ACE_HRTIMER_GETTIME
    );
void stop (
    const ACE_OS::ACE_HRTimer_Op = ACE_OS::ACE_HRTIMER_GETTIME
    );
void elapsed_time (ACE_Time_Value &tv) const;
tv to the number of microseconds elapsed.
void elapsed_time (ACE_hrtime_t &nanoseconds) const;
nanoseconds to the number of nanoseconds elapsed.
void elapsed_time (struct timespec &) const;
void elapsed_microseconds (ACE_hrtime_t &usecs) const;
usecs to the elapsed (stop - start) time in microseconds.
void start_incr (
    const ACE_OS::ACE_HRTimer_Op = ACE_OS::ACE_HRTIMER_GETTIME
    );
void stop_incr (
    const ACE_OS::ACE_HRTimer_Op = ACE_OS::ACE_HRTIMER_GETTIME
    );
void elapsed_time_incr (ACE_Time_Value &tv) const;
tv to the number of microseconds elapsed between all calls
to start_incr and stop_incr.
void elapsed_time_incr (ACE_hrtime_t &nanoseconds) const;
nsec to the number of nanoseconds elapsed between all calls
to start_incr and stop_incr.
@@ These two functions are currently not supported on Windows CE. However, we should probably use the handle and ACE_Log_Msg to print out the result.
void print_total (
    const char *message,
    const int iterations = 1,
    ACE_HANDLE handle = ACE_STDOUT
    ) const;
void print_ave (
    const char *message,
    const int iterations = 1,
    ACE_HANDLE handle = ACE_STDOUT
    ) const;
void dump (void) const;
ACE_ALLOC_HOOK_DECLARE;
ACE_OS::ACE_HRTIMER_GETTIME);
static void hrtime_to_tv (ACE_Time_Value &tv, const ACE_hrtime_t hrt);
hrt to tv using global_scale_factor_.
static ACE_UINT32 get_cpuinfo (void);