]> git.neil.brown.name Git - history.git/commitdiff
[PATCH] xircom init cleanups
authorDave Jones <davej@codemonkey.org.uk>
Sun, 25 May 2003 19:22:40 +0000 (15:22 -0400)
committerJeff Garzik <jgarzik@redhat.com>
Sun, 25 May 2003 19:22:40 +0000 (15:22 -0400)
drivers/net/tulip/xircom_cb.c

index 6aed1c21e642bdcb86519abb76752103607bc9e2..adc00edc3e0d1de46489ce0f833f96be640375f6 100644 (file)
@@ -243,38 +243,29 @@ static int __devinit xircom_probe(struct pci_dev *pdev, const struct pci_device_
                return -ENODEV;
        }
 
-       
        /* 
           Before changing the hardware, allocate the memory.
           This way, we can fail gracefully if not enough memory
           is available. 
         */
-       private = kmalloc(sizeof(*private),GFP_KERNEL);
-       memset(private, 0, sizeof(struct xircom_private));
+       if ((dev = init_etherdev(NULL, sizeof(struct xircom_private))) == NULL) {
+               printk(KERN_ERR "xircom_probe: failed to allocate etherdev\n");
+               goto device_fail;
+       }
+       private = dev->priv;
        
        /* Allocate the send/receive buffers */
        private->rx_buffer = pci_alloc_consistent(pdev,8192,&private->rx_dma_handle);
-       
        if (private->rx_buffer == NULL) {
                printk(KERN_ERR "xircom_probe: no memory for rx buffer \n");
-               kfree(private);
-               return -ENODEV;
+               goto rx_buf_fail;
        }       
        private->tx_buffer = pci_alloc_consistent(pdev,8192,&private->tx_dma_handle);
        if (private->tx_buffer == NULL) {
                printk(KERN_ERR "xircom_probe: no memory for tx buffer \n");
-               kfree(private->rx_buffer);
-               kfree(private);
-               return -ENODEV;
-       }
-       dev = init_etherdev(dev, 0);
-       if (dev == NULL) {
-               printk(KERN_ERR "xircom_probe: failed to allocate etherdev\n");
-               kfree(private->rx_buffer);
-               kfree(private->tx_buffer);
-               kfree(private);
-               return -ENODEV;
+               goto tx_buf_fail;
        }
+
        SET_MODULE_OWNER(dev);
        SET_NETDEV_DEV(dev, &pdev->dev);
        printk(KERN_INFO "%s: Xircom cardbus revision %i at irq %i \n", dev->name, chip_rev, pdev->irq);
@@ -305,14 +296,21 @@ static int __devinit xircom_probe(struct pci_dev *pdev, const struct pci_device_
        transceiver_voodoo(private);
        
        spin_lock_irqsave(&private->lock,flags);
-         activate_transmitter(private);
-         activate_receiver(private);
+       activate_transmitter(private);
+       activate_receiver(private);
        spin_unlock_irqrestore(&private->lock,flags);
        
        trigger_receive(private);
        
        leave("xircom_probe");
        return 0;
+
+tx_buf_fail:
+       kfree(private->rx_buffer);
+rx_buf_fail:
+       kfree(dev);
+device_fail:
+       return -ENODEV;
 }
 
 
@@ -337,7 +335,6 @@ static void __devexit xircom_remove(struct pci_dev *pdev)
                                pci_free_consistent(pdev,8192,card->tx_buffer,card->tx_dma_handle);
                        card->tx_buffer = NULL;                 
                }
-               kfree(card);
        }
        release_region(dev->base_addr, 128);
        unregister_netdev(dev);