about summary refs log tree commit diff
path: root/misc
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>2010-02-03 06:23:31 -0800
committerPetr Baudis <pasky@ucw.cz>2010-05-12 01:41:59 +0200
commitb204d65517276f8cdaf3a83349d0f1f553da68a2 (patch)
tree615653306b1e0204bff4fb4f5575272ab511651f /misc
parent272eb2b141c22d03c1c68050b4ad97b2a0adfc69 (diff)
downloadglibc-b204d65517276f8cdaf3a83349d0f1f553da68a2.tar.gz
glibc-b204d65517276f8cdaf3a83349d0f1f553da68a2.tar.xz
glibc-b204d65517276f8cdaf3a83349d0f1f553da68a2.zip
Fix endless loop with invalid /etc/shells file.
(cherry picked from commit caa6e77293d85e31dfde371b78862e9330a1478e)
Diffstat (limited to 'misc')
-rw-r--r--misc/getusershell.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/misc/getusershell.c b/misc/getusershell.c
index 636da322f9..0e4f79619f 100644
--- a/misc/getusershell.c
+++ b/misc/getusershell.c
@@ -116,7 +116,8 @@ initshells()
 	}
 	if (statb.st_size > ~(size_t)0 / sizeof (char *) * 3)
 		goto init_okshells;
-	if ((strings = malloc(statb.st_size + 2)) == NULL)
+	flen = statb.st_size + 3;
+	if ((strings = malloc(flen)) == NULL)
 		goto init_okshells;
 	shells = malloc(statb.st_size / 3 * sizeof (char *));
 	if (shells == NULL) {
@@ -126,7 +127,6 @@ initshells()
 	}
 	sp = shells;
 	cp = strings;
-	flen = statb.st_size + 2;
 	while (fgets_unlocked(cp, flen - (cp - strings), fp) != NULL) {
 		while (*cp != '#' && *cp != '/' && *cp != '\0')
 			cp++;