Commit e0e9db17 authored by Vlad Yasevich's avatar Vlad Yasevich

sctp: Select a working primary during sctp_connectx()

When sctp_connectx() is used, we pick the first address as
primary, even though it may not have worked.  This results
in excessive retransmits and poor performance.  We should
select the address that the association was established with.
Reported-by: default avatarThomas Dreibholz <dreibh@iem.uni-due.de>
Signed-off-by: default avatarVlad Yasevich <vladislav.yasevich@hp.com>
parent 6383cfb3
...@@ -512,7 +512,13 @@ void sctp_assoc_set_primary(struct sctp_association *asoc, ...@@ -512,7 +512,13 @@ void sctp_assoc_set_primary(struct sctp_association *asoc,
* to this destination address earlier. The sender MUST set * to this destination address earlier. The sender MUST set
* CYCLING_CHANGEOVER to indicate that this switch is a * CYCLING_CHANGEOVER to indicate that this switch is a
* double switch to the same destination address. * double switch to the same destination address.
*
* Really, only bother is we have data queued or outstanding on
* the association.
*/ */
if (!asoc->outqueue.outstanding_bytes && !asoc->outqueue.out_qlen)
return;
if (transport->cacc.changeover_active) if (transport->cacc.changeover_active)
transport->cacc.cycling_changeover = changeover; transport->cacc.cycling_changeover = changeover;
......
...@@ -1418,6 +1418,8 @@ static int sctp_cmd_interpreter(sctp_event_t event_type, ...@@ -1418,6 +1418,8 @@ static int sctp_cmd_interpreter(sctp_event_t event_type,
asoc->init_last_sent_to = t; asoc->init_last_sent_to = t;
chunk->transport = t; chunk->transport = t;
t->init_sent_count++; t->init_sent_count++;
/* Set the new transport as primary */
sctp_assoc_set_primary(asoc, t);
break; break;
case SCTP_CMD_INIT_RESTART: case SCTP_CMD_INIT_RESTART:
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment