diff options
author | Ben Dooks <ben-linux@fluff.org> | 2007-05-07 07:13:25 -0400 |
---|---|---|
committer | Jeff Garzik <jeff@garzik.org> | 2007-05-08 01:15:15 -0400 |
commit | 9fd9f9b669ca71f7b3a7709d02d305c3d428d2fe (patch) | |
tree | a5633e6cb443ad7c51b567f06fa25453e114aa9d /drivers/net/dm9000.c | |
parent | d17ecb23b2e5ca174c0f5ce6be42cb3909a02ed0 (diff) |
DM9000: fix use of kfree() on net device
The DM9000 network driver is calling kfree() on an netdev
causing the system to oops if the probe fails. The right
thing to do is call free_netdev().
Thanks to Russell King for spotting this.
Signed-off-by: Ben Dooks <ben-linux@fluff.org>
Signed-off-by: Jeff Garzik <jeff@garzik.org>
Diffstat (limited to 'drivers/net/dm9000.c')
-rw-r--r-- | drivers/net/dm9000.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/drivers/net/dm9000.c b/drivers/net/dm9000.c index 8cc1174e7f6..0e338539b82 100644 --- a/drivers/net/dm9000.c +++ b/drivers/net/dm9000.c | |||
@@ -601,7 +601,7 @@ dm9000_probe(struct platform_device *pdev) | |||
601 | printk("%s: not found (%d).\n", CARDNAME, ret); | 601 | printk("%s: not found (%d).\n", CARDNAME, ret); |
602 | 602 | ||
603 | dm9000_release_board(pdev, db); | 603 | dm9000_release_board(pdev, db); |
604 | kfree(ndev); | 604 | free_netdev(ndev); |
605 | 605 | ||
606 | return ret; | 606 | return ret; |
607 | } | 607 | } |
@@ -1193,7 +1193,7 @@ dm9000_drv_remove(struct platform_device *pdev) | |||
1193 | 1193 | ||
1194 | unregister_netdev(ndev); | 1194 | unregister_netdev(ndev); |
1195 | dm9000_release_board(pdev, (board_info_t *) ndev->priv); | 1195 | dm9000_release_board(pdev, (board_info_t *) ndev->priv); |
1196 | kfree(ndev); /* free device structure */ | 1196 | free_netdev(ndev); /* free device structure */ |
1197 | 1197 | ||
1198 | PRINTK1("clean_module() exit\n"); | 1198 | PRINTK1("clean_module() exit\n"); |
1199 | 1199 | ||