X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=src%2Fhelper%2Ftime_support.h;h=fab432d38d1c0fac843c42238ab98bbbd85aa3fd;hb=690e054a3d8c8847432c31224743b0f9dbd0f1bf;hp=a8036766fcb303a0b28c3d8bb6820fbb21950975;hpb=8b994145b849c40b0a195c3fb332b9770b2f9097;p=openocd diff --git a/src/helper/time_support.h b/src/helper/time_support.h index a8036766..fab432d3 100644 --- a/src/helper/time_support.h +++ b/src/helper/time_support.h @@ -37,19 +37,26 @@ # endif #endif -extern int timeval_subtract(struct timeval *result, struct timeval *x, struct timeval *y); -extern int timeval_add(struct timeval *result, struct timeval *x, struct timeval *y); -extern int timeval_add_time(struct timeval *result, int sec, int usec); -/* gettimeofday() timeval in 64 bit ms */ -extern long long timeval_ms(void); +int timeval_subtract(struct timeval *result, struct timeval *x, struct timeval *y); +int timeval_add_time(struct timeval *result, long sec, long usec); -typedef struct duration_s +/// @returns gettimeofday() timeval as 64-bit in ms +int64_t timeval_ms(void); + +struct duration { struct timeval start; - struct timeval duration; -} duration_t; + struct timeval elapsed; +}; + +/// Update the duration->start field to start the @a duration measurement. +int duration_start(struct duration *duration); +/// Update the duration->elapsed field to finish the @a duration measurment. +int duration_measure(struct duration *duration); -extern void duration_start_measure(duration_t *duration); -extern int duration_stop_measure(duration_t *duration, char **text); +/// @returns Elapsed time in seconds. +float duration_elapsed(struct duration *duration); +/// @returns KB/sec for the elapsed @a duration and @a count bytes. +float duration_kbps(struct duration *duration, size_t count); #endif /* TIME_SUPPORT_H */