mirror of
https://github.com/followmsi/android_kernel_google_msm.git
synced 2024-11-06 23:17:41 +00:00
libceph: don't touch con state in con_close_socket()
(cherry picked from commit 456ea46865
)
In con_close_socket(), a connection's SOCK_CLOSED flag gets set and
then cleared while its shutdown method is called and its reference
gets dropped.
Previously, that flag got set only if it had not already been set,
so setting it in con_close_socket() might have prevented additional
processing being done on a socket being shut down. We no longer set
SOCK_CLOSED in the socket event routine conditionally, so setting
that bit here no longer provides whatever benefit it might have
provided before.
A race condition could still leave the SOCK_CLOSED bit set even
after we've issued the call to con_close_socket(), so we still clear
that bit after shutting the socket down. Add a comment explaining
the reason for this.
Signed-off-by: Alex Elder <elder@inktank.com>
Reviewed-by: Sage Weil <sage@inktank.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
70b06043cd
commit
8a62c3339d
1 changed files with 7 additions and 1 deletions
|
@ -392,10 +392,16 @@ static int con_close_socket(struct ceph_connection *con)
|
||||||
dout("con_close_socket on %p sock %p\n", con, con->sock);
|
dout("con_close_socket on %p sock %p\n", con, con->sock);
|
||||||
if (!con->sock)
|
if (!con->sock)
|
||||||
return 0;
|
return 0;
|
||||||
set_bit(SOCK_CLOSED, &con->flags);
|
|
||||||
rc = con->sock->ops->shutdown(con->sock, SHUT_RDWR);
|
rc = con->sock->ops->shutdown(con->sock, SHUT_RDWR);
|
||||||
sock_release(con->sock);
|
sock_release(con->sock);
|
||||||
con->sock = NULL;
|
con->sock = NULL;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Forcibly clear the SOCK_CLOSE flag. It gets set
|
||||||
|
* independent of the connection mutex, and we could have
|
||||||
|
* received a socket close event before we had the chance to
|
||||||
|
* shut the socket down.
|
||||||
|
*/
|
||||||
clear_bit(SOCK_CLOSED, &con->flags);
|
clear_bit(SOCK_CLOSED, &con->flags);
|
||||||
con_sock_state_closed(con);
|
con_sock_state_closed(con);
|
||||||
return rc;
|
return rc;
|
||||||
|
|
Loading…
Reference in a new issue