]> git.proxmox.com Git - mirror_iproute2.git/commitdiff
netns: follow return value conventions of the rest of the code
authorStephen Hemminger <stephen@networkplumber.org>
Fri, 12 Jul 2013 15:43:23 +0000 (08:43 -0700)
committerStephen Hemminger <stephen@networkplumber.org>
Fri, 12 Jul 2013 15:43:23 +0000 (08:43 -0700)
The netns code was using EXIT_SUCCESS/EXIT_FAILURE but the rest of the ip
code used -1 explictly, so change to follow convention. Also, certain types
of errors like fork failure should abort a batch operation, rather than just
returning an error.

ip/ipnetns.c

index d534fb694daab8e5ea6df4f09330a1b42fd6880b..5b911f76d18e404aa5394fcfe741521afd820620 100644 (file)
@@ -65,7 +65,7 @@ static int usage(void)
        fprintf(stderr, "       ip netns pids NAME\n");
        fprintf(stderr, "       ip netns exec NAME cmd ...\n");
        fprintf(stderr, "       ip netns monitor\n");
-       return EXIT_FAILURE;
+       exit(-1);
 }
 
 int get_netns_fd(const char *name)
@@ -90,7 +90,7 @@ static int netns_list(int argc, char **argv)
 
        dir = opendir(NETNS_RUN_DIR);
        if (!dir)
-               return EXIT_SUCCESS;
+               return 0;
 
        while ((entry = readdir(dir)) != NULL) {
                if (strcmp(entry->d_name, ".") == 0)
@@ -100,7 +100,7 @@ static int netns_list(int argc, char **argv)
                printf("%s\n", entry->d_name);
        }
        closedir(dir);
-       return EXIT_SUCCESS;
+       return 0;
 }
 
 static void bind_etc(const char *name)
@@ -142,12 +142,13 @@ static int netns_exec(int argc, char **argv)
 
        if (argc < 1) {
                fprintf(stderr, "No netns name specified\n");
-               return EXIT_FAILURE;
+               return -1;
        }
        if (argc < 2) {
                fprintf(stderr, "No command specified\n");
-               return EXIT_FAILURE;
+               return -1;
        }
+
        name = argv[0];
        cmd = argv[1];
        snprintf(net_path, sizeof(net_path), "%s/%s", NETNS_RUN_DIR, name);
@@ -155,32 +156,33 @@ static int netns_exec(int argc, char **argv)
        if (netns < 0) {
                fprintf(stderr, "Cannot open network namespace \"%s\": %s\n",
                        name, strerror(errno));
-               return EXIT_FAILURE;
+               return -1;
        }
+
        if (setns(netns, CLONE_NEWNET) < 0) {
                fprintf(stderr, "seting the network namespace \"%s\" failed: %s\n",
                        name, strerror(errno));
-               return EXIT_FAILURE;
+               return -1;
        }
 
        if (unshare(CLONE_NEWNS) < 0) {
                fprintf(stderr, "unshare failed: %s\n", strerror(errno));
-               return EXIT_FAILURE;
+               return -1;
        }
        /* Don't let any mounts propogate back to the parent */
        if (mount("", "/", "none", MS_SLAVE | MS_REC, NULL)) {
                fprintf(stderr, "\"mount --make-rslave /\" failed: %s\n",
                        strerror(errno));
-               return EXIT_FAILURE;
+               return -1;
        }
        /* Mount a version of /sys that describes the network namespace */
        if (umount2("/sys", MNT_DETACH) < 0) {
                fprintf(stderr, "umount of /sys failed: %s\n", strerror(errno));
-               return EXIT_FAILURE;
+               return -1;
        }
        if (mount(name, "/sys", "sysfs", 0, NULL) < 0) {
                fprintf(stderr, "mount of /sys failed: %s\n",strerror(errno));
-               return EXIT_FAILURE;
+               return -1;
        }
 
        /* Setup bind mounts for config files in /etc */
