sctp: process duplicated strreset asoc request correctly
This patch is to fix the replay attack issue for strreset asoc requests. When a duplicated strreset asoc request is received, reply it with bad seqno if it's seqno < asoc->strreset_inseq - 2, and reply it with the result saved in asoc if it's seqno >= asoc->strreset_inseq - 2. But note that if the result saved in asoc is performed, the sender's next tsn and receiver's next tsn for the response chunk should be set. It's safe to get them from asoc. Because if it's changed, which means the peer has received the response already, the new response with wrong tsn won't be accepted by peer. Signed-off-by: Xin Long <lucien.xin@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
d0f025e611
commit
6c80138773
@ -529,12 +529,21 @@ struct sctp_chunk *sctp_process_strreset_tsnreq(
|
|||||||
__u16 i;
|
__u16 i;
|
||||||
|
|
||||||
request_seq = ntohl(tsnreq->request_seq);
|
request_seq = ntohl(tsnreq->request_seq);
|
||||||
if (request_seq > asoc->strreset_inseq) {
|
if (TSN_lt(asoc->strreset_inseq, request_seq) ||
|
||||||
|
TSN_lt(request_seq, asoc->strreset_inseq - 2)) {
|
||||||
result = SCTP_STRRESET_ERR_BAD_SEQNO;
|
result = SCTP_STRRESET_ERR_BAD_SEQNO;
|
||||||
goto out;
|
goto err;
|
||||||
} else if (request_seq == asoc->strreset_inseq) {
|
} else if (TSN_lt(request_seq, asoc->strreset_inseq)) {
|
||||||
asoc->strreset_inseq++;
|
i = asoc->strreset_inseq - request_seq - 1;
|
||||||
|
result = asoc->strreset_result[i];
|
||||||
|
if (result == SCTP_STRRESET_PERFORMED) {
|
||||||
|
next_tsn = asoc->next_tsn;
|
||||||
|
init_tsn =
|
||||||
|
sctp_tsnmap_get_ctsn(&asoc->peer.tsn_map) + 1;
|
||||||
|
}
|
||||||
|
goto err;
|
||||||
}
|
}
|
||||||
|
asoc->strreset_inseq++;
|
||||||
|
|
||||||
if (!(asoc->strreset_enable & SCTP_ENABLE_RESET_ASSOC_REQ))
|
if (!(asoc->strreset_enable & SCTP_ENABLE_RESET_ASSOC_REQ))
|
||||||
goto out;
|
goto out;
|
||||||
@ -591,6 +600,8 @@ struct sctp_chunk *sctp_process_strreset_tsnreq(
|
|||||||
next_tsn, GFP_ATOMIC);
|
next_tsn, GFP_ATOMIC);
|
||||||
|
|
||||||
out:
|
out:
|
||||||
|
sctp_update_strreset_result(asoc, result);
|
||||||
|
err:
|
||||||
return sctp_make_strreset_tsnresp(asoc, result, request_seq,
|
return sctp_make_strreset_tsnresp(asoc, result, request_seq,
|
||||||
next_tsn, init_tsn);
|
next_tsn, init_tsn);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user