NFSD: nfsd_file_hash_remove can compute hashval
authorChuck Lever <chuck.lever@oracle.com>
Fri, 8 Jul 2022 18:26:03 +0000 (14:26 -0400)
committerChuck Lever <chuck.lever@oracle.com>
Sat, 30 Jul 2022 00:12:01 +0000 (20:12 -0400)
Remove an unnecessary use of nf_hashval.

Reviewed-by: Jeff Layton <jlayton@kernel.org>
Signed-off-by: Chuck Lever <chuck.lever@oracle.com>
fs/nfsd/filecache.c

index 1ff58978421ca7b94fc0f5554f5e8ffd7f35b870..0766f6f39f16b71eba38c5eee05992a0da365bc3 100644 (file)
@@ -288,6 +288,18 @@ nfsd_file_do_unhash(struct nfsd_file *nf)
        atomic_long_dec(&nfsd_filecache_count);
 }
 
+static void
+nfsd_file_hash_remove(struct nfsd_file *nf)
+{
+       struct inode *inode = nf->nf_inode;
+       unsigned int hashval = (unsigned int)hash_long(inode->i_ino,
+                               NFSD_FILE_HASH_BITS);
+
+       spin_lock(&nfsd_file_hashtbl[hashval].nfb_lock);
+       nfsd_file_do_unhash(nf);
+       spin_unlock(&nfsd_file_hashtbl[hashval].nfb_lock);
+}
+
 static bool
 nfsd_file_unhash(struct nfsd_file *nf)
 {
@@ -507,11 +519,8 @@ static void nfsd_file_gc_dispose_list(struct list_head *dispose)
 {
        struct nfsd_file *nf;
 
-       list_for_each_entry(nf, dispose, nf_lru) {
-               spin_lock(&nfsd_file_hashtbl[nf->nf_hashval].nfb_lock);
-               nfsd_file_do_unhash(nf);
-               spin_unlock(&nfsd_file_hashtbl[nf->nf_hashval].nfb_lock);
-       }
+       list_for_each_entry(nf, dispose, nf_lru)
+               nfsd_file_hash_remove(nf);
        nfsd_file_dispose_list_delayed(dispose);
 }