From: Sowmini Varadhan Date: Fri, 4 Nov 2016 17:04:12 +0000 (-0700) Subject: RDS: TCP: start multipath acceptor loop at 0 X-Git-Url: http://git.cdn.openwrt.org/?a=commitdiff_plain;h=117d15bbfde643b5bd0a173fddaa0e6c65f14d47;p=openwrt%2Fstaging%2Fblogic.git RDS: TCP: start multipath acceptor loop at 0 The for() loop in rds_tcp_accept_one() assumes that the 0'th rds_tcp_conn_path is UP and starts multipath accepts at index 1. But this assumption may not always be true: if the 0'th path has failed (ERROR or DOWN state) an incoming connection request should be used to resurrect this path. Signed-off-by: Sowmini Varadhan Acked-by: Santosh Shilimkar Signed-off-by: David S. Miller --- diff --git a/net/rds/tcp_listen.c b/net/rds/tcp_listen.c index e0b23fb5b8d5..c9c496844cd7 100644 --- a/net/rds/tcp_listen.c +++ b/net/rds/tcp_listen.c @@ -103,7 +103,7 @@ struct rds_tcp_connection *rds_tcp_accept_one_path(struct rds_connection *conn) if (!peer_is_smaller) return NULL; - for (i = 1; i < npaths; i++) { + for (i = 0; i < npaths; i++) { struct rds_conn_path *cp = &conn->c_path[i]; if (rds_conn_path_transition(cp, RDS_CONN_DOWN,