From: vadimk Date: Sun, 31 Aug 2014 19:45:29 +0000 (+0300) Subject: ip netns: Create /var/run/netns dir when do 'ip netns monitor' X-Git-Tag: v3.17.0~15 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=c1cbb18adbf2f5abc13a840fb9dab7dd7d26b2aa;p=thirdparty%2Fiproute2.git ip netns: Create /var/run/netns dir when do 'ip netns monitor' netns monitor fails when there is no /var/run/netns dir which might be created later while monitoring. Signed-off-by: Vadim Kochan --- diff --git a/ip/ipnetns.c b/ip/ipnetns.c index 7f829088f..90a496f7a 100644 --- a/ip/ipnetns.c +++ b/ip/ipnetns.c @@ -383,6 +383,20 @@ static int netns_delete(int argc, char **argv) return 0; } +static int create_netns_dir(void) +{ + /* Create the base netns directory if it doesn't exist */ + if (mkdir(NETNS_RUN_DIR, S_IRWXU|S_IRGRP|S_IXGRP|S_IROTH|S_IXOTH)) { + if (errno != EEXIST) { + fprintf(stderr, "mkdir %s failed: %s\n", + NETNS_RUN_DIR, strerror(errno)); + return -1; + } + } + + return 0; +} + static int netns_add(int argc, char **argv) { /* This function creates a new network namespace and @@ -406,14 +420,8 @@ static int netns_add(int argc, char **argv) snprintf(netns_path, sizeof(netns_path), "%s/%s", NETNS_RUN_DIR, name); - /* Create the base netns directory if it doesn't exist */ - if (mkdir(NETNS_RUN_DIR, S_IRWXU|S_IRGRP|S_IXGRP|S_IROTH|S_IXOTH)) { - if (errno != EEXIST) { - fprintf(stderr, "mkdir %s failed: %s\n", - NETNS_RUN_DIR, strerror(errno)); - return -1; - } - } + if (create_netns_dir()) + return -1; /* Make it possible for network namespace mounts to propagate between * mount namespaces. This makes it likely that a unmounting a network @@ -476,6 +484,10 @@ static int netns_monitor(int argc, char **argv) strerror(errno)); return -1; } + + if (create_netns_dir()) + return -1; + if (inotify_add_watch(fd, NETNS_RUN_DIR, IN_CREATE | IN_DELETE) < 0) { fprintf(stderr, "inotify_add_watch failed: %s\n", strerror(errno));