mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-10 07:10:27 +00:00
jazzsonic: free irq if sonic_open() fails
jazzsonic_open() doesn't check sonic_open() return code. If it is error we must free requested IRQ. Signed-off-by: Kulikov Vasiliy <segooon@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
84ce981a07
commit
62cd69a106
@ -82,11 +82,20 @@ static unsigned short known_revisions[] =
|
||||
|
||||
static int jazzsonic_open(struct net_device* dev)
|
||||
{
|
||||
if (request_irq(dev->irq, sonic_interrupt, IRQF_DISABLED, "sonic", dev)) {
|
||||
printk(KERN_ERR "%s: unable to get IRQ %d.\n", dev->name, dev->irq);
|
||||
return -EAGAIN;
|
||||
int retval;
|
||||
|
||||
retval = request_irq(dev->irq, sonic_interrupt, IRQF_DISABLED,
|
||||
"sonic", dev);
|
||||
if (retval) {
|
||||
printk(KERN_ERR "%s: unable to get IRQ %d.\n",
|
||||
dev->name, dev->irq);
|
||||
return retval;
|
||||
}
|
||||
return sonic_open(dev);
|
||||
|
||||
retval = sonic_open(dev);
|
||||
if (retval)
|
||||
free_irq(dev->irq, dev);
|
||||
return retval;
|
||||
}
|
||||
|
||||
static int jazzsonic_close(struct net_device* dev)
|
||||
|
Loading…
x
Reference in New Issue
Block a user