Commit 449ac551 authored by David Howells's avatar David Howells Committed by Christian Brauner

fscache: Fix error handling in fscache_begin_operation()

Fix fscache_begin_operation() to clear cres->cache_priv on error, otherwise
fscache_resources_valid() will report it as being valid.
Signed-off-by: default avatarDavid Howells <dhowells@redhat.com>
Link: https://lore.kernel.org/r/3933237.1710514106@warthog.procyon.org.ukReviewed-by: default avatarJeff Layton <jlayton@kernel.org>
Reported-by: default avatarMarc Dionne <marc.dionne@auristor.com>
cc: Jeff Layton <jlayton@kernel.org>
cc: netfs@lists.linux.dev
cc: linux-fsdevel@vger.kernel.org
Signed-off-by: default avatarChristian Brauner <brauner@kernel.org>
parent 59a55a63
...@@ -83,8 +83,10 @@ static int fscache_begin_operation(struct netfs_cache_resources *cres, ...@@ -83,8 +83,10 @@ static int fscache_begin_operation(struct netfs_cache_resources *cres,
cres->debug_id = cookie->debug_id; cres->debug_id = cookie->debug_id;
cres->inval_counter = cookie->inval_counter; cres->inval_counter = cookie->inval_counter;
if (!fscache_begin_cookie_access(cookie, why)) if (!fscache_begin_cookie_access(cookie, why)) {
cres->cache_priv = NULL;
return -ENOBUFS; return -ENOBUFS;
}
again: again:
spin_lock(&cookie->lock); spin_lock(&cookie->lock);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment