aboutsummaryrefslogtreecommitdiffstats
path: root/net/ipv4/af_inet.c
diff options
context:
space:
mode:
authorMarcus Meissner <meissner@suse.de>2011-06-01 21:05:22 -0700
committerDavid S. Miller <davem@davemloft.net>2011-06-01 21:05:22 -0700
commitd0733d2e29b652b2e7b1438ececa732e4eed98eb (patch)
tree1fdc2634b52f097f0dc01f76196228492dac4be6 /net/ipv4/af_inet.c
parentRevert "net: fix section mismatches" (diff)
downloadlinux-dev-d0733d2e29b652b2e7b1438ececa732e4eed98eb.tar.xz
linux-dev-d0733d2e29b652b2e7b1438ececa732e4eed98eb.zip
net/ipv4: Check for mistakenly passed in non-IPv4 address
Check against mistakenly passing in IPv6 addresses (which would result in an INADDR_ANY bind) or similar incompatible sockaddrs. Signed-off-by: Marcus Meissner <meissner@suse.de> Cc: Reinhard Max <max@suse.de> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/ipv4/af_inet.c')
-rw-r--r--net/ipv4/af_inet.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/net/ipv4/af_inet.c b/net/ipv4/af_inet.c
index cc1463156cd0..9c1926027a26 100644
--- a/net/ipv4/af_inet.c
+++ b/net/ipv4/af_inet.c
@@ -465,6 +465,9 @@ int inet_bind(struct socket *sock, struct sockaddr *uaddr, int addr_len)
if (addr_len < sizeof(struct sockaddr_in))
goto out;
+ if (addr->sin_family != AF_INET)
+ goto out;
+
chk_addr_ret = inet_addr_type(sock_net(sk), addr->sin_addr.s_addr);
/* Not specified by any standard per-se, however it breaks too