Author: eelco
Date: Fri Mar 16 17:42:14 2012
New Revision: 33166
URL: https://nixos.org/websvn/nix/?rev=33166&sc=1

Log:
* portmap: Set SO_REUSEADDR to ensure that portmap can restart
  properly.

Added:
   nixpkgs/trunk/pkgs/servers/portmap/reuse-socket.patch
Modified:
   nixpkgs/trunk/pkgs/servers/portmap/default.nix

Modified: nixpkgs/trunk/pkgs/servers/portmap/default.nix
==============================================================================
--- nixpkgs/trunk/pkgs/servers/portmap/default.nix      Fri Mar 16 17:20:04 
2012        (r33165)
+++ nixpkgs/trunk/pkgs/servers/portmap/default.nix      Fri Mar 16 17:42:14 
2012        (r33166)
@@ -11,7 +11,9 @@
     sha256 = "1pj13ll4mbfwjwpn3fbg03qq9im6v2i8fcpa3ffp4viykz9j1j02";
   };
 
-  patchPhase = ''
+  patches = [ ./reuse-socket.patch ];
+
+  postPatch = ''
     substituteInPlace "Makefile" --replace "/usr/share" "" \
       --replace "install -o root -g root" "install"
   '';

Added: nixpkgs/trunk/pkgs/servers/portmap/reuse-socket.patch
==============================================================================
--- /dev/null   00:00:00 1970   (empty, because file is newly added)
+++ nixpkgs/trunk/pkgs/servers/portmap/reuse-socket.patch       Fri Mar 16 
17:42:14 2012        (r33166)
@@ -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);
_______________________________________________
nix-commits mailing list
[email protected]
http://lists.science.uu.nl/mailman/listinfo/nix-commits

Reply via email to