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)
51 __asm__ __volatile__ (
60 :
"=&r" (result),
"=m" (*p),
"=&r" (temp)
61 :
"r" (oldval),
"r" (newval),
"m" (*p));
76 inline uint64_t
compare_and_swap(
volatile uint64_t *p, uint64_t oldval, uint64_t newval)
81 __asm__ __volatile__ (
90 :
"=&r" (result),
"=m" (*p),
"=&r" (temp)
91 :
"r" (oldval),
"r" (newval),
"m" (*p));
102 __asm__ __volatile__ (
"mb" : : :
"memory");
111 __asm__ __volatile__ (
"wmb" : : :
"memory");
120 __asm__ __volatile__ (
"mb" : : :
"memory");
125 #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.
void write_memory_barrier(void)
A write memory barrier.
void instruction_barrier(void)
An instruction barrier.