Author: deischen
Date: Tue Jan 11 19:43:35 2011
New Revision: 217280
URL: http://svn.freebsd.org/changeset/base/217280

Log:
  MFC: 217169
  
  Make sure to always do source address selection on
  an unbound socket, regardless of any multicast options.
  If an address is specified via a multicast option, then
  let it override normal the source address selection.
  
  This fixes a bug where source address selection was
  not being performed when multicast options were present
  but without an interface being specified.
  
  Approved by:  re

Modified:
  releng/8.2/sys/netinet/in_pcb.c
Directory Properties:
  releng/8.2/sys/   (props changed)
  releng/8.2/sys/amd64/include/xen/   (props changed)
  releng/8.2/sys/cddl/contrib/opensolaris/   (props changed)
  releng/8.2/sys/contrib/dev/acpica/   (props changed)
  releng/8.2/sys/contrib/pf/   (props changed)

Modified: releng/8.2/sys/netinet/in_pcb.c
==============================================================================
--- releng/8.2/sys/netinet/in_pcb.c     Tue Jan 11 19:26:39 2011        
(r217279)
+++ releng/8.2/sys/netinet/in_pcb.c     Tue Jan 11 19:43:35 2011        
(r217280)
@@ -833,9 +833,10 @@ in_pcbconnect_setup(struct inpcb *inp, s
                }
        }
        if (laddr.s_addr == INADDR_ANY) {
+               error = in_pcbladdr(inp, &faddr, &laddr, cred);
                /*
                 * If the destination address is multicast and an outgoing
-                * interface has been set as a multicast option, use the
+                * interface has been set as a multicast option, prefer the
                 * address of that interface as our source address.
                 */
                if (IN_MULTICAST(ntohl(faddr.s_addr)) &&
@@ -852,16 +853,16 @@ in_pcbconnect_setup(struct inpcb *inp, s
                                                break;
                                if (ia == NULL) {
                                        IN_IFADDR_RUNLOCK();
-                                       return (EADDRNOTAVAIL);
+                                       error = EADDRNOTAVAIL;
+                               } else {
+                                       laddr = ia->ia_addr.sin_addr;
+                                       IN_IFADDR_RUNLOCK();
+                                       error = 0;
                                }
-                               laddr = ia->ia_addr.sin_addr;
-                               IN_IFADDR_RUNLOCK();
                        }
-               } else {
-                       error = in_pcbladdr(inp, &faddr, &laddr, cred);
-                       if (error) 
-                               return (error);
                }
+               if (error)
+                       return (error);
        }
        oinp = in_pcblookup_hash(inp->inp_pcbinfo, faddr, fport, laddr, lport,
            0, NULL);
_______________________________________________
svn-src-all@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/svn-src-all
To unsubscribe, send any mail to "svn-src-all-unsubscr...@freebsd.org"

Reply via email to