summaryrefslogtreecommitdiff
path: root/sys/kern/kern_kse.c
diff options
context:
space:
mode:
authorMaxim Sobolev <sobomax@FreeBSD.org>2005-01-29 23:12:00 +0000
committerMaxim Sobolev <sobomax@FreeBSD.org>2005-01-29 23:12:00 +0000
commit610ecfe035fa08e39d4f6f6a247a16b7e60188e7 (patch)
treec697d47092272c8c6973b42ba0a424e9763f7ce5 /sys/kern/kern_kse.c
parent3fcd9325ec61ead859015f90f524cda56ef9d347 (diff)
Notes
Diffstat (limited to 'sys/kern/kern_kse.c')
-rw-r--r--sys/kern/kern_kse.c8
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);