@@ -195,32 +197,28 @@ static int netns_exec(int argc, char **argv)
                pid = fork();
                if (pid < 0) {
                        perror("fork");
-                       return EXIT_FAILURE;
+                       exit(1);
                }
 
                if (pid != 0) {
                        /* Parent  */
                        if (waitpid(pid, &status, 0) < 0) {
                                perror("waitpid");
-                               return EXIT_FAILURE;
+                               exit(1);
                        }
 
-                       if (WIFEXITED(status)) {
-                               /* ip must returns the status of the child,
-                                * but do_cmd() will add a minus to this,
-                                * so let's add another one here to cancel it.
-                                */
-                               return -WEXITSTATUS(status);
-                       }
+                       /* If child failed, propogate status */
+                       if (WIFEXITED(status))
+                               exit(WEXITSTATUS(status));
 
-                       return EXIT_FAILURE;
+                       return 0;
                }
        }
 
        if (execvp(cmd, argv + 1)  < 0)
                fprintf(stderr, "exec of \"%s\" failed: %s\n",
                        cmd, strerror(errno));
-       _exit(EXIT_FAILURE);
+       _exit(1);
 }
 
 static int is_pid(const char *str)
@@ -244,11 +242,11 @@ static int netns_pids(int argc, char **argv)
 
        if (argc < 1) {
                fprintf(stderr, "No netns name specified\n");
-               return EXIT_FAILURE;
+               return -1;
        }
        if (argc > 1) {
                fprintf(stderr, "extra arguments specified\n");
-               return EXIT_FAILURE;
+               return -1;
        }
 
        name = argv[0];
@@ -257,18 +255,18 @@ static int netns_pids(int argc, char **argv)
        if (netns < 0) {
                fprintf(stderr, "Cannot open network namespace: %s\n",
                        strerror(errno));
-               return EXIT_FAILURE;
+               return -1;
        }
        if (fstat(netns, &netst) < 0) {
                fprintf(stderr, "Stat of netns failed: %s\n",
                        strerror(errno));
-               return EXIT_FAILURE;
+               return -1;
        }
        dir = opendir("/proc/");
        if (!dir) {
                fprintf(stderr, "Open of /proc failed: %s\n",
                        strerror(errno));
-               return EXIT_FAILURE;
+               return -1;
        }
        while((entry = readdir(dir))) {
                char pid_net_path[MAXPATHLEN];
@@ -285,7 +283,7 @@ static int netns_pids(int argc, char **argv)
                }
        }
        closedir(dir);
-       return EXIT_SUCCESS;
+       return 0;
        
 }
 
@@ -300,18 +298,18 @@ static int netns_identify(int argc, char **argv)
 
        if (argc < 1) {
                fprintf(stderr, "No pid specified\n");
-               return EXIT_FAILURE;
+               return -1;
        }
        if (argc > 1) {
                fprintf(stderr, "extra arguments specified\n");
-               return EXIT_FAILURE;
+               return -1;
        }
        pidstr = argv[0];
 
        if (!is_pid(pidstr)) {
                fprintf(stderr, "Specified string '%s' is not a pid\n",
                        pidstr);
-               return EXIT_FAILURE;
+               return -1;
        }
 
        snprintf(net_path, sizeof(net_path), "/proc/%s/ns/net", pidstr);
@@ -319,22 +317,22 @@ static int netns_identify(int argc, char **argv)
        if (netns < 0) {
                fprintf(stderr, "Cannot open network namespace: %s\n",
                        strerror(errno));
-               return EXIT_FAILURE;
+               return -1;
        }
        if (fstat(netns, &netst) < 0) {
                fprintf(stderr, "Stat of netns failed: %s\n",
                        strerror(errno));
-               return EXIT_FAILURE;
+               return -1;
        }
        dir = opendir(NETNS_RUN_DIR);
        if (!dir) {
                /* Succeed treat a missing directory as an empty directory */
                if (errno == ENOENT)
-                       return EXIT_SUCCESS;
+                       return 0;
 
                fprintf(stderr, "Failed to open directory %s:%s\n",
                        NETNS_RUN_DIR, strerror(errno));
-               return EXIT_FAILURE;
+               return -1;
        }
 
        while((entry = readdir(dir))) {
@@ -358,7 +356,7 @@ static int netns_identify(int argc, char **argv)
                }
        }
        closedir(dir);
