summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorNeilBrown <neilb@suse.de>2010-09-22 12:55:06 +1000
committerJ. Bruce Fields <bfields@redhat.com>2010-09-22 15:33:12 -0400
commite95dffa4304186ad87963255f3e5e96b5c41849f (patch)
treec5e382e2272b8ef8d7edfc480060608cd5bb493d
parentf904be9cc77f361d37d71468b13ff3d1a1823dea (diff)
downloadlinux-e95dffa4304186ad87963255f3e5e96b5c41849f.tar.bz2
sunrpc/cache: fix recent breakage of cache_clean_deferred
commit 6610f720e9e8103c22d1f1ccf8fbb695550a571f broke cache_clean_deferred as entries are no longer added to the pending list for subsequent revisiting. So put those requests back on the pending list. Signed-off-by: NeilBrown <neilb@suse.de> Signed-off-by: J. Bruce Fields <bfields@redhat.com>
-rw-r--r--net/sunrpc/cache.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/net/sunrpc/cache.c b/net/sunrpc/cache.c
index ac2c6e6abe65..ff733dfef3b8 100644
--- a/net/sunrpc/cache.c
+++ b/net/sunrpc/cache.c
@@ -671,8 +671,10 @@ void cache_clean_deferred(void *owner)
spin_lock(&cache_defer_lock);
list_for_each_entry_safe(dreq, tmp, &cache_defer_list, recent) {
- if (dreq->owner == owner)
+ if (dreq->owner == owner) {
__unhash_deferred_req(dreq);
+ list_add(&dreq->recent, &pending);
+ }
}
spin_unlock(&cache_defer_lock);