diff mbox series

[03/14] Consolidate non cancellable write call

Message ID 1501765874-6201-4-git-send-email-adhemerval.zanella@linaro.org
State Accepted
Commit c647fb885cb678471f6b6a66f394b4ca5515a016
Headers show
Series None | expand

Commit Message

Adhemerval Zanella Netto Aug. 3, 2017, 1:11 p.m. UTC
This patch consolidates all the non cancellable write calls to use
the __write_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.

	* sysdeps/generic/not-cancel.h (write_not_cancel): Remove macro.
	(__write_nocancel): New macro.
	* sysdeps/unix/sysv/linux/not-cancel.h (__write_nocancel):
	Rewrite as a function prototype.
	(write_not_cancel): Remove macro.
	* sysdeps/unix/sysv/linux/write.c (__write_nocancel): New function.
	* gmon/gmon.c (ERR): Replace write_not_cancel with __write_nocancel.
	(write_gmon): Likewise.
	* libio/fileops.c (_IO_new_file_write): Likewise.
	* login/utmp_file.c (pututline_file): Likewise.
	(updwtmp_file): Likewise.
	* stdio-common/psiginfo.c (psiginfo): Likewise.
	* sysdeps/posix/spawni.c (__spawni_child): Likewise.
	* sysdeps/unix/sysv/linux/gethostid.c (sethostid): Likewise.
	* sysdeps/unix/sysv/linux/libc_fatal.c (backtrace_and_maps):
	Likewise.
	* sysdeps/unix/sysv/linux/pthread_setname.c (pthread_setname_np):
	Likewise.
---
 ChangeLog                                 | 19 +++++++++++++++++++
 gmon/gmon.c                               |  4 ++--
 libio/fileops.c                           |  2 +-
 login/utmp_file.c                         |  4 ++--
 stdio-common/psiginfo.c                   |  2 +-
 sysdeps/generic/not-cancel.h              |  2 +-
 sysdeps/posix/spawni.c                    |  3 +--
 sysdeps/unix/sysv/linux/gethostid.c       |  2 +-
 sysdeps/unix/sysv/linux/libc_fatal.c      |  4 ++--
 sysdeps/unix/sysv/linux/not-cancel.h      |  8 ++------
 sysdeps/unix/sysv/linux/pthread_setname.c |  2 +-
 sysdeps/unix/sysv/linux/write.c           | 12 ++++++++++++
 12 files changed, 45 insertions(+), 19 deletions(-)

-- 
2.7.4

Comments

Adhemerval Zanella Netto Aug. 18, 2017, 1:36 p.m. UTC | #1
Since this is a refactor, if no one opposes I will commit it shortly.

On 03/08/2017 10:11, Adhemerval Zanella wrote:
> This patch consolidates all the non cancellable write calls to use

> the __write_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.

> 

> 	* sysdeps/generic/not-cancel.h (write_not_cancel): Remove macro.

> 	(__write_nocancel): New macro.

> 	* sysdeps/unix/sysv/linux/not-cancel.h (__write_nocancel):

> 	Rewrite as a function prototype.

> 	(write_not_cancel): Remove macro.

> 	* sysdeps/unix/sysv/linux/write.c (__write_nocancel): New function.

> 	* gmon/gmon.c (ERR): Replace write_not_cancel with __write_nocancel.

> 	(write_gmon): Likewise.

> 	* libio/fileops.c (_IO_new_file_write): Likewise.

> 	* login/utmp_file.c (pututline_file): Likewise.

> 	(updwtmp_file): Likewise.

> 	* stdio-common/psiginfo.c (psiginfo): Likewise.

> 	* sysdeps/posix/spawni.c (__spawni_child): Likewise.

> 	* sysdeps/unix/sysv/linux/gethostid.c (sethostid): Likewise.

> 	* sysdeps/unix/sysv/linux/libc_fatal.c (backtrace_and_maps):

> 	Likewise.

> 	* sysdeps/unix/sysv/linux/pthread_setname.c (pthread_setname_np):

> 	Likewise.

> ---

>  ChangeLog                                 | 19 +++++++++++++++++++

