From: Mathias Krause Date: Wed, 15 Aug 2012 11:31:52 +0000 (+0000) Subject: l2tp: fix info leak via getsockname() X-Git-Tag: v3.6-rc3~10^2~29 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=04d4fbca1017c11381e7d82acea21dd741e748bc;p=profile%2Fivi%2Fkernel-adaptation-intel-automotive.git l2tp: fix info leak via getsockname() The L2TP code for IPv6 fails to initialize the l2tp_unused member of struct sockaddr_l2tpip6 and that for leaks two bytes kernel stack via the getsockname() syscall. Initialize l2tp_unused with 0 to avoid the info leak. Signed-off-by: Mathias Krause Cc: James Chapman Signed-off-by: David S. Miller --- diff --git a/net/l2tp/l2tp_ip6.c b/net/l2tp/l2tp_ip6.c index 35e1e4b..9275471 100644 --- a/net/l2tp/l2tp_ip6.c +++ b/net/l2tp/l2tp_ip6.c @@ -410,6 +410,7 @@ static int l2tp_ip6_getname(struct socket *sock, struct sockaddr *uaddr, lsa->l2tp_family = AF_INET6; lsa->l2tp_flowinfo = 0; lsa->l2tp_scope_id = 0; + lsa->l2tp_unused = 0; if (peer) { if (!lsk->peer_conn_id) return -ENOTCONN;