summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorHåkon Bugge <haakon.bugge@oracle.com>2026-02-03 08:57:20 +0300
committerJakub Kicinski <kuba@kernel.org>2026-02-05 07:46:38 +0300
commitb89fc7c2523b2b0750d91840f4e52521270d70ed (patch)
tree924c6ba03c0ea0f5b3df8316b2282b2284d77b21
parentaa0cd656f03209733d941f0d27b4e68db4443a07 (diff)
downloadlinux-b89fc7c2523b2b0750d91840f4e52521270d70ed.tar.xz
net/rds: Clear reconnect pending bit
When canceling the reconnect worker, care must be taken to reset the reconnect-pending bit. If the reconnect worker has not yet been scheduled before it is canceled, the reconnect-pending bit will stay on forever. Signed-off-by: Håkon Bugge <haakon.bugge@oracle.com> Signed-off-by: Allison Henderson <allison.henderson@oracle.com> Link: https://patch.msgid.link/20260203055723.1085751-6-achender@kernel.org Signed-off-by: Jakub Kicinski <kuba@kernel.org>
-rw-r--r--net/rds/connection.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/net/rds/connection.c b/net/rds/connection.c
index 3f26a67f3180..4b7715eb2111 100644
--- a/net/rds/connection.c
+++ b/net/rds/connection.c
@@ -442,6 +442,8 @@ void rds_conn_shutdown(struct rds_conn_path *cp)
* to the conn hash, so we never trigger a reconnect on this
* conn - the reconnect is always triggered by the active peer. */
cancel_delayed_work_sync(&cp->cp_conn_w);
+
+ clear_bit(RDS_RECONNECT_PENDING, &cp->cp_flags);
rcu_read_lock();
if (!hlist_unhashed(&conn->c_hash_node)) {
rcu_read_unlock();