net: sched: atm: dont intepret cls results when asked to drop
[ Upstream commita2965c7be0] If asked to drop a packet via TC_ACT_SHOT it is unsafe to assume res.class contains a valid pointer Fixes:b0188d4dbe("[NET_SCHED]: sch_atm: Lindent") Signed-off-by: Jamal Hadi Salim <jhs@mojatatu.com> Signed-off-by: David S. Miller <davem@davemloft.net> Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
parent
f4a2ad1002
commit
5f65f48516
1 changed files with 4 additions and 1 deletions
|
|
@ -396,10 +396,13 @@ static int atm_tc_enqueue(struct sk_buff *skb, struct Qdisc *sch,
|
|||
result = tcf_classify(skb, fl, &res, true);
|
||||
if (result < 0)
|
||||
continue;
|
||||
if (result == TC_ACT_SHOT)
|
||||
goto done;
|
||||
|
||||
flow = (struct atm_flow_data *)res.class;
|
||||
if (!flow)
|
||||
flow = lookup_flow(sch, res.classid);
|
||||
goto done;
|
||||
goto drop;
|
||||
}
|
||||
}
|
||||
flow = NULL;
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue