26 #ifndef MD_ATOMIC_HPP_
27 #define MD_ATOMIC_HPP_ 1
46 inline uint32_t
compare_and_swap(
volatile uint32_t *p, uint32_t oldval, uint32_t newval)
54 __asm__ __volatile__ (
57 :
"=&r" (result),
"=m" (*p)
58 :
"r" (oldval),
"r" (newval),
"r" (p));
76 inline uint64_t
compare_and_swap(
volatile uint64_t *p, uint64_t oldval, uint64_t newval)
80 __asm__ __volatile__ (
83 :
"=&r" (result),
"=m" (*p)
84 :
"r" (oldval),
"r" (newval),
"r" (p));
95 __asm__ __volatile__ (
"membar 0x0F" : : :
"memory" );
104 __asm__ __volatile__ (
"wmb" : : :
"memory");
113 __asm__ __volatile__ (
"mb" : : :
"memory");
118 #endif // MD_ATOMIC_HPP_
uint32_t compare_and_swap(volatile uint32_t *p, uint32_t oldval, uint32_t newval)
An atomic compare and swap for 32-bit integer values.
void memory_barrier(void)
A memory barrier.
uint64_t compare_and_swap(volatile uint64_t *p, uint64_t oldval, uint64_t newval)
An atomic compare and swap for 64-bit integer values.
void instruction_barrier(void)
An instruction barrier.
uint32_t generic_compare_and_swap(volatile uint32_t *p, uint32_t oldval, uint32_t newval)
A generic atomic compare and swap for 32-bit integer values.
void write_memory_barrier(void)
A write memory barrier.