2022-04-12 05:20:17 -07:00
|
|
|
#ifndef COSMOPOLITAN_LIBC_INTRIN_SPINLOCK_H_
|
|
|
|
#define COSMOPOLITAN_LIBC_INTRIN_SPINLOCK_H_
|
|
|
|
#if !(__ASSEMBLER__ + __LINKER__ + 0)
|
2022-04-14 23:39:48 -07:00
|
|
|
#if (__GNUC__ + 0) * 100 + (__GNUC_MINOR__ + 0) >= 401 && \
|
|
|
|
!defined(__STRICT_ANSI__)
|
2022-04-12 05:20:17 -07:00
|
|
|
|
2022-04-17 12:25:10 -07:00
|
|
|
#define _spinlock(lock) \
|
|
|
|
do { \
|
|
|
|
for (;;) { \
|
|
|
|
typeof(*(lock)) x; \
|
|
|
|
__atomic_load(lock, &x, __ATOMIC_RELAXED); \
|
|
|
|
if (!x && !__sync_lock_test_and_set(lock, 1)) { \
|
|
|
|
break; \
|
|
|
|
} else { \
|
|
|
|
__builtin_ia32_pause(); \
|
|
|
|
} \
|
|
|
|
} \
|
2022-04-14 23:39:48 -07:00
|
|
|
} while (0)
|
2022-04-12 05:20:17 -07:00
|
|
|
|
2022-04-14 23:39:48 -07:00
|
|
|
#define _spunlock(lock) __sync_lock_release(lock)
|
2022-04-12 05:20:17 -07:00
|
|
|
|
2022-04-14 23:39:48 -07:00
|
|
|
#endif /* GNU 4.1+ */
|
2022-04-12 05:20:17 -07:00
|
|
|
#endif /* !(__ASSEMBLER__ + __LINKER__ + 0) */
|
|
|
|
#endif /* COSMOPOLITAN_LIBC_INTRIN_SPINLOCK_H_ */
|