>  gmon/gmon.c                               |  4 ++--

>  libio/fileops.c                           |  2 +-

>  login/utmp_file.c                         |  4 ++--

>  stdio-common/psiginfo.c                   |  2 +-

>  sysdeps/generic/not-cancel.h              |  2 +-

>  sysdeps/posix/spawni.c                    |  3 +--

>  sysdeps/unix/sysv/linux/gethostid.c       |  2 +-

>  sysdeps/unix/sysv/linux/libc_fatal.c      |  4 ++--

>  sysdeps/unix/sysv/linux/not-cancel.h      |  8 ++------

>  sysdeps/unix/sysv/linux/pthread_setname.c |  2 +-

>  sysdeps/unix/sysv/linux/write.c           | 12 ++++++++++++

>  12 files changed, 45 insertions(+), 19 deletions(-)

> 

> diff --git a/ChangeLog b/ChangeLog

> index 5199a69..0bc21b6 100644

> --- a/ChangeLog

> +++ b/ChangeLog

> @@ -1,5 +1,24 @@

>  2017-08-02  Adhemerval Zanella  <adhemerval.zanella@linaro.org>

>  

> +	* sysdeps/generic/not-cancel.h (write_not_cancel): Remove macro.

> +	(__write_nocancel): New macro.

> +	* sysdeps/unix/sysv/linux/not-cancel.h (__write_nocancel):

> +	Rewrite as a function prototype.

> +	(write_not_cancel): Remove macro.

> +	* sysdeps/unix/sysv/linux/write.c (__write_nocancel): New function.

> +	* gmon/gmon.c (ERR): Replace write_not_cancel with __write_nocancel.

> +	(write_gmon): Likewise.

> +	* libio/fileops.c (_IO_new_file_write): Likewise.

> +	* login/utmp_file.c (pututline_file): Likewise.

> +	(updwtmp_file): Likewise.

> +	* stdio-common/psiginfo.c (psiginfo): Likewise.

> +	* sysdeps/posix/spawni.c (__spawni_child): Likewise.

> +	* sysdeps/unix/sysv/linux/gethostid.c (sethostid): Likewise.

> +	* sysdeps/unix/sysv/linux/libc_fatal.c (backtrace_and_maps):

> +	Likewise.

> +	* sysdeps/unix/sysv/linux/pthread_setname.c (pthread_setname_np):

> +	Likewise.

> +

>  	* sysdeps/generic/not-cancel.h (read_not_cancel): Remove macro.

>  	(__read_nocancel): New macro.

>  	* sysdeps/unix/sysv/linux/Versions (libc) [GLIBC_PRIVATE]: Add

> diff --git a/gmon/gmon.c b/gmon/gmon.c

> index 87c3c4e..e7701b9 100644

> --- a/gmon/gmon.c

> +++ b/gmon/gmon.c

> @@ -58,7 +58,7 @@ struct gmonparam _gmonparam attribute_hidden = { GMON_PROF_OFF };

>  static int	s_scale;

>  #define		SCALE_1_TO_1	0x10000L

>  

> -#define ERR(s) write_not_cancel (STDERR_FILENO, s, sizeof (s) - 1)

> +#define ERR(s) __write_nocancel (STDERR_FILENO, s, sizeof (s) - 1)

>  

>  void moncontrol (int mode);

>  void __moncontrol (int mode);

> @@ -375,7 +375,7 @@ write_gmon (void)

>      memcpy (&ghdr.cookie[0], GMON_MAGIC, sizeof (ghdr.cookie));

>      ghdr.version = GMON_VERSION;

>      memset (ghdr.spare, '\0', sizeof (ghdr.spare));

> -    write_not_cancel (fd, &ghdr, sizeof (struct gmon_hdr));

> +    __write_nocancel (fd, &ghdr, sizeof (struct gmon_hdr));

>  

>      /* write PC histogram: */

>      write_hist (fd);

> diff --git a/libio/fileops.c b/libio/fileops.c

> index 80bd3f5..f025178 100644

> --- a/libio/fileops.c

> +++ b/libio/fileops.c

