From: Marcelo Ricardo Leitner <marcelo.leitner@gmail.com>
To: Xin Long <lucien.xin@gmail.com>
Cc: network dev <netdev@vger.kernel.org>,
linux-sctp@vger.kernel.org, davem@davemloft.net,
Neil Horman <nhorman@tuxdriver.com>
Subject: Re: [PATCH net 4/5] sctp: avoid flushing unsent queue when doing asoc reset
Date: Mon, 27 Nov 2017 13:37:03 +0000 [thread overview]
Message-ID: <20171127133703.GK3473@localhost.localdomain> (raw)
In-Reply-To: <01a98a157b28c058568ccb7b9909e990e7ac7744.1511614961.git.lucien.xin@gmail.com>
On Sat, Nov 25, 2017 at 09:05:35PM +0800, Xin Long wrote:
> Now when doing asoc reset, it cleans up sacked and abandoned queues
> by calling sctp_outq_free where it also cleans up unsent, retransmit
> and transmitted queues.
>
> It's safe for the sender of response, as these 3 queues are empty at
> that time. But when the receiver of response is doing the reset, the
> users may already enqueue some chunks into unsent during the time
> waiting the response, and these chunks should not be flushed.
>
> To void the chunks in it would be removed, it moves the queue into a
> temp list, then gets it back after sctp_outq_free is done.
>
> The patch also fixes some incorrect comments in
> sctp_process_strreset_tsnreq.
>
> Signed-off-by: Xin Long <lucien.xin@gmail.com>
Acked-by: Marcelo Ricardo Leitner <marcelo.leitner@gmail.com>
> ---
> net/sctp/stream.c | 21 ++++++++++++++-------
> 1 file changed, 14 insertions(+), 7 deletions(-)
>
> diff --git a/net/sctp/stream.c b/net/sctp/stream.c
> index f3b7d27..9dd5bfe 100644
> --- a/net/sctp/stream.c
> +++ b/net/sctp/stream.c
> @@ -747,9 +747,10 @@ struct sctp_chunk *sctp_process_strreset_tsnreq(
> goto out;
> }
>
> - /* G3: The same processing as though a SACK chunk with no gap report
> - * and a cumulative TSN ACK of the Sender's Next TSN minus 1 were
> - * received MUST be performed.
> + /* G4: The same processing as though a FWD-TSN chunk (as defined in
> + * [RFC3758]) with all streams affected and a new cumulative TSN
> + * ACK of the Receiver's Next TSN minus 1 were received MUST be
> + * performed.
> */
> max_tsn_seen = sctp_tsnmap_get_max_tsn_seen(&asoc->peer.tsn_map);
> sctp_ulpq_reasm_flushtsn(&asoc->ulpq, max_tsn_seen);
> @@ -764,10 +765,9 @@ struct sctp_chunk *sctp_process_strreset_tsnreq(
> sctp_tsnmap_init(&asoc->peer.tsn_map, SCTP_TSN_MAP_INITIAL,
> init_tsn, GFP_ATOMIC);
>
> - /* G4: The same processing as though a FWD-TSN chunk (as defined in
> - * [RFC3758]) with all streams affected and a new cumulative TSN
> - * ACK of the Receiver's Next TSN minus 1 were received MUST be
> - * performed.
> + /* G3: The same processing as though a SACK chunk with no gap report
> + * and a cumulative TSN ACK of the Sender's Next TSN minus 1 were
> + * received MUST be performed.
> */
> sctp_outq_free(&asoc->outqueue);
>
> @@ -1021,6 +1021,7 @@ struct sctp_chunk *sctp_process_strreset_resp(
> if (result = SCTP_STRRESET_PERFORMED) {
> __u32 mtsn = sctp_tsnmap_get_max_tsn_seen(
> &asoc->peer.tsn_map);
> + LIST_HEAD(temp);
>
> sctp_ulpq_reasm_flushtsn(&asoc->ulpq, mtsn);
> sctp_ulpq_abort_pd(&asoc->ulpq, GFP_ATOMIC);
> @@ -1029,7 +1030,13 @@ struct sctp_chunk *sctp_process_strreset_resp(
> SCTP_TSN_MAP_INITIAL,
> stsn, GFP_ATOMIC);
>
> + /* Clean up sacked and abandoned queues only. As the
> + * out_chunk_list may not be empty, splice it to temp,
> + * then get it back after sctp_outq_free is done.
> + */
> + list_splice_init(&asoc->outqueue.out_chunk_list, &temp);
> sctp_outq_free(&asoc->outqueue);
> + list_splice_init(&temp, &asoc->outqueue.out_chunk_list);
>
> asoc->next_tsn = rtsn;
> asoc->ctsn_ack_point = asoc->next_tsn - 1;
> --
> 2.1.0
>
> --
> To unsubscribe from this list: send the line "unsubscribe linux-sctp" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at http://vger.kernel.org/majordomo-info.html
>
WARNING: multiple messages have this Message-ID (diff)
From: Marcelo Ricardo Leitner <marcelo.leitner@gmail.com>
To: Xin Long <lucien.xin@gmail.com>
Cc: network dev <netdev@vger.kernel.org>,
linux-sctp@vger.kernel.org, davem@davemloft.net,
Neil Horman <nhorman@tuxdriver.com>
Subject: Re: [PATCH net 4/5] sctp: avoid flushing unsent queue when doing asoc reset
Date: Mon, 27 Nov 2017 11:37:03 -0200 [thread overview]
Message-ID: <20171127133703.GK3473@localhost.localdomain> (raw)
In-Reply-To: <01a98a157b28c058568ccb7b9909e990e7ac7744.1511614961.git.lucien.xin@gmail.com>
On Sat, Nov 25, 2017 at 09:05:35PM +0800, Xin Long wrote:
> Now when doing asoc reset, it cleans up sacked and abandoned queues
> by calling sctp_outq_free where it also cleans up unsent, retransmit
> and transmitted queues.
>
> It's safe for the sender of response, as these 3 queues are empty at
> that time. But when the receiver of response is doing the reset, the
> users may already enqueue some chunks into unsent during the time
> waiting the response, and these chunks should not be flushed.
>
> To void the chunks in it would be removed, it moves the queue into a
> temp list, then gets it back after sctp_outq_free is done.
>
> The patch also fixes some incorrect comments in
> sctp_process_strreset_tsnreq.
>
> Signed-off-by: Xin Long <lucien.xin@gmail.com>
Acked-by: Marcelo Ricardo Leitner <marcelo.leitner@gmail.com>
> ---
> net/sctp/stream.c | 21 ++++++++++++++-------
> 1 file changed, 14 insertions(+), 7 deletions(-)
>
> diff --git a/net/sctp/stream.c b/net/sctp/stream.c
> index f3b7d27..9dd5bfe 100644
> --- a/net/sctp/stream.c
> +++ b/net/sctp/stream.c
> @@ -747,9 +747,10 @@ struct sctp_chunk *sctp_process_strreset_tsnreq(
> goto out;
> }
>
> - /* G3: The same processing as though a SACK chunk with no gap report
> - * and a cumulative TSN ACK of the Sender's Next TSN minus 1 were
> - * received MUST be performed.
> + /* G4: The same processing as though a FWD-TSN chunk (as defined in
> + * [RFC3758]) with all streams affected and a new cumulative TSN
> + * ACK of the Receiver's Next TSN minus 1 were received MUST be
> + * performed.
> */
> max_tsn_seen = sctp_tsnmap_get_max_tsn_seen(&asoc->peer.tsn_map);
> sctp_ulpq_reasm_flushtsn(&asoc->ulpq, max_tsn_seen);
> @@ -764,10 +765,9 @@ struct sctp_chunk *sctp_process_strreset_tsnreq(
> sctp_tsnmap_init(&asoc->peer.tsn_map, SCTP_TSN_MAP_INITIAL,
> init_tsn, GFP_ATOMIC);
>
> - /* G4: The same processing as though a FWD-TSN chunk (as defined in
> - * [RFC3758]) with all streams affected and a new cumulative TSN
> - * ACK of the Receiver's Next TSN minus 1 were received MUST be
> - * performed.
> + /* G3: The same processing as though a SACK chunk with no gap report
> + * and a cumulative TSN ACK of the Sender's Next TSN minus 1 were
> + * received MUST be performed.
> */
> sctp_outq_free(&asoc->outqueue);
>
> @@ -1021,6 +1021,7 @@ struct sctp_chunk *sctp_process_strreset_resp(
> if (result == SCTP_STRRESET_PERFORMED) {
> __u32 mtsn = sctp_tsnmap_get_max_tsn_seen(
> &asoc->peer.tsn_map);
> + LIST_HEAD(temp);
>
> sctp_ulpq_reasm_flushtsn(&asoc->ulpq, mtsn);
> sctp_ulpq_abort_pd(&asoc->ulpq, GFP_ATOMIC);
> @@ -1029,7 +1030,13 @@ struct sctp_chunk *sctp_process_strreset_resp(
> SCTP_TSN_MAP_INITIAL,
> stsn, GFP_ATOMIC);
>
> + /* Clean up sacked and abandoned queues only. As the
> + * out_chunk_list may not be empty, splice it to temp,
> + * then get it back after sctp_outq_free is done.
> + */
> + list_splice_init(&asoc->outqueue.out_chunk_list, &temp);
> sctp_outq_free(&asoc->outqueue);
> + list_splice_init(&temp, &asoc->outqueue.out_chunk_list);
>
> asoc->next_tsn = rtsn;
> asoc->ctsn_ack_point = asoc->next_tsn - 1;
> --
> 2.1.0
>
> --
> To unsubscribe from this list: send the line "unsubscribe linux-sctp" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at http://vger.kernel.org/majordomo-info.html
>
next prev parent reply other threads:[~2017-11-27 13:37 UTC|newest]
Thread overview: 29+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-11-25 13:05 [PATCH net 0/5] sctp: a bunch of fixes for stream reconfig Xin Long
2017-11-25 13:05 ` Xin Long
2017-11-25 13:05 ` [PATCH net 1/5] sctp: use sizeof(__u16) for each stream number length instead of magic number Xin Long
2017-11-25 13:05 ` Xin Long
2017-11-25 13:05 ` [PATCH net 2/5] sctp: only allow the out stream reset when the stream outq is empty Xin Long
2017-11-25 13:05 ` Xin Long
2017-11-25 13:05 ` [PATCH net 3/5] sctp: only allow the asoc reset when the asoc " Xin Long
2017-11-25 13:05 ` Xin Long
2017-11-25 13:05 ` [PATCH net 4/5] sctp: avoid flushing unsent queue when doing asoc reset Xin Long
2017-11-25 13:05 ` Xin Long
2017-11-25 13:05 ` [PATCH net 5/5] sctp: set sender next_tsn for the old result with ctsn_ack_point plus 1 Xin Long
2017-11-25 13:05 ` Xin Long
2017-11-27 13:37 ` Marcelo Ricardo Leitner
2017-11-27 13:37 ` Marcelo Ricardo Leitner
2017-11-27 13:37 ` Marcelo Ricardo Leitner [this message]
2017-11-27 13:37 ` [PATCH net 4/5] sctp: avoid flushing unsent queue when doing asoc reset Marcelo Ricardo Leitner
2017-11-27 10:06 ` [PATCH net 3/5] sctp: only allow the asoc reset when the asoc outq is empty David Laight
2017-11-27 10:58 ` Xin Long
2017-11-27 10:58 ` Xin Long
2017-11-27 13:36 ` Marcelo Ricardo Leitner
2017-11-27 13:36 ` Marcelo Ricardo Leitner
2017-11-27 13:36 ` [PATCH net 2/5] sctp: only allow the out stream reset when the stream " Marcelo Ricardo Leitner
2017-11-27 13:36 ` Marcelo Ricardo Leitner
2017-11-27 13:36 ` [PATCH net 1/5] sctp: use sizeof(__u16) for each stream number length instead of magic number Marcelo Ricardo Leitner
2017-11-27 13:36 ` Marcelo Ricardo Leitner
2017-11-27 13:56 ` [PATCH net 0/5] sctp: a bunch of fixes for stream reconfig Neil Horman
2017-11-27 13:56 ` Neil Horman
2017-11-27 15:43 ` David Miller
2017-11-27 15:43 ` David Miller
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20171127133703.GK3473@localhost.localdomain \
--to=marcelo.leitner@gmail.com \
--cc=davem@davemloft.net \
--cc=linux-sctp@vger.kernel.org \
--cc=lucien.xin@gmail.com \
--cc=netdev@vger.kernel.org \
--cc=nhorman@tuxdriver.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.