!skb_try_coalesce(to, from, &fragstolen, &delta))
                return false;
 
+       pr_debug("colesced seq %llx into %llx new len %d new end seq %llx",
+                MPTCP_SKB_CB(from)->map_seq, MPTCP_SKB_CB(to)->map_seq,
+                to->len, MPTCP_SKB_CB(from)->end_seq);
        MPTCP_SKB_CB(to)->end_seq = MPTCP_SKB_CB(from)->end_seq;
        kfree_skb_partial(from, fragstolen);
        atomic_add(delta, &sk->sk_rmem_alloc);
        max_seq = tcp_space(sk);
        max_seq = max_seq > 0 ? max_seq + msk->ack_seq : msk->ack_seq;
 
+       pr_debug("msk=%p seq=%llx limit=%llx empty=%d", msk, seq, max_seq,
+                RB_EMPTY_ROOT(&msk->out_of_order_queue));
        if (after64(seq, max_seq)) {
                /* out of window */
                mptcp_drop(sk, skb);
+               MPTCP_INC_STATS(sock_net(sk), MPTCP_MIB_NODSSWINDOW);
                return;
        }
 
        p = &msk->out_of_order_queue.rb_node;
+       MPTCP_INC_STATS(sock_net(sk), MPTCP_MIB_OFOQUEUE);
        if (RB_EMPTY_ROOT(&msk->out_of_order_queue)) {
                rb_link_node(&skb->rbnode, NULL, p);
                rb_insert_color(&skb->rbnode, &msk->out_of_order_queue);
        /* with 2 subflows, adding at end of ooo queue is quite likely
         * Use of ooo_last_skb avoids the O(Log(N)) rbtree lookup.
         */
-       if (mptcp_ooo_try_coalesce(msk, msk->ooo_last_skb, skb))
+       if (mptcp_ooo_try_coalesce(msk, msk->ooo_last_skb, skb)) {
+               MPTCP_INC_STATS(sock_net(sk), MPTCP_MIB_OFOMERGE);
+               MPTCP_INC_STATS(sock_net(sk), MPTCP_MIB_OFOQUEUETAIL);
                return;
+       }
 
        /* Can avoid an rbtree lookup if we are adding skb after ooo_last_skb */
        if (!before64(seq, MPTCP_SKB_CB(msk->ooo_last_skb)->end_seq)) {
+               MPTCP_INC_STATS(sock_net(sk), MPTCP_MIB_OFOQUEUETAIL);
                parent = &msk->ooo_last_skb->rbnode;
                p = &parent->rb_right;
                goto insert;
                        if (!after64(end_seq, MPTCP_SKB_CB(skb1)->end_seq)) {
                                /* All the bits are present. Drop. */
                                mptcp_drop(sk, skb);
+                               MPTCP_INC_STATS(sock_net(sk), MPTCP_MIB_DUPDATA);
                                return;
                        }
                        if (after64(seq, MPTCP_SKB_CB(skb1)->map_seq)) {
                                rb_replace_node(&skb1->rbnode, &skb->rbnode,
                                                &msk->out_of_order_queue);
                                mptcp_drop(sk, skb1);
+                               MPTCP_INC_STATS(sock_net(sk), MPTCP_MIB_DUPDATA);
                                goto merge_right;
                        }
                } else if (mptcp_ooo_try_coalesce(msk, skb1, skb)) {
+                       MPTCP_INC_STATS(sock_net(sk), MPTCP_MIB_OFOMERGE);
                        return;
                }
                p = &parent->rb_right;
        }
+
 insert:
        /* Insert segment into RB tree. */
        rb_link_node(&skb->rbnode, parent, p);
                        break;
                rb_erase(&skb1->rbnode, &msk->out_of_order_queue);
                mptcp_drop(sk, skb1);
+               MPTCP_INC_STATS(sock_net(sk), MPTCP_MIB_DUPDATA);
        }
        /* If there is no skb after us, we are the last_skb ! */
        if (!skb1)
        /* old data, keep it simple and drop the whole pkt, sender
         * will retransmit as needed, if needed.
         */
+       MPTCP_INC_STATS(sock_net(sk), MPTCP_MIB_DUPDATA);
        mptcp_drop(sk, skb);
        return false;
 }
        u64 end_seq;
 
        p = rb_first(&msk->out_of_order_queue);
+       pr_debug("msk=%p empty=%d", msk, RB_EMPTY_ROOT(&msk->out_of_order_queue));
        while (p) {
                skb = rb_to_skb(p);
                if (after64(MPTCP_SKB_CB(skb)->map_seq, msk->ack_seq))
                if (unlikely(!after64(MPTCP_SKB_CB(skb)->end_seq,
                                      msk->ack_seq))) {
                        mptcp_drop(sk, skb);
+                       MPTCP_INC_STATS(sock_net(sk), MPTCP_MIB_DUPDATA);
                        continue;
                }
 
                        int delta = msk->ack_seq - MPTCP_SKB_CB(skb)->map_seq;
 
                        /* skip overlapping data, if any */
+                       pr_debug("uncoalesced seq=%llx ack seq=%llx delta=%d",
+                                MPTCP_SKB_CB(skb)->map_seq, msk->ack_seq,
+                                delta);
                        MPTCP_SKB_CB(skb)->offset += delta;
                        __skb_queue_tail(&sk->sk_receive_queue, skb);
                }