]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
Update.
authorUlrich Drepper <drepper@redhat.com>
Sun, 12 Sep 2004 20:38:38 +0000 (20:38 +0000)
committerUlrich Drepper <drepper@redhat.com>
Sun, 12 Sep 2004 20:38:38 +0000 (20:38 +0000)
2004-09-11  Thorsten Kukuk  <kukuk@suse.de>

* nis/nss_compat/compat-grp.c: Check that buflen is greater zero
before writing data into the buffer with negative offset.
* nis/nss_compat/compat-initgroups.c: Likewise.
* nis/nss_compat/compat-pwd.c: Likewise.
* nis/nss_compat/compat-spwd.c Likewise.

ChangeLog
nis/nss_compat/compat-grp.c
nis/nss_compat/compat-initgroups.c
nis/nss_compat/compat-pwd.c
nis/nss_compat/compat-spwd.c
nptl/sysdeps/pthread/pthread.h

index 71cd45bf05d2a909e97ce8515c3c6159f61f8514..f68cfd110eb58eac1befe4d6731fa1ac826c3861 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,11 @@
+2004-09-11  Thorsten Kukuk  <kukuk@suse.de>
+
+       * nis/nss_compat/compat-grp.c: Check that buflen is greater zero
+       before writing data into the buffer with negative offset.
+       * nis/nss_compat/compat-initgroups.c: Likewise.
+       * nis/nss_compat/compat-pwd.c: Likewise.
+       * nis/nss_compat/compat-spwd.c Likewise.
+
 2004-09-12  Ulrich Drepper  <drepper@redhat.com>
 
        * misc/syslog.c (vsyslog): Fix copying of PID in case of
index 85414ed81d8296f5a4ff71aa88f16e88786074ab..08bf5d2f80a4b2f2b9af35ebf12a5ee144183ef5 100644 (file)
@@ -1,4 +1,4 @@
-/* Copyright (C) 1996,1997,1998,1999,2001,2002, 2003 Free Software Foundation, Inc.
+/* Copyright (C) 1996-1999,2001,2002,2003,2004 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
    Contributed by Thorsten Kukuk <kukuk@suse.de>, 1996.
 
@@ -253,17 +253,25 @@ getgrent_next_file (struct group *result, ent_t *ent,
 
       do
        {
+         /* We need at least 3 characters for one line.  */
+         if (__builtin_expect (buflen < 3, 0))
+           {
+           erange:
+             *errnop = ERANGE;
+             return NSS_STATUS_TRYAGAIN;
+           }
+
          fgetpos (ent->stream, &pos);
          buffer[buflen - 1] = '\xff';
          p = fgets_unlocked (buffer, buflen, ent->stream);
          if (p == NULL && feof_unlocked (ent->stream))
            return NSS_STATUS_NOTFOUND;
 
-         if (p == NULL || buffer[buflen - 1] != '\xff')
+         if (p == NULL || __builtin_expect (buffer[buflen - 1] != '\xff', 0))
            {
+           erange_reset:
              fsetpos (ent->stream, &pos);
-             *errnop = ERANGE;
-             return NSS_STATUS_TRYAGAIN;
+             goto erange;
            }
 
          /* Terminate the line for any case.  */
@@ -279,13 +287,9 @@ getgrent_next_file (struct group *result, ent_t *ent,
             !(parse_res = _nss_files_parse_grent (p, result, data, buflen,
                                                   errnop)));
 
-      if (parse_res == -1)
-       {
-         /* The parser ran out of space.  */
-         fsetpos (ent->stream, &pos);
-         *errnop = ERANGE;
-         return NSS_STATUS_TRYAGAIN;
-       }
+      if (__builtin_expect (parse_res == -1, 0))
+       /* The parser ran out of space.  */
+       goto erange_reset;
 
       if (result->gr_name[0] != '+' && result->gr_name[0] != '-')
        /* This is a real entry.  */
