forked from mirrors/linux
		
	net: use rcu_barrier() in rollback_registered_many
netdev_wait_allrefs() waits that all references to a device vanishes. It currently uses a _very_ pessimistic 250 ms delay between each probe. Some users reported that no more than 4 devices can be dismantled per second, this is a pretty serious problem for some setups. Most of the time, a refcount is about to be released by an RCU callback, that is still in flight because rollback_registered_many() uses a synchronize_rcu() call instead of rcu_barrier(). Problem is visible if number of online cpus is one, because synchronize_rcu() is then a no op. time to remove 50 ipip tunnels on a UP machine : before patch : real 11.910s after patch : real 1.250s Reported-by: Nicolas Dichtel <nicolas.dichtel@6wind.com> Reported-by: Octavian Purdila <opurdila@ixiacom.com> Reported-by: Benjamin LaHaise <bcrl@kvack.org> Signed-off-by: Eric Dumazet <eric.dumazet@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
		
							parent
							
								
									ab12811c89
								
							
						
					
					
						commit
						ef885afbf8
					
				
					 1 changed files with 1 additions and 1 deletions
				
			
		| 
						 | 
				
			
			@ -4845,7 +4845,7 @@ static void rollback_registered_many(struct list_head *head)
 | 
			
		|||
	dev = list_first_entry(head, struct net_device, unreg_list);
 | 
			
		||||
	call_netdevice_notifiers(NETDEV_UNREGISTER_BATCH, dev);
 | 
			
		||||
 | 
			
		||||
	synchronize_net();
 | 
			
		||||
	rcu_barrier();
 | 
			
		||||
 | 
			
		||||
	list_for_each_entry(dev, head, unreg_list)
 | 
			
		||||
		dev_put(dev);
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
		Reference in a new issue