Author: tuexen
Date: Thu Oct 28 16:51:57 2010
New Revision: 214460
URL: http://svn.freebsd.org/changeset/base/214460

Log:
  MFC r210866:
  
  Fix a bug where endpoints bound to wildcard addresses where
  using addresses not announced to the peer due to address
  scoping.

Modified:
  stable/8/sys/netinet/sctp_output.c
Directory Properties:
  stable/8/sys/   (props changed)
  stable/8/sys/amd64/include/xen/   (props changed)
  stable/8/sys/cddl/contrib/opensolaris/   (props changed)
  stable/8/sys/contrib/dev/acpica/   (props changed)
  stable/8/sys/contrib/pf/   (props changed)
  stable/8/sys/dev/xen/xenpci/   (props changed)

Modified: stable/8/sys/netinet/sctp_output.c
==============================================================================
--- stable/8/sys/netinet/sctp_output.c  Thu Oct 28 16:49:11 2010        
(r214459)
+++ stable/8/sys/netinet/sctp_output.c  Thu Oct 28 16:51:57 2010        
(r214460)
@@ -2740,6 +2740,15 @@ sctp_select_nth_preferred_addr_from_ifn_
                        }
                }
                if (stcb) {
+                       if (sctp_is_address_in_scope(ifa,
+                           stcb->asoc.ipv4_addr_legal,
+                           stcb->asoc.ipv6_addr_legal,
+                           stcb->asoc.loopback_scope,
+                           stcb->asoc.ipv4_local_scope,
+                           stcb->asoc.local_scope,
+                           stcb->asoc.site_scope, 0) == 0) {
+                               continue;
+                       }
                        if (((non_asoc_addr_ok == 0) &&
                            (sctp_is_addr_restricted(stcb, sifa))) ||
                            (non_asoc_addr_ok &&
@@ -2783,6 +2792,15 @@ sctp_count_num_preferred_boundall(struct
                        continue;
                }
                if (stcb) {
+                       if (sctp_is_address_in_scope(ifa,
+                           stcb->asoc.ipv4_addr_legal,
+                           stcb->asoc.ipv6_addr_legal,
+                           stcb->asoc.loopback_scope,
+                           stcb->asoc.ipv4_local_scope,
+                           stcb->asoc.local_scope,
+                           stcb->asoc.site_scope, 0) == 0) {
+                               continue;
+                       }
                        if (((non_asoc_addr_ok == 0) &&
                            (sctp_is_addr_restricted(stcb, sifa))) ||
                            (non_asoc_addr_ok &&
@@ -2963,6 +2981,15 @@ bound_all_plan_b:
                if (sifa == NULL)
                        continue;
                if (stcb) {
+                       if (sctp_is_address_in_scope(sifa,
+                           stcb->asoc.ipv4_addr_legal,
+                           stcb->asoc.ipv6_addr_legal,
+                           stcb->asoc.loopback_scope,
+                           stcb->asoc.ipv4_local_scope,
+                           stcb->asoc.local_scope,
+                           stcb->asoc.site_scope, 0) == 0) {
+                               continue;
+                       }
                        if (((non_asoc_addr_ok == 0) &&
                            (sctp_is_addr_restricted(stcb, sifa))) ||
                            (non_asoc_addr_ok &&
@@ -3005,6 +3032,15 @@ plan_d:
                        if (sifa == NULL)
                                continue;
                        if (stcb) {
+                               if (sctp_is_address_in_scope(sifa,
+                                   stcb->asoc.ipv4_addr_legal,
+                                   stcb->asoc.ipv6_addr_legal,
+                                   stcb->asoc.loopback_scope,
+                                   stcb->asoc.ipv4_local_scope,
+                                   stcb->asoc.local_scope,
+                                   stcb->asoc.site_scope, 0) == 0) {
+                                       continue;
+                               }
                                if (((non_asoc_addr_ok == 0) &&
                                    (sctp_is_addr_restricted(stcb, sifa))) ||
                                    (non_asoc_addr_ok &&
_______________________________________________
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