[ltt-dev] [URCU PATCH] Optimize caa_get_cycles() for PowerPC64

Mathieu Desnoyers compudj at krystal.dyndns.org
Fri Sep 9 01:34:56 EDT 2011


* Tulio Magno Quites Machado Filho (tuliom at linux.vnet.ibm.com) wrote:
> Make caa_get_cycles() read from the Time Base register with only 1 instruction.

Merged,

I did a small coding style change to the patch, turning the
#if/#else/#endif into multiple function implementations rather than
affecting the cody of the same function.

Thanks!

Mathieu

> 
> Signed-off-by: Tulio Magno Quites Machado Filho <tuliom at linux.vnet.ibm.com>
> ---
>  urcu/arch/ppc.h |   11 +++++++++++
>  1 files changed, 11 insertions(+), 0 deletions(-)
> 
> diff --git a/urcu/arch/ppc.h b/urcu/arch/ppc.h
> index d7317bb..2b606d0 100644
> --- a/urcu/arch/ppc.h
> +++ b/urcu/arch/ppc.h
> @@ -48,10 +48,20 @@ extern "C" {
>  		rval;					\
>  	})
>  
> +#define mftb()						\
> +	({						\
> +		unsigned long long rval;		\
> +		asm volatile("mftb %0" : "=r" (rval));	\
> +		rval;					\
> +	})
> +
>  typedef unsigned long long cycles_t;
>  
>  static inline cycles_t caa_get_cycles (void)
>  {
> +#ifdef __powerpc64__
> +	return (cycles_t) mftb();
> +#else
>  	long h, l;
>  
>  	for (;;) {
> @@ -62,6 +72,7 @@ static inline cycles_t caa_get_cycles (void)
>  		if (mftbu() == h)
>  			return (((cycles_t) h) << 32) + l;
>  	}
> +#endif
>  }
>  
>  #ifdef __cplusplus 
> -- 
> 1.7.4.4
> 
> 
> _______________________________________________
> 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