From: Christian Brauner Date: Tue, 20 Oct 2020 15:41:06 +0000 (+0200) Subject: conf: account for early return when sending devpts fd X-Git-Tag: lxc-5.0.0~351^2 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=refs%2Fpull%2F3559%2Fhead;p=thirdparty%2Flxc.git conf: account for early return when sending devpts fd Signed-off-by: Christian Brauner --- diff --git a/src/lxc/conf.c b/src/lxc/conf.c index e006ea439..259d3766a 100644 --- a/src/lxc/conf.c +++ b/src/lxc/conf.c @@ -1549,7 +1549,14 @@ static int lxc_setup_devpts_child(struct lxc_handler *handler) if (devpts_fd < 0) { devpts_fd = -EBADF; TRACE("Failed to create detached devpts mount"); + ret = lxc_abstract_unix_send_fds(sock, NULL, 0, &devpts_fd, sizeof(int)); + } else { + ret = lxc_abstract_unix_send_fds(sock, &devpts_fd, 1, NULL, 0); } + if (ret < 0) + return log_error_errno(-1, errno, "Failed to send devpts fd to parent"); + + TRACE("Sent devpts file descriptor %d to parent", devpts_fd); /* Remove any pre-existing /dev/ptmx file. */ ret = remove("/dev/ptmx"); @@ -1583,16 +1590,8 @@ static int lxc_setup_devpts_child(struct lxc_handler *handler) ret = symlink("/dev/pts/ptmx", "/dev/ptmx"); if (ret < 0) return log_error_errno(-1, errno, "Failed to create symlink from \"/dev/ptmx\" to \"/dev/pts/ptmx\""); - DEBUG("Created symlink from \"/dev/ptmx\" to \"/dev/pts/ptmx\""); - if (devpts_fd < 0) - ret = lxc_abstract_unix_send_fds(sock, NULL, 0, &devpts_fd, sizeof(int)); - else - ret = lxc_abstract_unix_send_fds(sock, &devpts_fd, 1, NULL, 0); - if (ret < 0) - return log_error_errno(-1, errno, "Failed to send devpts fd to parent"); - - TRACE("Sent devpts file descriptor %d to parent", devpts_fd); + DEBUG("Created symlink from \"/dev/ptmx\" to \"/dev/pts/ptmx\""); return 0; }