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),
"=&r" (temp)
61 :
"r" (oldval),
"r" (newval),
"r" (p)
77 inline uint64_t
compare_and_swap(
volatile uint64_t *p, uint64_t oldval, uint64_t newval)
88 __asm__ __volatile__ (
"sync" : : :
"memory");
97 __asm__ __volatile__ (
"" : : :
"memory");
105 __asm__ __volatile__ (
"isync" : : :
"memory");
110 #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.
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.