diff options
Diffstat (limited to 'sys/dev/pci/if_epic_pci.c')
-rw-r--r-- | sys/dev/pci/if_epic_pci.c | 30 |
1 files changed, 9 insertions, 21 deletions
diff --git a/sys/dev/pci/if_epic_pci.c b/sys/dev/pci/if_epic_pci.c index e6f0d53ccd6..eef2e5147c2 100644 --- a/sys/dev/pci/if_epic_pci.c +++ b/sys/dev/pci/if_epic_pci.c @@ -1,4 +1,4 @@ -/* $OpenBSD: if_epic_pci.c,v 1.5 2006/04/20 20:31:12 miod Exp $ */ +/* $OpenBSD: if_epic_pci.c,v 1.6 2007/10/22 03:16:35 fgsch Exp $ */ /* $NetBSD: if_epic_pci.c,v 1.28 2005/02/27 00:27:32 perry Exp $ */ /*- @@ -158,32 +158,20 @@ epic_pci_attach(struct device *parent, struct device *self, void *aux) const struct epic_pci_subsys_info *esp; bus_space_tag_t iot, memt; bus_space_handle_t ioh, memh; - pcireg_t reg; - int pmreg, ioh_valid, memh_valid; - - if (pci_get_capability(pc, pa->pa_tag, PCI_CAP_PWRMGMT, &pmreg, 0)) { - reg = pci_conf_read(pc, pa->pa_tag, pmreg + PCI_PMCSR); - switch (reg & PCI_PMCSR_STATE_MASK) { - case PCI_PMCSR_STATE_D1: - case PCI_PMCSR_STATE_D2: - printf(": waking up from power state D%d\n", - reg & PCI_PMCSR_STATE_MASK); - pci_conf_write(pc, pa->pa_tag, pmreg + PCI_PMCSR, - (reg & ~PCI_PMCSR_STATE_MASK) | - PCI_PMCSR_STATE_D0); - break; - case PCI_PMCSR_STATE_D3: + int state, ioh_valid, memh_valid; + + state = pci_set_powerstate(pc, pa->pa_tag, PCI_PMCSR_STATE_D0); + if (state != PCI_PMCSR_STATE_D0) { + if (state == PCI_PMCSR_STATE_D3) { /* * IO and MEM are disabled. We can't enable * the card because the BARs might be invalid. */ - printf( - ": unable to wake up from power state D3, " + printf(": unable to wake up from power state D3, " "reboot required.\n"); - pci_conf_write(pc, pa->pa_tag, pmreg + PCI_PMCSR, - (reg & ~PCI_PMCSR_STATE_MASK) | - PCI_PMCSR_STATE_D0); return; + } else { + printf(": waking up from power state D%d\n", state); } } |