mirror of
				https://github.com/torvalds/linux.git
				synced 2025-11-04 10:40:15 +02:00 
			
		
		
		
	net: ipv4: relax AF_INET check in bind()
commit d0733d2e29 (Check for mistakenly passed in non-IPv4 address)
added regression on legacy apps that use bind() with AF_UNSPEC family.
Relax the check, but make sure the bind() is done on INADDR_ANY
addresses, as AF_UNSPEC has probably no sane meaning for other
addresses.
Bugzilla reference : https://bugzilla.kernel.org/show_bug.cgi?id=42012
Signed-off-by: Eric Dumazet <eric.dumazet@gmail.com>
Reported-and-bisected-by: Rene Meier <r_meier@freenet.de>
CC: Marcus Meissner <meissner@suse.de>
Signed-off-by: David S. Miller <davem@davemloft.net>
			
			
This commit is contained in:
		
							parent
							
								
									7858241655
								
							
						
					
					
						commit
						29c486df6a
					
				
					 1 changed files with 6 additions and 1 deletions
				
			
		| 
						 | 
				
			
			@ -466,8 +466,13 @@ int inet_bind(struct socket *sock, struct sockaddr *uaddr, int addr_len)
 | 
			
		|||
		goto out;
 | 
			
		||||
 | 
			
		||||
	if (addr->sin_family != AF_INET) {
 | 
			
		||||
		/* Compatibility games : accept AF_UNSPEC (mapped to AF_INET)
 | 
			
		||||
		 * only if s_addr is INADDR_ANY.
 | 
			
		||||
		 */
 | 
			
		||||
		err = -EAFNOSUPPORT;
 | 
			
		||||
		goto out;
 | 
			
		||||
		if (addr->sin_family != AF_UNSPEC ||
 | 
			
		||||
		    addr->sin_addr.s_addr != htonl(INADDR_ANY))
 | 
			
		||||
			goto out;
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	chk_addr_ret = inet_addr_type(sock_net(sk), addr->sin_addr.s_addr);
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
		Reference in a new issue