arp: fix -H/-t handling.
[oweals/busybox.git] / networking / udhcp / socket.c
index a5220ba74263732d69add1d986658fa0ca1e66ee..a42106960801d160a2f25b88976a368ba66dcebd 100644 (file)
@@ -80,6 +80,7 @@ int FAST_FUNC udhcp_listen_socket(/*uint32_t ip,*/ int port, const char *inf)
 {
        int fd;
        struct sockaddr_in addr;
+       char *colon;
 
        log1("Opening listen socket on *:%d %s", port, inf);
        fd = xsocket(PF_INET, SOCK_DGRAM, IPPROTO_UDP);
@@ -88,10 +89,17 @@ int FAST_FUNC udhcp_listen_socket(/*uint32_t ip,*/ int port, const char *inf)
        if (setsockopt_broadcast(fd) == -1)
                bb_perror_msg_and_die("SO_BROADCAST");
 
-       /* NB: bug 1032 says this doesn't work on ethernet aliases (ethN:M) */
+       /* SO_BINDTODEVICE doesn't work on ethernet aliases (ethN:M) */
+       colon = strrchr(inf, ':');
+       if (colon)
+               *colon = '\0';
+
        if (setsockopt_bindtodevice(fd, inf))
                xfunc_die(); /* warning is already printed */
 
+       if (colon)
+               *colon = ':';
+
        memset(&addr, 0, sizeof(addr));
        addr.sin_family = AF_INET;
        addr.sin_port = htons(port);