From: Phil Sutter Date: Wed, 19 Sep 2018 13:17:05 +0000 (+0200) Subject: libxtables: Use posix_spawn() instead of vfork() X-Git-Tag: v1.8.1~18 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=d95c1e8b65c4ec66b8fcd2f7ede257853a888750;p=thirdparty%2Fiptables.git libxtables: Use posix_spawn() instead of vfork() According to covscan, vfork() may lead to a deadlock in the parent process. It suggests to use posix_spawn() instead. Since the latter combines vfork() and exec() calls, use it for xtables_insmod(). Signed-off-by: Phil Sutter Signed-off-by: Florian Westphal --- diff --git a/libxtables/xtables.c b/libxtables/xtables.c index ffd8fbcf..6dd0b152 100644 --- a/libxtables/xtables.c +++ b/libxtables/xtables.c @@ -21,6 +21,7 @@ #include #include #include +#include #include #include #include @@ -362,6 +363,7 @@ int xtables_insmod(const char *modname, const char *modprobe, bool quiet) char *buf = NULL; char *argv[4]; int status; + pid_t pid; /* If they don't explicitly set it, read out of kernel */ if (!modprobe) { @@ -382,18 +384,11 @@ int xtables_insmod(const char *modname, const char *modprobe, bool quiet) */ fflush(stdout); - switch (vfork()) { - case 0: - execv(argv[0], argv); - - /* not usually reached */ - _exit(1); - case -1: + if (posix_spawn(&pid, argv[0], NULL, NULL, argv, NULL)) { free(buf); return -1; - - default: /* parent */ - wait(&status); + } else { + waitpid(pid, &status, 0); } free(buf);