forked from mirrors/linux
		
	ipv4: Fix flushing of cached routing informations
Currently we can not flush cached pmtu/redirect informations via the ipv4_sysctl_rtcache_flush sysctl. We need to check the rt_genid of the old route and reset the nh exeption if the old route is expired when we bind a new route to a nh exeption. Signed-off-by: Steffen Klassert <steffen.klassert@secunet.com> Acked-by: Eric Dumazet <edumazet@google.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
		
							parent
							
								
									18c22a03a2
								
							
						
					
					
						commit
						13d82bf50d
					
				
					 1 changed files with 6 additions and 3 deletions
				
			
		| 
						 | 
				
			
			@ -1163,8 +1163,12 @@ static bool rt_bind_exception(struct rtable *rt, struct fib_nh_exception *fnhe,
 | 
			
		|||
	spin_lock_bh(&fnhe_lock);
 | 
			
		||||
 | 
			
		||||
	if (daddr == fnhe->fnhe_daddr) {
 | 
			
		||||
		struct rtable *orig;
 | 
			
		||||
 | 
			
		||||
		struct rtable *orig = rcu_dereference(fnhe->fnhe_rth);
 | 
			
		||||
		if (orig && rt_is_expired(orig)) {
 | 
			
		||||
			fnhe->fnhe_gw = 0;
 | 
			
		||||
			fnhe->fnhe_pmtu = 0;
 | 
			
		||||
			fnhe->fnhe_expires = 0;
 | 
			
		||||
		}
 | 
			
		||||
		if (fnhe->fnhe_pmtu) {
 | 
			
		||||
			unsigned long expires = fnhe->fnhe_expires;
 | 
			
		||||
			unsigned long diff = expires - jiffies;
 | 
			
		||||
| 
						 | 
				
			
			@ -1181,7 +1185,6 @@ static bool rt_bind_exception(struct rtable *rt, struct fib_nh_exception *fnhe,
 | 
			
		|||
		} else if (!rt->rt_gateway)
 | 
			
		||||
			rt->rt_gateway = daddr;
 | 
			
		||||
 | 
			
		||||
		orig = rcu_dereference(fnhe->fnhe_rth);
 | 
			
		||||
		rcu_assign_pointer(fnhe->fnhe_rth, rt);
 | 
			
		||||
		if (orig)
 | 
			
		||||
			rt_free(orig);
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
		Reference in a new issue