mirror of
				https://github.com/torvalds/linux.git
				synced 2025-11-04 02:30:34 +02:00 
			
		
		
		
	fib_rules: return 0 directly if an exactly same rule exists when NLM_F_EXCL not supplied
With commit153380ec4b("fib_rules: Added NLM_F_EXCL support to fib_nl_newrule") we now able to check if a rule already exists. But this only works with iproute2. For other tools like libnl, NetworkManager, it still could add duplicate rules with only NLM_F_CREATE flag, like [localhost ~ ]# ip rule 0: from all lookup local 32766: from all lookup main 32767: from all lookup default 100000: from 192.168.7.5 lookup 5 100000: from 192.168.7.5 lookup 5 As it doesn't make sense to create two duplicate rules, let's just return 0 if the rule exists. Fixes:153380ec4b("fib_rules: Added NLM_F_EXCL support to fib_nl_newrule") Reported-by: Thomas Haller <thaller@redhat.com> Signed-off-by: Hangbin Liu <liuhangbin@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
		
							parent
							
								
									80f232121b
								
							
						
					
					
						commit
						e9919a24d3
					
				
					 1 changed files with 3 additions and 3 deletions
				
			
		| 
						 | 
				
			
			@ -757,9 +757,9 @@ int fib_nl_newrule(struct sk_buff *skb, struct nlmsghdr *nlh,
 | 
			
		|||
	if (err)
 | 
			
		||||
		goto errout;
 | 
			
		||||
 | 
			
		||||
	if ((nlh->nlmsg_flags & NLM_F_EXCL) &&
 | 
			
		||||
	    rule_exists(ops, frh, tb, rule)) {
 | 
			
		||||
		err = -EEXIST;
 | 
			
		||||
	if (rule_exists(ops, frh, tb, rule)) {
 | 
			
		||||
		if (nlh->nlmsg_flags & NLM_F_EXCL)
 | 
			
		||||
			err = -EEXIST;
 | 
			
		||||
		goto errout_free;
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
		Reference in a new issue