2001-06-07  Mark Kettenis  <kettenis@gnu.org>

	* grp/initgroups.c (initgroups): Factor out re-usable code into...
	(internal_getgrouplist): ... new function.
	(getgrouplist): New function.
	* grp/grp.h (getgrouplist): New prototype.
	* grp/Versions [2.2.4]: Add getgrouplist.

2001-06-16  Ulrich Drepper  <drepper@redhat.com>

	* inet/netinet/ip6.h: Fix comments in ip6_hdr.
	Patch by Pekka Savola <pekkas@netcore.fi>.
This commit is contained in:
Ulrich Drepper 2001-06-16 19:50:36 +00:00
parent cc765c2a2e
commit 8fee1bb0b2
7 changed files with 138 additions and 65 deletions

View File

@ -1,3 +1,16 @@
2001-06-07 Mark Kettenis <kettenis@gnu.org>
* grp/initgroups.c (initgroups): Factor out re-usable code into...
(internal_getgrouplist): ... new function.
(getgrouplist): New function.
* grp/grp.h (getgrouplist): New prototype.
* grp/Versions [2.2.4]: Add getgrouplist.
2001-06-16 Ulrich Drepper <drepper@redhat.com>
* inet/netinet/ip6.h: Fix comments in ip6_hdr.
Patch by Pekka Savola <pekkas@netcore.fi>.
2001-06-15 Roland McGrath <roland@frob.com> 2001-06-15 Roland McGrath <roland@frob.com>
* rt/Makefile (aio-routines, clock-routines, timer-routines): New * rt/Makefile (aio-routines, clock-routines, timer-routines): New

5
NEWS
View File

@ -1,4 +1,4 @@
GNU C Library NEWS -- history of user-visible changes. 2001-4-20 GNU C Library NEWS -- history of user-visible changes. 2001-6-16
Copyright (C) 1992-2000, 2001 Free Software Foundation, Inc. Copyright (C) 1992-2000, 2001 Free Software Foundation, Inc.
See the end for copying conditions. See the end for copying conditions.
@ -10,6 +10,9 @@ Version 2.2.4
* Stephen Moshier implemented cosh, expm1, log1p, acos, sinh for the * Stephen Moshier implemented cosh, expm1, log1p, acos, sinh for the
128-bit long double format. 128-bit long double format.
* Bruno Haible updated all the code handling Unicode in some form to
support Unicode 3.1.
Version 2.2.3 Version 2.2.3

View File

@ -24,4 +24,8 @@ libc {
# g* # g*
getgrent_r; getgrgid_r; getgrnam_r; getgrent_r; getgrgid_r; getgrnam_r;
} }
GLIBC_2.2.4 {
# g*
getgrouplist;
}
} }

View File

@ -1,4 +1,4 @@
/* Copyright (C) 1991,92,95,96,97,98,99,2000 Free Software Foundation, Inc. /* Copyright (C) 1991,92,95,96,97,98,99,2000,01 Free Software Foundation, Inc.
This file is part of the GNU C Library. This file is part of the GNU C Library.
The GNU C Library is free software; you can redistribute it and/or The GNU C Library is free software; you can redistribute it and/or
@ -136,6 +136,12 @@ extern int fgetgrent_r (FILE *__restrict __stream,
/* Set the group set for the current user to GROUPS (N of them). */ /* Set the group set for the current user to GROUPS (N of them). */
extern int setgroups (size_t __n, __const __gid_t *__groups) __THROW; extern int setgroups (size_t __n, __const __gid_t *__groups) __THROW;
/* Store at most *NGROUPS members of the group set for USER into
*GROUPS. Also include GROUP. The actual number of groups found is
returned in *NGROUPS. Return -1 if the if *NGROUPS is too small. */
extern int getgrouplist (__const char *__user, __gid_t __group,
__gid_t *__groups, int *__ngroups) __THROW;
/* Initialize the group set for the current user /* Initialize the group set for the current user
by reading the group database and using all groups by reading the group database and using all groups
of which USER is a member. Also include GROUP. */ of which USER is a member. Also include GROUP. */

View File

