From: Roy Marples Date: Mon, 31 Aug 2009 21:51:17 +0000 (+0000) Subject: Don't pass "dhcpcd $iface" to discover_interfaces so our X-Git-Tag: v5.1.0~5 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=d9458265513965001b7bd5da6ca065c1ebd48b4b;p=thirdparty%2Fdhcpcd.git Don't pass "dhcpcd $iface" to discover_interfaces so our denyinterfaces config option works for hotplugged interfaces. --- diff --git a/dhcpcd.c b/dhcpcd.c index 5dc46a9f..2cbb6320 100644 --- a/dhcpcd.c +++ b/dhcpcd.c @@ -1188,7 +1188,6 @@ void handle_interface(int action, const char *ifname) { struct interface *ifs, *ifp, *ifn, *ifl = NULL; - const char * const argv[] = { "dhcpcd", ifname }; int i; if (action == -1) { @@ -1210,23 +1209,24 @@ handle_interface(int action, const char *ifname) return; } - if ((ifs = discover_interfaces(2, UNCONST(argv)))) { - for (ifp = ifs; ifp; ifp = ifp->next) { - /* Check if we already have the interface */ - for (ifn = ifaces; ifn; ifn = ifn->next) { - if (strcmp(ifn->name, ifp->name) == 0) - break; - ifl = ifn; - } - if (ifn) - continue; - init_state(ifp, 2, UNCONST(argv)); - if (ifl) - ifl->next = ifp; - else - ifaces = ifp; - start_interface(ifp); + ifs = discover_interfaces(0, NULL); + for (ifp = ifs; ifp; ifp = ifp->next) { + if (strcmp(ifp->name, ifname) != 0) + continue; + /* Check if we already have the interface */ + for (ifn = ifaces; ifn; ifn = ifn->next) { + if (strcmp(ifn->name, ifp->name) == 0) + break; + ifl = ifn; } + if (ifn) + continue; + init_state(ifp, 0, NULL); + if (ifl) + ifl->next = ifp; + else + ifaces = ifp; + start_interface(ifp); } }