diff options
author | Dominik Brodowski <linux@dominikbrodowski.net> | 2006-03-31 10:26:06 -0500 |
---|---|---|
committer | Dominik Brodowski <linux@dominikbrodowski.net> | 2006-03-31 10:26:06 -0500 |
commit | 15b99ac1729503db9e6dc642a50b9b6cb3bf51f9 (patch) | |
tree | cfb8897487beba502aac2b28bc35066a87e34299 /drivers/net/pcmcia/ibmtr_cs.c | |
parent | fba395eee7d3f342ca739c20f5b3ee635d0420a0 (diff) |
[PATCH] pcmcia: add return value to _config() functions
Most of the driver initialization isn't done in the .probe function, but in
the internal _config() functions. Make them return a value, so that .probe
can properly report whether the probing of the device succeeded or not.
Signed-off-by: Dominik Brodowski <linux@dominikbrodowski.net>
Diffstat (limited to 'drivers/net/pcmcia/ibmtr_cs.c')
-rw-r--r-- | drivers/net/pcmcia/ibmtr_cs.c | 11 |
1 files changed, 5 insertions, 6 deletions
diff --git a/drivers/net/pcmcia/ibmtr_cs.c b/drivers/net/pcmcia/ibmtr_cs.c index 1b8b44dc4c5..e038d9278a5 100644 --- a/drivers/net/pcmcia/ibmtr_cs.c +++ b/drivers/net/pcmcia/ibmtr_cs.c | |||
@@ -105,7 +105,7 @@ MODULE_LICENSE("GPL"); | |||
105 | 105 | ||
106 | /*====================================================================*/ | 106 | /*====================================================================*/ |
107 | 107 | ||
108 | static void ibmtr_config(struct pcmcia_device *link); | 108 | static int ibmtr_config(struct pcmcia_device *link); |
109 | static void ibmtr_hw_setup(struct net_device *dev, u_int mmiobase); | 109 | static void ibmtr_hw_setup(struct net_device *dev, u_int mmiobase); |
110 | static void ibmtr_release(struct pcmcia_device *link); | 110 | static void ibmtr_release(struct pcmcia_device *link); |
111 | static void ibmtr_detach(struct pcmcia_device *p_dev); | 111 | static void ibmtr_detach(struct pcmcia_device *p_dev); |
@@ -174,9 +174,7 @@ static int ibmtr_attach(struct pcmcia_device *link) | |||
174 | SET_ETHTOOL_OPS(dev, &netdev_ethtool_ops); | 174 | SET_ETHTOOL_OPS(dev, &netdev_ethtool_ops); |
175 | 175 | ||
176 | link->state |= DEV_PRESENT; | 176 | link->state |= DEV_PRESENT; |
177 | ibmtr_config(link); | 177 | return ibmtr_config(link); |
178 | |||
179 | return 0; | ||
180 | } /* ibmtr_attach */ | 178 | } /* ibmtr_attach */ |
181 | 179 | ||
182 | /*====================================================================== | 180 | /*====================================================================== |
@@ -220,7 +218,7 @@ static void ibmtr_detach(struct pcmcia_device *link) | |||
220 | #define CS_CHECK(fn, ret) \ | 218 | #define CS_CHECK(fn, ret) \ |
221 | do { last_fn = (fn); if ((last_ret = (ret)) != 0) goto cs_failed; } while (0) | 219 | do { last_fn = (fn); if ((last_ret = (ret)) != 0) goto cs_failed; } while (0) |
222 | 220 | ||
223 | static void ibmtr_config(struct pcmcia_device *link) | 221 | static int ibmtr_config(struct pcmcia_device *link) |
224 | { | 222 | { |
225 | ibmtr_dev_t *info = link->priv; | 223 | ibmtr_dev_t *info = link->priv; |
226 | struct net_device *dev = info->dev; | 224 | struct net_device *dev = info->dev; |
@@ -323,12 +321,13 @@ static void ibmtr_config(struct pcmcia_device *link) | |||
323 | for (i = 0; i < TR_ALEN; i++) | 321 | for (i = 0; i < TR_ALEN; i++) |
324 | printk("%02X", dev->dev_addr[i]); | 322 | printk("%02X", dev->dev_addr[i]); |
325 | printk("\n"); | 323 | printk("\n"); |
326 | return; | 324 | return 0; |
327 | 325 | ||
328 | cs_failed: | 326 | cs_failed: |
329 | cs_error(link, last_fn, last_ret); | 327 | cs_error(link, last_fn, last_ret); |
330 | failed: | 328 | failed: |
331 | ibmtr_release(link); | 329 | ibmtr_release(link); |
330 | return -ENODEV; | ||
332 | } /* ibmtr_config */ | 331 | } /* ibmtr_config */ |
333 | 332 | ||
334 | /*====================================================================== | 333 | /*====================================================================== |