From 8539e6e887544a9b86f70c967ed55866904fdc23 Mon Sep 17 00:00:00 2001 From: Gerhard Rieger Date: Mon, 12 Jun 2023 12:21:09 +0200 Subject: [PATCH] Fixed an internal FD leak in the EXEC,SYSTEM addresses --- CHANGES | 2 ++ xio-progcall.c | 8 ++++---- 2 files changed, 6 insertions(+), 4 deletions(-) diff --git a/CHANGES b/CHANGES index c33b4e4..9c6df9d 100644 --- a/CHANGES +++ b/CHANGES @@ -32,6 +32,8 @@ Corrections: /dev/vsock. Thanks to Volker Simonis for sending a patch. + Fixed an internal FD leak in the EXEC,SYSTEM addresses. + Features: VSOCK, VSOCK-L support options pf, socktype, prototype (currently useless) diff --git a/xio-progcall.c b/xio-progcall.c index 206636a..19d329a 100644 --- a/xio-progcall.c +++ b/xio-progcall.c @@ -75,7 +75,7 @@ int _xioopen_foxec(int xioflags, /* XIO_RDONLY etc. */ bool nofork = false; bool withfork; char *tn = NULL; - int trigger[2]; + int trigger[2]; /* [0] watched by parent, [1] closed by child when ready */ popts = moveopts(*copts, GROUP_ALL); if (applyopts_single(fd, popts, PH_INIT) < 0) return -1; @@ -391,11 +391,11 @@ int _xioopen_foxec(int xioflags, /* XIO_RDONLY etc. */ } if (!withfork || pid == 0) { /* child */ if (withfork) { + Close(trigger[0]); /* in child: not needed here */ /* The child should have default handling for SIGCHLD. */ /* In particular, it's not defined whether ignoring SIGCHLD is inheritable. */ if (Signal(SIGCHLD, SIG_DFL) == SIG_ERR) { Warn1("signal(SIGCHLD, SIG_DFL): %s", strerror(errno)); - Close(trigger[0]); } #if HAVE_PTY @@ -546,7 +546,7 @@ int _xioopen_foxec(int xioflags, /* XIO_RDONLY etc. */ } if (withfork) { Info("Signalling parent ready"); - Close(trigger[1]); + Close(trigger[1]); /* in child, notify parent that ready */ } } /* withfork */ else { @@ -565,7 +565,7 @@ int _xioopen_foxec(int xioflags, /* XIO_RDONLY etc. */ /* for parent (this is our socat process) */ Notice1("forked off child process "F_pid, pid); - Close(trigger[1]); + Close(trigger[1]); /* in parent */ #if 0 if ((popts = copyopts(*copts,