diff options
author | Mark Kettenis <kettenis@cvs.openbsd.org> | 2010-08-25 21:38:00 +0000 |
---|---|---|
committer | Mark Kettenis <kettenis@cvs.openbsd.org> | 2010-08-25 21:38:00 +0000 |
commit | 1983c3805b3ebdcf9306dd80538f44e4947dcb23 (patch) | |
tree | db58344e83e8ec2da5c5a683d543bb6323d20f30 | |
parent | 5fa7cbf2720de57e4ec997758522caff75547a8a (diff) |
Make CardBus ral(4) suspend and resume properly on machines that keep the
CardBus bridge powered up during suspend. Step zero on the long road
towards fully suspending CardBus on all machines.
ok deraadt@, damien@
-rw-r--r-- | sys/dev/cardbus/cardbus.c | 5 | ||||
-rw-r--r-- | sys/dev/cardbus/cardslot.c | 5 | ||||
-rw-r--r-- | sys/dev/cardbus/if_ral_cardbus.c | 61 | ||||
-rw-r--r-- | sys/dev/ic/rt2560.c | 4 | ||||
-rw-r--r-- | sys/dev/ic/rt2661.c | 4 | ||||
-rw-r--r-- | sys/dev/ic/rt2860.c | 4 | ||||
-rw-r--r-- | sys/dev/pci/pccbb.c | 5 |
7 files changed, 61 insertions, 27 deletions
diff --git a/sys/dev/cardbus/cardbus.c b/sys/dev/cardbus/cardbus.c index 6b094139fec..6786f0fb293 100644 --- a/sys/dev/cardbus/cardbus.c +++ b/sys/dev/cardbus/cardbus.c @@ -1,4 +1,4 @@ -/* $OpenBSD: cardbus.c,v 1.44 2010/03/27 21:40:13 jsg Exp $ */ +/* $OpenBSD: cardbus.c,v 1.45 2010/08/25 21:37:59 kettenis Exp $ */ /* $NetBSD: cardbus.c,v 1.24 2000/04/02 19:11:37 mycroft Exp $ */ /* @@ -83,7 +83,8 @@ STATIC void disable_function(struct cardbus_softc *, int); struct cfattach cardbus_ca = { - sizeof(struct cardbus_softc), cardbusmatch, cardbusattach + sizeof(struct cardbus_softc), cardbusmatch, cardbusattach, + NULL, config_activate_children }; struct cfdriver cardbus_cd = { diff --git a/sys/dev/cardbus/cardslot.c b/sys/dev/cardbus/cardslot.c index f7a982ec298..0061e48ec32 100644 --- a/sys/dev/cardbus/cardslot.c +++ b/sys/dev/cardbus/cardslot.c @@ -1,4 +1,4 @@ -/* $OpenBSD: cardslot.c,v 1.13 2010/01/13 09:10:33 jsg Exp $ */ +/* $OpenBSD: cardslot.c,v 1.14 2010/08/25 21:37:59 kettenis Exp $ */ /* $NetBSD: cardslot.c,v 1.9 2000/03/22 09:35:06 haya Exp $ */ /* @@ -68,7 +68,8 @@ STATIC int cardslot_16_print(void *, const char *); STATIC int cardslot_16_submatch(struct device *, void *,void *); struct cfattach cardslot_ca = { - sizeof(struct cardslot_softc), cardslotmatch, cardslotattach + sizeof(struct cardslot_softc), cardslotmatch, cardslotattach, + NULL, config_activate_children }; struct cfdriver cardslot_cd = { diff --git a/sys/dev/cardbus/if_ral_cardbus.c b/sys/dev/cardbus/if_ral_cardbus.c index 1592363f53e..8b4444c0b0c 100644 --- a/sys/dev/cardbus/if_ral_cardbus.c +++ b/sys/dev/cardbus/if_ral_cardbus.c @@ -1,4 +1,4 @@ -/* $OpenBSD: if_ral_cardbus.c,v 1.18 2010/04/05 14:14:02 damien Exp $ */ +/* $OpenBSD: if_ral_cardbus.c,v 1.19 2010/08/25 21:37:59 kettenis Exp $ */ /*- * Copyright (c) 2005-2010 Damien Bergamini <damien.bergamini@free.fr> @@ -31,6 +31,7 @@ #include <sys/malloc.h> #include <sys/timeout.h> #include <sys/device.h> +#include <sys/workq.h> #include <machine/bus.h> #include <machine/intr.h> @@ -59,21 +60,29 @@ static struct ral_opns { int (*attach)(void *, int); int (*detach)(void *); + void (*suspend)(void *); + void (*resume)(void *); int (*intr)(void *); } ral_rt2560_opns = { rt2560_attach, rt2560_detach, + rt2560_suspend, + rt2560_resume, rt2560_intr }, ral_rt2661_opns = { rt2661_attach, rt2661_detach, + rt2661_suspend, + rt2661_resume, rt2661_intr }, ral_rt2860_opns = { rt2860_attach, rt2860_detach, + rt2860_suspend, + rt2860_resume, rt2860_intr }; @@ -94,15 +103,18 @@ struct ral_cardbus_softc { pcireg_t sc_bar_val; int sc_intrline; pci_chipset_tag_t sc_pc; + struct workq_task sc_resume_wqt; }; int ral_cardbus_match(struct device *, void *, void *); void ral_cardbus_attach(struct device *, struct device *, void *); int ral_cardbus_detach(struct device *, int); +int ral_cardbus_activate(struct device *, int); struct cfattach ral_cardbus_ca = { sizeof (struct ral_cardbus_softc), ral_cardbus_match, - ral_cardbus_attach, ral_cardbus_detach + ral_cardbus_attach, ral_cardbus_detach, + ral_cardbus_activate }; static const struct pci_matchid ral_cardbus_devices[] = { @@ -133,8 +145,8 @@ static const struct pci_matchid ral_cardbus_devices[] = { int ral_cardbus_enable(struct rt2560_softc *); void ral_cardbus_disable(struct rt2560_softc *); -void ral_cardbus_power(struct rt2560_softc *, int); void ral_cardbus_setup(struct ral_cardbus_softc *); +void ral_cardbus_resume(void *, void *); int ral_cardbus_match(struct device *parent, void *match, void *aux) @@ -180,7 +192,6 @@ ral_cardbus_attach(struct device *parent, struct device *self, void *aux) /* power management hooks */ sc->sc_enable = ral_cardbus_enable; sc->sc_disable = ral_cardbus_disable; - sc->sc_power = ral_cardbus_power; /* map control/status registers */ error = Cardbus_mapreg_map(ct, CARDBUS_BASE0_REG, @@ -231,6 +242,25 @@ ral_cardbus_detach(struct device *self, int flags) } int +ral_cardbus_activate(struct device *self, int act) +{ + struct ral_cardbus_softc *csc = (struct ral_cardbus_softc *)self; + struct rt2560_softc *sc = &csc->sc_sc; + + switch (act) { + case DVACT_SUSPEND: + (*csc->sc_opns->suspend)(sc); + break; + case DVACT_RESUME: + workq_queue_task(NULL, &csc->sc_resume_wqt, 0, + ral_cardbus_resume, csc, NULL); + break; + } + + return 0; +} + +int ral_cardbus_enable(struct rt2560_softc *sc) { struct ral_cardbus_softc *csc = (struct ral_cardbus_softc *)sc; @@ -274,17 +304,6 @@ ral_cardbus_disable(struct rt2560_softc *sc) } void -ral_cardbus_power(struct rt2560_softc *sc, int why) -{ - struct ral_cardbus_softc *csc = (struct ral_cardbus_softc *)sc; - - if (why == PWR_RESUME) { - /* kick the PCI configuration registers */ - ral_cardbus_setup(csc); - } -} - -void ral_cardbus_setup(struct ral_cardbus_softc *csc) { cardbus_devfunc_t ct = csc->sc_ct; @@ -308,3 +327,15 @@ ral_cardbus_setup(struct ral_cardbus_softc *csc) pci_conf_write(pc, csc->sc_tag, PCI_COMMAND_STATUS_REG, reg); } + +void +ral_cardbus_resume(void *arg1, void *arg2) +{ + struct ral_cardbus_softc *csc = arg1; + struct rt2560_softc *sc = &csc->sc_sc; + int s; + + s = splnet(); + (*csc->sc_opns->resume)(sc); + splx(s); +} diff --git a/sys/dev/ic/rt2560.c b/sys/dev/ic/rt2560.c index 51499087a4a..258059d8aad 100644 --- a/sys/dev/ic/rt2560.c +++ b/sys/dev/ic/rt2560.c @@ -1,4 +1,4 @@ -/* $OpenBSD: rt2560.c,v 1.49 2010/08/04 19:48:33 damien Exp $ */ +/* $OpenBSD: rt2560.c,v 1.50 2010/08/25 21:37:59 kettenis Exp $ */ /*- * Copyright (c) 2005, 2006 @@ -341,7 +341,7 @@ rt2560_suspend(void *xsc) struct ifnet *ifp = &sc->sc_ic.ic_if; if (ifp->if_flags & IFF_RUNNING) - rt2560_stop(ifp, 0); + rt2560_stop(ifp, 1); } void diff --git a/sys/dev/ic/rt2661.c b/sys/dev/ic/rt2661.c index ca351be844b..541d2941719 100644 --- a/sys/dev/ic/rt2661.c +++ b/sys/dev/ic/rt2661.c @@ -1,4 +1,4 @@ -/* $OpenBSD: rt2661.c,v 1.55 2010/08/04 19:48:33 damien Exp $ */ +/* $OpenBSD: rt2661.c,v 1.56 2010/08/25 21:37:59 kettenis Exp $ */ /*- * Copyright (c) 2006 @@ -408,7 +408,7 @@ rt2661_suspend(void *xsc) struct ifnet *ifp = &sc->sc_ic.ic_if; if (ifp->if_flags & IFF_RUNNING) - rt2661_stop(ifp, 0); + rt2661_stop(ifp, 1); } void diff --git a/sys/dev/ic/rt2860.c b/sys/dev/ic/rt2860.c index 25b6a782968..3dc0d81a66c 100644 --- a/sys/dev/ic/rt2860.c +++ b/sys/dev/ic/rt2860.c @@ -1,4 +1,4 @@ -/* $OpenBSD: rt2860.c,v 1.57 2010/08/04 19:48:33 damien Exp $ */ +/* $OpenBSD: rt2860.c,v 1.58 2010/08/25 21:37:59 kettenis Exp $ */ /*- * Copyright (c) 2007-2010 Damien Bergamini <damien.bergamini@free.fr> @@ -429,7 +429,7 @@ rt2860_suspend(void *xsc) struct ifnet *ifp = &sc->sc_ic.ic_if; if (ifp->if_flags & IFF_RUNNING) - rt2860_stop(ifp, 0); + rt2860_stop(ifp, 1); } void diff --git a/sys/dev/pci/pccbb.c b/sys/dev/pci/pccbb.c index 51517a241a6..499be28f01b 100644 --- a/sys/dev/pci/pccbb.c +++ b/sys/dev/pci/pccbb.c @@ -1,4 +1,4 @@ -/* $OpenBSD: pccbb.c,v 1.76 2010/06/30 19:46:30 blambert Exp $ */ +/* $OpenBSD: pccbb.c,v 1.77 2010/08/25 21:37:59 kettenis Exp $ */ /* $NetBSD: pccbb.c,v 1.96 2004/03/28 09:49:31 nakayama Exp $ */ /* @@ -176,7 +176,8 @@ void cb_show_regs(pci_chipset_tag_t, pcitag_t, bus_space_tag_t, #endif struct cfattach cbb_pci_ca = { - sizeof(struct pccbb_softc), pcicbbmatch, pccbbattach + sizeof(struct pccbb_softc), pcicbbmatch, pccbbattach, NULL, + config_activate_children }; static struct pcmcia_chip_functions pccbb_pcmcia_funcs = { |