block signals during fork
commitd4d6d6f322cd13cfca2b179345cdcf67997c3529
authorRich Felker <dalias@aerifal.cx>
Fri, 9 Aug 2013 03:17:05 +0000 (8 23:17 -0400)
committerRich Felker <dalias@aerifal.cx>
Fri, 9 Aug 2013 03:17:05 +0000 (8 23:17 -0400)
tree14f41853339c148be7315a2471d7123f3ae3239f
parent72482f9020e4362b8d35849df6dca49f26d24c54
block signals during fork

there are several reasons for this. some of them are related to race
conditions that arise since fork is required to be async-signal-safe:
if fork or pthread_create is called from a signal handler after the
fork syscall has returned but before the subsequent userspace code has
finished, inconsistent state could result. also, there seem to be
kernel and/or strace bugs related to arrival of signals during fork,
at least on some versions, and simply blocking signals eliminates the
possibility of such bugs.
src/process/fork.c