diff options
| author | Jeff Layton <jlayton@kernel.org> | 2022-09-30 16:56:02 -0400 | 
|---|---|---|
| committer | Chuck Lever <chuck.lever@oracle.com> | 2022-10-05 10:57:48 -0400 | 
| commit | 8d0d254b15cc5b7d46d85fb7ab8ecede9575e672 (patch) | |
| tree | 35d483aaacf4c9c76ed45291cc65f77fe6092cf5 /lib/mpi/mpi-inv.c | |
| parent | 895ddf5ed4c54ea9e3533606d7a8b4e4f27f95ef (diff) | |
nfsd: fix nfsd_file_unhash_and_dispose
nfsd_file_unhash_and_dispose() is called for two reasons:
We're either shutting down and purging the filecache, or we've gotten a
notification about a file delete, so we want to go ahead and unhash it
so that it'll get cleaned up when we close.
We're either walking the hashtable or doing a lookup in it and we
don't take a reference in either case. What we want to do in both cases
is to try and unhash the object and put it on the dispose list if that
was successful. If it's no longer hashed, then we don't want to touch
it, with the assumption being that something else is already cleaning
up the sentinel reference.
Instead of trying to selectively decrement the refcount in this
function, just unhash it, and if that was successful, move it to the
dispose list. Then, the disposal routine will just clean that up as
usual.
Also, just make this a void function, drop the WARN_ON_ONCE, and the
comments about deadlocking since the nature of the purported deadlock
is no longer clear.
Signed-off-by: Jeff Layton <jlayton@kernel.org>
Signed-off-by: Chuck Lever <chuck.lever@oracle.com>
Diffstat (limited to 'lib/mpi/mpi-inv.c')
0 files changed, 0 insertions, 0 deletions
