From c240c3a58f21d72982e74a485bd7c4900f188876 Mon Sep 17 00:00:00 2001 From: Joe Landers Date: Thu, 29 Oct 2009 19:59:59 -0700 Subject: Fix error handling in NIS. A buffer was freed even though it wasn't allocated as expected. Do this only when !batch_read. --- nis/nss_nis/nis-grp.c | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) (limited to 'nis') diff --git a/nis/nss_nis/nis-grp.c b/nis/nss_nis/nis-grp.c index 071d8a2a55..6ad30eb1bb 100644 --- a/nis/nss_nis/nis-grp.c +++ b/nis/nss_nis/nis-grp.c @@ -204,7 +204,8 @@ internal_nis_getgrent_r (struct group *grp, char *buffer, size_t buflen, if (__builtin_expect ((size_t) (len + 1) > buflen, 0)) { - free (result); + if (!batch_read) + free (result); *errnop = ERANGE; return NSS_STATUS_TRYAGAIN; } -- cgit v1.2.3