]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
Update.
authorUlrich Drepper <drepper@redhat.com>
Tue, 20 Apr 2004 04:31:12 +0000 (04:31 +0000)
committerUlrich Drepper <drepper@redhat.com>
Tue, 20 Apr 2004 04:31:12 +0000 (04:31 +0000)
2004-04-19  Ulrich Drepper  <drepper@redhat.com>

* sysdeps/unix/sysv/linux/mq_unlink.c: Rewrite to produce more
compact code.

ChangeLog
linuxthreads/ChangeLog
nptl/ChangeLog
sysdeps/unix/sysv/linux/mq_unlink.c

index 504cbbe5f34947cca6b6d5ac679397d63eb737fd..1f2744df7a97d5d3d56c4f965d9f248cd858d171 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+2004-04-19  Ulrich Drepper  <drepper@redhat.com>
+
+       * sysdeps/unix/sysv/linux/mq_unlink.c: Rewrite to produce more
+       compact code.
+
 2004-04-20  Jakub Jelinek  <jakub@redhat.com>
 
        * stdio-common/vfscanf.c (_IO_vfscanf): When skipping whitespace,
index 1b0f473a1d89e52d4f235336581c34c80e4548a8..998af796303d2f9e71c518ecb9f2b63eea51f8e0 100644 (file)
@@ -1,3 +1,9 @@
+2004-04-19  Kaz Kojima  <kkojima@rr.iij4u.or.jp>
+
+       * sysdeps/unix/sysv/linux/sh/sysdep-cancel.h (CENABLE): Define
+       for librt.  Save the return value to a safe register.
+       (CDISABLE): Define for librt.  Set the function argument correctly.
+
 2004-04-18  Jakub Jelinek  <jakub@redhat.com>
 
        * sysdeps/unix/sysv/linux/s390/s390-32/sysdep-cancel.h
index 501791c66181affb0bd8b601c4125d5f45dcfb8c..3dc83fcf431333fed864f9577b264a819a56ee50 100644 (file)
@@ -1,3 +1,8 @@
+2004-04-19  Ulrich Drepper  <drepper@redhat.com>
+
+       * sysdeps/unix/sysv/linux/mq_unlink.c: Rewrite to produce more
+       compact code.
+
 2004-04-19  Kaz Kojima  <kkojima@rr.iij4u.or.jp>
 
        * sysdeps/unix/sysv/linux/sh/sem_timedwait.S: Add frame info.
index 4344c5d0ef420cfe68c40f80d659dafc40a9e25a..8d87ffadf46acacb3e07e98cc8805a5ec3cbd41a 100644 (file)
@@ -32,12 +32,19 @@ mq_unlink (const char *name)
       return -1;
     }
 
-  int ret = INLINE_SYSCALL (mq_unlink, 1, name + 1);
+  INTERNAL_SYSCALL_DECL (err);
+  int ret = INTERNAL_SYSCALL (mq_unlink, err, 1, name + 1);
 
   /* While unlink can return either EPERM or EACCES, mq_unlink should
      return just EACCES.  */
-  if (ret < 0 && errno == EPERM)
-    __set_errno (EACCES);
+  if (__builtin_expect (INTERNAL_SYSCALL_ERROR_P (ret, err), 0))
+    {
+      ret = INTERNAL_SYSCALL_ERRNO (ret, err);
+      if (ret == EPERM)
+       ret = EACCES;
+      __set_errno (ret);
+      ret = -1;
+    }
 
   return ret;
 }