diff options
author | Kenneth R Westerback <krw@cvs.openbsd.org> | 2018-01-28 23:12:37 +0000 |
---|---|---|
committer | Kenneth R Westerback <krw@cvs.openbsd.org> | 2018-01-28 23:12:37 +0000 |
commit | 60d57d10ec62f3cb932aa2e8fc86d5b26c3e117d (patch) | |
tree | bf4688d80b006928240b3a2f845a93e8c3938b5f /sbin/dhclient/dispatch.c | |
parent | 74a0c8c07ea6d80b33dba9a4063557cc010cd693 (diff) |
Refactor and simplify the logic to select and invoke the
appropriate function to process a packet.
Diffstat (limited to 'sbin/dhclient/dispatch.c')
-rw-r--r-- | sbin/dhclient/dispatch.c | 36 |
1 files changed, 11 insertions, 25 deletions
diff --git a/sbin/dhclient/dispatch.c b/sbin/dhclient/dispatch.c index 3a9e6582c74..fed4b49d2aa 100644 --- a/sbin/dhclient/dispatch.c +++ b/sbin/dhclient/dispatch.c @@ -1,4 +1,4 @@ -/* $OpenBSD: dispatch.c,v 1.148 2018/01/25 15:43:51 krw Exp $ */ +/* $OpenBSD: dispatch.c,v 1.149 2018/01/28 23:12:36 krw Exp $ */ /* * Copyright 2004 Henning Brauer <henning@openbsd.org> @@ -181,10 +181,8 @@ packethandler(struct interface_info *ifi) struct dhcp_packet *packet = &ifi->recv_packet; struct reject_elem *ap; struct option_data *options; - char *type, *info; + char *src; ssize_t result; - void (*handler)(struct interface_info *, - struct option_data *, char *); int i, rslt; result = receive_packet(ifi, &from, &hfrom); @@ -242,48 +240,36 @@ packethandler(struct interface_info *ifi) return; } - type = "<unknown>"; - handler = NULL; + rslt = asprintf(&src, "%s (%s)",inet_ntoa(ifrom), ether_ntoa(&hfrom)); + if (rslt == -1) + fatal("src"); i = DHO_DHCP_MESSAGE_TYPE; if (options[i].data != NULL) { /* Always try a DHCP packet, even if a bad option was seen. */ switch (options[i].data[0]) { case DHCPOFFER: - handler = dhcpoffer; - type = "DHCPOFFER"; + dhcpoffer(ifi, options, src); break; case DHCPNAK: - handler = dhcpnak; - type = "DHCPNACK"; + dhcpnak(ifi, src); break; case DHCPACK: - handler = dhcpack; - type = "DHCPACK"; + dhcpack(ifi, options, src); break; default: DPRINTF("%s: discarding DHCP packet of unknown type " "(%d)", log_procname, options[i].data[0]); - return; + break; } } else if (packet->op == BOOTREPLY) { - handler = dhcpoffer; - type = "BOOTREPLY"; + bootreply(ifi, options, src); } else { DPRINTF("%s: discarding packet which is neither DHCP nor " "BOOTP", log_procname); - return; } - rslt = asprintf(&info, "%s from %s (%s)", type, inet_ntoa(ifrom), - ether_ntoa(&hfrom)); - if (rslt == -1) - fatal("info string"); - - if (handler != NULL) - (*handler)(ifi, options, info); - - free(info); + free(src); } /* |