aboutsummaryrefslogtreecommitdiffstats
path: root/lib/rhashtable.c
diff options
context:
space:
mode:
Diffstat (limited to 'lib/rhashtable.c')
-rw-r--r--lib/rhashtable.c18
1 files changed, 10 insertions, 8 deletions
diff --git a/lib/rhashtable.c b/lib/rhashtable.c
index 8514f7c5f029..50abe4fec4b8 100644
--- a/lib/rhashtable.c
+++ b/lib/rhashtable.c
@@ -153,7 +153,7 @@ static struct bucket_table *rhashtable_last_table(struct rhashtable *ht,
153 return new_tbl; 153 return new_tbl;
154} 154}
155 155
156static int rhashtable_rehash_one(struct rhashtable *ht, unsigned old_hash) 156static int rhashtable_rehash_one(struct rhashtable *ht, unsigned int old_hash)
157{ 157{
158 struct bucket_table *old_tbl = rht_dereference(ht->tbl, ht); 158 struct bucket_table *old_tbl = rht_dereference(ht->tbl, ht);
159 struct bucket_table *new_tbl = rhashtable_last_table(ht, 159 struct bucket_table *new_tbl = rhashtable_last_table(ht,
@@ -162,7 +162,7 @@ static int rhashtable_rehash_one(struct rhashtable *ht, unsigned old_hash)
162 int err = -ENOENT; 162 int err = -ENOENT;
163 struct rhash_head *head, *next, *entry; 163 struct rhash_head *head, *next, *entry;
164 spinlock_t *new_bucket_lock; 164 spinlock_t *new_bucket_lock;
165 unsigned new_hash; 165 unsigned int new_hash;
166 166
167 rht_for_each(entry, old_tbl, old_hash) { 167 rht_for_each(entry, old_tbl, old_hash) {
168 err = 0; 168 err = 0;
@@ -199,7 +199,8 @@ out:
199 return err; 199 return err;
200} 200}
201 201
202static void rhashtable_rehash_chain(struct rhashtable *ht, unsigned old_hash) 202static void rhashtable_rehash_chain(struct rhashtable *ht,
203 unsigned int old_hash)
203{ 204{
204 struct bucket_table *old_tbl = rht_dereference(ht->tbl, ht); 205 struct bucket_table *old_tbl = rht_dereference(ht->tbl, ht);
205 spinlock_t *old_bucket_lock; 206 spinlock_t *old_bucket_lock;
@@ -244,7 +245,7 @@ static int rhashtable_rehash_table(struct rhashtable *ht)
244 struct bucket_table *old_tbl = rht_dereference(ht->tbl, ht); 245 struct bucket_table *old_tbl = rht_dereference(ht->tbl, ht);
245 struct bucket_table *new_tbl; 246 struct bucket_table *new_tbl;
246 struct rhashtable_walker *walker; 247 struct rhashtable_walker *walker;
247 unsigned old_hash; 248 unsigned int old_hash;
248 249
249 new_tbl = rht_dereference(old_tbl->future_tbl, ht); 250 new_tbl = rht_dereference(old_tbl->future_tbl, ht);
250 if (!new_tbl) 251 if (!new_tbl)
@@ -324,11 +325,12 @@ static int rhashtable_expand(struct rhashtable *ht)
324static int rhashtable_shrink(struct rhashtable *ht) 325static int rhashtable_shrink(struct rhashtable *ht)
325{ 326{
326 struct bucket_table *new_tbl, *old_tbl = rht_dereference(ht->tbl, ht); 327 struct bucket_table *new_tbl, *old_tbl = rht_dereference(ht->tbl, ht);
327 unsigned size = roundup_pow_of_two(atomic_read(&ht->nelems) * 3 / 2); 328 unsigned int size;
328 int err; 329 int err;
329 330
330 ASSERT_RHT_MUTEX(ht); 331 ASSERT_RHT_MUTEX(ht);
331 332
333 size = roundup_pow_of_two(atomic_read(&ht->nelems) * 3 / 2);
332 if (size < ht->p.min_size) 334 if (size < ht->p.min_size)
333 size = ht->p.min_size; 335 size = ht->p.min_size;
334 336
@@ -379,9 +381,9 @@ unlock:
379 381
380static bool rhashtable_check_elasticity(struct rhashtable *ht, 382static bool rhashtable_check_elasticity(struct rhashtable *ht,
381 struct bucket_table *tbl, 383 struct bucket_table *tbl,
382 unsigned hash) 384 unsigned int hash)
383{ 385{
384 unsigned elasticity = ht->elasticity; 386 unsigned int elasticity = ht->elasticity;
385 struct rhash_head *head; 387 struct rhash_head *head;
386 388
387 rht_for_each(head, tbl, hash) 389 rht_for_each(head, tbl, hash)
@@ -431,7 +433,7 @@ int rhashtable_insert_slow(struct rhashtable *ht, const void *key,
431 struct bucket_table *tbl) 433 struct bucket_table *tbl)
432{ 434{
433 struct rhash_head *head; 435 struct rhash_head *head;
434 unsigned hash; 436 unsigned int hash;
435 int err; 437 int err;
436 438
437 tbl = rhashtable_last_table(ht, tbl); 439 tbl = rhashtable_last_table(ht, tbl);