diff options
author | Dominik Brodowski <linux@dominikbrodowski.net> | 2006-03-01 18:02:33 -0500 |
---|---|---|
committer | Dominik Brodowski <linux@dominikbrodowski.net> | 2006-03-31 10:15:52 -0500 |
commit | 8661bb5b4af1849c1f5a4e80c4e275fd13c155d6 (patch) | |
tree | ad99d85ea8d6f5c4c99b93f869bfd412994fb4ee /drivers/net/pcmcia/axnet_cs.c | |
parent | 50db3fdbbc98260fb538c1cc3f8cc597ba7bffe7 (diff) |
[PATCH] pcmcia: default suspend and resume handling
In all but one case, the suspend and resume functions of PCMCIA drivers
contain mostly of calls to pcmcia_release_configuration() and
pcmcia_request_configuration(). Therefore, move this code out of the
drivers and into the core.
Signed-off-by: Dominik Brodowski <linux@dominikbrodowski.net>
Diffstat (limited to 'drivers/net/pcmcia/axnet_cs.c')
-rw-r--r-- | drivers/net/pcmcia/axnet_cs.c | 18 |
1 files changed, 5 insertions, 13 deletions
diff --git a/drivers/net/pcmcia/axnet_cs.c b/drivers/net/pcmcia/axnet_cs.c index 9b9c0f19b21c..c34547c79245 100644 --- a/drivers/net/pcmcia/axnet_cs.c +++ b/drivers/net/pcmcia/axnet_cs.c | |||
@@ -464,12 +464,8 @@ static int axnet_suspend(struct pcmcia_device *p_dev) | |||
464 | dev_link_t *link = dev_to_instance(p_dev); | 464 | dev_link_t *link = dev_to_instance(p_dev); |
465 | struct net_device *dev = link->priv; | 465 | struct net_device *dev = link->priv; |
466 | 466 | ||
467 | link->state |= DEV_SUSPEND; | 467 | if ((link->state & DEV_CONFIG) && (link->open)) |
468 | if (link->state & DEV_CONFIG) { | ||
469 | if (link->open) | ||
470 | netif_device_detach(dev); | 468 | netif_device_detach(dev); |
471 | pcmcia_release_configuration(link->handle); | ||
472 | } | ||
473 | 469 | ||
474 | return 0; | 470 | return 0; |
475 | } | 471 | } |
@@ -479,14 +475,10 @@ static int axnet_resume(struct pcmcia_device *p_dev) | |||
479 | dev_link_t *link = dev_to_instance(p_dev); | 475 | dev_link_t *link = dev_to_instance(p_dev); |
480 | struct net_device *dev = link->priv; | 476 | struct net_device *dev = link->priv; |
481 | 477 | ||
482 | link->state &= ~DEV_SUSPEND; | 478 | if ((link->state & DEV_CONFIG) && (link->open)) { |
483 | if (link->state & DEV_CONFIG) { | 479 | axnet_reset_8390(dev); |
484 | pcmcia_request_configuration(link->handle, &link->conf); | 480 | AX88190_init(dev, 1); |
485 | if (link->open) { | 481 | netif_device_attach(dev); |
486 | axnet_reset_8390(dev); | ||
487 | AX88190_init(dev, 1); | ||
488 | netif_device_attach(dev); | ||
489 | } | ||
490 | } | 482 | } |
491 | 483 | ||
492 | return 0; | 484 | return 0; |