]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
Update.
authorUlrich Drepper <drepper@redhat.com>
Tue, 20 Apr 2004 18:58:56 +0000 (18:58 +0000)
committerUlrich Drepper <drepper@redhat.com>
Tue, 20 Apr 2004 18:58:56 +0000 (18:58 +0000)
2004-04-20  Jakub Jelinek  <jakub@redhat.com>

* sysdeps/unix/sysv/linux/shm_open.c (shm_unlink): Change EPERM into
EACCES.

2004-04-20  Jakub Jelinek  <jakub@redhat.com>

* stdio-common/vfscanf.c (_IO_vfscanf): Revert last %% whitespace
handling change.
* stdio-common/tst-sscanf.c (int_tests): Adjust.

* nis/nss-nis.c: Include stdlib.h.

* sysdeps/sparc/sparc32/dl-machine.h (elf_machine_rela): Shut up a
warning.
* sysdeps/sparc/sparc64/memcmp.S (memcmp): Remove BP_SYM () from
libc_hidden_builtin_def.

2004-04-20  Jim Meyering  <jim@meyering.net>

* misc/error.c (error_tail): Don't leak upon realloc failure.

2004-04-20  Martin Schwidefsky  <schwidefsky@de.ibm.com>

* sysdeps/unix/sysv/linux/dl-execstack.c (_dl_make_stack_executable):
Use RETURN_ADDRESS instead of __builtin_return_address.

13 files changed:
ChangeLog
linuxthreads/ChangeLog
linuxthreads/oldsemaphore.c
misc/error.c
nis/nss-nis.c
nptl/ChangeLog
nptl/sem_unlink.c
stdio-common/tst-sscanf.c
stdio-common/vfscanf.c
sysdeps/sparc/sparc32/dl-machine.h
sysdeps/sparc/sparc64/memcmp.S
sysdeps/unix/sysv/linux/dl-execstack.c
sysdeps/unix/sysv/linux/shm_open.c

index 1f2744df7a97d5d3d56c4f965d9f248cd858d171..bb2a76505e7b62d80d01846b7099ec20b1e2d4c4 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,30 @@
+2004-04-20  Jakub Jelinek  <jakub@redhat.com>
+
+       * sysdeps/unix/sysv/linux/shm_open.c (shm_unlink): Change EPERM into
+       EACCES.
+
+2004-04-20  Jakub Jelinek  <jakub@redhat.com>
+
+       * stdio-common/vfscanf.c (_IO_vfscanf): Revert last %% whitespace
+       handling change.
+       * stdio-common/tst-sscanf.c (int_tests): Adjust.
+
+       * nis/nss-nis.c: Include stdlib.h.
+
+       * sysdeps/sparc/sparc32/dl-machine.h (elf_machine_rela): Shut up a
+       warning.
+       * sysdeps/sparc/sparc64/memcmp.S (memcmp): Remove BP_SYM () from
+       libc_hidden_builtin_def.
+
+2004-04-20  Jim Meyering  <jim@meyering.net>
+
+       * misc/error.c (error_tail): Don't leak upon realloc failure.
+
+2004-04-20  Martin Schwidefsky  <schwidefsky@de.ibm.com>
+
+       * sysdeps/unix/sysv/linux/dl-execstack.c (_dl_make_stack_executable):
+       Use RETURN_ADDRESS instead of __builtin_return_address.
+
 2004-04-19  Ulrich Drepper  <drepper@redhat.com>
 
        * sysdeps/unix/sysv/linux/mq_unlink.c: Rewrite to produce more
index 998af796303d2f9e71c518ecb9f2b63eea51f8e0..40e23ec337cce8d4ba987f286b2c547aee08015a 100644 (file)
@@ -1,3 +1,7 @@
+2004-04-20  Jakub Jelinek  <jakub@redhat.com>
+
+       * oldsemaphore.c (SEM_VALUE_MAX): Remove.
+
 2004-04-19  Kaz Kojima  <kkojima@rr.iij4u.or.jp>
 
        * sysdeps/unix/sysv/linux/sh/sysdep-cancel.h (CENABLE): Define
