summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
Diffstat (limited to 'sys')
-rw-r--r--sys/dev/cardbus/if_bcw_cardbus.c21
-rw-r--r--sys/dev/ic/bcw.c29
-rw-r--r--sys/dev/ic/bcwvar.h10
-rw-r--r--sys/dev/pci/if_bcw_pci.c29
4 files changed, 45 insertions, 44 deletions
diff --git a/sys/dev/cardbus/if_bcw_cardbus.c b/sys/dev/cardbus/if_bcw_cardbus.c
index 296127b9b08..9782db0cdb5 100644
--- a/sys/dev/cardbus/if_bcw_cardbus.c
+++ b/sys/dev/cardbus/if_bcw_cardbus.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_bcw_cardbus.c,v 1.10 2007/02/26 14:36:11 mglocker Exp $ */
+/* $OpenBSD: if_bcw_cardbus.c,v 1.11 2007/03/04 00:43:25 mglocker Exp $ */
/*
* Copyright (c) 2006 Jon Simola <jsimola@gmail.com>
@@ -64,8 +64,8 @@ void bcw_cardbus_power(struct bcw_softc *, int);
void bcw_cardbus_setup(struct bcw_cardbus_softc *);
int bcw_cardbus_enable(struct bcw_softc *);
void bcw_cardbus_disable(struct bcw_softc *);
-void bcw_cardbus_conf_write(struct bcw_softc *, uint32_t, uint32_t);
-uint32_t bcw_cardbus_conf_read(struct bcw_softc *, uint32_t);
+void bcw_cardbus_conf_write(void *, uint32_t, uint32_t);
+uint32_t bcw_cardbus_conf_read(void *, uint32_t);
struct cfattach bcw_cardbus_ca = {
sizeof (struct bcw_cardbus_softc), bcw_cardbus_match,
@@ -107,8 +107,7 @@ bcw_cardbus_attach(struct device *parent, struct device *self, void *aux)
csc->sc_ct = ct;
csc->sc_tag = ca->ca_tag;
csc->sc_intrline = ca->ca_intrline;
- sc->sc_ca.ca_tag = ca->ca_tag;
- sc->sc_ca.ca_ct = ca->ca_ct;
+ sc->sc_dev_softc = csc;
/* power management hooks */
sc->sc_enable = bcw_cardbus_enable;
@@ -258,13 +257,17 @@ bcw_cardbus_disable(struct bcw_softc *sc)
}
void
-bcw_cardbus_conf_write(struct bcw_softc *sc, uint32_t reg, uint32_t val)
+bcw_cardbus_conf_write(void *self, uint32_t reg, uint32_t val)
{
- Cardbus_conf_write(sc->sc_ca.ca_ct, sc->sc_ca.ca_tag, reg, val);
+ struct bcw_cardbus_softc *csc = (struct bcw_cardbus_softc *)self;
+
+ Cardbus_conf_write(csc->sc_ct, csc->sc_tag, reg, val);
}
uint32_t
-bcw_cardbus_conf_read(struct bcw_softc *sc, uint32_t reg)
+bcw_cardbus_conf_read(void *self, uint32_t reg)
{
- return (Cardbus_conf_read(sc->sc_ca.ca_ct, sc->sc_ca.ca_tag, reg));
+ struct bcw_cardbus_softc *csc = (struct bcw_cardbus_softc *)self;
+
+ return (Cardbus_conf_read(csc->sc_ct, csc->sc_tag, reg));
}
diff --git a/sys/dev/ic/bcw.c b/sys/dev/ic/bcw.c
index 370539f67dc..a50b0cada85 100644
--- a/sys/dev/ic/bcw.c
+++ b/sys/dev/ic/bcw.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: bcw.c,v 1.63 2007/03/01 19:48:00 mglocker Exp $ */
+/* $OpenBSD: bcw.c,v 1.64 2007/03/04 00:43:26 mglocker Exp $ */
/*
* Copyright (c) 2006 Jon Simola <jsimola@gmail.com>
@@ -56,7 +56,6 @@
#include <dev/pci/pcireg.h>
#include <dev/pci/pcivar.h>
#include <dev/pci/pcidevs.h>
-#include <dev/cardbus/cardbusvar.h>
#include <dev/ic/bcwreg.h>
#include <dev/ic/bcwvar.h>
@@ -1450,7 +1449,7 @@ bcw_intr(void *xsc)
sc = xsc;
for (wantinit = 0; wantinit == 0;) {
- intstatus = (sc->sc_conf_read)(sc, BCW_INT_STS);
+ intstatus = (sc->sc_conf_read)(sc->sc_dev_softc, BCW_INT_STS);
/* ignore if not ours, or unsolicited interrupts */
intstatus &= sc->sc_intmask;
@@ -1460,7 +1459,7 @@ bcw_intr(void *xsc)
handled = 1;
/* Ack interrupt */
- (sc->sc_conf_write)(sc, BCW_INT_STS, intstatus);
+ (sc->sc_conf_write)(sc->sc_dev_softc, BCW_INT_STS, intstatus);
/* Receive interrupts. */
if (intstatus & I_RI)
@@ -2603,15 +2602,15 @@ bcw_powercontrol_crystal_on(struct bcw_softc *sc)
{
uint32_t sbval;
- sbval = (sc->sc_conf_read)(sc, BCW_GPIOI);
+ sbval = (sc->sc_conf_read)(sc->sc_dev_softc, BCW_GPIOI);
if ((sbval & BCW_XTALPOWERUP) != BCW_XTALPOWERUP) {
- sbval = (sc->sc_conf_read)(sc, BCW_GPIOO);
+ sbval = (sc->sc_conf_read)(sc->sc_dev_softc, BCW_GPIOO);
sbval |= (BCW_XTALPOWERUP & BCW_PLLPOWERDOWN);
- (sc->sc_conf_write)(sc, BCW_GPIOO, sbval);
+ (sc->sc_conf_write)(sc->sc_dev_softc, BCW_GPIOO, sbval);
delay(1000);
- sbval = (sc->sc_conf_read)(sc, BCW_GPIOO);
+ sbval = (sc->sc_conf_read)(sc->sc_dev_softc, BCW_GPIOO);
sbval &= ~BCW_PLLPOWERDOWN;
- (sc->sc_conf_write)(sc, BCW_GPIOO, sbval);
+ (sc->sc_conf_write)(sc->sc_dev_softc, BCW_GPIOO, sbval);
delay(5000);
}
}
@@ -2629,13 +2628,13 @@ bcw_powercontrol_crystal_off(struct bcw_softc *sc)
/* XXX bcw_powercontrol_clock_slow() */
- sbval = (sc->sc_conf_read)(sc, BCW_GPIOO);
+ sbval = (sc->sc_conf_read)(sc->sc_dev_softc, BCW_GPIOO);
sbval |= BCW_PLLPOWERDOWN;
sbval &= ~BCW_XTALPOWERUP;
- (sc->sc_conf_write)(sc, BCW_GPIOO, sbval);
- sbval = (sc->sc_conf_read)(sc, BCW_GPIOE);
+ (sc->sc_conf_write)(sc->sc_dev_softc, BCW_GPIOO, sbval);
+ sbval = (sc->sc_conf_read)(sc->sc_dev_softc, BCW_GPIOE);
sbval |= BCW_PLLPOWERDOWN | BCW_XTALPOWERUP;
- (sc->sc_conf_write)(sc, BCW_GPIOE, sbval);
+ (sc->sc_conf_write)(sc->sc_dev_softc, BCW_GPIOE, sbval);
}
int
@@ -2644,11 +2643,11 @@ bcw_change_core(struct bcw_softc *sc, int changeto)
uint32_t sbval;
int i;
- (sc->sc_conf_write)(sc, BCW_ADDR_SPACE0,
+ (sc->sc_conf_write)(sc->sc_dev_softc, BCW_ADDR_SPACE0,
BCW_CORE_SELECT(changeto));
/* loop to see if the selected core shows up */
for (i = 0; i < 10; i++) {
- sbval = (sc->sc_conf_read)(sc, BCW_ADDR_SPACE0);
+ sbval = (sc->sc_conf_read)(sc->sc_dev_softc, BCW_ADDR_SPACE0);
if (sbval == BCW_CORE_SELECT(changeto))
break;
delay(10);
diff --git a/sys/dev/ic/bcwvar.h b/sys/dev/ic/bcwvar.h
index e24c0977e82..7baa47c1622 100644
--- a/sys/dev/ic/bcwvar.h
+++ b/sys/dev/ic/bcwvar.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: bcwvar.h,v 1.26 2007/03/01 19:48:00 mglocker Exp $ */
+/* $OpenBSD: bcwvar.h,v 1.27 2007/03/04 00:43:26 mglocker Exp $ */
/*
* Copyright (c) 2006 Jon Simola <jsimola@gmail.com>
@@ -200,9 +200,8 @@ struct bcw_softc {
int (*sc_enable)(struct bcw_softc *);
void (*sc_disable)(struct bcw_softc *);
void (*sc_power)(struct bcw_softc *, int);
- void (*sc_conf_write)(struct bcw_softc *,
- uint32_t, uint32_t);
- uint32_t (*sc_conf_read)(struct bcw_softc *, uint32_t);
+ void (*sc_conf_write)(void *, uint32_t, uint32_t);
+ uint32_t (*sc_conf_read)(void *, uint32_t);
struct timeout sc_scan_to;
@@ -212,8 +211,7 @@ struct bcw_softc {
void *bcw_intrhand;
const char *bcw_intrstr; /* interrupt description */
- struct pci_attach_args sc_pa;
- struct cardbus_attach_args sc_ca;
+ void *sc_dev_softc;
uint32_t sc_phy; /* eeprom indicated phy */
struct bcw_dma_slot *bcw_rx_ring; /* receive ring */
struct bcw_dma_slot *bcw_tx_ring; /* transmit ring */
diff --git a/sys/dev/pci/if_bcw_pci.c b/sys/dev/pci/if_bcw_pci.c
index 2caa93e9b05..56decc5835a 100644
--- a/sys/dev/pci/if_bcw_pci.c
+++ b/sys/dev/pci/if_bcw_pci.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_bcw_pci.c,v 1.12 2007/02/26 14:36:11 mglocker Exp $ */
+/* $OpenBSD: if_bcw_pci.c,v 1.13 2007/03/04 00:43:26 mglocker Exp $ */
/*
* Copyright (c) 2006 Jon Simola <jsimola@gmail.com>
@@ -60,7 +60,6 @@
#include <dev/pci/pcireg.h>
#include <dev/pci/pcivar.h>
#include <dev/pci/pcidevs.h>
-#include <dev/cardbus/cardbusvar.h>
#include <dev/ic/bcwreg.h>
#include <dev/ic/bcwvar.h>
@@ -91,8 +90,8 @@ struct bcw_pci_softc {
int bcw_pci_match(struct device *, void *, void *);
void bcw_pci_attach(struct device *, struct device *, void *);
-void bcw_pci_conf_write(struct bcw_softc *, uint32_t, uint32_t);
-uint32_t bcw_pci_conf_read(struct bcw_softc *, uint32_t);
+void bcw_pci_conf_write(void *, uint32_t, uint32_t);
+uint32_t bcw_pci_conf_read(void *, uint32_t);
struct cfattach bcw_pci_ca = {
sizeof(struct bcw_pci_softc), bcw_pci_match, bcw_pci_attach
@@ -108,9 +107,9 @@ bcw_pci_match(struct device *parent, void *match, void *aux)
void
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;
+ struct bcw_pci_softc *psc = (void *)self;
struct pci_attach_args *pa = (struct pci_attach_args *)aux;
+ struct bcw_softc *sc = &psc->psc_bcw;
pci_chipset_tag_t pc = pa->pa_pc;
pcireg_t memtype;
bus_addr_t memaddr;
@@ -118,10 +117,10 @@ bcw_pci_attach(struct device *parent, struct device *self, void *aux)
int pmreg;
pcireg_t pmode;
+ sc->sc_dmat = pa->pa_dmat;
psc->psc_pc = pa->pa_pc;
psc->psc_pcitag = pa->pa_tag;
- sc->sc_pa.pa_pc = pa->pa_pc;
- sc->sc_pa.pa_tag = pa->pa_tag;
+ sc->sc_dev_softc = psc;
/* Get it out of power save mode if needed. */
if (pci_get_capability(pc, pa->pa_tag, PCI_CAP_PWRMGMT, &pmreg, 0)) {
@@ -159,8 +158,6 @@ bcw_pci_attach(struct device *parent, struct device *self, void *aux)
return;
}
- sc->sc_dmat = pa->pa_dmat;
-
/* Map the PCI interrupt */
if (pci_intr_map(pa, &psc->psc_ih)) {
printf("%s: couldn't map interrupt\n",
@@ -219,13 +216,17 @@ bcw_pci_attach(struct device *parent, struct device *self, void *aux)
}
void
-bcw_pci_conf_write(struct bcw_softc *sc, uint32_t reg, uint32_t val)
+bcw_pci_conf_write(void *self, uint32_t reg, uint32_t val)
{
- pci_conf_write(sc->sc_pa.pa_pc, sc->sc_pa.pa_tag, reg, val);
+ struct bcw_pci_softc *psc = (struct bcw_pci_softc *)self;
+
+ pci_conf_write(psc->psc_pc, psc->psc_pcitag, reg, val);
}
uint32_t
-bcw_pci_conf_read(struct bcw_softc *sc, uint32_t reg)
+bcw_pci_conf_read(void *self, uint32_t reg)
{
- return (pci_conf_read(sc->sc_pa.pa_pc, sc->sc_pa.pa_tag, reg));
+ struct bcw_pci_softc *psc = (struct bcw_pci_softc *)self;
+
+ return (pci_conf_read(psc->psc_pc, psc->psc_pcitag, reg));
}