Lines Matching full:tsn
42 static int sctp_acked(struct sctp_sackhdr *sack, __u32 tsn);
153 static inline int sctp_cacc_skip_3_2(struct sctp_transport *primary, __u32 tsn) in sctp_cacc_skip_3_2() argument
156 TSN_lt(tsn, primary->cacc.next_tsn_at_change)) in sctp_cacc_skip_3_2()
163 * 3) If the missing report count for TSN t is to be
168 * TSN t SHOULD NOT be incremented.
178 __u32 tsn) in sctp_cacc_skip() argument
182 sctp_cacc_skip_3_2(primary, tsn))) in sctp_cacc_skip()
327 ntsn = ntohl(nchunk->subh.data_hdr->tsn); in sctp_insert_list()
331 ltsn = ntohl(lchunk->subh.data_hdr->tsn); in sctp_insert_list()
504 * 'TSN.Missing.Report' of all affected TSNs is set in sctp_retransmit_mark()
618 * E3) Determine how many of the earliest (i.e., lowest TSN) in __sctp_outq_flush_rtx()
968 /* PR-SCTP C5) If a FORWARD TSN is sent, the in sctp_outq_flush_ctrl()
1103 pr_debug("%s: outq:%p, chunk:%p[%s], tx-tsn:0x%x skb->head:%p skb->users:%d\n", in sctp_outq_flush_data()
1106 "illegal chunk", ntohl(chunk->subh.data_hdr->tsn), in sctp_outq_flush_data()
1117 pr_debug("%s: could not transmit tsn:0x%x, status:%d\n", in sctp_outq_flush_data()
1118 __func__, ntohl(chunk->subh.data_hdr->tsn), in sctp_outq_flush_data()
1208 * within a SCTP packet in increasing order of TSN. in sctp_outq_flush()
1256 __u32 sack_ctsn, ctsn, tsn; in sctp_outq_sack() local
1314 /* Get the highest TSN in the sack. */ in sctp_outq_sack()
1347 /* Move the Cumulative TSN Ack Point if appropriate. */ in sctp_outq_sack()
1372 tsn = ntohl(tchunk->subh.data_hdr->tsn); in sctp_outq_sack()
1373 if (TSN_lte(tsn, ctsn)) { in sctp_outq_sack()
1384 * Cumulative TSN Ack and the Gap Ack Blocks. in sctp_outq_sack()
1400 pr_debug("%s: sack cumulative tsn ack:0x%x\n", __func__, sack_ctsn); in sctp_outq_sack()
1401 pr_debug("%s: cumulative tsn ack of assoc:%p is 0x%x, " in sctp_outq_sack()
1423 * list and move chunks that are acked by the Cumulative TSN Ack to q->sacked.
1428 * Instead of printing 'sacked' or 'kept' for each TSN on the
1442 __u32 tsn; in sctp_check_transmitted() local
1476 tsn = ntohl(tchunk->subh.data_hdr->tsn); in sctp_check_transmitted()
1477 if (sctp_acked(sack, tsn)) { in sctp_check_transmitted()
1503 if (TSN_lte(tsn, sack_ctsn)) { in sctp_check_transmitted()
1511 * B) For each TSN t being acked that in sctp_check_transmitted()
1514 * the destination that the TSN was in sctp_check_transmitted()
1533 if (TSN_lt(*highest_new_tsn_in_sack, tsn)) in sctp_check_transmitted()
1534 *highest_new_tsn_in_sack = tsn; in sctp_check_transmitted()
1541 if (TSN_lte(tsn, sack_ctsn)) { in sctp_check_transmitted()
1546 * with the earliest outstanding TSN in sctp_check_transmitted()
1559 * 'Stray DATA chunk(s)' record the highest TSN in sctp_check_transmitted()
1568 * unacknowledged DATA chunks whose TSN is in sctp_check_transmitted()
1576 pr_debug("%s: receiver reneged on data TSN:0x%x\n", in sctp_check_transmitted()
1577 __func__, tsn); in sctp_check_transmitted()
1587 * TSN that was previously acknowledged via a in sctp_check_transmitted()
1612 /* 8.2. When an outstanding TSN is acknowledged, in sctp_check_transmitted()
1713 __u32 tsn; in sctp_mark_missing() local
1720 tsn = ntohl(chunk->subh.data_hdr->tsn); in sctp_mark_missing()
1723 * 'Unacknowledged TSN's', if the TSN number of an in sctp_mark_missing()
1724 * 'Unacknowledged TSN' is smaller than the 'HighestTSNinSack' in sctp_mark_missing()
1725 * value, increment the 'TSN.Missing.Report' count on that in sctp_mark_missing()
1731 TSN_lt(tsn, highest_new_tsn_in_sack)) { in sctp_mark_missing()
1738 count_of_newacks, tsn)) { in sctp_mark_missing()
1741 pr_debug("%s: tsn:0x%x missing counter:%d\n", in sctp_mark_missing()
1742 __func__, tsn, chunk->tsn_missing_report); in sctp_mark_missing()
1747 * 'TSN.Missing.Report' in sctp_mark_missing()
1769 /* Is the given TSN acked by this packet? */
1770 static int sctp_acked(struct sctp_sackhdr *sack, __u32 tsn) in sctp_acked() argument
1777 if (TSN_lte(tsn, ctsn)) in sctp_acked()
1786 * chunks with TSNs greater than or equal to (Cumulative TSN in sctp_acked()
1788 * (Cumulative TSN Ack + Gap Ack Block End) of each Gap Ack in sctp_acked()
1794 tsn_offset = tsn - ctsn; in sctp_acked()
1826 __u32 tsn; in sctp_generate_fwdtsn() local
1833 /* PR-SCTP C1) Let SackCumAck be the Cumulative TSN ACK carried in the in sctp_generate_fwdtsn()
1847 * Assuming that a SACK arrived with the Cumulative TSN ACK 102 in sctp_generate_fwdtsn()
1866 tsn = ntohl(chunk->subh.data_hdr->tsn); in sctp_generate_fwdtsn()
1871 if (TSN_lte(tsn, ctsn)) { in sctp_generate_fwdtsn()
1875 if (TSN_lte(tsn, asoc->adv_peer_ack_point+1)) { in sctp_generate_fwdtsn()
1876 asoc->adv_peer_ack_point = tsn; in sctp_generate_fwdtsn()
1897 * is greater than the Cumulative TSN ACK carried in the received in sctp_generate_fwdtsn()
1898 * SACK, the data sender MUST send the data receiver a FORWARD TSN in sctp_generate_fwdtsn()
1902 * C4) For each "abandoned" TSN the sender of the FORWARD TSN SHOULD in sctp_generate_fwdtsn()
1903 * list each stream and sequence number in the forwarded TSN. This in sctp_generate_fwdtsn()
1905 * stranded TSN's waiting on stream reorder queues. Each stream in sctp_generate_fwdtsn()
1909 * total size of the FORWARD TSN does NOT fit in a single MTU then in sctp_generate_fwdtsn()
1910 * the sender of the FORWARD TSN SHOULD lower the in sctp_generate_fwdtsn()
1911 * Advanced.Peer.Ack.Point to the last TSN that will fit in a in sctp_generate_fwdtsn()