index 80a82dfcf6896aa9b32370da44a89b873ced01a4..d35683b98bb96a4a61640f4302b44a736fe0bbe8 100644 (file)
@@ -41,10 +41,6 @@ extern int __old_sem_post (old_sem_t *__sem);
 extern int __old_sem_getvalue (old_sem_t *__sem, int *__sval);
 extern int __old_sem_destroy (old_sem_t *__sem);
 
-
-/* Maximum value the semaphore can have.  */
-#define SEM_VALUE_MAX   ((int) ((~0u) >> 1))
-
 static inline int sem_compare_and_swap(old_sem_t *sem, long oldval, long newval)
 {
     return compare_and_swap(&sem->sem_status, oldval, newval, &sem->sem_spinlock);
index de3b797a40f968e29a0711485f93ce7a50a4c09b..250158336621343d1a8ab1ed8de6faab9fd14f36 100644 (file)
@@ -1,5 +1,5 @@
 /* Error handler for noninteractive utilities
-   Copyright (C) 1990-1998, 2000-2002, 2003 Free Software Foundation, Inc.
+   Copyright (C) 1990-1998, 2000-2003, 2004 Free Software Foundation, Inc.
    This file is part of the GNU C Library.  Its master source is NOT part of
    the C library, however.  The master source lives in /gd/gnu/lib.
 
@@ -192,18 +192,19 @@ error_tail (int status, int errnum, const char *message, va_list args)
              if (wmessage != NULL && len / 2 < ALLOCA_LIMIT)
                wmessage = NULL;
 
-             wmessage = (wchar_t *) realloc (wmessage,
-                                             len * sizeof (wchar_t));
-
-             if (wmessage == NULL)
+             wchar_t *p = (wchar_t *) realloc (wmessage,
+                                               len * sizeof (wchar_t));
+             if (p == NULL)
                {
+                 free (wmessage);
                  fputws_unlocked (L"out of memory\n", stderr);
                  return;
                }
+             wmessage = p;
            }
 
          memset (&st, '\0', sizeof (st));
-         tmp =message;
+         tmp = message;
        }
       while ((res = mbsrtowcs (wmessage, &tmp, len, &st)) == len);
 
index 59129a894388ca123fafedb6a39aacea26b7248e..40370bae3b7de300fa17c545c625e3850cba5220 100644 (file)
@@ -19,6 +19,7 @@
 #include <ctype.h>
 #include <stdio.h>
 #include <stdio_ext.h>
+#include <stdlib.h>
 #include <string.h>
 #include <rpcsvc/ypclnt.h>
 
index 501791c66181affb0bd8b601c4125d5f45dcfb8c..9e3717da69fdc0fb45cff9401a90e8087bd0a7a4 100644 (file)
@@ -1,3 +1,7 @@
+2004-04-20  Jakub Jelinek  <jakub@redhat.com>
+
+       * sem_unlink.c (sem_unlink): Change EPERM into EACCES.
+
 2004-04-19  Kaz Kojima  <kkojima@rr.iij4u.or.jp>
 
        * sysdeps/unix/sysv/linux/sh/sem_timedwait.S: Add frame info.
index 92288df8be1ba58cae321545bc3a82725352daab..17074774db3a1619028eefc046df2839772aeb3a 100644 (file)
@@ -1,4 +1,4 @@
-/* Copyright (C) 2002 Free Software Foundation, Inc.
+/* Copyright (C) 2002, 2004 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
    Contributed by Ulrich Drepper <drepper@redhat.com>, 2002.
 
@@ -60,5 +60,8 @@ sem_unlink (name)
             name, namelen + 1);
 
   /* Now try removing it.  */
-  return unlink (fname);
+  int ret = unlink (fname);
+  if (ret < 0 && errno == EPERM)
+    __set_errno (EACCES);
+  return ret;
 }
index 3bd7c3583249e95639069ddf14133c1d645c5d39..e710e190d79f78c8ef2de081002c09c4115de89c 100644 (file)
@@ -78,7 +78,6 @@ struct int_test
   { "foo\t", "foo bar", -1 },
   { "foo\t", "foo %d", -1 },
   { "foo\t", "foo\t%d", -1 },
