X-Git-Url: http://git.meshlink.io/?a=blobdiff_plain;f=avahi-core%2Fsocket.c;h=17ab6e553b0074b1f2c608b11e94d2ca76049641;hb=9c0f9c65093cfa53d45f9b68782321eb8063a032;hp=e69ec7d42a7d1f947d1c7f3988e443dd68255873;hpb=46109dfec75534fe270c0ab902576f685d5ab3a6;p=catta diff --git a/avahi-core/socket.c b/avahi-core/socket.c index e69ec7d..17ab6e5 100644 --- a/avahi-core/socket.c +++ b/avahi-core/socket.c @@ -726,7 +726,7 @@ AvahiDnsPacket *avahi_recv_dns_packet_ipv4( case IP_PKTINFO: { struct in_pktinfo *i = (struct in_pktinfo*) CMSG_DATA(cmsg); - if (ret_iface) + if (ret_iface && i->ipi_ifindex > 0) *ret_iface = (int) i->ipi_ifindex; if (ret_dst_address) @@ -742,12 +742,16 @@ AvahiDnsPacket *avahi_recv_dns_packet_ipv4( case IP_RECVIF: { struct sockaddr_dl *sdl = (struct sockaddr_dl *) CMSG_DATA (cmsg); - if (ret_iface) + if (ret_iface) { #ifdef __sun - *ret_iface = *(uint_t*) sdl; + if (*(uint_t*) sdl > 0) + *ret_iface = *(uint_t*) sdl; #else - *ret_iface = (int) sdl->sdl_index; + + if (sdl->sdl_index > 0) + *ret_iface = (int) sdl->sdl_index; #endif + } break; } @@ -763,7 +767,7 @@ AvahiDnsPacket *avahi_recv_dns_packet_ipv4( #endif default: - avahi_log_warn("Unhandled cmsg_type : %d", cmsg->cmsg_type); + avahi_log_warn("Unhandled cmsg_type: %d", cmsg->cmsg_type); break; } } @@ -874,7 +878,7 @@ AvahiDnsPacket *avahi_recv_dns_packet_ipv6( case IPV6_PKTINFO: { struct in6_pktinfo *i = (struct in6_pktinfo*) CMSG_DATA(cmsg); - if (ret_iface) + if (ret_iface && i->ipi6_ifindex > 0) *ret_iface = i->ipi6_ifindex; if (ret_dst_address) @@ -885,7 +889,7 @@ AvahiDnsPacket *avahi_recv_dns_packet_ipv6( } default: - avahi_log_warn("Unhandled cmsg_type : %d", cmsg->cmsg_type); + avahi_log_warn("Unhandled cmsg_type: %d", cmsg->cmsg_type); break; } }