1
1

Rework of r16807. For opal atomics:

* Conditionalize around `static inline` using
   `OPAL_HAVE_INLINE_ATOMIC*` macros
 * Remove redundant `opal_atomic*` prototypes (they 
   belong in the top-level `sys/atomic.h`

This commit was SVN r16957.

The following SVN revision numbers were found above:
  r16807 --> open-mpi/ompi@b7c885247a
Этот коммит содержится в:
Ethan Mallove 2007-12-14 15:11:35 +00:00
родитель cb7c435a9c
Коммит a20a1a806a
3 изменённых файлов: 76 добавлений и 49 удалений

Просмотреть файл

@ -9,6 +9,7 @@
* University of Stuttgart. All rights reserved. * University of Stuttgart. All rights reserved.
* Copyright (c) 2004-2005 The Regents of the University of California. * Copyright (c) 2004-2005 The Regents of the University of California.
* All rights reserved. * All rights reserved.
* Copyright (c) 2007 Sun Microsystems, Inc. All rights reserved.
* $COPYRIGHT$ * $COPYRIGHT$
* *
* Additional copyrights may follow * Additional copyrights may follow
@ -108,6 +109,21 @@ struct opal_atomic_lock_t {
}; };
typedef struct opal_atomic_lock_t opal_atomic_lock_t; typedef struct opal_atomic_lock_t opal_atomic_lock_t;
/**********************************************************************
*
* Zero these macros in the architecture-specific atomic.h files if we
* need to define their corresponding functions as non-inline (e.g.,
* in an opal/asm/base/<arch>.asm file). These macros allow us to make
* the signatures of the prototype and definition identical.
*
*********************************************************************/
#define OPAL_HAVE_INLINE_ATOMIC_MEM_BARRIER 1
#define OPAL_HAVE_INLINE_ATOMIC_CMPSET_32 1
#define OPAL_HAVE_INLINE_ATOMIC_CMPSET_64 1
#define OPAL_HAVE_INLINE_ATOMIC_ADD_32 1
#define OPAL_HAVE_INLINE_ATOMIC_SUB_32 1
#define OPAL_HAVE_INLINE_ATOMIC_ADD_64 1
#define OPAL_HAVE_INLINE_ATOMIC_SUB_64 1
/********************************************************************** /**********************************************************************
* *
@ -179,6 +195,10 @@ typedef struct opal_atomic_lock_t opal_atomic_lock_t;
* generally grinding the memory controller's performance. Use only * generally grinding the memory controller's performance. Use only
* if you need *both* read and write barriers. * if you need *both* read and write barriers.
*/ */
#if OPAL_HAVE_INLINE_ATOMIC_MEM_BARRIER
static inline
#endif
void opal_atomic_mb(void); void opal_atomic_mb(void);
/** /**
@ -190,6 +210,10 @@ void opal_atomic_mb(void);
* next read. Nothing is said about the ordering of writes when using * next read. Nothing is said about the ordering of writes when using
* \c opal_atomic_rmb(). * \c opal_atomic_rmb().
*/ */
#if OPAL_HAVE_INLINE_ATOMIC_MEM_BARRIER
static inline
#endif
void opal_atomic_rmb(void); void opal_atomic_rmb(void);
/** /**
@ -201,6 +225,10 @@ void opal_atomic_rmb(void);
* next write. Nothing is said about the ordering of reads when using * next write. Nothing is said about the ordering of reads when using
* \c opal_atomic_wmb(). * \c opal_atomic_wmb().
*/ */
#if OPAL_HAVE_INLINE_ATOMIC_MEM_BARRIER
static inline
#endif
void opal_atomic_wmb(void); void opal_atomic_wmb(void);
#endif /* defined(DOXYGEN) || OPAL_HAVE_ATOMIC_MEM_BARRIER */ #endif /* defined(DOXYGEN) || OPAL_HAVE_ATOMIC_MEM_BARRIER */
@ -293,10 +321,22 @@ void opal_atomic_unlock(opal_atomic_lock_t *lock);
#define OPAL_HAVE_ATOMIC_CMPSET_32 0 #define OPAL_HAVE_ATOMIC_CMPSET_32 0
#endif #endif
#if defined(DOXYGEN) || OPAL_HAVE_ATOMIC_CMPSET_32 #if defined(DOXYGEN) || OPAL_HAVE_ATOMIC_CMPSET_32
#if OPAL_HAVE_INLINE_ATOMIC_CMPSET_32
static inline
#endif
int opal_atomic_cmpset_32(volatile int32_t *addr, int32_t oldval, int opal_atomic_cmpset_32(volatile int32_t *addr, int32_t oldval,
int32_t newval); int32_t newval);
#if OPAL_HAVE_INLINE_ATOMIC_CMPSET_32
static inline
#endif
int opal_atomic_cmpset_acq_32(volatile int32_t *addr, int32_t oldval, int opal_atomic_cmpset_acq_32(volatile int32_t *addr, int32_t oldval,
int32_t newval); int32_t newval);
#if OPAL_HAVE_INLINE_ATOMIC_CMPSET_32
static inline
#endif
int opal_atomic_cmpset_rel_32(volatile int32_t *addr, int32_t oldval, int opal_atomic_cmpset_rel_32(volatile int32_t *addr, int32_t oldval,
int32_t newval); int32_t newval);
#endif #endif
@ -306,28 +346,46 @@ int opal_atomic_cmpset_rel_32(volatile int32_t *addr, int32_t oldval,
#define OPAL_HAVE_ATOMIC_CMPSET_64 0 #define OPAL_HAVE_ATOMIC_CMPSET_64 0
#endif #endif
#if defined(DOXYGEN) || OPAL_HAVE_ATOMIC_CMPSET_64 #if defined(DOXYGEN) || OPAL_HAVE_ATOMIC_CMPSET_64
#if OPAL_HAVE_INLINE_ATOMIC_CMPSET_64
static inline
#endif
int opal_atomic_cmpset_64(volatile int64_t *addr, int64_t oldval, int opal_atomic_cmpset_64(volatile int64_t *addr, int64_t oldval,
int64_t newval); int64_t newval);
#if OPAL_HAVE_INLINE_ATOMIC_CMPSET_64
static inline
#endif
int opal_atomic_cmpset_acq_64(volatile int64_t *addr, int64_t oldval, int opal_atomic_cmpset_acq_64(volatile int64_t *addr, int64_t oldval,
int64_t newval); int64_t newval);
#if OPAL_HAVE_INLINE_ATOMIC_CMPSET_64
static inline
#endif
int opal_atomic_cmpset_rel_64(volatile int64_t *addr, int64_t oldval, int opal_atomic_cmpset_rel_64(volatile int64_t *addr, int64_t oldval,
int64_t newval); int64_t newval);
#endif #endif
#if !defined(OPAL_HAVE_ATOMIC_MATH_32) && !defined(DOXYGEN) #if !defined(OPAL_HAVE_ATOMIC_MATH_32) && !defined(DOXYGEN)
/* define to 0 for these tests. WIll fix up later. */ /* define to 0 for these tests. WIll fix up later. */
#define OPAL_HAVE_ATOMIC_MATH_32 0 #define OPAL_HAVE_ATOMIC_MATH_32 0
#endif #endif
#if defined(DOXYGEN) || OPAL_HAVE_ATOMIC_MATH_32 || OPAL_HAVE_ATOMIC_CMPSET_32 #if defined(DOXYGEN) || OPAL_HAVE_ATOMIC_MATH_32 || OPAL_HAVE_ATOMIC_CMPSET_32
#if ! OPAL_HAVE_ATOMIC_MATH_32
#if OPAL_HAVE_INLINE_ATOMIC_ADD_32
static inline static inline
#endif #endif
int32_t opal_atomic_add_32(volatile int32_t *addr, int delta); int32_t opal_atomic_add_32(volatile int32_t *addr, int delta);
#if ! OPAL_HAVE_ATOMIC_MATH_32
#if OPAL_HAVE_INLINE_ATOMIC_SUB_32
static inline static inline
#endif #endif
int32_t opal_atomic_sub_32(volatile int32_t *addr, int delta); int32_t opal_atomic_sub_32(volatile int32_t *addr, int delta);
#endif /* OPAL_HAVE_ATOMIC_MATH_32 */ #endif /* OPAL_HAVE_ATOMIC_MATH_32 */
#if ! OPAL_HAVE_ATOMIC_MATH_32 #if ! OPAL_HAVE_ATOMIC_MATH_32
/* fix up the value of ompi_have_atomic_math_32 to allow for C versions */ /* fix up the value of ompi_have_atomic_math_32 to allow for C versions */
#undef OPAL_HAVE_ATOMIC_MATH_32 #undef OPAL_HAVE_ATOMIC_MATH_32
@ -338,16 +396,21 @@ int32_t opal_atomic_sub_32(volatile int32_t *addr, int delta);
/* define to 0 for these tests. WIll fix up later. */ /* define to 0 for these tests. WIll fix up later. */
#define OPAL_HAVE_ATOMIC_MATH_64 0 #define OPAL_HAVE_ATOMIC_MATH_64 0
#endif #endif
#if defined(DOXYGEN) || OPAL_HAVE_ATOMIC_MATH_64 || OPAL_HAVE_ATOMIC_CMPSET_64 #if defined(DOXYGEN) || OPAL_HAVE_ATOMIC_MATH_64 || OPAL_HAVE_ATOMIC_CMPSET_64
#if OPAL_HAVE_ATOMIC_CMPSET_64
#if OPAL_HAVE_INLINE_ATOMIC_ADD_64
static inline static inline
#endif #endif
int64_t opal_atomic_add_64(volatile int64_t *addr, int64_t delta); int64_t opal_atomic_add_64(volatile int64_t *addr, int64_t delta);
#if OPAL_HAVE_ATOMIC_CMPSET_64
#if OPAL_HAVE_INLINE_ATOMIC_SUB_64
static inline static inline
#endif #endif
int64_t opal_atomic_sub_64(volatile int64_t *addr, int64_t delta); int64_t opal_atomic_sub_64(volatile int64_t *addr, int64_t delta);
#endif /* OPAL_HAVE_ATOMIC_MATH_32 */ #endif /* OPAL_HAVE_ATOMIC_MATH_32 */
#if ! OPAL_HAVE_ATOMIC_MATH_64 #if ! OPAL_HAVE_ATOMIC_MATH_64
/* fix up the value of ompi_have_atomic_math_64 to allow for C versions */ /* fix up the value of ompi_have_atomic_math_64 to allow for C versions */
#undef OPAL_HAVE_ATOMIC_MATH_64 #undef OPAL_HAVE_ATOMIC_MATH_64
@ -525,12 +588,8 @@ static inline int64_t opal_atomic_sub_ptr( volatile void* addr, void* delta );
*********************************************************************/ *********************************************************************/
#include "opal/sys/atomic_impl.h" #include "opal/sys/atomic_impl.h"
#if defined(c_plusplus) || defined(__cplusplus) #if defined(c_plusplus) || defined(__cplusplus)
} }
#endif #endif
#endif /* OPAL_SYS_ATOMIC_H */ #endif /* OPAL_SYS_ATOMIC_H */