-  { "foo \t %bar1", "foo%%bar%d", 0 },
   { "foo", "foo", 0 },
   { "foon", "foo bar", 0 },
   { "foon", "foo %d", 0 },
@@ -89,7 +88,9 @@ struct int_test
   { "foo bar", "foo %d", 0 },
   { "foo bar", "foon%d", 0 },
   { "foo ", "foo %n", 0 },
-  { "foo%bar1", "foo%%bar%d", 1 }
+  { "foo%bar1", "foo%%bar%d", 1 },
+  /* Some OSes skip whitespace here while others don't.  */
+  { "foo \t %bar1", "foo%%bar%d", 1 }
 };
 
 int
index 551849b1154bedeae96d9e95ceee4fead6c82995..63e7bd8815a38fb5efd73f338a14a3473941ea04 100644 (file)
@@ -543,8 +543,7 @@ _IO_vfscanf (s, format, argptr, errp)
       /* Find the conversion specifier.  */
       fc = *f++;
       if (skip_space || (fc != L_('[') && fc != L_('c')
-                        && fc != L_('C') && fc != L_('n')
-                        && fc != L_('%')))
+                        && fc != L_('C') && fc != L_('n')))
        {
          /* Eat whitespace.  */
          int save_errno = errno;
index da631d2f548fc758e489d8918cac0f6c69625d16..5f39949c0088c761ec2ae15370747d14b432e5cb 100644 (file)
@@ -441,9 +441,9 @@ elf_machine_rela (struct link_map *map, const Elf32_Rela *reloc,
     {
 #if !defined RTLD_BOOTSTRAP && !defined RESOLVE_CONFLICT_FIND_MAP
       const Elf32_Sym *const refsym = sym;
-#endif
-#if defined USE_TLS && !defined RTLD_BOOTSTRAP
+# ifdef USE_TLS
       struct link_map *sym_map;
+# endif
 #endif
       Elf32_Addr value;
 #ifndef RESOLVE_CONFLICT_FIND_MAP
index dbc99217691020a1da7378f21dd901db319f344a..074767b983c9a911bcf9558e232dff9d723661fa 100644 (file)
@@ -1,6 +1,6 @@
 /* Compare two memory blocks for differences in the first COUNT bytes.
    For SPARC v9.
-   Copyright (C) 1998,1999, 2004 Free Software Foundation, Inc.
+   Copyright (C) 1998, 1999, 2004 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
    Contributed by Jan Vondrak <jvon4518@ss1000.ms.mff.cuni.cz> and
                   Jakub Jelinek <jj@ultra.linux.cz>.
@@ -140,4 +140,4 @@ END(memcmp)
 
 #undef bcmp
 weak_alias(memcmp, bcmp)
-libc_hidden_builtin_def (BP_SYM (memcmp))
+libc_hidden_builtin_def (memcmp)
index 248196040a4dac444dd767260300bd21c21c4313..3ca9b0b83543e195e689034539e6b17c3d7a5717 100644 (file)
@@ -37,7 +37,7 @@ _dl_make_stack_executable (void **stack_endp)
                    & -(intptr_t) GLRO(dl_pagesize));
 
   /* Challenge the caller.  */
-  if (__builtin_expect (__check_caller (__builtin_return_address (0),
+  if (__builtin_expect (__check_caller (RETURN_ADDRESS (0),
                                        allow_ldso|allow_libpthread) != 0, 0)
       || __builtin_expect (*stack_endp != __libc_stack_end, 0))
     return EPERM;
index 73804f5349bbb219252f7be89274d058ccbd3ee6..2e94b76cdbdc9f131d5200a2b6ff9e9a6c4ba3df 100644 (file)
@@ -1,4 +1,4 @@
-/* Copyright (C) 2000, 2001, 2002, 2003 Free Software Foundation, Inc.
+/* Copyright (C) 2000, 2001, 2002, 2003, 2004 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
 
    The GNU C Library is free software; you can redistribute it and/or
@@ -227,7 +227,10 @@ shm_unlink (const char *name)
             name, namelen + 1);
 
   /* And remove the file.  */
-  return unlink (fname);
+  int ret = unlink (fname);
+  if (ret < 0 && errno == EPERM)
+    __set_errno (EACCES);
+  return ret;
 }