diff options
Diffstat (limited to 'sbin/dhclient')
-rw-r--r-- | sbin/dhclient/dhclient.c | 4 | ||||
-rw-r--r-- | sbin/dhclient/dhcpd.h | 4 | ||||
-rw-r--r-- | sbin/dhclient/dispatch.c | 78 |
3 files changed, 22 insertions, 64 deletions
diff --git a/sbin/dhclient/dhclient.c b/sbin/dhclient/dhclient.c index b5ce59a1f90..8f683232e98 100644 --- a/sbin/dhclient/dhclient.c +++ b/sbin/dhclient/dhclient.c @@ -1,4 +1,4 @@ -/* $OpenBSD: dhclient.c,v 1.20 2004/02/24 17:26:43 henning Exp $ */ +/* $OpenBSD: dhclient.c,v 1.21 2004/03/02 12:40:31 henning Exp $ */ /* DHCP Client. */ @@ -289,7 +289,7 @@ main(int argc, char *argv[]) add_protocol("AF_ROUTE", routefd, routehandler, interfaces); /* set up the interfaces. */ - discover_interfaces(); + discover_interfaces(ip); /* Make up a seed for the random number generator from current time plus the sum of the last four bytes of each diff --git a/sbin/dhclient/dhcpd.h b/sbin/dhclient/dhcpd.h index 68fba116ea8..4ac24a73852 100644 --- a/sbin/dhclient/dhcpd.h +++ b/sbin/dhclient/dhcpd.h @@ -1,4 +1,4 @@ -/* $OpenBSD: dhcpd.h,v 1.19 2004/02/25 14:22:12 henning Exp $ */ +/* $OpenBSD: dhcpd.h,v 1.20 2004/03/02 12:40:31 henning Exp $ */ /* * Copyright (c) 2004 Henning Brauer <henning@openbsd.org> @@ -326,7 +326,7 @@ extern int quiet_interface_discovery; extern void (*bootp_packet_handler)(struct interface_info *, struct dhcp_packet *, int, unsigned int, struct iaddr, struct hardware *); extern struct timeout *timeouts; -void discover_interfaces(void); +void discover_interfaces(struct interface_info *); void reinitialize_interfaces(void); void dispatch(void); void got_one(struct protocol *); diff --git a/sbin/dhclient/dispatch.c b/sbin/dhclient/dispatch.c index 7a183811ea4..c321b0665ee 100644 --- a/sbin/dhclient/dispatch.c +++ b/sbin/dhclient/dispatch.c @@ -1,6 +1,4 @@ -/* $OpenBSD: dispatch.c,v 1.16 2004/03/02 12:19:14 henning Exp $ */ - -/* Network input dispatcher... */ +/* $OpenBSD: dispatch.c,v 1.17 2004/03/02 12:40:31 henning Exp $ */ /* * Copyright 2004 Henning Brauer <henning@openbsd.org> @@ -49,9 +47,6 @@ #include <ifaddrs.h> #include <poll.h> -/* Most boxes has less than 16 interfaces, so this might be a good guess. */ -#define INITIAL_IFREQ_COUNT 16 - struct interface_info *interfaces, *dummy_interfaces, *fallback_interface; struct protocol *protocols; struct timeout *timeouts; @@ -72,10 +67,8 @@ int quiet_interface_discovery; * what subnet it's on, and add it to the list of interfaces. */ void -discover_interfaces(void) +discover_interfaces(struct interface_info *iface) { - struct interface_info *tmp; - struct interface_info *last, *next; struct sockaddr_in foo; struct ifreq *tif; struct ifaddrs *ifap, *ifa; @@ -89,11 +82,7 @@ discover_interfaces(void) (!(ifa->ifa_flags & IFF_UP))) continue; - for (tmp = interfaces; tmp; tmp = tmp->next) - if (!strcmp(tmp->name, ifa->ifa_name)) - break; - - if (!tmp) + if (strcmp(iface->name, ifa->ifa_name)) break; /* @@ -103,10 +92,10 @@ discover_interfaces(void) if (ifa->ifa_addr->sa_family == AF_LINK) { struct sockaddr_dl *foo = (struct sockaddr_dl *)ifa->ifa_addr; - tmp->index = foo->sdl_index; - tmp->hw_address.hlen = foo->sdl_alen; - tmp->hw_address.htype = HTYPE_ETHER; /* XXX */ - memcpy(tmp->hw_address.haddr, + iface->index = foo->sdl_index; + iface->hw_address.hlen = foo->sdl_alen; + iface->hw_address.htype = HTYPE_ETHER; /* XXX */ + memcpy(iface->hw_address.haddr, LLADDR(foo), foo->sdl_alen); } else if (ifa->ifa_addr->sa_family == AF_INET) { struct iaddr addr; @@ -114,59 +103,28 @@ discover_interfaces(void) bcopy(ifa->ifa_addr, &foo, sizeof(foo)); if (foo.sin_addr.s_addr == htonl(INADDR_LOOPBACK)) continue; - if (!tmp->ifp) { + if (!iface->ifp) { int len = IFNAMSIZ + ifa->ifa_addr->sa_len; - tif = malloc(len); - if (!tif) - error("no space to remember ifp."); + if ((tif = malloc(len)) == NULL) + error("no space to remember ifp"); strlcpy(tif->ifr_name, ifa->ifa_name, IFNAMSIZ); memcpy(&tif->ifr_addr, ifa->ifa_addr, ifa->ifa_addr->sa_len); - tmp->ifp = tif; - tmp->primary_address = foo.sin_addr; + iface->ifp = tif; + iface->primary_address = foo.sin_addr; } addr.len = 4; memcpy(addr.iabuf, &foo.sin_addr.s_addr, addr.len); } } - /* - * Now cycle through all the interfaces we found, looking for - * hardware addresses. - */ - - /* Weed out the interfaces that did not have IP addresses. */ - last = NULL; - for (tmp = interfaces; tmp; tmp = next) { - next = tmp->next; - if (!tmp->ifp || !(tmp->flags & INTERFACE_REQUESTED)) { - if ((tmp->flags & INTERFACE_REQUESTED)) - error("%s: not found", tmp->name); - if (!last) - interfaces = interfaces->next; - else - last->next = tmp->next; - - /* - * Remember the interface in case we need to know - * about it later. - */ - tmp->next = dummy_interfaces; - dummy_interfaces = tmp; - continue; - } - last = tmp; - - memcpy(&foo, &tmp->ifp->ifr_addr, sizeof(tmp->ifp->ifr_addr)); - - /* Register the interface... */ - if_register_receive(tmp); - if_register_send(tmp); - } + if (!iface->ifp) + error("%s: not found", iface->name); - /* Now register all the remaining interfaces as protocols. */ - for (tmp = interfaces; tmp; tmp = tmp->next) - add_protocol(tmp->name, tmp->rfdesc, got_one, tmp); + /* Register the interface... */ + if_register_receive(iface); + if_register_send(iface); + add_protocol(iface->name, iface->rfdesc, got_one, iface); freeifaddrs(ifap); } |