mirror of https://gitee.com/openkylin/linux.git
hippi: Fix a Fix a possible sleep-in-atomic bug in rr_close
The driver may sleep under a spinlock. The function call path is: rr_close (acquire the spinlock) free_irq --> may sleep To fix it, free_irq is moved to the place without holding the spinlock. This bug is found by my static analysis tool(DSAC) and checked by my code review. Signed-off-by: Jia-Ju Bai <baijiaju1990@163.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
d6da83813f
commit
6e266610eb
|
@ -1379,8 +1379,8 @@ static int rr_close(struct net_device *dev)
|
||||||
rrpriv->info_dma);
|
rrpriv->info_dma);
|
||||||
rrpriv->info = NULL;
|
rrpriv->info = NULL;
|
||||||
|
|
||||||
free_irq(pdev->irq, dev);
|
|
||||||
spin_unlock_irqrestore(&rrpriv->lock, flags);
|
spin_unlock_irqrestore(&rrpriv->lock, flags);
|
||||||
|
free_irq(pdev->irq, dev);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue