Skip to content
/ linux Public

Commit 19e384a

Browse files
gerd-rauschSasha Levin
authored andcommitted
net/rds: No shortcut out of RDS_CONN_ERROR
[ Upstream commit ad22d24 ] RDS connections carry a state "rds_conn_path::cp_state" and transitions from one state to another and are conditional upon an expected state: "rds_conn_path_transition." There is one exception to this conditionality, which is "RDS_CONN_ERROR" that can be enforced by "rds_conn_path_drop" regardless of what state the condition is currently in. But as soon as a connection enters state "RDS_CONN_ERROR", the connection handling code expects it to go through the shutdown-path. The RDS/TCP multipath changes added a shortcut out of "RDS_CONN_ERROR" straight back to "RDS_CONN_CONNECTING" via "rds_tcp_accept_one_path" (e.g. after "rds_tcp_state_change"). A subsequent "rds_tcp_reset_callbacks" can then transition the state to "RDS_CONN_RESETTING" with a shutdown-worker queued. That'll trip up "rds_conn_init_shutdown", which was never adjusted to handle "RDS_CONN_RESETTING" and subsequently drops the connection with the dreaded "DR_INV_CONN_STATE", which leaves "RDS_SHUTDOWN_WORK_QUEUED" on forever. So we do two things here: a) Don't shortcut "RDS_CONN_ERROR", but take the longer path through the shutdown code. b) Add "RDS_CONN_RESETTING" to the expected states in "rds_conn_init_shutdown" so that we won't error out and get stuck, if we ever hit weird state transitions like this again." Signed-off-by: Gerd Rausch <gerd.rausch@oracle.com> Signed-off-by: Allison Henderson <allison.henderson@oracle.com> Link: https://patch.msgid.link/20260122055213.83608-2-achender@kernel.org Signed-off-by: Jakub Kicinski <kuba@kernel.org> Signed-off-by: Sasha Levin <sashal@kernel.org>
1 parent 5468c8e commit 19e384a

File tree

2 files changed

+2
-5
lines changed

2 files changed

+2
-5
lines changed

net/rds/connection.c

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -381,6 +381,8 @@ void rds_conn_shutdown(struct rds_conn_path *cp)
381381
if (!rds_conn_path_transition(cp, RDS_CONN_UP,
382382
RDS_CONN_DISCONNECTING) &&
383383
!rds_conn_path_transition(cp, RDS_CONN_ERROR,
384+
RDS_CONN_DISCONNECTING) &&
385+
!rds_conn_path_transition(cp, RDS_CONN_RESETTING,
384386
RDS_CONN_DISCONNECTING)) {
385387
rds_conn_path_error(cp,
386388
"shutdown called in state %d\n",

net/rds/tcp_listen.c

Lines changed: 0 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -58,9 +58,6 @@ void rds_tcp_keepalive(struct socket *sock)
5858
* socket and force a reconneect from smaller -> larger ip addr. The reason
5959
* we special case cp_index 0 is to allow the rds probe ping itself to itself
6060
* get through efficiently.
61-
* Since reconnects are only initiated from the node with the numerically
62-
* smaller ip address, we recycle conns in RDS_CONN_ERROR on the passive side
63-
* by moving them to CONNECTING in this function.
6461
*/
6562
static
6663
struct rds_tcp_connection *rds_tcp_accept_one_path(struct rds_connection *conn)
@@ -85,8 +82,6 @@ struct rds_tcp_connection *rds_tcp_accept_one_path(struct rds_connection *conn)
8582
struct rds_conn_path *cp = &conn->c_path[i];
8683

8784
if (rds_conn_path_transition(cp, RDS_CONN_DOWN,
88-
RDS_CONN_CONNECTING) ||
89-
rds_conn_path_transition(cp, RDS_CONN_ERROR,
9085
RDS_CONN_CONNECTING)) {
9186
return cp->cp_transport_data;
9287
}

0 commit comments

Comments
 (0)