Commit c3d88dfd authored by Alexander Aring's avatar Alexander Aring Committed by David Teigland

fs: dlm: cleanup listen sock handling

This patch removes save_listen_callbacks() and add_listen_sock() as they
are only used once in lowcomms functionality. For shutdown lowcomms it's
not necessary to whole flush the workqueues to synchronize with
restoring the old sk_data_ready() callback. Only the listen con receive
work need to be cancelled. For each individual node shutdown we should be
sure that last ack was been transmitted which is done by flushing per
connection swork worker.
Signed-off-by: default avatarAlexander Aring <aahringo@redhat.com>
Signed-off-by: default avatarDavid Teigland <teigland@redhat.com>
parent 4f567acb
...@@ -647,17 +647,6 @@ static void lowcomms_error_report(struct sock *sk) ...@@ -647,17 +647,6 @@ static void lowcomms_error_report(struct sock *sk)
orig_report(sk); orig_report(sk);
} }
/* Note: sk_callback_lock must be locked before calling this function. */
static void save_listen_callbacks(struct socket *sock)
{
struct sock *sk = sock->sk;
listen_sock.sk_data_ready = sk->sk_data_ready;
listen_sock.sk_state_change = sk->sk_state_change;
listen_sock.sk_write_space = sk->sk_write_space;
listen_sock.sk_error_report = sk->sk_error_report;
}
static void restore_callbacks(struct socket *sock) static void restore_callbacks(struct socket *sock)
{ {
struct sock *sk = sock->sk; struct sock *sk = sock->sk;
...@@ -671,21 +660,6 @@ static void restore_callbacks(struct socket *sock) ...@@ -671,21 +660,6 @@ static void restore_callbacks(struct socket *sock)
release_sock(sk); release_sock(sk);
} }
static void add_listen_sock(struct socket *sock, struct listen_connection *con)
{
struct sock *sk = sock->sk;
lock_sock(sk);
save_listen_callbacks(sock);
con->sock = sock;
sk->sk_user_data = con;
sk->sk_allocation = GFP_NOFS;
/* Install a data_ready callback */
sk->sk_data_ready = lowcomms_listen_data_ready;
release_sock(sk);
}
/* Make a socket active */ /* Make a socket active */
static void add_sock(struct socket *sock, struct connection *con) static void add_sock(struct socket *sock, struct connection *con)
{ {
...@@ -1593,13 +1567,12 @@ static int work_start(void) ...@@ -1593,13 +1567,12 @@ static int work_start(void)
void dlm_lowcomms_shutdown(void) void dlm_lowcomms_shutdown(void)
{ {
restore_callbacks(listen_con.sock); /* stop lowcomms_listen_data_ready calls */
lock_sock(listen_con.sock->sk);
if (recv_workqueue) listen_con.sock->sk->sk_data_ready = listen_sock.sk_data_ready;
flush_workqueue(recv_workqueue); release_sock(listen_con.sock->sk);
if (send_workqueue)
flush_workqueue(send_workqueue);
cancel_work_sync(&listen_con.rwork);
dlm_close_sock(&listen_con.sock); dlm_close_sock(&listen_con.sock);
} }
...@@ -1615,6 +1588,7 @@ void dlm_lowcomms_shutdown_node(int nodeid, bool force) ...@@ -1615,6 +1588,7 @@ void dlm_lowcomms_shutdown_node(int nodeid, bool force)
return; return;
} }
flush_work(&con->swork);
WARN_ON_ONCE(!force && !list_empty(&con->writequeue)); WARN_ON_ONCE(!force && !list_empty(&con->writequeue));
clean_one_writequeue(con); clean_one_writequeue(con);
if (con->othercon) if (con->othercon)
...@@ -1736,8 +1710,17 @@ static int dlm_listen_for_all(void) ...@@ -1736,8 +1710,17 @@ static int dlm_listen_for_all(void)
if (result < 0) if (result < 0)
goto out; goto out;
save_listen_callbacks(sock); lock_sock(sock->sk);
add_listen_sock(sock, &listen_con); listen_sock.sk_data_ready = sock->sk->sk_data_ready;
listen_sock.sk_write_space = sock->sk->sk_write_space;
listen_sock.sk_error_report = sock->sk->sk_error_report;
listen_sock.sk_state_change = sock->sk->sk_state_change;
listen_con.sock = sock;
sock->sk->sk_allocation = GFP_NOFS;
sock->sk->sk_data_ready = lowcomms_listen_data_ready;
release_sock(sock->sk);
result = sock->ops->listen(sock, 5); result = sock->ops->listen(sock, 5);
if (result < 0) { if (result < 0) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment