diff options
author | Ronnie Sahlberg <lsahlber@redhat.com> | 2019-03-28 02:20:02 +0100 |
---|---|---|
committer | Steve French <stfrench@microsoft.com> | 2019-04-01 21:33:30 +0200 |
commit | 2f94a3125b8742b05a011d62b16f52eb8f9ebe1c (patch) | |
tree | f32e1140c6857b8d6d751bb014fbe4c5793a9d57 /fs/cifs/smb2pdu.c | |
parent | Merge branch 'work.aio' of git://git.kernel.org/pub/scm/linux/kernel/git/viro... (diff) | |
download | linux-2f94a3125b8742b05a011d62b16f52eb8f9ebe1c.tar.xz linux-2f94a3125b8742b05a011d62b16f52eb8f9ebe1c.zip |
cifs: fix kref underflow in close_shroot()
Fix a bug where we used to not initialize the cached fid structure at all
in open_shroot() if the open was successful but we did not get a lease.
This would leave the structure uninitialized and later when we close the handle
we would in close_shroot() try to kref_put() an uninitialized refcount.
Fix this by always initializing this structure if the open was successful
but only do the extra get() if we got a lease.
This extra get() is only used to hold the structure until we get a lease
break from the server at which point we will kref_put() it during lease
processing.
Signed-off-by: Ronnie Sahlberg <lsahlber@redhat.com>
Signed-off-by: Steve French <stfrench@microsoft.com>
CC: Stable <stable@vger.kernel.org>
Diffstat (limited to 'fs/cifs/smb2pdu.c')
0 files changed, 0 insertions, 0 deletions