[ltt-dev] [PATCH 08/12] move whether atomic byte/short exists to uatomic_arch_*.h

Mathieu Desnoyers compudj at krystal.dyndns.org
Wed Feb 17 22:12:28 EST 2010


* Paolo Bonzini (pbonzini at redhat.com) wrote:
> And add more generic implementations to uatomic_defaults.h.
> 
> Signed-off-by: Paolo Bonzini <pbonzini at redhat.com>
> ---
>  tests/test_uatomic.c    |   15 +------
>  urcu/uatomic_arch_x86.h |    3 +
>  urcu/uatomic_defaults.h |   96 +++++++++++++++++++++++++++++++++++++++++++++++
>  3 files changed, 101 insertions(+), 13 deletions(-)
> 
> diff --git a/tests/test_uatomic.c b/tests/test_uatomic.c
> index c0f36fe..5682655 100644
> --- a/tests/test_uatomic.c
> +++ b/tests/test_uatomic.c
> @@ -1,21 +1,10 @@
>  #include <stdio.h>
>  #include <assert.h>
> -
> -#define UATOMIC_NO_LINK_ERROR
>  #include <urcu/uatomic_arch.h>
>  
> -#if (defined(__i386__) || defined(__x86_64__))
> -#define HAS_ATOMIC_BYTE
> -#define HAS_ATOMIC_SHORT
> -#endif
> -
>  struct testvals {
> -#ifdef HAS_ATOMIC_BYTE
>  	unsigned char c;
> -#endif
> -#ifdef HAS_ATOMIC_SHORT
>  	unsigned short s;
> -#endif
>  	unsigned int i;
>  	unsigned long l;
>  };
> @@ -54,10 +43,10 @@ do {						\
>  
>  int main(int argc, char **argv)
>  {
> -#ifdef HAS_ATOMIC_BYTE
> +#ifdef UATOMIC_HAS_ATOMIC_BYTE
>  	do_test(&vals.c);
>  #endif
> -#ifdef HAS_ATOMIC_SHORT
> +#ifdef UATOMIC_HAS_ATOMIC_SHORT
>  	do_test(&vals.s);
>  #endif
>  	do_test(&vals.i);
> diff --git a/urcu/uatomic_arch_x86.h b/urcu/uatomic_arch_x86.h
> index 8a81995..f2d0c19 100644
> --- a/urcu/uatomic_arch_x86.h
> +++ b/urcu/uatomic_arch_x86.h
> @@ -23,6 +23,9 @@
>  #include <urcu/compiler.h>
>  #include <urcu/system.h>
>  
> +#define UATOMIC_HAS_ATOMIC_BYTE
> +#define UATOMIC_HAS_ATOMIC_SHORT
> +
>  #ifdef __cplusplus
>  extern "C" {
>  #endif 
> diff --git a/urcu/uatomic_defaults.h b/urcu/uatomic_defaults.h
> index 93467dd..2d0af6e 100644
> --- a/urcu/uatomic_defaults.h
> +++ b/urcu/uatomic_defaults.h
> @@ -64,6 +64,14 @@ unsigned long _uatomic_cmpxchg(void *addr, unsigned long old,
>  			      unsigned long _new, int len)
>  {
>  	switch (len) {
> +#ifdef UATOMIC_HAS_ATOMIC_BYTE
> +	case 1:
> +		return __sync_val_compare_and_swap_1(addr, old, _new);
> +#endif
> +#ifdef UATOMIC_HAS_ATOMIC_SHORT
> +	case 2:
> +		return __sync_val_compare_and_swap_2(addr, old, _new);
> +#endif
>  	case 4:
>  		return __sync_val_compare_and_swap_4(addr, old, _new);
>  #if (BITS_PER_LONG == 64)
> @@ -90,6 +98,14 @@ unsigned long _uatomic_add_return(void *addr, unsigned long val,
>  				 int len)
>  {
>  	switch (len) {
> +#ifdef UATOMIC_HAS_ATOMIC_BYTE
> +	case 1:
> +		return __sync_add_and_fetch_1(addr, val);
> +#endif
> +#ifdef UATOMIC_HAS_ATOMIC_SHORT
> +	case 2:
> +		return __sync_add_and_fetch_2(addr, val);
> +#endif
>  	case 4:
>  		return __sync_add_and_fetch_4(addr, val);
>  #if (BITS_PER_LONG == 64)
> @@ -115,6 +131,30 @@ static inline __attribute__((always_inline))
>  unsigned long _uatomic_exchange(void *addr, unsigned long val, int len)
>  {
>  	switch (len) {
> +#ifdef UATOMIC_HAS_ATOMIC_BYTE
> +	case 1:
> +	{
> +		unsigned char old;
> +
> +		do
> +			old = uatomic_read((unsigned char *)addr);
> +		while (!__sync_bool_compare_and_swap_1(addr, old, val));

Same here for brackets.

> +
> +		return old;
> +	}
> +#endif
> +#ifdef UATOMIC_HAS_ATOMIC_SHORT
> +	case 2:
> +	{
> +		unsigned short old;
> +
> +		do
> +			old = uatomic_read((unsigned short *)addr);
> +		while (!__sync_bool_compare_and_swap_2(addr, old, val));

And here.

Thanks,

Mathieu

> +
> +		return old;
> +	}
> +#endif
>  	case 4:
>  	{
>  		unsigned int old;
> @@ -156,6 +196,34 @@ static inline __attribute__((always_inline))
>  unsigned long _uatomic_add_return(void *addr, unsigned long val, int len)
>  {
>  	switch (len) {
> +#ifdef UATOMIC_HAS_ATOMIC_BYTE
> +	case 1:
> +	{
> +		unsigned char old, oldt;
> +
> +		oldt = uatomic_read((unsigned char *)addr);
> +		do {
> +			old = oldt;
> +			oldt = _uatomic_cmpxchg(addr, old, old + val, 1);
> +		} while (oldt != old);
> +
> +		return old + val;
> +	}
> +#endif
> +#ifdef UATOMIC_HAS_ATOMIC_SHORT
> +	case 2:
> +	{
> +		unsigned short old, oldt;
> +
> +		oldt = uatomic_read((unsigned short *)addr);
> +		do {
> +			old = oldt;
> +			oldt = _uatomic_cmpxchg(addr, old, old + val, 2);
> +		} while (oldt != old);
> +
> +		return old + val;
> +	}
> +#endif
>  	case 4:
>  	{
>  		unsigned int old, oldt;
> @@ -200,6 +268,34 @@ static inline __attribute__((always_inline))
>  unsigned long _uatomic_exchange(void *addr, unsigned long val, int len)
>  {
>  	switch (len) {
> +#ifdef UATOMIC_HAS_ATOMIC_BYTE
> +	case 1:
> +	{
> +		unsigned char old, oldt;
> +
> +		oldt = uatomic_read((unsigned char *)addr);
> +		do {
> +			old = oldt;
> +			oldt = _uatomic_cmpxchg(addr, old, val, 1);
> +		} while (oldt != old);
> +
> +		return old;
> +	}
> +#endif
> +#ifdef UATOMIC_HAS_ATOMIC_SHORT
> +	case 2:
> +	{
> +		unsigned short old, oldt;
> +
> +		oldt = uatomic_read((unsigned short *)addr);
> +		do {
> +			old = oldt;
> +			oldt = _uatomic_cmpxchg(addr, old, val, 2);
> +		} while (oldt != old);
> +
> +		return old;
> +	}
> +#endif
>  	case 4:
>  	{
>  		unsigned int old, oldt;
> -- 
> 1.6.6
> 
> 
> 
> _______________________________________________
> ltt-dev mailing list
> ltt-dev at lists.casi.polymtl.ca
> http://lists.casi.polymtl.ca/cgi-bin/mailman/listinfo/ltt-dev
> 

-- 
Mathieu Desnoyers
OpenPGP key fingerprint: 8CD5 52C3 8E3C 4140 715F  BA06 3F25 A8FE 3BAE 9A68




More information about the lttng-dev mailing list