mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-07 13:53:24 +00:00
rhashtable: future table needs to be traversed when remove an object
When remove an object from hash table, we currently only traverse old bucket table to check whether the object exists. If the object is not found in it, we will try again. But in the second search loop, we still search the object from the old table instead of future table. As a result, the object may be not removed from hash table especially when resizing is currently in progress and the object is just saved in the future table. Signed-off-by: Ying Xue <ying.xue@windriver.com> Cc: Thomas Graf <tgraf@suug.ch> Acked-by: Thomas Graf <tgraf@suug.ch> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
db30485408
commit
bd6d4db552
@ -608,10 +608,10 @@ bool rhashtable_remove(struct rhashtable *ht, struct rhash_head *obj)
|
||||
return true;
|
||||
}
|
||||
|
||||
if (tbl != rht_dereference_rcu(ht->tbl, ht)) {
|
||||
if (tbl != rht_dereference_rcu(ht->future_tbl, ht)) {
|
||||
spin_unlock_bh(lock);
|
||||
|
||||
tbl = rht_dereference_rcu(ht->tbl, ht);
|
||||
tbl = rht_dereference_rcu(ht->future_tbl, ht);
|
||||
hash = head_hashfn(ht, tbl, obj);
|
||||
|
||||
lock = bucket_lock(tbl, hash);
|
||||
|
Loading…
Reference in New Issue
Block a user