__mptcp_check_send_data_fin(sk);
 }
 
-static void __mptcp_subflow_push_pending(struct sock *sk, struct sock *ssk)
+static void __mptcp_subflow_push_pending(struct sock *sk, struct sock *ssk, bool first)
 {
        struct mptcp_sock *msk = mptcp_sk(sk);
        struct mptcp_sendmsg_info info = {
        struct mptcp_data_frag *dfrag;
        struct sock *xmit_ssk;
        int len, copied = 0;
-       bool first = true;
 
        info.flags = 0;
        while ((dfrag = mptcp_send_head(sk))) {
                while (len > 0) {
                        int ret = 0;
 
-                       /* the caller already invoked the packet scheduler,
-                        * check for a different subflow usage only after
+                       /* check for a different subflow usage only after
                         * spooling the first chunk of data
                         */
                        xmit_ssk = first ? ssk : mptcp_subflow_get_send(msk);
        if (!mptcp_send_head(sk))
                return;
 
-       if (!sock_owned_by_user(sk)) {
-               struct sock *xmit_ssk = mptcp_subflow_get_send(mptcp_sk(sk));
-
-               if (xmit_ssk == ssk)
-                       __mptcp_subflow_push_pending(sk, ssk);
-               else if (xmit_ssk)
-                       mptcp_subflow_delegate(mptcp_subflow_ctx(xmit_ssk), MPTCP_DELEGATE_SEND);
-       } else {
+       if (!sock_owned_by_user(sk))
+               __mptcp_subflow_push_pending(sk, ssk, false);
+       else
                __set_bit(MPTCP_PUSH_PENDING, &mptcp_sk(sk)->cb_flags);
-       }
 }
 
 #define MPTCP_FLAGS_PROCESS_CTX_NEED (BIT(MPTCP_PUSH_PENDING) | \
        if (test_bit(MPTCP_DELEGATE_SEND, &subflow->delegated_status)) {
                mptcp_data_lock(sk);
                if (!sock_owned_by_user(sk))
-                       __mptcp_subflow_push_pending(sk, ssk);
+                       __mptcp_subflow_push_pending(sk, ssk, true);
                else
                        __set_bit(MPTCP_PUSH_PENDING, &mptcp_sk(sk)->cb_flags);
                mptcp_data_unlock(sk);