summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sys/dev/ic/bcw.c1362
-rw-r--r--sys/dev/ic/bcwreg.h105
-rw-r--r--sys/dev/ic/bcwvar.h175
-rw-r--r--sys/dev/pci/if_bcw_pci.c45
4 files changed, 1034 insertions, 653 deletions
diff --git a/sys/dev/ic/bcw.c b/sys/dev/ic/bcw.c
index 40ff18db4b1..52f3ed35448 100644
--- a/sys/dev/ic/bcw.c
+++ b/sys/dev/ic/bcw.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: bcw.c,v 1.2 2006/11/17 20:04:52 mglocker Exp $ */
+/* $OpenBSD: bcw.c,v 1.3 2006/11/21 11:41:14 mglocker Exp $ */
/*
* Copyright (c) 2006 Jon Simola <jsimola@gmail.com>
@@ -80,7 +80,7 @@ void bcw_reset(struct bcw_softc *);
int bcw_init(struct ifnet *);
void bcw_start(struct ifnet *);
void bcw_stop(struct ifnet *, int);
-/* Functions copied from bce - */
+
void bcw_watchdog(struct ifnet *);
void bcw_rxintr(struct bcw_softc *);
void bcw_txintr(struct bcw_softc *);
@@ -90,6 +90,16 @@ void bcw_rxdrain(struct bcw_softc *);
void bcw_set_filter(struct ifnet *);
void bcw_tick(void *);
int bcw_ioctl(struct ifnet *, u_long, caddr_t);
+
+int bcw_alloc_rx_ring(struct bcw_softc *sc, struct bcw_rx_ring *ring,
+ int count);
+void bcw_reset_rx_ring(struct bcw_softc *sc, struct bcw_rx_ring *ring);
+void bcw_free_rx_ring(struct bcw_softc *sc, struct bcw_rx_ring *ring);
+int bcw_alloc_tx_ring(struct bcw_softc *sc, struct bcw_tx_ring *ring,
+ int count);
+void bcw_reset_tx_ring(struct bcw_softc *sc, struct bcw_tx_ring *ring);
+void bcw_free_tx_ring(struct bcw_softc *sc, struct bcw_tx_ring *ring);
+
/* 80211 functions copied from iwi */
int bcw_newstate(struct ieee80211com *, enum ieee80211_state, int);
int bcw_media_change(struct ifnet *);
@@ -97,15 +107,6 @@ void bcw_media_status(struct ifnet *, struct ifmediareq *);
/* fashionably new functions */
int bcw_validatechipaccess(struct bcw_softc *ifp);
-/* read/write functions */
-u_int8_t bcw_read8(void *, u_int32_t);
-u_int16_t bcw_read16(void *, u_int32_t);
-u_int32_t bcw_read32(void *, u_int32_t);
-void bcw_write8(void *, u_int32_t, u_int8_t);
-void bcw_write16(void *, u_int32_t, u_int16_t);
-void bcw_write32(void *, u_int32_t, u_int32_t);
-void bcw_barrier(void *, u_int32_t, u_int32_t, int);
-
struct cfdriver bcw_cd = {
NULL, "bcw", DV_IFNET
};
@@ -113,19 +114,18 @@ struct cfdriver bcw_cd = {
void
bcw_attach(struct bcw_softc *sc)
{
- struct ieee80211com *ic = &sc->bcw_ic;
+ struct ieee80211com *ic = &sc->sc_ic;
struct ifnet *ifp = &ic->ic_if;
- struct bcw_regs *regs = &sc->bcw_regs;
#if 0
- struct pci_attach_args *pa = &sc->bcw_pa;
+ struct pci_attach_args *pa = &sc->sc_pa;
pci_chipset_tag_t pc = pa->pa_pc;
pci_intr_handle_t ih;
const char *intrstr = NULL;
#endif
+#if 0
caddr_t kva;
bus_dma_segment_t seg;
int rseg;
-#if 0
pcireg_t memtype;
bus_addr_t memaddr;
bus_size_t memsize;
@@ -137,18 +137,6 @@ bcw_attach(struct bcw_softc *sc)
u_int32_t sbval;
u_int16_t sbval16;
- //sc->bcw_pa = *pa;
- //sc->bcw_dmatag = pa->pa_dmat;
-
- if (sc->bcw_regs.r_read8 == NULL) {
- sc->bcw_regs.r_read8 = bcw_read8;
- sc->bcw_regs.r_read16 = bcw_read16;
- sc->bcw_regs.r_read32 = bcw_read32;
- sc->bcw_regs.r_write8 = bcw_write8;
- sc->bcw_regs.r_write16 = bcw_write16;
- sc->bcw_regs.r_write32 = bcw_write32;
- sc->bcw_regs.r_barrier = bcw_barrier;
- }
/*
* Reset the chip
@@ -180,83 +168,102 @@ bcw_attach(struct bcw_softc *sc)
* - Single Core
*/
- sbval = BCW_READ32(regs, BCW_ADDR_SPACE0);
+ sbval = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_ADDR_SPACE0);
if ((sbval & 0xffff0000) != 0x18000000) {
DPRINTF(("%s: Trial Core read was 0x%x, single core only?\n",
- sc->bcw_dev.dv_xname, sbval));
- //sc->bcw_singlecore=1;
+ sc->sc_dev.dv_xname, sbval));
+ //sc->sc_singlecore=1;
}
/*
* Try and change to the ChipCommon Core
*/
for (i = 0; i < 10; i++) {
- BCW_WRITE32(regs, BCW_ADDR_SPACE0, BCW_CORE_SELECT(0));
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_ADDR_SPACE0,
+ BCW_CORE_SELECT(0));
delay(10);
- sbval = BCW_READ32(regs, BCW_ADDR_SPACE0);
+ sbval = bus_space_read_4(sc->sc_iot, sc->sc_ioh,
+ BCW_ADDR_SPACE0);
DPRINTF(("%s: Core change read %d = 0x%x\n",
- sc->bcw_dev.dv_xname,i,sbval));
+ sc->sc_dev.dv_xname,i,sbval));
if (sbval == BCW_CORE_SELECT(0)) break;
delay(10);
}
+ /*
+ * Try and change to random cores
+ */
+ for (j = 1; j < 10; j++) {
+ for (i = 0; i < 10; i++) {
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh,
+ BCW_ADDR_SPACE0, BCW_CORE_SELECT(j));
+ delay(10);
+ sbval = bus_space_read_4(sc->sc_iot, sc->sc_ioh,
+ BCW_ADDR_SPACE0);
+ DPRINTF(("%s: Core change read %d = 0x%x\n",
+ sc->sc_dev.dv_xname,i,sbval));
+ if (sbval == BCW_CORE_SELECT(j)) break;
+ delay(10);
+ }
+ }
//DPRINTF(("\n")); /* Pretty print so the debugs start on new lines */
/*
* Core ID REG, this is either the default wireless core (0x812) or
* a ChipCommon core
*/
- sbval = BCW_READ32(regs, BCW_CIR_SBID_HI);
+ sbval = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_CIR_SBID_HI);
DPRINTF(("%s: Got Core ID Reg 0x%x, type is 0x%x\n",
- sc->bcw_dev.dv_xname, sbval, (sbval & 0x8ff0) >> 4));
+ sc->sc_dev.dv_xname, sbval, (sbval & 0x8ff0) >> 4));
/* If we successfully got a commoncore, and the corerev=4 or >=6
get the number of cores from the chipid reg */
if (((sbval & 0x00008ff0) >> 4) == BCW_CORE_COMMON) {
- sc->bcw_havecommon = 1;
- sbval = BCW_READ32(regs, BCW_CORE_COMMON_CHIPID);
- sc->bcw_chipid = (sbval & 0x0000ffff);
- sc->bcw_corerev =
+ sc->sc_havecommon = 1;
+ sbval = bus_space_read_4(sc->sc_iot, sc->sc_ioh,
+ BCW_CORE_COMMON_CHIPID);
+ sc->sc_chipid = (sbval & 0x0000ffff);
+ sc->sc_corerev =
((sbval & 0x00007000) >> 8 | (sbval & 0x0000000f));
- if ((sc->bcw_corerev == 4) || (sc->bcw_corerev >= 6))
- sc->bcw_numcores = (sbval & 0x0f000000) >> 24;
+ if ((sc->sc_corerev == 4) || (sc->sc_corerev >= 6))
+ sc->sc_numcores = (sbval & 0x0f000000) >> 24;
else
- switch (sc->bcw_chipid) {
+ switch (sc->sc_chipid) {
case 0x4710:
case 0x4610:
case 0x4704:
- sc->bcw_numcores = 9;
+ sc->sc_numcores = 9;
break;
case 0x4310:
- sc->bcw_numcores = 8;
+ sc->sc_numcores = 8;
break;
case 0x5365:
- sc->bcw_numcores = 7;
+ sc->sc_numcores = 7;
break;
case 0x4306:
- sc->bcw_numcores = 6;
+ sc->sc_numcores = 6;
break;
case 0x4307:
case 0x4301:
- sc->bcw_numcores = 5;
+ sc->sc_numcores = 5;
break;
case 0x4402:
- sc->bcw_numcores = 3;
+ sc->sc_numcores = 3;
break;
default:
/* XXX Educated Guess */
- sc->bcw_numcores = 0;
+ sc->sc_numcores = 0;
} /* end of switch */
} else { /* No CommonCore, set chipid,cores,rev based on product id */
- sc->bcw_havecommon = 0;
- switch(sc->bcw_prodid) {
+ sc->sc_havecommon = 0;
+ switch(sc->sc_prodid) {
case 0x4710:
case 0x4711:
case 0x4712:
case 0x4713:
case 0x4714:
case 0x4715:
- sc->bcw_chipid = 0x4710;
- sc->bcw_numcores = 9;
+ sc->sc_chipid = 0x4710;
+ sc->sc_numcores = 9;
break;
case 0x4610:
case 0x4611:
@@ -264,54 +271,56 @@ bcw_attach(struct bcw_softc *sc)
case 0x4613:
case 0x4614:
case 0x4615:
- sc->bcw_chipid = 0x4610;
- sc->bcw_numcores = 9;
+ sc->sc_chipid = 0x4610;
+ sc->sc_numcores = 9;
break;
case 0x4402:
case 0x4403:
- sc->bcw_chipid = 0x4402;
- sc->bcw_numcores = 3;
+ sc->sc_chipid = 0x4402;
+ sc->sc_numcores = 3;
break;
case 0x4305:
case 0x4306:
case 0x4307:
- sc->bcw_chipid = 0x4307;
- sc->bcw_numcores = 5;
+ sc->sc_chipid = 0x4307;
+ sc->sc_numcores = 5;
break;
case 0x4301:
- sc->bcw_chipid = 0x4301;
- sc->bcw_numcores = 5;
+ sc->sc_chipid = 0x4301;
+ sc->sc_numcores = 5;
break;
default:
- sc->bcw_chipid = sc->bcw_prodid;
+ sc->sc_chipid = sc->sc_prodid;
/* XXX educated guess */
- sc->bcw_numcores = 1;
+ sc->sc_numcores = 1;
} /* end of switch */
} /* End of if/else */
DPRINTF(("%s: ChipID=0x%x, ChipRev=0x%x, NumCores=%d\n",
- sc->bcw_dev.dv_xname, sc->bcw_chipid,
- sc->bcw_chiprev, sc->bcw_numcores));
+ sc->sc_dev.dv_xname, sc->sc_chipid,
+ sc->sc_chiprev, sc->sc_numcores));
/* Identify each core */
- if (sc->bcw_numcores >= 2) { /* Exclude single core chips */
- for (i = 0; i <= sc->bcw_numcores; i++) {
+ if (sc->sc_numcores >= 2) { /* Exclude single core chips */
+ for (i = 0; i <= sc->sc_numcores; i++) {
DPRINTF(("%s: Trying core %d - ",
- sc->bcw_dev.dv_xname, i));
- BCW_WRITE32(regs, BCW_ADDR_SPACE0, BCW_CORE_SELECT(i));
+ sc->sc_dev.dv_xname, i));
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh,
+ BCW_ADDR_SPACE0, BCW_CORE_SELECT(i));
/* loop to see if the selected core shows up */
for (j = 0; j < 10; j++) {
- sbval=BCW_READ32(regs, BCW_ADDR_SPACE0);
+ sbval=bus_space_read_4(sc->sc_iot, sc->sc_ioh,
+ BCW_ADDR_SPACE0);
DPRINTF(("%s: read %d for core %d = 0x%x ",
- sc->bcw_dev.dv_xname, j, i, sbval));
+ sc->sc_dev.dv_xname, j, i, sbval));
if (sbval == BCW_CORE_SELECT(i)) break;
delay(10);
}
if (j < 10)
DPRINTF(("%s: Found core %d of type 0x%x\n",
- sc->bcw_dev.dv_xname, i,
+ sc->sc_dev.dv_xname, i,
(sbval & 0x00008ff0) >> 4));
- //sc->bcw_core[i].id = (sbval & 0x00008ff0) >> 4;
+ //sc->sc_core[i].id = (sbval & 0x00008ff0) >> 4;
} /* End of For loop */
DPRINTF(("\n")); /* Make pretty debug output */
}
@@ -319,38 +328,38 @@ bcw_attach(struct bcw_softc *sc)
/*
* Attach cores to the backplane, if we have more than one
*/
- // ??? if (!sc->bcw_singlecore) {
- if (sc->bcw_havecommon == 1) {
- sbval = BCW_READ32(regs, BCW_PCICR);
+ // ??? if (!sc->sc_singlecore) {
+ if (sc->sc_havecommon == 1) {
+ sbval = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_PCICR);
sbval |= 0x1 << 8; /* XXX hardcoded bitmask of single core */
- BCW_WRITE32(regs, BCW_PCICR, sbval);
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_PCICR, sbval);
}
/*
* Get and display the PHY info from the MIMO
*/
- sbval = BCW_READ16(regs, 0x3E0);
- sc->bcw_phy_version = (sbval&0xf000)>>12;
- sc->bcw_phy_rev = sbval&0xf;
- sc->bcw_phy_type = (sbval&0xf00)>>8;
+ sbval = bus_space_read_2(sc->sc_iot, sc->sc_ioh, 0x3E0);
+ sc->sc_phy_version = (sbval&0xf000)>>12;
+ sc->sc_phy_rev = sbval&0xf;
+ sc->sc_phy_type = (sbval&0xf00)>>8;
DPRINTF(("%s: PHY version %d revision %d ",
- sc->bcw_dev.dv_xname, sc->bcw_phy_version, sc->bcw_phy_rev));
- switch (sc->bcw_phy_type) {
+ sc->sc_dev.dv_xname, sc->sc_phy_version, sc->sc_phy_rev));
+ switch (sc->sc_phy_type) {
case BCW_PHY_TYPEA:
- DPRINTF(("PHY %d (A)\n",sc->bcw_phy_type));
+ DPRINTF(("PHY %d (A)\n",sc->sc_phy_type));
break;
case BCW_PHY_TYPEB:
- DPRINTF(("PHY %d (B)\n",sc->bcw_phy_type));
+ DPRINTF(("PHY %d (B)\n",sc->sc_phy_type));
break;
case BCW_PHY_TYPEG:
- DPRINTF(("PHY %d (G)\n",sc->bcw_phy_type));
+ DPRINTF(("PHY %d (G)\n",sc->sc_phy_type));
break;
case BCW_PHY_TYPEN:
- DPRINTF(("PHY %d (N)\n",sc->bcw_phy_type));
+ DPRINTF(("PHY %d (N)\n",sc->sc_phy_type));
break;
default:
DPRINTF(("Unrecognizeable PHY type %d\n",
- sc->bcw_phy_type));
+ sc->sc_phy_type));
break;
} /* end of switch */
@@ -362,42 +371,54 @@ bcw_attach(struct bcw_softc *sc)
* Radio registers, and requires seperate 16bit reads from the low
* and the high data addresses.
*/
- if (sc->bcw_chipid != 0x4317) {
- BCW_WRITE16(regs, BCW_RADIO_CONTROL, BCW_RADIO_ID);
- sbval=BCW_READ16(regs, BCW_RADIO_DATAHIGH);
+ if (sc->sc_chipid != 0x4317) {
+ bus_space_write_2(sc->sc_iot, sc->sc_ioh, BCW_RADIO_CONTROL,
+ BCW_RADIO_ID);
+ sbval=bus_space_read_2(sc->sc_iot, sc->sc_ioh,
+ BCW_RADIO_DATAHIGH);
sbval <<= 16;
- BCW_WRITE16(regs, BCW_RADIO_CONTROL, BCW_RADIO_ID);
- sc->bcw_radioid = sbval | BCW_READ16(regs, BCW_RADIO_DATALOW);
+ bus_space_write_2(sc->sc_iot, sc->sc_ioh, BCW_RADIO_CONTROL,
+ BCW_RADIO_ID);
+ sc->sc_radioid = sbval | bus_space_read_2(sc->sc_iot,
+ sc->sc_ioh, BCW_RADIO_DATALOW);
} else {
- switch(sc->bcw_corerev) {
+ switch(sc->sc_corerev) {
case 0:
- sc->bcw_radioid = 0x3205017F;
+ sc->sc_radioid = 0x3205017F;
break;
case 1:
- sc->bcw_radioid = 0x4205017f;
+ sc->sc_radioid = 0x4205017f;
break;
default:
- sc->bcw_radioid = 0x5205017f;
+ sc->sc_radioid = 0x5205017f;
}
}
- sc->bcw_radiorev = (sc->bcw_radioid & 0xf0000000) >> 28;
- sc->bcw_radiotype = (sc->bcw_radioid & 0x0ffff000) >> 12;
+ sc->sc_radiorev = (sc->sc_radioid & 0xf0000000) >> 28;
+ sc->sc_radiotype = (sc->sc_radioid & 0x0ffff000) >> 12;
DPRINTF(("%s: Radio Rev %d, Ver 0x%x, Manuf 0x%x\n",
- sc->bcw_dev.dv_xname, sc->bcw_radiorev, sc->bcw_radiotype,
- sc->bcw_radioid & 0xfff));
+ sc->sc_dev.dv_xname, sc->sc_radiorev, sc->sc_radiotype,
+ sc->sc_radioid & 0xfff));
error = bcw_validatechipaccess(sc);
if (error) {
printf("%s: failed Chip Access Validation at %d\n",
- sc->bcw_dev.dv_xname, error);
+ sc->sc_dev.dv_xname, error);
return;
}
+ /* Get a copy of the BoardFlags and fix for broken boards */
+ sc->sc_boardflags = bus_space_read_2(sc->sc_iot, sc->sc_ioh,
+ BCW_SPROM_BOARDFLAGS);
+ /*
+ * Dell, Product ID 0x4301 Revision 0x74, set BCW_BF_BTCOEXIST
+ * Apple Board Type 0x4e Revision > 0x40, set BCW_BF_PACTRL
+ */
+
/* Test for valid PHY/revision combinations, probably a simpler way */
- if (sc->bcw_phy_type == BCW_PHY_TYPEA) {
- switch(sc->bcw_phy_rev) {
+ if (sc->sc_phy_type == BCW_PHY_TYPEA) {
+ switch(sc->sc_phy_rev) {
case 2:
case 3:
case 5:
@@ -405,23 +426,23 @@ bcw_attach(struct bcw_softc *sc)
case 7: break;
default:
printf("%s: invalid PHY A revision %d\n",
- sc->bcw_dev.dv_xname, sc->bcw_phy_rev);
+ sc->sc_dev.dv_xname, sc->sc_phy_rev);
return;
}
}
- if (sc->bcw_phy_type == BCW_PHY_TYPEB) {
- switch(sc->bcw_phy_rev) {
+ if (sc->sc_phy_type == BCW_PHY_TYPEB) {
+ switch(sc->sc_phy_rev) {
case 2:
case 4:
case 7: break;
default:
printf("%s: invalid PHY B revision %d\n",
- sc->bcw_dev.dv_xname, sc->bcw_phy_rev);
+ sc->sc_dev.dv_xname, sc->sc_phy_rev);
return;
}
}
- if (sc->bcw_phy_type == BCW_PHY_TYPEG) {
- switch(sc->bcw_phy_rev) {
+ if (sc->sc_phy_type == BCW_PHY_TYPEG) {
+ switch(sc->sc_phy_rev) {
case 1:
case 2:
case 4:
@@ -430,41 +451,45 @@ bcw_attach(struct bcw_softc *sc)
case 8: break;
default:
printf("%s: invalid PHY G revision %d\n",
- sc->bcw_dev.dv_xname, sc->bcw_phy_rev);
+ sc->sc_dev.dv_xname, sc->sc_phy_rev);
return;
}
}
/* test for valid radio revisions */
- if ((sc->bcw_phy_type == BCW_PHY_TYPEA) &
- (sc->bcw_radiotype != 0x2060)) {
+ if ((sc->sc_phy_type == BCW_PHY_TYPEA) &
+ (sc->sc_radiotype != 0x2060)) {
printf("%s: invalid PHY A radio 0x%x\n",
- sc->bcw_dev.dv_xname, sc->bcw_radiotype);
+ sc->sc_dev.dv_xname, sc->sc_radiotype);
return;
}
- if ((sc->bcw_phy_type == BCW_PHY_TYPEB) &
- ((sc->bcw_radiotype & 0xfff0) != 0x2050)) {
+ if ((sc->sc_phy_type == BCW_PHY_TYPEB) &
+ ((sc->sc_radiotype & 0xfff0) != 0x2050)) {
printf("%s: invalid PHY B radio 0x%x\n",
- sc->bcw_dev.dv_xname, sc->bcw_radiotype);
+ sc->sc_dev.dv_xname, sc->sc_radiotype);
return;
}
- if ((sc->bcw_phy_type == BCW_PHY_TYPEG) &
- (sc->bcw_radiotype != 0x2050)) {
+ if ((sc->sc_phy_type == BCW_PHY_TYPEG) &
+ (sc->sc_radiotype != 0x2050)) {
printf("%s: invalid PHY G radio 0x%x\n",
- sc->bcw_dev.dv_xname, sc->bcw_radiotype);
+ sc->sc_dev.dv_xname, sc->sc_radiotype);
return;
}
/*
* Switch the radio off - candidate for seperate function
*/
- switch(sc->bcw_phy_type) {
+ switch(sc->sc_phy_type) {
case BCW_PHY_TYPEA:
/* Magic unexplained values */
- BCW_WRITE16(regs, BCW_RADIO_CONTROL, 0x04);
- BCW_WRITE16(regs, BCW_RADIO_DATALOW, 0xff);
- BCW_WRITE16(regs, BCW_RADIO_CONTROL, 0x05);
- BCW_WRITE16(regs, BCW_RADIO_DATALOW, 0xfb);
+ bus_space_write_2(sc->sc_iot, sc->sc_ioh,
+ BCW_RADIO_CONTROL, 0x04);
+ bus_space_write_2(sc->sc_iot, sc->sc_ioh,
+ BCW_RADIO_DATALOW, 0xff);
+ bus_space_write_2(sc->sc_iot, sc->sc_ioh,
+ BCW_RADIO_CONTROL, 0x05);
+ bus_space_write_2(sc->sc_iot, sc->sc_ioh,
+ BCW_RADIO_DATALOW, 0xfb);
/*
* "When the term MaskSet is used, it is shorthand
* for reading a value from a register, applying a
@@ -475,92 +500,114 @@ bcw_attach(struct bcw_softc *sc)
* here we read a value, AND it with 0xffff, then
* OR with 0x8. Why not just set the 0x8 bit?
*/
- BCW_WRITE16(regs, BCW_PHY_CONTROL, 0x10);
- sbval16 = BCW_READ16(regs, BCW_PHY_DATA);
+ bus_space_write_2(sc->sc_iot, sc->sc_ioh,
+ BCW_PHY_CONTROL, 0x10);
+ sbval16 = bus_space_read_2(sc->sc_iot, sc->sc_ioh,
+ BCW_PHY_DATA);
sbval16 |= 0x8;
- BCW_WRITE16(regs, BCW_PHY_CONTROL, 0x10);
- BCW_WRITE16(regs, BCW_PHY_DATA, sbval16);
-
- BCW_WRITE16(regs, BCW_PHY_CONTROL, 0x11);
- sbval16 = BCW_READ16(regs, BCW_PHY_DATA);
+ bus_space_write_2(sc->sc_iot, sc->sc_ioh,
+ BCW_PHY_CONTROL, 0x10);
+ bus_space_write_2(sc->sc_iot, sc->sc_ioh,
+ BCW_PHY_DATA, sbval16);
+
+ bus_space_write_2(sc->sc_iot, sc->sc_ioh,
+ BCW_PHY_CONTROL, 0x11);
+ sbval16 = bus_space_read_2(sc->sc_iot, sc->sc_ioh,
+ BCW_PHY_DATA);
sbval16 |= 0x8;
- BCW_WRITE16(regs, BCW_PHY_CONTROL, 0x11);
- BCW_WRITE16(regs, BCW_PHY_DATA, sbval16);
+ bus_space_write_2(sc->sc_iot, sc->sc_ioh,
+ BCW_PHY_CONTROL, 0x11);
+ bus_space_write_2(sc->sc_iot, sc->sc_ioh,
+ BCW_PHY_DATA, sbval16);
break;
case BCW_PHY_TYPEG:
- if (sc->bcw_corerev >= 5) {
- BCW_WRITE16(regs, BCW_PHY_CONTROL, 0x811);
- sbval16 = BCW_READ16(regs, BCW_PHY_DATA);
+ if (sc->sc_corerev >= 5) {
+ bus_space_write_2(sc->sc_iot, sc->sc_ioh,
+ BCW_PHY_CONTROL, 0x811);
+ sbval16 = bus_space_read_2(sc->sc_iot,
+ sc->sc_ioh, BCW_PHY_DATA);
sbval16 |= 0x8c;
- BCW_WRITE16(regs, BCW_PHY_CONTROL, 0x811);
- BCW_WRITE16(regs, BCW_PHY_DATA, sbval16);
-
- BCW_WRITE16(regs, BCW_PHY_CONTROL, 0x812);
- sbval16 = BCW_READ16(regs, BCW_PHY_DATA);
+ bus_space_write_2(sc->sc_iot, sc->sc_ioh,
+ BCW_PHY_CONTROL, 0x811);
+ bus_space_write_2(sc->sc_iot, sc->sc_ioh,
+ BCW_PHY_DATA, sbval16);
+
+ bus_space_write_2(sc->sc_iot, sc->sc_ioh,
+ BCW_PHY_CONTROL, 0x812);
+ sbval16 = bus_space_read_2(sc->sc_iot,
+ sc->sc_ioh, BCW_PHY_DATA);
sbval16 &= 0xff73;
- BCW_WRITE16(regs, BCW_PHY_CONTROL, 0x812);
- BCW_WRITE16(regs, BCW_PHY_DATA, sbval16);
+ bus_space_write_2(sc->sc_iot, sc->sc_ioh,
+ BCW_PHY_CONTROL, 0x812);
+ bus_space_write_2(sc->sc_iot, sc->sc_ioh,
+ BCW_PHY_DATA, sbval16);
}
/* FALL-THROUGH */
default:
- BCW_WRITE16(regs, BCW_PHY_CONTROL, 0x15);
- BCW_WRITE16(regs, BCW_PHY_DATA, 0xaa00);
+ bus_space_write_2(sc->sc_iot, sc->sc_ioh,
+ BCW_PHY_CONTROL, 0x15);
+ bus_space_write_2(sc->sc_iot, sc->sc_ioh,
+ BCW_PHY_DATA, 0xaa00);
} /* end of switch statement to turn off radio */
- // XXX - Get a copy of the BoardFlags to keep in RAM
-
/* Read antenna gain from SPROM and multiply by 4 */
- sbval = BCW_READ16(regs, BCW_SPROM_ANTGAIN);
+ sbval = bus_space_read_2(sc->sc_iot, sc->sc_ioh, BCW_SPROM_ANTGAIN);
/* If unset, assume 2 */
if((sbval == 0) || (sbval == 0xffff)) sbval = 0x0202;
- if(sc->bcw_phy_type == BCW_PHY_TYPEA)
- sc->bcw_radio_gain = (sbval & 0xff);
+ if(sc->sc_phy_type == BCW_PHY_TYPEA)
+ sc->sc_radio_gain = (sbval & 0xff);
else
- sc->bcw_radio_gain = ((sbval & 0xff00) >> 8);
- sc->bcw_radio_gain *= 4;
+ sc->sc_radio_gain = ((sbval & 0xff00) >> 8);
+ sc->sc_radio_gain *= 4;
/*
* Set the paXbY vars, X=0 for PHY A, X=1 for B/G, but we'll
* just grab them all while we're here
*/
- sc->bcw_radio_pa0b0 = BCW_READ16(regs, BCW_SPROM_PA0B0);
- sc->bcw_radio_pa0b1 = BCW_READ16(regs, BCW_SPROM_PA0B1);
- sc->bcw_radio_pa0b2 = BCW_READ16(regs, BCW_SPROM_PA0B2);
- sc->bcw_radio_pa1b0 = BCW_READ16(regs, BCW_SPROM_PA1B0);
- sc->bcw_radio_pa1b1 = BCW_READ16(regs, BCW_SPROM_PA1B1);
- sc->bcw_radio_pa1b2 = BCW_READ16(regs, BCW_SPROM_PA1B2);
+ sc->sc_radio_pa0b0 = bus_space_read_2(sc->sc_iot, sc->sc_ioh,
+ BCW_SPROM_PA0B0);
+ sc->sc_radio_pa0b1 = bus_space_read_2(sc->sc_iot, sc->sc_ioh,
+ BCW_SPROM_PA0B1);
+ sc->sc_radio_pa0b2 = bus_space_read_2(sc->sc_iot, sc->sc_ioh,
+ BCW_SPROM_PA0B2);
+ sc->sc_radio_pa1b0 = bus_space_read_2(sc->sc_iot, sc->sc_ioh,
+ BCW_SPROM_PA1B0);
+ sc->sc_radio_pa1b1 = bus_space_read_2(sc->sc_iot, sc->sc_ioh,
+ BCW_SPROM_PA1B1);
+ sc->sc_radio_pa1b2 = bus_space_read_2(sc->sc_iot, sc->sc_ioh,
+ BCW_SPROM_PA1B2);
/* Get the idle TSSI */
- sbval = BCW_READ16(regs, BCW_SPROM_IDLETSSI);
- if(sc->bcw_phy_type == BCW_PHY_TYPEA)
- sc->bcw_idletssi = (sbval & 0xff);
+ sbval = bus_space_read_2(sc->sc_iot, sc->sc_ioh, BCW_SPROM_IDLETSSI);
+ if(sc->sc_phy_type == BCW_PHY_TYPEA)
+ sc->sc_idletssi = (sbval & 0xff);
else
- sc->bcw_idletssi = ((sbval & 0xff00) >> 8);
+ sc->sc_idletssi = ((sbval & 0xff00) >> 8);
/* Init the Microcode Flags Bitfield */
/* http://bcm-specs.sipsolutions.net/MicrocodeFlagsBitfield */
sbval = 0;
- if((sc->bcw_phy_type == BCW_PHY_TYPEA) ||
- (sc->bcw_phy_type == BCW_PHY_TYPEB) ||
- (sc->bcw_phy_type == BCW_PHY_TYPEG))
+ if((sc->sc_phy_type == BCW_PHY_TYPEA) ||
+ (sc->sc_phy_type == BCW_PHY_TYPEB) ||
+ (sc->sc_phy_type == BCW_PHY_TYPEG))
sbval |= 2; /* Turned on during init for non N phys */
- if((sc->bcw_phy_type == BCW_PHY_TYPEG) &&
- (sc->bcw_phy_rev == 1))
+ if((sc->sc_phy_type == BCW_PHY_TYPEG) &&
+ (sc->sc_phy_rev == 1))
sbval |= 0x20;
- /*
- * XXX If this is a G PHY with BoardFlags BFL_PACTRL set,
- * set bit 0x40
- */
- if((sc->bcw_phy_type == BCW_PHY_TYPEG) &&
- (sc->bcw_phy_rev < 3))
+ if ((sc->sc_phy_type == BCW_PHY_TYPEG) &&
+ ((sc->sc_boardflags & BCW_BF_PACTRL) == BCW_BF_PACTRL))
+ sbval |= 0x40;
+ if((sc->sc_phy_type == BCW_PHY_TYPEG) &&
+ (sc->sc_phy_rev < 3))
sbval |= 0x8; /* MAGIC */
- /* XXX If BoardFlags BFL_XTAL is set, set bit 0x400 */
- if(sc->bcw_phy_type == BCW_PHY_TYPEB)
+ if ((sc->sc_boardflags & BCW_BF_XTAL) == BCW_BF_XTAL)
+ sbval |= 0x400;
+ if(sc->sc_phy_type == BCW_PHY_TYPEB)
sbval |= 0x4;
- if((sc->bcw_radiotype == 0x2050) &&
- (sc->bcw_radiorev <= 5))
+ if((sc->sc_radiotype == 0x2050) &&
+ (sc->sc_radiorev <= 5))
sbval |= 0x40000;
/*
* XXX If the device isn't up and this is a PCI bus with revision
@@ -577,10 +624,12 @@ bcw_attach(struct bcw_softc *sc)
* This explanation could make more sense, but an SHM read/write
* wrapper of some sort would be better.
*/
- BCW_WRITE32(regs, BCW_SHM_CONTROL,
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_SHM_CONTROL,
(BCW_SHM_CONTROL_SHARED << 16) + BCW_SHM_MICROCODEFLAGSLOW - 2);
- BCW_WRITE16(regs, BCW_SHM_DATAHIGH, sbval & 0x00ff);
- BCW_WRITE16(regs, BCW_SHM_DATALOW, (sbval & 0xff00)>>16);
+ bus_space_write_2(sc->sc_iot, sc->sc_ioh, BCW_SHM_DATAHIGH,
+ sbval & 0x00ff);
+ bus_space_write_2(sc->sc_iot, sc->sc_ioh, BCW_SHM_DATALOW,
+ (sbval & 0xff00)>>16);
/*
* Initialize the TSSI to DBM table
@@ -591,7 +640,7 @@ bcw_attach(struct bcw_softc *sc)
/*
* TODO still for the card attach:
- * - Disable the 80211 Core
+ * - Disable the 80211 Core (and wrapper for on/off)
* - Powercontrol Crystal Off (and write a wrapper for on/off)
* - Setup LEDs to blink in whatever fashionable manner
*/
@@ -599,68 +648,9 @@ bcw_attach(struct bcw_softc *sc)
/*
* Allocate DMA-safe memory for ring descriptors.
* The receive, and transmit rings are 4k aligned
- * XXX - still not too sure on how this works, it is
- * some of the remaining untouched code from if_bce
*/
- if ((error = bus_dmamem_alloc(sc->bcw_dmatag,
- 2 * PAGE_SIZE, PAGE_SIZE, 2 * PAGE_SIZE,
- &seg, 1, &rseg, BUS_DMA_NOWAIT))) {
- printf("%s: unable to alloc space for ring descriptors, "
- "error = %d\n", sc->bcw_dev.dv_xname, error);
- return;
- }
- /* map ring space to kernel */
- if ((error = bus_dmamem_map(sc->bcw_dmatag, &seg, rseg,
- 2 * PAGE_SIZE, &kva, BUS_DMA_NOWAIT))) {
- printf("%s: unable to map DMA buffers, error = %d\n",
- sc->bcw_dev.dv_xname, error);
- bus_dmamem_free(sc->bcw_dmatag, &seg, rseg);
- return;
- }
- /* create a dma map for the ring */
- if ((error = bus_dmamap_create(sc->bcw_dmatag,
- 2 * PAGE_SIZE, 1, 2 * PAGE_SIZE, 0, BUS_DMA_NOWAIT,
- &sc->bcw_ring_map))) {
- printf("%s: unable to create ring DMA map, error = %d\n",
- sc->bcw_dev.dv_xname, error);
- bus_dmamem_unmap(sc->bcw_dmatag, kva, 2 * PAGE_SIZE);
- bus_dmamem_free(sc->bcw_dmatag, &seg, rseg);
- return;
- }
- /* connect the ring space to the dma map */
- if (bus_dmamap_load(sc->bcw_dmatag, sc->bcw_ring_map, kva,
- 2 * PAGE_SIZE, NULL, BUS_DMA_NOWAIT)) {
- bus_dmamap_destroy(sc->bcw_dmatag, sc->bcw_ring_map);
- bus_dmamem_unmap(sc->bcw_dmatag, kva, 2 * PAGE_SIZE);
- bus_dmamem_free(sc->bcw_dmatag, &seg, rseg);
- return;
- }
- /* save the ring space in softc */
- sc->bcw_rx_ring = (struct bcw_dma_slot *) kva;
- sc->bcw_tx_ring = (struct bcw_dma_slot *) (kva + PAGE_SIZE);
-
- /* Create the transmit buffer DMA maps. */
- for (i = 0; i < BCW_NTXDESC; i++) {
- if ((error = bus_dmamap_create(sc->bcw_dmatag, MCLBYTES,
- BCW_NTXFRAGS, MCLBYTES, 0, 0,
- &sc->bcw_cdata.bcw_tx_map[i])) != 0) {
- printf("%s: unable to create tx DMA map, error = %d\n",
- sc->bcw_dev.dv_xname, error);
- }
- sc->bcw_cdata.bcw_tx_chain[i] = NULL;
- }
-
- /* Create the receive buffer DMA maps. */
- for (i = 0; i < BCW_NRXDESC; i++) {
- if ((error = bus_dmamap_create(sc->bcw_dmatag, MCLBYTES, 1,
- MCLBYTES, 0, 0, &sc->bcw_cdata.bcw_rx_map[i])) != 0) {
- printf("%s: unable to create rx DMA map, error = %d\n",
- sc->bcw_dev.dv_xname, error);
- }
- sc->bcw_cdata.bcw_rx_chain[i] = NULL;
- }
-
- /* End of the DMA stuff */
+ bcw_alloc_rx_ring(sc, &sc->sc_rxring, BCW_RX_RING_COUNT);
+ bcw_alloc_tx_ring(sc, &sc->sc_txring, BCW_TX_RING_COUNT);
ic->ic_phytype = IEEE80211_T_OFDM;
ic->ic_opmode = IEEE80211_M_STA; /* default to BSS mode */
@@ -670,24 +660,30 @@ bcw_attach(struct bcw_softc *sc)
ic->ic_caps = IEEE80211_C_IBSS; /* IBSS mode supported */
/* MAC address */
- if(sc->bcw_phy_type == BCW_PHY_TYPEA) {
- i=BCW_READ16(regs, BCW_SPROM_ET1MACADDR);
+ if(sc->sc_phy_type == BCW_PHY_TYPEA) {
+ i = bus_space_read_2(sc->sc_iot, sc->sc_ioh,
+ BCW_SPROM_ET1MACADDR);
ic->ic_myaddr[0] = (i & 0xff00) >> 8;
ic->ic_myaddr[1] = i & 0xff;
- i=BCW_READ16(regs, BCW_SPROM_ET1MACADDR + 2);
+ i = bus_space_read_2(sc->sc_iot, sc->sc_ioh,
+ BCW_SPROM_ET1MACADDR + 2);
ic->ic_myaddr[2] = (i & 0xff00) >> 8;
ic->ic_myaddr[3] = i & 0xff;
- i=BCW_READ16(regs, BCW_SPROM_ET1MACADDR + 4);
+ i = bus_space_read_2(sc->sc_iot, sc->sc_ioh,
+ BCW_SPROM_ET1MACADDR + 4);
ic->ic_myaddr[4] = (i & 0xff00) >> 8;
ic->ic_myaddr[5] = i & 0xff;
} else { /* assume B or G PHY */
- i=BCW_READ16(regs, BCW_SPROM_IL0MACADDR);
+ i = bus_space_read_2(sc->sc_iot, sc->sc_ioh,
+ BCW_SPROM_IL0MACADDR);
ic->ic_myaddr[0] = (i & 0xff00) >> 8;
ic->ic_myaddr[1] = i & 0xff;
- i=BCW_READ16(regs, BCW_SPROM_IL0MACADDR + 2);
+ i = bus_space_read_2(sc->sc_iot, sc->sc_ioh,
+ BCW_SPROM_IL0MACADDR + 2);
ic->ic_myaddr[2] = (i & 0xff00) >> 8;
ic->ic_myaddr[3] = i & 0xff;
- i=BCW_READ16(regs, BCW_SPROM_IL0MACADDR + 4);
+ i = bus_space_read_2(sc->sc_iot, sc->sc_ioh,
+ BCW_SPROM_IL0MACADDR + 4);
ic->ic_myaddr[4] = (i & 0xff00) >> 8;
ic->ic_myaddr[5] = i & 0xff;
}
@@ -718,7 +714,7 @@ bcw_attach(struct bcw_softc *sc)
ifp->if_start = bcw_start;
ifp->if_watchdog = bcw_watchdog;
IFQ_SET_READY(&ifp->if_snd);
- bcopy(sc->bcw_dev.dv_xname, ifp->if_xname, IFNAMSIZ);
+ bcopy(sc->sc_dev.dv_xname, ifp->if_xname, IFNAMSIZ);
/* Attach the interface */
if_attach(ifp);
@@ -728,7 +724,7 @@ bcw_attach(struct bcw_softc *sc)
ic->ic_newstate = bcw_newstate;
ieee80211_media_init(ifp, bcw_media_change, bcw_media_status);
- timeout_set(&sc->bcw_timeout, bcw_tick, sc);
+ timeout_set(&sc->sc_timeout, bcw_tick, sc);
}
/* handle media, and ethernet requests */
@@ -736,19 +732,12 @@ int
bcw_ioctl(struct ifnet *ifp, u_long cmd, caddr_t data)
{
struct bcw_softc *sc = ifp->if_softc;
- struct ieee80211com *ic = &sc->bcw_ic;
- //struct bcw_regs *regs = &sc->bcw_regs;
+ struct ieee80211com *ic = &sc->sc_ic;
struct ifreq *ifr = (struct ifreq *) data;
struct ifaddr *ifa = (struct ifaddr *)data;
int s, error = 0;
s = splnet();
-#if 0
- if ((error = ether_ioctl(ifp, &sc->bcw_ac, cmd, data)) > 0) {
- splx(s);
- return (error);
- }
-#endif
switch (cmd) {
case SIOCSIFADDR:
@@ -758,7 +747,7 @@ bcw_ioctl(struct ifnet *ifp, u_long cmd, caddr_t data)
#ifdef INET
case AF_INET:
bcw_init(ifp);
- arp_ifinit(&sc->bcw_ac, ifa);
+ /* XXX arp_ifinit(&sc->bcw_ac, ifa); */
break;
#endif /* INET */
default:
@@ -810,14 +799,13 @@ bcw_ioctl(struct ifnet *ifp, u_long cmd, caddr_t data)
void
bcw_start(struct ifnet *ifp)
{
- struct bcw_softc *sc = ifp->if_softc;
- struct bcw_regs *regs = &sc->bcw_regs;
- struct mbuf *m0;
- bus_dmamap_t dmamap;
- int txstart;
- int txsfree;
+// struct bcw_softc *sc = ifp->if_softc;
+// struct mbuf *m0;
+// bus_dmamap_t dmamap;
+// int txstart;
+// int txsfree;
int newpkts = 0;
- int error;
+// int error;
/*
* do not start another if currently transmitting, and more
@@ -826,11 +814,12 @@ bcw_start(struct ifnet *ifp)
if ((ifp->if_flags & (IFF_RUNNING | IFF_OACTIVE)) != IFF_RUNNING)
return;
+#if 0 /* FIXME */
/* determine number of descriptors available */
- if (sc->bcw_txsnext >= sc->bcw_txin)
- txsfree = BCW_NTXDESC - 1 + sc->bcw_txin - sc->bcw_txsnext;
+ if (sc->sc_txsnext >= sc->sc_txin)
+ txsfree = BCW_NTXDESC - 1 + sc->sc_txin - sc->sc_txsnext;
else
- txsfree = sc->bcw_txin - sc->bcw_txsnext - 1;
+ txsfree = sc->sc_txin - sc->sc_txsnext - 1;
/*
* Loop through the send queue, setting up transmit descriptors
@@ -846,7 +835,7 @@ bcw_start(struct ifnet *ifp)
break;
/* get the transmit slot dma map */
- dmamap = sc->bcw_cdata.bcw_tx_map[sc->bcw_txsnext];
+ dmamap = sc->sc_cdata.bcw_tx_map[sc->sc_txsnext];
/*
* Load the DMA map. If this fails, the packet either
@@ -855,11 +844,11 @@ bcw_start(struct ifnet *ifp)
* it will be dropped. If short on resources, it will
* be tried again later.
*/
- error = bus_dmamap_load_mbuf(sc->bcw_dmatag, dmamap, m0,
+ error = bus_dmamap_load_mbuf(sc->sc_dmat, dmamap, m0,
BUS_DMA_WRITE | BUS_DMA_NOWAIT);
if (error == EFBIG) {
printf("%s: Tx packet consumes too many DMA segments, "
- "dropping...\n", sc->bcw_dev.dv_xname);
+ "dropping...\n", sc->sc_dev.dv_xname);
IFQ_DEQUEUE(&ifp->if_snd, m0);
m_freem(m0);
ifp->if_oerrors++;
@@ -867,13 +856,13 @@ bcw_start(struct ifnet *ifp)
} else if (error) {
/* short on resources, come back later */
printf("%s: unable to load Tx buffer, error = %d\n",
- sc->bcw_dev.dv_xname, error);
+ sc->sc_dev.dv_xname, error);
break;
}
/* If not enough descriptors available, try again later */
if (dmamap->dm_nsegs > txsfree) {
ifp->if_flags |= IFF_OACTIVE;
- bus_dmamap_unload(sc->bcw_dmatag, dmamap);
+ bus_dmamap_unload(sc->sc_dmat, dmamap);
break;
}
/* WE ARE NOW COMMITTED TO TRANSMITTING THE PACKET. */
@@ -882,14 +871,14 @@ bcw_start(struct ifnet *ifp)
IFQ_DEQUEUE(&ifp->if_snd, m0);
/* save the pointer so it can be freed later */
- sc->bcw_cdata.bcw_tx_chain[sc->bcw_txsnext] = m0;
+ sc->sc_cdata.bcw_tx_chain[sc->sc_txsnext] = m0;
/* Sync the data DMA map. */
- bus_dmamap_sync(sc->bcw_dmatag, dmamap, 0, dmamap->dm_mapsize,
+ bus_dmamap_sync(sc->sc_dmat, dmamap, 0, dmamap->dm_mapsize,
BUS_DMASYNC_PREWRITE);
/* Initialize the transmit descriptor(s). */
- txstart = sc->bcw_txsnext;
+ txstart = sc->sc_txsnext;
for (seg = 0; seg < dmamap->dm_nsegs; seg++) {
u_int32_t ctrl;
@@ -898,28 +887,28 @@ bcw_start(struct ifnet *ifp)
ctrl |= CTRL_SOF;
if (seg == dmamap->dm_nsegs - 1)
ctrl |= CTRL_EOF;
- if (sc->bcw_txsnext == BCW_NTXDESC - 1)
+ if (sc->sc_txsnext == BCW_NTXDESC - 1)
ctrl |= CTRL_EOT;
ctrl |= CTRL_IOC;
- sc->bcw_tx_ring[sc->bcw_txsnext].ctrl = htole32(ctrl);
+ sc->bcw_tx_ring[sc->sc_txsnext].ctrl = htole32(ctrl);
/* MAGIC */
- sc->bcw_tx_ring[sc->bcw_txsnext].addr =
+ sc->bcw_tx_ring[sc->sc_txsnext].addr =
htole32(dmamap->dm_segs[seg].ds_addr + 0x40000000);
- if (sc->bcw_txsnext + 1 > BCW_NTXDESC - 1)
- sc->bcw_txsnext = 0;
+ if (sc->sc_txsnext + 1 > BCW_NTXDESC - 1)
+ sc->sc_txsnext = 0;
else
- sc->bcw_txsnext++;
+ sc->sc_txsnext++;
txsfree--;
}
/* sync descriptors being used */
- bus_dmamap_sync(sc->bcw_dmatag, sc->bcw_ring_map,
+ bus_dmamap_sync(sc->sc_dmat, sc->sc_ring_map,
sizeof(struct bcw_dma_slot) * txstart + PAGE_SIZE,
sizeof(struct bcw_dma_slot) * dmamap->dm_nsegs,
BUS_DMASYNC_PREREAD | BUS_DMASYNC_PREWRITE);
/* Give the packet to the chip. */
- BCW_WRITE32(regs, BCW_DMA_DPTR,
- sc->bcw_txsnext * sizeof(struct bcw_dma_slot));
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_DMA_DPTR,
+ sc->sc_txsnext * sizeof(struct bcw_dma_slot));
newpkts++;
@@ -933,6 +922,7 @@ bcw_start(struct ifnet *ifp)
/* No more slots left; notify upper layer. */
ifp->if_flags |= IFF_OACTIVE;
}
+#endif /* FIXME */
if (newpkts) {
/* Set a watchdog timer in case the chip flakes out. */
ifp->if_timer = 5;
@@ -945,7 +935,7 @@ bcw_watchdog(struct ifnet *ifp)
{
struct bcw_softc *sc = ifp->if_softc;
- printf("%s: device timeout\n", sc->bcw_dev.dv_xname);
+ printf("%s: device timeout\n", sc->sc_dev.dv_xname);
ifp->if_oerrors++;
(void) bcw_init(ifp);
@@ -958,28 +948,27 @@ int
bcw_intr(void *xsc)
{
struct bcw_softc *sc;
- struct bcw_regs *regs;
struct ifnet *ifp;
u_int32_t intstatus;
int wantinit;
int handled = 0;
sc = xsc;
- regs = &sc->bcw_regs;
- ifp = &sc->bcw_ac.ac_if;
for (wantinit = 0; wantinit == 0;) {
- intstatus = BCW_READ32(regs, BCW_INT_STS);
+ intstatus = bus_space_read_4(sc->sc_iot, sc->sc_ioh,
+ BCW_INT_STS);
/* ignore if not ours, or unsolicited interrupts */
- intstatus &= sc->bcw_intmask;
+ intstatus &= sc->sc_intmask;
if (intstatus == 0)
break;
handled = 1;
/* Ack interrupt */
- BCW_WRITE32(regs, BCW_INT_STS, intstatus);
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_INT_STS,
+ intstatus);
/* Receive interrupts. */
if (intstatus & I_RI)
@@ -991,27 +980,27 @@ bcw_intr(void *xsc)
if (intstatus & ~(I_RI | I_XI)) {
if (intstatus & I_XU)
printf("%s: transmit fifo underflow\n",
- sc->bcw_dev.dv_xname);
+ sc->sc_dev.dv_xname);
if (intstatus & I_RO) {
printf("%s: receive fifo overflow\n",
- sc->bcw_dev.dv_xname);
+ sc->sc_dev.dv_xname);
ifp->if_ierrors++;
}
if (intstatus & I_RU)
printf("%s: receive descriptor underflow\n",
- sc->bcw_dev.dv_xname);
+ sc->sc_dev.dv_xname);
if (intstatus & I_DE)
printf("%s: descriptor protocol error\n",
- sc->bcw_dev.dv_xname);
+ sc->sc_dev.dv_xname);
if (intstatus & I_PD)
printf("%s: data error\n",
- sc->bcw_dev.dv_xname);
+ sc->sc_dev.dv_xname);
if (intstatus & I_PC)
printf("%s: descriptor error\n",
- sc->bcw_dev.dv_xname);
+ sc->sc_dev.dv_xname);
if (intstatus & I_TO)
printf("%s: general purpose timeout\n",
- sc->bcw_dev.dv_xname);
+ sc->sc_dev.dv_xname);
wantinit = 1;
}
}
@@ -1029,35 +1018,35 @@ bcw_intr(void *xsc)
void
bcw_rxintr(struct bcw_softc *sc)
{
- struct ifnet *ifp = &sc->bcw_ac.ac_if;
- struct bcw_regs *regs = &sc->bcw_regs;
- struct rx_pph *pph;
- struct mbuf *m;
+// struct rx_pph *pph;
+// struct mbuf *m;
int curr;
- int len;
- int i;
+// int len;
+// int i;
/* get pointer to active receive slot */
- curr = BCW_READ32(regs, BCW_DMA_RXSTATUS) & RS_CD_MASK;
+ curr = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_DMA_RXSTATUS(0)) &
+ RS_CD_MASK;
curr = curr / sizeof(struct bcw_dma_slot);
- if (curr >= BCW_NRXDESC)
- curr = BCW_NRXDESC - 1;
+ if (curr >= BCW_RX_RING_COUNT)
+ curr = BCW_RX_RING_COUNT - 1;
+#if 0
/* process packets up to but not current packet being worked on */
- for (i = sc->bcw_rxin; i != curr;
+ for (i = sc->sc_rxin; i != curr;
i + 1 > BCW_NRXDESC - 1 ? i = 0 : i++) {
/* complete any post dma memory ops on packet */
- bus_dmamap_sync(sc->bcw_dmatag, sc->bcw_cdata.bcw_rx_map[i], 0,
- sc->bcw_cdata.bcw_rx_map[i]->dm_mapsize,
+ bus_dmamap_sync(sc->sc_dmat, sc->sc_cdata.bcw_rx_map[i], 0,
+ sc->sc_cdata.bcw_rx_map[i]->dm_mapsize,
BUS_DMASYNC_POSTREAD);
/*
* If the packet had an error, simply recycle the buffer,
* resetting the len, and flags.
*/
- pph = mtod(sc->bcw_cdata.bcw_rx_chain[i], struct rx_pph *);
+ pph = mtod(sc->sc_cdata.bcw_rx_chain[i], struct rx_pph *);
if (pph->flags & (RXF_NO | RXF_RXER | RXF_CRC | RXF_OV)) {
- ifp->if_ierrors++;
+ /* XXX Increment input error count */
pph->len = 0;
pph->flags = 0;
continue;
@@ -1069,7 +1058,7 @@ bcw_rxintr(struct bcw_softc *sc)
pph->len = 0;
pph->flags = 0;
/* bump past pre header to packet */
- sc->bcw_cdata.bcw_rx_chain[i]->m_data +=
+ sc->sc_cdata.bcw_rx_chain[i]->m_data +=
BCW_PREPKT_HEADER_SIZE;
/*
@@ -1095,20 +1084,20 @@ bcw_rxintr(struct bcw_softc *sc)
goto dropit;
m->m_data += 2;
memcpy(mtod(m, caddr_t),
- mtod(sc->bcw_cdata.bcw_rx_chain[i], caddr_t), len);
- sc->bcw_cdata.bcw_rx_chain[i]->m_data -=
+ mtod(sc->sc_cdata.bcw_rx_chain[i], caddr_t), len);
+ sc->sc_cdata.bcw_rx_chain[i]->m_data -=
BCW_PREPKT_HEADER_SIZE;
} else {
- m = sc->bcw_cdata.bcw_rx_chain[i];
+ m = sc->sc_cdata.bcw_rx_chain[i];
if (bcw_add_rxbuf(sc, i) != 0) {
dropit:
- ifp->if_ierrors++;
+ /* XXX increment wireless input error counter */
/* continue to use old buffer */
- sc->bcw_cdata.bcw_rx_chain[i]->m_data -=
+ sc->sc_cdata.bcw_rx_chain[i]->m_data -=
BCW_PREPKT_HEADER_SIZE;
- bus_dmamap_sync(sc->bcw_dmatag,
- sc->bcw_cdata.bcw_rx_map[i], 0,
- sc->bcw_cdata.bcw_rx_map[i]->dm_mapsize,
+ bus_dmamap_sync(sc->sc_dmat,
+ sc->sc_cdata.bcw_rx_map[i], 0,
+ sc->sc_cdata.bcw_rx_map[i]->dm_mapsize,
BUS_DMASYNC_PREREAD);
continue;
}
@@ -1116,70 +1105,73 @@ bcw_rxintr(struct bcw_softc *sc)
m->m_pkthdr.rcvif = ifp;
m->m_pkthdr.len = m->m_len = len;
- ifp->if_ipackets++;
+ /* XXX Increment input packet count */
#if NBPFILTER > 0
/*
* Pass this up to any BPF listeners, but only
* pass it up the stack if it's for us.
+ *
+ * if (ifp->if_bpf)
+ * bpf_mtap(ifp->if_bpf, m, BPF_DIRECTION_IN);
*/
- if (ifp->if_bpf)
- bpf_mtap(ifp->if_bpf, m, BPF_DIRECTION_IN);
#endif /* NBPFILTER > 0 */
- /* Pass it on. */
- ether_input_mbuf(ifp, m);
+ /* XXX Pass it on. */
+ //ether_input_mbuf(ifp, m);
/* re-check current in case it changed */
- curr = (BCW_READ32(regs,
+ curr = (bus_space_read_4(sc->sc_iot, sc->sc_ioh,
BCW_DMA_RXSTATUS) & RS_CD_MASK) /
sizeof(struct bcw_dma_slot);
if (curr >= BCW_NRXDESC)
curr = BCW_NRXDESC - 1;
}
- sc->bcw_rxin = curr;
+ sc->sc_rxin = curr;
+#endif
}
/* Transmit interrupt handler */
void
bcw_txintr(struct bcw_softc *sc)
{
- struct ifnet *ifp = &sc->bcw_ac.ac_if;
- struct bcw_regs *regs = &sc->bcw_regs;
+// struct ifnet *ifp = &sc->bcw_ac.ac_if;
int curr;
- int i;
+// int i;
- ifp->if_flags &= ~IFF_OACTIVE;
+// ifp->if_flags &= ~IFF_OACTIVE;
+#if 0
/*
* Go through the Tx list and free mbufs for those
* frames which have been transmitted.
*/
- curr = BCW_READ32(regs, BCW_DMA_TXSTATUS) & RS_CD_MASK;
+ curr = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_DMA_TXSTATUS) & RS_CD_MASK;
curr = curr / sizeof(struct bcw_dma_slot);
if (curr >= BCW_NTXDESC)
curr = BCW_NTXDESC - 1;
- for (i = sc->bcw_txin; i != curr;
+ for (i = sc->sc_txin; i != curr;
i + 1 > BCW_NTXDESC - 1 ? i = 0 : i++) {
/* do any post dma memory ops on transmit data */
- if (sc->bcw_cdata.bcw_tx_chain[i] == NULL)
+ if (sc->sc_cdata.bcw_tx_chain[i] == NULL)
continue;
- bus_dmamap_sync(sc->bcw_dmatag, sc->bcw_cdata.bcw_tx_map[i], 0,
- sc->bcw_cdata.bcw_tx_map[i]->dm_mapsize,
+ bus_dmamap_sync(sc->sc_dmat, sc->sc_cdata.bcw_tx_map[i], 0,
+ sc->sc_cdata.bcw_tx_map[i]->dm_mapsize,
BUS_DMASYNC_POSTWRITE);
- bus_dmamap_unload(sc->bcw_dmatag, sc->bcw_cdata.bcw_tx_map[i]);
- m_freem(sc->bcw_cdata.bcw_tx_chain[i]);
- sc->bcw_cdata.bcw_tx_chain[i] = NULL;
+ bus_dmamap_unload(sc->sc_dmat, sc->sc_cdata.bcw_tx_map[i]);
+ m_freem(sc->sc_cdata.bcw_tx_chain[i]);
+ sc->sc_cdata.bcw_tx_chain[i] = NULL;
ifp->if_opackets++;
}
- sc->bcw_txin = curr;
+#endif
+ sc->sc_txin = curr;
/*
* If there are no more pending transmissions, cancel the watchdog
* timer
*/
- if (sc->bcw_txsnext == sc->bcw_txin)
- ifp->if_timer = 0;
+// if (sc->sc_txsnext == sc->sc_txin)
+// ifp->if_timer = 0;
}
/* initialize the interface */
@@ -1187,10 +1179,7 @@ int
bcw_init(struct ifnet *ifp)
{
struct bcw_softc *sc = ifp->if_softc;
- struct bcw_regs *regs = &sc->bcw_regs;
u_int32_t reg_win;
- int error;
- int i;
/* Cancel any pending I/O. */
bcw_stop(ifp, 0);
@@ -1202,118 +1191,101 @@ bcw_init(struct ifnet *ifp)
* written for.
*/
- /* enable pci inerrupts, bursts, and prefetch */
+ /* enable pci interrupts, bursts, and prefetch */
/* remap the pci registers to the Sonics config registers */
/* save the current map, so it can be restored */
- reg_win = BCW_READ32(regs, BCW_REG0_WIN);
+ reg_win = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_REG0_WIN);
/* set register window to Sonics registers */
- BCW_WRITE32(regs, BCW_REG0_WIN, BCW_SONICS_WIN);
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_REG0_WIN, BCW_SONICS_WIN);
/* enable SB to PCI interrupt */
- BCW_WRITE32(regs, BCW_SBINTVEC,
- BCW_READ32(regs, BCW_SBINTVEC) |
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_SBINTVEC,
+ bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_SBINTVEC) |
SBIV_ENET0);
/* enable prefetch and bursts for sonics-to-pci translation 2 */
- BCW_WRITE32(regs, BCW_SPCI_TR2,
- BCW_READ32(regs, BCW_SPCI_TR2) |
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_SPCI_TR2,
+ bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_SPCI_TR2) |
SBTOPCI_PREF | SBTOPCI_BURST);
/* restore to ethernet register space */
- BCW_WRITE32(regs, BCW_REG0_WIN, reg_win);
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_REG0_WIN, reg_win);
/* Reset the chip to a known state. */
bcw_reset(sc);
+#if 0 /* FIXME */
/* Initialize transmit descriptors */
memset(sc->bcw_tx_ring, 0, BCW_NTXDESC * sizeof(struct bcw_dma_slot));
- sc->bcw_txsnext = 0;
- sc->bcw_txin = 0;
+ sc->sc_txsnext = 0;
+ sc->sc_txin = 0;
+#endif
/* enable crc32 generation and set proper LED modes */
- BCW_WRITE32(regs, BCW_MACCTL,
- BCW_READ32(regs, BCW_MACCTL) |
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_MACCTL,
+ bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_MACCTL) |
BCW_EMC_CRC32_ENAB | BCW_EMC_LED);
/* reset or clear powerdown control bit */
- BCW_WRITE32(regs, BCW_MACCTL,
- BCW_READ32(regs, BCW_MACCTL) &
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_MACCTL,
+ bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_MACCTL) &
~BCW_EMC_PDOWN);
/* setup DMA interrupt control */
- BCW_WRITE32(regs, BCW_DMAI_CTL, 1 << 24); /* MAGIC */
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_DMAI_CTL, 1 << 24); /* MAGIC */
/* setup packet filter */
bcw_set_filter(ifp);
/* set max frame length, account for possible VLAN tag */
- BCW_WRITE32(regs, BCW_RX_MAX,
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_RX_MAX,
ETHER_MAX_LEN + ETHER_VLAN_ENCAP_LEN);
- BCW_WRITE32(regs, BCW_TX_MAX,
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_TX_MAX,
ETHER_MAX_LEN + ETHER_VLAN_ENCAP_LEN);
/* set tx watermark */
- BCW_WRITE32(regs, BCW_TX_WATER, 56);
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_TX_WATER, 56);
/* enable transmit */
- BCW_WRITE32(regs, BCW_DMA_TXCTL, XC_XE);
- /* MAGIC */
- BCW_WRITE32(regs, BCW_DMA_TXADDR,
- sc->bcw_ring_map->dm_segs[0].ds_addr + PAGE_SIZE + 0x40000000);
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_DMA_TXCTL, XC_XE);
/*
* Give the receive ring to the chip, and
* start the receive DMA engine.
*/
- sc->bcw_rxin = 0;
+ sc->sc_rxin = 0;
- /* clear the rx descriptor ring */
- memset(sc->bcw_rx_ring, 0, BCW_NRXDESC * sizeof(struct bcw_dma_slot));
/* enable receive */
- BCW_WRITE32(regs, BCW_DMA_RXCTL,
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_DMA_RXCTL,
BCW_PREPKT_HEADER_SIZE << 1 | 1);
- BCW_WRITE32(regs, BCW_DMA_RXADDR,
- sc->bcw_ring_map->dm_segs[0].ds_addr + 0x40000000); /* MAGIC */
-
- /* Initalize receive descriptors */
- for (i = 0; i < BCW_NRXDESC; i++) {
- if (sc->bcw_cdata.bcw_rx_chain[i] == NULL) {
- if ((error = bcw_add_rxbuf(sc, i)) != 0) {
- printf("%s: unable to allocate or map rx(%d) "
- "mbuf, error = %d\n", sc->bcw_dev.dv_xname,
- i, error);
- bcw_rxdrain(sc);
- return (error);
- }
- } else
- BCW_INIT_RXDESC(sc, i);
- }
/* Enable interrupts */
- sc->bcw_intmask =
+ sc->sc_intmask =
I_XI | I_RI | I_XU | I_RO | I_RU | I_DE | I_PD | I_PC | I_TO;
- BCW_WRITE32(regs, BCW_INT_MASK,
- sc->bcw_intmask);
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_INT_MASK,
+ sc->sc_intmask);
+#if 0 /* FIXME */
/* start the receive dma */
- BCW_WRITE32(regs, BCW_DMA_RXDPTR,
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_DMA_RXDPTR,
BCW_NRXDESC * sizeof(struct bcw_dma_slot));
+#endif
/* set media */
//mii_mediachg(&sc->bcw_mii);
/* turn on the ethernet mac */
#if 0
- bus_space_write_4(sc->bcw_btag, sc->bcw_bhandle, BCW_ENET_CTL,
- bus_space_read_4(sc->bcw_btag, sc->bcw_bhandle,
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_ENET_CTL,
+ bus_space_read_4(sc->sc_iot, sc->sc_ioh,
BCW_ENET_CTL) | EC_EE);
#endif
/* start timer */
- timeout_add(&sc->bcw_timeout, hz);
+ timeout_add(&sc->sc_timeout, hz);
/* mark as running, and no outputs active */
ifp->if_flags |= IFF_RUNNING;
@@ -1326,6 +1298,7 @@ bcw_init(struct ifnet *ifp)
int
bcw_add_rxbuf(struct bcw_softc *sc, int idx)
{
+#if 0
struct mbuf *m;
int error;
@@ -1338,24 +1311,26 @@ bcw_add_rxbuf(struct bcw_softc *sc, int idx)
m_freem(m);
return (ENOBUFS);
}
- if (sc->bcw_cdata.bcw_rx_chain[idx] != NULL)
- bus_dmamap_unload(sc->bcw_dmatag,
- sc->bcw_cdata.bcw_rx_map[idx]);
+ if (sc->sc_cdata.bcw_rx_chain[idx] != NULL)
+ bus_dmamap_unload(sc->sc_dmat,
+ sc->sc_cdata.bcw_rx_map[idx]);
- sc->bcw_cdata.bcw_rx_chain[idx] = m;
+ sc->sc_cdata.bcw_rx_chain[idx] = m;
- error = bus_dmamap_load(sc->bcw_dmatag, sc->bcw_cdata.bcw_rx_map[idx],
+ error = bus_dmamap_load(sc->sc_dmat, sc->sc_cdata.bcw_rx_map[idx],
m->m_ext.ext_buf, m->m_ext.ext_size, NULL,
BUS_DMA_READ | BUS_DMA_NOWAIT);
if (error)
return (error);
- bus_dmamap_sync(sc->bcw_dmatag, sc->bcw_cdata.bcw_rx_map[idx], 0,
- sc->bcw_cdata.bcw_rx_map[idx]->dm_mapsize, BUS_DMASYNC_PREREAD);
+ bus_dmamap_sync(sc->sc_dmat, sc->sc_cdata.bcw_rx_map[idx], 0,
+ sc->sc_cdata.bcw_rx_map[idx]->dm_mapsize, BUS_DMASYNC_PREREAD);
BCW_INIT_RXDESC(sc, idx);
return (0);
+#endif
+ return (1);
}
@@ -1363,16 +1338,18 @@ bcw_add_rxbuf(struct bcw_softc *sc, int idx)
void
bcw_rxdrain(struct bcw_softc *sc)
{
+#if 0 /* FIXME */
int i;
for (i = 0; i < BCW_NRXDESC; i++) {
- if (sc->bcw_cdata.bcw_rx_chain[i] != NULL) {
- bus_dmamap_unload(sc->bcw_dmatag,
- sc->bcw_cdata.bcw_rx_map[i]);
- m_freem(sc->bcw_cdata.bcw_rx_chain[i]);
- sc->bcw_cdata.bcw_rx_chain[i] = NULL;
+ if (sc->sc_cdata.bcw_rx_chain[i] != NULL) {
+ bus_dmamap_unload(sc->sc_dmat,
+ sc->sc_cdata.bcw_rx_map[i]);
+ m_freem(sc->sc_cdata.bcw_rx_chain[i]);
+ sc->sc_cdata.bcw_rx_chain[i] = NULL;
}
}
+#endif
}
/* Stop transmission on the interface */
@@ -1380,27 +1357,25 @@ void
bcw_stop(struct ifnet *ifp, int disable)
{
struct bcw_softc *sc = ifp->if_softc;
- struct bcw_regs *regs = &sc->bcw_regs;
- int i;
//u_int32_t val;
/* Stop the 1 second timer */
- timeout_del(&sc->bcw_timeout);
+ timeout_del(&sc->sc_timeout);
/* Mark the interface down and cancel the watchdog timer. */
ifp->if_flags &= ~(IFF_RUNNING | IFF_OACTIVE);
ifp->if_timer = 0;
/* Disable interrupts. */
- BCW_WRITE32(regs, BCW_INT_MASK, 0);
- sc->bcw_intmask = 0;
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_INT_MASK, 0);
+ sc->sc_intmask = 0;
delay(10);
/* Disable emac */
#if 0
- bus_space_write_4(sc->bcw_btag, sc->bcw_bhandle, BCW_ENET_CTL, EC_ED);
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_ENET_CTL, EC_ED);
for (i = 0; i < 200; i++) {
- val = bus_space_read_4(sc->bcw_btag, sc->bcw_bhandle,
+ val = bus_space_read_4(sc->sc_iot, sc->sc_ioh,
BCW_ENET_CTL);
if (!(val & EC_ED))
break;
@@ -1408,19 +1383,21 @@ bcw_stop(struct ifnet *ifp, int disable)
}
#endif
/* Stop the DMA */
- BCW_WRITE32(regs, BCW_DMA_RXCTL, 0);
- BCW_WRITE32(regs, BCW_DMA_TXCTL, 0);
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_DMA_RXCONTROL(0), 0);
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_DMA_TXCONTROL(0), 0);
delay(10);
+#if 0 /* FIXME */
/* Release any queued transmit buffers. */
for (i = 0; i < BCW_NTXDESC; i++) {
- if (sc->bcw_cdata.bcw_tx_chain[i] != NULL) {
- bus_dmamap_unload(sc->bcw_dmatag,
- sc->bcw_cdata.bcw_tx_map[i]);
- m_freem(sc->bcw_cdata.bcw_tx_chain[i]);
- sc->bcw_cdata.bcw_tx_chain[i] = NULL;
+ if (sc->sc_cdata.bcw_tx_chain[i] != NULL) {
+ bus_dmamap_unload(sc->sc_dmat,
+ sc->sc_cdata.bcw_tx_map[i]);
+ m_freem(sc->sc_cdata.bcw_tx_chain[i]);
+ sc->sc_cdata.bcw_tx_chain[i] = NULL;
}
}
+#endif
/* drain receive queue */
if (disable)
@@ -1431,43 +1408,45 @@ bcw_stop(struct ifnet *ifp, int disable)
void
bcw_reset(struct bcw_softc *sc)
{
- struct bcw_regs *regs = &sc->bcw_regs;
u_int32_t val;
u_int32_t sbval;
int i;
/* if SB core is up, only clock of clock,reset,reject will be set */
- sbval = BCW_READ32(regs, BCW_SBTMSTATELOW);
+ sbval = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_SBTMSTATELOW);
/* The core isn't running if the if the clock isn't enabled */
if ((sbval & (SBTML_RESET | SBTML_REJ | SBTML_CLK)) == SBTML_CLK) {
+#if 0
// Stop all DMA
- BCW_WRITE32(regs, BCW_DMAI_CTL, 0);
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_DMAI_CTL, 0);
/* reset the dma engines */
- BCW_WRITE32(regs, BCW_DMA_TXCTL, 0);
- val = BCW_READ32(regs, BCW_DMA_RXSTATUS);
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_DMA_TXCTL, 0);
+ val = bus_space_read_4(sc->sc_iot, sc->sc_ioh,
+ BCW_DMA_RXSTATUS);
/* if error on receive, wait to go idle */
if (val & RS_ERROR) {
for (i = 0; i < 100; i++) {
- val = BCW_READ32(regs, BCW_DMA_RXSTATUS);
+ val = bus_space_read_4(sc->sc_iot, sc->sc_ioh,
+ BCW_DMA_RXSTATUS);
if (val & RS_DMA_IDLE)
break;
delay(10);
}
if (i == 100)
printf("%s: receive dma did not go idle after"
- " error\n", sc->bcw_dev.dv_xname);
+ " error\n", sc->sc_dev.dv_xname);
}
- BCW_WRITE32(regs, BCW_DMA_RXSTATUS, 0);
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_DMA_RXSTATUS, 0);
/* reset ethernet mac */
-#if 0
- bus_space_write_4(sc->bcw_btag, sc->bcw_bhandle, BCW_ENET_CTL,
+
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_ENET_CTL,
EC_ES);
for (i = 0; i < 200; i++) {
- val = bus_space_read_4(sc->bcw_btag, sc->bcw_bhandle,
+ val = bus_space_read_4(sc->sc_iot, sc->sc_ioh,
BCW_ENET_CTL);
if (!(val & EC_ES))
break;
@@ -1475,116 +1454,123 @@ bcw_reset(struct bcw_softc *sc)
}
if (i == 200)
printf("%s: timed out resetting ethernet mac\n",
- sc->bcw_dev.dv_xname);
+ sc->sc_dev.dv_xname);
#endif
} else {
u_int32_t reg_win;
/* remap the pci registers to the Sonics config registers */
-
+#if 0
/* save the current map, so it can be restored */
- reg_win = BCW_READ32(regs, BCW_REG0_WIN);
+ reg_win = bus_space_read_4(sc->sc_iot, sc->sc_ioh,
+ BCW_REG0_WIN);
/* set register window to Sonics registers */
- BCW_WRITE32(regs, BCW_REG0_WIN, BCW_SONICS_WIN);
-
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_REG0_WIN,
+ BCW_SONICS_WIN);
+#endif
/* enable SB to PCI interrupt */
- BCW_WRITE32(regs, BCW_SBINTVEC,
- BCW_READ32(regs,
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_SBINTVEC,
+ bus_space_read_4(sc->sc_iot, sc->sc_ioh,
BCW_SBINTVEC) |
SBIV_ENET0);
/* enable prefetch and bursts for sonics-to-pci translation 2 */
- BCW_WRITE32(regs, BCW_SPCI_TR2,
- BCW_READ32(regs,
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_SPCI_TR2,
+ bus_space_read_4(sc->sc_iot, sc->sc_ioh,
BCW_SPCI_TR2) |
SBTOPCI_PREF | SBTOPCI_BURST);
/* restore to ethernet register space */
- BCW_WRITE32(regs, BCW_REG0_WIN, reg_win);
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_REG0_WIN, reg_win);
}
/* disable SB core if not in reset */
if (!(sbval & SBTML_RESET)) {
/* set the reject bit */
- BCW_WRITE32(regs, BCW_SBTMSTATELOW, SBTML_REJ | SBTML_CLK);
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_SBTMSTATELOW,
+ SBTML_REJ | SBTML_CLK);
for (i = 0; i < 200; i++) {
- val = BCW_READ32(regs, BCW_SBTMSTATELOW);
+ val = bus_space_read_4(sc->sc_iot, sc->sc_ioh,
+ BCW_SBTMSTATELOW);
if (val & SBTML_REJ)
break;
delay(1);
}
if (i == 200)
printf("%s: while resetting core, reject did not set\n",
- sc->bcw_dev.dv_xname);
+ sc->sc_dev.dv_xname);
/* wait until busy is clear */
for (i = 0; i < 200; i++) {
- val = BCW_READ32(regs, BCW_SBTMSTATEHI);
+ val = bus_space_read_4(sc->sc_iot, sc->sc_ioh,
+ BCW_SBTMSTATEHI);
if (!(val & 0x4))
break;
delay(1);
}
if (i == 200)
printf("%s: while resetting core, busy did not clear\n",
- sc->bcw_dev.dv_xname);
+ sc->sc_dev.dv_xname);
/* set reset and reject while enabling the clocks */
- BCW_WRITE32(regs, BCW_SBTMSTATELOW,
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_SBTMSTATELOW,
SBTML_FGC | SBTML_CLK | SBTML_REJ | SBTML_RESET |
SBTML_80211FLAG);
- val = BCW_READ32(regs, BCW_SBTMSTATELOW);
+ val = bus_space_read_4(sc->sc_iot, sc->sc_ioh,
+ BCW_SBTMSTATELOW);
delay(10);
- BCW_WRITE32(regs, BCW_SBTMSTATELOW, SBTML_REJ | SBTML_RESET);
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_SBTMSTATELOW,
+ SBTML_REJ | SBTML_RESET);
delay(1);
}
/* This is enabling/resetting the core */
/* enable clock */
- BCW_WRITE32(regs, BCW_SBTMSTATELOW,
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_SBTMSTATELOW,
SBTML_FGC | SBTML_CLK | SBTML_RESET |
SBTML_80211FLAG | SBTML_80211PHY );
- val = BCW_READ32(regs, BCW_SBTMSTATELOW);
+ val = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_SBTMSTATELOW);
delay(1);
/* clear any error bits that may be on */
- val = BCW_READ32(regs, BCW_SBTMSTATEHI);
+ val = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_SBTMSTATEHI);
if (val & 1)
- BCW_WRITE32(regs, BCW_SBTMSTATEHI, 0);
- val = BCW_READ32(regs, BCW_SBIMSTATE);
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_SBTMSTATEHI, 0);
+ val = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_SBIMSTATE);
if (val & SBIM_MAGIC_ERRORBITS)
- BCW_WRITE32(regs, BCW_SBIMSTATE,
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_SBIMSTATE,
val & ~SBIM_MAGIC_ERRORBITS);
/* clear reset and allow it to propagate throughout the core */
- BCW_WRITE32(regs, BCW_SBTMSTATELOW,
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_SBTMSTATELOW,
SBTML_FGC | SBTML_CLK | SBTML_80211FLAG | SBTML_80211PHY );
- val = BCW_READ32(regs, BCW_SBTMSTATELOW);
+ val = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_SBTMSTATELOW);
delay(1);
/* leave clock enabled */
- BCW_WRITE32(regs, BCW_SBTMSTATELOW,
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_SBTMSTATELOW,
SBTML_CLK | SBTML_80211FLAG | SBTML_80211PHY);
- val = BCW_READ32(regs, BCW_SBTMSTATELOW);
+ val = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_SBTMSTATELOW);
delay(1);
-
+#if 0
/* Write a 0 to MMIO reg 0x3e6, Baseband attenuation */
- BCW_WRITE16(regs, 0x3e6,0);
-
+ bus_space_write_2(sc->sc_iot, sc->sc_ioh, 0x3e6,0);
+#endif
/* Set 0x400 in the MMIO StatusBitField reg */
- sbval=BCW_READ32(regs, 0x120);
+ sbval=bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_SBF);
sbval |= 0x400;
- BCW_WRITE32(regs, 0x120, sbval);
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_SBF, sbval);
#if 0
/* initialize MDC preamble, frequency */
/* MAGIC */
- bus_space_write_4(sc->bcw_btag, sc->bcw_bhandle, BCW_MI_CTL, 0x8d);
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_MI_CTL, 0x8d);
/* enable phy, differs for internal, and external */
- val = bus_space_read_4(sc->bcw_btag, sc->bcw_bhandle, BCW_DEVCTL);
+ val = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_DEVCTL);
if (!(val & BCW_DC_IP)) {
/* select external phy */
- bus_space_write_4(sc->bcw_btag, sc->bcw_bhandle, BCW_ENET_CTL,
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_ENET_CTL,
EC_EP);
} else if (val & BCW_DC_ER) { /* internal, clear reset bit if on */
- bus_space_write_4(sc->bcw_btag, sc->bcw_bhandle, BCW_DEVCTL,
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_DEVCTL,
val & ~BCW_DC_ER);
delay(100);
}
@@ -1626,7 +1612,7 @@ bcw_set_filter(struct ifnet *ifp)
0);
/* add our own address */
- bcw_add_mac(sc, sc->bcw_ac.ac_enaddr, 0);
+ // bcw_add_mac(sc, sc->bcw_ac.ac_enaddr, 0);
/* for now accept all multicast */
bus_space_write_4(sc->bcw_btag, sc->bcw_bhandle, BCW_RX_CTL,
@@ -1674,9 +1660,9 @@ void
bcw_media_status(struct ifnet *ifp, struct ifmediareq *imr)
{
struct bcw_softc *sc = ifp->if_softc;
- struct ieee80211com *ic = &sc->bcw_ic;
+ struct ieee80211com *ic = &sc->sc_ic;
//uint32_t val;
- int rate;
+ int rate;
imr->ifm_status = IFM_AVALID;
imr->ifm_active = IFM_IEEE80211;
@@ -1725,7 +1711,6 @@ bcw_tick(void *v)
int
bcw_validatechipaccess(struct bcw_softc *sc)
{
- struct bcw_regs *regs = &sc->bcw_regs;
u_int32_t save,val;
/*
@@ -1735,17 +1720,19 @@ bcw_validatechipaccess(struct bcw_softc *sc)
*/
/* Backup SHM uCode Revision before we clobber it */
- BCW_WRITE32(regs, BCW_SHM_CONTROL,
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_SHM_CONTROL,
(BCW_SHM_CONTROL_SHARED << 16) + 0);
- save = BCW_READ32(regs, BCW_SHM_DATA);
+ save = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_SHM_DATA);
/* write test value */
- BCW_WRITE32(regs, BCW_SHM_CONTROL, (BCW_SHM_CONTROL_SHARED << 16) + 0);
- BCW_WRITE32(regs, BCW_SHM_DATA, 0xaa5555aa);
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_SHM_CONTROL,
+ (BCW_SHM_CONTROL_SHARED << 16) + 0);
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_SHM_DATA, 0xaa5555aa);
DPRINTF(("Write test 1, "));
/* Read it back */
- BCW_WRITE32(regs, BCW_SHM_CONTROL, (BCW_SHM_CONTROL_SHARED << 16) + 0);
- val = BCW_READ32(regs, BCW_SHM_DATA);
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_SHM_CONTROL,
+ (BCW_SHM_CONTROL_SHARED << 16) + 0);
+ val = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_SHM_DATA);
DPRINTF(("Read test 1, "));
if (val != 0xaa5555aa) {
DPRINTF(("Failed test 1\n"));
@@ -1754,12 +1741,14 @@ bcw_validatechipaccess(struct bcw_softc *sc)
DPRINTF(("Passed test 1\n"));
/* write 2nd test value */
- BCW_WRITE32(regs, BCW_SHM_CONTROL, (BCW_SHM_CONTROL_SHARED << 16) + 0);
- BCW_WRITE32(regs, BCW_SHM_DATA, 0x55aaaa55);
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_SHM_CONTROL,
+ (BCW_SHM_CONTROL_SHARED << 16) + 0);
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_SHM_DATA, 0x55aaaa55);
DPRINTF(("Write test 2, "));
/* Read it back */
- BCW_WRITE32(regs, BCW_SHM_CONTROL, (BCW_SHM_CONTROL_SHARED << 16) + 0);
- val = BCW_READ32(regs, BCW_SHM_DATA);
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_SHM_CONTROL,
+ (BCW_SHM_CONTROL_SHARED << 16) + 0);
+ val = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_SHM_DATA);
DPRINTF(("Read test 2, "));
if (val != 0x55aaaa55) {
DPRINTF(("Failed test 2\n"));
@@ -1768,10 +1757,11 @@ bcw_validatechipaccess(struct bcw_softc *sc)
DPRINTF(("Passed test 2\n"));
/* Restore the saved value now that we're done */
- BCW_WRITE32(regs, BCW_SHM_CONTROL, (BCW_SHM_CONTROL_SHARED << 16) + 0);
- BCW_WRITE32(regs, BCW_SHM_DATA, save);
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_SHM_CONTROL,
+ (BCW_SHM_CONTROL_SHARED << 16) + 0);
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_SHM_DATA, save);
- if (sc->bcw_corerev >= 3) {
+ if (sc->sc_corerev >= 3) {
DPRINTF(("Doing corerev >= 3 tests\n"));
/* do some test writes and reads against the TSF */
/*
@@ -1780,35 +1770,35 @@ bcw_validatechipaccess(struct bcw_softc *sc)
* say that we're reading/writing silly places, so these regs
* are not quite documented yet
*/
- BCW_WRITE16(regs, 0x18c, 0xaaaa);
- BCW_WRITE32(regs, 0x18c, 0xccccbbbb);
- val = BCW_READ16(regs, 0x604);
+ bus_space_write_2(sc->sc_iot, sc->sc_ioh, 0x18c, 0xaaaa);
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, 0x18c, 0xccccbbbb);
+ val = bus_space_read_2(sc->sc_iot, sc->sc_ioh, 0x604);
if (val != 0xbbbb) return 3;
- val = BCW_READ16(regs, 0x606);
+ val = bus_space_read_2(sc->sc_iot, sc->sc_ioh, 0x606);
if (val != 0xcccc) return 4;
/* re-clear the TSF since we just filled it with garbage */
- BCW_WRITE32(regs, 0x18c, 0x0);
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, 0x18c, 0x0);
}
/* Check the Status Bit Field for some unknown bits */
- val = BCW_READ32(regs, BCW_SBF);
+ val = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_SBF);
if ((val | 0x80000000) != 0x80000400 ) {
printf("%s: Warning, SBF is 0x%x, expected 0x80000400\n",
- sc->bcw_dev.dv_xname,val);
+ sc->sc_dev.dv_xname, val);
/* May not be a critical failure, just warn for now */
//return (5);
}
/* Verify there are no interrupts active on the core */
- val = BCW_READ32(regs, BCW_GIR);
- if (val!=0) {
- DPRINTF(("Failed Pending Interrupt test with val=0x%x\n",val));
+ val = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_GIR);
+ if (val != 0) {
+ DPRINTF(("Failed Pending Interrupt test with val=0x%x\n", val));
return (6);
}
/* Above G means it's unsupported currently, like N */
- if (sc->bcw_phy_type > BCW_PHY_TYPEG) {
+ if (sc->sc_phy_type > BCW_PHY_TYPEG) {
DPRINTF(("PHY type %d greater than supported type %d\n",
- sc->bcw_phy_type, BCW_PHY_TYPEG));
+ sc->sc_phy_type, BCW_PHY_TYPEG));
return (7);
}
@@ -1816,55 +1806,367 @@ bcw_validatechipaccess(struct bcw_softc *sc)
}
-/*
- * Abstracted reads and writes - from rtw
- */
-u_int8_t
-bcw_read8(void *arg, u_int32_t off)
+
+int
+bcw_detach(void *arg)
{
- struct bcw_regs *regs = (struct bcw_regs *)arg;
- return (bus_space_read_1(regs->r_bt, regs->r_bh, off));
+ struct bcw_softc *sc = arg;
+ struct ieee80211com *ic = &sc->sc_ic;
+ struct ifnet *ifp = &ic->ic_if;
+
+ timeout_del(&sc->sc_scan_to);
+
+ bcw_stop(ifp, 1);
+ ieee80211_ifdetach(ifp);
+ if_detach(ifp);
+ bcw_free_rx_ring(sc, &sc->sc_rxring);
+ bcw_free_tx_ring(sc, &sc->sc_txring);
+
+ return (0);
}
-u_int16_t
-bcw_read16(void *arg, u_int32_t off)
+
+#if 0
+void
+bcw_free_ring(struct bcw_softc *sc, struct bcw_dma_slot *ring)
{
- struct bcw_regs *regs = (struct bcw_regs *)arg;
- return (bus_space_read_2(regs->r_bt, regs->r_bh, off));
+ struct bcw_chain data *data;
+ struct bcw_dma_slot *bcwd;
+ int i;
+
+ if (sc->bcw_rx_chain != NULL) {
+ if (i = 0; i < BCW_NRXDESC; i++) {
+ bcwd = &sc->bcw_rx_ring[i];
+
+ if (sc->bcw_rx_chain[i] != NULL) {
+ bus_dmamap_sync(sc->sc_dmat,
+ sc->bcw_ring_map,
+ sizeof(struct bcw_dma_slot) * x,
+ sizeof(struct bcw_dma_slot),
+ BUS_DMASYNC_POSTREAD);
+ bus_dmamap_unload(sc->sc_dmat,
+ sc->bcw_ring_map);
+ m_freem(sc->bcw_rx_chain[i]);
+ }
+
+ if (sc->bcw_ring_map != NULL)
+ bus_dmamap_destroy(sc->sc_dmat,
+ sc->bcw_ring_map);
+ }
+ }
}
+#endif
-u_int32_t
-bcw_read32(void *arg, u_int32_t off)
+int
+bcw_alloc_rx_ring(struct bcw_softc *sc, struct bcw_rx_ring *ring, int count)
{
- struct bcw_regs *regs = (struct bcw_regs *)arg;
- return (bus_space_read_4(regs->r_bt, regs->r_bh, off));
+ struct bcw_desc *desc;
+ struct bcw_rx_data *data;
+ int i, nsegs, error;
+
+ ring->count = count;
+ ring->cur = ring->next = 0;
+
+ error = bus_dmamap_create(sc->sc_dmat,
+ count * sizeof(struct bcw_desc), 1,
+ count * sizeof(struct bcw_desc), 0,
+ BUS_DMA_NOWAIT, &ring->map);
+ if (error != 0) {
+ printf("%s: could not create desc DMA map\n",
+ sc->sc_dev.dv_xname);
+ goto fail;
+ }
+
+ error = bus_dmamem_alloc(sc->sc_dmat,
+ count * sizeof(struct bcw_desc),
+ PAGE_SIZE, 0, &ring->seg, 1, &nsegs, BUS_DMA_NOWAIT);
+ if (error != 0) {
+ printf("%s: could not allocate DMA memory\n",
+ sc->sc_dev.dv_xname);
+ goto fail;
+ }
+
+ error = bus_dmamem_map(sc->sc_dmat, &ring->seg, nsegs,
+ count * sizeof(struct bcw_desc), (caddr_t *)&ring->desc,
+ BUS_DMA_NOWAIT);
+ if (error != 0) {
+ printf("%s: could not map desc DMA memory\n",
+ sc->sc_dev.dv_xname);
+ goto fail;
+ }
+
+ error = bus_dmamap_load(sc->sc_dmat, ring->map, ring->desc,
+ count * sizeof(struct bcw_desc), NULL, BUS_DMA_NOWAIT);
+ if (error != 0) {
+ printf("%s: could not load desc DMA map\n",
+ sc->sc_dev.dv_xname);
+ goto fail;
+ }
+
+ bzero(ring->desc, count * sizeof(struct bcw_desc));
+ ring->physaddr = ring->map->dm_segs->ds_addr;
+
+ ring->data = malloc(count * sizeof (struct bcw_rx_data), M_DEVBUF,
+ M_NOWAIT);
+ if (ring->data == NULL) {
+ printf("%s: could not allocate soft data\n",
+ sc->sc_dev.dv_xname);
+ error = ENOMEM;
+ goto fail;
+ }
+
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_DMA_RXADDR,
+ ring->physaddr + 0x40000000);
+
+ /*
+ * Pre-allocate Rx buffers and populate Rx ring.
+ */
+ bzero(ring->data, count * sizeof (struct bcw_rx_data));
+ for (i = 0; i < count; i++) {
+ desc = &ring->desc[i];
+ data = &ring->data[i];
+
+ error = bus_dmamap_create(sc->sc_dmat, MCLBYTES, 1, MCLBYTES,
+ 0, BUS_DMA_NOWAIT, &data->map);
+ if (error != 0) {
+ printf("%s: could not create DMA map\n",
+ sc->sc_dev.dv_xname);
+ goto fail;
+ }
+
+ MGETHDR(data->m, M_DONTWAIT, MT_DATA);
+ if (data->m == NULL) {
+ printf("%s: could not allocate rx mbuf\n",
+ sc->sc_dev.dv_xname);
+ error = ENOMEM;
+ goto fail;
+ }
+
+ MCLGET(data->m, M_DONTWAIT);
+ if (!(data->m->m_flags & M_EXT)) {
+ printf("%s: could not allocate rx mbuf cluster\n",
+ sc->sc_dev.dv_xname);
+ error = ENOMEM;
+ goto fail;
+ }
+
+ error = bus_dmamap_load(sc->sc_dmat, data->map,
+ mtod(data->m, void *), MCLBYTES, NULL, BUS_DMA_NOWAIT);
+ if (error != 0) {
+ printf("%s: could not load rx buf DMA map",
+ sc->sc_dev.dv_xname);
+ goto fail;
+ }
+
+ desc->addr = htole32(data->map->dm_segs->ds_addr);
+
+ if (i != (count - 1))
+ desc->ctrl = htole32(BCW_RXBUF_LEN);
+ else
+ desc->ctrl = htole32(BCW_RXBUF_LEN | CTRL_EOT);
+ }
+
+ bus_dmamap_sync(sc->sc_dmat, ring->map, 0, ring->map->dm_mapsize,
+ BUS_DMASYNC_PREWRITE);
+
+ return (0);
+
+fail: bcw_free_rx_ring(sc, ring);
+ return (error);
}
void
-bcw_write8(void *arg, u_int32_t off, u_int8_t val)
+bcw_reset_rx_ring(struct bcw_softc *sc, struct bcw_rx_ring *ring)
{
- struct bcw_regs *regs = (struct bcw_regs *)arg;
- bus_space_write_1(regs->r_bt, regs->r_bh, off, val);
+ bus_dmamap_sync(sc->sc_dmat, ring->map, 0, ring->map->dm_mapsize,
+ BUS_DMASYNC_PREWRITE);
+
+ ring->cur = ring->next = 0;
}
void
-bcw_write16(void *arg, u_int32_t off, u_int16_t val)
+bcw_free_rx_ring(struct bcw_softc *sc, struct bcw_rx_ring *ring)
{
- struct bcw_regs *regs = (struct bcw_regs *)arg;
- bus_space_write_2(regs->r_bt, regs->r_bh, off, val);
+ struct bcw_rx_data *data;
+ int i;
+
+ if (ring->desc != NULL) {
+ bus_dmamap_sync(sc->sc_dmat, ring->map, 0,
+ ring->map->dm_mapsize, BUS_DMASYNC_POSTWRITE);
+ bus_dmamap_unload(sc->sc_dmat, ring->map);
+ bus_dmamem_unmap(sc->sc_dmat, (caddr_t)ring->desc,
+ ring->count * sizeof(struct bcw_desc));
+ bus_dmamem_free(sc->sc_dmat, &ring->seg, 1);
+ }
+
+ if (ring->data != NULL) {
+ for (i = 0; i < ring->count; i++) {
+ data = &ring->data[i];
+
+ if (data->m != NULL) {
+ bus_dmamap_sync(sc->sc_dmat, data->map, 0,
+ data->map->dm_mapsize,
+ BUS_DMASYNC_POSTREAD);
+ bus_dmamap_unload(sc->sc_dmat, data->map);
+ m_freem(data->m);
+ }
+
+ if (data->map != NULL)
+ bus_dmamap_destroy(sc->sc_dmat, data->map);
+ }
+ free(ring->data, M_DEVBUF);
+ }
+}
+
+int
+bcw_alloc_tx_ring(struct bcw_softc *sc, struct bcw_tx_ring *ring,
+ int count)
+{
+ int i, nsegs, error;
+
+ ring->count = count;
+ ring->queued = 0;
+ ring->cur = ring->next = ring->stat = 0;
+
+ error = bus_dmamap_create(sc->sc_dmat,
+ count * sizeof(struct bcw_desc), 1,
+ count * sizeof(struct bcw_desc), 0, BUS_DMA_NOWAIT, &ring->map);
+ if (error != 0) {
+ printf("%s: could not create desc DMA map\n",
+ sc->sc_dev.dv_xname);
+ goto fail;
+ }
+
+ error = bus_dmamem_alloc(sc->sc_dmat,
+ count * sizeof(struct bcw_desc),
+ PAGE_SIZE, 0, &ring->seg, 1, &nsegs, BUS_DMA_NOWAIT);
+ if (error != 0) {
+ printf("%s: could not allocate DMA memory\n",
+ sc->sc_dev.dv_xname);
+ goto fail;
+ }
+
+ error = bus_dmamem_map(sc->sc_dmat, &ring->seg, nsegs,
+ count * sizeof(struct bcw_desc), (caddr_t *)&ring->desc,
+ BUS_DMA_NOWAIT);
+ if (error != 0) {
+ printf("%s: could not map desc DMA memory\n",
+ sc->sc_dev.dv_xname);
+ goto fail;
+ }
+
+ error = bus_dmamap_load(sc->sc_dmat, ring->map, ring->desc,
+ count * sizeof(struct bcw_desc), NULL, BUS_DMA_NOWAIT);
+ if (error != 0) {
+ printf("%s: could not load desc DMA map\n",
+ sc->sc_dev.dv_xname);
+ goto fail;
+ }
+
+ memset(ring->desc, 0, count * sizeof(struct bcw_desc));
+ ring->physaddr = ring->map->dm_segs->ds_addr;
+
+ /* MAGIC */
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_DMA_TXADDR,
+ ring->physaddr + 0x40000000);
+
+ ring->data = malloc(count * sizeof(struct bcw_tx_data), M_DEVBUF,
+ M_NOWAIT);
+ if (ring->data == NULL) {
+ printf("%s: could not allocate soft data\n",
+ sc->sc_dev.dv_xname);
+ error = ENOMEM;
+ goto fail;
+ }
+
+ memset(ring->data, 0, count * sizeof(struct bcw_tx_data));
+ for (i = 0; i < count; i++) {
+ error = bus_dmamap_create(sc->sc_dmat, MCLBYTES,
+ BCW_MAX_SCATTER, MCLBYTES, 0, BUS_DMA_NOWAIT,
+ &ring->data[i].map);
+ if (error != 0) {
+ printf("%s: could not create DMA map\n",
+ sc->sc_dev.dv_xname);
+ goto fail;
+ }
+ }
+
+ return (0);
+
+fail: bcw_free_tx_ring(sc, ring);
+ return (error);
}
void
-bcw_write32(void *arg, u_int32_t off, u_int32_t val)
+bcw_reset_tx_ring(struct bcw_softc *sc, struct bcw_tx_ring *ring)
{
- struct bcw_regs *regs = (struct bcw_regs *)arg;
- bus_space_write_4(regs->r_bt, regs->r_bh, off, val);
+ struct bcw_desc *desc;
+ struct bcw_tx_data *data;
+ int i;
+
+ for (i = 0; i < ring->count; i++) {
+ desc = &ring->desc[i];
+ data = &ring->data[i];
+
+ if (data->m != NULL) {
+ bus_dmamap_sync(sc->sc_dmat, data->map, 0,
+ data->map->dm_mapsize, BUS_DMASYNC_POSTWRITE);
+ bus_dmamap_unload(sc->sc_dmat, data->map);
+ m_freem(data->m);
+ data->m = NULL;
+ }
+
+ /*
+ * The node has already been freed at that point so don't call
+ * ieee80211_release_node() here.
+ */
+ data->ni = NULL;
+ }
+
+ bus_dmamap_sync(sc->sc_dmat, ring->map, 0, ring->map->dm_mapsize,
+ BUS_DMASYNC_PREWRITE);
+
+ ring->queued = 0;
+ ring->cur = ring->next = ring->stat = 0;
}
void
-bcw_barrier(void *arg, u_int32_t reg0, u_int32_t reg1, int flags)
+bcw_free_tx_ring(struct bcw_softc *sc, struct bcw_tx_ring *ring)
{
- struct bcw_regs *regs = (struct bcw_regs *)arg;
- bus_space_barrier(regs->r_bh, regs->r_bt, MIN(reg0, reg1),
- MAX(reg0, reg1) - MIN(reg0, reg1) + 4, flags);
+ struct bcw_tx_data *data;
+ int i;
+
+ if (ring->desc != NULL) {
+ bus_dmamap_sync(sc->sc_dmat, ring->map, 0,
+ ring->map->dm_mapsize, BUS_DMASYNC_POSTWRITE);
+ bus_dmamap_unload(sc->sc_dmat, ring->map);
+ bus_dmamem_unmap(sc->sc_dmat, (caddr_t)ring->desc,
+ ring->count * sizeof(struct bcw_desc));
+ bus_dmamem_free(sc->sc_dmat, &ring->seg, 1);
+ }
+
+ if (ring->data != NULL) {
+ for (i = 0; i < ring->count; i++) {
+ data = &ring->data[i];
+
+ if (data->m != NULL) {
+ bus_dmamap_sync(sc->sc_dmat, data->map, 0,
+ data->map->dm_mapsize,
+ BUS_DMASYNC_POSTWRITE);
+ bus_dmamap_unload(sc->sc_dmat, data->map);
+ m_freem(data->m);
+ }
+
+ /*
+ * The node has already been freed at that point so
+ * don't call ieee80211_release_node() here.
+ */
+ data->ni = NULL;
+
+ if (data->map != NULL)
+ bus_dmamap_destroy(sc->sc_dmat, data->map);
+ }
+ free(ring->data, M_DEVBUF);
+ }
}
+
diff --git a/sys/dev/ic/bcwreg.h b/sys/dev/ic/bcwreg.h
index ba385b91e01..ee3a266f0a0 100644
--- a/sys/dev/ic/bcwreg.h
+++ b/sys/dev/ic/bcwreg.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: bcwreg.h,v 1.2 2006/11/17 20:49:27 mglocker Exp $ */
+/* $OpenBSD: bcwreg.h,v 1.3 2006/11/21 11:41:14 mglocker Exp $ */
/*
* Copyright (c) 2006 Jon Simola <jsimola@gmail.com>
@@ -116,11 +116,11 @@
#define XC_LE 0x4 /* loopback enable */
#define BCW_DMA_TXADDR 0x0204 /* tx ring base address */
#define BCW_DMA_DPTR 0x0208 /* last tx descriptor */
-#define BCW_DMA_TXSTATUS 0x020C /* active desc, etc */
+//#define BCW_DMA_TXSTATUS 0x020C /* active desc, etc */
#define BCW_DMA_RXCTL 0x0210 /* enable, etc */
#define BCW_DMA_RXADDR 0x0214 /* rx ring base address */
#define BCW_DMA_RXDPTR 0x0218 /* last descriptor */
-#define BCW_DMA_RXSTATUS 0x021C /* active desc, etc */
+//#define BCW_DMA_RXSTATUS 0x021C /* active desc, etc */
/* receive status bits */
#define RS_CD_MASK 0x0fff /* current descriptor pointer */
#define RS_DMA_IDLE 0x2000 /* DMA is idle */
@@ -209,9 +209,58 @@
#define BCW_SHM_MICROCODEFLAGSLOW 0x005e /* Flags for Microcode ops */
#define BCW_SHM_MICROCODEFLAGSHIGH 0x0060 /* Flags for Microcode ops */
/* http://bcm-specs.sipsolutions.net/MicrocodeFlagsBitfield */
-#define BCW_SHM_MICROCODEFLAGS
-/* 0x200 DMA Register space */
+/* 0x200 DMA Register space, there are 6 controllers */
+/* 32 bit DMA controllers */
+#define BCW_DMA_TXCONTROL(x) (0x200 + (x * 0x20))
+ /* DMA Control Word*/
+#define BCW_DMA_TXRINGADDR(x) (0x204 + (x * 0x20))
+ /* Ring Address */
+#define BCW_DMA_TXSTOPADDR(x) (0x208 + (x * 0x20))
+ /* Last Descriptor */
+#define BCW_DMA_TXSTATUS(x) (0x20c + (x * 0x20))
+ /* Transmit Status Word */
+#define BCW_DMA_RXCONTROL(x) (0x200 + (x * 0x20))
+ /* DMA Control Word*/
+#define BCW_DMA_RXRINGADDR(x) (0x204 + (x * 0x20))
+ /* Ring Address */
+#define BCW_DMA_RXSTOPADDR(x) (0x208 + (x * 0x20))
+ /* Last descriptor */
+#define BCW_DMA_RXSTATUS(x) (0x20c + (x * 0x20))
+ /* Receive Status Word */
+/* 64 bit DMA controllers */
+#define BCW_DMA64_TXCONTROL(x) (0x200 + (x * 0x40))
+ /* DMA control Word */
+#define BCW_DMA64_TXSTOPADDR(x) (0x204 + (x * 0x40))
+ /* Last Descriptor */
+#define BCW_DMA64_TXRINGADDRLOW(x) (0x208 + (x * 0x40))
+ /* Low 32 bits Ring Address */
+#define BCW_DMA64_TXRINGADDRHIGH(x) (0x20c + (x * 0x40))
+ /* High 32 bits Ring Address */
+#define BCW_DMA64_TXSTATUS(x) (0x210 + (x * 0x40))
+ /* Transmit Status State */
+#define BCW_DMA64_TXERROR(x) (0x214 + (x * 0x40))
+ /* Transmit Status Error */
+#define BCW_DMA64_RXCONTROL(x) (0x220 + (x * 0x40))
+ /* DMA control Word */
+#define BCW_DMA64_RXSTOPADDR(x) (0x224 + (x * 0x40))
+ /* Last Descriptor */
+#define BCW_DMA64_RXRINGADDRLOW(x) (0x228 + (x * 0x40))
+ /* Low 32 bits Ring Address */
+#define BCW_DMA64_RXRINGADDRHIGH(x) (0x22c + (x * 0x40))
+ /* High 32 bits Ring Address */
+#define BCW_DMA64_RXSTATUS(x) (0x230 + (x * 0x40))
+ /* Transmit Status State */
+#define BCW_DMA64_RXERROR(x) (0x234 + (x * 0x40))
+ /* Transmit Status Error */
+
+#define BCW_DMA_CONTROL_ENABLE 0x1 /* Enable */
+#define BCW_DMA_CONTROL_SUSPEND 0x2 /* Suspend Request */
+#define BCW_DMA_CONTROL_LOOPBACK 0x4 /* Loopback Enable */
+#define BCW_DMA_CONTROL_FLUSH 0x10 /* Flush Request */
+#define BCW_DMA_CONTROL_ADDREXT 0x30000 /* Address Extension */
+
+
/* 0x300 PIO Register space */
#define BCW_RADIO_CONTROL 0x3f6 /* Control - 16bit */
@@ -225,19 +274,36 @@
/* SPROM registers are 16 bit and based at MMIO offset 0x1000 */
#define BCW_MMIO_BASE 0x1000
-
-#define BCW_SPROM_IL0MACADDR 0x1048 /* 802.11b/g MAC */
+#define BCW_SPROM_IL0MACADDR 0x1048 /* 802.11b/g MAC */
#define BCW_SPROM_ET0MACADDR 0x104e /* ethernet MAC */
#define BCW_SPROM_ET1MACADDR 0x1054 /* 802.11a MAC */
#define BCW_SPROM_PA0B0 0x105e
#define BCW_SPROM_PA0B1 0x1060
#define BCW_SPROM_PA0B2 0x1062
-#define BCW_SPROM_PAMAXPOWER 0x1066 /* 7-0 for A, 15-8 for B/G */
+#define BCW_SPROM_PAMAXPOWER 0x1066 /* 7-0 for A, 15-8 for B/G */
#define BCW_SPROM_PA1B0 0x106a
#define BCW_SPROM_PA1B1 0x106c
#define BCW_SPROM_PA1B2 0x106e
#define BCW_SPROM_IDLETSSI 0x1070 /* As below */
+#define BCW_SPROM_BOARDFLAGS 0x1072 /* lower 16 bits */
+#define BCW_BF_BTCOEXIST 0x0001 /* Bluetooth Co-existance */
+#define BCW_BF_PACTRL 0x0002 /* GPIO 9 controls PA */
+#define BCW_BF_AIRLINEMODE 0x0004 /* GPIO13 -> radio off LED */
+#define BCW_BF_RSSI 0x0008 /* "something RSSI related */
+#define BCW_BF_ENETSPI 0x0010 /* EPHY Roboswitch SPI */
+#define BCW_BF_XTAL 0x0020 /* XTAL doesn't slow clock */
+#define BCW_BF_CCKHIPWR 0x0040 /* HiPower CCK xmission */
+#define BCW_BF_ENETADM 0x0080 /* has ADMtek Switch */
+#define BCW_BF_ENETVLAN 0x0100 /* VLAN capable - huh? */
+#define BCW_BF_AFTERBURNER 0x0200 /* Afterburner capable */
+#define BCW_BF_NOPCI 0x0400 /* Board leaves PCI floating */
+#define BCW_BF_FEM 0x0800 /* Front End Module support */
+#define BCW_BF_EXTLNA 0x1000 /* has external LNA */
+#define BCW_BF_HGPA 0x2000 /* has High Gain PA */
+#define BCW_BF_BTCMOD 0x4000 /* BTCOEXIST in alt GPIOs */
+#define BCW_BF_ALTIQ 0x8000 /* Alternate I/Q settings */
+
#define BCW_SPROM_ANTGAIN 0x1074 /* bits 7-0 for an A PHY
bits 15-8 for B/G PHYs */
@@ -246,26 +312,3 @@
#define BCW_PHY_TYPEG 0x2 /* 802.11g PHY */
#define BCW_PHY_TYPEN 0x4 /* 802.11n PHY */
-#define BCW_READ8(regs, ofs) \
- ((*(regs)->r_read8)(regs, ofs))
-
-#define BCW_READ16(regs, ofs) \
- ((*(regs)->r_read16)(regs, ofs))
-
-#define BCW_READ32(regs, ofs) \
- ((*(regs)->r_read32)(regs, ofs))
-
-#define BCW_WRITE8(regs, ofs, val) \
- ((*(regs)->r_write8)(regs, ofs, val))
-
-#define BCW_WRITE16(regs, ofs, val) \
- ((*(regs)->r_write16)(regs, ofs, val))
-
-#define BCW_WRITE32(regs, ofs, val) \
- ((*(regs)->r_write32)(regs, ofs, val))
-
-#define BCW_ISSET(regs, reg, mask) \
- (BCW_READ32((regs), (reg)) & (mask))
-
-#define BCW_CLR(regs, reg, mask) \
- BCW_WRITE32((regs), (reg), BCW_READ32((regs), (reg)) & ~(mask))
diff --git a/sys/dev/ic/bcwvar.h b/sys/dev/ic/bcwvar.h
index bd497ab93ad..9ae42d64b89 100644
--- a/sys/dev/ic/bcwvar.h
+++ b/sys/dev/ic/bcwvar.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: bcwvar.h,v 1.2 2006/11/17 20:49:27 mglocker Exp $ */
+/* $OpenBSD: bcwvar.h,v 1.3 2006/11/21 11:41:14 mglocker Exp $ */
/*
* Copyright (c) 2006 Jon Simola <jsimola@gmail.com>
@@ -50,9 +50,65 @@ struct bcw_core {
};
/* number of descriptors used in a ring */
-#define BCW_NRXDESC 128
-#define BCW_NTXDESC 128
+#define BCW_RX_RING_COUNT 128
+#define BCW_TX_RING_COUNT 128
+#define BCW_MAX_SCATTER 8 /* XXX unknown, wild guess */
+struct bcw_rx_data {
+ bus_dmamap_t map;
+ struct mbuf *m;
+};
+
+struct bcw_tx_data {
+ bus_dmamap_t map;
+ struct mbuf *m;
+ uint32_t softstat;
+ struct ieee80211_node *ni;
+};
+
+struct bcw_rx_ring {
+ bus_dmamap_t map;
+ bus_dma_segment_t seg;
+ bus_addr_t physaddr;
+ struct bcw_desc *desc;
+ struct bcw_rx_data *data;
+ int count;
+ int cur;
+ int next;
+};
+
+struct bcw_tx_ring {
+ bus_dmamap_t map;
+ bus_dma_segment_t seg;
+ bus_addr_t physaddr;
+ struct bcw_desc *desc;
+ struct bcw_tx_data *data;
+ int count;
+ int queued;
+ int cur;
+ int next;
+ int stat;
+};
+
+struct bcw_desc {
+ u_int32_t ctrl;
+ u_int32_t addr;
+};
+
+/* ring descriptor */
+struct bcw_dma_slot {
+ u_int32_t ctrl;
+ u_int32_t addr;
+};
+
+#define CTRL_BC_MASK 0x1fff /* buffer byte count */
+#define CTRL_EOT 0x10000000 /* end of descriptor table */
+#define CTRL_IOC 0x20000000 /* interrupt on completion */
+#define CTRL_EOF 0x40000000 /* end of frame */
+#define CTRL_SOF 0x80000000 /* start of frame */
+
+
+#if 0
/*
* Mbuf pointers. We need these to keep track of the virtual addresses
* of our mbuf chains since we can only convert from physical to virtual,
@@ -67,77 +123,72 @@ struct bcw_chain_data {
bus_dmamap_t bcw_tx_map[BCW_NTXDESC];
bus_dmamap_t bcw_rx_map[BCW_NRXDESC];
};
+#endif
-struct bcw_regs {
- bus_space_tag_t r_bt;
- bus_space_handle_t r_bh;
-// enum bcw_access r_access;
- void *r_priv;
-
- /* bus independent I/O callbacks */
- u_int8_t (*r_read8)(void *, u_int32_t);
- u_int16_t (*r_read16)(void *, u_int32_t);
- u_int32_t (*r_read32)(void *, u_int32_t);
- void (*r_write8)(void *, u_int32_t, u_int8_t);
- void (*r_write16)(void *, u_int32_t, u_int16_t);
- void (*r_write32)(void *, u_int32_t, u_int32_t);
- void (*r_barrier)(void *, u_int32_t, u_int32_t, int);
-};
+struct bcw_rx_ring;
+struct bcw_tx_ring;
/* Needs to have garbage removed */
struct bcw_softc {
- struct device bcw_dev;
- struct ieee80211com bcw_ic;
- struct bcw_regs bcw_regs;
+ struct device sc_dev;
+ struct ieee80211com sc_ic;
+ struct bcw_rx_ring sc_rxring;
+ struct bcw_tx_ring sc_txring;
+
int (*sc_newstate)(struct ieee80211com *,
enum ieee80211_state, int);
int (*sc_enable)(struct bcw_softc *);
void (*sc_disable)(struct bcw_softc *);
- bus_space_tag_t bcw_btag;
- bus_space_handle_t bcw_bhandle;
- bus_dma_tag_t bcw_dmatag;
- struct arpcom bcw_ac; /* interface info */
+ struct timeout sc_scan_to;
+
+ bus_dma_tag_t sc_dmat;
+ bus_space_tag_t sc_iot;
+ bus_space_handle_t sc_ioh;
+
void *bcw_intrhand;
const char *bcw_intrstr; /* interrupt description */
- struct pci_attach_args bcw_pa;
- u_int32_t bcw_phy; /* eeprom indicated phy */
+ struct pci_attach_args sc_pa;
+ u_int32_t sc_phy; /* eeprom indicated phy */
struct bcw_dma_slot *bcw_rx_ring; /* receive ring */
struct bcw_dma_slot *bcw_tx_ring; /* transmit ring */
- struct bcw_chain_data bcw_cdata; /* mbufs */
- bus_dmamap_t bcw_ring_map;
- u_int32_t bcw_intmask; /* current intr mask */
- u_int32_t bcw_rxin; /* last rx descriptor seen */
- u_int32_t bcw_txin; /* last tx descriptor seen */
- int bcw_txsfree; /* no. tx slots available */
- int bcw_txsnext; /* next available tx slot */
- struct timeout bcw_timeout;
+// struct bcw_chain_data sc_cdata; /* mbufs */
+ bus_dmamap_t sc_ring_map;
+ u_int32_t sc_intmask; /* current intr mask */
+ u_int32_t sc_rxin; /* last rx descriptor seen */
+ u_int32_t sc_txin; /* last tx descriptor seen */
+ int sc_txsfree; /* no. tx slots available */
+ int sc_txsnext; /* next available tx slot */
+ struct timeout sc_timeout;
/* Break these out into seperate structs */
- u_int16_t bcw_chipid; /* Chip ID */
- u_int16_t bcw_chiprev; /* Chip Revision */
- u_int16_t bcw_prodid; /* Product ID */
+ u_int16_t sc_chipid; /* Chip ID */
+ u_int16_t sc_chiprev; /* Chip Revision */
+ u_int16_t sc_prodid; /* Product ID */
// struct bcw_core core[BCW_MAX_CORES];
// struct bcw_radio radio[BCW_MAX_RADIOS];
- u_int16_t bcw_phy_version;
- u_int16_t bcw_phy_type;
- u_int16_t bcw_phy_rev;
- u_int16_t bcw_corerev;
- u_int32_t bcw_radioid;
- u_int16_t bcw_radiorev;
- u_int16_t bcw_radiotype;
- u_int32_t bcw_phyinfo;
- u_int16_t bcw_numcores;
- u_int16_t bcw_havecommon;
- u_int8_t bcw_radio_gain;
- u_int16_t bcw_radio_pa0b0;
- u_int16_t bcw_radio_pa0b1;
- u_int16_t bcw_radio_pa0b2;
- u_int16_t bcw_radio_pa1b0;
- u_int16_t bcw_radio_pa1b1;
- u_int16_t bcw_radio_pa1b2;
- u_int8_t bcw_idletssi;
+ u_int16_t sc_phy_version;
+ u_int16_t sc_phy_type;
+ u_int16_t sc_phy_rev;
+ u_int16_t sc_corerev;
+ u_int32_t sc_radioid;
+ u_int16_t sc_radiorev;
+ u_int16_t sc_radiotype;
+ u_int32_t sc_phyinfo;
+ u_int16_t sc_numcores;
+ u_int16_t sc_havecommon;
+ u_int8_t sc_radio_gain;
+ u_int16_t sc_radio_pa0b0;
+ u_int16_t sc_radio_pa0b1;
+ u_int16_t sc_radio_pa0b2;
+ u_int16_t sc_radio_pa1b0;
+ u_int16_t sc_radio_pa1b1;
+ u_int16_t sc_radio_pa1b2;
+ u_int8_t sc_idletssi;
+ u_int8_t sc_spromrev;
+ u_int16_t sc_boardflags;
};
void bcw_attach(struct bcw_softc *);
+int bcw_detach(void *arg);
int bcw_intr(void *);
#define BCW_DEBUG
@@ -158,18 +209,6 @@ int bcw_intr(void *);
/* transmit buffer max frags allowed */
#define BCW_NTXFRAGS 16
-/* ring descriptor */
-struct bcw_dma_slot {
- u_int32_t ctrl;
- u_int32_t addr;
-};
-
-#define CTRL_BC_MASK 0x1fff /* buffer byte count */
-#define CTRL_EOT 0x10000000 /* end of descriptor table */
-#define CTRL_IOC 0x20000000 /* interrupt on completion */
-#define CTRL_EOF 0x40000000 /* end of frame */
-#define CTRL_SOF 0x80000000 /* start of frame */
-
/* Packet status is returned in a pre-packet header */
struct rx_pph {
u_int16_t len;
diff --git a/sys/dev/pci/if_bcw_pci.c b/sys/dev/pci/if_bcw_pci.c
index 18843d93397..7028d6b8d19 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.1 2006/11/17 18:58:30 mglocker Exp $ */
+/* $OpenBSD: if_bcw_pci.c,v 1.2 2006/11/21 11:41:14 mglocker Exp $ */
/*
* Copyright (c) 2006 Jon Simola <jsimola@gmail.com>
@@ -126,10 +126,10 @@ bcw_pci_enable(struct bcw_softc *sc)
/* Establish PCI interrupt */
psc->psc_intrcookie = pci_intr_establish(psc->psc_pc, psc->psc_ih,
- IPL_NET, bcw_intr, sc, sc->bcw_dev.dv_xname);
+ IPL_NET, bcw_intr, sc, sc->sc_dev.dv_xname);
if(psc->psc_intrcookie == NULL) {
printf("%s: unable to establish interrupt\n",
- sc->bcw_dev.dv_xname);
+ sc->sc_dev.dv_xname);
return (1);
}
@@ -153,7 +153,6 @@ bcw_pci_attach(parent, self, aux)
{
struct bcw_pci_softc *psc = (void *) self;
struct bcw_softc *sc = &psc->psc_bcw;
- struct bcw_regs *regs = &sc->bcw_regs;
struct pci_attach_args *pa = (struct pci_attach_args *)aux;
pci_chipset_tag_t pc = pa->pa_pc;
// const char *intrstr = NULL;
@@ -185,12 +184,12 @@ bcw_pci_attach(parent, self, aux)
* this state, so punt.
*/
printf("%s: unable to wake up from power state D3\n",
- sc->bcw_dev.dv_xname);
+ sc->sc_dev.dv_xname);
return;
}
if (pmode != 0) {
printf("%s: waking up from power state D%d\n",
- sc->bcw_dev.dv_xname, pmode);
+ sc->sc_dev.dv_xname, pmode);
pci_conf_write(pc, pa->pa_tag, pmreg + 4, 0);
}
}
@@ -204,35 +203,33 @@ bcw_pci_attach(parent, self, aux)
switch (memtype) {
case PCI_MAPREG_TYPE_MEM | PCI_MAPREG_MEM_TYPE_32BIT:
case PCI_MAPREG_TYPE_MEM | PCI_MAPREG_MEM_TYPE_64BIT:
- if (pci_mapreg_map(pa, BCW_PCI_BAR0, memtype, 0, &sc->bcw_btag,
- &sc->bcw_bhandle, &memaddr, &memsize, 0) == 0)
+ if (pci_mapreg_map(pa, BCW_PCI_BAR0, memtype, 0, &sc->sc_iot,
+ &sc->sc_ioh, &memaddr, &memsize, 0) == 0)
break;
default:
printf("%s: unable to find mem space\n",
- sc->bcw_dev.dv_xname);
+ sc->sc_dev.dv_xname);
return;
}
- regs->r_bt = sc->bcw_btag;
- regs->r_bh = sc->bcw_bhandle;
- sc->bcw_dmatag = pa->pa_dmat;
+ 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",
- sc->bcw_dev.dv_xname);
+ sc->sc_dev.dv_xname);
return;
}
sc->bcw_intrstr = pci_intr_string(pc, psc->psc_ih);
psc->psc_intrcookie = pci_intr_establish(pc, psc->psc_ih, IPL_NET,
- bcw_intr, sc, sc->bcw_dev.dv_xname);
+ bcw_intr, sc, sc->sc_dev.dv_xname);
if (psc->psc_intrcookie == NULL) {
printf("%s: couldn't establish interrupt",
- sc->bcw_dev.dv_xname);
+ sc->sc_dev.dv_xname);
if (sc->bcw_intrstr != NULL)
printf(" at %s", sc->bcw_intrstr);
printf("\n");
@@ -247,23 +244,23 @@ bcw_pci_attach(parent, self, aux)
/*
* Get some PCI based info into the softc
*/
- sc->bcw_chiprev=PCI_REVISION(pa->pa_class);
- sc->bcw_prodid=PCI_PRODUCT(pa->pa_id);
+ sc->sc_chiprev=PCI_REVISION(pa->pa_class);
+ sc->sc_prodid=PCI_PRODUCT(pa->pa_id);
/*
* Start the card up while we're in PCI land
*/
/* Turn the Crystal On */
- sbval = bus_space_read_4(sc->bcw_btag, sc->bcw_bhandle, BCW_GPIOI);
+ 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->bcw_btag, sc->bcw_bhandle, BCW_GPIOO);
+ sbval = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_GPIOO);
sbval |= (BCW_XTALPOWERUP & BCW_PLLPOWERDOWN);
- bus_space_write_4(sc->bcw_btag, sc->bcw_bhandle, BCW_GPIOO, sbval);
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_GPIOO, sbval);
delay(1000);
- sbval = bus_space_read_4(sc->bcw_btag, sc->bcw_bhandle, BCW_GPIOO);
+ sbval = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_GPIOO);
sbval &= ~BCW_PLLPOWERDOWN;
- bus_space_write_4(sc->bcw_btag, sc->bcw_bhandle, BCW_GPIOO, sbval);
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_GPIOO, sbval);
delay(5000);
}
@@ -271,9 +268,9 @@ bcw_pci_attach(parent, self, aux)
* Clear PCI_STATUS_TARGET_TARGET_ABORT, Docs and Linux call it
* PCI_STATUS_SIG_TARGET_ABORT - should use pci_conf_read/write?
*/
- bus_space_write_4(sc->bcw_btag, sc->bcw_bhandle,
+ bus_space_write_4(sc->sc_iot, sc->sc_ioh,
PCI_COMMAND_STATUS_REG,
- bus_space_read_4(sc->bcw_btag, sc->bcw_bhandle,
+ bus_space_read_4(sc->sc_iot, sc->sc_ioh,
PCI_COMMAND_STATUS_REG)
& ~PCI_STATUS_TARGET_TARGET_ABORT);