[PATCH] sk98lin: error handling on probe

The sk98lin driver doesn't do proper error number handling
during initialization. Note: -EAGAIN is a bogus return value for
hardware errors.

Signed-off-by: Stephen Hemminger <shemminger@osdl.org>
Signed-off-by: Jeff Garzik <jgarzik@pobox.com>
This commit is contained in:
Stephen Hemminger 2006-01-06 16:57:43 -08:00 committed by Jeff Garzik
parent 26fc354914
commit 162875570e
1 changed files with 17 additions and 11 deletions

View File

@ -530,7 +530,7 @@ SK_BOOL DualNet;
if (SkGeInit(pAC, pAC->IoBase, SK_INIT_DATA) != 0) { if (SkGeInit(pAC, pAC->IoBase, SK_INIT_DATA) != 0) {
printk("HWInit (0) failed.\n"); printk("HWInit (0) failed.\n");
spin_unlock_irqrestore(&pAC->SlowPathLock, Flags); spin_unlock_irqrestore(&pAC->SlowPathLock, Flags);
return(-EAGAIN); return -EIO;
} }
SkI2cInit( pAC, pAC->IoBase, SK_INIT_DATA); SkI2cInit( pAC, pAC->IoBase, SK_INIT_DATA);
SkEventInit(pAC, pAC->IoBase, SK_INIT_DATA); SkEventInit(pAC, pAC->IoBase, SK_INIT_DATA);
@ -552,7 +552,7 @@ SK_BOOL DualNet;
if (SkGeInit(pAC, pAC->IoBase, SK_INIT_IO) != 0) { if (SkGeInit(pAC, pAC->IoBase, SK_INIT_IO) != 0) {
printk("sk98lin: HWInit (1) failed.\n"); printk("sk98lin: HWInit (1) failed.\n");
spin_unlock_irqrestore(&pAC->SlowPathLock, Flags); spin_unlock_irqrestore(&pAC->SlowPathLock, Flags);
return(-EAGAIN); return -EIO;
} }
SkI2cInit( pAC, pAC->IoBase, SK_INIT_IO); SkI2cInit( pAC, pAC->IoBase, SK_INIT_IO);
SkEventInit(pAC, pAC->IoBase, SK_INIT_IO); SkEventInit(pAC, pAC->IoBase, SK_INIT_IO);
@ -584,20 +584,20 @@ SK_BOOL DualNet;
} else { } else {
printk(KERN_WARNING "sk98lin: Illegal number of ports: %d\n", printk(KERN_WARNING "sk98lin: Illegal number of ports: %d\n",
pAC->GIni.GIMacsFound); pAC->GIni.GIMacsFound);
return -EAGAIN; return -EIO;
} }
if (Ret) { if (Ret) {
printk(KERN_WARNING "sk98lin: Requested IRQ %d is busy.\n", printk(KERN_WARNING "sk98lin: Requested IRQ %d is busy.\n",
dev->irq); dev->irq);
return -EAGAIN; return Ret;
} }
pAC->AllocFlag |= SK_ALLOC_IRQ; pAC->AllocFlag |= SK_ALLOC_IRQ;
/* Alloc memory for this board (Mem for RxD/TxD) : */ /* Alloc memory for this board (Mem for RxD/TxD) : */
if(!BoardAllocMem(pAC)) { if(!BoardAllocMem(pAC)) {
printk("No memory for descriptor rings.\n"); printk("No memory for descriptor rings.\n");
return(-EAGAIN); return -ENOMEM;
} }
BoardInitMem(pAC); BoardInitMem(pAC);
@ -613,7 +613,7 @@ SK_BOOL DualNet;
DualNet)) { DualNet)) {
BoardFreeMem(pAC); BoardFreeMem(pAC);
printk("sk98lin: SkGeInitAssignRamToQueues failed.\n"); printk("sk98lin: SkGeInitAssignRamToQueues failed.\n");
return(-EAGAIN); return -EIO;
} }
return (0); return (0);
@ -4800,8 +4800,10 @@ static int __devinit skge_probe_one(struct pci_dev *pdev,
} }
} }
if ((dev = alloc_etherdev(sizeof(DEV_NET))) == NULL) { error = -ENOMEM;
printk(KERN_ERR "Unable to allocate etherdev " dev = alloc_etherdev(sizeof(DEV_NET));
if (!dev) {
printk(KERN_ERR "sk98lin: unable to allocate etherdev "
"structure!\n"); "structure!\n");
goto out_disable_device; goto out_disable_device;
} }
@ -4809,7 +4811,7 @@ static int __devinit skge_probe_one(struct pci_dev *pdev,
pNet = netdev_priv(dev); pNet = netdev_priv(dev);
pNet->pAC = kzalloc(sizeof(SK_AC), GFP_KERNEL); pNet->pAC = kzalloc(sizeof(SK_AC), GFP_KERNEL);
if (!pNet->pAC) { if (!pNet->pAC) {
printk(KERN_ERR "Unable to allocate adapter " printk(KERN_ERR "sk98lin: unable to allocate adapter "
"structure!\n"); "structure!\n");
goto out_free_netdev; goto out_free_netdev;
} }
@ -4822,6 +4824,7 @@ static int __devinit skge_probe_one(struct pci_dev *pdev,
pAC->CheckQueue = SK_FALSE; pAC->CheckQueue = SK_FALSE;
dev->irq = pdev->irq; dev->irq = pdev->irq;
error = SkGeInitPCI(pAC); error = SkGeInitPCI(pAC);
if (error) { if (error) {
printk(KERN_ERR "sk98lin: PCI setup failed: %i\n", error); printk(KERN_ERR "sk98lin: PCI setup failed: %i\n", error);
@ -4861,17 +4864,20 @@ static int __devinit skge_probe_one(struct pci_dev *pdev,
pAC->Index = boards_found++; pAC->Index = boards_found++;
if (SkGeBoardInit(dev, pAC)) error = SkGeBoardInit(dev, pAC);
if (error)
goto out_free_netdev; goto out_free_netdev;
/* Read Adapter name from VPD */ /* Read Adapter name from VPD */
if (ProductStr(pAC, DeviceStr, sizeof(DeviceStr)) != 0) { if (ProductStr(pAC, DeviceStr, sizeof(DeviceStr)) != 0) {
error = -EIO;
printk(KERN_ERR "sk98lin: Could not read VPD data.\n"); printk(KERN_ERR "sk98lin: Could not read VPD data.\n");
goto out_free_resources; goto out_free_resources;
} }
/* Register net device */ /* Register net device */
if (register_netdev(dev)) { error = register_netdev(dev);
if (error) {
printk(KERN_ERR "sk98lin: Could not register device.\n"); printk(KERN_ERR "sk98lin: Could not register device.\n");
goto out_free_resources; goto out_free_resources;
} }