mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2025-01-06 13:55:08 +08:00
misc: st_core: Do not call kfree_skb() under spin_lock_irqsave()
[ Upstream commit4d08c3d12b
] 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 spin_lock_irqsave(). Compile tested only. Fixes:53618cc1e5
("Staging: sources for ST core") Signed-off-by: Jinjie Ruan <ruanjinjie@huawei.com> Link: https://lore.kernel.org/r/20230823035020.1281892-1-ruanjinjie@huawei.com Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org> Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
parent
84f254d901
commit
d2ab1ff309
@ -15,6 +15,7 @@
|
||||
#include <linux/skbuff.h>
|
||||
|
||||
#include <linux/ti_wilink_st.h>
|
||||
#include <linux/netdevice.h>
|
||||
|
||||
/*
|
||||
* function pointer pointing to either,
|
||||
@ -429,7 +430,7 @@ static void st_int_enqueue(struct st_data_s *st_gdata, struct sk_buff *skb)
|
||||
case ST_LL_AWAKE_TO_ASLEEP:
|
||||
pr_err("ST LL is illegal state(%ld),"
|
||||
"purging received skb.", st_ll_getstate(st_gdata));
|
||||
kfree_skb(skb);
|
||||
dev_kfree_skb_irq(skb);
|
||||
break;
|
||||
case ST_LL_ASLEEP:
|
||||
skb_queue_tail(&st_gdata->tx_waitq, skb);
|
||||
@ -438,7 +439,7 @@ static void st_int_enqueue(struct st_data_s *st_gdata, struct sk_buff *skb)
|
||||
default:
|
||||
pr_err("ST LL is illegal state(%ld),"
|
||||
"purging received skb.", st_ll_getstate(st_gdata));
|
||||
kfree_skb(skb);
|
||||
dev_kfree_skb_irq(skb);
|
||||
break;
|
||||
}
|
||||
|
||||
@ -492,7 +493,7 @@ void st_tx_wakeup(struct st_data_s *st_data)
|
||||
spin_unlock_irqrestore(&st_data->lock, flags);
|
||||
break;
|
||||
}
|
||||
kfree_skb(skb);
|
||||
dev_kfree_skb_irq(skb);
|
||||
spin_unlock_irqrestore(&st_data->lock, flags);
|
||||
}
|
||||
/* if wake-up is set in another context- restart sending */
|
||||
|
Loading…
Reference in New Issue
Block a user