[SCTP]: Implement SCTP_ADDR_CONFIRMED state for ADDR_CHNAGE event
Signed-off-by: Vlad Yasevich <vladislav.yasevich@hp.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
d49d91d79a
commit
1ae4114dce
2 changed files with 10 additions and 1 deletions
|
@ -265,6 +265,7 @@ enum sctp_spc_state {
|
|||
SCTP_ADDR_REMOVED,
|
||||
SCTP_ADDR_ADDED,
|
||||
SCTP_ADDR_MADE_PRIM,
|
||||
SCTP_ADDR_CONFIRMED,
|
||||
};
|
||||
|
||||
|
||||
|
|
|
@ -714,8 +714,16 @@ void sctp_assoc_control_transport(struct sctp_association *asoc,
|
|||
/* Record the transition on the transport. */
|
||||
switch (command) {
|
||||
case SCTP_TRANSPORT_UP:
|
||||
transport->state = SCTP_ACTIVE;
|
||||
/* If we are moving from UNCONFIRMED state due
|
||||
* to heartbeat success, report the SCTP_ADDR_CONFIRMED
|
||||
* state to the user, otherwise report SCTP_ADDR_AVAILABLE.
|
||||
*/
|
||||
if (SCTP_UNCONFIRMED == transport->state &&
|
||||
SCTP_HEARTBEAT_SUCCESS == error)
|
||||
spc_state = SCTP_ADDR_CONFIRMED;
|
||||
else
|
||||
spc_state = SCTP_ADDR_AVAILABLE;
|
||||
transport->state = SCTP_ACTIVE;
|
||||
break;
|
||||
|
||||
case SCTP_TRANSPORT_DOWN:
|
||||
|
|
Loading…
Reference in a new issue