aboutsummaryrefslogtreecommitdiff
path: root/src/threading.cpp
diff options
context:
space:
mode:
authorAndreas T Jonsson <mail@andreasjonsson.se>2024-04-25 21:50:34 +0200
committerAndreas T Jonsson <mail@andreasjonsson.se>2024-04-25 21:50:34 +0200
commit3000508c027c9d30c168266d0ae276cc14de3982 (patch)
tree33e0c906f6483f9008c2b33ae68aeb2ba590bc34 /src/threading.cpp
parentce80c37c751e2c59151ad5bcbb6137c560d72d64 (diff)
Switched to native futex on NetBSD
Diffstat (limited to 'src/threading.cpp')
-rw-r--r--src/threading.cpp13
1 files changed, 9 insertions, 4 deletions
diff --git a/src/threading.cpp b/src/threading.cpp
index 79ed8e8a4..b2cfa6d8e 100644
--- a/src/threading.cpp
+++ b/src/threading.cpp
@@ -634,9 +634,15 @@ gb_internal void thread_set_name(Thread *t, char const *name) {
#endif
}
-#if defined(GB_SYSTEM_LINUX)
-#include <linux/futex.h>
+#if defined(GB_SYSTEM_LINUX) || defined(GB_SYSTEM_NETBSD)
+
#include <sys/syscall.h>
+#ifdef GB_SYSTEM_LINUX
+ #include <linux/futex.h>
+#else
+ #include <sys/futex.h>
+ #define SYS_futex SYS___futex
+#endif
gb_internal void futex_signal(Futex *addr) {
int ret = syscall(SYS_futex, addr, FUTEX_WAKE | FUTEX_PRIVATE_FLAG, 1, NULL, NULL, 0);
@@ -903,11 +909,10 @@ gb_internal void futex_wait(Futex *f, Footex val) {
} while (f->load() == val);
}
-#elif defined(GB_SYSTEM_HAIKU) || defined(GB_SYSTEM_NETBSD)
+#elif defined(GB_SYSTEM_HAIKU)
// Futex implementation taken from https://tavianator.com/2023/futex.html
-#include <signal.h>
#include <pthread.h>
#include <atomic>