summary refs log tree commit diff
path: root/pkgs
diff options
context:
space:
mode:
authorEelco Dolstra <eelco.dolstra@logicblox.com>2012-03-16 17:42:14 +0000
committerEelco Dolstra <eelco.dolstra@logicblox.com>2012-03-16 17:42:14 +0000
commit0ac7828c6b36816b41f41513f8126b9f100c6eb1 (patch)
tree11e058e829a41a439818daf437142a89cb3b51fc /pkgs
parent1148fc2f76f1f3a02ee64e96a833e980b461aca3 (diff)
downloadnixpkgs-0ac7828c6b36816b41f41513f8126b9f100c6eb1.tar
nixpkgs-0ac7828c6b36816b41f41513f8126b9f100c6eb1.tar.gz
nixpkgs-0ac7828c6b36816b41f41513f8126b9f100c6eb1.tar.bz2
nixpkgs-0ac7828c6b36816b41f41513f8126b9f100c6eb1.tar.lz
nixpkgs-0ac7828c6b36816b41f41513f8126b9f100c6eb1.tar.xz
nixpkgs-0ac7828c6b36816b41f41513f8126b9f100c6eb1.tar.zst
nixpkgs-0ac7828c6b36816b41f41513f8126b9f100c6eb1.zip
* portmap: Set SO_REUSEADDR to ensure that portmap can restart
  properly.

svn path=/nixpkgs/trunk/; revision=33166
Diffstat (limited to 'pkgs')
-rw-r--r--pkgs/servers/portmap/default.nix4
-rw-r--r--pkgs/servers/portmap/reuse-socket.patch38
2 files changed, 41 insertions, 1 deletions
diff --git a/pkgs/servers/portmap/default.nix b/pkgs/servers/portmap/default.nix
index 52635b5818f..d7a05261ff2 100644
--- a/pkgs/servers/portmap/default.nix
+++ b/pkgs/servers/portmap/default.nix
@@ -11,7 +11,9 @@ stdenv.mkDerivation rec {
     sha256 = "1pj13ll4mbfwjwpn3fbg03qq9im6v2i8fcpa3ffp4viykz9j1j02";
   };
 
-  patchPhase = ''
+  patches = [ ./reuse-socket.patch ];
+
+  postPatch = ''
     substituteInPlace "Makefile" --replace "/usr/share" "" \
       --replace "install -o root -g root" "install"
   '';
diff --git a/pkgs/servers/portmap/reuse-socket.patch b/pkgs/servers/portmap/reuse-socket.patch
new file mode 100644
index 00000000000..7d1a0ca0952
--- /dev/null
+++ b/pkgs/servers/portmap/reuse-socket.patch
@@ -0,0 +1,38 @@
+Set SO_REUSEADDR to ensure that portmap can restart properly.
+
+https://bugs.launchpad.net/ubuntu/+source/portmap/+bug/688550
+
+===================================================================
+--- portmap-6.0.0.orig/portmap.c	2011-03-16 20:43:26.000000000 +0100
++++ portmap-6.0.0/portmap.c	2011-03-17 07:30:17.000000000 +0100
+@@ -142,9 +142,9 @@
+   * loopback interface address.
+   */
+ 
++static int on = 1;
+ #ifdef LOOPBACK_SETUNSET
+ static SVCXPRT *ludpxprt, *ltcpxprt;
+-static int on = 1;
+ #ifndef INADDR_LOOPBACK
+ #define INADDR_LOOPBACK ntohl(inet_addr("127.0.0.1"))
+ #endif
+@@ -399,9 +399,7 @@
+ 		syslog(LOG_ERR, "cannot create udp socket: %m");
+ 		exit(1);
+ 	}
+-#ifdef LOOPBACK_SETUNSET
+ 	setsockopt(sock, SOL_SOCKET, SO_REUSEADDR, &on, sizeof on);
+-#endif
+ 
+ 	memset((char *) &addr, 0, sizeof(addr));
+ 	addr.sin_addr.s_addr = 0;
+@@ -434,9 +432,7 @@
+ 		syslog(LOG_ERR, "cannot create tcp socket: %m");
+ 		exit(1);
+ 	}
+-#ifdef LOOPBACK_SETUNSET
+ 	setsockopt(sock, SOL_SOCKET, SO_REUSEADDR, &on, sizeof on);
+-#endif
+ 	if (bind(sock, (struct sockaddr *)&addr, len) != 0) {
+ 		syslog(LOG_ERR, "cannot bind tcp: %m");
+ 		exit(1);