Commit 1ea2a016 authored by Al Viro's avatar Al Viro

mn10300: switch to generic fork/vfork/clone

Signed-off-by: default avatarAl Viro <viro@zeniv.linux.org.uk>
parent 3416e809
...@@ -44,6 +44,9 @@ ...@@ -44,6 +44,9 @@
#define __ARCH_WANT_SYS_RT_SIGACTION #define __ARCH_WANT_SYS_RT_SIGACTION
#define __ARCH_WANT_SYS_RT_SIGSUSPEND #define __ARCH_WANT_SYS_RT_SIGSUSPEND
#define __ARCH_WANT_SYS_EXECVE #define __ARCH_WANT_SYS_EXECVE
#define __ARCH_WANT_SYS_FORK
#define __ARCH_WANT_SYS_VFORK
#define __ARCH_WANT_SYS_CLONE
/* /*
* "Conditional" syscalls * "Conditional" syscalls
......
...@@ -206,7 +206,7 @@ int arch_dup_task_struct(struct task_struct *dst, struct task_struct *src) ...@@ -206,7 +206,7 @@ int arch_dup_task_struct(struct task_struct *dst, struct task_struct *src)
*/ */
int copy_thread(unsigned long clone_flags, int copy_thread(unsigned long clone_flags,
unsigned long c_usp, unsigned long ustk_size, unsigned long c_usp, unsigned long ustk_size,
struct task_struct *p, struct pt_regs *kregs) struct task_struct *p, struct pt_regs *unused)
{ {
struct thread_info *ti = task_thread_info(p); struct thread_info *ti = task_thread_info(p);
struct pt_regs *c_regs; struct pt_regs *c_regs;
...@@ -227,7 +227,7 @@ int copy_thread(unsigned long clone_flags, ...@@ -227,7 +227,7 @@ int copy_thread(unsigned long clone_flags,
p->thread.wchan = p->thread.pc; p->thread.wchan = p->thread.pc;
p->thread.usp = c_usp; p->thread.usp = c_usp;
if (unlikely(!kregs)) { if (unlikely(p->flags & PF_KTHREAD)) {
memset(c_regs, 0, sizeof(struct pt_regs)); memset(c_regs, 0, sizeof(struct pt_regs));
c_regs->a0 = c_usp; /* function */ c_regs->a0 = c_usp; /* function */
c_regs->d0 = ustk_size; /* argument */ c_regs->d0 = ustk_size; /* argument */
...@@ -236,7 +236,8 @@ int copy_thread(unsigned long clone_flags, ...@@ -236,7 +236,8 @@ int copy_thread(unsigned long clone_flags,
p->thread.pc = (unsigned long) ret_from_kernel_thread; p->thread.pc = (unsigned long) ret_from_kernel_thread;
return 0; return 0;
} }
*c_regs = *kregs; *c_regs = *current_pt_regs();
if (c_usp)
c_regs->sp = c_usp; c_regs->sp = c_usp;
c_regs->epsw &= ~EPSW_FE; /* my FPU */ c_regs->epsw &= ~EPSW_FE; /* my FPU */
...@@ -249,30 +250,6 @@ int copy_thread(unsigned long clone_flags, ...@@ -249,30 +250,6 @@ int copy_thread(unsigned long clone_flags,
return 0; return 0;
} }
/*
* clone a process
* - tlsptr is retrieved by copy_thread() from current_frame()->d3
*/
asmlinkage long sys_clone(unsigned long clone_flags, unsigned long newsp,
int __user *parent_tidptr, int __user *child_tidptr,
int __user *tlsptr)
{
return do_fork(clone_flags, newsp ?: current_frame()->sp,
current_frame(), 0, parent_tidptr, child_tidptr);
}
asmlinkage long sys_fork(void)
{
return do_fork(SIGCHLD, current_frame()->sp,
current_frame(), 0, NULL, NULL);
}
asmlinkage long sys_vfork(void)
{
return do_fork(CLONE_VFORK | CLONE_VM | SIGCHLD, current_frame()->sp,
current_frame(), 0, NULL, NULL);
}
unsigned long get_wchan(struct task_struct *p) unsigned long get_wchan(struct task_struct *p)
{ {
return p->thread.wchan; return p->thread.wchan;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment