8272501ea0
Signed-off-by: Peter Korsgaard <jacmet@sunsite.dk>
148 lines
3.7 KiB
Diff
148 lines
3.7 KiB
Diff
[PATCH] avahi-core: make ipv6 support optional on uclibc 0.9.31+
|
|
|
|
uClibc 0.9.31+ doesn't define the IPV6_* defines when IPv6 support isn't
|
|
enabled, causing the avahi build to break. Detect this configuration, and
|
|
comment out IPv6 code if so.
|
|
|
|
Signed-off-by: Peter Korsgaard <jacmet@sunsite.dk>
|
|
---
|
|
avahi-core/socket.c | 28 +++++++++++++++++++++++-----
|
|
1 file changed, 23 insertions(+), 5 deletions(-)
|
|
|
|
Index: avahi-0.6.23/avahi-core/socket.c
|
|
===================================================================
|
|
--- avahi-0.6.23.orig/avahi-core/socket.c
|
|
+++ avahi-0.6.23/avahi-core/socket.c
|
|
@@ -47,6 +47,11 @@
|
|
#include <net/if_dl.h>
|
|
#endif
|
|
|
|
+#include <features.h>
|
|
+#if defined(__UCLIBC__) && !defined (__UCLIBC_HAS_IPV6__)
|
|
+#define NO_IPV6
|
|
+#endif
|
|
+
|
|
#include "dns.h"
|
|
#include "fdutil.h"
|
|
#include "socket.h"
|
|
@@ -75,6 +80,7 @@ static void mdns_mcast_group_ipv4(struct
|
|
inet_pton(AF_INET, AVAHI_IPV4_MCAST_GROUP, &ret_sa->sin_addr);
|
|
}
|
|
|
|
+#ifndef NO_IPV6
|
|
static void mdns_mcast_group_ipv6(struct sockaddr_in6 *ret_sa) {
|
|
assert(ret_sa);
|
|
|
|
@@ -83,6 +89,7 @@ static void mdns_mcast_group_ipv6(struct
|
|
ret_sa->sin6_port = htons(AVAHI_MDNS_PORT);
|
|
inet_pton(AF_INET6, AVAHI_IPV6_MCAST_GROUP, &ret_sa->sin6_addr);
|
|
}
|
|
+#endif
|
|
|
|
static void ipv4_address_to_sockaddr(struct sockaddr_in *ret_sa, const AvahiIPv4Address *a, uint16_t port) {
|
|
assert(ret_sa);
|
|
@@ -95,6 +102,7 @@ static void ipv4_address_to_sockaddr(str
|
|
memcpy(&ret_sa->sin_addr, a, sizeof(AvahiIPv4Address));
|
|
}
|
|
|
|
+#ifndef NO_IPV6
|
|
static void ipv6_address_to_sockaddr(struct sockaddr_in6 *ret_sa, const AvahiIPv6Address *a, uint16_t port) {
|
|
assert(ret_sa);
|
|
assert(a);
|
|
@@ -105,6 +113,7 @@ static void ipv6_address_to_sockaddr(str
|
|
ret_sa->sin6_port = htons(port);
|
|
memcpy(&ret_sa->sin6_addr, a, sizeof(AvahiIPv6Address));
|
|
}
|
|
+#endif
|
|
|
|
int avahi_mdns_mcast_join_ipv4(int fd, const AvahiIPv4Address *a, int idx, int join) {
|
|
#ifdef HAVE_STRUCT_IP_MREQN
|
|
@@ -143,6 +152,7 @@ int avahi_mdns_mcast_join_ipv4(int fd, c
|
|
}
|
|
|
|
int avahi_mdns_mcast_join_ipv6(int fd, const AvahiIPv6Address *a, int idx, int join) {
|
|
+#ifndef NO_IPV6
|
|
struct ipv6_mreq mreq6;
|
|
struct sockaddr_in6 sa6;
|
|
|
|
@@ -164,6 +174,9 @@ int avahi_mdns_mcast_join_ipv6(int fd, c
|
|
}
|
|
|
|
return 0;
|
|
+#else
|
|
+ return -1;
|
|
+#endif
|
|
}
|
|
|
|
static int reuseaddr(int fd) {
|
|
@@ -372,6 +385,7 @@ fail:
|
|
}
|
|
|
|
int avahi_open_socket_ipv6(int no_reuse) {
|
|
+#ifndef NO_IPV6
|
|
struct sockaddr_in6 sa, local;
|
|
int fd = -1, yes, r;
|
|
int ttl;
|
|
@@ -437,7 +451,7 @@ int avahi_open_socket_ipv6(int no_reuse)
|
|
fail:
|
|
if (fd >= 0)
|
|
close(fd);
|
|
-
|
|
+#endif
|
|
return -1;
|
|
}
|
|
|
|
@@ -567,7 +581,7 @@ int avahi_send_dns_packet_ipv6(
|
|
const AvahiIPv6Address *src_address,
|
|
const AvahiIPv6Address *dst_address,
|
|
uint16_t dst_port) {
|
|
-
|
|
+#ifndef NO_IPV6
|
|
struct sockaddr_in6 sa;
|
|
struct msghdr msg;
|
|
struct iovec io;
|
|
@@ -620,6 +634,9 @@ int avahi_send_dns_packet_ipv6(
|
|
}
|
|
|
|
return sendmsg_loop(fd, &msg, 0);
|
|
+#else
|
|
+ return -1;
|
|
+#endif
|
|
}
|
|
|
|
AvahiDnsPacket *avahi_recv_dns_packet_ipv4(
|
|
@@ -782,7 +799,7 @@ AvahiDnsPacket *avahi_recv_dns_packet_ip
|
|
AvahiIPv6Address *ret_dst_address,
|
|
AvahiIfIndex *ret_iface,
|
|
uint8_t *ret_ttl) {
|
|
-
|
|
+#ifndef NO_IPV6
|
|
AvahiDnsPacket *p = NULL;
|
|
struct msghdr msg;
|
|
struct iovec io;
|
|
@@ -889,7 +906,7 @@ AvahiDnsPacket *avahi_recv_dns_packet_ip
|
|
fail:
|
|
if (p)
|
|
avahi_dns_packet_free(p);
|
|
-
|
|
+#endif
|
|
return NULL;
|
|
}
|
|
|
|
@@ -934,6 +951,7 @@ fail:
|
|
}
|
|
|
|
int avahi_open_unicast_socket_ipv6(void) {
|
|
+#ifndef NO_IPV6
|
|
struct sockaddr_in6 local;
|
|
int fd = -1, yes;
|
|
|
|
@@ -974,6 +992,6 @@ int avahi_open_unicast_socket_ipv6(void)
|
|
fail:
|
|
if (fd >= 0)
|
|
close(fd);
|
|
-
|
|
+#endif
|
|
return -1;
|
|
}
|