X-Git-Url: https://review.openocd.org/gitweb?a=blobdiff_plain;f=src%2Fhelper%2Ftime_support.c;h=05eaf0a9d08e4cfae9a1dddf28c12d906813a2fb;hb=877cec20dca6e78f9f029f0f173879cda101a6c2;hp=9b86e52fe9ec224fb909b166e03e52a974baf347;hpb=2689f58f2a0afa296a29ab301a4c1665b914caab;p=openocd.git diff --git a/src/helper/time_support.c b/src/helper/time_support.c index 9b86e52fe9..05eaf0a9d0 100644 --- a/src/helper/time_support.c +++ b/src/helper/time_support.c @@ -19,22 +19,19 @@ * GNU General Public License for more details. * * * * You should have received a copy of the GNU General Public License * - * along with this program; if not, write to the * - * Free Software Foundation, Inc., * - * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * + * along with this program. If not, see . * ***************************************************************************/ + #ifdef HAVE_CONFIG_H #include "config.h" #endif #include "time_support.h" - /* calculate difference between two struct timeval values */ int timeval_subtract(struct timeval *result, struct timeval *x, struct timeval *y) { - if (x->tv_usec < y->tv_usec) - { + if (x->tv_usec < y->tv_usec) { int nsec = (y->tv_usec - x->tv_usec) / 1000000 + 1; y->tv_usec -= 1000000 * nsec; y->tv_sec += nsec; @@ -52,15 +49,12 @@ int timeval_subtract(struct timeval *result, struct timeval *x, struct timeval * return x->tv_sec < y->tv_sec; } -/* add two struct timeval values */ -int timeval_add(struct timeval *result, struct timeval *x, struct timeval *y) +int timeval_add_time(struct timeval *result, long sec, long usec) { - result->tv_sec = x->tv_sec + y->tv_sec; - - result->tv_usec = x->tv_usec + y->tv_usec; + result->tv_sec += sec; + result->tv_usec += usec; - while (result->tv_usec > 1000000) - { + while (result->tv_usec > 1000000) { result->tv_usec -= 1000000; result->tv_sec++; } @@ -68,18 +62,19 @@ int timeval_add(struct timeval *result, struct timeval *x, struct timeval *y) return 0; } -int timeval_add_time(struct timeval *result, int sec, int usec) +/* compare two timevals and return -1/0/+1 accordingly */ +int timeval_compare(const struct timeval *x, const struct timeval *y) { - result->tv_sec += sec; - result->tv_usec += usec; - - while (result->tv_usec > 1000000) - { - result->tv_usec -= 1000000; - result->tv_sec++; - } - - return 0; + if (x->tv_sec < y->tv_sec) + return -1; + else if (x->tv_sec > y->tv_sec) + return 1; + else if (x->tv_usec < y->tv_usec) + return -1; + else if (x->tv_usec > y->tv_usec) + return 1; + else + return 0; } int duration_start(struct duration *duration) @@ -96,26 +91,14 @@ int duration_measure(struct duration *duration) return retval; } -float duration_elapsed(struct duration *duration) +float duration_elapsed(const struct duration *duration) { float t = duration->elapsed.tv_sec; t += (float)duration->elapsed.tv_usec / 1000000.0; return t; } -float duration_kbps(struct duration *duration, size_t count) +float duration_kbps(const struct duration *duration, size_t count) { return count / (1024.0 * duration_elapsed(duration)); } - -long long timeval_ms() -{ - struct timeval now; - long long t = 0; - gettimeofday(&now, NULL); - - t += now.tv_usec/1000; - t += now.tv_sec*1000; - - return t; -}