26 #ifndef MD_ATOMIC_HPP_
27 #define MD_ATOMIC_HPP_ 1
48 inline uint32_t
compare_and_swap(
volatile uint32_t *p, uint32_t oldval, uint32_t newval)
53 __asm__ __volatile__ (
62 :
"=&r" (result),
"=m" (*p),
"=&r" (temp)
63 :
"r" (oldval),
"r" (newval),
"m" (*p)
79 inline uint64_t
compare_and_swap(
volatile uint64_t *p, uint64_t oldval, uint64_t newval)
84 __asm__ __volatile__ (
93 :
"=&r" (result),
"=m" (*p),
"=&r" (temp)
94 :
"r" (oldval),
"r" (newval),
"m" (*p)
107 __asm__ __volatile__ (
"dmb SY" : : :
"memory");
117 __asm__ __volatile__ (
"dmb SY" : : :
"memory");
126 __asm__ __volatile__ (
"isb" : : :
"memory");
131 #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.