nfsd: Clean up nfsd_file_put()
authorTrond Myklebust <trond.myklebust@hammerspace.com>
Thu, 31 Mar 2022 13:54:02 +0000 (09:54 -0400)
committerChuck Lever <chuck.lever@oracle.com>
Thu, 31 Mar 2022 14:39:59 +0000 (10:39 -0400)
Make it a little less racy, by removing the refcount_read() test. Then
remove the redundant 'is_hashed' variable.

Signed-off-by: Trond Myklebust <trond.myklebust@hammerspace.com>
Signed-off-by: Chuck Lever <chuck.lever@oracle.com>
fs/nfsd/filecache.c

index 496f7b3f75237475f09d694e4b0e7e8b81eab5ff..8f7ed5dbb0031740169502725a1aac87e990812a 100644 (file)
@@ -301,21 +301,14 @@ nfsd_file_put_noref(struct nfsd_file *nf)
 void
 nfsd_file_put(struct nfsd_file *nf)
 {
-       bool is_hashed;
-
        set_bit(NFSD_FILE_REFERENCED, &nf->nf_flags);
-       if (refcount_read(&nf->nf_ref) > 2 || !nf->nf_file) {
-               nfsd_file_put_noref(nf);
-               return;
-       }
-
-       is_hashed = test_bit(NFSD_FILE_HASHED, &nf->nf_flags) != 0;
-       if (!is_hashed) {
+       if (test_bit(NFSD_FILE_HASHED, &nf->nf_flags) == 0) {
                nfsd_file_flush(nf);
                nfsd_file_put_noref(nf);
        } else {
                nfsd_file_put_noref(nf);
-               nfsd_file_schedule_laundrette();
+               if (nf->nf_file)
+                       nfsd_file_schedule_laundrette();
        }
        if (atomic_long_read(&nfsd_filecache_count) >= NFSD_FILE_LRU_LIMIT)
                nfsd_file_gc();