提交 569bc643 编写于 作者: U Ursula Braun 提交者: David S. Miller

net/smc: no tx work trigger for fallback sockets

If TCP_NODELAY is set or TCP_CORK is reset, setsockopt triggers the
tx worker. This does not make sense, if the SMC socket switched to
the TCP fallback when the connection is created. This patch adds
the additional check for the fallback case.
Signed-off-by: NUrsula Braun <ubraun@linux.ibm.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 7d6541fb
...@@ -1353,14 +1353,14 @@ static int smc_setsockopt(struct socket *sock, int level, int optname, ...@@ -1353,14 +1353,14 @@ static int smc_setsockopt(struct socket *sock, int level, int optname,
break; break;
case TCP_NODELAY: case TCP_NODELAY:
if (sk->sk_state != SMC_INIT && sk->sk_state != SMC_LISTEN) { if (sk->sk_state != SMC_INIT && sk->sk_state != SMC_LISTEN) {
if (val) if (val && !smc->use_fallback)
mod_delayed_work(system_wq, &smc->conn.tx_work, mod_delayed_work(system_wq, &smc->conn.tx_work,
0); 0);
} }
break; break;
case TCP_CORK: case TCP_CORK:
if (sk->sk_state != SMC_INIT && sk->sk_state != SMC_LISTEN) { if (sk->sk_state != SMC_INIT && sk->sk_state != SMC_LISTEN) {
if (!val) if (!val && !smc->use_fallback)
mod_delayed_work(system_wq, &smc->conn.tx_work, mod_delayed_work(system_wq, &smc->conn.tx_work,
0); 0);
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册