summaryrefslogtreecommitdiff
path: root/libc/sysdeps/linux/common/getgroups.c
diff options
context:
space:
mode:
authorMike Frysinger <vapier@gentoo.org>2005-12-28 21:19:58 +0000
committerMike Frysinger <vapier@gentoo.org>2005-12-28 21:19:58 +0000
commitba56672d0f0932384b3b749b48173f14ae9dc6fc (patch)
treed8a882b9cf91df32cfe0c5c540c5bc89dac4dd65 /libc/sysdeps/linux/common/getgroups.c
parent8f7b38133bb46cb5fa211ae97e3d22d1f76dcb8f (diff)
make sure we handle the (malloc(0)==NULL) case as Aubrey points out via the e-mail list
Diffstat (limited to 'libc/sysdeps/linux/common/getgroups.c')
-rw-r--r--libc/sysdeps/linux/common/getgroups.c6
1 files changed, 4 insertions, 2 deletions
diff --git a/libc/sysdeps/linux/common/getgroups.c b/libc/sysdeps/linux/common/getgroups.c
index 92cdca2d0..83d92627e 100644
--- a/libc/sysdeps/linux/common/getgroups.c
+++ b/libc/sysdeps/linux/common/getgroups.c
@@ -32,7 +32,7 @@ ret_error:
size = MIN(size, sysconf(_SC_NGROUPS_MAX));
kernel_groups = (__kernel_gid_t *)malloc(sizeof(*kernel_groups) * size);
- if (kernel_groups == NULL)
+ if (size && kernel_groups == NULL)
goto ret_error;
ngids = __syscall_getgroups(size, kernel_groups);
@@ -41,7 +41,9 @@ ret_error:
groups[i] = kernel_groups[i];
}
}
- free(kernel_groups);
+
+ if (kernel_groups)
+ free(kernel_groups);
return ngids;
}
}