Fix exec_map resource leaks.

Tested by: kris@
This commit is contained in:
ups 2006-03-08 20:21:54 +00:00
parent edc000b320
commit 5ad34fd1d6
3 changed files with 46 additions and 28 deletions

View File

@ -130,7 +130,7 @@ linux_exec_copyin_args(struct image_args *args, char *fname,
copystr(fname, args->fname, PATH_MAX, &length) :
copyinstr(fname, args->fname, PATH_MAX, &length);
if (error != 0)
return (error);
goto err_exit;
/*
* extract arguments first
@ -139,16 +139,16 @@ linux_exec_copyin_args(struct image_args *args, char *fname,
for (;;) {
error = copyin(p32++, &arg, sizeof(arg));
if (error)
return (error);
goto err_exit;
if (arg == 0)
break;
argp = PTRIN(arg);
error = copyinstr(argp, args->endp, args->stringspace, &length);
if (error) {
if (error == ENAMETOOLONG)
return (E2BIG);
else
return (error);
error = E2BIG;
goto err_exit;
}
args->stringspace -= length;
args->endp += length;
@ -165,7 +165,7 @@ linux_exec_copyin_args(struct image_args *args, char *fname,
for (;;) {
error = copyin(p32++, &arg, sizeof(arg));
if (error)
return (error);
goto err_exit;
if (arg == 0)
break;
envp = PTRIN(arg);
@ -173,9 +173,8 @@ linux_exec_copyin_args(struct image_args *args, char *fname,
&length);
if (error) {
if (error == ENAMETOOLONG)
return (E2BIG);
else
return (error);
error = E2BIG;
goto err_exit;
}
args->stringspace -= length;
args->endp += length;
@ -184,6 +183,12 @@ linux_exec_copyin_args(struct image_args *args, char *fname,
}
return (0);
err_exit:
kmem_free_wakeup(exec_map, (vm_offset_t)args->buf,
PATH_MAX + ARG_MAX + MAXSHELLCMDLEN);
args->buf = NULL;
return (error);
}
int

View File

@ -260,7 +260,7 @@ freebsd32_exec_copyin_args(struct image_args *args, char *fname,
copystr(fname, args->fname, PATH_MAX, &length) :
copyinstr(fname, args->fname, PATH_MAX, &length);
if (error != 0)
return (error);
goto err_exit;
/*
* extract arguments first
@ -269,16 +269,15 @@ freebsd32_exec_copyin_args(struct image_args *args, char *fname,
for (;;) {
error = copyin(p32++, &arg, sizeof(arg));
if (error)
return (error);
goto err_exit;
if (arg == 0)
break;
argp = PTRIN(arg);
error = copyinstr(argp, args->endp, args->stringspace, &length);
if (error) {
if (error == ENAMETOOLONG)
return (E2BIG);
else
return (error);
error = E2BIG;
goto err_exit;
}
args->stringspace -= length;
args->endp += length;
@ -295,7 +294,7 @@ freebsd32_exec_copyin_args(struct image_args *args, char *fname,
for (;;) {
error = copyin(p32++, &arg, sizeof(arg));
if (error)
return (error);
goto err_exit;
if (arg == 0)
break;
envp = PTRIN(arg);
@ -303,9 +302,8 @@ freebsd32_exec_copyin_args(struct image_args *args, char *fname,
&length);
if (error) {
if (error == ENAMETOOLONG)
return (E2BIG);
else
return (error);
error = E2BIG;
goto err_exit;
}
args->stringspace -= length;
args->endp += length;
@ -314,6 +312,12 @@ freebsd32_exec_copyin_args(struct image_args *args, char *fname,
}
return (0);
err_exit:
kmem_free_wakeup(exec_map, (vm_offset_t)args->buf,
PATH_MAX + ARG_MAX + MAXSHELLCMDLEN);
args->buf = NULL;
return (error);
}
int

View File

@ -243,6 +243,7 @@ kern_execve(td, args, mac_p)
PROC_LOCK(p);
if (thread_single(SINGLE_BOUNDARY)) {
PROC_UNLOCK(p);
exec_free_args(args);
return (ERESTART); /* Try again later. */
}
PROC_UNLOCK(p);
@ -980,19 +981,21 @@ exec_copyin_args(struct image_args *args, char *fname,
copystr(fname, args->fname, PATH_MAX, &length) :
copyinstr(fname, args->fname, PATH_MAX, &length);
if (error != 0)
return (error);
goto err_exit;
/*
* extract arguments first
*/
while ((argp = (caddr_t) (intptr_t) fuword(argv++))) {
if (argp == (caddr_t) -1)
return (EFAULT);
if (argp == (caddr_t) -1) {
error = EFAULT;
goto err_exit;
}
if ((error = copyinstr(argp, args->endp,
args->stringspace, &length))) {
if (error == ENAMETOOLONG)
return (E2BIG);
return (error);
if (error == ENAMETOOLONG)
error = E2BIG;
goto err_exit;
}
args->stringspace -= length;
args->endp += length;
@ -1006,13 +1009,15 @@ exec_copyin_args(struct image_args *args, char *fname,
*/
if (envv) {
while ((envp = (caddr_t)(intptr_t)fuword(envv++))) {
if (envp == (caddr_t)-1)
return (EFAULT);
if (envp == (caddr_t)-1) {
error = EFAULT;
goto err_exit;
}
if ((error = copyinstr(envp, args->endp,
args->stringspace, &length))) {
if (error == ENAMETOOLONG)
return (E2BIG);
return (error);
error = E2BIG;
goto err_exit;
}
args->stringspace -= length;
args->endp += length;
@ -1021,6 +1026,10 @@ exec_copyin_args(struct image_args *args, char *fname,
}
return (0);
err_exit:
exec_free_args(args);
return (error);
}
static void