@@ -315,17 +319,15 @@ getgrent_next_file (struct group *result, ent_t *ent,
          blacklist_store_name (buf, ent);
          if (status == NSS_STATUS_SUCCESS)     /* We found the entry. */
            break;
-         else if (status == NSS_STATUS_RETURN  /* We couldn't parse the entry */
+         else if (status == NSS_STATUS_RETURN /* We couldn't parse the entry*/
                   || status == NSS_STATUS_NOTFOUND)    /* No group in NIS */
            continue;
          else
            {
              if (status == NSS_STATUS_TRYAGAIN)
-               {
-                 /* The parser ran out of space.  */
-                 fsetpos (ent->stream, &pos);
-                 *errnop = ERANGE;
-               }
+               /* The parser ran out of space.  */
+               goto erange_reset;
+
              return status;
            }
        }
@@ -384,17 +386,25 @@ internal_getgrnam_r (const char *name, struct group *result, ent_t *ent,
 
       do
        {
+         /* We need at least 3 characters for one line.  */
+         if (__builtin_expect (buflen < 3, 0))
+           {
+           erange:
+             *errnop = ERANGE;
+             return NSS_STATUS_TRYAGAIN;
+           }
+
          fgetpos (ent->stream, &pos);
          buffer[buflen - 1] = '\xff';
          p = fgets_unlocked (buffer, buflen, ent->stream);
          if (p == NULL && feof_unlocked (ent->stream))
            return NSS_STATUS_NOTFOUND;
 
-         if (p == NULL || buffer[buflen - 1] != '\xff')
+         if (p == NULL || __builtin_expect (buffer[buflen - 1] != '\xff', 0))
            {
+           erange_reset:
              fsetpos (ent->stream, &pos);
-             *errnop = ERANGE;
-             return NSS_STATUS_TRYAGAIN;
+             goto erange;
            }
 
          /* Terminate the line for any case.  */
@@ -410,13 +420,9 @@ internal_getgrnam_r (const char *name, struct group *result, ent_t *ent,
             !(parse_res = _nss_files_parse_grent (p, result, data, buflen,
                                                   errnop)));
 
-      if (parse_res == -1)
-       {
-         /* The parser ran out of space.  */
-         fsetpos (ent->stream, &pos);
-         *errnop = ERANGE;
-         return NSS_STATUS_TRYAGAIN;
-       }
+      if (__builtin_expect (parse_res == -1, 0))
+       /* The parser ran out of space.  */
+       goto erange_reset;
 
       /* This is a real entry.  */
       if (result->gr_name[0] != '+' && result->gr_name[0] != '-')
@@ -511,17 +517,25 @@ internal_getgrgid_r (gid_t gid, struct group *result, ent_t *ent,
 
       do
        {
+         /* We need at least 3 characters for one line.  */
+         if (__builtin_expect (buflen < 3, 0))
+           {
+           erange:
+             *errnop = ERANGE;
+             return NSS_STATUS_TRYAGAIN;
+           }
+
          fgetpos (ent->stream, &pos);
          buffer[buflen - 1] = '\xff';
          p = fgets_unlocked (buffer, buflen, ent->stream);
          if (p == NULL && feof_unlocked (ent->stream))
            return NSS_STATUS_NOTFOUND;
 
-         if (p == NULL || buffer[buflen - 1] != '\xff')
+         if (p == NULL || __builtin_expect (buffer[buflen - 1] != '\xff', 0))
            {
+           erange_reset:
              fsetpos (ent->stream, &pos);
-             *errnop = ERANGE;
-             return NSS_STATUS_TRYAGAIN;
+             goto erange;
            }
 
          /* Terminate the line for any case.  */
@@ -538,12 +552,8 @@ internal_getgrgid_r (gid_t gid, struct group *result, ent_t *ent,
                                                   errnop)));
 
       if (parse_res == -1)
-       {
-         /* The parser ran out of space.  */
-         fsetpos (ent->stream, &pos);
-         *errnop = ERANGE;
-         return NSS_STATUS_TRYAGAIN;
-       }
+       /* The parser ran out of space.  */
+       goto erange_reset;
 
       /* This is a real entry.  */
       if (result->gr_name[0] != '+' && result->gr_name[0] != '-')
index 100febc672c3d55257fa93a82bd7e179a73bb887..9574ea7c0bee7a3662dc960f348f4065628b0d96 100644 (file)
@@ -327,17 +327,25 @@ internal_getgrent_r (ent_t *ent, char *buffer, size_t buflen, const char *user,
 
       do
        {
+         /* We need at least 3 characters for one line.  */
+         if (__builtin_expect (buflen < 3, 0))
+           {
+           erange:
+             *errnop = ERANGE;
+             return NSS_STATUS_TRYAGAIN;
+           }
+
          fgetpos (ent->stream, &pos);
          buffer[buflen - 1] = '\xff';
          p = fgets_unlocked (buffer, buflen, ent->stream);
          if (p == NULL && feof_unlocked (ent->stream))
            return NSS_STATUS_NOTFOUND;
 
-         if (p == NULL || buffer[buflen - 1] != '\xff')
+         if (p == NULL || __builtin_expect (buffer[buflen - 1] != '\xff', 0))
            {
+           erange_reset:
              fsetpos (ent->stream, &pos);
-             *errnop = ERANGE;
-             return NSS_STATUS_TRYAGAIN;
+             goto erange;
            }
 
          /* Terminate the line for any case.  */
@@ -353,13 +361,9 @@ internal_getgrent_r (ent_t *ent, char *buffer, size_t buflen, const char *user,
             !(parse_res = _nss_files_parse_grent (p, &grpbuf, data, buflen,
                                                   errnop)));
 
-      if (parse_res == -1)
-       {
-         /* The parser ran out of space.  */
-         fsetpos (ent->stream, &pos);
-         *errnop = ERANGE;
-         return NSS_STATUS_TRYAGAIN;
-       }
+      if (__builtin_expect (parse_res == -1, 0))
+       /* The parser ran out of space.  */
+       goto erange_reset;
 
       if (grpbuf.gr_name[0] != '+' && grpbuf.gr_name[0] != '-')
        /* This is a real entry.  */
index b8c5890b5ba33f772bb03765b62d1e175ccdbf11..89a6a7013e14ff6505066754d4e091c2dba6c982 100644 (file)
@@ -1,4 +1,4 @@
-/* Copyright (C) 1996-1999,2001,2002,2003 Free Software Foundation, Inc.
+/* Copyright (C) 1996-1999,2001,2002,2003,2004 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
    Contributed by Thorsten Kukuk <kukuk@vt.uni-paderborn.de>, 1996.
 
@@ -499,17 +499,25 @@ getpwent_next_file (struct passwd *result, ent_t *ent,
 
       do
        {
+         /* We need at least 3 characters for one line.  */
+         if (__builtin_expect (buflen < 3, 0))
+           {
+           erange:
+             *errnop = ERANGE;
+             return NSS_STATUS_TRYAGAIN;
+           }
+
          fgetpos (ent->stream, &pos);
          buffer[buflen - 1] = '\xff';
          p = fgets_unlocked (buffer, buflen, ent->stream);
          if (p == NULL && feof_unlocked (ent->stream))
            return NSS_STATUS_NOTFOUND;
 
-         if (p == NULL || buffer[buflen - 1] != '\xff')
+         if (p == NULL || __builtin_expect (buffer[buflen - 1] != '\xff', 0))
            {
+           erange_reset:
              fsetpos (ent->stream, &pos);
-             *errnop = ERANGE;
-             return NSS_STATUS_TRYAGAIN;
+             goto erange;
            }
 
          /* Terminate the line for any case.  */
@@ -525,13 +533,9 @@ getpwent_next_file (struct passwd *result, ent_t *ent,
             !(parse_res = _nss_files_parse_pwent (p, result, data, buflen,
                                                   errnop)));
 
-      if (parse_res == -1)
-       {
-         /* The parser ran out of space.  */
-         fsetpos (ent->stream, &pos);
-         *errnop = ERANGE;
-         return NSS_STATUS_TRYAGAIN;
-       }
+      if (__builtin_expect (parse_res == -1, 0))
+       /* The parser ran out of space.  */
+       goto erange_reset;
 
       if (result->pw_name[0] != '+' && result->pw_name[0] != '-')
        /* This is a real entry.  */
@@ -694,6 +698,14 @@ internal_getpwnam_r (const char *name, struct passwd *result, ent_t *ent,
 
       do
        {
+         /* We need at least 3 characters for one line.  */
+         if (__builtin_expect (buflen < 3, 0))
+           {
+           erange:
+             *errnop = ERANGE;
+             return NSS_STATUS_TRYAGAIN;
+           }
+
          fgetpos (ent->stream, &pos);
          buffer[buflen - 1] = '\xff';
          p = fgets_unlocked (buffer, buflen, ent->stream);
@@ -701,11 +713,11 @@ internal_getpwnam_r (const char *name, struct passwd *result, ent_t *ent,
            {
              return NSS_STATUS_NOTFOUND;
            }
-         if (p == NULL || buffer[buflen - 1] != '\xff')
+         if (p == NULL || __builtin_expect (buffer[buflen - 1] != '\xff', 0))
            {
+           erange_reset:
              fsetpos (ent->stream, &pos);
-             *errnop = ERANGE;
-             return NSS_STATUS_TRYAGAIN;
+             goto erange;
            }
 
          /* Terminate the line for any case.  */
@@ -721,13 +733,9 @@ internal_getpwnam_r (const char *name, struct passwd *result, ent_t *ent,
             !(parse_res = _nss_files_parse_pwent (p, result, data, buflen,
                                                   errnop)));
 
-      if (parse_res == -1)
-       {
-         /* The parser ran out of space.  */
-         fsetpos (ent->stream, &pos);
-         *errnop = ERANGE;
-         return NSS_STATUS_TRYAGAIN;
-       }
+      if (__builtin_expect (parse_res == -1, 0))
+       /* The parser ran out of space.  */
+       goto erange_reset;
 
       /* This is a real entry.  */
       if (result->pw_name[0] != '+' && result->pw_name[0] != '-')
@@ -897,17 +905,25 @@ internal_getpwuid_r (uid_t uid, struct passwd *result, ent_t *ent,
 
       do
        {
+         /* We need at least 3 characters for one line.  */
+         if (__builtin_expect (buflen < 3, 0))
+           {
+           erange:
+             *errnop = ERANGE;
+             return NSS_STATUS_TRYAGAIN;
+           }
+
          fgetpos (ent->stream, &pos);
          buffer[buflen - 1] = '\xff';
          p = fgets_unlocked (buffer, buflen, ent->stream);
          if (p == NULL && feof_unlocked (ent->stream))
            return NSS_STATUS_NOTFOUND;
 
-         if (p == NULL || buffer[buflen - 1] != '\xff')
+         if (p == NULL || __builtin_expect (buffer[buflen - 1] != '\xff', 0))
            {
+           erange_reset:
              fsetpos (ent->stream, &pos);
-             *errnop = ERANGE;
-             return NSS_STATUS_TRYAGAIN;
+             goto erange;
            }
 
          /* Terminate the line for any case.  */
@@ -923,13 +939,9 @@ internal_getpwuid_r (uid_t uid, struct passwd *result, ent_t *ent,
             !(parse_res = _nss_files_parse_pwent (p, result, data, buflen,
                                                   errnop)));
 
-      if (parse_res == -1)
-       {
-         /* The parser ran out of space.  */
-         fsetpos (ent->stream, &pos);
-         *errnop = ERANGE;
-         return NSS_STATUS_TRYAGAIN;
-       }
+      if (__builtin_expect (parse_res == -1, 0))
+       /* The parser ran out of space.  */
+       goto erange_reset;
 
       /* This is a real entry.  */
       if (result->pw_name[0] != '+' && result->pw_name[0] != '-')
index 55db10eadb6ae019c8d9d6e5e28bc63e9989a8f8..4ca6368139c733e1a3dcffc922acdf2a761860f1 100644 (file)
@@ -1,4 +1,4 @@
-/* Copyright (C) 1996-1999,2001,2002,2003 Free Software Foundation, Inc.
+/* Copyright (C) 1996-1999,2001,2002,2003,2004 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
    Contributed by Thorsten Kukuk <kukuk@vt.uni-paderborn.de>, 1996.
 
@@ -451,17 +451,25 @@ getspent_next_file (struct spwd *result, ent_t *ent,
 
       do
        {
+         /* We need at least 3 characters for one line.  */
+         if (__builtin_expect (buflen < 3, 0))
+           {
+           erange:
+             *errnop = ERANGE;
+             return NSS_STATUS_TRYAGAIN;
+           }
+
          fgetpos (ent->stream, &pos);
          buffer[buflen - 1] = '\xff';
          p = fgets_unlocked (buffer, buflen, ent->stream);
          if (p == NULL && feof_unlocked (ent->stream))
            return NSS_STATUS_NOTFOUND;
 
-         if (p == NULL || buffer[buflen - 1] != '\xff')
+         if (p == NULL || __builtin_expect (buffer[buflen - 1] != '\xff', 0))
            {
+           erange_reset:
              fsetpos (ent->stream, &pos);
-             *errnop = ERANGE;
-             return NSS_STATUS_TRYAGAIN;
+             goto erange;
            }
 
          /* Skip leading blanks.  */
@@ -474,13 +482,9 @@ getspent_next_file (struct spwd *result, ent_t *ent,
             || !(parse_res = _nss_files_parse_spent (p, result, data,
                                                      buflen, errnop)));
 
-      if (parse_res == -1)
-       {
-         /* The parser ran out of space.  */
-         fsetpos (ent->stream, &pos);
-         *errnop = ERANGE;
-         return NSS_STATUS_TRYAGAIN;
-       }
+      if (__builtin_expect (parse_res == -1, 0))
+       /* The parser ran out of space.  */
+       goto erange_reset;
 
       if (result->sp_namp[0] != '+' && result->sp_namp[0] != '-')
        /* This is a real entry.  */
@@ -645,6 +649,14 @@ internal_getspnam_r (const char *name, struct spwd *result, ent_t *ent,
 
       do
        {
+         /* We need at least 3 characters for one line.  */
+         if (__builtin_expect (buflen < 3, 0))
+           {
+           erange:
+             *errnop = ERANGE;
+             return NSS_STATUS_TRYAGAIN;
+           }
+
          fgetpos (ent->stream, &pos);
          buffer[buflen - 1] = '\xff';
          p = fgets_unlocked (buffer, buflen, ent->stream);
@@ -653,9 +665,9 @@ internal_getspnam_r (const char *name, struct spwd *result, ent_t *ent,
 
          if (p == NULL || buffer[buflen - 1] != '\xff')
            {
+           erange_reset:
              fsetpos (ent->stream, &pos);
-             *errnop = ERANGE;
-             return NSS_STATUS_TRYAGAIN;
+             goto erange;
            }
 
           /* Terminate the line for any case.  */
@@ -671,13 +683,9 @@ internal_getspnam_r (const char *name, struct spwd *result, ent_t *ent,
             !(parse_res = _nss_files_parse_spent (p, result, data, buflen,
                                                   errnop)));
 
-      if (parse_res == -1)
-       {
-         /* The parser ran out of space.  */
-         fsetpos (ent->stream, &pos);
-         *errnop = ERANGE;
-         return NSS_STATUS_TRYAGAIN;
-       }
+      if (__builtin_expect (parse_res == -1, 0))
+       /* The parser ran out of space.  */
+       goto erange_reset;
 
       /* This is a real entry.  */
       if (result->sp_namp[0] != '+' && result->sp_namp[0] != '-')
index 18ccb83c507b08d6b6b0725c1778822a7bb1901e..27666483d9cbccdc504d9154154ec3521e24c7b3 100644 (file)
@@ -83,7 +83,7 @@ enum
 
 
 /* Read-write lock types.  */
-#ifdef __USE_UNIX98
+#if defined __USE_UNIX98 || defined __USE_XOPEN2K
 enum
 {
   PTHREAD_RWLOCK_PREFER_READER_NP,
@@ -91,21 +91,21 @@ enum
   PTHREAD_RWLOCK_PREFER_WRITER_NONRECURSIVE_NP,
   PTHREAD_RWLOCK_DEFAULT_NP = PTHREAD_RWLOCK_PREFER_READER_NP
 };
-#endif  /* Unix98 */
 
 /* Read-write lock initializers.  */
-#define PTHREAD_RWLOCK_INITIALIZER \
+# define PTHREAD_RWLOCK_INITIALIZER \
   { }
-#ifdef __USE_GNU
-# if __WORDSIZE == 64
-#  define PTHREAD_RWLOCK_WRITER_NONRECURSIVE_INITIALIZER_NP \
+# ifdef __USE_GNU
+#  if __WORDSIZE == 64
+#   define PTHREAD_RWLOCK_WRITER_NONRECURSIVE_INITIALIZER_NP \
   { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,                                          \
       PTHREAD_RWLOCK_PREFER_WRITER_NONRECURSIVE_NP } }
-# else
-#  define PTHREAD_RWLOCK_WRITER_NONRECURSIVE_INITIALIZER_NP \
+#  else
+#   define PTHREAD_RWLOCK_WRITER_NONRECURSIVE_INITIALIZER_NP \
   { { 0, 0, 0, 0, 0, 0, PTHREAD_RWLOCK_PREFER_WRITER_NONRECURSIVE_NP } }
+#  endif
 # endif
-#endif
+#endif  /* Unix98 or XOpen2K */
 
 
 /* Scheduler inheritance.  */