Select one of the symbols to view example projects that use it.
 
Outline
#include "config.h"
#include "time_support.h"
timeval_subtract(struct timeval *, struct timeval *, struct timeval *)
timeval_add_time(struct timeval *, long, long)
timeval_compare(const struct timeval *, const struct timeval *)
duration_start(struct duration *)
duration_measure(struct duration *)
duration_elapsed(const struct duration *)
duration_kbps(const struct duration *, size_t)
Files
loading...
CodeScopeDevelopment ToolsOpenOCDsrc/helper/time_support.c
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
// SPDX-License-Identifier: GPL-2.0-or-later /*************************************************************************** * Copyright (C) 2006 by Dominic Rath * * Dominic.Rath@gmx.de * * * * Copyright (C) 2007,2008 Øyvind Harboe * * oyvind.harboe@zylin.com * * * * Copyright (C) 2008 by Spencer Oliver * * spen@spen-soft.co.uk * ***************************************************************************//* ... */ #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) { int nsec = (y->tv_usec - x->tv_usec) / 1000000 + 1; y->tv_usec -= 1000000 * nsec; y->tv_sec += nsec; }if (x->tv_usec < y->tv_usec) { ... } if (x->tv_usec - y->tv_usec > 1000000) { int nsec = (x->tv_usec - y->tv_usec) / 1000000; y->tv_usec += 1000000 * nsec; y->tv_sec -= nsec; }if (x->tv_usec - y->tv_usec > 1000000) { ... } result->tv_sec = x->tv_sec - y->tv_sec; result->tv_usec = x->tv_usec - y->tv_usec; /* Return 1 if result is negative. */ return x->tv_sec < y->tv_sec; }{ ... } int timeval_add_time(struct timeval *result, long sec, long usec) { result->tv_sec += sec; result->tv_usec += usec; while (result->tv_usec > 1000000) { result->tv_usec -= 1000000; result->tv_sec++; }while (result->tv_usec > 1000000) { ... } return 0; }{ ... } /* compare two timevals and return -1/0/+1 accordingly */ int timeval_compare(const struct timeval *x, const struct timeval *y) { 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) { return gettimeofday(&duration->start, NULL); }{ ... } int duration_measure(struct duration *duration) { struct timeval end; int retval = gettimeofday(&end, NULL); if (retval == 0) timeval_subtract(&duration->elapsed, &end, &duration->start); return retval; }{ ... } 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(const struct duration *duration, size_t count) { return count / (1024.0 * duration_elapsed(duration)); }{ ... }