]> www.infradead.org Git - users/jedix/linux-maple.git/commitdiff
ipv6_sockglue: Fix a missing-check bug in ip6_ra_control()
authorGen Zhang <blackgod016574@gmail.com>
Fri, 24 May 2019 03:19:46 +0000 (11:19 +0800)
committerBrian Maly <brian.maly@oracle.com>
Wed, 17 Jul 2019 16:31:54 +0000 (12:31 -0400)
In function ip6_ra_control(), the pointer new_ra is allocated a memory
space via kmalloc(). And it is used in the following codes. However,
when there is a memory allocation error, kmalloc() fails. Thus null
pointer dereference may happen. And it will cause the kernel to crash.
Therefore, we should check the return value and handle the error.

Signed-off-by: Gen Zhang <blackgod016574@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
(cherry picked from commit 95baa60a0da80a0143e3ddd4d3725758b4513825)

Orabug: 29926057
CVE: CVE-2019-12378

Reviewed-by: John Donnelly <John.p.donnelly@oracle.com>
Signed-off-by: Allen Pais <allen.pais@oracle.com>
Signed-off-by: Brian Maly <brian.maly@oracle.com>
net/ipv6/ipv6_sockglue.c

index 4449ad1f81147cab79c44209f3f2a73dc1f6a934..7bdb24acced791e9a2a709de65402fd570f97ac1 100644 (file)
@@ -67,6 +67,8 @@ int ip6_ra_control(struct sock *sk, int sel)
                return -ENOPROTOOPT;
 
        new_ra = (sel >= 0) ? kmalloc(sizeof(*new_ra), GFP_KERNEL) : NULL;
+       if (sel >= 0 && !new_ra)
+               return -ENOMEM;
 
        write_lock_bh(&ip6_ra_lock);
        for (rap = &ip6_ra_chain; (ra = *rap) != NULL; rap = &ra->next) {