Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 89a86be0 authored by Sage Weil's avatar Sage Weil
Browse files

libceph: transition socket state prior to actual connect



Once we call ->connect(), we are racing against the actual
connection, and a subsequent transition from CONNECTING ->
CONNECTED.  Set the state to CONNECTING before that, under the
protection of the mutex, to avoid the race.

This was introduced in 928443cd,
with the original socket state code.

Signed-off-by: default avatarSage Weil <sage@inktank.com>
Reviewed-by: default avatarAlex Elder <elder@inktank.com>
parent a5506049
Loading
Loading
Loading
Loading
+1 −2
Original line number Diff line number Diff line
@@ -321,6 +321,7 @@ static int ceph_tcp_connect(struct ceph_connection *con)

	dout("connect %s\n", ceph_pr_addr(&con->peer_addr.in_addr));

	con_sock_state_connecting(con);
	ret = sock->ops->connect(sock, (struct sockaddr *)paddr, sizeof(*paddr),
				 O_NONBLOCK);
	if (ret == -EINPROGRESS) {
@@ -336,8 +337,6 @@ static int ceph_tcp_connect(struct ceph_connection *con)
		return ret;
	}
	con->sock = sock;
	con_sock_state_connecting(con);

	return 0;
}