public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* xircom init_etherdev conversion.
@ 2003-03-24 16:41 davej
  2003-03-29  5:02 ` Jeff Garzik
  0 siblings, 1 reply; 4+ messages in thread
From: davej @ 2003-03-24 16:41 UTC (permalink / raw)
  To: jgarzik; +Cc: linux-kernel

- Also cleans up some exit paths.

diff -urpN --exclude-from=/home/davej/.exclude bk-linus/drivers/net/tulip/xircom_cb.c linux-2.5/drivers/net/tulip/xircom_cb.c
--- bk-linus/drivers/net/tulip/xircom_cb.c	2003-03-08 09:57:19.000000000 +0000
+++ linux-2.5/drivers/net/tulip/xircom_cb.c	2003-02-25 14:07:53.000000000 +0000
@@ -249,32 +249,24 @@ static int __devinit xircom_probe(struct
 	   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(dev, 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);
 	printk(KERN_INFO "%s: Xircom cardbus revision %i at irq %i \n", dev->name, chip_rev, pdev->irq);
 
@@ -304,14 +296,21 @@ static int __devinit xircom_probe(struct
 	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;
 }
 
 

^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: xircom init_etherdev conversion.
  2003-03-24 16:41 xircom init_etherdev conversion davej
@ 2003-03-29  5:02 ` Jeff Garzik
  2003-03-29 11:02   ` Dave Jones
  0 siblings, 1 reply; 4+ messages in thread
From: Jeff Garzik @ 2003-03-29  5:02 UTC (permalink / raw)
  To: davej; +Cc: linux-kernel

davej@codemonkey.org.uk wrote:
> - Also cleans up some exit paths.

...and now xircom_remove is kfree'ing memory that was never kmalloc'd


^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: xircom init_etherdev conversion.
  2003-03-29  5:02 ` Jeff Garzik
@ 2003-03-29 11:02   ` Dave Jones
  2003-03-29 13:49     ` Jeff Garzik
  0 siblings, 1 reply; 4+ messages in thread
From: Dave Jones @ 2003-03-29 11:02 UTC (permalink / raw)
  To: Jeff Garzik; +Cc: linux-kernel

On Sat, Mar 29, 2003 at 12:02:57AM -0500, Jeff Garzik wrote:
 > davej@codemonkey.org.uk wrote:
 > >- Also cleans up some exit paths.
 > 
 > ...and now xircom_remove is kfree'ing memory that was never kmalloc'd

Which one ? I don't see it..

		Dave

^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: xircom init_etherdev conversion.
  2003-03-29 11:02   ` Dave Jones
@ 2003-03-29 13:49     ` Jeff Garzik
  0 siblings, 0 replies; 4+ messages in thread
From: Jeff Garzik @ 2003-03-29 13:49 UTC (permalink / raw)
  To: Dave Jones; +Cc: linux-kernel

Dave Jones wrote:
> On Sat, Mar 29, 2003 at 12:02:57AM -0500, Jeff Garzik wrote:
>  > davej@codemonkey.org.uk wrote:
>  > >- Also cleans up some exit paths.
>  > 
>  > ...and now xircom_remove is kfree'ing memory that was never kmalloc'd
> 
> Which one ? I don't see it..

"kfree(card)" here:

                 card=dev->priv;
...
                 kfree(card);
         }
         release_region(dev->base_addr, 128);
         unregister_netdev(dev);
         kfree(dev);
         leave("xircom_remove");



^ permalink raw reply	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2003-03-29 13:37 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2003-03-24 16:41 xircom init_etherdev conversion davej
2003-03-29  5:02 ` Jeff Garzik
2003-03-29 11:02   ` Dave Jones
2003-03-29 13:49     ` Jeff Garzik

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox