aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--include/linux/rhashtable.h3
-rw-r--r--lib/rhashtable.c7
2 files changed, 6 insertions, 4 deletions
diff --git a/include/linux/rhashtable.h b/include/linux/rhashtable.h
index 99425f2be708..c85363c45fc0 100644
--- a/include/linux/rhashtable.h
+++ b/include/linux/rhashtable.h
@@ -181,7 +181,8 @@ static inline int lockdep_rht_bucket_is_held(const struct bucket_table *tbl,
181} 181}
182#endif /* CONFIG_PROVE_LOCKING */ 182#endif /* CONFIG_PROVE_LOCKING */
183 183
184int rhashtable_init(struct rhashtable *ht, struct rhashtable_params *params); 184int rhashtable_init(struct rhashtable *ht,
185 const struct rhashtable_params *params);
185 186
186void rhashtable_insert(struct rhashtable *ht, struct rhash_head *node); 187void rhashtable_insert(struct rhashtable *ht, struct rhash_head *node);
187bool rhashtable_remove(struct rhashtable *ht, struct rhash_head *node); 188bool rhashtable_remove(struct rhashtable *ht, struct rhash_head *node);
diff --git a/lib/rhashtable.c b/lib/rhashtable.c
index e75c48d9d82f..e0a9d59f80d6 100644
--- a/lib/rhashtable.c
+++ b/lib/rhashtable.c
@@ -870,7 +870,7 @@ out:
870} 870}
871EXPORT_SYMBOL_GPL(rhashtable_walk_stop); 871EXPORT_SYMBOL_GPL(rhashtable_walk_stop);
872 872
873static size_t rounded_hashtable_size(struct rhashtable_params *params) 873static size_t rounded_hashtable_size(const struct rhashtable_params *params)
874{ 874{
875 return max(roundup_pow_of_two(params->nelem_hint * 4 / 3), 875 return max(roundup_pow_of_two(params->nelem_hint * 4 / 3),
876 (unsigned long)params->min_size); 876 (unsigned long)params->min_size);
@@ -919,7 +919,8 @@ static size_t rounded_hashtable_size(struct rhashtable_params *params)
919 * .obj_hashfn = my_hash_fn, 919 * .obj_hashfn = my_hash_fn,
920 * }; 920 * };
921 */ 921 */
922int rhashtable_init(struct rhashtable *ht, struct rhashtable_params *params) 922int rhashtable_init(struct rhashtable *ht,
923 const struct rhashtable_params *params)
923{ 924{
924 struct bucket_table *tbl; 925 struct bucket_table *tbl;
925 size_t size; 926 size_t size;
@@ -946,7 +947,7 @@ int rhashtable_init(struct rhashtable *ht, struct rhashtable_params *params)
946 if (params->max_size) 947 if (params->max_size)
947 ht->p.max_size = rounddown_pow_of_two(params->max_size); 948 ht->p.max_size = rounddown_pow_of_two(params->max_size);
948 949
949 ht->p.min_size = max(params->min_size, HASH_MIN_SIZE); 950 ht->p.min_size = max(ht->p.min_size, HASH_MIN_SIZE);
950 951
951 if (params->locks_mul) 952 if (params->locks_mul)
952 ht->p.locks_mul = roundup_pow_of_two(params->locks_mul); 953 ht->p.locks_mul = roundup_pow_of_two(params->locks_mul);