svn commit: r414130 - in head/net/csync2: . files

Tijl Coosemans tijl at FreeBSD.org
Wed Apr 27 20:05:12 UTC 2016


Author: tijl
Date: Wed Apr 27 20:05:11 2016
New Revision: 414130
URL: https://svnweb.freebsd.org/changeset/ports/414130

Log:
  Rather than listening on two sockets, one for IPv4 and one for IPv6 the
  csync server listens on one IPv6 socket and uses IPv4 mapped IPv6 addresses
  to support IPv4.  This IPv6 feature is disabled by default on FreeBSD so
  add a patch to enable it on the server socket.
  
  PR:		208928
  Tested by:	ari at ish.com.au
  Approved by:	alexey at renatasystems.org (maintainer)

Added:
  head/net/csync2/files/patch-csync2.c   (contents, props changed)
Modified:
  head/net/csync2/Makefile

Modified: head/net/csync2/Makefile
==============================================================================
--- head/net/csync2/Makefile	Wed Apr 27 19:24:33 2016	(r414129)
+++ head/net/csync2/Makefile	Wed Apr 27 20:05:11 2016	(r414130)
@@ -3,7 +3,7 @@
 
 PORTNAME=	csync2
 PORTVERSION=	2.0
-PORTREVISION=	1
+PORTREVISION=	2
 CATEGORIES=	net
 MASTER_SITES=	http://oss.linbit.com/csync2/
 

Added: head/net/csync2/files/patch-csync2.c
==============================================================================
--- /dev/null	00:00:00 1970	(empty, because file is newly added)
+++ head/net/csync2/files/patch-csync2.c	Wed Apr 27 20:05:11 2016	(r414130)
@@ -0,0 +1,21 @@
+--- csync2.c.orig	2013-05-02 12:58:04 UTC
++++ csync2.c
+@@ -256,7 +256,7 @@ static int csync_server_bind(void)
+ 	struct addrinfo hints;
+ 	struct addrinfo *result, *rp;
+ 	int save_errno;
+-	int sfd = -1, s, on = 1;
++	int sfd = -1, s, off = 0, on = 1;
+ 	memset(&hints, 0, sizeof(struct addrinfo));
+ 	hints.ai_family = AF_UNSPEC;	/* Allow IPv4 or IPv6 */
+ 	hints.ai_socktype = SOCK_STREAM;
+@@ -284,6 +284,9 @@ static int csync_server_bind(void)
+ 			goto error;
+ 		if (setsockopt(sfd, IPPROTO_TCP, TCP_NODELAY, &on, (socklen_t) sizeof(on)) < 0)
+ 			goto error;
++		if (rp->ai_family == AF_INET6)
++			if (setsockopt(sfd, IPPROTO_IPV6, IPV6_V6ONLY, &off, (socklen_t) sizeof(off)) < 0)
++				goto error;
+ 
+ 		if (bind(sfd, rp->ai_addr, rp->ai_addrlen) == 0)
+ 			break;	/* Success */


More information about the svn-ports-head mailing list