wilc1000: use wilc handler as cookie in request_threaded_irq()
Use same cookie for request_threaded_irq() & free_irq() to properly free IRQ during module unload. free_irq() already uses *wilc* handler so the changes are required for request_threaded_irq(). Signed-off-by: Ajay Singh <ajay.kathat@microchip.com> Signed-off-by: Kalle Valo <kvalo@codeaurora.org> Link: https://lore.kernel.org/r/20210225042302.17048-1-ajay.kathat@microchip.com
This commit is contained in:
parent
e21b6e5a54
commit
5077369630
@ -24,12 +24,10 @@
|
||||
|
||||
static irqreturn_t isr_uh_routine(int irq, void *user_data)
|
||||
{
|
||||
struct net_device *dev = user_data;
|
||||
struct wilc_vif *vif = netdev_priv(dev);
|
||||
struct wilc *wilc = vif->wilc;
|
||||
struct wilc *wilc = user_data;
|
||||
|
||||
if (wilc->close) {
|
||||
netdev_err(dev, "Can't handle UH interrupt\n");
|
||||
pr_err("Can't handle UH interrupt");
|
||||
return IRQ_HANDLED;
|
||||
}
|
||||
return IRQ_WAKE_THREAD;
|
||||
@ -37,12 +35,10 @@ static irqreturn_t isr_uh_routine(int irq, void *user_data)
|
||||
|
||||
static irqreturn_t isr_bh_routine(int irq, void *userdata)
|
||||
{
|
||||
struct net_device *dev = userdata;
|
||||
struct wilc_vif *vif = netdev_priv(userdata);
|
||||
struct wilc *wilc = vif->wilc;
|
||||
struct wilc *wilc = userdata;
|
||||
|
||||
if (wilc->close) {
|
||||
netdev_err(dev, "Can't handle BH interrupt\n");
|
||||
pr_err("Can't handle BH interrupt\n");
|
||||
return IRQ_HANDLED;
|
||||
}
|
||||
|
||||
@ -60,7 +56,7 @@ static int init_irq(struct net_device *dev)
|
||||
ret = request_threaded_irq(wl->dev_irq_num, isr_uh_routine,
|
||||
isr_bh_routine,
|
||||
IRQF_TRIGGER_FALLING | IRQF_ONESHOT,
|
||||
"WILC_IRQ", dev);
|
||||
"WILC_IRQ", wl);
|
||||
if (ret) {
|
||||
netdev_err(dev, "Failed to request IRQ [%d]\n", ret);
|
||||
return ret;
|
||||
|
Loading…
x
Reference in New Issue
Block a user