> @@ -1251,7 +1251,7 @@ _IO_new_file_write (_IO_FILE *f, const void *data, _IO_ssize_t n)

>      {

>        _IO_ssize_t count = (__builtin_expect (f->_flags2

>  					     & _IO_FLAGS2_NOTCANCEL, 0)

> -			   ? write_not_cancel (f->_fileno, data, to_do)

> +			   ? __write_nocancel (f->_fileno, data, to_do)

>  			   : write (f->_fileno, data, to_do));

>        if (count < 0)

>  	{

> diff --git a/login/utmp_file.c b/login/utmp_file.c

> index 61d03d6..26e3f4b 100644

> --- a/login/utmp_file.c

> +++ b/login/utmp_file.c

> @@ -444,7 +444,7 @@ pututline_file (const struct utmp *data)

>      }

>  

>    /* Write the new data.  */

> -  if (write_not_cancel (file_fd, data, sizeof (struct utmp))

> +  if (__write_nocancel (file_fd, data, sizeof (struct utmp))

>        != sizeof (struct utmp))

>      {

>        /* If we appended a new record this is only partially written.

> @@ -505,7 +505,7 @@ updwtmp_file (const char *file, const struct utmp *utmp)

>    /* Write the entry.  If we can't write all the bytes, reset the file

>       size back to the original size.  That way, no partial entries

>       will remain.  */

> -  if (write_not_cancel (fd, utmp, sizeof (struct utmp))

> +  if (__write_nocancel (fd, utmp, sizeof (struct utmp))

>        != sizeof (struct utmp))

>      {

>        __ftruncate64 (fd, offset);

> diff --git a/stdio-common/psiginfo.c b/stdio-common/psiginfo.c

> index 6954a42..7bf2e2d 100644

> --- a/stdio-common/psiginfo.c

> +++ b/stdio-common/psiginfo.c

> @@ -199,5 +199,5 @@ Signal generated by the completion of an I/O request");

>  

>    fclose (fp);

>  

> -  write_not_cancel (STDERR_FILENO, buf, strlen (buf));

> +  __write_nocancel (STDERR_FILENO, buf, strlen (buf));

>  }

> diff --git a/sysdeps/generic/not-cancel.h b/sysdeps/generic/not-cancel.h

> index 4fada2f..e91cb6c 100644

> --- a/sysdeps/generic/not-cancel.h

> +++ b/sysdeps/generic/not-cancel.h

> @@ -36,7 +36,7 @@

>    (void) __close (fd)

>  #define __read_nocancel(fd, buf, n) \

>    __read (fd, buf, n)

> -#define write_not_cancel(fd, buf, n) \

> +#define __write_nocancel(fd, buf, n) \

>    __write (fd, buf, n)

>  #define writev_not_cancel_no_status(fd, iov, n) \

>    (void) __writev (fd, iov, n)

> diff --git a/sysdeps/posix/spawni.c b/sysdeps/posix/spawni.c

> index 823db11..a43b841 100644

> --- a/sysdeps/posix/spawni.c

> +++ b/sysdeps/posix/spawni.c

> @@ -233,8 +233,7 @@ fail:

>       abort(), but that seems needlessly harsh.  */

>    ret = errno ? : ECHILD;

>    if (ret)

> -    /* Since sizeof errno < PIPE_BUF, the write is atomic. */

> -    while (write_not_cancel (args->pipe[1], &ret, sizeof (ret)) < 0);

> +    while (__write_nocancel (args->pipe[1], &ret, sizeof (ret)) < 0);

>  

>    _exit (SPAWN_ERROR);

>  }

> diff --git a/sysdeps/unix/sysv/linux/gethostid.c b/sysdeps/unix/sysv/linux/gethostid.c

> index 6e19dee..11c7e73 100644

> --- a/sysdeps/unix/sysv/linux/gethostid.c

> +++ b/sysdeps/unix/sysv/linux/gethostid.c

> @@ -51,7 +51,7 @@ sethostid (long int id)

>    if (fd < 0)

>      return -1;

>  

> -  written = write_not_cancel (fd, &id32, sizeof (id32));

> +  written = __write_nocancel (fd, &id32, sizeof (id32));

>  

>    close_not_cancel_no_status (fd);

>  

> diff --git a/sysdeps/unix/sysv/linux/libc_fatal.c b/sysdeps/unix/sysv/linux/libc_fatal.c

> index ca838a7..c7c6a07 100644

> --- a/sysdeps/unix/sysv/linux/libc_fatal.c

> +++ b/sysdeps/unix/sysv/linux/libc_fatal.c

> @@ -48,7 +48,7 @@ backtrace_and_maps (int do_abort, bool written, int fd)

>        if (n > 2)

>          {

>  #define strnsize(str) str, strlen (str)

> -#define writestr(str) write_not_cancel (fd, str)

> +#define writestr(str) __write_nocancel (fd, str)

>            writestr (strnsize ("======= Backtrace: =========\n"));

>            __backtrace_symbols_fd (addrs + 1, n - 1, fd);

>  

> @@ -57,7 +57,7 @@ backtrace_and_maps (int do_abort, bool written, int fd)

>            char buf[1024];

>            ssize_t n2;

>            while ((n2 = __read_nocancel (fd2, buf, sizeof (buf))) > 0)

> -            if (write_not_cancel (fd, buf, n2) != n2)

> +            if (__write_nocancel (fd, buf, n2) != n2)

>                break;

>            close_not_cancel_no_status (fd2);

>          }

> diff --git a/sysdeps/unix/sysv/linux/not-cancel.h b/sysdeps/unix/sysv/linux/not-cancel.h

> index 3d26075..84dc72a 100644

> --- a/sysdeps/unix/sysv/linux/not-cancel.h

> +++ b/sysdeps/unix/sysv/linux/not-cancel.h

> @@ -39,8 +39,8 @@ __typeof (__read) __read_nocancel;

>  libc_hidden_proto (__read_nocancel)

>  

>  /* Uncancelable write.  */

> -#define __write_nocancel(fd, buf, len) \

> -  INLINE_SYSCALL (write, 3, fd, buf, len)

> +__typeof (__write) __write_nocancel;

> +libc_hidden_proto (__write_nocancel)

>  

>  /* Uncancelable openat.  */

>  #define openat_not_cancel(fd, fname, oflag, mode) \

> @@ -61,10 +61,6 @@ libc_hidden_proto (__read_nocancel)

>    (void) ({ INTERNAL_SYSCALL_DECL (err);				      \

>  	    INTERNAL_SYSCALL (close, err, 1, (fd)); })

>  

> -/* Uncancelable write.  */

> -#define write_not_cancel(fd, buf, n) \

> -  __write_nocancel (fd, buf, n)

> -

>  /* Uncancelable writev.  */

>  #define writev_not_cancel_no_status(fd, iov, n) \

>    (void) ({ INTERNAL_SYSCALL_DECL (err);				      \

> diff --git a/sysdeps/unix/sysv/linux/pthread_setname.c b/sysdeps/unix/sysv/linux/pthread_setname.c

> index 93f0e9d..c5e9a33 100644

> --- a/sysdeps/unix/sysv/linux/pthread_setname.c

> +++ b/sysdeps/unix/sysv/linux/pthread_setname.c

> @@ -51,7 +51,7 @@ pthread_setname_np (pthread_t th, const char *name)

>      return errno;

>  

>    int res = 0;

> -  ssize_t n = TEMP_FAILURE_RETRY (write_not_cancel (fd, name, name_len));

> +  ssize_t n = TEMP_FAILURE_RETRY (__write_nocancel (fd, name, name_len));

>    if (n < 0)

>      res = errno;

>    else if (n != name_len)

> diff --git a/sysdeps/unix/sysv/linux/write.c b/sysdeps/unix/sysv/linux/write.c

> index d495145..f8896eb 100644

> --- a/sysdeps/unix/sysv/linux/write.c

> +++ b/sysdeps/unix/sysv/linux/write.c

> @@ -18,6 +18,7 @@

>  

>  #include <unistd.h>

>  #include <sysdep-cancel.h>

> +#include <not-cancel.h>

>  

>  /* Write NBYTES of BUF to FD.  Return the number written, or -1.  */

>  ssize_t

> @@ -31,3 +32,14 @@ weak_alias (__libc_write, __write)

>  libc_hidden_weak (__write)

>  weak_alias (__libc_write, write)

>  libc_hidden_weak (write)

> +

> +#if !IS_IN (rtld)

> +ssize_t

> +__write_nocancel (int fd, const void *buf, size_t nbytes)

> +{

> +  return INLINE_SYSCALL_CALL (write, fd, buf, nbytes);

> +}

> +#else

> +strong_alias (__libc_write, __write_nocancel)

> +#endif

> +libc_hidden_def (__write_nocancel)

>
diff mbox series

Patch

diff --git a/ChangeLog b/ChangeLog
index 5199a69..0bc21b6 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,24 @@ 
 2017-08-02  Adhemerval Zanella  <adhemerval.zanella@linaro.org>
 
+	* sysdeps/generic/not-cancel.h (write_not_cancel): Remove macro.
+	(__write_nocancel): New macro.
+	* sysdeps/unix/sysv/linux/not-cancel.h (__write_nocancel):
+	Rewrite as a function prototype.
+	(write_not_cancel): Remove macro.
+	* sysdeps/unix/sysv/linux/write.c (__write_nocancel): New function.
+	* gmon/gmon.c (ERR): Replace write_not_cancel with __write_nocancel.
+	(write_gmon): Likewise.
+	* libio/fileops.c (_IO_new_file_write): Likewise.
+	* login/utmp_file.c (pututline_file): Likewise.
+	(updwtmp_file): Likewise.
+	* stdio-common/psiginfo.c (psiginfo): Likewise.
+	* sysdeps/posix/spawni.c (__spawni_child): Likewise.
+	* sysdeps/unix/sysv/linux/gethostid.c (sethostid): Likewise.
+	* sysdeps/unix/sysv/linux/libc_fatal.c (backtrace_and_maps):
+	Likewise.
+	* sysdeps/unix/sysv/linux/pthread_setname.c (pthread_setname_np):
+	Likewise.
+
 	* sysdeps/generic/not-cancel.h (read_not_cancel): Remove macro.
 	(__read_nocancel): New macro.
 	* sysdeps/unix/sysv/linux/Versions (libc) [GLIBC_PRIVATE]: Add
diff --git a/gmon/gmon.c b/gmon/gmon.c
index 87c3c4e..e7701b9 100644
--- a/gmon/gmon.c
+++ b/gmon/gmon.c
@@ -58,7 +58,7 @@  struct gmonparam _gmonparam attribute_hidden = { GMON_PROF_OFF };
 static int	s_scale;
 #define		SCALE_1_TO_1	0x10000L
 
-#define ERR(s) write_not_cancel (STDERR_FILENO, s, sizeof (s) - 1)
+#define ERR(s) __write_nocancel (STDERR_FILENO, s, sizeof (s) - 1)
 
 void moncontrol (int mode);
 void __moncontrol (int mode);
@@ -375,7 +375,7 @@  write_gmon (void)
     memcpy (&ghdr.cookie[0], GMON_MAGIC, sizeof (ghdr.cookie));
     ghdr.version = GMON_VERSION;
     memset (ghdr.spare, '\0', sizeof (ghdr.spare));
-    write_not_cancel (fd, &ghdr, sizeof (struct gmon_hdr));
+    __write_nocancel (fd, &ghdr, sizeof (struct gmon_hdr));
 
     /* write PC histogram: */
     write_hist (fd);
diff --git a/libio/fileops.c b/libio/fileops.c
index 80bd3f5..f025178 100644
--- a/libio/fileops.c
+++ b/libio/fileops.c
@@ -1251,7 +1251,7 @@  _IO_new_file_write (_IO_FILE *f, const void *data, _IO_ssize_t n)
     {
       _IO_ssize_t count = (__builtin_expect (f->_flags2
 					     & _IO_FLAGS2_NOTCANCEL, 0)
-			   ? write_not_cancel (f->_fileno, data, to_do)
+			   ? __write_nocancel (f->_fileno, data, to_do)
 			   : write (f->_fileno, data, to_do));
       if (count < 0)
 	{
diff --git a/login/utmp_file.c b/login/utmp_file.c
index 61d03d6..26e3f4b 100644
--- a/login/utmp_file.c
+++ b/login/utmp_file.c
@@ -444,7 +444,7 @@  pututline_file (const struct utmp *data)
     }
 
   /* Write the new data.  */
-  if (write_not_cancel (file_fd, data, sizeof (struct utmp))
+  if (__write_nocancel (file_fd, data, sizeof (struct utmp))
       != sizeof (struct utmp))
     {
       /* If we appended a new record this is only partially written.
@@ -505,7 +505,7 @@  updwtmp_file (const char *file, const struct utmp *utmp)
   /* Write the entry.  If we can't write all the bytes, reset the file
      size back to the original size.  That way, no partial entries
      will remain.  */
-  if (write_not_cancel (fd, utmp, sizeof (struct utmp))
+  if (__write_nocancel (fd, utmp, sizeof (struct utmp))
       != sizeof (struct utmp))
     {
       __ftruncate64 (fd, offset);
diff --git a/stdio-common/psiginfo.c b/stdio-common/psiginfo.c
index 6954a42..7bf2e2d 100644
--- a/stdio-common/psiginfo.c
+++ b/stdio-common/psiginfo.c
@@ -199,5 +199,5 @@  Signal generated by the completion of an I/O request");
 
   fclose (fp);
 
-  write_not_cancel (STDERR_FILENO, buf, strlen (buf));
+  __write_nocancel (STDERR_FILENO, buf, strlen (buf));
 }
diff --git a/sysdeps/generic/not-cancel.h b/sysdeps/generic/not-cancel.h
index 4fada2f..e91cb6c 100644
--- a/sysdeps/generic/not-cancel.h
+++ b/sysdeps/generic/not-cancel.h
@@ -36,7 +36,7 @@ 
   (void) __close (fd)
 #define __read_nocancel(fd, buf, n) \
   __read (fd, buf, n)
-#define write_not_cancel(fd, buf, n) \
+#define __write_nocancel(fd, buf, n) \
   __write (fd, buf, n)
 #define writev_not_cancel_no_status(fd, iov, n) \
   (void) __writev (fd, iov, n)
diff --git a/sysdeps/posix/spawni.c b/sysdeps/posix/spawni.c
index 823db11..a43b841 100644
--- a/sysdeps/posix/spawni.c
+++ b/sysdeps/posix/spawni.c
@@ -233,8 +233,7 @@  fail:
      abort(), but that seems needlessly harsh.  */
   ret = errno ? : ECHILD;
   if (ret)
-    /* Since sizeof errno < PIPE_BUF, the write is atomic. */
-    while (write_not_cancel (args->pipe[1], &ret, sizeof (ret)) < 0);
+    while (__write_nocancel (args->pipe[1], &ret, sizeof (ret)) < 0);
 
   _exit (SPAWN_ERROR);
 }
diff --git a/sysdeps/unix/sysv/linux/gethostid.c b/sysdeps/unix/sysv/linux/gethostid.c
index 6e19dee..11c7e73 100644
--- a/sysdeps/unix/sysv/linux/gethostid.c
+++ b/sysdeps/unix/sysv/linux/gethostid.c
@@ -51,7 +51,7 @@  sethostid (long int id)
   if (fd < 0)
     return -1;
 
-  written = write_not_cancel (fd, &id32, sizeof (id32));
+  written = __write_nocancel (fd, &id32, sizeof (id32));
 
   close_not_cancel_no_status (fd);
 
diff --git a/sysdeps/unix/sysv/linux/libc_fatal.c b/sysdeps/unix/sysv/linux/libc_fatal.c
index ca838a7..c7c6a07 100644
--- a/sysdeps/unix/sysv/linux/libc_fatal.c
+++ b/sysdeps/unix/sysv/linux/libc_fatal.c
@@ -48,7 +48,7 @@  backtrace_and_maps (int do_abort, bool written, int fd)
       if (n > 2)
         {
 #define strnsize(str) str, strlen (str)
-#define writestr(str) write_not_cancel (fd, str)
+#define writestr(str) __write_nocancel (fd, str)
           writestr (strnsize ("======= Backtrace: =========\n"));
           __backtrace_symbols_fd (addrs + 1, n - 1, fd);
 
@@ -57,7 +57,7 @@  backtrace_and_maps (int do_abort, bool written, int fd)
           char buf[1024];
           ssize_t n2;
           while ((n2 = __read_nocancel (fd2, buf, sizeof (buf))) > 0)
-            if (write_not_cancel (fd, buf, n2) != n2)
+            if (__write_nocancel (fd, buf, n2) != n2)
               break;
           close_not_cancel_no_status (fd2);
         }
diff --git a/sysdeps/unix/sysv/linux/not-cancel.h b/sysdeps/unix/sysv/linux/not-cancel.h
index 3d26075..84dc72a 100644
--- a/sysdeps/unix/sysv/linux/not-cancel.h
+++ b/sysdeps/unix/sysv/linux/not-cancel.h
@@ -39,8 +39,8 @@  __typeof (__read) __read_nocancel;
 libc_hidden_proto (__read_nocancel)
 
 /* Uncancelable write.  */
-#define __write_nocancel(fd, buf, len) \
-  INLINE_SYSCALL (write, 3, fd, buf, len)
+__typeof (__write) __write_nocancel;
+libc_hidden_proto (__write_nocancel)
 
 /* Uncancelable openat.  */
 #define openat_not_cancel(fd, fname, oflag, mode) \
@@ -61,10 +61,6 @@  libc_hidden_proto (__read_nocancel)
   (void) ({ INTERNAL_SYSCALL_DECL (err);				      \
 	    INTERNAL_SYSCALL (close, err, 1, (fd)); })
 
-/* Uncancelable write.  */
-#define write_not_cancel(fd, buf, n) \
-  __write_nocancel (fd, buf, n)
-
 /* Uncancelable writev.  */
 #define writev_not_cancel_no_status(fd, iov, n) \
   (void) ({ INTERNAL_SYSCALL_DECL (err);				      \
diff --git a/sysdeps/unix/sysv/linux/pthread_setname.c b/sysdeps/unix/sysv/linux/pthread_setname.c
index 93f0e9d..c5e9a33 100644
--- a/sysdeps/unix/sysv/linux/pthread_setname.c
+++ b/sysdeps/unix/sysv/linux/pthread_setname.c
@@ -51,7 +51,7 @@  pthread_setname_np (pthread_t th, const char *name)
     return errno;
 
   int res = 0;
-  ssize_t n = TEMP_FAILURE_RETRY (write_not_cancel (fd, name, name_len));
+  ssize_t n = TEMP_FAILURE_RETRY (__write_nocancel (fd, name, name_len));
   if (n < 0)
     res = errno;
   else if (n != name_len)
diff --git a/sysdeps/unix/sysv/linux/write.c b/sysdeps/unix/sysv/linux/write.c
index d495145..f8896eb 100644
--- a/sysdeps/unix/sysv/linux/write.c
+++ b/sysdeps/unix/sysv/linux/write.c
@@ -18,6 +18,7 @@ 
 
 #include <unistd.h>
 #include <sysdep-cancel.h>
+#include <not-cancel.h>
 
 /* Write NBYTES of BUF to FD.  Return the number written, or -1.  */
 ssize_t
@@ -31,3 +32,14 @@  weak_alias (__libc_write, __write)
 libc_hidden_weak (__write)
 weak_alias (__libc_write, write)
 libc_hidden_weak (write)
+
+#if !IS_IN (rtld)
+ssize_t
+__write_nocancel (int fd, const void *buf, size_t nbytes)
+{
+  return INLINE_SYSCALL_CALL (write, fd, buf, nbytes);
+}
+#else
+strong_alias (__libc_write, __write_nocancel)
+#endif
+libc_hidden_def (__write_nocancel)