aboutsummaryrefslogtreecommitdiff
path: root/src/threading.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/threading.cpp')
-rw-r--r--src/threading.cpp47
1 files changed, 23 insertions, 24 deletions
diff --git a/src/threading.cpp b/src/threading.cpp
index bcbdaf083..cda8fe89b 100644
--- a/src/threading.cpp
+++ b/src/threading.cpp
@@ -548,9 +548,9 @@ gb_internal void futex_wait(Futex *addr, Footex val) {
#include <sys/futex.h>
-gb_internal void futex_signal(Futex *addr) {
+gb_internal void futex_signal(Futex *f) {
for (;;) {
- int ret = futex((volatile uint32_t *)addr, FUTEX_WAKE | FUTEX_PRIVATE_FLAG, 1, NULL, NULL);
+ int ret = futex((volatile uint32_t *)f, FUTEX_WAKE | FUTEX_PRIVATE_FLAG, 1, NULL, NULL);
if (ret == -1) {
if (errno == ETIMEDOUT || errno == EINTR) {
continue;
@@ -565,9 +565,9 @@ gb_internal void futex_signal(Futex *addr) {
}
-gb_internal void futex_broadcast(Futex *addr) {
+gb_internal void futex_broadcast(Futex *f) {
for (;;) {
- int ret = futex((volatile uint32_t *)addr, FUTEX_WAKE | FUTEX_PRIVATE_FLAG, INT32_MAX, NULL, NULL);
+ int ret = futex((volatile uint32_t *)f, FUTEX_WAKE | FUTEX_PRIVATE_FLAG, INT32_MAX, NULL, NULL);
if (ret == -1) {
if (errno == ETIMEDOUT || errno == EINTR) {
continue;
@@ -581,11 +581,11 @@ gb_internal void futex_broadcast(Futex *addr) {
}
}
-gb_internal void futex_wait(Futex *addr, Footex val) {
+gb_internal void futex_wait(Futex *f, Footex val) {
for (;;) {
- int ret = futex((volatile uint32_t *)addr, FUTEX_WAIT | FUTEX_PRIVATE_FLAG, val, NULL, NULL);
+ int ret = futex((volatile uint32_t *)f, FUTEX_WAIT | FUTEX_PRIVATE_FLAG, val, NULL, NULL);
if (ret == -1) {
- if (*addr != val) {
+ if (*f != val) {
return;
}
@@ -607,9 +607,9 @@ gb_internal void futex_wait(Futex *addr, Footex val) {
extern "C" int __ulock_wait(uint32_t operation, void *addr, uint64_t value, uint32_t timeout); /* timeout is specified in microseconds */
extern "C" int __ulock_wake(uint32_t operation, void *addr, uint64_t wake_value);
-gb_internal void futex_signal(Futex *addr) {
+gb_internal void futex_signal(Futex *f) {
for (;;) {
- int ret = __ulock_wake(UL_COMPARE_AND_WAIT | ULF_NO_ERRNO, addr, 0);
+ int ret = __ulock_wake(UL_COMPARE_AND_WAIT | ULF_NO_ERRNO, f, 0);
if (ret >= 0) {
return;
}
@@ -623,9 +623,10 @@ gb_internal void futex_signal(Futex *addr) {
}
}
-gb_internal void futex_broadcast(Futex *addr) {
+gb_internal void futex_broadcast(Futex *f) {
for (;;) {
- int ret = __ulock_wake(UL_COMPARE_AND_WAIT | ULF_NO_ERRNO, addr, 0);
+ enum { ULF_WAKE_ALL = 0x00000100 };
+ int ret = __ulock_wake(UL_COMPARE_AND_WAIT | ULF_NO_ERRNO | ULF_WAKE_ALL, f, 0);
if (ret >= 0) {
return;
}
@@ -639,12 +640,11 @@ gb_internal void futex_broadcast(Futex *addr) {
}
}
-gb_internal void futex_wait(Futex *addr, Footex val) {
+gb_internal void futex_wait(Futex *f, Footex val) {
for (;;) {
- enum { ULF_WAKE_ALL = 0x00000100 };
- int ret = __ulock_wait(UL_COMPARE_AND_WAIT | ULF_NO_ERRNO | ULF_WAKE_ALL, addr, val, 0);
+ int ret = __ulock_wait(UL_COMPARE_AND_WAIT | ULF_NO_ERRNO, f, val, 0);
if (ret >= 0) {
- if (*addr != val) {
+ if (*f != val) {
return;
}
continue;
@@ -661,19 +661,18 @@ gb_internal void futex_wait(Futex *addr, Footex val) {
}
#elif defined(GB_SYSTEM_WINDOWS)
-gb_internal void futex_signal(Futex *addr) {
- WakeByAddressSingle((void *)addr);
+gb_internal void futex_signal(Futex *f) {
+ WakeByAddressSingle(f);
}
-gb_internal void futex_broadcast(Futex *addr) {
- WakeByAddressAll((void *)addr);
+gb_internal void futex_broadcast(Futex *f) {
+ WakeByAddressAll(f);
}
-gb_internal void futex_wait(Futex *addr, Footex val) {
- for (;;) {
- WaitOnAddress(addr, (void *)&val, sizeof(val), INFINITE);
- if (*addr != val) break;
- }
+gb_internal void futex_wait(Futex *f, Footex val) {
+ do {
+ WaitOnAddress(f, (void *)&val, sizeof(val), INFINITE);
+ } while (f->load() == val);
}
#endif