diff options
| author | Denys Vlasenko <vda.linux@googlemail.com> | 2011-11-05 01:26:18 +0100 |
|---|---|---|
| committer | Denys Vlasenko <vda.linux@googlemail.com> | 2011-11-05 01:26:18 +0100 |
| commit | 3b46fcb95d1276c538f4c84b63eec33cc27ac760 (patch) | |
| tree | e0fab966012202cd9f76d3cb55545fce7441962e | |
| parent | d38ca03946000f0837e9a0e04937499509db54c4 (diff) | |
| download | busybox-w32-3b46fcb95d1276c538f4c84b63eec33cc27ac760.tar.gz busybox-w32-3b46fcb95d1276c538f4c84b63eec33cc27ac760.tar.bz2 busybox-w32-3b46fcb95d1276c538f4c84b63eec33cc27ac760.zip | |
udhcpc: remove workaround for bugs in Win98 dhcp server ("MSFT 98" vendor string)
Stats for last three commits:
function old new delta
udhcpc_main 2635 2646 +11
udhcp_recv_raw_packet 425 414 -11
udhcp_recv_kernel_packet 210 134 -76
packed_usage 28940 28857 -83
------------------------------------------------------------------------------
(add/remove: 0/0 grow/shrink: 1/3 up/down: 11/-170) Total: -159 bytes
text data bss dec hex filename
879524 493 7584 887601 d8b31 busybox_old
879340 493 7584 887417 d8a79 busybox_unstripped
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
| -rw-r--r-- | networking/udhcp/packet.c | 34 |
1 files changed, 3 insertions, 31 deletions
diff --git a/networking/udhcp/packet.c b/networking/udhcp/packet.c index 4d5ff0676..bd754f766 100644 --- a/networking/udhcp/packet.c +++ b/networking/udhcp/packet.c | |||
| @@ -81,7 +81,6 @@ void FAST_FUNC udhcp_dump_packet(struct dhcp_packet *packet) | |||
| 81 | int FAST_FUNC udhcp_recv_kernel_packet(struct dhcp_packet *packet, int fd) | 81 | int FAST_FUNC udhcp_recv_kernel_packet(struct dhcp_packet *packet, int fd) |
| 82 | { | 82 | { |
| 83 | int bytes; | 83 | int bytes; |
| 84 | unsigned char *vendor; | ||
| 85 | 84 | ||
| 86 | memset(packet, 0, sizeof(*packet)); | 85 | memset(packet, 0, sizeof(*packet)); |
| 87 | bytes = safe_read(fd, packet, sizeof(*packet)); | 86 | bytes = safe_read(fd, packet, sizeof(*packet)); |
| @@ -90,42 +89,15 @@ int FAST_FUNC udhcp_recv_kernel_packet(struct dhcp_packet *packet, int fd) | |||
| 90 | return bytes; /* returns -1 */ | 89 | return bytes; /* returns -1 */ |
| 91 | } | 90 | } |
| 92 | 91 | ||
| 93 | if (packet->cookie != htonl(DHCP_MAGIC)) { | 92 | if (bytes < offsetof(struct dhcp_packet, options) |
| 93 | || packet->cookie != htonl(DHCP_MAGIC) | ||
| 94 | ) { | ||
| 94 | bb_info_msg("Packet with bad magic, ignoring"); | 95 | bb_info_msg("Packet with bad magic, ignoring"); |
| 95 | return -2; | 96 | return -2; |
| 96 | } | 97 | } |
| 97 | log1("Received a packet"); | 98 | log1("Received a packet"); |
| 98 | udhcp_dump_packet(packet); | 99 | udhcp_dump_packet(packet); |
| 99 | 100 | ||
| 100 | if (packet->op == BOOTREQUEST) { | ||
| 101 | vendor = udhcp_get_option(packet, DHCP_VENDOR); | ||
| 102 | if (vendor) { | ||
| 103 | #if 0 | ||
| 104 | static const char broken_vendors[][8] = { | ||
| 105 | "MSFT 98", | ||
| 106 | "" | ||
| 107 | }; | ||
| 108 | int i; | ||
| 109 | for (i = 0; broken_vendors[i][0]; i++) { | ||
| 110 | if (vendor[OPT_LEN - OPT_DATA] == (uint8_t)strlen(broken_vendors[i]) | ||
| 111 | && strncmp((char*)vendor, broken_vendors[i], vendor[OPT_LEN - OPT_DATA]) == 0 | ||
| 112 | ) { | ||
| 113 | log1("Broken client (%s), forcing broadcast replies", | ||
| 114 | broken_vendors[i]); | ||
| 115 | packet->flags |= htons(BROADCAST_FLAG); | ||
| 116 | } | ||
| 117 | } | ||
| 118 | #else | ||
| 119 | if (vendor[OPT_LEN - OPT_DATA] == (uint8_t)(sizeof("MSFT 98")-1) | ||
| 120 | && memcmp(vendor, "MSFT 98", sizeof("MSFT 98")-1) == 0 | ||
| 121 | ) { | ||
| 122 | log1("Broken client (%s), forcing broadcast replies", "MSFT 98"); | ||
| 123 | packet->flags |= htons(BROADCAST_FLAG); | ||
| 124 | } | ||
| 125 | #endif | ||
| 126 | } | ||
| 127 | } | ||
| 128 | |||
| 129 | return bytes; | 101 | return bytes; |
| 130 | } | 102 | } |
| 131 | 103 | ||