Просмотреть файл

@ -48,6 +48,8 @@
#define OPAL_HAVE_ATOMIC_CMPSET_64 1 #define OPAL_HAVE_ATOMIC_CMPSET_64 1
#undef OPAL_HAVE_INLINE_ATOMIC_CMPSET_64
#define OPAL_HAVE_INLINE_ATOMIC_CMPSET_64 0
/********************************************************************** /**********************************************************************
* *

Просмотреть файл

@ -96,24 +96,15 @@ void opal_atomic_wmb(void)
* containing the right hex for the instructions). * containing the right hex for the instructions).
*/ */
void opal_atomic_mb(void);
#pragma mc_func opal_atomic_mb { "7c0004ac" } /* sync */ #pragma mc_func opal_atomic_mb { "7c0004ac" } /* sync */
#pragma reg_killed_by opal_atomic_mb /* none */ #pragma reg_killed_by opal_atomic_mb /* none */
void opal_atomic_rmb(void);
#pragma mc_func opal_atomic_rmb { "7c2004ac" } /* lwsync */ #pragma mc_func opal_atomic_rmb { "7c2004ac" } /* lwsync */
#pragma reg_killed_by opal_atomic_rmb /* none */ #pragma reg_killed_by opal_atomic_rmb /* none */
void opal_atomic_wmb(void);
#pragma mc_func opal_atomic_wmb { "7c0006ac" } /* eieio */ #pragma mc_func opal_atomic_wmb { "7c0006ac" } /* eieio */
#pragma reg_killed_by opal_atomic_wmb /* none */ #pragma reg_killed_by opal_atomic_wmb /* none */
#else /* end OMPI_XLC_INLINE_ASSEMBLY */
void opal_atomic_mb(void);
void opal_atomic_rmb(void);
void opal_atomic_wmb(void);
#endif #endif
/********************************************************************** /**********************************************************************
@ -166,13 +157,6 @@ static inline int opal_atomic_cmpset_rel_32(volatile int32_t *addr,
return opal_atomic_cmpset_32(addr, oldval, newval); return opal_atomic_cmpset_32(addr, oldval, newval);
} }
#else
int opal_atomic_cmpset_32(volatile int32_t *addr,
int32_t oldval, int32_t newval);
int opal_atomic_cmpset_acq_32(volatile int32_t *addr,
int32_t oldval, int32_t newval);
int opal_atomic_cmpset_rel_32(volatile int32_t *addr,
int32_t oldval, int32_t newval);
#endif /* OMPI_GCC_INLINE_ASSEMBLY */ #endif /* OMPI_GCC_INLINE_ASSEMBLY */
@ -222,15 +206,6 @@ static inline int opal_atomic_cmpset_rel_64(volatile int64_t *addr,
return opal_atomic_cmpset_64(addr, oldval, newval); return opal_atomic_cmpset_64(addr, oldval, newval);
} }
#else /* OMPI_GCC_INLINE_ASSEMBLY */
int opal_atomic_cmpset_64(volatile int64_t *addr,
int64_t oldval, int64_t newval);
int opal_atomic_cmpset_acq_64(volatile int64_t *addr,
int64_t oldval, int64_t newval);
int opal_atomic_cmpset_rel_64(volatile int64_t *addr,
int64_t oldval, int64_t newval);
#endif /* OMPI_GCC_INLINE_ASSEMBLY */ #endif /* OMPI_GCC_INLINE_ASSEMBLY */
#elif (OMPI_ASSEMBLY_ARCH == OMPI_POWERPC32) && OMPI_ASM_SUPPORT_64BIT #elif (OMPI_ASSEMBLY_ARCH == OMPI_POWERPC32) && OMPI_ASM_SUPPORT_64BIT
@ -302,15 +277,6 @@ static inline int opal_atomic_cmpset_rel_64(volatile int64_t *addr,
return opal_atomic_cmpset_64(addr, oldval, newval); return opal_atomic_cmpset_64(addr, oldval, newval);
} }
#else /* OMPI_GCC_INLINE_ASSEMBLY */
int opal_atomic_cmpset_64(volatile int64_t *addr,
int64_t oldval, int64_t newval);
int opal_atomic_cmpset_acq_64(volatile int64_t *addr,
int64_t oldval, int64_t newval);
int opal_atomic_cmpset_rel_64(volatile int64_t *addr,
int64_t oldval, int64_t newval);
#endif /* OMPI_GCC_INLINE_ASSEMBLY */ #endif /* OMPI_GCC_INLINE_ASSEMBLY */
#endif /* OMPI_ASM_SUPPORT_64BIT */ #endif /* OMPI_ASM_SUPPORT_64BIT */