2020-02-25 16:35:52 +00:00
|
|
|
#include "stopwatch.h"
|
|
|
|
|
2021-01-05 09:56:54 +00:00
|
|
|
struct timing_fx _static_tfx;
|
|
|
|
|
|
|
|
struct timing_fx* static_tfx() { return &_static_tfx; }
|
|
|
|
|
2020-02-25 16:35:52 +00:00
|
|
|
void timing_fx_init(struct timing_fx* tfx, enum timing_config conf, char* startt, char* endt) {
|
|
|
|
tfx->config = conf;
|
|
|
|
strncpy (tfx->start_template, startt, sizeof(tfx->start_template) - 1);
|
|
|
|
strncpy (tfx->end_template, endt, sizeof(tfx->end_template) - 1);
|
|
|
|
tfx->start_template[sizeof(tfx->start_template) - 1] = 0; // Enforce null terminated string
|
|
|
|
tfx->end_template[sizeof(tfx->end_template) - 1] = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
void timing_fx_start(struct timing_fx* tfx, ...) {
|
|
|
|
va_list args;
|
|
|
|
if (!(tfx->config & TIMING_ACTIVATED)) return;
|
|
|
|
if (tfx->config & (TIMING_DISPLAY_START | TIMING_DISPLAY_BOTH)) {
|
|
|
|
va_start(args, tfx);
|
|
|
|
vfprintf(stderr, tfx->start_template, args);
|
|
|
|
va_end(args);
|
|
|
|
}
|
|
|
|
|
2020-02-27 15:41:52 +00:00
|
|
|
if (clock_gettime(CLOCK_MONOTONIC_RAW, &tfx->start) == -1) {
|
2020-02-25 16:35:52 +00:00
|
|
|
perror("clock_gettime");
|
|
|
|
exit(EXIT_FAILURE);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
double timing_fx_stop(struct timing_fx* tfx, ...) {
|
|
|
|
va_list args;
|
|
|
|
struct timespec stop;
|
|
|
|
double elapsed_in_cb;
|
|
|
|
|
|
|
|
if (!(tfx->config & TIMING_ACTIVATED)) return 0.;
|
|
|
|
|
2020-02-27 15:41:52 +00:00
|
|
|
if (clock_gettime(CLOCK_MONOTONIC_RAW, &stop) == -1) {
|
2020-02-25 16:35:52 +00:00
|
|
|
perror("clock_gettime");
|
|
|
|
exit(EXIT_FAILURE);
|
|
|
|
}
|
|
|
|
|
|
|
|
elapsed_in_cb = (double)elapsed_micros (&tfx->start, &stop) / 1000000.;
|
|
|
|
|
|
|
|
if (tfx->config & (TIMING_DISPLAY_END | TIMING_DISPLAY_BOTH)) {
|
|
|
|
va_start(args, tfx);
|
|
|
|
vfprintf(stderr, tfx->end_template, args);
|
|
|
|
fprintf(stderr, ": done in %f sec\n", elapsed_in_cb);
|
|
|
|
va_end(args);
|
|
|
|
}
|
|
|
|
return elapsed_in_cb;
|
|
|
|
}
|
|
|
|
|