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:
		
					parent
					
						
							
								2ca292d968
							
						
					
				
			
			
				commit
				
					
						c88455ce50
					
				
			
		
					 1 changed files with 1 additions and 7 deletions
				
			
		| 
						 | 
				
			
			@ -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,
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue