Commit 24abc645 authored by Alexander Viro's avatar Alexander Viro Committed by Jeff Garzik

[PATCH] olympic_open() cleanup and fixes

Signed-off-by: default avatarAl Viro <viro@parcelfarce.linux.theplanet.co.uk>
parent d59386e3
...@@ -438,8 +438,8 @@ static int olympic_open(struct net_device *dev) ...@@ -438,8 +438,8 @@ static int olympic_open(struct net_device *dev)
struct olympic_private *olympic_priv=(struct olympic_private *)dev->priv; struct olympic_private *olympic_priv=(struct olympic_private *)dev->priv;
u8 __iomem *olympic_mmio=olympic_priv->olympic_mmio,*init_srb; u8 __iomem *olympic_mmio=olympic_priv->olympic_mmio,*init_srb;
unsigned long flags, t; unsigned long flags, t;
char open_error[255] ;
int i, open_finished = 1 ; int i, open_finished = 1 ;
u8 resp, err;
DECLARE_WAITQUEUE(wait,current) ; DECLARE_WAITQUEUE(wait,current) ;
...@@ -540,35 +540,33 @@ static int olympic_open(struct net_device *dev) ...@@ -540,35 +540,33 @@ static int olympic_open(struct net_device *dev)
* timed out. * timed out.
*/ */
if(readb(init_srb+2)== OLYMPIC_CLEAR_RET_CODE) { switch (resp = readb(init_srb+2)) {
case OLYMPIC_CLEAR_RET_CODE:
printk(KERN_WARNING "%s: Adapter Open time out or error.\n", dev->name) ; printk(KERN_WARNING "%s: Adapter Open time out or error.\n", dev->name) ;
return -EIO ; goto out;
} case 0:
open_finished = 1;
if(readb(init_srb+2)!=0) { break;
if (readb(init_srb+2) == 0x07) { case 0x07:
if (!olympic_priv->olympic_ring_speed && open_finished) { /* Autosense , first time around */ if (!olympic_priv->olympic_ring_speed && open_finished) { /* Autosense , first time around */
printk(KERN_WARNING "%s: Retrying at different ring speed \n", dev->name); printk(KERN_WARNING "%s: Retrying at different ring speed \n", dev->name);
open_finished = 0 ; open_finished = 0 ;
} else { continue;
}
strcpy(open_error, open_maj_error[(readb(init_srb+7) & 0xf0) >> 4]) ; err = readb(init_srb+7);
strcat(open_error," - ") ;
strcat(open_error, open_min_error[(readb(init_srb+7) & 0x0f)]) ;
if (!olympic_priv->olympic_ring_speed && ((readb(init_srb+7) & 0x0f) == 0x0d)) { if (!olympic_priv->olympic_ring_speed && ((err & 0x0f) == 0x0d)) {
printk(KERN_WARNING "%s: Tried to autosense ring speed with no monitors present\n",dev->name); printk(KERN_WARNING "%s: Tried to autosense ring speed with no monitors present\n",dev->name);
printk(KERN_WARNING "%s: Please try again with a specified ring speed \n",dev->name); printk(KERN_WARNING "%s: Please try again with a specified ring speed \n",dev->name);
free_irq(dev->irq, dev); } else {
return -EIO ; printk(KERN_WARNING "%s: %s - %s\n", dev->name,
open_maj_error[(err & 0xf0) >> 4],
open_min_error[(err & 0x0f)]);
} }
goto out;
printk(KERN_WARNING "%s: %s\n",dev->name,open_error); case 0x32:
free_irq(dev->irq,dev) ;
return -EIO ;
} /* if autosense && open_finished */
} else if (init_srb[2] == 0x32) {
printk(KERN_WARNING "%s: Invalid LAA: %02x:%02x:%02x:%02x:%02x:%02x\n", printk(KERN_WARNING "%s: Invalid LAA: %02x:%02x:%02x:%02x:%02x:%02x\n",
dev->name, dev->name,
olympic_priv->olympic_laa[0], olympic_priv->olympic_laa[0],
...@@ -577,15 +575,13 @@ static int olympic_open(struct net_device *dev) ...@@ -577,15 +575,13 @@ static int olympic_open(struct net_device *dev)
olympic_priv->olympic_laa[3], olympic_priv->olympic_laa[3],
olympic_priv->olympic_laa[4], olympic_priv->olympic_laa[4],
olympic_priv->olympic_laa[5]) ; olympic_priv->olympic_laa[5]) ;
free_irq(dev->irq,dev) ; goto out;
return -EIO ;
} else { default:
printk(KERN_WARNING "%s: Bad OPEN response: %x\n", dev->name,init_srb[2]); printk(KERN_WARNING "%s: Bad OPEN response: %x\n", dev->name, resp);
free_irq(dev->irq, dev); goto out;
return -EIO;
} }
} else
open_finished = 1 ;
} while (!(open_finished)) ; /* Will only loop if ring speed mismatch re-open attempted && autosense is on */ } while (!(open_finished)) ; /* Will only loop if ring speed mismatch re-open attempted && autosense is on */
if (readb(init_srb+18) & (1<<3)) if (readb(init_srb+18) & (1<<3))
...@@ -634,8 +630,7 @@ static int olympic_open(struct net_device *dev) ...@@ -634,8 +630,7 @@ static int olympic_open(struct net_device *dev)
if (i==0) { if (i==0) {
printk(KERN_WARNING "%s: Not enough memory to allocate rx buffers. Adapter disabled\n",dev->name); printk(KERN_WARNING "%s: Not enough memory to allocate rx buffers. Adapter disabled\n",dev->name);
free_irq(dev->irq, dev); goto out;
return -EIO;
} }
olympic_priv->rx_ring_dma_addr = pci_map_single(olympic_priv->pdev,olympic_priv->olympic_rx_ring, olympic_priv->rx_ring_dma_addr = pci_map_single(olympic_priv->pdev,olympic_priv->olympic_rx_ring,
...@@ -738,6 +733,9 @@ static int olympic_open(struct net_device *dev) ...@@ -738,6 +733,9 @@ static int olympic_open(struct net_device *dev)
netif_start_queue(dev); netif_start_queue(dev);
return 0; return 0;
out:
free_irq(dev->irq, dev);
return -EIO;
} }
/* /*
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment