Skip to content

Commit 06242e4

Browse files
Paolo Abenidavem330
authored andcommitted
mptcp: add OoO related mibs
Add a bunch of MPTCP mibs related to MPTCP OoO data processing. Signed-off-by: Paolo Abeni <[email protected]> Reviewed-by: Mat Martineau <[email protected]> Signed-off-by: David S. Miller <[email protected]>
1 parent 04e4cd4 commit 06242e4

File tree

4 files changed

+34
-1
lines changed

4 files changed

+34
-1
lines changed

net/mptcp/mib.c

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -22,6 +22,11 @@ static const struct snmp_mib mptcp_snmp_list[] = {
2222
SNMP_MIB_ITEM("MPJoinAckHMacFailure", MPTCP_MIB_JOINACKMAC),
2323
SNMP_MIB_ITEM("DSSNotMatching", MPTCP_MIB_DSSNOMATCH),
2424
SNMP_MIB_ITEM("InfiniteMapRx", MPTCP_MIB_INFINITEMAPRX),
25+
SNMP_MIB_ITEM("OFOQueueTail", MPTCP_MIB_OFOQUEUETAIL),
26+
SNMP_MIB_ITEM("OFOQueue", MPTCP_MIB_OFOQUEUE),
27+
SNMP_MIB_ITEM("OFOMerge", MPTCP_MIB_OFOMERGE),
28+
SNMP_MIB_ITEM("NoDSSInWindow", MPTCP_MIB_NODSSWINDOW),
29+
SNMP_MIB_ITEM("DuplicateData", MPTCP_MIB_DUPDATA),
2530
SNMP_MIB_SENTINEL
2631
};
2732

net/mptcp/mib.h

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -15,6 +15,11 @@ enum linux_mptcp_mib_field {
1515
MPTCP_MIB_JOINACKMAC, /* HMAC was wrong on ACK + MP_JOIN */
1616
MPTCP_MIB_DSSNOMATCH, /* Received a new mapping that did not match the previous one */
1717
MPTCP_MIB_INFINITEMAPRX, /* Received an infinite mapping */
18+
MPTCP_MIB_OFOQUEUETAIL, /* Segments inserted into OoO queue tail */
19+
MPTCP_MIB_OFOQUEUE, /* Segments inserted into OoO queue */
20+
MPTCP_MIB_OFOMERGE, /* Segments merged in OoO queue */
21+
MPTCP_MIB_NODSSWINDOW, /* Segments not in MPTCP windows */
22+
MPTCP_MIB_DUPDATA, /* Segments discarded due to duplicate DSS */
1823
__MPTCP_MIB_MAX
1924
};
2025

net/mptcp/protocol.c

Lines changed: 23 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -128,6 +128,9 @@ static bool mptcp_try_coalesce(struct sock *sk, struct sk_buff *to,
128128
!skb_try_coalesce(to, from, &fragstolen, &delta))
129129
return false;
130130

131+
pr_debug("colesced seq %llx into %llx new len %d new end seq %llx",
132+
MPTCP_SKB_CB(from)->map_seq, MPTCP_SKB_CB(to)->map_seq,
133+
to->len, MPTCP_SKB_CB(from)->end_seq);
131134
MPTCP_SKB_CB(to)->end_seq = MPTCP_SKB_CB(from)->end_seq;
132135
kfree_skb_partial(from, fragstolen);
133136
atomic_add(delta, &sk->sk_rmem_alloc);
@@ -160,13 +163,17 @@ static void mptcp_data_queue_ofo(struct mptcp_sock *msk, struct sk_buff *skb)
160163
max_seq = tcp_space(sk);
161164
max_seq = max_seq > 0 ? max_seq + msk->ack_seq : msk->ack_seq;
162165

166+
pr_debug("msk=%p seq=%llx limit=%llx empty=%d", msk, seq, max_seq,
167+
RB_EMPTY_ROOT(&msk->out_of_order_queue));
163168
if (after64(seq, max_seq)) {
164169
/* out of window */
165170
mptcp_drop(sk, skb);
171+
MPTCP_INC_STATS(sock_net(sk), MPTCP_MIB_NODSSWINDOW);
166172
return;
167173
}
168174

