aboutsummaryrefslogtreecommitdiffstats
path: root/fs/cifs/cifssmb.c
diff options
context:
space:
mode:
Diffstat (limited to 'fs/cifs/cifssmb.c')
-rw-r--r--fs/cifs/cifssmb.c22
1 files changed, 7 insertions, 15 deletions
diff --git a/fs/cifs/cifssmb.c b/fs/cifs/cifssmb.c
index cd9e9a145e4d..9c95617baa4d 100644
--- a/fs/cifs/cifssmb.c
+++ b/fs/cifs/cifssmb.c
@@ -799,20 +799,16 @@ CIFSSMBLogoff(const int xid, struct cifsSesInfo *ses)
799 int rc = 0; 799 int rc = 0;
800 800
801 cFYI(1, ("In SMBLogoff for session disconnect")); 801 cFYI(1, ("In SMBLogoff for session disconnect"));
802 if (ses)
803 down(&ses->sesSem);
804 else
805 return -EIO;
806
807 atomic_dec(&ses->inUse);
808 if (atomic_read(&ses->inUse) > 0) {
809 up(&ses->sesSem);
810 return -EBUSY;
811 }
812 802
813 if (ses->server == NULL) 803 /*
804 * BB: do we need to check validity of ses and server? They should
805 * always be valid since we have an active reference. If not, that
806 * should probably be a BUG()
807 */
808 if (!ses || !ses->server)
814 return -EIO; 809 return -EIO;
815 810
811 down(&ses->sesSem);
816 if (ses->need_reconnect) 812 if (ses->need_reconnect)
817 goto session_already_dead; /* no need to send SMBlogoff if uid 813 goto session_already_dead; /* no need to send SMBlogoff if uid
818 already closed due to reconnect */ 814 already closed due to reconnect */
@@ -833,10 +829,6 @@ CIFSSMBLogoff(const int xid, struct cifsSesInfo *ses)
833 pSMB->AndXCommand = 0xFF; 829 pSMB->AndXCommand = 0xFF;
834 rc = SendReceiveNoRsp(xid, ses, (struct smb_hdr *) pSMB, 0); 830 rc = SendReceiveNoRsp(xid, ses, (struct smb_hdr *) pSMB, 0);
835session_already_dead: 831session_already_dead:
836 if (ses->server) {
837 cifs_put_tcp_session(ses->server);
838 rc = 0;
839 }
840 up(&ses->sesSem); 832 up(&ses->sesSem);
841 833
842 /* if session dead then we do not need to do ulogoff, 834 /* if session dead then we do not need to do ulogoff,