sctp: Failover transmitted list on transport delete
Add-IP feature allows users to delete an active transport. If that transport has chunks in flight, those chunks need to be moved to another transport or association may get into unrecoverable state. Reported-by: Rafael Laufer <rlaufer@cisco.com> Signed-off-by: Vlad Yasevich <vladislav.yasevich@hp.com>
This commit is contained in:
@@ -3543,6 +3543,12 @@ sctp_disposition_t sctp_sf_do_asconf(const struct sctp_endpoint *ep,
|
||||
asconf_ack = sctp_assoc_lookup_asconf_ack(asoc, hdr->serial);
|
||||
if (!asconf_ack)
|
||||
return SCTP_DISPOSITION_DISCARD;
|
||||
|
||||
/* Reset the transport so that we select the correct one
|
||||
* this time around. This is to make sure that we don't
|
||||
* accidentally use a stale transport that's been removed.
|
||||
*/
|
||||
asconf_ack->transport = NULL;
|
||||
} else {
|
||||
/* ADDIP 5.2 E5) Otherwise, the ASCONF Chunk is discarded since
|
||||
* it must be either a stale packet or from an attacker.
|
||||
|
Reference in New Issue
Block a user