]> git.meshlink.io Git - catta/commitdiff
* portability function for IP_PKTINFO
authorSebastien Estienne <sebastien.estienne@gmail.com>
Wed, 12 Oct 2005 22:41:44 +0000 (22:41 +0000)
committerSebastien Estienne <sebastien.estienne@gmail.com>
Wed, 12 Oct 2005 22:41:44 +0000 (22:41 +0000)
git-svn-id: file:///home/lennart/svn/public/avahi/trunk@748 941a03a8-eaeb-0310-b9a0-b1bbd8fe43fe

avahi-core/socket.c

index 7e1cdacf8749ee53cad2982194dfc7fe61152cc2..a555eafba1a0f039ed22d236ebda045d848af820 100644 (file)
@@ -211,6 +211,36 @@ static int bind_with_warn(int fd, const struct sockaddr *sa, socklen_t l) {
     return 0;
 }
 
     return 0;
 }
 
+static int ip_pktinfo (int fd, int yes)
+{
+    int ret = -1;
+
+#if IP_PKTINFO
+    if ((ret = setsockopt(fd, IPPROTO_IP, IP_PKTINFO, &yes, sizeof(yes))) < 0) {
+        avahi_log_warn("IP_PKTINFO failed: %s", strerror(errno));
+    }
+#else
+#ifdef IP_RECVINTERFACE
+    if ((ret = setsockopt (fd, IPPROTO_IP, IP_RECVINTERFACE, &yes, sizeof (yes))) < 0) {
+        avahi_log_warn("IP_RECVINTERFACE failed: %s", strerror(errno));
+    }
+#else
+#ifdef IP_RECVIF
+    if ((ret = setsockopt (fd, IPPROTO_IP, IP_RECVIF, &yes, sizeof (yes))) < 0) {
+        avahi_log_warn("IP_RECVIF failed: %s", strerror(errno));
+    }
+#endif /* IP_RECVIF */
+#endif /* IP_RECVINTERFACE */
+#if defined (IP_RECVDSTADDR) /* && !defined(solaris) */
+    if ((ret = setsockopt (fd, IPPROTO_IP, IP_RECVDSTADDR, &yes, sizeof (yes))) < 0) {
+        avahi_log_warn("IP_RECVDSTADDR failed: %s", strerror(errno));
+    }
+#endif /* IP_RECVDSTADDR */
+#endif /* IP_PKTINFO */
+
+    return (ret);
+}
+
 int avahi_open_socket_ipv4(int no_reuse) {
     struct sockaddr_in local;
     int fd = -1, ttl, yes, r;
 int avahi_open_socket_ipv4(int no_reuse) {
     struct sockaddr_in local;
     int fd = -1, ttl, yes, r;
@@ -257,11 +287,10 @@ int avahi_open_socket_ipv4(int no_reuse) {
     }
 
     yes = 1;
     }
 
     yes = 1;
-    if (setsockopt(fd, IPPROTO_IP, IP_PKTINFO, &yes, sizeof(yes)) < 0) {
-        avahi_log_warn("IP_PKTINFO failed: %s", strerror(errno));
-        goto fail;
+    if (ip_pktinfo (fd, yes) < 0) {
+         goto fail;
     }
     }
-    
+
     if (avahi_set_cloexec(fd) < 0) {
         avahi_log_warn("FD_CLOEXEC failed: %s", strerror(errno));
         goto fail;
     if (avahi_set_cloexec(fd) < 0) {
         avahi_log_warn("FD_CLOEXEC failed: %s", strerror(errno));
         goto fail;
@@ -673,11 +702,10 @@ int avahi_open_unicast_socket_ipv4(void) {
     }
 
     yes = 1;
     }
 
     yes = 1;
-    if (setsockopt(fd, IPPROTO_IP, IP_PKTINFO, &yes, sizeof(yes)) < 0) {
-        avahi_log_warn("IP_PKTINFO failed: %s", strerror(errno));
-        goto fail;
+    if (ip_pktinfo (fd, yes) < 0) {
+         goto fail;
     }
     }
-    
+
     if (avahi_set_cloexec(fd) < 0) {
         avahi_log_warn("FD_CLOEXEC failed: %s", strerror(errno));
         goto fail;
     if (avahi_set_cloexec(fd) < 0) {
         avahi_log_warn("FD_CLOEXEC failed: %s", strerror(errno));
         goto fail;