diff options
author | Denis Vlasenko | 2008-02-04 13:12:16 +0000 |
---|---|---|
committer | Denis Vlasenko | 2008-02-04 13:12:16 +0000 |
commit | d55fe3e595eb0aad60484d273e251cfee4ef8aa5 (patch) | |
tree | 1b9ff57d70411902db36582da8dbaded99485eeb /networking/udhcp/clientsocket.c | |
parent | e8ef7ec7de0cd9906b42a94eddb800ed1229a614 (diff) | |
download | busybox-d55fe3e595eb0aad60484d273e251cfee4ef8aa5.zip busybox-d55fe3e595eb0aad60484d273e251cfee4ef8aa5.tar.gz |
udhcp: optional support for non-standard DHCP ports (+300 bytes when selected)
Diffstat (limited to 'networking/udhcp/clientsocket.c')
-rw-r--r-- | networking/udhcp/clientsocket.c | 14 |
1 files changed, 9 insertions, 5 deletions
diff --git a/networking/udhcp/clientsocket.c b/networking/udhcp/clientsocket.c index 954db53..b5534f8 100644 --- a/networking/udhcp/clientsocket.c +++ b/networking/udhcp/clientsocket.c @@ -33,8 +33,8 @@ #include <linux/filter.h> #include "common.h" - -#define SERVER_AND_CLIENT_PORTS ((SERVER_PORT << 16) + CLIENT_PORT) +#include "dhcpd.h" +#include "dhcpc.h" int raw_socket(int ifindex) { @@ -62,6 +62,7 @@ int raw_socket(int ifindex) * * TODO: make conditional? */ +#define SERVER_AND_CLIENT_PORTS ((67 << 16) + 68) static const struct sock_filter filter_instr[] = { /* check for udp */ BPF_STMT(BPF_LD|BPF_B|BPF_ABS, 9), @@ -89,10 +90,13 @@ int raw_socket(int ifindex) fd = xsocket(PF_PACKET, SOCK_DGRAM, htons(ETH_P_IP)); DEBUG("got raw socket fd %d", fd); - /* Ignoring error (kernel may lack support for this) */ - if (setsockopt(fd, SOL_SOCKET, SO_ATTACH_FILTER, &filter_prog, + if (SERVER_PORT == 67 && CLIENT_PORT == 68) { + /* Use only if standard ports are in use */ + /* Ignoring error (kernel may lack support for this) */ + if (setsockopt(fd, SOL_SOCKET, SO_ATTACH_FILTER, &filter_prog, sizeof(filter_prog)) >= 0) - DEBUG("attached filter to raw socket fd %d", fd); + DEBUG("attached filter to raw socket fd %d", fd); + } sock.sll_family = AF_PACKET; sock.sll_protocol = htons(ETH_P_IP); |