mirror of
https://github.com/systemd/systemd.git
synced 2025-03-19 22:50:17 +03:00
posix_spawn_wrapper: do not set POSIX_SPAWN_SETSIGDEF flag
Setting this flag is a noop without a corresponding call to posix_spawnattr_setsigdefault. If we call posix_spawnattr_setsigdefault with a full signal set, it causes glibc's posix_spawn implementation to call sigaction 63 times, once for each signal. That seems wasteful. This feature is really only useful for signals which have their disposition set to SIG_IGN. Otherwise the dispostion gets set to SIG_DFL automatically, either by clone(CLONE_CLEAR_SIGHAND) or the subsequent execve. As far as I can tell, systemd does not have any signals set to SIG_IGN under normal operating conditions. (cherry picked from commit ff94426f8a2d6cd4ea2e370835db152917a1684e)
This commit is contained in:
parent
9d060fb7eb
commit
aa0aa1093d
@ -2036,7 +2036,7 @@ int posix_spawn_wrapper(
|
||||
const char *cgroup,
|
||||
PidRef *ret_pidref) {
|
||||
|
||||
short flags = POSIX_SPAWN_SETSIGMASK|POSIX_SPAWN_SETSIGDEF;
|
||||
short flags = POSIX_SPAWN_SETSIGMASK;
|
||||
posix_spawnattr_t attr;
|
||||
sigset_t mask;
|
||||
int r;
|
||||
|
Loading…
x
Reference in New Issue
Block a user