diff options
author | Marcus Glocker <mglocker@cvs.openbsd.org> | 2006-11-29 21:34:07 +0000 |
---|---|---|
committer | Marcus Glocker <mglocker@cvs.openbsd.org> | 2006-11-29 21:34:07 +0000 |
commit | e5f289c3ed0e2258d84d06f4fb231938503cfd4b (patch) | |
tree | ba2738010bd94bf17a5cf7ab16b7517269f29394 /sys/dev | |
parent | 2f7e792c81f62a7f644ef21ae3da628189ea40b8 (diff) |
From Jon Simola <simola@mecha.com>:
New bcw_powercontrol_crystal_on() function, and fix the license for the
pci wrapper.
Diffstat (limited to 'sys/dev')
-rw-r--r-- | sys/dev/ic/bcw.c | 19 | ||||
-rw-r--r-- | sys/dev/ic/bcwvar.h | 5 | ||||
-rw-r--r-- | sys/dev/pci/if_bcw_pci.c | 53 |
3 files changed, 35 insertions, 42 deletions
diff --git a/sys/dev/ic/bcw.c b/sys/dev/ic/bcw.c index 264275ad0bc..6721a83e872 100644 --- a/sys/dev/ic/bcw.c +++ b/sys/dev/ic/bcw.c @@ -1,4 +1,4 @@ -/* $OpenBSD: bcw.c,v 1.7 2006/11/26 11:14:17 deraadt Exp $ */ +/* $OpenBSD: bcw.c,v 1.8 2006/11/29 21:34:06 mglocker Exp $ */ /* * Copyright (c) 2006 Jon Simola <jsimola@gmail.com> @@ -2124,3 +2124,20 @@ bcw_free_tx_ring(struct bcw_softc *sc, struct bcw_tx_ring *ring) } } +void +bcw_powercontrol_crystal_on(struct bcw_softc *sc) +{ + u_int32_t sbval; + + sbval = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_GPIOI); + if ((sbval & BCW_XTALPOWERUP) != BCW_XTALPOWERUP) { + sbval = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_GPIOO); + sbval |= (BCW_XTALPOWERUP & BCW_PLLPOWERDOWN); + bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_GPIOO, sbval); + delay(1000); + sbval = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_GPIOO); + sbval &= ~BCW_PLLPOWERDOWN; + bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_GPIOO, sbval); + delay(5000); + } +} diff --git a/sys/dev/ic/bcwvar.h b/sys/dev/ic/bcwvar.h index 8250e8f3e41..08f59231442 100644 --- a/sys/dev/ic/bcwvar.h +++ b/sys/dev/ic/bcwvar.h @@ -1,4 +1,4 @@ -/* $OpenBSD: bcwvar.h,v 1.6 2006/11/26 11:14:17 deraadt Exp $ */ +/* $OpenBSD: bcwvar.h,v 1.7 2006/11/29 21:34:06 mglocker Exp $ */ /* * Copyright (c) 2006 Jon Simola <jsimola@gmail.com> @@ -178,8 +178,9 @@ struct bcw_softc { }; void bcw_attach(struct bcw_softc *); -int bcw_detach(void *arg); +int bcw_detach(void *); int bcw_intr(void *); +void bcw_powercontrol_crystal_on(struct bcw_softc *); #define BCW_DEBUG #ifdef BCW_DEBUG diff --git a/sys/dev/pci/if_bcw_pci.c b/sys/dev/pci/if_bcw_pci.c index c816ab46873..a1bd93e0dff 100644 --- a/sys/dev/pci/if_bcw_pci.c +++ b/sys/dev/pci/if_bcw_pci.c @@ -1,31 +1,19 @@ -/* $OpenBSD: if_bcw_pci.c,v 1.4 2006/11/22 23:46:49 brad Exp $ */ +/* $OpenBSD: if_bcw_pci.c,v 1.5 2006/11/29 21:34:06 mglocker Exp $ */ /* * Copyright (c) 2006 Jon Simola <jsimola@gmail.com> - * Copyright (c) 2003 Clifford Wright. All rights reserved. * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR `AS IS'' AND ANY EXPRESS OR - * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES - * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. - * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, - * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, - * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; - * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED - * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, - * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY - * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF - * SUCH DAMAGE. + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. */ /* @@ -148,9 +136,7 @@ bcw_pci_disable(struct bcw_softc *sc) } void -bcw_pci_attach(parent, self, aux) - struct device *parent, *self; - void *aux; +bcw_pci_attach(struct device *parent, struct device *self, void *aux) { struct bcw_pci_softc *psc = (void *) self; struct bcw_softc *sc = &psc->psc_bcw; @@ -161,7 +147,6 @@ bcw_pci_attach(parent, self, aux) bus_size_t memsize; int pmreg; pcireg_t pmode; - u_int32_t sbval; psc->psc_pc = pa->pa_pc; psc->psc_pcitag = pa->pa_tag; @@ -243,18 +228,8 @@ bcw_pci_attach(parent, self, aux) */ /* Turn the Crystal On */ - sbval = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_GPIOI); - if ((sbval & BCW_XTALPOWERUP) != BCW_XTALPOWERUP) { - sbval = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_GPIOO); - sbval |= (BCW_XTALPOWERUP & BCW_PLLPOWERDOWN); - bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_GPIOO, sbval); - delay(1000); - sbval = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_GPIOO); - sbval &= ~BCW_PLLPOWERDOWN; - bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_GPIOO, sbval); - delay(5000); - } - + bcw_powercontrol_crystal_on(sc); + /* * Clear PCI_STATUS_TARGET_TARGET_ABORT, Docs and Linux call it * PCI_STATUS_SIG_TARGET_ABORT - should use pci_conf_read/write? |