169175
p = &msk->out_of_order_queue.rb_node;
176+
MPTCP_INC_STATS(sock_net(sk), MPTCP_MIB_OFOQUEUE);
170177
if (RB_EMPTY_ROOT(&msk->out_of_order_queue)) {
171178
rb_link_node(&skb->rbnode, NULL, p);
172179
rb_insert_color(&skb->rbnode, &msk->out_of_order_queue);
@@ -177,11 +184,15 @@ static void mptcp_data_queue_ofo(struct mptcp_sock *msk, struct sk_buff *skb)
177184
/* with 2 subflows, adding at end of ooo queue is quite likely
178185
* Use of ooo_last_skb avoids the O(Log(N)) rbtree lookup.
179186
*/
180-
if (mptcp_ooo_try_coalesce(msk, msk->ooo_last_skb, skb))
187+
if (mptcp_ooo_try_coalesce(msk, msk->ooo_last_skb, skb)) {
188+
MPTCP_INC_STATS(sock_net(sk), MPTCP_MIB_OFOMERGE);
189+
MPTCP_INC_STATS(sock_net(sk), MPTCP_MIB_OFOQUEUETAIL);
181190
return;
191+
}
182192

183193
/* Can avoid an rbtree lookup if we are adding skb after ooo_last_skb */
184194
if (!before64(seq, MPTCP_SKB_CB(msk->ooo_last_skb)->end_seq)) {
195+
MPTCP_INC_STATS(sock_net(sk), MPTCP_MIB_OFOQUEUETAIL);
185196
parent = &msk->ooo_last_skb->rbnode;
186197
p = &parent->rb_right;
187198
goto insert;
@@ -200,6 +211,7 @@ static void mptcp_data_queue_ofo(struct mptcp_sock *msk, struct sk_buff *skb)
200211
if (!after64(end_seq, MPTCP_SKB_CB(skb1)->end_seq)) {
201212
/* All the bits are present. Drop. */
202213
mptcp_drop(sk, skb);
214+
MPTCP_INC_STATS(sock_net(sk), MPTCP_MIB_DUPDATA);
203215
return;
204216
}
205217
if (after64(seq, MPTCP_SKB_CB(skb1)->map_seq)) {
@@ -215,13 +227,16 @@ static void mptcp_data_queue_ofo(struct mptcp_sock *msk, struct sk_buff *skb)
215227
rb_replace_node(&skb1->rbnode, &skb->rbnode,
216228
&msk->out_of_order_queue);
217229
mptcp_drop(sk, skb1);
230+
MPTCP_INC_STATS(sock_net(sk), MPTCP_MIB_DUPDATA);
218231
goto merge_right;
219232
}
220233
} else if (mptcp_ooo_try_coalesce(msk, skb1, skb)) {
234+
MPTCP_INC_STATS(sock_net(sk), MPTCP_MIB_OFOMERGE);
221235
return;
222236
}
223237
p = &parent->rb_right;
224238
}
239+
225240
insert:
226241
/* Insert segment into RB tree. */
227242
rb_link_node(&skb->rbnode, parent, p);
@@ -234,6 +249,7 @@ static void mptcp_data_queue_ofo(struct mptcp_sock *msk, struct sk_buff *skb)
234249
break;
235250
rb_erase(&skb1->rbnode, &msk->out_of_order_queue);
236251
mptcp_drop(sk, skb1);
252+
MPTCP_INC_STATS(sock_net(sk), MPTCP_MIB_DUPDATA);
237253
}
238254
/* If there is no skb after us, we are the last_skb ! */
239255
if (!skb1)
@@ -283,6 +299,7 @@ static bool __mptcp_move_skb(struct mptcp_sock *msk, struct sock *ssk,
283299
/* old data, keep it simple and drop the whole pkt, sender
284300
* will retransmit as needed, if needed.
285301
*/
302+
MPTCP_INC_STATS(sock_net(sk), MPTCP_MIB_DUPDATA);
286303
mptcp_drop(sk, skb);
287304
return false;
288305
}
@@ -511,6 +528,7 @@ static bool mptcp_ofo_queue(struct mptcp_sock *msk)
511528
u64 end_seq;
512529

513530
p = rb_first(&msk->out_of_order_queue);
531+
pr_debug("msk=%p empty=%d", msk, RB_EMPTY_ROOT(&msk->out_of_order_queue));
514532
while (p) {
515533
skb = rb_to_skb(p);
516534
if (after64(MPTCP_SKB_CB(skb)->map_seq, msk->ack_seq))
@@ -522,6 +540,7 @@ static bool mptcp_ofo_queue(struct mptcp_sock *msk)
522540
if (unlikely(!after64(MPTCP_SKB_CB(skb)->end_seq,
523541
msk->ack_seq))) {
524542
mptcp_drop(sk, skb);
543+
MPTCP_INC_STATS(sock_net(sk), MPTCP_MIB_DUPDATA);
525544
continue;
526545
}
527546

@@ -531,6 +550,9 @@ static bool mptcp_ofo_queue(struct mptcp_sock *msk)
531550
int delta = msk->ack_seq - MPTCP_SKB_CB(skb)->map_seq;
532551

533552
/* skip overlapping data, if any */
553+
pr_debug("uncoalesced seq=%llx ack seq=%llx delta=%d",
554+
MPTCP_SKB_CB(skb)->map_seq, msk->ack_seq,
555+
delta);
534556
MPTCP_SKB_CB(skb)->offset += delta;
535557
__skb_queue_tail(&sk->sk_receive_queue, skb);
536558
}

net/mptcp/subflow.c

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -816,6 +816,7 @@ static void mptcp_subflow_discard_data(struct sock *ssk, struct sk_buff *skb,
816816

817817
pr_debug("discarding=%d len=%d seq=%d", incr, skb->len,
818818
subflow->map_subflow_seq);
819+
MPTCP_INC_STATS(sock_net(ssk), MPTCP_MIB_DUPDATA);
819820
tcp_sk(ssk)->copied_seq += incr;
820821
if (!before(tcp_sk(ssk)->copied_seq, TCP_SKB_CB(skb)->end_seq))
821822
sk_eat_skb(ssk, skb);

0 commit comments

Comments
 (0)