mirror of
https://git.musl-libc.org/git/musl
synced 2025-01-09 16:23:23 +03:00
ea818ea834
conceptually, a_spin needs to be at least a compiler barrier, so the compiler will not optimize out loops (and the load on each iteration) while spinning. it should also be a memory barrier, or the spinning thread might keep spinning without noticing stores from other threads, thus delaying for longer than it should. ideally, an optimal a_spin implementation that avoids unnecessary cache/memory contention should be chosen for each arch, but for now, the easiest thing is to perform a useless a_cas on the calling thread's stack. |
||
---|---|---|
.. | ||
bits | ||
atomic.h | ||
crt_arch.h | ||
ksigaction.h | ||
pthread_arch.h | ||
reloc.h | ||
syscall_arch.h |