From b9b9a51e4911b17e75b39fd3db9f7268e233ce20 Mon Sep 17 00:00:00 2001 From: Ulrich Drepper Date: Wed, 23 Apr 2003 21:27:36 +0000 Subject: Update. 2003-04-23 Ulrich Drepper * grp/initgroups.c (getgrouplist): Don't copy too much into the user buffer if more groups are found than fit into it. * nis/nss_nis/nis-initgroups.c (_nss_nis_initgroups_dyn): Use extend_alloca. --- grp/initgroups.c | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) (limited to 'grp') diff --git a/grp/initgroups.c b/grp/initgroups.c index dd7a8fde1c..1e4c2b5c2b 100644 --- a/grp/initgroups.c +++ b/grp/initgroups.c @@ -1,4 +1,4 @@ -/* Copyright (C) 1989,91,93,1996-2001, 2002 Free Software Foundation, Inc. +/* Copyright (C) 1989,91,93,1996-2002, 2003 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 @@ -23,6 +23,7 @@ #include #include #include +#include #include #include @@ -207,6 +208,9 @@ getgrouplist (const char *user, gid_t group, gid_t *groups, int *ngroups) return -1; result = internal_getgrouplist (user, group, &size, &newgroups, -1); + + memcpy (groups, newgroups, MIN (*ngroups, result) * sizeof (gid_t)); + if (result > *ngroups) { *ngroups = result; @@ -215,8 +219,6 @@ getgrouplist (const char *user, gid_t group, gid_t *groups, int *ngroups) else *ngroups = result; - memcpy (groups, newgroups, *ngroups * sizeof (gid_t)); - free (newgroups); return result; } -- cgit 1.4.1