score: switch to generic sigaltstack
authorAl Viro <viro@zeniv.linux.org.uk>
Sun, 23 Dec 2012 08:43:28 +0000 (03:43 -0500)
committerAl Viro <viro@zeniv.linux.org.uk>
Sun, 3 Feb 2013 23:16:15 +0000 (18:16 -0500)
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
arch/score/Kconfig
arch/score/include/asm/syscalls.h
arch/score/kernel/entry.S
arch/score/kernel/signal.c

index 3b1482e7afacd37969f338158468bc95bb2dc8d6..a125d7207bccfe735f8c1c0a00443b2095ba9aae 100644 (file)
@@ -14,6 +14,7 @@ config SCORE
        select HAVE_MOD_ARCH_SPECIFIC
        select MODULES_USE_ELF_REL
        select CLONE_BACKWARDS
+       select GENERIC_SIGALTSTACK
 
 choice
        prompt "System type"
index acaeed6809562c70444b015d3e8c621c57421edd..98d1df92fbd13df31cfa1e2ebbfcbd5322008d16 100644 (file)
@@ -1,7 +1,6 @@
 #ifndef _ASM_SCORE_SYSCALLS_H
 #define _ASM_SCORE_SYSCALLS_H
 
-asmlinkage long score_sigaltstack(struct pt_regs *regs);
 asmlinkage long score_rt_sigreturn(struct pt_regs *regs);
 
 #include <asm-generic/syscalls.h>
index 1557ca1a29519d6e93a5fbf5c201da9fc3907cfd..7234ed09b7b7ef5e815b749d8f364921a04b6500 100644 (file)
@@ -491,8 +491,3 @@ ENTRY(sys_rt_sigreturn)
        mv      r4, r0
        la      r8, score_rt_sigreturn
        br      r8
-
-ENTRY(sys_sigaltstack)
-       mv      r4, r0
-       la      r8, score_sigaltstack
-       br      r8
index 02353bde92d883c3aeb0557ba423e0e3c16edfad..a00fba32b0ebe4fb414a8f21b4ab326b3980149b 100644 (file)
@@ -133,16 +133,6 @@ static void __user *get_sigframe(struct k_sigaction *ka,
        return (void __user*)((sp - frame_size) & ~7);
 }
 
-asmlinkage long
-score_sigaltstack(struct pt_regs *regs)
-{
-       const stack_t __user *uss = (const stack_t __user *) regs->regs[4];
-       stack_t __user *uoss = (stack_t __user *) regs->regs[5];
-       unsigned long usp = regs->regs[0];
-
-       return do_sigaltstack(uss, uoss, usp);
-}
-
 asmlinkage long
 score_rt_sigreturn(struct pt_regs *regs)
 {
@@ -167,9 +157,7 @@ score_rt_sigreturn(struct pt_regs *regs)
        else if (sig)
                force_sig(sig, current);
 
-       /* It is more difficult to avoid calling this function than to
-          call it and ignore errors.  */
-       if (do_sigaltstack(&frame->rs_uc.uc_stack, NULL, regs->regs[0]) == -EFAULT)
+       if (restore_altstack(&frame->rs_uc.uc_stack))
                goto badframe;
        regs->is_syscall = 0;
 
@@ -209,12 +197,7 @@ static int setup_rt_frame(struct k_sigaction *ka, struct pt_regs *regs,
        err |= copy_siginfo_to_user(&frame->rs_info, info);
        err |= __put_user(0, &frame->rs_uc.uc_flags);
        err |= __put_user(NULL, &frame->rs_uc.uc_link);
-       err |= __put_user((void __user *)current->sas_ss_sp,
-                               &frame->rs_uc.uc_stack.ss_sp);
-       err |= __put_user(sas_ss_flags(regs->regs[0]),
-                               &frame->rs_uc.uc_stack.ss_flags);
-       err |= __put_user(current->sas_ss_size,
-                               &frame->rs_uc.uc_stack.ss_size);
+       err |= __save_altstack(&frame->rs_uc.uc_stack, regs->regs[0]);
        err |= setup_sigcontext(regs, &frame->rs_uc.uc_mcontext);
        err |= __copy_to_user(&frame->rs_uc.uc_sigmask, set, sizeof(*set));