* 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