From cde0b03bbce663dcdff4438c5708a1d8668f14f6 Mon Sep 17 00:00:00 2001 From: Rene Mayrhofer Date: Wed, 21 Oct 2009 19:13:53 +0000 Subject: Use popen, which makes the code much simpler. --- src/starter/interfaces.c | 90 +++++++++++++++++------------------------------- 1 file changed, 31 insertions(+), 59 deletions(-) (limited to 'src') diff --git a/src/starter/interfaces.c b/src/starter/interfaces.c index de79e2da1..1721b869c 100644 --- a/src/starter/interfaces.c +++ b/src/starter/interfaces.c @@ -110,76 +110,48 @@ get_defaultroute(defaultroute_t *defaultroute) { plog("no default route in table 'main', checking table 'default' instead"); - pid_t pid; - int rv; - int commpipe[2]; /* This holds the fd for the input & output of the pipe */ + fd = (FILE*) popen(IP_ROUTE, "r"); - /* Setup communication pipeline first */ - if (pipe(commpipe)) + if (!fd) { - plog("unable to open pipe to execute '%s' command", IP_ROUTE); + plog("could not execute '%s'", IP_ROUTE); + return; } - else + + /* parse the output - it should only be one line */ + while (fgets(line, sizeof(line), fd) != 0) { - /* Attempt to fork and check for errors */ - if( (pid=fork()) == -1) + char destination[19]; + char buf1[4], buf2[4]; + char gateway[16]; + char iface[11]; + int items; + + /* parsing a single line of the output */ + items = sscanf(line, "%s %s %s %s %s", + destination, buf1, gateway, buf2, iface); + if (items < 5) { - plog("unable to fork process, this should not happen"); + plog("parsing error while scanning 'ip route' output"); + continue; } - else if (pid) + + if (streq(destination, "default")) { - close(commpipe[1]); /* Close unused side of pipe (out side from this process) */ - setvbuf(stdout,(char*)NULL,_IONBF,0); /* Set non-buffered output on stdout */ - wait(&rv); /* Wait for child process to end */ - if (rv != 0) - plog("'%s' command exited with code %d", IP_ROUTE, rv); - else + if (defaultroute->defined) { - /* parse the output - it should only be one line */ - while (fgets(line, sizeof(line), commpipe[0]) != 0) - { - char destination[19]; - char buf1[4], buf2[4]; - char gateway[16]; - char iface[11]; - - /* parsing a single line of the output */ - items = sscanf(line, "%s %s %s %s %s", - destination, buf1, gateway, buf2, iface); - if (items < 5) - { - plog("parsing error while scanning 'ip route' output"); - continue; - } - - if (streq(destination, "default") - { - if (defaultroute->defined) - { - plog("multiple default routes in table 'default' - cannot cope with %%defaultroute!!!"); - defaultroute->defined = FALSE; - close(commpipe[0]); - return; - } - - ttoaddr(gateway, strlen(gateway), AF_INET, &defaultroute->nexthop); - strncpy(defaultroute->iface, iface, IFNAMSIZ); - defaultroute->defined = TRUE; - } - } - close(commpipe[0]); - } - else - { - /* A zero PID indicates that this is the child process */ - dup2(commpipe[0],0); /* Replace stdin with the in side of the pipe */ - close(commpipe[1]); /* Close unused side of pipe (out side) */ - /* Replace the child fork with a new process */ - if(execl("ip", IP_ROUTE, NULL) == -1){ - plog("unable to execute '%s' command", IP_ROUTE); + plog("multiple default routes in table 'default' - cannot cope with %%defaultroute!!!"); + defaultroute->defined = FALSE; + pclose(fd); + return; } + + ttoaddr(gateway, strlen(gateway), AF_INET, &defaultroute->nexthop); + strncpy(defaultroute->iface, iface, IFNAMSIZ); + defaultroute->defined = TRUE; } } + pclose(fd); } if (!defaultroute->defined) -- cgit v1.2.3