[ltt-dev] PATCH [0/1]: Replace gettimeofday with clock_gettime
Pierre-Marc Fournier
pierre-marc.fournier at polymtl.ca
Tue May 25 10:31:20 EDT 2010
Thanks, comments below.
On 05/24/2010 10:54 AM, Nils Carlson wrote:
> This patch replaces gettimeofday with clock_gettime(CLOCK_MONOTONIC,)
>
> Signed-off-by: Nils Carlson<nils.carlson at ludd.ltu.se>
>
> diff --git a/include/ust/clock.h b/include/ust/clock.h
> index d4b6a9d..bc26d26 100644
> --- a/include/ust/clock.h
> +++ b/include/ust/clock.h
> @@ -18,6 +18,7 @@
> #ifndef UST_CLOCK_H
> #define UST_CLOCK_H
>
> +#include<time.h>
> #include<sys/time.h>
> #include<ust/kcompat/kcompat.h>
>
> @@ -25,7 +26,7 @@
>
> /* There are two types of clocks that can be used.
> - TSC based clock
> - - gettimeofday() clock
> + - gettimeofday() clock - to guarantee monotonicity use clock_gettime
>
> Microbenchmarks on Linux 2.6.30 on Core2 Duo 3GHz (functions are
> inlined):
> Calls (100000000) to tsc(): 4004035641 cycles or 40 cycles/call
> @@ -41,13 +42,13 @@
>
> static __inline__ u64 trace_clock_read64(void)
> {
> - struct timeval tv;
> + struct timespec ts;
> u64 retval;
>
> - gettimeofday(&tv, NULL);
> - retval = tv.tv_sec;
> + clock_gettime(CLOCK_MONOTONIC,&ts);
> + retval = ts.tv_sec;
> retval *= 1000000;
> - retval += tv.tv_usec;
> + retval += ts.tv_nsec / 1000;
Any specific reason for truncating the nanoseconds here?
>
> return retval;
> }
> diff --git a/libust/Makefile.am b/libust/Makefile.am
> index 2de5857..e357ad1 100644
> --- a/libust/Makefile.am
> +++ b/libust/Makefile.am
> @@ -27,6 +27,7 @@ libust_la_LDFLAGS = -no-undefined -version-info 0:0:0
>
> libust_la_LIBADD = \
> -lpthread \
> + -lrt \
I guess this isn't supposed to be part of the patch?
> $(top_builddir)/snprintf/libustsnprintf.la \
> $(top_builddir)/libustcomm/libustcomm.la
>
>
>
>
>
> _______________________________________________
> ltt-dev mailing list
> ltt-dev at lists.casi.polymtl.ca
> http://lists.casi.polymtl.ca/cgi-bin/mailman/listinfo/ltt-dev
More information about the lttng-dev
mailing list