summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog9
-rw-r--r--grp/initgroups.c18
2 files changed, 18 insertions, 9 deletions
diff --git a/ChangeLog b/ChangeLog
index 46db0361be..d480a2578d 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,12 @@
+2001-04-16 Roland McGrath <roland@frob.com>
+
+ * grp/initgroups.c (initgroups) [NGROUPS_MAX != 0]: Always use sysconf
+ instead of the constant NGROUPS_MAX. That way, the limit can be
+ raised in the kernel configuration without having to recompile libc.
+
+ * sysdeps/posix/euidaccess.c: Don't #include <limits.h> or try to
+ define NGROUPS_MAX; we don't use it here.
+
2001-04-16 Andreas Jaeger <aj@suse.de>
* math/libm-test.inc (atan2_test): Add more testcases.
diff --git a/grp/initgroups.c b/grp/initgroups.c
index 6ae73687fe..89dc4d64fc 100644
--- a/grp/initgroups.c
+++ b/grp/initgroups.c
@@ -1,4 +1,4 @@
-/* Copyright (C) 1989, 91, 93, 1996-1999, 2000 Free Software Foundation, Inc.
+/* Copyright (C) 1989,91,93,1996-1999,2000,01 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
@@ -158,21 +158,21 @@ initgroups (user, group)
/* Start is one, because we have the first group as parameter. */
long int start = 1;
long int size;
- long int limit;
gid_t *groups;
int result;
-#ifdef NGROUPS_MAX
- size = NGROUPS_MAX;
- limit = -1;
-#else
+
+ /* We always use sysconf even if NGROUPS_MAX is defined. That way, the
+ limit can be raised in the kernel configuration without having to
+ recompile libc. */
long int limit = __sysconf (_SC_NGROUPS_MAX);
if (limit > 0)
size = limit;
else
- /* No fixed limit on groups. Pick a starting buffer size. */
- size = 16;
-#endif
+ {
+ /* No fixed limit on groups. Pick a starting buffer size. */
+ size = 16;
+ }
groups = (gid_t *) malloc (size * sizeof (gid_t));
if (__builtin_expect (groups == NULL, 0))