summaryrefslogtreecommitdiff
path: root/lib/pthread-rwlock.c
diff options
context:
space:
mode:
authorBruno Haible <bruno@clisp.org>2023-05-15 14:36:17 +0200
committerBruno Haible <bruno@clisp.org>2023-05-15 14:36:17 +0200
commit3a70af2168910c6ad0d59924d276f831638a52e0 (patch)
tree9268245b1a4ca43369c4a3583f36936b7c33a026 /lib/pthread-rwlock.c
parentebd843b31b8f61d3f9dd250b41c237bf5f3e01a6 (diff)
downloadgnulib-3a70af2168910c6ad0d59924d276f831638a52e0.tar.gz
gettimeofday, pthread-*, thread, thrd: Don't omit intended initializers.
* lib/gettimeofday.c (gettimeofday): List the initializers of both tv_sec and tv_usec. * lib/glthread/thread.c (gl_thread_self): List the initializers of both tv_sec and tv_nsec. * lib/pthread-cond.c (pthread_cond_wait): Likewise. * lib/thrd.c (rpl_thrd_current): Likewise. * lib/pthread-rwlock.c (MIN): New macro. (pthread_rwlock_timedrdlock, pthread_rwlock_timedwrlock): List the initializers of both tv_sec and tv_nsec. Don't modify the duration after having initialized it. * lib/pthread_mutex_timedlock.c (MIN): New macro. (pthread_mutex_timedlock): List the initializers of both tv_sec and tv_nsec. Don't modify the duration after having initialized it.
Diffstat (limited to 'lib/pthread-rwlock.c')
-rw-r--r--lib/pthread-rwlock.c20
1 files changed, 14 insertions, 6 deletions
diff --git a/lib/pthread-rwlock.c b/lib/pthread-rwlock.c
index 5087661b0b..25ff5eeb37 100644
--- a/lib/pthread-rwlock.c
+++ b/lib/pthread-rwlock.c
@@ -30,6 +30,10 @@
# include <time.h>
#endif
+#ifndef MIN
+# define MIN(a, b) ((a) < (b) ? (a) : (b))
+#endif
+
#if ((defined _WIN32 && ! defined __CYGWIN__) && USE_WINDOWS_THREADS) || !HAVE_PTHREAD_H
int
@@ -409,9 +413,11 @@ pthread_rwlock_timedrdlock (pthread_rwlock_t *lock,
return ETIMEDOUT;
/* Sleep 1 ms. */
- struct timespec duration = { .tv_nsec = 1000000 };
- if (duration.tv_nsec > remaining)
- duration.tv_nsec = remaining;
+ struct timespec duration =
+ {
+ .tv_sec = 0,
+ .tv_nsec = MIN (1000000, remaining)
+ };
nanosleep (&duration, NULL);
}
}
@@ -464,9 +470,11 @@ pthread_rwlock_timedwrlock (pthread_rwlock_t *lock,
return ETIMEDOUT;
/* Sleep 1 ms. */
- struct timespec duration = { .tv_nsec = 1000000 };
- if (duration.tv_nsec > remaining)
- duration.tv_nsec = remaining;
+ struct timespec duration =
+ {
+ .tv_sec = 0,
+ .tv_nsec = MIN (1000000, remaining)
+ };
nanosleep (&duration, NULL);
}
}