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/3c589_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/3c589_cs.c')
-rw-r--r-- | drivers/net/pcmcia/3c589_cs.c | 18 |
1 files changed, 5 insertions, 13 deletions
diff --git a/drivers/net/pcmcia/3c589_cs.c b/drivers/net/pcmcia/3c589_cs.c index e36153851793..b15066be26f8 100644 --- a/drivers/net/pcmcia/3c589_cs.c +++ b/drivers/net/pcmcia/3c589_cs.c | |||
@@ -394,12 +394,8 @@ static int tc589_suspend(struct pcmcia_device *p_dev) | |||
394 | dev_link_t *link = dev_to_instance(p_dev); | 394 | dev_link_t *link = dev_to_instance(p_dev); |
395 | struct net_device *dev = link->priv; | 395 | struct net_device *dev = link->priv; |
396 | 396 | ||
397 | link->state |= DEV_SUSPEND; | 397 | if ((link->state & DEV_CONFIG) && (link->open)) |
398 | if (link->state & DEV_CONFIG) { | 398 | netif_device_detach(dev); |
399 | if (link->open) | ||
400 | netif_device_detach(dev); | ||
401 | pcmcia_release_configuration(link->handle); | ||
402 | } | ||
403 | 399 | ||
404 | return 0; | 400 | return 0; |
405 | } | 401 | } |
@@ -409,13 +405,9 @@ static int tc589_resume(struct pcmcia_device *p_dev) | |||
409 | dev_link_t *link = dev_to_instance(p_dev); | 405 | dev_link_t *link = dev_to_instance(p_dev); |
410 | struct net_device *dev = link->priv; | 406 | struct net_device *dev = link->priv; |
411 | 407 | ||
412 | link->state &= ~DEV_SUSPEND; | 408 | if ((link->state & DEV_CONFIG) && (link->open)) { |
413 | if (link->state & DEV_CONFIG) { | 409 | tc589_reset(dev); |
414 | pcmcia_request_configuration(link->handle, &link->conf); | 410 | netif_device_attach(dev); |
415 | if (link->open) { | ||
416 | tc589_reset(dev); | ||
417 | netif_device_attach(dev); | ||
418 | } | ||
419 | } | 411 | } |
420 | 412 | ||
421 | return 0; | 413 | return 0; |