diff options
| author | Kacper <kacper@mail.openlinux.dev> | 2025-12-16 17:02:05 +0100 |
|---|---|---|
| committer | Kacper <kacper@mail.openlinux.dev> | 2025-12-16 17:02:05 +0100 |
| commit | 90dad97fc07f049383903a166631e2c257f9b8c1 (patch) | |
| tree | 096cd247ecfda9e46598215a4f32aecedeedda90 /lib/libc/include/atomic.h | |
| parent | 0e832a9329cc4d4647e1ce529846073f21e66991 (diff) | |
Add support for TLS in the libc
Diffstat (limited to 'lib/libc/include/atomic.h')
| -rw-r--r-- | lib/libc/include/atomic.h | 23 |
1 files changed, 0 insertions, 23 deletions
diff --git a/lib/libc/include/atomic.h b/lib/libc/include/atomic.h deleted file mode 100644 index e0593021..00000000 --- a/lib/libc/include/atomic.h +++ /dev/null @@ -1,23 +0,0 @@ -#ifndef __LIBC_ATOMIC_H -#define __LIBC_ATOMIC_H - -#include <stdatomic.h> - -#define LIBC_LOCK(__lock) __libc_lock(&((__lock))) -#define LIBC_UNLOCK(__lock) atomic_flag_clear(&((__lock))) - -static __inline void __libc_lock(volatile atomic_flag *lock) -{ - while (atomic_flag_test_and_set_explicit(lock, memory_order_acquire)) { - unsigned int spins = 1; - do { - for (unsigned int i = 0; i < spins; i++) - __asm__ volatile("pause"); - if (spins < 64) - spins *= 2; - } while (atomic_flag_test_and_set_explicit( - lock, memory_order_relaxed)); - } -} - -#endif |
