]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
net: sched: Fix a possible null-pointer dereference in dequeue_func()
authorJia-Ju Bai <baijiaju1990@gmail.com>
Mon, 29 Jul 2019 08:24:33 +0000 (16:24 +0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Sun, 11 Aug 2019 10:20:45 +0000 (12:20 +0200)
[ Upstream commit 051c7b39be4a91f6b7d8c4548444e4b850f1f56c ]

In dequeue_func(), there is an if statement on line 74 to check whether
skb is NULL:
    if (skb)

When skb is NULL, it is used on line 77:
    prefetch(&skb->end);

Thus, a possible null-pointer dereference may occur.

To fix this bug, skb->end is used when skb is not NULL.

This bug is found by a static analysis tool STCheck written by us.

Fixes: 76e3cc126bb2 ("codel: Controlled Delay AQM")
Signed-off-by: Jia-Ju Bai <baijiaju1990@gmail.com>
Reviewed-by: Jiri Pirko <jiri@mellanox.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
net/sched/sch_codel.c

index 9b7e2980ee5c64c18477d003957fedd10c1718d5..3bc5dec3b17b19dc03f7da873ee5656e77bd71ec 100644 (file)
@@ -68,7 +68,8 @@ static struct sk_buff *dequeue(struct codel_vars *vars, struct Qdisc *sch)
 {
        struct sk_buff *skb = __skb_dequeue(&sch->q);
 
-       prefetch(&skb->end); /* we'll need skb_shinfo() */
+       if (skb)
+               prefetch(&skb->end); /* we'll need skb_shinfo() */
        return skb;
 }