inet: add a schedule point in inet_twsk_purge()
On a large hash table, we can easily spend seconds to walk over all entries. Add a cond_resched() to yield cpu if necessary. Signed-off-by: Eric Dumazet <edumazet@google.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
db19170bc0
commit
738e6d30d3
@ -487,6 +487,7 @@ void inet_twsk_purge(struct inet_hashinfo *hashinfo,
|
|||||||
for (slot = 0; slot <= hashinfo->ehash_mask; slot++) {
|
for (slot = 0; slot <= hashinfo->ehash_mask; slot++) {
|
||||||
struct inet_ehash_bucket *head = &hashinfo->ehash[slot];
|
struct inet_ehash_bucket *head = &hashinfo->ehash[slot];
|
||||||
restart_rcu:
|
restart_rcu:
|
||||||
|
cond_resched();
|
||||||
rcu_read_lock();
|
rcu_read_lock();
|
||||||
restart:
|
restart:
|
||||||
sk_nulls_for_each_rcu(sk, node, &head->chain) {
|
sk_nulls_for_each_rcu(sk, node, &head->chain) {
|
||||||
|
Loading…
Reference in New Issue
Block a user