Add atomic_add for 64-bit integers.

Now only GCC intrinsics are used.
This commit is contained in:
Johan Wikman 2017-03-30 12:33:20 +03:00
parent b458b63756
commit a1d1413b24
2 changed files with 18 additions and 26 deletions

View File

@ -21,11 +21,7 @@
MXS_BEGIN_DECLS
/**
* Implementation of an atomic add operation for the GCC environment, or the
* X86 processor. If we are working within GNU C then we can use the GCC
* atomic add built in function, which is portable across platforms that
* implement GCC. Otherwise, this function currently supports only X86
* architecture (without further development).
* Implementation of an atomic add operations for the GCC environment.
*
* Adds a value to the contents of a location pointed to by the first parameter.
* The add operation is atomic and the return value is the value stored in the
@ -36,7 +32,9 @@ MXS_BEGIN_DECLS
* @param value Value to be added
* @return The value of variable before the add occurred
*/
int atomic_add(int *variable, int value);
int atomic_add(int *variable, int value);
int64_t atomic_add_int64(int64_t *variable, int64_t value);
uint64_t atomic_add_uint64(uint64_t *variable, int64_t value);
/**
* @brief Impose a full memory barrier

View File

@ -11,29 +11,23 @@
* Public License.
*/
#include <maxscale/atomic.h>
/**
* @file atomic.c - Implementation of atomic operations for MaxScale
*
* @verbatim
* Revision History
*
* Date Who Description
* 10/06/13 Mark Riddoch Initial implementation
*
* @endverbatim
*/
int
atomic_add(int *variable, int value)
int atomic_add(int *variable, int value)
{
#ifdef __GNUC__
return (int) __sync_fetch_and_add (variable, value);
#else
asm volatile(
"lock; xaddl %%eax, %2;"
:"=a" (value)
: "a" (value), "m" (*variable)
: "memory" );
return value;
#endif
return __sync_fetch_and_add(variable, value);
}
int64_t atomic_add_int64(int64_t *variable, int64_t value)
{
return __sync_fetch_and_add(variable, value);
}
uint64_t atomic_add_uint64(uint64_t *variable, int64_t value)
{
return __sync_fetch_and_add(variable, value);
}