RDS: TCP: rds_tcp_accept_worker() must exit gracefully when terminating rds-tcp
authorSowmini Varadhan <sowmini.varadhan@oracle.com>
Wed, 18 May 2016 17:06:23 +0000 (10:06 -0700)
committerDavid S. Miller <davem@davemloft.net>
Fri, 20 May 2016 23:19:57 +0000 (19:19 -0400)
There are two instances where we want to terminate RDS-TCP: when
exiting the netns or during module unload. In either case, the
termination sequence is to stop the listen socket, mark the
rtn->rds_tcp_listen_sock as null, and flush any accept workqs.
Thus any workqs that get flushed at this point will encounter a
null rds_tcp_listen_sock, and must exit gracefully to allow
the RDS-TCP termination to complete successfully.

Signed-off-by: Sowmini Varadhan <sowmini.varadhan@oracle.com>
Acked-by: Santosh Shilimkar <santosh.shilimkar@oracle.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/rds/tcp_listen.c

index 3fa367945105a44a43163d3bc96da8afb78ec34a..094a8cae0ef1d18ab7e10634b33db57461e47390 100644 (file)
@@ -80,6 +80,9 @@ int rds_tcp_accept_one(struct socket *sock)
        int conn_state;
        struct sock *nsk;
 
+       if (!sock) /* module unload or netns delete in progress */
+               return -ENETUNREACH;
+
        ret = sock_create_kern(sock_net(sock->sk), sock->sk->sk_family,
                               sock->sk->sk_type, sock->sk->sk_protocol,
                               &new_sock);