[BZ #6980]
authorUlrich Drepper <drepper@redhat.com>
Fri, 31 Oct 2008 14:27:36 +0000 (14:27 +0000)
committerUlrich Drepper <drepper@redhat.com>
Fri, 31 Oct 2008 14:27:36 +0000 (14:27 +0000)
* debug/getgroups_chk.c (__getgroups_chk): Return EINVAL error for
negative sizees.
* posix/bits/unistd.h (getgroups): Call __getgroups_chk for
negative __size.

ChangeLog
debug/getgroups_chk.c
posix/bits/unistd.h

index b1876983d6f32bf4183f4f8e05fa97942f8c00a6..7dac2c5ff55bf29bce73f37fc8ff2e5a6a28b5f6 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,11 @@
 2008-10-31  Ulrich Drepper  <drepper@redhat.com>
 
+       [BZ #6980]
+       * debug/getgroups_chk.c (__getgroups_chk): Return EINVAL error for
+       negative sizees.
+       * posix/bits/unistd.h (getgroups): Call __getgroups_chk for
+       negative __size.
+
        [BZ #6995]
        * sysdeps/powerpc/powerpc32/dl-machine.c: Fix typo in message.
 
index c877ddb9cae349956350432f489d1e1249348901..8c3d99da7e72598c2e833f8a86432c91d6843ec6 100644 (file)
@@ -1,4 +1,4 @@
-/* Copyright (C) 2005 Free Software Foundation, Inc.
+/* Copyright (C) 2005, 2008 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
 int
 __getgroups_chk (int size, __gid_t list[], size_t listlen)
 {
+  if (__builtin_expect (size < 0, 0))
+    {
+      __set_errno (EINVAL);
+      return -1;
+    }
+
   if (__builtin_expect (size * sizeof (__gid_t) > listlen, 0))
     __chk_fail ();
 
index efd7f75a50716e080318218d2368a575950392af..e29b4cca467f513739f8dd5993511c8a9105be33 100644 (file)
@@ -1,5 +1,5 @@
 /* Checking macros for unistd functions.
-   Copyright (C) 2005, 2006, 2007 Free Software Foundation, Inc.
+   Copyright (C) 2005, 2006, 2007, 2008 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
@@ -267,7 +267,7 @@ __NTH (getgroups (int __size, __gid_t __list[]))
 {
   if (__bos (__list) != (size_t) -1)
     {
-      if (!__builtin_constant_p (__size))
+      if (!__builtin_constant_p (__size) || __size < 0)
        return __getgroups_chk (__size, __list, __bos (__list));
 
       if (__size * sizeof (__gid_t) > __bos (__list))