mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2024-12-22 13:45:38 +00:00
util: virExec may blocked by reading pipe if grandchild prematurely exit
When VIR_EXEC_DAEMON is set, if virPidFileAcquirePath/virSetInherit failed, then pipesync[0] can not be closed when granchild process exit, because pipesync[1] still opened in child process. and then saferead in child process may blocked forever, and left grandchild process in defunct state. Signed-off-by: Xu Chao <xu.chao6@zte.com.cn> Signed-off-by: Yi Wang <wang.yi59@zte.com.cn> Signed-off-by: Michal Privoznik <mprivozn@redhat.com> Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
This commit is contained in:
parent
c1a85daf99
commit
6fac961b08
@ -782,6 +782,10 @@ virExec(virCommand *cmd)
|
||||
}
|
||||
|
||||
if (pid > 0) {
|
||||
/* At this point it's us and the child that holds the write end of
|
||||
* the pipe open. Close the write end of the pipe, so that the pipe
|
||||
* is fully closed if child dies prematurely. */
|
||||
VIR_FORCE_CLOSE(pipesync[1]);
|
||||
/* The parent expect us to have written the pid file before
|
||||
* exiting. Wait here for the child to write it and signal us. */
|
||||
if (cmd->pidfile &&
|
||||
|
Loading…
Reference in New Issue
Block a user