score: switch to generic fork/vfork/clone
authorAl Viro <viro@zeniv.linux.org.uk>
Sun, 21 Oct 2012 20:44:57 +0000 (16:44 -0400)
committerAl Viro <viro@zeniv.linux.org.uk>
Thu, 29 Nov 2012 04:43:40 +0000 (23:43 -0500)
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
arch/score/Kconfig
arch/score/include/asm/syscalls.h
arch/score/include/asm/unistd.h
arch/score/kernel/entry.S
arch/score/kernel/process.c
arch/score/kernel/sys_score.c

index a285e78fb9c563d1eab1e33daee7787b8aa44756..45893390c7ddb4f32052764177b3f2d01949b53c 100644 (file)
@@ -15,6 +15,7 @@ config SCORE
        select MODULES_USE_ELF_REL
        select GENERIC_KERNEL_THREAD
        select GENERIC_KERNEL_EXECVE
+       select CLONE_BACKWARDS
 
 choice
        prompt "System type"
index 8d332534342f608f5ae6c037707c73e94b7b8db8..acaeed6809562c70444b015d3e8c621c57421edd 100644 (file)
@@ -1,7 +1,6 @@
 #ifndef _ASM_SCORE_SYSCALLS_H
 #define _ASM_SCORE_SYSCALLS_H
 
-asmlinkage long score_clone(struct pt_regs *regs);
 asmlinkage long score_sigaltstack(struct pt_regs *regs);
 asmlinkage long score_rt_sigreturn(struct pt_regs *regs);
 
index b006ca435120500d4ee75c10ef61ca02413e110b..56001c93095aaa7977d869e41f7866a5b0598f2c 100644 (file)
@@ -5,5 +5,8 @@
 #define __ARCH_WANT_SYSCALL_OFF_T
 #define __ARCH_WANT_SYSCALL_DEPRECATED
 #define __ARCH_WANT_SYS_EXECVE
+#define __ARCH_WANT_SYS_CLONE
+#define __ARCH_WANT_SYS_FORK
+#define __ARCH_WANT_SYS_VFORK
 
 #include <asm-generic/unistd.h>
index da9901088bbbc907be62d85c367615ec2151462d..1557ca1a29519d6e93a5fbf5c201da9fc3907cfd 100644 (file)
@@ -487,11 +487,6 @@ illegal_syscall:
        sw      r9, [r0, PT_R7]
        j       syscall_return
 
-ENTRY(sys_clone)
-       mv      r4, r0
-       la      r8, score_clone
-       br      r8
-
 ENTRY(sys_rt_sigreturn)
        mv      r4, r0
        la      r8, score_rt_sigreturn
@@ -501,16 +496,3 @@ ENTRY(sys_sigaltstack)
        mv      r4, r0
        la      r8, score_sigaltstack
        br      r8
-
-#ifdef __ARCH_WANT_SYSCALL_DEPRECATED
-ENTRY(sys_fork)
-       mv      r4, r0
-       la      r8, score_fork
-       br      r8
-
-ENTRY(sys_vfork)
-       mv      r4, r0
-       la      r8, score_vfork
-       br      r8
-#endif /* __ARCH_WANT_SYSCALL_DEPRECATED */
-
index 6f311cf64b9987385b473e6a8f7209defd78af76..f96379a5aee032cdd03e0d5194148d45a9ffd6ee 100644 (file)
@@ -94,17 +94,17 @@ int copy_thread(unsigned long clone_flags, unsigned long usp,
        struct pt_regs *childregs = task_pt_regs(p);
 
        p->thread.reg0 = (unsigned long) childregs;
-       if (unlikely(!regs)) {
+       if (unlikely(p->flags & PF_KTHREAD)) {
                memset(childregs, 0, sizeof(struct pt_regs));
                p->thread->reg12 = usp;
                p->thread->reg13 = arg;
                p->thread.reg3 = (unsigned long) ret_from_kernel_thread;
        } else {
-               *childregs = *regs;
+               *childregs = *current_pt_regs();
                childregs->regs[7] = 0;         /* Clear error flag */
                childregs->regs[4] = 0;         /* Child gets zero as return value */
-               childregs->regs[0] = usp;       /* user fork */
-               regs->regs[4] = p->pid;         /* WTF? */
+               if (usp)
+                       childregs->regs[0] = usp;       /* user fork */
                p->thread.reg3 = (unsigned long) ret_from_fork;
        }
 
index c54434c2fd9dfeb8a5578d5c73d0e4987242856c..47c20ba461676f432573f1518249940514b3da4c 100644 (file)
@@ -48,38 +48,3 @@ sys_mmap(unsigned long addr, unsigned long len, unsigned long prot,
                return -EINVAL;
        return sys_mmap_pgoff(addr, len, prot, flags, fd, offset >> PAGE_SHIFT);
 }
-
-asmlinkage long
-score_fork(struct pt_regs *regs)
-{
-       return do_fork(SIGCHLD, regs->regs[0], regs, 0, NULL, NULL);
-}
-
-/*
- * Clone a task - this clones the calling program thread.
- * This is called indirectly via a small wrapper
- */
-asmlinkage long
-score_clone(struct pt_regs *regs)
-{
-       unsigned long clone_flags;
-       unsigned long newsp;
-       int __user *parent_tidptr, *child_tidptr;
-
-       clone_flags = regs->regs[4];
-       newsp = regs->regs[5];
-       if (!newsp)
-               newsp = regs->regs[0];
-       parent_tidptr = (int __user *)regs->regs[6];
-       child_tidptr = (int __user *)regs->regs[8];
-
-       return do_fork(clone_flags, newsp, regs, 0,
-                       parent_tidptr, child_tidptr);
-}
-
-asmlinkage long
-score_vfork(struct pt_regs *regs)
-{
-       return do_fork(CLONE_VFORK | CLONE_VM | SIGCHLD,
-                       regs->regs[0], regs, 0, NULL, NULL);
-}