rhashtable: key_hashfn() must return full hash value
The value computed by key_hashfn() is used by rhashtable_lookup_compare()
to traverse both tables during a resize. key_hashfn() must therefore
return the hash value without the buckets mask applied so it can be
masked to the size of each individual table.
Fixes: 97defe1ecf
("rhashtable: Per bucket locks & deferred expansion/shrinking")
Signed-off-by: Thomas Graf <tgraf@suug.ch>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
Родитель
2ca292d968
Коммит
c88455ce50
|
@ -94,13 +94,7 @@ static u32 obj_raw_hashfn(const struct rhashtable *ht, const void *ptr)
|
|||
|
||||
static u32 key_hashfn(struct rhashtable *ht, const void *key, u32 len)
|
||||
{
|
||||
struct bucket_table *tbl = rht_dereference_rcu(ht->tbl, ht);
|
||||
u32 hash;
|
||||
|
||||
hash = ht->p.hashfn(key, len, ht->p.hash_rnd);
|
||||
hash >>= HASH_RESERVED_SPACE;
|
||||
|
||||
return rht_bucket_index(tbl, hash);
|
||||
return ht->p.hashfn(key, len, ht->p.hash_rnd) >> HASH_RESERVED_SPACE;
|
||||
}
|
||||
|
||||
static u32 head_hashfn(const struct rhashtable *ht,
|
||||
|
|
Загрузка…
Ссылка в новой задаче