summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEric Dumazet <eric.dumazet@gmail.com>2011-11-23 15:49:31 -0500
committerDavid S. Miller <davem@davemloft.net>2011-11-23 15:49:31 -0500
commitc16a98ed91597b40b22b540c6517103497ef8e74 (patch)
tree55e607b5facf5f29f58484b7c6662c1c8e1cb7ba
parent4d65a2465f6f2694de67777a8aedb1272f473979 (diff)
downloadlinux-c16a98ed91597b40b22b540c6517103497ef8e74.tar.gz
linux-c16a98ed91597b40b22b540c6517103497ef8e74.tar.bz2
linux-c16a98ed91597b40b22b540c6517103497ef8e74.zip
ipv6: tcp: fix panic in SYN processing
commit 72a3effaf633bc ([NET]: Size listen hash tables using backlog hint) added a bug allowing inet6_synq_hash() to return an out of bound array index, because of u16 overflow. Bug can happen if system admins set net.core.somaxconn & net.ipv4.tcp_max_syn_backlog sysctls to values greater than 65536 Signed-off-by: Eric Dumazet <eric.dumazet@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r--net/ipv6/inet6_connection_sock.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/net/ipv6/inet6_connection_sock.c b/net/ipv6/inet6_connection_sock.c
index fee46d5a2f12..1567fb120392 100644
--- a/net/ipv6/inet6_connection_sock.c
+++ b/net/ipv6/inet6_connection_sock.c
@@ -85,7 +85,7 @@ struct dst_entry *inet6_csk_route_req(struct sock *sk,
* request_sock (formerly open request) hash tables.
*/
static u32 inet6_synq_hash(const struct in6_addr *raddr, const __be16 rport,
- const u32 rnd, const u16 synq_hsize)
+ const u32 rnd, const u32 synq_hsize)
{
u32 c;