Fix memory leak.

* libmisc/setupenv.c: Free pw_dir and pw_shell before reallocating
	them.
This commit is contained in:
Nicolas François 2013-08-02 20:28:24 +02:00
parent b6c1a8579e
commit ee1952424d
2 changed files with 4 additions and 0 deletions

View File

@ -3,6 +3,8 @@
* libmisc/setupenv.c: xstrdup the static char* temp_pw_dir / * libmisc/setupenv.c: xstrdup the static char* temp_pw_dir /
temp_pw_shell. That way we can continue to use pw_free() without temp_pw_shell. That way we can continue to use pw_free() without
segving. Thanks to Serge Hallyn for the patch. segving. Thanks to Serge Hallyn for the patch.
* libmisc/setupenv.c: Free pw_dir and pw_shell before reallocating
them.
2013-08-01 Yuri Kozlov <yuray@komyakino.ru> 2013-08-01 Yuri Kozlov <yuray@komyakino.ru>

View File

@ -228,6 +228,7 @@ void setup_env (struct passwd *info)
exit (EXIT_FAILURE); exit (EXIT_FAILURE);
} }
(void) puts (_("No directory, logging in with HOME=/")); (void) puts (_("No directory, logging in with HOME=/"));
free (info->pw_dir);
info->pw_dir = xstrdup (temp_pw_dir); info->pw_dir = xstrdup (temp_pw_dir);
} }
@ -244,6 +245,7 @@ void setup_env (struct passwd *info)
if ((NULL == info->pw_shell) || ('\0' == *info->pw_shell)) { if ((NULL == info->pw_shell) || ('\0' == *info->pw_shell)) {
static char temp_pw_shell[] = SHELL; static char temp_pw_shell[] = SHELL;
free (info->pw_shell);
info->pw_shell = xstrdup (temp_pw_shell); info->pw_shell = xstrdup (temp_pw_shell);
} }