net: arcnet: Do not call kfree_skb() under local_irq_disable()
It is not allowed to call kfree_skb() from hardware interrupt
context or with hardware interrupts being disabled.
So replace kfree_skb() with dev_kfree_skb_irq() under
local_irq_disable(). Compile tested only.
Fixes: 05fcd31cc4
("arcnet: add err_skb package for package status feedback")
Signed-off-by: Jinjie Ruan <ruanjinjie@huawei.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
49fa4b0d06
commit
786c96e92f
|
@ -464,7 +464,7 @@ static void arcnet_reply_tasklet(struct tasklet_struct *t)
|
|||
|
||||
ret = sock_queue_err_skb(sk, ackskb);
|
||||
if (ret)
|
||||
kfree_skb(ackskb);
|
||||
dev_kfree_skb_irq(ackskb);
|
||||
|
||||
local_irq_enable();
|
||||
};
|
||||
|
|
Loading…
Reference in New Issue