[ltt-dev] [PATCH] Remove PowerPC specific time reading function

Mathieu Desnoyers compudj at krystal.dyndns.org
Thu Feb 10 11:01:20 EST 2011


* Yannick Brosseau (yannick.brosseau at gmail.com) wrote:
> The PPC version of the trace_clock_read64 was using the TB register
> which is not constant accross implementations. The currently
> measured time base on PPC was not accurate.
> So, for now, we rely on the CLOCK_MONOTONIC.
> 
> This patch remove a bunch of #ifdef for x86 and PPC, since we now rely on
> the same base clock. It also fix the build on PPC that was currently broken

Merged, thanks !

We should do a 0.12 bugfix release soon. This is a major showstopper on
ppc.

Mathieu

> 
> Signed-off-by: Yannick Brosseau <yannick.brosseau at gmail.com>
> ---
>  include/ust/clock.h |   30 ++----------------------------
>  1 files changed, 2 insertions(+), 28 deletions(-)
> 
> diff --git a/include/ust/clock.h b/include/ust/clock.h
> index 04785fc..5e558f8 100644
> --- a/include/ust/clock.h
> +++ b/include/ust/clock.h
> @@ -39,7 +39,6 @@
>     precision and monotonicity.
>  */
>  
> -#if __i386__ || __x86_64__
>  /* Only available for x86 arch */
>  #define CLOCK_TRACE_FREQ  14
>  #define CLOCK_TRACE  15
> @@ -47,36 +46,10 @@ union lttng_timespec {
>  	struct timespec ts;
>  	u64 lttng_ts;
>  };
> -#endif /* __i386__ || __x86_64__ */
>  
>  extern int ust_clock_source;
>  
>  /* Choosing correct trace clock */
> -#if __PPC__
> -static __inline__ u64 trace_clock_read64(void)
> -{
> -	unsigned long tb_l;
> -	unsigned long tb_h;
> -	unsigned long tb_h2;
> -	u64 tb;
> -
> -	__asm__ (
> -		"1:\n\t"
> -		"mftbu %[rhigh]\n\t"
> -		"mftb %[rlow]\n\t"
> -		"mftbu %[rhigh2]\n\t"
> -		"cmpw %[rhigh],%[rhigh2]\n\t"
> -		"bne 1b\n\t"
> -		: [rhigh] "=r" (tb_h), [rhigh2] "=r" (tb_h2), [rlow] "=r" (tb_l));
> -
> -	tb = tb_h;
> -	tb <<= 32;
> -	tb |= tb_l;
> -
> -	return tb;
> -}
> -
> -#else	/* !__PPC__ */
>  
>  static __inline__ u64 trace_clock_read64(void)
>  {
> @@ -101,17 +74,18 @@ static __inline__ u64 trace_clock_read64(void)
>  	return retval;
>  }
>  
> -#endif /* __PPC__ */
>  
>  static __inline__ u64 trace_clock_frequency(void)
>  {
>  	struct timespec ts;
>  	union lttng_timespec *lts = (union lttng_timespec *) &ts;
>  
> +#if __i386__ || __x86_64__
>  	if (likely(ust_clock_source == CLOCK_TRACE)) {
>  		clock_gettime(CLOCK_TRACE_FREQ, &ts);
>  		return lts->lttng_ts;
>  	}
> +#endif
>  	return 1000000000LL;
>  }
>  
> -- 
> 1.7.2.3
> 
> 
> _______________________________________________
> ltt-dev mailing list
> ltt-dev at lists.casi.polymtl.ca
> http://lists.casi.polymtl.ca/cgi-bin/mailman/listinfo/ltt-dev
> 

-- 
Mathieu Desnoyers
Operating System Efficiency R&D Consultant
EfficiOS Inc.
http://www.efficios.com




More information about the lttng-dev mailing list