aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorsem <sem@FreeBSD.org>2011-04-03 02:15:01 +0800
committersem <sem@FreeBSD.org>2011-04-03 02:15:01 +0800
commitc3a86b049a9a6a97a6f61ede322ebf6287d0c5a8 (patch)
tree9f9644e9d13df7d615065d59ecbb2e0f770ecc83
parent1269685abf44a8178c5013d2e24129559006e7f9 (diff)
downloadfreebsd-ports-gnome-c3a86b049a9a6a97a6f61ede322ebf6287d0c5a8.tar.gz
freebsd-ports-gnome-c3a86b049a9a6a97a6f61ede322ebf6287d0c5a8.tar.zst
freebsd-ports-gnome-c3a86b049a9a6a97a6f61ede322ebf6287d0c5a8.zip
- Fix ripd on 7.0+.
ripd could not join multicast group and complains to the log: Can't setsockopt IP_MULTICAST_IF on fd 11 to source address XXX.XXX.XXX.XXX for interface ng2 can't send packet : Permission denied PR: ports/155706 Submitted by: Eugene Grosbein Approved by: maintainer
-rw-r--r--net/quagga/Makefile2
-rw-r--r--net/quagga/files/patch-lib-sockopt.c90
2 files changed, 80 insertions, 12 deletions
diff --git a/net/quagga/Makefile b/net/quagga/Makefile
index 7ad09e4ba56f..04d439b25deb 100644
--- a/net/quagga/Makefile
+++ b/net/quagga/Makefile
@@ -7,7 +7,7 @@
PORTNAME= quagga
PORTVERSION= 0.99.17
-PORTREVISION= 6
+PORTREVISION= 7
CATEGORIES= net ipv6
MASTER_SITES= http://quagga.net/download/ \
http://www.ru.quagga.net/download/ \
diff --git a/net/quagga/files/patch-lib-sockopt.c b/net/quagga/files/patch-lib-sockopt.c
index 5995b3756e5f..49f355e61f1e 100644
--- a/net/quagga/files/patch-lib-sockopt.c
+++ b/net/quagga/files/patch-lib-sockopt.c
@@ -1,13 +1,81 @@
---- lib/sockopt.c.orig 2008-01-11 16:47:21.000000000 +0300
-+++ lib/sockopt.c 2008-01-11 16:47:57.000000000 +0300
-@@ -23,6 +23,10 @@
- #include "log.h"
- #include "sockopt.h"
+--- lib/sockopt.c 2010-04-20 21:44:26.000000000 -0400
++++ lib/sockopt.c 2010-11-03 10:55:06.000000000 -0400
+@@ -221,13 +221,13 @@ setsockopt_multicast_ipv4(int sock,
+ #ifdef HAVE_STRUCT_IP_MREQN_IMR_IFINDEX
+ /* This is better because it uses ifindex directly */
+ struct ip_mreqn mreqn;
++ struct group_req gr;
++ struct sockaddr_in *si;
+ int ret;
+
+ switch (optname)
+ {
+ case IP_MULTICAST_IF:
+- case IP_ADD_MEMBERSHIP:
+- case IP_DROP_MEMBERSHIP:
+ memset (&mreqn, 0, sizeof(mreqn));
-+#ifdef HAVE_STRUCT_IP_MREQN_IMR_IFINDEX
-+#undef HAVE_STRUCT_IP_MREQN_IMR_IFINDEX
-+#endif
+ if (mcast_addr)
+@@ -240,6 +240,37 @@ setsockopt_multicast_ipv4(int sock,
+
+ ret = setsockopt(sock, IPPROTO_IP, optname,
+ (void *)&mreqn, sizeof(mreqn));
++ return ret;
++ break;
+
- int
- setsockopt_so_recvbuf (int sock, int size)
- {
++ case IP_ADD_MEMBERSHIP:
++ case IP_DROP_MEMBERSHIP:
++ if (ifindex)
++ {
++ memset (&gr, 0, sizeof(gr));
++ si = (struct sockaddr_in *)&gr.gr_group;
++ gr.gr_interface = ifindex;
++ if (mcast_addr)
++ si->sin_family = AF_INET;
++#ifdef HAVE_STRUCT_SOCKADDR_IN_SIN_LEN
++ si->sin_len = sizeof(struct sockaddr_in);
++#endif /* HAVE_STRUCT_SOCKADDR_IN_SIN_LEN */
++ si->sin_addr.s_addr = mcast_addr;
++ if (optname == IP_ADD_MEMBERSHIP)
++ ret = setsockopt(sock, IPPROTO_IP, MCAST_JOIN_GROUP, (void *)&gr, sizeof(gr));
++ else
++ ret = setsockopt(sock, IPPROTO_IP, MCAST_LEAVE_GROUP, (void *)&gr, sizeof(gr));
++ }
++ else
++ {
++ memset (&mreqn, 0, sizeof(mreqn));
++ if (mcast_addr)
++ mreqn.imr_multiaddr.s_addr = mcast_addr;
++ mreqn.imr_address = if_addr;
++
++ ret = setsockopt(sock, IPPROTO_IP, optname,
++ (void *)&mreqn, sizeof(mreqn));
++ }
+ if ((ret < 0) && (optname == IP_ADD_MEMBERSHIP) && (errno == EADDRINUSE))
+ {
+ /* see above: handle possible problem when interface comes back up */
+@@ -248,12 +279,18 @@ setsockopt_multicast_ipv4(int sock,
+ "re-add (fd %d, ifaddr %s, mcast %s, ifindex %u)",
+ sock,
+ inet_ntop(AF_INET, &if_addr, buf[0], sizeof(buf[0])),
+- inet_ntop(AF_INET, &mreqn.imr_multiaddr,
+- buf[1], sizeof(buf[1])), ifindex);
+- setsockopt(sock, IPPROTO_IP, IP_DROP_MEMBERSHIP,
+- (void *)&mreqn, sizeof(mreqn));
+- ret = setsockopt(sock, IPPROTO_IP, IP_ADD_MEMBERSHIP,
+- (void *)&mreqn, sizeof(mreqn));
++ inet_ntop(AF_INET, &mcast_addr, buf[1], sizeof(buf[1])),
++ ifindex);
++ if (ifindex)
++ {
++ setsockopt(sock, IPPROTO_IP, MCAST_LEAVE_GROUP, (void *)&gr, sizeof(gr));
++ ret = setsockopt(sock, IPPROTO_IP, MCAST_JOIN_GROUP, (void *)&gr, sizeof(gr));
++ }
++ else
++ {
++ setsockopt(sock, IPPROTO_IP, IP_DROP_MEMBERSHIP, (void *)&mreqn, sizeof(mreqn));
++ ret = setsockopt(sock, IPPROTO_IP, IP_ADD_MEMBERSHIP, (void *)&mreqn, sizeof(mreqn));
++ }
+ }
+ return ret;
+ break;