diff options
author | NeilBrown <neilb@suse.de> | 2010-09-22 12:55:06 +1000 |
---|---|---|
committer | J. Bruce Fields <bfields@redhat.com> | 2010-09-22 15:33:12 -0400 |
commit | e95dffa4304186ad87963255f3e5e96b5c41849f (patch) | |
tree | c5e382e2272b8ef8d7edfc480060608cd5bb493d /net/sunrpc | |
parent | f904be9cc77f361d37d71468b13ff3d1a1823dea (diff) | |
download | op-kernel-dev-e95dffa4304186ad87963255f3e5e96b5c41849f.zip op-kernel-dev-e95dffa4304186ad87963255f3e5e96b5c41849f.tar.gz |
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>
Diffstat (limited to 'net/sunrpc')
-rw-r--r-- | net/sunrpc/cache.c | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/net/sunrpc/cache.c b/net/sunrpc/cache.c index ac2c6e6..ff733df 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); |