aboutsummaryrefslogtreecommitdiffstats
path: root/net/sctp/ulpqueue.c
diff options
context:
space:
mode:
authorDavid Miller <davem@davemloft.net>2019-04-11 18:02:04 -0400
committerDavid S. Miller <davem@davemloft.net>2019-04-12 00:33:31 -0400
commit178ca044aa60cb05102148b635cb82f6986451a3 (patch)
treea8df6a4501ec1665a79bf59a15d54154285b385f /net/sctp/ulpqueue.c
parent5e8f641db673cb6ef84b2151e473300f24c9f5a0 (diff)
sctp: Make sctp_enqueue_event tak an skb list.
Pass this, instead of an event. Then everything trickles down and we always have events a non-empty list. Then we needs a list creating stub to place into .enqueue_event for sctp_stream_interleave_1. Signed-off-by: David S. Miller <davem@davemloft.net> Acked-by: Marcelo Ricardo Leitner <marcelo.leitner@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/sctp/ulpqueue.c')
-rw-r--r--net/sctp/ulpqueue.c5
1 files changed, 3 insertions, 2 deletions
diff --git a/net/sctp/ulpqueue.c b/net/sctp/ulpqueue.c
index b22f558adc49..a698f1a509bf 100644
--- a/net/sctp/ulpqueue.c
+++ b/net/sctp/ulpqueue.c
@@ -116,12 +116,13 @@ int sctp_ulpq_tail_data(struct sctp_ulpq *ulpq, struct sctp_chunk *chunk,
116 event = sctp_ulpq_reasm(ulpq, event); 116 event = sctp_ulpq_reasm(ulpq, event);
117 117
118 /* Do ordering if needed. */ 118 /* Do ordering if needed. */
119 if ((event) && (event->msg_flags & MSG_EOR)) { 119 if (event) {
120 /* Create a temporary list to collect chunks on. */ 120 /* Create a temporary list to collect chunks on. */
121 skb_queue_head_init(&temp); 121 skb_queue_head_init(&temp);
122 __skb_queue_tail(&temp, sctp_event2skb(event)); 122 __skb_queue_tail(&temp, sctp_event2skb(event));
123 123
124 event = sctp_ulpq_order(ulpq, event); 124 if (event->msg_flags & MSG_EOR)
125 event = sctp_ulpq_order(ulpq, event);
125 } 126 }
126 127
127 /* Send event to the ULP. 'event' is the sctp_ulpevent for 128 /* Send event to the ULP. 'event' is the sctp_ulpevent for