diff options
-rw-r--r-- | usr.sbin/dhcpd/convert.c | 24 | ||||
-rw-r--r-- | usr.sbin/dhcpd/dhcp.c | 16 | ||||
-rw-r--r-- | usr.sbin/dhcpd/dhcpd.h | 5 | ||||
-rw-r--r-- | usr.sbin/dhcpd/options.c | 249 | ||||
-rw-r--r-- | usr.sbin/dhcpd/print.c | 70 |
5 files changed, 4 insertions, 360 deletions
diff --git a/usr.sbin/dhcpd/convert.c b/usr.sbin/dhcpd/convert.c index 4f1e6fc93e5..e2750f67da9 100644 --- a/usr.sbin/dhcpd/convert.c +++ b/usr.sbin/dhcpd/convert.c @@ -1,4 +1,4 @@ -/* $OpenBSD: convert.c,v 1.3 2004/05/04 20:28:40 deraadt Exp $ */ +/* $OpenBSD: convert.c,v 1.4 2004/05/04 21:25:27 deraadt Exp $ */ /* * Safe copying of option values into and out of the option buffer, @@ -54,17 +54,6 @@ getULong(unsigned char *buf) return (ntohl(ibuf)); } -#ifdef DEBUG_PACKET -int32_t -getLong(unsigned char *(buf)) -{ - int32_t ibuf; - - memcpy(&ibuf, buf, sizeof(ibuf)); - return (ntohl(ibuf)); -} -#endif - u_int16_t getUShort(unsigned char *buf) { @@ -74,17 +63,6 @@ getUShort(unsigned char *buf) return (ntohs(ibuf)); } -#ifdef DEBUG_PACKET -int16_t -getShort(unsigned char *buf) -{ - int16_t ibuf; - - memcpy(&ibuf, buf, sizeof(ibuf)); - return (ntohs(ibuf)); -} -#endif - void putULong(unsigned char *obuf, u_int32_t val) { diff --git a/usr.sbin/dhcpd/dhcp.c b/usr.sbin/dhcpd/dhcp.c index 530fcb9ef3d..10278f81dd4 100644 --- a/usr.sbin/dhcpd/dhcp.c +++ b/usr.sbin/dhcpd/dhcp.c @@ -537,13 +537,6 @@ nak_lease(struct packet *packet, struct iaddr *cip) packet->raw->chaddr), packet->raw->giaddr.s_addr ? inet_ntoa(packet->raw->giaddr) : packet->interface->name); -#ifdef DEBUG_PACKET - dump_packet(packet); - dump_raw((unsigned char *)packet->raw, packet->packet_length); - dump_packet(&outgoing); - dump_raw((unsigned char *)&raw, outgoing.packet_length); -#endif - hto.htype = packet->raw->htype; hto.hlen = packet->raw->hlen; memcpy(hto.haddr, packet->raw->chaddr, hto.hlen); @@ -1082,11 +1075,6 @@ ack_lease(struct packet *packet, struct lease *lease, unsigned int offer, state->options[i]->tree = NULL; } -#ifdef DEBUG_PACKET - dump_packet(packet); - dump_raw((unsigned char *)packet->raw, packet->packet_length); -#endif - lease->state = state; /* If this is a DHCPOFFER, ping the lease address before actually @@ -1218,10 +1206,6 @@ dhcp_reply(struct lease *lease) to.sin_len = sizeof to; #endif -#ifdef DEBUG_PACKET - dump_raw((unsigned char *)&raw, packet_length); -#endif - /* Make sure outgoing packets are at least as big as a BOOTP packet. */ if (packet_length < BOOTP_MIN_LEN) diff --git a/usr.sbin/dhcpd/dhcpd.h b/usr.sbin/dhcpd/dhcpd.h index 57e6a98aa17..b1cf14672c5 100644 --- a/usr.sbin/dhcpd/dhcpd.h +++ b/usr.sbin/dhcpd/dhcpd.h @@ -1,4 +1,4 @@ -/* $OpenBSD: dhcpd.h,v 1.12 2004/05/04 20:28:40 deraadt Exp $ */ +/* $OpenBSD: dhcpd.h,v 1.13 2004/05/04 21:25:27 deraadt Exp $ */ /* * Copyright (c) 1995, 1996, 1997, 1998, 1999 @@ -701,9 +701,6 @@ void free_tree(struct tree *, char *); /* print.c */ char *print_hw_addr(int, int, unsigned char *); void dump_raw(unsigned char *, int); -#ifdef DEBUG_PACKET -void dump_packet(struct packet *); -#endif /* bpf.c */ int if_register_bpf(struct interface_info *); diff --git a/usr.sbin/dhcpd/options.c b/usr.sbin/dhcpd/options.c index cd8157c61fb..eb19bb0e60e 100644 --- a/usr.sbin/dhcpd/options.c +++ b/usr.sbin/dhcpd/options.c @@ -1,4 +1,4 @@ -/* $OpenBSD: options.c,v 1.3 2004/05/04 20:28:40 deraadt Exp $ */ +/* $OpenBSD: options.c,v 1.4 2004/05/04 21:25:27 deraadt Exp $ */ /* DHCP options parsing and reassembly. */ @@ -457,253 +457,6 @@ store_options(unsigned char *buffer, int buflen, struct tree_cache **options, return (bufix); } -#ifdef DEBUG_PACKET -/* - * Format the specified option so that a human can easily read it. - */ -char * -pretty_print_option(unsigned int code, unsigned char *data, int len, - int emit_commas, int emit_quotes) -{ - static char optbuf[32768]; /* XXX */ - int hunksize = 0; - int numhunk = -1; - int numelem = 0; - char fmtbuf[32]; - int i, j, k; - char *op = optbuf; - int opleft = sizeof(optbuf); - unsigned char *dp = data; - struct in_addr foo; - char comma; - - - /* Code should be between 0 and 255. */ - if (code > 255) - error("pretty_print_option: bad code %d\n", code); - - if (emit_commas) - comma = ','; - else - comma = ' '; - - /* Figure out the size of the data. */ - for (i = 0; dhcp_options[code].format[i]; i++) { - if (!numhunk) { - warn("%s: Excess information in format string: %s", - dhcp_options[code].name, - &(dhcp_options[code].format[i])); - break; - } - numelem++; - fmtbuf[i] = dhcp_options[code].format[i]; - switch (dhcp_options[code].format[i]) { - case 'A': - --numelem; - fmtbuf[i] = 0; - numhunk = 0; - break; - case 'X': - for (k = 0; k < len; k++) - if (!isascii(data[k]) || - !isprint(data[k])) - break; - if (k == len) { - fmtbuf[i] = 't'; - numhunk = -2; - } else { - fmtbuf[i] = 'x'; - hunksize++; - comma = ':'; - numhunk = 0; - } - fmtbuf[i + 1] = 0; - break; - case 't': - fmtbuf[i] = 't'; - fmtbuf[i + 1] = 0; - numhunk = -2; - break; - case 'I': - case 'l': - case 'L': - hunksize += 4; - break; - case 's': - case 'S': - hunksize += 2; - break; - case 'b': - case 'B': - case 'f': - hunksize++; - break; - case 'e': - break; - default: - warn("%s: garbage in format string: %s", - dhcp_options[code].name, - &(dhcp_options[code].format[i])); - break; - } - } - - /* Check for too few bytes... */ - if (hunksize > len) { - warn("%s: expecting at least %d bytes; got %d", - dhcp_options[code].name, hunksize, len); - return ("<error>"); - } - /* Check for too many bytes... */ - if (numhunk == -1 && hunksize < len) - warn("%s: %d extra bytes", - dhcp_options[code].name, len - hunksize); - - /* If this is an array, compute its size. */ - if (!numhunk) - numhunk = len / hunksize; - /* See if we got an exact number of hunks. */ - if (numhunk > 0 && numhunk * hunksize < len) - warn("%s: %d extra bytes at end of array", - dhcp_options[code].name, len - numhunk * hunksize); - - /* A one-hunk array prints the same as a single hunk. */ - if (numhunk < 0) - numhunk = 1; - - /* Cycle through the array (or hunk) printing the data. */ - for (i = 0; i < numhunk; i++) { - for (j = 0; j < numelem; j++) { - int opcount; - switch (fmtbuf[j]) { - case 't': - if (emit_quotes) { - *op++ = '"'; - opleft--; - } - for (; dp < data + len; dp++) { - if (!isascii(*dp) || - !isprint(*dp)) { - if (dp + 1 != data + len || - *dp != 0) { - snprintf(op, opleft, - "\\%03o", *dp); - op += 4; - opleft -= 4; - } - } else if (*dp == '"' || - *dp == '\'' || - *dp == '$' || - *dp == '`' || - *dp == '\\') { - *op++ = '\\'; - *op++ = *dp; - opleft -= 2; - } else { - *op++ = *dp; - opleft--; - } - } - if (emit_quotes) { - *op++ = '"'; - opleft--; - } - - *op = 0; - break; - case 'I': - foo.s_addr = htonl(getULong(dp)); - opcount = strlcpy(op, inet_ntoa(foo), opleft); - if (opcount >= opleft) - goto toobig; - opleft -= opcount; - dp += 4; - break; - case 'l': - opcount = snprintf(op, opleft, "%ld", - (long)getLong(dp)); - if (opcount >= opleft) - goto toobig; - opleft -= opcount; - dp += 4; - break; - case 'L': - opcount = snprintf(op, opleft, "%ld", - (unsigned long)getULong(dp)); - if (opcount >= opleft) - goto toobig; - opleft -= opcount; - dp += 4; - break; - case 's': - opcount = snprintf(op, opleft, "%d", - getShort(dp)); - if (opcount >= opleft) - goto toobig; - opleft -= opcount; - dp += 2; - break; - case 'S': - opcount = snprintf(op, opleft, "%d", - getUShort(dp)); - if (opcount >= opleft) - goto toobig; - opleft -= opcount; - dp += 2; - break; - case 'b': - opcount = snprintf(op, opleft, "%d", - *(char *)dp++); - if (opcount >= opleft) - goto toobig; - opleft -= opcount; - break; - case 'B': - opcount = snprintf(op, opleft, "%d", *dp++); - if (opcount >= opleft) - goto toobig; - opleft -= opcount; - break; - case 'x': - opcount = snprintf(op, opleft, "%x", *dp++); - if (opcount >= opleft) - goto toobig; - opleft -= opcount; - break; - case 'f': - opcount = strlcpy(op, - *dp++ ? "true" : "false", opleft); - if (opcount >= opleft) - goto toobig; - opleft -= opcount; - break; - default: - warn("Unexpected format code %c", fmtbuf[j]); - } - op += strlen(op); - opleft -= strlen(op); - if (opleft < 1) - goto toobig; - if (j + 1 < numelem && comma != ':') { - *op++ = ' '; - opleft--; - } - } - if (i + 1 < numhunk) { - *op++ = comma; - opleft--; - } - if (opleft < 1) - goto toobig; - - } - return (optbuf); - toobig: - warn("dhcp option too large"); - return ("<error>"); -} -#endif /* DEBUG_PACKET */ - void do_packet(struct interface_info *interface, struct dhcp_packet *packet, int len, unsigned int from_port, struct iaddr from, struct hardware *hfrom) diff --git a/usr.sbin/dhcpd/print.c b/usr.sbin/dhcpd/print.c index 30de7624a22..69642907582 100644 --- a/usr.sbin/dhcpd/print.c +++ b/usr.sbin/dhcpd/print.c @@ -1,4 +1,4 @@ -/* $OpenBSD: print.c,v 1.7 2004/05/04 20:28:40 deraadt Exp $ */ +/* $OpenBSD: print.c,v 1.8 2004/05/04 21:25:27 deraadt Exp $ */ /* Turn data structures into printable text. */ @@ -72,71 +72,3 @@ bad: return habuf; } - -#ifdef DEBUG_PACKET -void -dump_packet(struct packet *tp) -{ - struct dhcp_packet *tdp = tp->raw; - - debug("packet length %d", tp->packet_length); - debug("op = %d htype = %d hlen = %d hops = %d", tdp->op, tdp->htype, - tdp->hlen, tdp->hops); - debug("xid = %x secs = %d flags = %x", tdp->xid, tdp->secs, - tdp->flags); - debug("ciaddr = %s", inet_ntoa(tdp->ciaddr)); - debug("yiaddr = %s", inet_ntoa(tdp->yiaddr)); - debug("siaddr = %s", inet_ntoa(tdp->siaddr)); - debug("giaddr = %s", inet_ntoa(tdp->giaddr)); - debug("chaddr = %02x:%02x:%02x:%02x:%02x:%02x", - ((unsigned char *)(tdp->chaddr))[0], - ((unsigned char *)(tdp->chaddr))[1], - ((unsigned char *)(tdp->chaddr))[2], - ((unsigned char *)(tdp->chaddr))[3], - ((unsigned char *)(tdp->chaddr))[4], - ((unsigned char *)(tdp->chaddr))[5]); - debug("filename = %s", tdp->file); - debug("server_name = %s", tdp->sname); - if (tp->options_valid) { - int i; - - for (i = 0; i < 256; i++) { - if (tp->options[i].data) - debug(" %s = %s", dhcp_options[i].name, - pretty_print_option(i, tp->options[i].data, - tp->options[i].len, 1, 1)); - } - } - debug("%s", ""); -} - -void -dump_raw(unsigned char *buf, int len) -{ - char lbuf[80]; - int i, j, llen = sizeof(lbuf), lbix = 0; - - lbuf[0] = 0; - - for (i = 0; i < len; i++) { - if ((i & 15) == 0) { - if (lbix) - note("%s", lbuf); - j = snprintf(lbuf, llen, "%03x:", i); - if (j >= llen) - return; - lbix += j; - llen -= j; - } else if ((i & 7) == 0) { - lbuf[lbix++] = ' '; - len--; - } - j = snprintf(&lbuf[lbix], llen, " %02x", buf[i]); - if (j >= llen) - return; - lbix += j; - llen -= j; - } - note("%s", lbuf); -} -#endif /* DEBUG_PACKET */ |