forked from mirrors/linux
		
	net/ipv6: Move call_fib6_entry_notifiers up for route adds
Move call to call_fib6_entry_notifiers for new IPv6 routes to right before the insertion into the FIB. At this point notifier handlers can decide the fate of the new route with a clean path to delete the potential new entry if the notifier returns non-0. Signed-off-by: David Ahern <dsa@cumulusnetworks.com> Reviewed-by: Ido Schimmel <idosch@mellanox.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
		
							parent
							
								
									c1d7ee67ac
								
							
						
					
					
						commit
						2233000cba
					
				
					 1 changed files with 12 additions and 4 deletions
				
			
		| 
						 | 
					@ -1007,12 +1007,16 @@ static int fib6_add_rt2node(struct fib6_node *fn, struct rt6_info *rt,
 | 
				
			||||||
		if (err)
 | 
							if (err)
 | 
				
			||||||
			return err;
 | 
								return err;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							err = call_fib6_entry_notifiers(info->nl_net,
 | 
				
			||||||
 | 
											FIB_EVENT_ENTRY_ADD,
 | 
				
			||||||
 | 
											rt, extack);
 | 
				
			||||||
 | 
							if (err)
 | 
				
			||||||
 | 
								return err;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		rcu_assign_pointer(rt->rt6_next, iter);
 | 
							rcu_assign_pointer(rt->rt6_next, iter);
 | 
				
			||||||
		atomic_inc(&rt->rt6i_ref);
 | 
							atomic_inc(&rt->rt6i_ref);
 | 
				
			||||||
		rcu_assign_pointer(rt->rt6i_node, fn);
 | 
							rcu_assign_pointer(rt->rt6i_node, fn);
 | 
				
			||||||
		rcu_assign_pointer(*ins, rt);
 | 
							rcu_assign_pointer(*ins, rt);
 | 
				
			||||||
		call_fib6_entry_notifiers(info->nl_net, FIB_EVENT_ENTRY_ADD,
 | 
					 | 
				
			||||||
					  rt, extack);
 | 
					 | 
				
			||||||
		if (!info->skip_notify)
 | 
							if (!info->skip_notify)
 | 
				
			||||||
			inet6_rt_notify(RTM_NEWROUTE, rt, info, nlflags);
 | 
								inet6_rt_notify(RTM_NEWROUTE, rt, info, nlflags);
 | 
				
			||||||
		info->nl_net->ipv6.rt6_stats->fib_rt_entries++;
 | 
							info->nl_net->ipv6.rt6_stats->fib_rt_entries++;
 | 
				
			||||||
| 
						 | 
					@ -1036,12 +1040,16 @@ static int fib6_add_rt2node(struct fib6_node *fn, struct rt6_info *rt,
 | 
				
			||||||
		if (err)
 | 
							if (err)
 | 
				
			||||||
			return err;
 | 
								return err;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							err = call_fib6_entry_notifiers(info->nl_net,
 | 
				
			||||||
 | 
											FIB_EVENT_ENTRY_REPLACE,
 | 
				
			||||||
 | 
											rt, extack);
 | 
				
			||||||
 | 
							if (err)
 | 
				
			||||||
 | 
								return err;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		atomic_inc(&rt->rt6i_ref);
 | 
							atomic_inc(&rt->rt6i_ref);
 | 
				
			||||||
		rcu_assign_pointer(rt->rt6i_node, fn);
 | 
							rcu_assign_pointer(rt->rt6i_node, fn);
 | 
				
			||||||
		rt->rt6_next = iter->rt6_next;
 | 
							rt->rt6_next = iter->rt6_next;
 | 
				
			||||||
		rcu_assign_pointer(*ins, rt);
 | 
							rcu_assign_pointer(*ins, rt);
 | 
				
			||||||
		call_fib6_entry_notifiers(info->nl_net, FIB_EVENT_ENTRY_REPLACE,
 | 
					 | 
				
			||||||
					  rt, extack);
 | 
					 | 
				
			||||||
		if (!info->skip_notify)
 | 
							if (!info->skip_notify)
 | 
				
			||||||
			inet6_rt_notify(RTM_NEWROUTE, rt, info, NLM_F_REPLACE);
 | 
								inet6_rt_notify(RTM_NEWROUTE, rt, info, NLM_F_REPLACE);
 | 
				
			||||||
		if (!(fn->fn_flags & RTN_RTINFO)) {
 | 
							if (!(fn->fn_flags & RTN_RTINFO)) {
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
		Reference in a new issue