1 /* Copyright (C) 2010 Pierre-Marc Fournier
3 * This library is free software; you can redistribute it and/or
4 * modify it under the terms of the GNU Lesser General Public
5 * License as published by the Free Software Foundation; either
6 * version 2.1 of the License, or (at your option) any later version.
8 * This library is distributed in the hope that it will be useful,
9 * but WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
11 * Lesser General Public License for more details.
13 * You should have received a copy of the GNU Lesser General Public
14 * License along with this library; if not, write to the Free Software
15 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
23 #include <ust/kcompat/kcompat.h>
27 /* There are two types of clocks that can be used.
29 - gettimeofday() clock
31 Microbenchmarks on Linux 2.6.30 on Core2 Duo 3GHz (functions are inlined):
32 Calls (100000000) to tsc(): 4004035641 cycles or 40 cycles/call
33 Calls (100000000) to gettimeofday(): 9723158352 cycles or 97 cycles/call
35 For merging traces with the kernel, a time source compatible with that of
36 the kernel is necessary.
38 Instead of gettimeofday(), we are now using clock_gettime for better
39 precision and monotonicity.
42 #if __i386__ || __x86_64__
43 /* Only available for x86 arch */
44 #define CLOCK_TRACE_FREQ 14
45 #define CLOCK_TRACE 15
46 union lttng_timespec
{
50 #endif /* __i386__ || __x86_64__ */
52 static int ust_clock_source
;
54 /* Choosing correct trace clock */
56 static __inline__ u64
trace_clock_read64(void)
68 "cmpw %[rhigh],%[rhigh2]\n\t"
70 : [rhigh
] "=r" (tb_h
), [rhigh2
] "=r" (tb_h2
), [rlow
] "=r" (tb_l
));
81 static __inline__ u64
trace_clock_read64(void)
85 union lttng_timespec
*lts
= (union lttng_timespec
*) &ts
;
87 clock_gettime(ust_clock_source
, &ts
);
89 * Clock source can change when loading the binary (tracectl.c)
90 * so we must check if the clock source has changed before
91 * returning the correct value
93 if (likely(ust_clock_source
== CLOCK_TRACE
)) {
94 retval
= lts
->lttng_ts
;
95 } else { /* CLOCK_MONOTONIC */
106 static __inline__ u64
trace_clock_frequency(void)
109 union lttng_timespec
*lts
= (union lttng_timespec
*) &ts
;
111 if (likely(ust_clock_source
== CLOCK_TRACE
)) {
112 clock_gettime(CLOCK_TRACE_FREQ
, &ts
);
113 return lts
->lttng_ts
;
118 static __inline__ u32
trace_clock_freq_scale(void)
123 #endif /* _UST_CLOCK_H */
This page took 0.032981 seconds and 5 git commands to generate.