mirror of
https://github.com/fish-shell/fish-shell.git
synced 2025-01-23 12:08:53 +08:00
Don't wait for disowned pgids if they are special
If a job is disowned that, for some reason, has a pgid that is special to waitpid, like 0 (process with pgid of the calling process), -1 (any process), or our actual pgid, that would lead to us waiting for too many processes when we later try to reap the disowned processes (to stop zombies from appearing). And that means we'd snag away the processes we actually do want to wait for, which would end with us in a waiting loop. This is tough to reproduce, the easiest I've found was fish -ic 'sleep 5 &; disown; set -g __fish_git_prompt_showupstream auto; __fish_git_prompt' in a git repo. What we do is to not allow special pgids in the disowned_pids list. That means we might leave a zombie around (though we probably wait on 0 somewhere), but that's preferable to infinitely looping. See #5426.
This commit is contained in:
parent
32e6bf6f64
commit
4a3ac6e91e
|
@ -354,7 +354,12 @@ typedef unsigned int process_generation_count_t;
|
||||||
static std::vector<pid_t> s_disowned_pids;
|
static std::vector<pid_t> s_disowned_pids;
|
||||||
|
|
||||||
void add_disowned_pgid(pid_t pgid) {
|
void add_disowned_pgid(pid_t pgid) {
|
||||||
s_disowned_pids.push_back(pgid * -1);
|
// NEVER add our own pgid, or one of the special values,
|
||||||
|
// or waiting for it will
|
||||||
|
// snag other processes away.
|
||||||
|
if (pgid != getpgrp() && (pgid > 0 || pgid < -1)) {
|
||||||
|
s_disowned_pids.push_back(pgid * -1);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// A static value tracking how many SIGCHLDs we have seen, which is used in a heurstic to
|
/// A static value tracking how many SIGCHLDs we have seen, which is used in a heurstic to
|
||||||
|
|
Loading…
Reference in New Issue
Block a user