Update.
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:
parent
cc765c2a2e
commit
8fee1bb0b2
13
ChangeLog
13
ChangeLog
@ -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
5
NEWS
@ -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
|
||||||
|
|
||||||
|
@ -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;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -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. */
|
||||||
|
141
grp/initgroups.c
141
grp/initgroups.c
@ -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,14 +234,9 @@ 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
|
||||||
@ -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);
|
||||||
|
|
||||||
|
@ -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
|
||||||
@ -28,12 +28,13 @@ struct ip6_hdr
|
|||||||
{
|
{
|
||||||
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 */
|
||||||
|
@ -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.
|
||||||
|
Loading…
x
Reference in New Issue
Block a user