aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--net/sctp/sm_statefuns.c16
1 files changed, 15 insertions, 1 deletions
diff --git a/net/sctp/sm_statefuns.c b/net/sctp/sm_statefuns.c
index 910926906a3a..73bdeb2b6c62 100644
--- a/net/sctp/sm_statefuns.c
+++ b/net/sctp/sm_statefuns.c
@@ -2570,6 +2570,12 @@ sctp_disposition_t sctp_sf_do_9_2_shutdown(const struct sctp_endpoint *ep,
2570 chunk->subh.shutdown_hdr = sdh; 2570 chunk->subh.shutdown_hdr = sdh;
2571 ctsn = ntohl(sdh->cum_tsn_ack); 2571 ctsn = ntohl(sdh->cum_tsn_ack);
2572 2572
2573 if (TSN_lt(ctsn, asoc->ctsn_ack_point)) {
2574 SCTP_DEBUG_PRINTK("ctsn %x\n", ctsn);
2575 SCTP_DEBUG_PRINTK("ctsn_ack_point %x\n", asoc->ctsn_ack_point);
2576 return SCTP_DISPOSITION_DISCARD;
2577 }
2578
2573 /* If Cumulative TSN Ack beyond the max tsn currently 2579 /* If Cumulative TSN Ack beyond the max tsn currently
2574 * send, terminating the association and respond to the 2580 * send, terminating the association and respond to the
2575 * sender with an ABORT. 2581 * sender with an ABORT.
@@ -2633,6 +2639,7 @@ sctp_disposition_t sctp_sf_do_9_2_shut_ctsn(const struct sctp_endpoint *ep,
2633{ 2639{
2634 struct sctp_chunk *chunk = arg; 2640 struct sctp_chunk *chunk = arg;
2635 sctp_shutdownhdr_t *sdh; 2641 sctp_shutdownhdr_t *sdh;
2642 __u32 ctsn;
2636 2643
2637 if (!sctp_vtag_verify(chunk, asoc)) 2644 if (!sctp_vtag_verify(chunk, asoc))
2638 return sctp_sf_pdiscard(ep, asoc, type, arg, commands); 2645 return sctp_sf_pdiscard(ep, asoc, type, arg, commands);
@@ -2644,12 +2651,19 @@ sctp_disposition_t sctp_sf_do_9_2_shut_ctsn(const struct sctp_endpoint *ep,
2644 commands); 2651 commands);
2645 2652
2646 sdh = (sctp_shutdownhdr_t *)chunk->skb->data; 2653 sdh = (sctp_shutdownhdr_t *)chunk->skb->data;
2654 ctsn = ntohl(sdh->cum_tsn_ack);
2655
2656 if (TSN_lt(ctsn, asoc->ctsn_ack_point)) {
2657 SCTP_DEBUG_PRINTK("ctsn %x\n", ctsn);
2658 SCTP_DEBUG_PRINTK("ctsn_ack_point %x\n", asoc->ctsn_ack_point);
2659 return SCTP_DISPOSITION_DISCARD;
2660 }
2647 2661
2648 /* If Cumulative TSN Ack beyond the max tsn currently 2662 /* If Cumulative TSN Ack beyond the max tsn currently
2649 * send, terminating the association and respond to the 2663 * send, terminating the association and respond to the
2650 * sender with an ABORT. 2664 * sender with an ABORT.
2651 */ 2665 */
2652 if (!TSN_lt(ntohl(sdh->cum_tsn_ack), asoc->next_tsn)) 2666 if (!TSN_lt(ctsn, asoc->next_tsn))
2653 return sctp_sf_violation_ctsn(ep, asoc, type, arg, commands); 2667 return sctp_sf_violation_ctsn(ep, asoc, type, arg, commands);
2654 2668
2655 /* verify, by checking the Cumulative TSN Ack field of the 2669 /* verify, by checking the Cumulative TSN Ack field of the