Author: ed
Date: Wed Feb 24 17:10:32 2016
New Revision: 295974
URL: https://svnweb.freebsd.org/changeset/base/295974

Log:
  Make asynchronous connection failures on UNIX sockets fail with ECONNRESET.
  
  While making CloudABI work well on Linux, I discovered that I had a
  FreeBSD-ism in one of my unit tests. The test did the following:
  
  - Create UNIX socket 1, bind it, make it listen.
  - Create UNIX socket 2, connect it to UNIX socket 1.
  - Close UNIX socket 1.
  - Obtain SO_ERROR from socket 2.
  
  On FreeBSD this returns ECONNABORTED, while on Linux it returns
  ECONNRESET. I dug through some of the relevant specifications[1] and it
  looks like Linux is all right here. ECONNABORTED should only be returned
  when the local connection (socket 2) is aborted; not the peer (socket 1).
  
  It is of course slightly misleading: the function in which we set this
  error is called uipc_abort(), but keep in mind that we're aborting the
  peer, thus resetting the local socket.
  
  [1] http://pubs.opengroup.org/onlinepubs/9699919799/functions/connect.html
  
  Reviewed by:  cem
  Sponsored by: Nuxi, the Netherlands
  Differential Revision:        https://reviews.freebsd.org/D5419

Modified:
  head/sys/kern/uipc_usrreq.c

Modified: head/sys/kern/uipc_usrreq.c
==============================================================================
--- head/sys/kern/uipc_usrreq.c Wed Feb 24 16:52:03 2016        (r295973)
+++ head/sys/kern/uipc_usrreq.c Wed Feb 24 17:10:32 2016        (r295974)
@@ -354,7 +354,7 @@ uipc_abort(struct socket *so)
        unp2 = unp->unp_conn;
        if (unp2 != NULL) {
                UNP_PCB_LOCK(unp2);
-               unp_drop(unp2, ECONNABORTED);
+               unp_drop(unp2, ECONNRESET);
                UNP_PCB_UNLOCK(unp2);
        }
        UNP_PCB_UNLOCK(unp);
_______________________________________________
svn-src-head@freebsd.org mailing list
https://lists.freebsd.org/mailman/listinfo/svn-src-head
To unsubscribe, send any mail to "svn-src-head-unsubscr...@freebsd.org"

Reply via email to