-       return EXIT_SUCCESS;
+       return 0;
        
 }
 
@@ -369,7 +367,7 @@ static int netns_delete(int argc, char **argv)
 
        if (argc < 1) {
                fprintf(stderr, "No netns name specified\n");
-               return EXIT_FAILURE;
+               return -1;
        }
 
        name = argv[0];
@@ -378,9 +376,9 @@ static int netns_delete(int argc, char **argv)
        if (unlink(netns_path) < 0) {
                fprintf(stderr, "Cannot remove namespace file \"%s\": %s\n",
                        netns_path, strerror(errno));
-               return EXIT_FAILURE;
+               return -1;
        }
-       return EXIT_SUCCESS;
+       return 0;
 }
 
 static int netns_add(int argc, char **argv)
@@ -400,7 +398,7 @@ static int netns_add(int argc, char **argv)
 
        if (argc < 1) {
                fprintf(stderr, "No netns name specified\n");
-               return EXIT_FAILURE;
+               return -1;
        }
        name = argv[0];
 
@@ -420,14 +418,14 @@ static int netns_add(int argc, char **argv)
                if (errno != EINVAL || made_netns_run_dir_mount) {
                        fprintf(stderr, "mount --make-shared %s failed: %s\n",
                                NETNS_RUN_DIR, strerror(errno));
-                       return EXIT_FAILURE;
+                       return -1;
                }
 
                /* Upgrade NETNS_RUN_DIR to a mount point */
                if (mount(NETNS_RUN_DIR, NETNS_RUN_DIR, "none", MS_BIND, NULL)) {
                        fprintf(stderr, "mount --bind %s %s failed: %s\n",
                                NETNS_RUN_DIR, NETNS_RUN_DIR, strerror(errno));
-                       return EXIT_FAILURE;
+                       return -1;
                }
                made_netns_run_dir_mount = 1;
        }
@@ -437,7 +435,7 @@ static int netns_add(int argc, char **argv)
        if (fd < 0) {
                fprintf(stderr, "Cannot not create namespace file \"%s\": %s\n",
                        netns_path, strerror(errno));
-               return EXIT_FAILURE;
+               return -1;
        }
        close(fd);
        if (unshare(CLONE_NEWNET) < 0) {
@@ -452,10 +450,10 @@ static int netns_add(int argc, char **argv)
                        netns_path, strerror(errno));
                goto out_delete;
        }
-       return EXIT_SUCCESS;
+       return 0;
 out_delete:
        netns_delete(argc, argv);
-       return EXIT_FAILURE;
+       return -1;
 }
 
 
@@ -468,19 +466,19 @@ static int netns_monitor(int argc, char **argv)
        if (fd < 0) {
                fprintf(stderr, "inotify_init failed: %s\n",
                        strerror(errno));
-               return EXIT_FAILURE;
+               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));
-               return EXIT_FAILURE;
+               return -1;
        }
        for(;;) {
                ssize_t len = read(fd, buf, sizeof(buf));
                if (len < 0) {
                        fprintf(stderr, "read failed: %s\n",
                                strerror(errno));
-                       return EXIT_FAILURE;
+                       return -1;
                }
                for (event = (struct inotify_event *)buf;
                     (char *)event < &buf[len];
@@ -491,7 +489,7 @@ static int netns_monitor(int argc, char **argv)
                                printf("delete %s\n", event->name);
                }
        }
-       return EXIT_SUCCESS;
+       return 0;
 }
 
 int do_netns(int argc, char **argv)
@@ -525,5 +523,5 @@ int do_netns(int argc, char **argv)
                return netns_monitor(argc-1, argv+1);
 
        fprintf(stderr, "Command \"%s\" is unknown, try \"ip netns help\".\n", *argv);
-       return EXIT_FAILURE;
+       exit(-1);
 }