if server shutdown happens in the situation that
there are connections, workqueue could be destroyed
before queueing disconnect work.
Signed-off-by: Hyunchul Lee <hyc.lee@gmail.com>
Signed-off-by: Namjae Jeon <namjae.jeon@samsung.com>
Signed-off-by: Steve French <stfrench@microsoft.com>
 static void
 smb_direct_disconnect_rdma_connection(struct smb_direct_transport *t)
 {
-       queue_work(smb_direct_wq, &t->disconnect_work);
+       if (t->status == SMB_DIRECT_CS_CONNECTED)
+               queue_work(smb_direct_wq, &t->disconnect_work);
 }
 
 static void smb_direct_send_immediate_work(struct work_struct *work)
 
        ksmbd_debug(RDMA, "Disconnecting cm_id=%p\n", st->cm_id);
 
-       smb_direct_disconnect_rdma_connection(st);
+       smb_direct_disconnect_rdma_work(&st->disconnect_work);
        wait_event_interruptible(st->wait_status,
                                 st->status == SMB_DIRECT_CS_DISCONNECTED);
        free_transport(st);