On Wed, Apr 25, 2012 at 03:03:29PM +0200, Oleg Nesterov wrote: > Yes, and it sets TIF_SIGPENDING, but unless I missed something this doesn't > matter. > > > So no, > > it might have been blocked prior to sigsuspend(). > > If it was not blocked, then the next do_signal()->get_signal_to_deliver() > returns 0 and clears TIF_SIGPENDING. After that we finally re-enter > sys_sigsuspend() and (assuming it unblocks this sig) notice this pending > signal again and return -EINTR eventually. Point... Still, since we are talking about an arbitrary wide window (the damn thing is waiting for signals to arrive, after all) this doesn't sound good; sure, we might have been hit by SIGSTOP just before entering that sigsuspend() with SIGCONT arriving only when the signal in question had, ending up with handler running before sigsuspend(), but... IMO it's a QoI problem at the very least. As for SA_RESTART/!SA_RESTART mixes, if SA_RESTART comes first we should just take that restart and pretend that the second signal has arrived at the very beginning of handler, I think. Assuming I understood you correctly, that is. -- To unsubscribe from this list: send the line "unsubscribe linux-arch" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html