Searched hist:"14203 e19cbc562a79f49117c45c80639a1e65bdd" (Results 1 – 1 of 1) sorted by relevance
/openbmc/linux/arch/microblaze/kernel/ |
H A D | entry.S | diff 14203e19cbc562a79f49117c45c80639a1e65bdd Sun Apr 29 03:11:34 CDT 2012 Al Viro <viro@zeniv.linux.org.uk> microblaze: fix the horror with restarts of sigreturn()
solution a-la arm one - pick a callee-saved register (r30), set it non-zero when entering a syscall, have sigreturn wrapper zero it out and pass the value in it to do_notify_resume() as "in_syscall" (actually, "restarts allowed") argument.
Note that we don't give a damn about ret_from_fork() - return value is not restart-worthy anyway.
Possible remaining bug: on !MMU we still have _debug_exception() restartable. If it hits with -ERESTART_... accidentally in r3, fun happens. MMU does _not_ have _debug_exception() restartable. If that's decided to be a bug (as I strongly suspect it to be), we'll just need to replace setting r30 to 1 with setting r30 to 0 in !MMU _debug_exception(). Up to microblaze maintainers...
[folded a fix from Michal]
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
|