pptp: verify sockaddr_len in pptp_bind() and pptp_connect() 70/154670/1
authorWANG Cong <xiyou.wangcong@gmail.com>
Mon, 14 Dec 2015 21:48:36 +0000 (13:48 -0800)
committerSeung-Woo Kim <sw0312.kim@samsung.com>
Wed, 11 Oct 2017 04:26:29 +0000 (13:26 +0900)
[ Upstream commit 09ccfd238e5a0e670d8178cf50180ea81ae09ae1 ]

Reported-by: Dmitry Vyukov <dvyukov@gmail.com>
Signed-off-by: Cong Wang <xiyou.wangcong@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
[sw0312.kim: cherry-pick from linux-3.10.y to fix CVE-2015-8569]
Signed-off-by: Seung-Woo Kim <sw0312.kim@samsung.com>
Change-Id: Ice4407c9ce5e0cfd7e91b1f704ac772496fe3e22

drivers/net/ppp/pptp.c

index 0d5a5fa..9a42343 100644 (file)
@@ -420,6 +420,9 @@ static int pptp_bind(struct socket *sock, struct sockaddr *uservaddr,
        struct pptp_opt *opt = &po->proto.pptp;
        int error = 0;
 
+       if (sockaddr_len < sizeof(struct sockaddr_pppox))
+               return -EINVAL;
+
        lock_sock(sk);
 
        opt->src_addr = sp->sa_addr.pptp;
@@ -441,6 +444,9 @@ static int pptp_connect(struct socket *sock, struct sockaddr *uservaddr,
        struct flowi4 fl4;
        int error = 0;
 
+       if (sockaddr_len < sizeof(struct sockaddr_pppox))
+               return -EINVAL;
+
        if (sp->sa_protocol != PX_PROTO_PPTP)
                return -EINVAL;