[ltt-dev] PATCH [0/1]: Replace gettimeofday with clock_gettime

Nils Carlson nils.carlson at ludd.ltu.se
Tue May 25 15:38:20 EDT 2010


Comments below,

On May 25, 2010, at 4:31 PM, Pierre-Marc Fournier wrote:

> 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?

Only to provide the same fidelity as the previous code. I don't know  
enough
about how you use the timer, so I didn't take it upon myself to change  
the
resolution.

>
>>
>>         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?

It is. clock_gettime requires the realtime clock library.

>
>>         $(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