summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/sem.c9
-rw-r--r--test/test_sem.c2
2 files changed, 10 insertions, 1 deletions
diff --git a/src/sem.c b/src/sem.c
index d9aa6d1..cb00c3a 100644
--- a/src/sem.c
+++ b/src/sem.c
@@ -178,8 +178,11 @@ zix_sem_timed_wait(ZixSem* sem,
const uint32_t seconds,
const uint32_t nanoseconds)
{
+# define NS_PER_SECOND 1000000000L
+
# if !USE_CLOCK_GETTIME || !USE_SEM_TIMEDWAIT
return ZIX_STATUS_NOT_SUPPORTED;
+
# else
struct timespec ts = {0, 0};
@@ -188,6 +191,10 @@ zix_sem_timed_wait(ZixSem* sem,
if (!(r = clock_gettime(CLOCK_REALTIME, &ts))) {
ts.tv_sec += (time_t)seconds;
ts.tv_nsec += (long)nanoseconds;
+ if (ts.tv_nsec >= NS_PER_SECOND) {
+ ts.tv_nsec -= NS_PER_SECOND;
+ ts.tv_sec++;
+ }
while ((r = sem_timedwait(&sem->sem, &ts)) && errno == EINTR) {
// Interrupted, try again
@@ -196,6 +203,8 @@ zix_sem_timed_wait(ZixSem* sem,
return zix_errno_status_if(r);
# endif
+
+# undef NS_PER_SECOND
}
#endif
diff --git a/test/test_sem.c b/test/test_sem.c
index 36d01c5..9517659 100644
--- a/test/test_sem.c
+++ b/test/test_sem.c
@@ -57,7 +57,7 @@ test_timed_wait(void)
{
assert(!zix_sem_init(&sem, 0));
assert(zix_sem_timed_wait(&sem, 0, 0) == ZIX_STATUS_TIMEOUT);
- assert(zix_sem_timed_wait(&sem, 0, 5000000) == ZIX_STATUS_TIMEOUT);
+ assert(zix_sem_timed_wait(&sem, 0, 999999999) == ZIX_STATUS_TIMEOUT);
assert(!zix_sem_post(&sem));
assert(!zix_sem_timed_wait(&sem, 5, 0));
assert(!zix_sem_post(&sem));