patch-2.2.19 linux/drivers/net/cs89x0.c
Next file: linux/drivers/net/eepro100.c
Previous file: linux/drivers/net/cosa.c
Back to the patch index
Back to the overall index
- Lines: 74
- Date:
Sun Mar 25 11:37:34 2001
- Orig file:
v2.2.18/drivers/net/cs89x0.c
- Orig date:
Sun Mar 25 11:12:50 2001
diff -u --new-file --recursive --exclude-from /usr/src/exclude v2.2.18/drivers/net/cs89x0.c linux/drivers/net/cs89x0.c
@@ -27,6 +27,8 @@
: is running from all accounts.
Alan Cox : Removed 1.2 support, added 2.1 extra counters.
+
+ Arnaldo Melo : release resources on failure in cs89x0_probe1
*/
static char *version =
@@ -249,13 +251,17 @@
struct net_local *lp;
static unsigned version_printed = 0;
int i;
+ char priv_alloced_here = 0;
unsigned rev_type = 0;
int eeprom_buff[CHKSUM_LEN];
/* Initialize the device structure. */
if (dev->priv == NULL) {
dev->priv = kmalloc(sizeof(struct net_local), GFP_KERNEL);
+ if (!dev->priv)
+ return -ENOMEM;
memset(dev->priv, 0, sizeof(struct net_local));
+ priv_alloced_here = 1;
}
lp = (struct net_local *)dev->priv;
@@ -265,12 +271,12 @@
if (ioaddr & 1) {
ioaddr &= ~1;
if ((inw(ioaddr + ADD_PORT) & ADD_MASK) != ADD_SIG)
- return ENODEV;
+ goto err;
outw(PP_ChipID, ioaddr + ADD_PORT);
}
if (inw(ioaddr + DATA_PORT) != CHIP_EISA_ID_SIG)
- return ENODEV;
+ goto err;
/* Fill in the 'dev' fields. */
dev->base_addr = ioaddr;
@@ -388,6 +394,11 @@
printk("\n");
return 0;
+err: if (priv_alloced_here) {
+ kfree(dev->priv);
+ dev->priv = NULL;
+ }
+ return -ENODEV;
}
@@ -1007,16 +1018,15 @@
MODULE_PARM(io, "i");
MODULE_PARM(irq, "i");
MODULE_PARM(debug, "i");
-MODULE_PARM(media, "s");
+MODULE_PARM(media, "c8");
MODULE_PARM(duplex, "i");
EXPORT_NO_SYMBOLS;
/*
-* media=t - specify media type
- or media=2
+* media=rj45 - specify media type
+ or media=bnc
or media=aui
- or medai=auto
* duplex=0 - specify forced half/full/autonegotiate duplex
* debug=# - debug level
FUNET's LINUX-ADM group, linux-adm@nic.funet.fi
TCL-scripts by Sam Shen (who was at: slshen@lbl.gov)