CIFS: Fix a memory leak when a lease break comes
authorPavel Shilovsky <pshilovsky@samba.org>
Thu, 5 Sep 2013 11:04:04 +0000 (15:04 +0400)
committerSteve French <smfrench@gmail.com>
Sun, 8 Sep 2013 19:41:40 +0000 (14:41 -0500)
This happens when we receive a lease break from a server, then
find an appropriate lease key in opened files and schedule the
oplock_break slow work. lw pointer isn't freed in this case.

Cc: <stable@vger.kernel.org>
Signed-off-by: Pavel Shilovsky <pshilovsky@samba.org>
Signed-off-by: Steve French <smfrench@gmail.com>
fs/cifs/smb2misc.c

index 6103359..38c93c3 100644 (file)
@@ -477,6 +477,7 @@ smb2_is_valid_lease_break(char *buffer, struct TCP_Server_Info *server)
 
                                queue_work(cifsiod_wq, &cfile->oplock_break);
 
+                               kfree(lw);
                                spin_unlock(&cifs_file_list_lock);
                                spin_unlock(&cifs_tcp_ses_lock);
                                return true;