diff options
author | Herbert Xu <herbert@gondor.apana.org.au> | 2015-03-13 22:57:24 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2015-03-15 01:35:34 -0400 |
commit | 63d512d0cffcae40505d9448abd509972465e846 (patch) | |
tree | 61aa0d3763daf884a089e41f8f0f7b829b9357c4 /lib | |
parent | 9d901bc05153bbf33b5da2cd6266865e531f0545 (diff) |
rhashtable: Add rehash counter to bucket_table
This patch adds a rehash counter to bucket_table to indicate
the last bucket that has been rehashed. This serves two purposes:
1. Any bucket that has been rehashed can never gain a new object.
2. If the rehash counter reaches the size of the table, the table
will forever remain empty.
This patch also downsizes bucket_table->size to an unsigned int
since we do not support sizes greater than 32 bits yet.
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'lib')
-rw-r--r-- | lib/rhashtable.c | 1 | ||||
-rw-r--r-- | lib/test_rhashtable.c | 2 |
2 files changed, 2 insertions, 1 deletions
diff --git a/lib/rhashtable.c b/lib/rhashtable.c index 36fb0910bec2..ff4ea1704546 100644 --- a/lib/rhashtable.c +++ b/lib/rhashtable.c | |||
@@ -260,6 +260,7 @@ static void rhashtable_rehash_chain(struct rhashtable *ht, unsigned old_hash) | |||
260 | spin_lock_bh(old_bucket_lock); | 260 | spin_lock_bh(old_bucket_lock); |
261 | while (!rhashtable_rehash_one(ht, old_hash)) | 261 | while (!rhashtable_rehash_one(ht, old_hash)) |
262 | ; | 262 | ; |
263 | old_tbl->rehash++; | ||
263 | spin_unlock_bh(old_bucket_lock); | 264 | spin_unlock_bh(old_bucket_lock); |
264 | } | 265 | } |
265 | 266 | ||
diff --git a/lib/test_rhashtable.c b/lib/test_rhashtable.c index 67c7593d1dd6..16974fd89e4e 100644 --- a/lib/test_rhashtable.c +++ b/lib/test_rhashtable.c | |||
@@ -80,7 +80,7 @@ static void test_bucket_stats(struct rhashtable *ht, bool quiet) | |||
80 | rcu_cnt = cnt = 0; | 80 | rcu_cnt = cnt = 0; |
81 | 81 | ||
82 | if (!quiet) | 82 | if (!quiet) |
83 | pr_info(" [%#4x/%zu]", i, tbl->size); | 83 | pr_info(" [%#4x/%u]", i, tbl->size); |
84 | 84 | ||
85 | rht_for_each_entry_rcu(obj, pos, tbl, i, node) { | 85 | rht_for_each_entry_rcu(obj, pos, tbl, i, node) { |
86 | cnt++; | 86 | cnt++; |