Skip to content

Commit

Permalink
Revert "mptcp: drop 'first' in __mptcp_subflow_push_pending"
Browse files Browse the repository at this point in the history
This reverts commit 9d5b4f8.
  • Loading branch information
Geliang Tang committed Apr 21, 2024
1 parent 8195553 commit 6b13332
Showing 1 changed file with 16 additions and 3 deletions.
19 changes: 16 additions & 3 deletions net/mptcp/protocol.c
Original file line number Diff line number Diff line change
Expand Up @@ -1642,7 +1642,7 @@ void __mptcp_push_pending(struct sock *sk, unsigned int flags)
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 = {
Expand All @@ -1657,6 +1657,19 @@ static void __mptcp_subflow_push_pending(struct sock *sk, struct sock *ssk)
struct mptcp_subflow_context *subflow = mptcp_subflow_ctx(ssk);
int ret = 0;

/* check for a different subflow usage only after
* spooling the first chunk of data
*/
if (first) {
mptcp_subflow_set_scheduled(subflow, false);
ret = __subflow_push_pending(sk, ssk, &info);
first = false;
if (ret <= 0)
break;
copied += ret;
continue;
}

if (mptcp_sched_get_send(msk))
goto out;

Expand Down Expand Up @@ -3404,7 +3417,7 @@ void __mptcp_check_push(struct sock *sk, struct sock *ssk)
return;

if (!sock_owned_by_user(sk))
__mptcp_subflow_push_pending(sk, ssk);
__mptcp_subflow_push_pending(sk, ssk, false);
else
__set_bit(MPTCP_PUSH_PENDING, &mptcp_sk(sk)->cb_flags);
}
Expand Down Expand Up @@ -3502,7 +3515,7 @@ void mptcp_subflow_process_delegated(struct sock *ssk, long status)
if (status & BIT(MPTCP_DELEGATE_SEND)) {
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);
Expand Down

0 comments on commit 6b13332

Please sign in to comment.