Update Red Hat Copyright Notices
[nbdkit.git] / common / utils / bench.h
blobf1dc0fb18023f27332d8f2af649174b365d84786
1 /* libnbd
2 * Copyright Red Hat
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are
6 * met:
8 * * Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer.
11 * * Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
15 * * Neither the name of Red Hat nor the names of its contributors may be
16 * used to endorse or promote products derived from this software without
17 * specific prior written permission.
19 * THIS SOFTWARE IS PROVIDED BY RED HAT AND CONTRIBUTORS ''AS IS'' AND
20 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
21 * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
22 * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL RED HAT OR
23 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
24 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
25 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
26 * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
27 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
28 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
29 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
30 * SUCH DAMAGE.
33 #ifndef LIBNBD_BENCH_H
34 #define LIBNBD_BENCH_H
36 #include <sys/time.h>
38 #define MICROSECONDS 1000000
40 struct bench {
41 struct timeval start, stop;
44 static inline void
45 bench_start (struct bench *b)
47 gettimeofday (&b->start, NULL);
50 static inline void
51 bench_stop (struct bench *b)
53 gettimeofday (&b->stop, NULL);
56 static inline double
57 bench_sec (struct bench *b)
59 struct timeval dt;
61 dt.tv_sec = b->stop.tv_sec - b->start.tv_sec;
62 dt.tv_usec = b->stop.tv_usec - b->start.tv_usec;
64 if (dt.tv_usec < 0) {
65 dt.tv_sec -= 1;
66 dt.tv_usec += MICROSECONDS;
69 return ((double)dt.tv_sec * MICROSECONDS + dt.tv_usec) / MICROSECONDS;
72 #endif /* LIBNBD_BENCH_H */