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
Этот коммит содержится в:
родитель
cb7c435a9c
Коммит
a20a1a806a
@ -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 */
|
||||||
|
Загрузка…
Ссылка в новой задаче
Block a user