]> sourceware.org Git - glibc.git/commitdiff
Consolidate non cancellable nanosleep call
authorAdhemerval Zanella <adhemerval.zanella@linaro.org>
Mon, 3 Jul 2017 18:54:02 +0000 (15:54 -0300)
committerAdhemerval Zanella <adhemerval.zanella@linaro.org>
Tue, 22 Aug 2017 17:25:08 +0000 (14:25 -0300)
This patch consolidates all the non cancellable nanosleep calls to use
the __nanosleep_nocancel identifier.  For non cancellable targets it will
be just a macro to call the default respective symbol while on Linux
will be a internal one.

Checked on x86_64-linux-gnu, x86_64-linux-gnu-x32, and i686-linux-gnu.

* nptl/pthread_mutex_timedlock.c (__pthread_mutex_timedlock): Replace
nanosleep_not_cancel with __nanosleep_nocancel.
* sysdeps/generic/not-cancel.h (nanosleep_not_cancel): Remove macro.
(__nanosleep_nocancel): New macro.
* sysdeps/unix/sysv/linux/nanosleep.c (__nanosleep_nocancel): New
function.
* sysdeps/unix/sysv/linux/not-cancel.h (nanosleep_not_cancel): Remove
macro.
(__nanosleep_nocancel): New prototype.

ChangeLog
nptl/pthread_mutex_timedlock.c
sysdeps/generic/not-cancel.h
sysdeps/unix/sysv/linux/nanosleep.c
sysdeps/unix/sysv/linux/not-cancel.h

index 912921f8eabcd82dadc587682d53cb7db3da55ad..edac4d29dcfda51a7eed29bb64b7133e8061c324 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,15 @@
 2017-08-22  Adhemerval Zanella  <adhemerval.zanella@linaro.org>
 
+       * nptl/pthread_mutex_timedlock.c (__pthread_mutex_timedlock): Replace
+       nanosleep_not_cancel with __nanosleep_nocancel.
+       * sysdeps/generic/not-cancel.h (nanosleep_not_cancel): Remove macro.
+       (__nanosleep_nocancel): New macro.
+       * sysdeps/unix/sysv/linux/nanosleep.c (__nanosleep_nocancel): New
+       function.
+       * sysdeps/unix/sysv/linux/not-cancel.h (nanosleep_not_cancel): Remove
+       macro.
+       (__nanosleep_nocancel): New prototype.
+
        * nptl/pthread_mutex_lock.c (__pthread_mutex_lock_full): Replace
        pause_not_cancel with __pause_nocancel.
        * sysdeps/generic/not-cancel.h (pause_not_cancel): Remove macro.
index d5ec3141f3469e2e7a4cd8a125c87ef4f7658b2a..45f34548a8d9f6edbf8f276c419dff55b262d181 100644 (file)
@@ -432,7 +432,7 @@ __pthread_mutex_timedlock (pthread_mutex_t *mutex,
                        --reltime.tv_sec;
                      }
                    if (reltime.tv_sec >= 0)
-                     while (nanosleep_not_cancel (&reltime, &reltime) != 0)
+                     while (__nanosleep_nocancel (&reltime, &reltime) != 0)
                        continue;
 
                    return ETIMEDOUT;
index f2140c245bf2f0a801ca372eee410aa26f585e6b..e4a8584724cef6dfa6f742714a9e71bd3557336c 100644 (file)
@@ -40,7 +40,7 @@
   __waitpid (pid, stat_loc, options)
 #define __pause_nocancel() \
   __pause ()
-#define nanosleep_not_cancel(requested_time, remaining) \
+#define __nanosleep_nocancel(requested_time, remaining) \
   __nanosleep (requested_time, remaining)
 #define sigsuspend_not_cancel(set) \
   __sigsuspend (set)
index 2d15328e40149c5754e127f0e40b41c1e6c134d1..e7ac2c06aa5f3c15a420e0f7cc9d7017f8908317 100644 (file)
@@ -18,6 +18,7 @@
 
 #include <time.h>
 #include <sysdep-cancel.h>
+#include <not-cancel.h>
 
 /* Pause execution for a number of nanoseconds.  */
 int
@@ -28,3 +29,11 @@ __nanosleep (const struct timespec *requested_time,
 }
 hidden_def (__nanosleep)
 weak_alias (__nanosleep, nanosleep)
+
+int
+__nanosleep_nocancel (const struct timespec *requested_time,
+                     struct timespec *remaining)
+{
+  return INLINE_SYSCALL_CALL (nanosleep, requested_time, remaining);
+}
+hidden_def (__nanosleep_nocancel)
index ac78cb38c340efd66c09b89b9c79fa092163dadf..577dca8297598a887b11163f47896fce9948081f 100644 (file)
@@ -26,6 +26,7 @@
 #include <unistd.h>
 #include <sys/syscall.h>
 #include <sys/wait.h>
+#include <time.h>
 
 /* Non cancellable open syscall.  */
 __typeof (open) __open_nocancel;
@@ -81,8 +82,8 @@ __typeof (pause) __pause_nocancel;
 libc_hidden_proto (__pause_nocancel)
 
 /* Uncancelable nanosleep.  */
-#define nanosleep_not_cancel(requested_time, remaining) \
-  INLINE_SYSCALL (nanosleep, 2, requested_time, remaining)
+__typeof (__nanosleep) __nanosleep_nocancel;
+hidden_proto (__nanosleep_nocancel)
 
 /* Uncancelable sigsuspend.  */
 #define sigsuspend_not_cancel(set) \
This page took 0.054161 seconds and 5 git commands to generate.