diff options
author | Dominik Brodowski <linux@dominikbrodowski.net> | 2006-01-15 03:32:39 -0500 |
---|---|---|
committer | Dominik Brodowski <linux@dominikbrodowski.net> | 2006-03-31 10:15:50 -0500 |
commit | 5f2a71fcb7995633b335a1e380ac63a968e61320 (patch) | |
tree | d47f4227d314fc9f298b75c217fa78440004e6e7 /drivers/net | |
parent | 1de9cedfbdff1d8adb662cd3afc5bda66e393351 (diff) |
[PATCH] pcmcia: add pcmcia_disable_device
pcmcia_disable_device(struct pcmcia_device *p_dev) performs the necessary
cleanups upon device or driver removal: it calls the appropriate
pcmcia_release_* functions, and can replace (most) of the current drivers'
_release() functions.
Signed-off-by: Dominik Brodowski <linux@dominikbrodowski.net>
Diffstat (limited to 'drivers/net')
-rw-r--r-- | drivers/net/pcmcia/3c574_cs.c | 8 | ||||
-rw-r--r-- | drivers/net/pcmcia/3c589_cs.c | 8 | ||||
-rw-r--r-- | drivers/net/pcmcia/axnet_cs.c | 8 | ||||
-rw-r--r-- | drivers/net/pcmcia/com20020_cs.c | 12 | ||||
-rw-r--r-- | drivers/net/pcmcia/fmvj18x_cs.c | 12 | ||||
-rw-r--r-- | drivers/net/pcmcia/ibmtr_cs.c | 23 | ||||
-rw-r--r-- | drivers/net/pcmcia/nmclan_cs.c | 10 | ||||
-rw-r--r-- | drivers/net/pcmcia/pcnet_cs.c | 15 | ||||
-rw-r--r-- | drivers/net/pcmcia/smc91c92_cs.c | 21 | ||||
-rw-r--r-- | drivers/net/pcmcia/xirc2ps_cs.c | 22 | ||||
-rw-r--r-- | drivers/net/wireless/airo_cs.c | 19 | ||||
-rw-r--r-- | drivers/net/wireless/atmel_cs.c | 21 | ||||
-rw-r--r-- | drivers/net/wireless/hostap/hostap_cs.c | 11 | ||||
-rw-r--r-- | drivers/net/wireless/netwave_cs.c | 19 | ||||
-rw-r--r-- | drivers/net/wireless/orinoco_cs.c | 8 | ||||
-rw-r--r-- | drivers/net/wireless/spectrum_cs.c | 8 | ||||
-rw-r--r-- | drivers/net/wireless/wavelan_cs.c | 18 | ||||
-rw-r--r-- | drivers/net/wireless/wl3501_cs.c | 10 |
18 files changed, 62 insertions, 191 deletions
diff --git a/drivers/net/pcmcia/3c574_cs.c b/drivers/net/pcmcia/3c574_cs.c index ce90becb8bdf..1799660bdc67 100644 --- a/drivers/net/pcmcia/3c574_cs.c +++ b/drivers/net/pcmcia/3c574_cs.c | |||
@@ -511,13 +511,7 @@ failed: | |||
511 | 511 | ||
512 | static void tc574_release(dev_link_t *link) | 512 | static void tc574_release(dev_link_t *link) |
513 | { | 513 | { |
514 | DEBUG(0, "3c574_release(0x%p)\n", link); | 514 | pcmcia_disable_device(link->handle); |
515 | |||
516 | pcmcia_release_configuration(link->handle); | ||
517 | pcmcia_release_io(link->handle, &link->io); | ||
518 | pcmcia_release_irq(link->handle, &link->irq); | ||
519 | |||
520 | link->state &= ~DEV_CONFIG; | ||
521 | } | 515 | } |
522 | 516 | ||
523 | static int tc574_suspend(struct pcmcia_device *p_dev) | 517 | static int tc574_suspend(struct pcmcia_device *p_dev) |
diff --git a/drivers/net/pcmcia/3c589_cs.c b/drivers/net/pcmcia/3c589_cs.c index 3dba50849da7..e36153851793 100644 --- a/drivers/net/pcmcia/3c589_cs.c +++ b/drivers/net/pcmcia/3c589_cs.c | |||
@@ -386,13 +386,7 @@ failed: | |||
386 | 386 | ||
387 | static void tc589_release(dev_link_t *link) | 387 | static void tc589_release(dev_link_t *link) |
388 | { | 388 | { |
389 | DEBUG(0, "3c589_release(0x%p)\n", link); | 389 | pcmcia_disable_device(link->handle); |
390 | |||
391 | pcmcia_release_configuration(link->handle); | ||
392 | pcmcia_release_io(link->handle, &link->io); | ||
393 | pcmcia_release_irq(link->handle, &link->irq); | ||
394 | |||
395 | link->state &= ~DEV_CONFIG; | ||
396 | } | 390 | } |
397 | 391 | ||
398 | static int tc589_suspend(struct pcmcia_device *p_dev) | 392 | static int tc589_suspend(struct pcmcia_device *p_dev) |
diff --git a/drivers/net/pcmcia/axnet_cs.c b/drivers/net/pcmcia/axnet_cs.c index 1cc94b2d76c1..9b9c0f19b21c 100644 --- a/drivers/net/pcmcia/axnet_cs.c +++ b/drivers/net/pcmcia/axnet_cs.c | |||
@@ -456,13 +456,7 @@ failed: | |||
456 | 456 | ||
457 | static void axnet_release(dev_link_t *link) | 457 | static void axnet_release(dev_link_t *link) |
458 | { | 458 | { |
459 | DEBUG(0, "axnet_release(0x%p)\n", link); | 459 | pcmcia_disable_device(link->handle); |
460 | |||
461 | pcmcia_release_configuration(link->handle); | ||
462 | pcmcia_release_io(link->handle, &link->io); | ||
463 | pcmcia_release_irq(link->handle, &link->irq); | ||
464 | |||
465 | link->state &= ~DEV_CONFIG; | ||
466 | } | 460 | } |
467 | 461 | ||
468 | static int axnet_suspend(struct pcmcia_device *p_dev) | 462 | static int axnet_suspend(struct pcmcia_device *p_dev) |
diff --git a/drivers/net/pcmcia/com20020_cs.c b/drivers/net/pcmcia/com20020_cs.c index 2827a48ea37c..a0ec5e7aacc6 100644 --- a/drivers/net/pcmcia/com20020_cs.c +++ b/drivers/net/pcmcia/com20020_cs.c | |||
@@ -377,16 +377,8 @@ failed: | |||
377 | 377 | ||
378 | static void com20020_release(dev_link_t *link) | 378 | static void com20020_release(dev_link_t *link) |
379 | { | 379 | { |
380 | 380 | DEBUG(0, "com20020_release(0x%p)\n", link); | |
381 | DEBUG(1,"release...\n"); | 381 | pcmcia_disable_device(link->handle); |
382 | |||
383 | DEBUG(0, "com20020_release(0x%p)\n", link); | ||
384 | |||
385 | pcmcia_release_configuration(link->handle); | ||
386 | pcmcia_release_io(link->handle, &link->io); | ||
387 | pcmcia_release_irq(link->handle, &link->irq); | ||
388 | |||
389 | link->state &= ~(DEV_CONFIG | DEV_RELEASE_PENDING); | ||
390 | } | 382 | } |
391 | 383 | ||
392 | static int com20020_suspend(struct pcmcia_device *p_dev) | 384 | static int com20020_suspend(struct pcmcia_device *p_dev) |
diff --git a/drivers/net/pcmcia/fmvj18x_cs.c b/drivers/net/pcmcia/fmvj18x_cs.c index b7ac14ba8877..6b435e940607 100644 --- a/drivers/net/pcmcia/fmvj18x_cs.c +++ b/drivers/net/pcmcia/fmvj18x_cs.c | |||
@@ -674,16 +674,8 @@ static int fmvj18x_setup_mfc(dev_link_t *link) | |||
674 | 674 | ||
675 | static void fmvj18x_release(dev_link_t *link) | 675 | static void fmvj18x_release(dev_link_t *link) |
676 | { | 676 | { |
677 | 677 | DEBUG(0, "fmvj18x_release(0x%p)\n", link); | |
678 | DEBUG(0, "fmvj18x_release(0x%p)\n", link); | 678 | pcmcia_disable_device(link->handle); |
679 | |||
680 | /* Don't bother checking to see if these succeed or not */ | ||
681 | pcmcia_release_window(link->win); | ||
682 | pcmcia_release_configuration(link->handle); | ||
683 | pcmcia_release_io(link->handle, &link->io); | ||
684 | pcmcia_release_irq(link->handle, &link->irq); | ||
685 | |||
686 | link->state &= ~DEV_CONFIG; | ||
687 | } | 679 | } |
688 | 680 | ||
689 | static int fmvj18x_suspend(struct pcmcia_device *p_dev) | 681 | static int fmvj18x_suspend(struct pcmcia_device *p_dev) |
diff --git a/drivers/net/pcmcia/ibmtr_cs.c b/drivers/net/pcmcia/ibmtr_cs.c index b9c7e39576f5..1948a0bc198d 100644 --- a/drivers/net/pcmcia/ibmtr_cs.c +++ b/drivers/net/pcmcia/ibmtr_cs.c | |||
@@ -348,22 +348,17 @@ failed: | |||
348 | 348 | ||
349 | static void ibmtr_release(dev_link_t *link) | 349 | static void ibmtr_release(dev_link_t *link) |
350 | { | 350 | { |
351 | ibmtr_dev_t *info = link->priv; | 351 | ibmtr_dev_t *info = link->priv; |
352 | struct net_device *dev = info->dev; | 352 | struct net_device *dev = info->dev; |
353 | |||
354 | DEBUG(0, "ibmtr_release(0x%p)\n", link); | ||
355 | 353 | ||
356 | pcmcia_release_configuration(link->handle); | 354 | DEBUG(0, "ibmtr_release(0x%p)\n", link); |
357 | pcmcia_release_io(link->handle, &link->io); | ||
358 | pcmcia_release_irq(link->handle, &link->irq); | ||
359 | if (link->win) { | ||
360 | struct tok_info *ti = netdev_priv(dev); | ||
361 | iounmap(ti->mmio); | ||
362 | pcmcia_release_window(link->win); | ||
363 | pcmcia_release_window(info->sram_win_handle); | ||
364 | } | ||
365 | 355 | ||
366 | link->state &= ~DEV_CONFIG; | 356 | if (link->win) { |
357 | struct tok_info *ti = netdev_priv(dev); | ||
358 | iounmap(ti->mmio); | ||
359 | pcmcia_release_window(info->sram_win_handle); | ||
360 | } | ||
361 | pcmcia_disable_device(link->handle); | ||
367 | } | 362 | } |
368 | 363 | ||
369 | static int ibmtr_suspend(struct pcmcia_device *p_dev) | 364 | static int ibmtr_suspend(struct pcmcia_device *p_dev) |
diff --git a/drivers/net/pcmcia/nmclan_cs.c b/drivers/net/pcmcia/nmclan_cs.c index 787176c57fd9..76ef453d172d 100644 --- a/drivers/net/pcmcia/nmclan_cs.c +++ b/drivers/net/pcmcia/nmclan_cs.c | |||
@@ -765,14 +765,8 @@ nmclan_release | |||
765 | ---------------------------------------------------------------------------- */ | 765 | ---------------------------------------------------------------------------- */ |
766 | static void nmclan_release(dev_link_t *link) | 766 | static void nmclan_release(dev_link_t *link) |
767 | { | 767 | { |
768 | 768 | DEBUG(0, "nmclan_release(0x%p)\n", link); | |
769 | DEBUG(0, "nmclan_release(0x%p)\n", link); | 769 | pcmcia_disable_device(link->handle); |
770 | |||
771 | pcmcia_release_configuration(link->handle); | ||
772 | pcmcia_release_io(link->handle, &link->io); | ||
773 | pcmcia_release_irq(link->handle, &link->irq); | ||
774 | |||
775 | link->state &= ~DEV_CONFIG; | ||
776 | } | 770 | } |
777 | 771 | ||
778 | static int nmclan_suspend(struct pcmcia_device *p_dev) | 772 | static int nmclan_suspend(struct pcmcia_device *p_dev) |
diff --git a/drivers/net/pcmcia/pcnet_cs.c b/drivers/net/pcmcia/pcnet_cs.c index b46e5f703efa..52f44bdff1f7 100644 --- a/drivers/net/pcmcia/pcnet_cs.c +++ b/drivers/net/pcmcia/pcnet_cs.c | |||
@@ -732,19 +732,14 @@ failed: | |||
732 | 732 | ||
733 | static void pcnet_release(dev_link_t *link) | 733 | static void pcnet_release(dev_link_t *link) |
734 | { | 734 | { |
735 | pcnet_dev_t *info = PRIV(link->priv); | 735 | pcnet_dev_t *info = PRIV(link->priv); |
736 | 736 | ||
737 | DEBUG(0, "pcnet_release(0x%p)\n", link); | 737 | DEBUG(0, "pcnet_release(0x%p)\n", link); |
738 | 738 | ||
739 | if (info->flags & USE_SHMEM) { | 739 | if (info->flags & USE_SHMEM) |
740 | iounmap(info->base); | 740 | iounmap(info->base); |
741 | pcmcia_release_window(link->win); | ||
742 | } | ||
743 | pcmcia_release_configuration(link->handle); | ||
744 | pcmcia_release_io(link->handle, &link->io); | ||
745 | pcmcia_release_irq(link->handle, &link->irq); | ||
746 | 741 | ||
747 | link->state &= ~DEV_CONFIG; | 742 | pcmcia_disable_device(link->handle); |
748 | } | 743 | } |
749 | 744 | ||
750 | /*====================================================================== | 745 | /*====================================================================== |
diff --git a/drivers/net/pcmcia/smc91c92_cs.c b/drivers/net/pcmcia/smc91c92_cs.c index 8839c4faafd6..56700b154d44 100644 --- a/drivers/net/pcmcia/smc91c92_cs.c +++ b/drivers/net/pcmcia/smc91c92_cs.c | |||
@@ -1181,20 +1181,13 @@ config_failed: /* CS_EXIT_TEST() calls jump to here... */ | |||
1181 | 1181 | ||
1182 | static void smc91c92_release(dev_link_t *link) | 1182 | static void smc91c92_release(dev_link_t *link) |
1183 | { | 1183 | { |
1184 | 1184 | DEBUG(0, "smc91c92_release(0x%p)\n", link); | |
1185 | DEBUG(0, "smc91c92_release(0x%p)\n", link); | 1185 | if (link->win) { |
1186 | 1186 | struct net_device *dev = link->priv; | |
1187 | pcmcia_release_configuration(link->handle); | 1187 | struct smc_private *smc = netdev_priv(dev); |
1188 | pcmcia_release_io(link->handle, &link->io); | 1188 | iounmap(smc->base); |
1189 | pcmcia_release_irq(link->handle, &link->irq); | 1189 | } |
1190 | if (link->win) { | 1190 | pcmcia_disable_device(link->handle); |
1191 | struct net_device *dev = link->priv; | ||
1192 | struct smc_private *smc = netdev_priv(dev); | ||
1193 | iounmap(smc->base); | ||
1194 | pcmcia_release_window(link->win); | ||
1195 | } | ||
1196 | |||
1197 | link->state &= ~DEV_CONFIG; | ||
1198 | } | 1191 | } |
1199 | 1192 | ||
1200 | /*====================================================================== | 1193 | /*====================================================================== |
diff --git a/drivers/net/pcmcia/xirc2ps_cs.c b/drivers/net/pcmcia/xirc2ps_cs.c index eed496803fe4..2b57a87371f3 100644 --- a/drivers/net/pcmcia/xirc2ps_cs.c +++ b/drivers/net/pcmcia/xirc2ps_cs.c | |||
@@ -1090,21 +1090,15 @@ xirc2ps_config(dev_link_t * link) | |||
1090 | static void | 1090 | static void |
1091 | xirc2ps_release(dev_link_t *link) | 1091 | xirc2ps_release(dev_link_t *link) |
1092 | { | 1092 | { |
1093 | DEBUG(0, "release(0x%p)\n", link); | ||
1093 | 1094 | ||
1094 | DEBUG(0, "release(0x%p)\n", link); | 1095 | if (link->win) { |
1095 | 1096 | struct net_device *dev = link->priv; | |
1096 | if (link->win) { | 1097 | local_info_t *local = netdev_priv(dev); |
1097 | struct net_device *dev = link->priv; | 1098 | if (local->dingo) |
1098 | local_info_t *local = netdev_priv(dev); | 1099 | iounmap(local->dingo_ccr - 0x0800); |
1099 | if (local->dingo) | 1100 | } |
1100 | iounmap(local->dingo_ccr - 0x0800); | 1101 | pcmcia_disable_device(link->handle); |
1101 | pcmcia_release_window(link->win); | ||
1102 | } | ||
1103 | pcmcia_release_configuration(link->handle); | ||
1104 | pcmcia_release_io(link->handle, &link->io); | ||
1105 | pcmcia_release_irq(link->handle, &link->irq); | ||
1106 | link->state &= ~DEV_CONFIG; | ||
1107 | |||
1108 | } /* xirc2ps_release */ | 1102 | } /* xirc2ps_release */ |
1109 | 1103 | ||
1110 | /*====================================================================*/ | 1104 | /*====================================================================*/ |
diff --git a/drivers/net/wireless/airo_cs.c b/drivers/net/wireless/airo_cs.c index a496460ce224..489ef7f3d950 100644 --- a/drivers/net/wireless/airo_cs.c +++ b/drivers/net/wireless/airo_cs.c | |||
@@ -429,24 +429,7 @@ static void airo_config(dev_link_t *link) | |||
429 | static void airo_release(dev_link_t *link) | 429 | static void airo_release(dev_link_t *link) |
430 | { | 430 | { |
431 | DEBUG(0, "airo_release(0x%p)\n", link); | 431 | DEBUG(0, "airo_release(0x%p)\n", link); |
432 | 432 | pcmcia_disable_device(link->handle); | |
433 | /* Unlink the device chain */ | ||
434 | link->dev = NULL; | ||
435 | |||
436 | /* | ||
437 | In a normal driver, additional code may be needed to release | ||
438 | other kernel data structures associated with this device. | ||
439 | */ | ||
440 | |||
441 | /* Don't bother checking to see if these succeed or not */ | ||
442 | if (link->win) | ||
443 | pcmcia_release_window(link->win); | ||
444 | pcmcia_release_configuration(link->handle); | ||
445 | if (link->io.NumPorts1) | ||
446 | pcmcia_release_io(link->handle, &link->io); | ||
447 | if (link->irq.AssignedIRQ) | ||
448 | pcmcia_release_irq(link->handle, &link->irq); | ||
449 | link->state &= ~DEV_CONFIG; | ||
450 | } | 433 | } |
451 | 434 | ||
452 | static int airo_suspend(struct pcmcia_device *p_dev) | 435 | static int airo_suspend(struct pcmcia_device *p_dev) |
diff --git a/drivers/net/wireless/atmel_cs.c b/drivers/net/wireless/atmel_cs.c index d6f4a5a3e55a..1da8e6197ffb 100644 --- a/drivers/net/wireless/atmel_cs.c +++ b/drivers/net/wireless/atmel_cs.c | |||
@@ -418,23 +418,14 @@ static void atmel_config(dev_link_t *link) | |||
418 | static void atmel_release(dev_link_t *link) | 418 | static void atmel_release(dev_link_t *link) |
419 | { | 419 | { |
420 | struct net_device *dev = ((local_info_t*)link->priv)->eth_dev; | 420 | struct net_device *dev = ((local_info_t*)link->priv)->eth_dev; |
421 | 421 | ||
422 | DEBUG(0, "atmel_release(0x%p)\n", link); | 422 | DEBUG(0, "atmel_release(0x%p)\n", link); |
423 | 423 | ||
424 | /* Unlink the device chain */ | 424 | if (dev) |
425 | link->dev = NULL; | ||
426 | |||
427 | if (dev) | ||
428 | stop_atmel_card(dev); | 425 | stop_atmel_card(dev); |
429 | ((local_info_t*)link->priv)->eth_dev = NULL; | 426 | ((local_info_t*)link->priv)->eth_dev = NULL; |
430 | 427 | ||
431 | /* Don't bother checking to see if these succeed or not */ | 428 | pcmcia_disable_device(link->handle); |
432 | pcmcia_release_configuration(link->handle); | ||
433 | if (link->io.NumPorts1) | ||
434 | pcmcia_release_io(link->handle, &link->io); | ||
435 | if (link->irq.AssignedIRQ) | ||
436 | pcmcia_release_irq(link->handle, &link->irq); | ||
437 | link->state &= ~DEV_CONFIG; | ||
438 | } | 429 | } |
439 | 430 | ||
440 | static int atmel_suspend(struct pcmcia_device *dev) | 431 | static int atmel_suspend(struct pcmcia_device *dev) |
diff --git a/drivers/net/wireless/hostap/hostap_cs.c b/drivers/net/wireless/hostap/hostap_cs.c index d335b250923a..7a1023f3875b 100644 --- a/drivers/net/wireless/hostap/hostap_cs.c +++ b/drivers/net/wireless/hostap/hostap_cs.c | |||
@@ -804,16 +804,7 @@ static void prism2_release(u_long arg) | |||
804 | iface->local->shutdown = 1; | 804 | iface->local->shutdown = 1; |
805 | } | 805 | } |
806 | 806 | ||
807 | if (link->win) | 807 | pcmcia_disable_device(link->handle); |
808 | pcmcia_release_window(link->win); | ||
809 | pcmcia_release_configuration(link->handle); | ||
810 | if (link->io.NumPorts1) | ||
811 | pcmcia_release_io(link->handle, &link->io); | ||
812 | if (link->irq.AssignedIRQ) | ||
813 | pcmcia_release_irq(link->handle, &link->irq); | ||
814 | |||
815 | link->state &= ~DEV_CONFIG; | ||
816 | |||
817 | PDEBUG(DEBUG_FLOW, "release - done\n"); | 808 | PDEBUG(DEBUG_FLOW, "release - done\n"); |
818 | } | 809 | } |
819 | 810 | ||
diff --git a/drivers/net/wireless/netwave_cs.c b/drivers/net/wireless/netwave_cs.c index 75ce6ddb0cf5..dfb47ac9da50 100644 --- a/drivers/net/wireless/netwave_cs.c +++ b/drivers/net/wireless/netwave_cs.c | |||
@@ -869,21 +869,14 @@ failed: | |||
869 | */ | 869 | */ |
870 | static void netwave_release(dev_link_t *link) | 870 | static void netwave_release(dev_link_t *link) |
871 | { | 871 | { |
872 | struct net_device *dev = link->priv; | 872 | struct net_device *dev = link->priv; |
873 | netwave_private *priv = netdev_priv(dev); | 873 | netwave_private *priv = netdev_priv(dev); |
874 | |||
875 | DEBUG(0, "netwave_release(0x%p)\n", link); | ||
876 | 874 | ||
877 | /* Don't bother checking to see if these succeed or not */ | 875 | DEBUG(0, "netwave_release(0x%p)\n", link); |
878 | if (link->win) { | ||
879 | iounmap(priv->ramBase); | ||
880 | pcmcia_release_window(link->win); | ||
881 | } | ||
882 | pcmcia_release_configuration(link->handle); | ||
883 | pcmcia_release_io(link->handle, &link->io); | ||
884 | pcmcia_release_irq(link->handle, &link->irq); | ||
885 | 876 | ||
886 | link->state &= ~DEV_CONFIG; | 877 | pcmcia_disable_device(link->handle); |
878 | if (link->win) | ||
879 | iounmap(priv->ramBase); | ||
887 | } | 880 | } |
888 | 881 | ||
889 | static int netwave_suspend(struct pcmcia_device *p_dev) | 882 | static int netwave_suspend(struct pcmcia_device *p_dev) |
diff --git a/drivers/net/wireless/orinoco_cs.c b/drivers/net/wireless/orinoco_cs.c index ec6f2a48895b..7fdc4ff55107 100644 --- a/drivers/net/wireless/orinoco_cs.c +++ b/drivers/net/wireless/orinoco_cs.c | |||
@@ -416,13 +416,7 @@ orinoco_cs_release(dev_link_t *link) | |||
416 | priv->hw_unavailable++; | 416 | priv->hw_unavailable++; |
417 | spin_unlock_irqrestore(&priv->lock, flags); | 417 | spin_unlock_irqrestore(&priv->lock, flags); |
418 | 418 | ||
419 | /* Don't bother checking to see if these succeed or not */ | 419 | pcmcia_disable_device(link->handle); |
420 | pcmcia_release_configuration(link->handle); | ||
421 | if (link->io.NumPorts1) | ||
422 | pcmcia_release_io(link->handle, &link->io); | ||
423 | if (link->irq.AssignedIRQ) | ||
424 | pcmcia_release_irq(link->handle, &link->irq); | ||
425 | link->state &= ~DEV_CONFIG; | ||
426 | if (priv->hw.iobase) | 420 | if (priv->hw.iobase) |
427 | ioport_unmap(priv->hw.iobase); | 421 | ioport_unmap(priv->hw.iobase); |
428 | } /* orinoco_cs_release */ | 422 | } /* orinoco_cs_release */ |
diff --git a/drivers/net/wireless/spectrum_cs.c b/drivers/net/wireless/spectrum_cs.c index 5fa6fbe35bb9..78320c1a1c15 100644 --- a/drivers/net/wireless/spectrum_cs.c +++ b/drivers/net/wireless/spectrum_cs.c | |||
@@ -894,13 +894,7 @@ spectrum_cs_release(dev_link_t *link) | |||
894 | priv->hw_unavailable++; | 894 | priv->hw_unavailable++; |
895 | spin_unlock_irqrestore(&priv->lock, flags); | 895 | spin_unlock_irqrestore(&priv->lock, flags); |
896 | 896 | ||
897 | /* Don't bother checking to see if these succeed or not */ | 897 | pcmcia_disable_device(link->handle); |
898 | pcmcia_release_configuration(link->handle); | ||
899 | if (link->io.NumPorts1) | ||
900 | pcmcia_release_io(link->handle, &link->io); | ||
901 | if (link->irq.AssignedIRQ) | ||
902 | pcmcia_release_irq(link->handle, &link->irq); | ||
903 | link->state &= ~DEV_CONFIG; | ||
904 | if (priv->hw.iobase) | 898 | if (priv->hw.iobase) |
905 | ioport_unmap(priv->hw.iobase); | 899 | ioport_unmap(priv->hw.iobase); |
906 | } /* spectrum_cs_release */ | 900 | } /* spectrum_cs_release */ |
diff --git a/drivers/net/wireless/wavelan_cs.c b/drivers/net/wireless/wavelan_cs.c index 98122f3a4bc2..696aeb9d8f52 100644 --- a/drivers/net/wireless/wavelan_cs.c +++ b/drivers/net/wireless/wavelan_cs.c | |||
@@ -4098,24 +4098,18 @@ wv_pcmcia_config(dev_link_t * link) | |||
4098 | static void | 4098 | static void |
4099 | wv_pcmcia_release(dev_link_t *link) | 4099 | wv_pcmcia_release(dev_link_t *link) |
4100 | { | 4100 | { |
4101 | struct net_device * dev = (struct net_device *) link->priv; | 4101 | struct net_device * dev = (struct net_device *) link->priv; |
4102 | net_local * lp = netdev_priv(dev); | 4102 | net_local * lp = netdev_priv(dev); |
4103 | 4103 | ||
4104 | #ifdef DEBUG_CONFIG_TRACE | 4104 | #ifdef DEBUG_CONFIG_TRACE |
4105 | printk(KERN_DEBUG "%s: -> wv_pcmcia_release(0x%p)\n", dev->name, link); | 4105 | printk(KERN_DEBUG "%s: -> wv_pcmcia_release(0x%p)\n", dev->name, link); |
4106 | #endif | 4106 | #endif |
4107 | 4107 | ||
4108 | /* Don't bother checking to see if these succeed or not */ | 4108 | iounmap(lp->mem); |
4109 | iounmap(lp->mem); | 4109 | pcmcia_disable_device(link->handle); |
4110 | pcmcia_release_window(link->win); | ||
4111 | pcmcia_release_configuration(link->handle); | ||
4112 | pcmcia_release_io(link->handle, &link->io); | ||
4113 | pcmcia_release_irq(link->handle, &link->irq); | ||
4114 | |||
4115 | link->state &= ~DEV_CONFIG; | ||
4116 | 4110 | ||
4117 | #ifdef DEBUG_CONFIG_TRACE | 4111 | #ifdef DEBUG_CONFIG_TRACE |
4118 | printk(KERN_DEBUG "%s: <- wv_pcmcia_release()\n", dev->name); | 4112 | printk(KERN_DEBUG "%s: <- wv_pcmcia_release()\n", dev->name); |
4119 | #endif | 4113 | #endif |
4120 | } | 4114 | } |
4121 | 4115 | ||
diff --git a/drivers/net/wireless/wl3501_cs.c b/drivers/net/wireless/wl3501_cs.c index 48e10b0c7e74..0c81b3e7d7ff 100644 --- a/drivers/net/wireless/wl3501_cs.c +++ b/drivers/net/wireless/wl3501_cs.c | |||
@@ -2149,16 +2149,10 @@ static void wl3501_release(dev_link_t *link) | |||
2149 | struct net_device *dev = link->priv; | 2149 | struct net_device *dev = link->priv; |
2150 | 2150 | ||
2151 | /* Unlink the device chain */ | 2151 | /* Unlink the device chain */ |
2152 | if (link->dev) { | 2152 | if (link->dev) |
2153 | unregister_netdev(dev); | 2153 | unregister_netdev(dev); |
2154 | link->dev = NULL; | ||
2155 | } | ||
2156 | 2154 | ||
2157 | /* Don't bother checking to see if these succeed or not */ | 2155 | pcmcia_disable_device(link->handle); |
2158 | pcmcia_release_configuration(link->handle); | ||
2159 | pcmcia_release_io(link->handle, &link->io); | ||
2160 | pcmcia_release_irq(link->handle, &link->irq); | ||
2161 | link->state &= ~DEV_CONFIG; | ||
2162 | } | 2156 | } |
2163 | 2157 | ||
2164 | static int wl3501_suspend(struct pcmcia_device *p_dev) | 2158 | static int wl3501_suspend(struct pcmcia_device *p_dev) |