Initial
This commit is contained in:
57
fsecs.c
Executable file
57
fsecs.c
Executable file
@@ -0,0 +1,57 @@
|
||||
/****************************
|
||||
* High-level timing wrappers
|
||||
****************************/
|
||||
#include <stdio.h>
|
||||
#include "fsecs.h"
|
||||
#include "fcyc.h"
|
||||
#include "clock.h"
|
||||
#include "ftimer.h"
|
||||
#include "config.h"
|
||||
|
||||
static double Mhz; /* estimated CPU clock frequency */
|
||||
|
||||
extern int verbose; /* -v option in mdriver.c */
|
||||
|
||||
/*
|
||||
* init_fsecs - initialize the timing package
|
||||
*/
|
||||
void init_fsecs(void)
|
||||
{
|
||||
Mhz = 0; /* keep gcc -Wall happy */
|
||||
|
||||
#if USE_FCYC
|
||||
if (verbose)
|
||||
printf("Measuring performance with a cycle counter.\n");
|
||||
|
||||
/* set key parameters for the fcyc package */
|
||||
set_fcyc_maxsamples(20);
|
||||
set_fcyc_clear_cache(1);
|
||||
set_fcyc_compensate(1);
|
||||
set_fcyc_epsilon(0.01);
|
||||
set_fcyc_k(3);
|
||||
Mhz = mhz(verbose > 0);
|
||||
#elif USE_ITIMER
|
||||
if (verbose)
|
||||
printf("Measuring performance with the interval timer.\n");
|
||||
#elif USE_GETTOD
|
||||
if (verbose)
|
||||
printf("Measuring performance with gettimeofday().\n");
|
||||
#endif
|
||||
}
|
||||
|
||||
/*
|
||||
* fsecs - Return the running time of a function f (in seconds)
|
||||
*/
|
||||
double fsecs(fsecs_test_funct f, void *argp)
|
||||
{
|
||||
#if USE_FCYC
|
||||
double cycles = fcyc(f, argp);
|
||||
return cycles/(Mhz*1e6);
|
||||
#elif USE_ITIMER
|
||||
return ftimer_itimer(f, argp, 10);
|
||||
#elif USE_GETTOD
|
||||
return ftimer_gettod(f, argp, 10);
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user