]> bbs.cooldavid.org Git - net-next-2.6.git/blobdiff - arch/sparc/kernel/signal32.c
sparc: Prevent no-handler signal syscall restart recursion.
[net-next-2.6.git] / arch / sparc / kernel / signal32.c
index 643a354795cc70aa422354ece784ef44797e23a6..75fad425e249bc40559f98d14ead5699839bbbb8 100644 (file)
@@ -616,7 +616,7 @@ static int setup_frame32(struct k_sigaction *ka, struct pt_regs *regs,
 
                flush_signal_insns(address);
        }
-       return;
+       return 0;
 
 sigill:
        do_exit(SIGILL);
@@ -840,12 +840,14 @@ void do_signal32(sigset_t *oldset, struct pt_regs * regs,
                regs->u_regs[UREG_I0] = orig_i0;
                regs->tpc -= 4;
                regs->tnpc -= 4;
+               pt_regs_clear_syscall(regs);
        }
        if (restart_syscall &&
            regs->u_regs[UREG_I0] == ERESTART_RESTARTBLOCK) {
                regs->u_regs[UREG_G1] = __NR_restart_syscall;
                regs->tpc -= 4;
                regs->tnpc -= 4;
+               pt_regs_clear_syscall(regs);
        }
 
        /* If there's no signal to deliver, we just put the saved sigmask