From 1599ed4e959e6e5b319d82389667f51d01d53da0 Mon Sep 17 00:00:00 2001 From: Florian Weimer Date: Mon, 25 Jun 2018 19:22:46 +0200 Subject: [PATCH] getent: Use dynarray in initgroups_keys [BZ #18023] --- ChangeLog | 6 ++++++ nss/getent.c | 40 ++++++++++++++++++++++++++++++---------- 2 files changed, 36 insertions(+), 10 deletions(-) diff --git a/ChangeLog b/ChangeLog index a2fc4b793f4..b0159351952 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,9 @@ +2018-06-25 Florian Weimer + + [BZ #18023] + * nss/getent.c (initgroups_keys): Use dynarray instead of + extend_alloca. + 2018-06-25 Florian Weimer [BZ #18023] diff --git a/nss/getent.c b/nss/getent.c index e609e5f9bb6..92ade41d751 100644 --- a/nss/getent.c +++ b/nss/getent.c @@ -39,6 +39,7 @@ #include #include #include +#include /* Get libc version number. */ #include @@ -473,34 +474,51 @@ netgroup_keys (int number, char *key[]) return result; } +#define DYNARRAY_STRUCT gid_list +#define DYNARRAY_ELEMENT gid_t +#define DYNARRAY_PREFIX gid_list_ +#define DYNARRAY_INITIAL_SIZE 10 +#include + /* This is for initgroups */ static int initgroups_keys (int number, char *key[]) { - int ngrps = 100; - size_t grpslen = ngrps * sizeof (gid_t); - gid_t *grps = alloca (grpslen); - if (number == 0) { fprintf (stderr, _("Enumeration not supported on %s\n"), "initgroups"); return 3; } + struct gid_list list; + gid_list_init (&list); + if (!gid_list_resize (&list, 10)) + { + fprintf (stderr, _("Could not allocate group list: %m\n")); + return 3; + } + for (int i = 0; i < number; ++i) { - int no = ngrps; + int no = gid_list_size (&list); int n; - while ((n = getgrouplist (key[i], -1, grps, &no)) == -1 - && no > ngrps) + while ((n = getgrouplist (key[i], -1, gid_list_begin (&list), &no)) == -1 + && no > gid_list_size (&list)) { - grps = extend_alloca (grps, grpslen, no * sizeof (gid_t)); - ngrps = no; + if (!gid_list_resize (&list, no)) + { + fprintf (stderr, _("Could not allocate group list: %m\n")); + return 3; + } } if (n == -1) - return 1; + { + gid_list_free (&list); + return 1; + } + const gid_t *grps = gid_list_begin (&list); printf ("%-21s", key[i]); for (int j = 0; j < n; ++j) if (grps[j] != -1) @@ -508,6 +526,8 @@ initgroups_keys (int number, char *key[]) putchar_unlocked ('\n'); } + gid_list_free (&list); + return 0; } -- 2.39.2