mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-11-24 15:01:13 +07:00
[NET_SCHED]: cls_basic: fix NULL pointer dereference
cls_basic doesn't allocate tp->root before it is linked into the active classifier list, resulting in a NULL pointer dereference when packets hit the classifier before its ->change function is called. Reported by Chris Madden <chris@reflexsecurity.com> Signed-off-by: Patrick McHardy <kaber@trash.net> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
c93a882ebe
commit
d3fa76ee6b
@ -81,6 +81,13 @@ static void basic_put(struct tcf_proto *tp, unsigned long f)
|
|||||||
|
|
||||||
static int basic_init(struct tcf_proto *tp)
|
static int basic_init(struct tcf_proto *tp)
|
||||||
{
|
{
|
||||||
|
struct basic_head *head;
|
||||||
|
|
||||||
|
head = kzalloc(sizeof(*head), GFP_KERNEL);
|
||||||
|
if (head == NULL)
|
||||||
|
return -ENOBUFS;
|
||||||
|
INIT_LIST_HEAD(&head->flist);
|
||||||
|
tp->root = head;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -176,15 +183,6 @@ static int basic_change(struct tcf_proto *tp, unsigned long base, u32 handle,
|
|||||||
}
|
}
|
||||||
|
|
||||||
err = -ENOBUFS;
|
err = -ENOBUFS;
|
||||||
if (head == NULL) {
|
|
||||||
head = kzalloc(sizeof(*head), GFP_KERNEL);
|
|
||||||
if (head == NULL)
|
|
||||||
goto errout;
|
|
||||||
|
|
||||||
INIT_LIST_HEAD(&head->flist);
|
|
||||||
tp->root = head;
|
|
||||||
}
|
|
||||||
|
|
||||||
f = kzalloc(sizeof(*f), GFP_KERNEL);
|
f = kzalloc(sizeof(*f), GFP_KERNEL);
|
||||||
if (f == NULL)
|
if (f == NULL)
|
||||||
goto errout;
|
goto errout;
|
||||||
|
Loading…
Reference in New Issue
Block a user