]> asedeno.scripts.mit.edu Git - linux.git/commitdiff
nfsd: cleanup nfsd_file_lru_dispose()
authorTrond Myklebust <trondmy@gmail.com>
Mon, 6 Jan 2020 18:18:04 +0000 (13:18 -0500)
committerJ. Bruce Fields <bfields@redhat.com>
Wed, 22 Jan 2020 21:25:40 +0000 (16:25 -0500)
Signed-off-by: Trond Myklebust <trond.myklebust@hammerspace.com>
Signed-off-by: J. Bruce Fields <bfields@redhat.com>
fs/nfsd/filecache.c

index 0a3e5c2aac4b4f60d65ced5fad072c2395f4b5a4..c048e3071db76f6a77093e480ce4590c3e928851 100644 (file)
@@ -256,8 +256,6 @@ nfsd_file_do_unhash(struct nfsd_file *nf)
                nfsd_reset_boot_verifier(net_generic(nf->nf_net, nfsd_net_id));
        --nfsd_file_hashtbl[nf->nf_hashval].nfb_count;
        hlist_del_rcu(&nf->nf_node);
-       if (!list_empty(&nf->nf_lru))
-               list_lru_del(&nfsd_file_lru, &nf->nf_lru);
        atomic_long_dec(&nfsd_filecache_count);
 }
 
@@ -266,6 +264,8 @@ nfsd_file_unhash(struct nfsd_file *nf)
 {
        if (test_and_clear_bit(NFSD_FILE_HASHED, &nf->nf_flags)) {
                nfsd_file_do_unhash(nf);
+               if (!list_empty(&nf->nf_lru))
+                       list_lru_del(&nfsd_file_lru, &nf->nf_lru);
                return true;
        }
        return false;
@@ -402,15 +402,14 @@ nfsd_file_lru_cb(struct list_head *item, struct list_lru_one *lru,
 static void
 nfsd_file_lru_dispose(struct list_head *head)
 {
-       while(!list_empty(head)) {
-               struct nfsd_file *nf = list_first_entry(head,
-                               struct nfsd_file, nf_lru);
-               list_del_init(&nf->nf_lru);
+       struct nfsd_file *nf;
+
+       list_for_each_entry(nf, head, 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);
-               nfsd_file_put_noref(nf);
        }
+       nfsd_file_dispose_list(head);
 }
 
 static unsigned long