@ -136,13 +136,96 @@ compat_call (service_user *nip, const char *user, gid_t group, long int *start,
return NSS_STATUS_SUCCESS; return NSS_STATUS_SUCCESS;
} }
static int
internal_getgrouplist (const char *user, gid_t group, long int *size,
gid_t **groupsp, long int limit)
{
service_user *nip = NULL;
initgroups_dyn_function fct;
enum nss_status status = NSS_STATUS_UNAVAIL;
int no_more;
/* Start is one, because we have the first group as parameter. */
long int start = 1;
*groupsp[0] = group;
if (__nss_group_database != NULL)
{
no_more = 0;
nip = __nss_group_database;
}
else
no_more = __nss_database_lookup ("group", NULL,
"compat [NOTFOUND=return] files", &nip);
while (! no_more)
{
fct = __nss_lookup_function (nip, "initgroups_dyn");
if (fct == NULL)
{
status = compat_call (nip, user, group, &start, size, groupsp,
limit, &errno);
if (nss_next_action (nip, NSS_STATUS_UNAVAIL) != NSS_ACTION_CONTINUE)
break;
}
else
status = DL_CALL_FCT (fct, (user, group, &start, size, groupsp,
limit, &errno));
/* This is really only for debugging. */
if (NSS_STATUS_TRYAGAIN > status || status > NSS_STATUS_RETURN)
__libc_fatal ("illegal status in " __FUNCTION__);
if (status != NSS_STATUS_SUCCESS
&& nss_next_action (nip, status) == NSS_ACTION_RETURN)
break;
if (nip->next == NULL)
no_more = -1;
else
nip = nip->next;
}
return start;
}
/* Store at most *NGROUPS members of the group set for USER into
*GROUPS. Also include GROUP. The actual number of groups found is
returned in *NGROUPS. Return -1 if the if *NGROUPS is too small. */
int
getgrouplist (const char *user, gid_t group, gid_t *groups, int *ngroups)
{
gid_t *newgroups;
long int size = *ngroups;
int result;
newgroups = (gid_t *) malloc (size * sizeof (gid_t));
if (__builtin_expect (newgroups == NULL, 0))
/* No more memory. */
return -1;
result = internal_getgrouplist (user, group, &size, &newgroups, -1);
if (result > *ngroups)
{
*ngroups = result;
result = -1;
}
else
*ngroups = result;
memcpy (groups, newgroups, *ngroups * sizeof (gid_t));
free (newgroups);
return result;
}
/* Initialize the group set for the current user /* Initialize the group set for the current user
by reading the group database and using all groups by reading the group database and using all groups
of which USER is a member. Also include GROUP. */ of which USER is a member. Also include GROUP. */
int int
initgroups (user, group) initgroups (const char *user, gid_t group)
const char *user;
gid_t group;
{ {
#if defined NGROUPS_MAX && NGROUPS_MAX == 0 #if defined NGROUPS_MAX && NGROUPS_MAX == 0
@ -151,17 +234,12 @@ initgroups (user, group)
#else #else
service_user *nip = NULL;
initgroups_dyn_function fct;
enum nss_status status = NSS_STATUS_UNAVAIL;
int no_more;
/* Start is one, because we have the first group as parameter. */
long int start = 1;
long int size; long int size;
gid_t *groups; gid_t *groups;
int ngroups;
int result; int result;
/* We always use sysconf even if NGROUPS_MAX is defined. That way, the /* We always use sysconf even if NGROUPS_MAX is defined. That way, the
limit can be raised in the kernel configuration without having to limit can be raised in the kernel configuration without having to
recompile libc. */ recompile libc. */
long int limit = __sysconf (_SC_NGROUPS_MAX); long int limit = __sysconf (_SC_NGROUPS_MAX);
@ -179,51 +257,12 @@ initgroups (user, group)
/* No more memory. */ /* No more memory. */
return -1; return -1;
groups[0] = group; ngroups = internal_getgrouplist (user, group, &size, &groups, limit);
if (__nss_group_database != NULL)
{
no_more = 0;
nip = __nss_group_database;
}
else
no_more = __nss_database_lookup ("group", NULL,
"compat [NOTFOUND=return] files", &nip);
while (! no_more)
{
fct = __nss_lookup_function (nip, "initgroups_dyn");
if (fct == NULL)
{
status = compat_call (nip, user, group, &start, &size, &groups,
limit, &errno);
if (nss_next_action (nip, NSS_STATUS_UNAVAIL) != NSS_ACTION_CONTINUE)
break;
}
else
status = DL_CALL_FCT (fct, (user, group, &start, &size, &groups,
limit, &errno));
/* This is really only for debugging. */
if (NSS_STATUS_TRYAGAIN > status || status > NSS_STATUS_RETURN)
__libc_fatal ("illegal status in " __FUNCTION__);
if (status != NSS_STATUS_SUCCESS
&& nss_next_action (nip, status) == NSS_ACTION_RETURN)
break;
if (nip->next == NULL)
no_more = -1;
else
nip = nip->next;
}
/* Try to set the maximum number of groups the kernel can handle. */ /* Try to set the maximum number of groups the kernel can handle. */
do do
result = setgroups (start, groups); result = setgroups (ngroups, groups);
while (result == -1 && errno == EINVAL && --start > 0); while (result == -1 && errno == EINVAL && --ngroups > 0);
free (groups); free (groups);

View File

@ -1,4 +1,4 @@
/* Copyright (C) 1991, 92, 93, 94, 95, 96, 97 Free Software Foundation, Inc. /* Copyright (C) 1991-1997, 2001 Free Software Foundation, Inc.
This file is part of the GNU C Library. This file is part of the GNU C Library.
The GNU C Library is free software; you can redistribute it and/or The GNU C Library is free software; you can redistribute it and/or
@ -22,18 +22,19 @@
#include <inttypes.h> #include <inttypes.h>
#include <netinet/in.h> #include <netinet/in.h>
struct ip6_hdr struct ip6_hdr
{ {
union union
{ {
struct ip6_hdrctl struct ip6_hdrctl
{ {
uint32_t ip6_un1_flow; /* 24 bits of flow-ID */ uint32_t ip6_un1_flow; /* 4 bits version, 8 bits TC,
20 bits flow-ID */
uint16_t ip6_un1_plen; /* payload length */ uint16_t ip6_un1_plen; /* payload length */
uint8_t ip6_un1_nxt; /* next header */ uint8_t ip6_un1_nxt; /* next header */
uint8_t ip6_un1_hlim; /* hop limit */ uint8_t ip6_un1_hlim; /* hop limit */
} ip6_un1; } ip6_un1;
uint8_t ip6_un2_vfc; /* 4 bits version, 4 bits priority */ uint8_t ip6_un2_vfc; /* 4 bits version, top 4 bits tclass */
} ip6_ctlun; } ip6_ctlun;
struct in6_addr ip6_src; /* source address */ struct in6_addr ip6_src; /* source address */
struct in6_addr ip6_dst; /* destination address */ struct in6_addr ip6_dst; /* destination address */
@ -47,7 +48,7 @@ struct ip6_hdr
#define ip6_hops ip6_ctlun.ip6_un1.ip6_un1_hlim #define ip6_hops ip6_ctlun.ip6_un1.ip6_un1_hlim
/* Hop-by-Hop options header. */ /* Hop-by-Hop options header. */
struct ip6_hbh struct ip6_hbh
{ {
uint8_t ip6h_nxt; /* next hesder. */ uint8_t ip6h_nxt; /* next hesder. */
uint8_t ip6h_len; /* length in units of 8 octets. */ uint8_t ip6h_len; /* length in units of 8 octets. */
@ -55,7 +56,7 @@ struct ip6_hbh
}; };
/* Destination options header */ /* Destination options header */
struct ip6_dest struct ip6_dest
{ {
uint8_t ip6d_nxt; /* next header */ uint8_t ip6d_nxt; /* next header */
uint8_t ip6d_len; /* length in units of 8 octets */ uint8_t ip6d_len; /* length in units of 8 octets */
@ -63,7 +64,7 @@ struct ip6_dest
}; };
/* Routing header */ /* Routing header */
struct ip6_rthdr struct ip6_rthdr
{ {
uint8_t ip6r_nxt; /* next header */ uint8_t ip6r_nxt; /* next header */
uint8_t ip6r_len; /* length in units of 8 octets */ uint8_t ip6r_len; /* length in units of 8 octets */
@ -73,7 +74,7 @@ struct ip6_rthdr
}; };
/* Type 0 Routing header */ /* Type 0 Routing header */
struct ip6_rthdr0 struct ip6_rthdr0
{ {
uint8_t ip6r0_nxt; /* next header */ uint8_t ip6r0_nxt; /* next header */
uint8_t ip6r0_len; /* length in units of 8 octets */ uint8_t ip6r0_len; /* length in units of 8 octets */
@ -85,7 +86,7 @@ struct ip6_rthdr0
}; };
/* Fragment header */ /* Fragment header */
struct ip6_frag struct ip6_frag
{ {
uint8_t ip6f_nxt; /* next header */ uint8_t ip6f_nxt; /* next header */
uint8_t ip6f_reserved; /* reserved field */ uint8_t ip6f_reserved; /* reserved field */

View File

@ -1,3 +1,10 @@
2001-03-23 Matthew Wilcox <willy@ldl.fc.hp.com>
* attr.c: Make _STACK_GROWS_UP work.
* internals.h: Likewise.
* manager.c: Likewise.
* pthread.c: Likewise.
2001-06-15 H.J. Lu <hjl@gnu.org> 2001-06-15 H.J. Lu <hjl@gnu.org>
* pthread.c (__pthread_reset_main_thread): Fix a typo. * pthread.c (__pthread_reset_main_thread): Fix a typo.