diff options
author | NeilBrown <neilb@suse.de> | 2012-07-11 20:37:34 -0400 |
---|---|---|
committer | J. Bruce Fields <bfields@redhat.com> | 2012-07-12 11:20:28 -0400 |
commit | 200724a7074281e7a0bf1101784a59fecddfa77d (patch) | |
tree | 4b20a0b9de0f725d5af7654621bb8b750bb0d0c9 /net | |
parent | bbf43dc888833ac0539e437dbaeb28bfd4fbab9f (diff) |
SUNRPC/cache: fix reporting of expired cache entries in 'content' file.
Entries that are in a sunrpc cache but are not valid should be reported
with a leading '#' so they look like a comment.
Commit d202cce8963d9 (sunrpc: never return expired entries in sunrpc_cache_lookup)
broke this for expired entries.
This particularly applies to entries that have been replaced by newer entries.
sunrpc_cache_update sets the expiry of the replaced entry to '0', but it
remains in the cache until the next 'cache_clean'.
The result is that if you
echo 0 2000000000 1 0 > /proc/net/rpc/auth.unix.gid/channel
several times, then
cat /proc/net/rpc/auth.unix.gid/content
It will display multiple entries for the one uid, which is at least confusing:
#uid cnt: gids...
0 1: 0
0 1: 0
0 1: 0
With this patch, expired entries are marked as comments so you get
#uid cnt: gids...
0 1: 0
# 0 1: 0
# 0 1: 0
These expired entries will never be seen by cache_check() as they are always
*after* a non-expired entry with the same key - so the extra check is only
needed in c_show()
Signed-off-by: NeilBrown <neilb@suse.de>
--
It's not a big problem, but it had me confused for a while, so it could
well confuse others.
Thanks,
NeilBrown
Signed-off-by: J. Bruce Fields <bfields@redhat.com>
Diffstat (limited to 'net')
-rw-r--r-- | net/sunrpc/cache.c | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/net/sunrpc/cache.c b/net/sunrpc/cache.c index 47ad2666fdf..2afd2a84dc3 100644 --- a/net/sunrpc/cache.c +++ b/net/sunrpc/cache.c | |||
@@ -1349,8 +1349,11 @@ static int c_show(struct seq_file *m, void *p) | |||
1349 | if (cache_check(cd, cp, NULL)) | 1349 | if (cache_check(cd, cp, NULL)) |
1350 | /* cache_check does a cache_put on failure */ | 1350 | /* cache_check does a cache_put on failure */ |
1351 | seq_printf(m, "# "); | 1351 | seq_printf(m, "# "); |
1352 | else | 1352 | else { |
1353 | if (cache_is_expired(cd, cp)) | ||
1354 | seq_printf(m, "# "); | ||
1353 | cache_put(cp, cd); | 1355 | cache_put(cp, cd); |
1356 | } | ||
1354 | 1357 | ||
1355 | return cd->cache_show(m, cd, cp); | 1358 | return cd->cache_show(m, cd, cp); |
1356 | } | 1359 | } |