David S. Miller 2678fefedb sparc64: Fix syscall restart, for real...
The change I put into copy_thread() just papered over the real
problem.

When we are looking to see if we should do a syscall restart, when
deliverying a signal, we should only interpret the syscall return
value as an error if the carry condition code(s) are set.

Otherwise it's a success return.

Also, sigreturn paths should do a pt_regs_clear_trap_type().

It turns out that doing a syscall restart when returning from a fork()
does and should happen, from time to time.  Even if copy_thread()
returns success, copy_process() can still unwind and signal
-ERESTARTNOINTR in the parent.

Signed-off-by: David S. Miller <davem@davemloft.net>
2008-05-02 05:22:52 -07:00
..
2008-04-26 21:41:19 -07:00
2008-04-23 23:32:16 -07:00
2008-04-23 23:32:16 -07:00
2008-04-26 21:41:15 -07:00
2008-04-29 02:38:50 -07:00
2008-04-29 02:38:50 -07:00
2008-04-29 02:38:50 -07:00
2008-04-23 23:32:16 -07:00
2008-04-29 03:19:38 -07:00
2008-04-23 23:32:17 -07:00
2008-04-29 02:38:50 -07:00