diff options
| author | Maxim Sobolev <sobomax@FreeBSD.org> | 2005-01-29 23:12:00 +0000 |
|---|---|---|
| committer | Maxim Sobolev <sobomax@FreeBSD.org> | 2005-01-29 23:12:00 +0000 |
| commit | 610ecfe035fa08e39d4f6f6a247a16b7e60188e7 (patch) | |
| tree | c697d47092272c8c6973b42ba0a424e9763f7ce5 /sys/kern/kern_kse.c | |
| parent | 3fcd9325ec61ead859015f90f524cda56ef9d347 (diff) | |
Notes
Diffstat (limited to 'sys/kern/kern_kse.c')
| -rw-r--r-- | sys/kern/kern_kse.c | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/sys/kern/kern_kse.c b/sys/kern/kern_kse.c index d0e03ecb9df7..4e648f541850 100644 --- a/sys/kern/kern_kse.c +++ b/sys/kern/kern_kse.c @@ -32,6 +32,7 @@ __FBSDID("$FreeBSD$"); #include <sys/param.h> #include <sys/systm.h> #include <sys/kernel.h> +#include <sys/imgact.h> #include <sys/lock.h> #include <sys/mutex.h> #include <sys/proc.h> @@ -176,6 +177,7 @@ int kse_thr_interrupt(struct thread *td, struct kse_thr_interrupt_args *uap) { struct kse_execve_args args; + struct image_args iargs; struct proc *p; struct thread *td2; struct kse_upcall *ku; @@ -261,7 +263,11 @@ kse_thr_interrupt(struct thread *td, struct kse_thr_interrupt_args *uap) error = copyin((void *)uap->data, &args, sizeof(args)); if (error) return (error); - error = kern_execve(td, args.path, args.argv, args.envp, NULL); + error = exec_copyin_args(&iargs, args.path, UIO_USERSPACE, + args.argv, args.envp); + if (error == 0) + error = kern_execve(td, &iargs, NULL); + exec_free_args(&iargs); if (error == 0) { PROC_LOCK(p); SIGSETOR(td->td_siglist, args.sigpend); |
