diff options
author | Ronnie Sahlberg <lsahlber@redhat.com> | 2019-03-28 04:20:02 +0300 |
---|---|---|
committer | Steve French <stfrench@microsoft.com> | 2019-04-01 22:33:30 +0300 |
commit | 2f94a3125b8742b05a011d62b16f52eb8f9ebe1c (patch) | |
tree | f32e1140c6857b8d6d751bb014fbe4c5793a9d57 /kernel/compat.c | |
parent | 5e7a8ca319268a70a6c7c3c1fde5bea38e1e5539 (diff) | |
download | linux-2f94a3125b8742b05a011d62b16f52eb8f9ebe1c.tar.xz |
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 'kernel/compat.c')
0 files changed, 0 insertions, 0 deletions