Author: tuexen
Date: Sat Apr 30 14:25:00 2016
New Revision: 298847
URL: https://svnweb.freebsd.org/changeset/base/298847

Log:
  Add the UDP encaps port as a parameter to sctp_add_remote_addr().
  
  This is currently only a code change without any functional
  change. But this allows to set the remote encapsulation port
  in a more detailed way, which will be provided in a follow-up
  commit.
  
  MFC after: 1 week

Modified:
  head/sys/netinet/sctp_asconf.c
  head/sys/netinet/sctp_input.c
  head/sys/netinet/sctp_output.c
  head/sys/netinet/sctp_pcb.c
  head/sys/netinet/sctp_pcb.h
  head/sys/netinet/sctputil.c

Modified: head/sys/netinet/sctp_asconf.c
==============================================================================
--- head/sys/netinet/sctp_asconf.c      Sat Apr 30 12:44:03 2016        
(r298846)
+++ head/sys/netinet/sctp_asconf.c      Sat Apr 30 14:25:00 2016        
(r298847)
@@ -244,7 +244,8 @@ sctp_process_asconf_add_ip(struct sockad
                m_reply = sctp_asconf_error_response(aph->correlation_id,
                    SCTP_CAUSE_INVALID_PARAM, (uint8_t *) aph,
                    aparam_length);
-       } else if (sctp_add_remote_addr(stcb, sa, &net, SCTP_DONOT_SETSCOPE,
+       } else if (sctp_add_remote_addr(stcb, sa, &net, stcb->asoc.port,
+                   SCTP_DONOT_SETSCOPE,
            SCTP_ADDR_DYNAMIC_ADDED) != 0) {
                SCTPDBG(SCTP_DEBUG_ASCONF1,
                    "process_asconf_add_ip: error adding address\n");

Modified: head/sys/netinet/sctp_input.c
==============================================================================
--- head/sys/netinet/sctp_input.c       Sat Apr 30 12:44:03 2016        
(r298846)
+++ head/sys/netinet/sctp_input.c       Sat Apr 30 14:25:00 2016        
(r298847)
@@ -2718,7 +2718,8 @@ sctp_handle_cookie_echo(struct mbuf *m, 
         */
        if (netl == NULL) {
                /* TSNH! Huh, why do I need to add this address here? */
-               if (sctp_add_remote_addr(*stcb, to, NULL, SCTP_DONOT_SETSCOPE, 
SCTP_IN_COOKIE_PROC)) {
+               if (sctp_add_remote_addr(*stcb, to, NULL, (*stcb)->asoc.port,
+                   SCTP_DONOT_SETSCOPE, SCTP_IN_COOKIE_PROC)) {
                        return (NULL);
                }
                netl = sctp_findnet(*stcb, to);

Modified: head/sys/netinet/sctp_output.c
==============================================================================
--- head/sys/netinet/sctp_output.c      Sat Apr 30 12:44:03 2016        
(r298846)
+++ head/sys/netinet/sctp_output.c      Sat Apr 30 14:25:00 2016        
(r298847)
@@ -3677,7 +3677,7 @@ sctp_process_cmsgs_for_init(struct sctp_
                                        *error = EINVAL;
                                        return (1);
                                }
-                               if (sctp_add_remote_addr(stcb, (struct sockaddr 
*)&sin, NULL,
+                               if (sctp_add_remote_addr(stcb, (struct sockaddr 
*)&sin, NULL, stcb->asoc.port,
                                    SCTP_DONOT_SETSCOPE, 
SCTP_ADDR_IS_CONFIRMED)) {
                                        *error = ENOBUFS;
                                        return (1);
@@ -3709,14 +3709,14 @@ sctp_process_cmsgs_for_init(struct sctp_
                                                *error = EINVAL;
                                                return (1);
                                        }
-                                       if (sctp_add_remote_addr(stcb, (struct 
sockaddr *)&sin, NULL,
+                                       if (sctp_add_remote_addr(stcb, (struct 
sockaddr *)&sin, NULL, stcb->asoc.port,
                                            SCTP_DONOT_SETSCOPE, 
SCTP_ADDR_IS_CONFIRMED)) {
                                                *error = ENOBUFS;
                                                return (1);
                                        }
                                } else
 #endif
-                                       if (sctp_add_remote_addr(stcb, (struct 
sockaddr *)&sin6, NULL,
+                                       if (sctp_add_remote_addr(stcb, (struct 
sockaddr *)&sin6, NULL, stcb->asoc.port,
                                    SCTP_DONOT_SETSCOPE, 
SCTP_ADDR_IS_CONFIRMED)) {
                                        *error = ENOBUFS;
                                        return (1);

Modified: head/sys/netinet/sctp_pcb.c
==============================================================================
--- head/sys/netinet/sctp_pcb.c Sat Apr 30 12:44:03 2016        (r298846)
+++ head/sys/netinet/sctp_pcb.c Sat Apr 30 14:25:00 2016        (r298847)
@@ -3766,7 +3766,7 @@ sctp_is_address_on_local_host(struct soc
  */
 int
 sctp_add_remote_addr(struct sctp_tcb *stcb, struct sockaddr *newaddr,
-    struct sctp_nets **netp, int set_scope, int from)
+    struct sctp_nets **netp, uint16_t port, int set_scope, int from)
 {
        /*
         * The following is redundant to the same lines in the
@@ -3944,7 +3944,7 @@ sctp_add_remote_addr(struct sctp_tcb *st
        stcb->asoc.numnets++;
        net->ref_count = 1;
        net->cwr_window_tsn = net->last_cwr_tsn = stcb->asoc.sending_seq - 1;
-       net->port = stcb->asoc.port;
+       net->port = port;
        net->dscp = stcb->asoc.default_dscp;
 #ifdef INET6
        net->flowlabel = stcb->asoc.default_flowlabel;
@@ -4384,7 +4384,7 @@ sctp_aloc_assoc(struct sctp_inpcb *inp, 
        LIST_INSERT_HEAD(head, stcb, sctp_asocs);
        SCTP_INP_INFO_WUNLOCK();
 
-       if ((err = sctp_add_remote_addr(stcb, firstaddr, NULL, 
SCTP_DO_SETSCOPE, SCTP_ALLOC_ASOC))) {
+       if ((err = sctp_add_remote_addr(stcb, firstaddr, NULL, asoc->port, 
SCTP_DO_SETSCOPE, SCTP_ALLOC_ASOC))) {
                /* failure.. memory error? */
                if (asoc->strmout) {
                        SCTP_FREE(asoc->strmout, SCTP_M_STRMO);
@@ -6159,7 +6159,7 @@ sctp_load_addresses_from_init(struct sct
 #ifdef INET
                case AF_INET:
                        if (stcb->asoc.scope.ipv4_addr_legal) {
-                               if (sctp_add_remote_addr(stcb, sa, NULL, 
SCTP_DONOT_SETSCOPE, SCTP_LOAD_ADDR_2)) {
+                               if (sctp_add_remote_addr(stcb, sa, NULL, 
stcb->asoc.port, SCTP_DONOT_SETSCOPE, SCTP_LOAD_ADDR_2)) {
                                        return (-1);
                                }
                        }
@@ -6168,7 +6168,7 @@ sctp_load_addresses_from_init(struct sct
 #ifdef INET6
                case AF_INET6:
                        if (stcb->asoc.scope.ipv6_addr_legal) {
-                               if (sctp_add_remote_addr(stcb, sa, NULL, 
SCTP_DONOT_SETSCOPE, SCTP_LOAD_ADDR_3)) {
+                               if (sctp_add_remote_addr(stcb, sa, NULL, 
stcb->asoc.port, SCTP_DONOT_SETSCOPE, SCTP_LOAD_ADDR_3)) {
                                        return (-2);
                                }
                        }
@@ -6253,7 +6253,7 @@ sctp_load_addresses_from_init(struct sct
                                                /* the assoc was freed? */
                                                return (-7);
                                        }
-                                       if (sctp_add_remote_addr(stcb, sa, 
NULL, SCTP_DONOT_SETSCOPE, SCTP_LOAD_ADDR_4)) {
+                                       if (sctp_add_remote_addr(stcb, sa, 
NULL, stcb->asoc.port, SCTP_DONOT_SETSCOPE, SCTP_LOAD_ADDR_4)) {
                                                return (-8);
                                        }
                                } else if (stcb_tmp == stcb) {
@@ -6348,7 +6348,7 @@ sctp_load_addresses_from_init(struct sct
                                         * we must add the address, no scope
                                         * set
                                         */
-                                       if (sctp_add_remote_addr(stcb, sa, 
NULL, SCTP_DONOT_SETSCOPE, SCTP_LOAD_ADDR_5)) {
+                                       if (sctp_add_remote_addr(stcb, sa, 
NULL, stcb->asoc.port, SCTP_DONOT_SETSCOPE, SCTP_LOAD_ADDR_5)) {
                                                return (-17);
                                        }
                                } else if (stcb_tmp == stcb) {

Modified: head/sys/netinet/sctp_pcb.h
==============================================================================
--- head/sys/netinet/sctp_pcb.h Sat Apr 30 12:44:03 2016        (r298846)
+++ head/sys/netinet/sctp_pcb.h Sat Apr 30 14:25:00 2016        (r298847)
@@ -601,7 +601,7 @@ void sctp_add_local_addr_ep(struct sctp_
 
 void sctp_del_local_addr_ep(struct sctp_inpcb *, struct sctp_ifa *);
 
-int sctp_add_remote_addr(struct sctp_tcb *, struct sockaddr *, struct 
sctp_nets **, int, int);
+int sctp_add_remote_addr(struct sctp_tcb *, struct sockaddr *, struct 
sctp_nets **, uint16_t, int, int);
 
 void sctp_remove_net(struct sctp_tcb *, struct sctp_nets *);
 

Modified: head/sys/netinet/sctputil.c
==============================================================================
--- head/sys/netinet/sctputil.c Sat Apr 30 12:44:03 2016        (r298846)
+++ head/sys/netinet/sctputil.c Sat Apr 30 14:25:00 2016        (r298847)
@@ -6277,7 +6277,9 @@ sctp_connectx_helper_add(struct sctp_tcb
                                *error = EINVAL;
                                goto out_now;
                        }
-                       if (sctp_add_remote_addr(stcb, sa, NULL, 
SCTP_DONOT_SETSCOPE, SCTP_ADDR_IS_CONFIRMED)) {
+                       if (sctp_add_remote_addr(stcb, sa, NULL, 
stcb->asoc.port,
+                           SCTP_DONOT_SETSCOPE,
+                           SCTP_ADDR_IS_CONFIRMED)) {
                                /* assoc gone no un-lock */
                                SCTP_LTRACE_ERR_RET(NULL, stcb, NULL, 
SCTP_FROM_SCTPUTIL, ENOBUFS);
                                (void)sctp_free_assoc(inp, stcb, 
SCTP_NORMAL_PROC,
@@ -6300,7 +6302,9 @@ sctp_connectx_helper_add(struct sctp_tcb
                                *error = EINVAL;
                                goto out_now;
                        }
-                       if (sctp_add_remote_addr(stcb, sa, NULL, 
SCTP_DONOT_SETSCOPE, SCTP_ADDR_IS_CONFIRMED)) {
+                       if (sctp_add_remote_addr(stcb, sa, NULL, 
stcb->asoc.port,
+                           SCTP_DONOT_SETSCOPE,
+                           SCTP_ADDR_IS_CONFIRMED)) {
                                /* assoc gone no un-lock */
                                SCTP_LTRACE_ERR_RET(NULL, stcb, NULL, 
SCTP_FROM_SCTPUTIL, ENOBUFS);
                                (void)sctp_free_assoc(inp, stcb, 
SCTP_NORMAL_PROC,
_______________________________________________
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