summaryrefslogtreecommitdiff
path: root/sys/dev
diff options
context:
space:
mode:
authorMarcus Glocker <mglocker@cvs.openbsd.org>2006-11-29 21:34:07 +0000
committerMarcus Glocker <mglocker@cvs.openbsd.org>2006-11-29 21:34:07 +0000
commite5f289c3ed0e2258d84d06f4fb231938503cfd4b (patch)
treeba2738010bd94bf17a5cf7ab16b7517269f29394 /sys/dev
parent2f7e792c81f62a7f644ef21ae3da628189ea40b8 (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.c19
-rw-r--r--sys/dev/ic/bcwvar.h5
-rw-r--r--sys/dev/pci/if_bcw_pci.c53
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?