summaryrefslogtreecommitdiff
path: root/sys/dev
diff options
context:
space:
mode:
Diffstat (limited to 'sys/dev')
-rw-r--r--sys/dev/ic/bcw.c311
1 files changed, 161 insertions, 150 deletions
diff --git a/sys/dev/ic/bcw.c b/sys/dev/ic/bcw.c
index 42e07ecba79..40ff18db4b1 100644
--- a/sys/dev/ic/bcw.c
+++ b/sys/dev/ic/bcw.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: bcw.c,v 1.1 2006/11/17 18:58:31 mglocker Exp $ */
+/* $OpenBSD: bcw.c,v 1.2 2006/11/17 20:04:52 mglocker Exp $ */
/*
* Copyright (c) 2006 Jon Simola <jsimola@gmail.com>
@@ -84,7 +84,7 @@ void bcw_stop(struct ifnet *, int);
void bcw_watchdog(struct ifnet *);
void bcw_rxintr(struct bcw_softc *);
void bcw_txintr(struct bcw_softc *);
-//static void bcw_add_mac(struct bcw_softc *, u_int8_t *, unsigned long);
+//void bcw_add_mac(struct bcw_softc *, u_int8_t *, unsigned long);
int bcw_add_rxbuf(struct bcw_softc *, int);
void bcw_rxdrain(struct bcw_softc *);
void bcw_set_filter(struct ifnet *);
@@ -106,7 +106,6 @@ 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
};
@@ -117,25 +116,29 @@ bcw_attach(struct bcw_softc *sc)
struct ieee80211com *ic = &sc->bcw_ic;
struct ifnet *ifp = &ic->ic_if;
struct bcw_regs *regs = &sc->bcw_regs;
-// struct pci_attach_args *pa = &sc->bcw_pa;
-// pci_chipset_tag_t pc = pa->pa_pc;
-// pci_intr_handle_t ih;
-// const char *intrstr = NULL;
+#if 0
+ struct pci_attach_args *pa = &sc->bcw_pa;
+ pci_chipset_tag_t pc = pa->pa_pc;
+ pci_intr_handle_t ih;
+ const char *intrstr = NULL;
+#endif
caddr_t kva;
bus_dma_segment_t seg;
int rseg;
-// pcireg_t memtype;
-// bus_addr_t memaddr;
-// bus_size_t memsize;
-// int pmreg;
-// pcireg_t pmode;
+#if 0
+ pcireg_t memtype;
+ bus_addr_t memaddr;
+ bus_size_t memsize;
+ int pmreg;
+ pcireg_t pmode;
+#endif
int error;
int i,j;
u_int32_t sbval;
u_int16_t sbval16;
-// sc->bcw_pa = *pa;
-// sc->bcw_dmatag = pa->pa_dmat;
+ //sc->bcw_pa = *pa;
+ //sc->bcw_dmatag = pa->pa_dmat;
if (sc->bcw_regs.r_read8 == NULL) {
sc->bcw_regs.r_read8 = bcw_read8;
@@ -147,7 +150,6 @@ bcw_attach(struct bcw_softc *sc)
sc->bcw_regs.r_barrier = bcw_barrier;
}
-
/*
* Reset the chip
*/
@@ -197,7 +199,7 @@ bcw_attach(struct bcw_softc *sc)
if (sbval == BCW_CORE_SELECT(0)) break;
delay(10);
}
-// DPRINTF(("\n")); // Pretty print so the debugs start on new lines
+ //DPRINTF(("\n")); /* Pretty print so the debugs start on new lines */
/*
* Core ID REG, this is either the default wireless core (0x812) or
@@ -213,7 +215,8 @@ bcw_attach(struct bcw_softc *sc)
sc->bcw_havecommon = 1;
sbval = BCW_READ32(regs, BCW_CORE_COMMON_CHIPID);
sc->bcw_chipid = (sbval & 0x0000ffff);
- sc->bcw_corerev = ((sbval & 0x00007000) >> 8 | (sbval & 0x0000000f));
+ sc->bcw_corerev =
+ ((sbval & 0x00007000) >> 8 | (sbval & 0x0000000f));
if ((sc->bcw_corerev == 4) || (sc->bcw_corerev >= 6))
sc->bcw_numcores = (sbval & 0x0f000000) >> 24;
else
@@ -308,7 +311,7 @@ bcw_attach(struct bcw_softc *sc)
DPRINTF(("%s: Found core %d of type 0x%x\n",
sc->bcw_dev.dv_xname, i,
(sbval & 0x00008ff0) >> 4));
-// sc->bcw_core[i].id = (sbval & 0x00008ff0) >> 4;
+ //sc->bcw_core[i].id = (sbval & 0x00008ff0) >> 4;
} /* End of For loop */
DPRINTF(("\n")); /* Make pretty debug output */
}
@@ -455,7 +458,6 @@ bcw_attach(struct bcw_softc *sc)
/*
* Switch the radio off - candidate for seperate function
*/
-
switch(sc->bcw_phy_type) {
case BCW_PHY_TYPEA:
/* Magic unexplained values */
@@ -537,7 +539,7 @@ bcw_attach(struct bcw_softc *sc)
/* Init the Microcode Flags Bitfield */
- // http://bcm-specs.sipsolutions.net/MicrocodeFlagsBitfield
+ /* http://bcm-specs.sipsolutions.net/MicrocodeFlagsBitfield */
sbval = 0;
if((sc->bcw_phy_type == BCW_PHY_TYPEA) ||
@@ -547,22 +549,26 @@ bcw_attach(struct bcw_softc *sc)
if((sc->bcw_phy_type == BCW_PHY_TYPEG) &&
(sc->bcw_phy_rev == 1))
sbval |= 0x20;
- // XXX If this is a G PHY with BoardFlags BFL_PACTRL set, set bit 0x40
+ /*
+ * 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))
sbval |= 0x8; /* MAGIC */
- // XXX If BoardFlags BFL_XTAL is set, set bit 0x400
+ /* XXX If BoardFlags BFL_XTAL is set, set bit 0x400 */
if(sc->bcw_phy_type == BCW_PHY_TYPEB)
sbval |= 0x4;
if((sc->bcw_radiotype == 0x2050) &&
(sc->bcw_radiorev <= 5))
sbval |= 0x40000;
- /* XXX If the device isn't up and this is a PCI bus with revision
- 10 or less set bit 0x80000 */
-
-
- /* Now, write the value into the regster */
/*
+ * XXX If the device isn't up and this is a PCI bus with revision
+ * 10 or less set bit 0x80000
+ */
+
+ /* Now, write the value into the regster
+ *
* The MicrocodeBitFlags is an unaligned 32bit value in SHM, so the
* strategy is to select the aligned word for the lower 16 bits,
* but write to the unaligned address. Then, because the SHM
@@ -582,7 +588,6 @@ bcw_attach(struct bcw_softc *sc)
* http://bcm-specs.sipsolutions.net/TSSI_to_DBM_Table
* but I suspect there's a standard way to do it in the 80211 stuff
*/
-
/*
* TODO still for the card attach:
@@ -591,8 +596,6 @@ bcw_attach(struct bcw_softc *sc)
* - Setup LEDs to blink in whatever fashionable manner
*/
-
-
/*
* Allocate DMA-safe memory for ring descriptors.
* The receive, and transmit rings are 4k aligned
@@ -601,7 +604,7 @@ bcw_attach(struct bcw_softc *sc)
*/
if ((error = bus_dmamem_alloc(sc->bcw_dmatag,
2 * PAGE_SIZE, PAGE_SIZE, 2 * PAGE_SIZE,
- &seg, 1, &rseg, BUS_DMA_NOWAIT))) {
+ &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;
@@ -617,7 +620,7 @@ bcw_attach(struct bcw_softc *sc)
/* 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))) {
+ &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);
@@ -639,7 +642,8 @@ bcw_attach(struct bcw_softc *sc)
/* 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) {
+ 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);
}
@@ -658,14 +662,12 @@ bcw_attach(struct bcw_softc *sc)
/* End of the DMA stuff */
-
ic->ic_phytype = IEEE80211_T_OFDM;
- ic->ic_opmode = IEEE80211_M_STA; /* default to BSS mode */
+ ic->ic_opmode = IEEE80211_M_STA; /* default to BSS mode */
ic->ic_state = IEEE80211_S_INIT;
/* set device capabilities - keep it simple */
- ic->ic_caps =
- IEEE80211_C_IBSS; /* IBSS mode supported */
+ ic->ic_caps = IEEE80211_C_IBSS; /* IBSS mode supported */
/* MAC address */
if(sc->bcw_phy_type == BCW_PHY_TYPEA) {
@@ -699,11 +701,11 @@ bcw_attach(struct bcw_softc *sc)
/* Set supported channels */
for (i = 1; i <= 14; i++) {
- ic->ic_channels[i].ic_freq =
- ieee80211_ieee2mhz(i, IEEE80211_CHAN_2GHZ);
- ic->ic_channels[i].ic_flags =
- IEEE80211_CHAN_CCK | IEEE80211_CHAN_OFDM |
- IEEE80211_CHAN_DYN | IEEE80211_CHAN_2GHZ;
+ ic->ic_channels[i].ic_freq =
+ ieee80211_ieee2mhz(i, IEEE80211_CHAN_2GHZ);
+ ic->ic_channels[i].ic_flags =
+ IEEE80211_CHAN_CCK | IEEE80211_CHAN_OFDM |
+ IEEE80211_CHAN_DYN | IEEE80211_CHAN_2GHZ;
}
/* IBSS channel undefined for now */
@@ -735,17 +737,18 @@ 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 bcw_regs *regs = &sc->bcw_regs;
struct ifreq *ifr = (struct ifreq *) data;
struct ifaddr *ifa = (struct ifaddr *)data;
int s, error = 0;
s = splnet();
-
-// if ((error = ether_ioctl(ifp, &sc->bcw_ac, cmd, data)) > 0) {
-// splx(s);
-// return (error);
-// }
+#if 0
+ if ((error = ether_ioctl(ifp, &sc->bcw_ac, cmd, data)) > 0) {
+ splx(s);
+ return (error);
+ }
+#endif
switch (cmd) {
case SIOCSIFADDR:
@@ -883,7 +886,7 @@ bcw_start(struct ifnet *ifp)
/* Sync the data DMA map. */
bus_dmamap_sync(sc->bcw_dmatag, dmamap, 0, dmamap->dm_mapsize,
- BUS_DMASYNC_PREWRITE);
+ BUS_DMASYNC_PREWRITE);
/* Initialize the transmit descriptor(s). */
txstart = sc->bcw_txsnext;
@@ -899,8 +902,9 @@ bcw_start(struct ifnet *ifp)
ctrl |= CTRL_EOT;
ctrl |= CTRL_IOC;
sc->bcw_tx_ring[sc->bcw_txsnext].ctrl = htole32(ctrl);
+ /* MAGIC */
sc->bcw_tx_ring[sc->bcw_txsnext].addr =
- htole32(dmamap->dm_segs[seg].ds_addr + 0x40000000); /* MAGIC */
+ htole32(dmamap->dm_segs[seg].ds_addr + 0x40000000);
if (sc->bcw_txsnext + 1 > BCW_NTXDESC - 1)
sc->bcw_txsnext = 0;
else
@@ -955,16 +959,15 @@ bcw_intr(void *xsc)
{
struct bcw_softc *sc;
struct bcw_regs *regs;
- struct ifnet *ifp;
+ struct ifnet *ifp;
u_int32_t intstatus;
- int wantinit;
- int handled = 0;
+ 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);
@@ -1026,13 +1029,13 @@ bcw_intr(void *xsc)
void
bcw_rxintr(struct bcw_softc *sc)
{
- struct ifnet *ifp = &sc->bcw_ac.ac_if;
+ struct ifnet *ifp = &sc->bcw_ac.ac_if;
struct bcw_regs *regs = &sc->bcw_regs;
- struct rx_pph *pph;
- struct mbuf *m;
- int curr;
- int len;
- int i;
+ struct rx_pph *pph;
+ struct mbuf *m;
+ int curr;
+ int len;
+ int i;
/* get pointer to active receive slot */
curr = BCW_READ32(regs, BCW_DMA_RXSTATUS) & RS_CD_MASK;
@@ -1141,10 +1144,10 @@ bcw_rxintr(struct bcw_softc *sc)
void
bcw_txintr(struct bcw_softc *sc)
{
- struct ifnet *ifp = &sc->bcw_ac.ac_if;
+ struct ifnet *ifp = &sc->bcw_ac.ac_if;
struct bcw_regs *regs = &sc->bcw_regs;
- int curr;
- int i;
+ int curr;
+ int i;
ifp->if_flags &= ~IFF_OACTIVE;
@@ -1186,8 +1189,8 @@ 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;
+ int error;
+ int i;
/* Cancel any pending I/O. */
bcw_stop(ifp, 0);
@@ -1257,8 +1260,9 @@ bcw_init(struct ifnet *ifp)
/* 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); /* MAGIC */
+ sc->bcw_ring_map->dm_segs[0].ds_addr + PAGE_SIZE + 0x40000000);
/*
* Give the receive ring to the chip, and
@@ -1299,12 +1303,14 @@ bcw_init(struct ifnet *ifp)
BCW_NRXDESC * sizeof(struct bcw_dma_slot));
/* set media */
-// mii_mediachg(&sc->bcw_mii);
+ //mii_mediachg(&sc->bcw_mii);
/* turn on the ethernet mac */
-// bus_space_write_4(sc->bcw_btag, sc->bcw_bhandle, BCW_ENET_CTL,
-// bus_space_read_4(sc->bcw_btag, sc->bcw_bhandle,
-// BCW_ENET_CTL) | EC_EE);
+#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,
+ BCW_ENET_CTL) | EC_EE);
+#endif
/* start timer */
timeout_add(&sc->bcw_timeout, hz);
@@ -1313,15 +1319,15 @@ bcw_init(struct ifnet *ifp)
ifp->if_flags |= IFF_RUNNING;
ifp->if_flags &= ~IFF_OACTIVE;
- return 0;
+ return (0);
}
/* Add a receive buffer to the indiciated descriptor. */
int
bcw_add_rxbuf(struct bcw_softc *sc, int idx)
{
- struct mbuf *m;
- int error;
+ struct mbuf *m;
+ int error;
MGETHDR(m, M_DONTWAIT, MT_DATA);
if (m == NULL)
@@ -1357,7 +1363,7 @@ bcw_add_rxbuf(struct bcw_softc *sc, int idx)
void
bcw_rxdrain(struct bcw_softc *sc)
{
- int i;
+ int i;
for (i = 0; i < BCW_NRXDESC; i++) {
if (sc->bcw_cdata.bcw_rx_chain[i] != NULL) {
@@ -1375,7 +1381,7 @@ bcw_stop(struct ifnet *ifp, int disable)
{
struct bcw_softc *sc = ifp->if_softc;
struct bcw_regs *regs = &sc->bcw_regs;
- int i;
+ int i;
//u_int32_t val;
/* Stop the 1 second timer */
@@ -1390,7 +1396,8 @@ bcw_stop(struct ifnet *ifp, int disable)
sc->bcw_intmask = 0;
delay(10);
- /* Disable emac
+ /* Disable emac */
+#if 0
bus_space_write_4(sc->bcw_btag, sc->bcw_bhandle, BCW_ENET_CTL, EC_ED);
for (i = 0; i < 200; i++) {
val = bus_space_read_4(sc->bcw_btag, sc->bcw_bhandle,
@@ -1399,7 +1406,7 @@ bcw_stop(struct ifnet *ifp, int disable)
break;
delay(10);
}
- */
+#endif
/* Stop the DMA */
BCW_WRITE32(regs, BCW_DMA_RXCTL, 0);
BCW_WRITE32(regs, BCW_DMA_TXCTL, 0);
@@ -1422,14 +1429,12 @@ bcw_stop(struct ifnet *ifp, int disable)
/* reset the chip */
void
-bcw_reset(sc)
- struct bcw_softc *sc;
+bcw_reset(struct bcw_softc *sc)
{
struct bcw_regs *regs = &sc->bcw_regs;
u_int32_t val;
u_int32_t sbval;
- int i;
-
+ int i;
/* if SB core is up, only clock of clock,reset,reject will be set */
sbval = BCW_READ32(regs, BCW_SBTMSTATELOW);
@@ -1457,7 +1462,8 @@ bcw_reset(sc)
}
BCW_WRITE32(regs, BCW_DMA_RXSTATUS, 0);
- /* reset ethernet mac
+ /* reset ethernet mac */
+#if 0
bus_space_write_4(sc->bcw_btag, sc->bcw_bhandle, BCW_ENET_CTL,
EC_ES);
for (i = 0; i < 200; i++) {
@@ -1470,7 +1476,7 @@ bcw_reset(sc)
if (i == 200)
printf("%s: timed out resetting ethernet mac\n",
sc->bcw_dev.dv_xname);
- */
+#endif
} else {
u_int32_t reg_win;
@@ -1523,13 +1529,14 @@ bcw_reset(sc)
sc->bcw_dev.dv_xname);
/* set reset and reject while enabling the clocks */
BCW_WRITE32(regs, BCW_SBTMSTATELOW,
- SBTML_FGC | SBTML_CLK | SBTML_REJ | SBTML_RESET | SBTML_80211FLAG );
+ SBTML_FGC | SBTML_CLK | SBTML_REJ | SBTML_RESET |
+ SBTML_80211FLAG);
val = BCW_READ32(regs, BCW_SBTMSTATELOW);
delay(10);
BCW_WRITE32(regs, BCW_SBTMSTATELOW, SBTML_REJ | SBTML_RESET);
delay(1);
}
- // This is enabling/resetting the core
+ /* This is enabling/resetting the core */
/* enable clock */
BCW_WRITE32(regs, BCW_SBTMSTATELOW,
SBTML_FGC | SBTML_CLK | SBTML_RESET |
@@ -1565,80 +1572,87 @@ bcw_reset(sc)
sbval=BCW_READ32(regs, 0x120);
sbval |= 0x400;
BCW_WRITE32(regs, 0x120, sbval);
-
-// /* initialize MDC preamble, frequency */
-// bus_space_write_4(sc->bcw_btag, sc->bcw_bhandle, BCW_MI_CTL, 0x8d); /* MAGIC */
+#if 0
+ /* initialize MDC preamble, frequency */
+ /* MAGIC */
+ bus_space_write_4(sc->bcw_btag, sc->bcw_bhandle, BCW_MI_CTL, 0x8d);
/* enable phy, differs for internal, and external */
-// val = bus_space_read_4(sc->bcw_btag, sc->bcw_bhandle, BCW_DEVCTL);
-// if (!(val & BCW_DC_IP)) {
+ val = bus_space_read_4(sc->bcw_btag, sc->bcw_bhandle, BCW_DEVCTL);
+ if (!(val & BCW_DC_IP)) {
/* select external phy */
-// bus_space_write_4(sc->bcw_btag, sc->bcw_bhandle, 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,
-// val & ~BCW_DC_ER);
-// delay(100);
-// }
+ bus_space_write_4(sc->bcw_btag, sc->bcw_bhandle, 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,
+ val & ~BCW_DC_ER);
+ delay(100);
+ }
+#endif
}
/* Set up the receive filter. */
void
bcw_set_filter(struct ifnet *ifp)
{
-// struct bcw_softc *sc = ifp->if_softc;
+#if 0
+ struct bcw_softc *sc = ifp->if_softc;
-// if (ifp->if_flags & IFF_PROMISC) {
-// ifp->if_flags |= IFF_ALLMULTI;
-// bus_space_write_4(sc->bcw_btag, sc->bcw_bhandle, BCW_RX_CTL,
-// bus_space_read_4(sc->bcw_btag, sc->bcw_bhandle, BCW_RX_CTL)
-// | ERC_PE);
-// } else {
-// ifp->if_flags &= ~IFF_ALLMULTI;
+ if (ifp->if_flags & IFF_PROMISC) {
+ ifp->if_flags |= IFF_ALLMULTI;
+ bus_space_write_4(sc->bcw_btag, sc->bcw_bhandle, BCW_RX_CTL,
+ bus_space_read_4(sc->bcw_btag, sc->bcw_bhandle, BCW_RX_CTL)
+ | ERC_PE);
+ } else {
+ ifp->if_flags &= ~IFF_ALLMULTI;
/* turn off promiscuous */
-// bus_space_write_4(sc->bcw_btag, sc->bcw_bhandle, BCW_RX_CTL,
-// bus_space_read_4(sc->bcw_btag, sc->bcw_bhandle,
-// BCW_RX_CTL) & ~ERC_PE);
+ bus_space_write_4(sc->bcw_btag, sc->bcw_bhandle, BCW_RX_CTL,
+ bus_space_read_4(sc->bcw_btag, sc->bcw_bhandle,
+ BCW_RX_CTL) & ~ERC_PE);
/* enable/disable broadcast */
-// if (ifp->if_flags & IFF_BROADCAST)
-// bus_space_write_4(sc->bcw_btag, sc->bcw_bhandle,
-// BCW_RX_CTL, bus_space_read_4(sc->bcw_btag,
-// sc->bcw_bhandle, BCW_RX_CTL) & ~ERC_DB);
-// else
-// bus_space_write_4(sc->bcw_btag, sc->bcw_bhandle,
-// BCW_RX_CTL, bus_space_read_4(sc->bcw_btag,
-// sc->bcw_bhandle, BCW_RX_CTL) | ERC_DB);
+ if (ifp->if_flags & IFF_BROADCAST)
+ bus_space_write_4(sc->bcw_btag, sc->bcw_bhandle,
+ BCW_RX_CTL, bus_space_read_4(sc->bcw_btag,
+ sc->bcw_bhandle, BCW_RX_CTL) & ~ERC_DB);
+ else
+ bus_space_write_4(sc->bcw_btag, sc->bcw_bhandle,
+ BCW_RX_CTL, bus_space_read_4(sc->bcw_btag,
+ sc->bcw_bhandle, BCW_RX_CTL) | ERC_DB);
/* disable the filter */
-// bus_space_write_4(sc->bcw_btag, sc->bcw_bhandle, BCW_FILT_CTL,
-// 0);
+ bus_space_write_4(sc->bcw_btag, sc->bcw_bhandle, BCW_FILT_CTL,
+ 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,
-// bus_space_read_4(sc->bcw_btag, sc->bcw_bhandle, BCW_RX_CTL) |
-// ERC_AM);
-// ifp->if_flags |= IFF_ALLMULTI;
+ bus_space_write_4(sc->bcw_btag, sc->bcw_bhandle, BCW_RX_CTL,
+ bus_space_read_4(sc->bcw_btag, sc->bcw_bhandle, BCW_RX_CTL) |
+ ERC_AM);
+ ifp->if_flags |= IFF_ALLMULTI;
/* enable the filter */
-// bus_space_write_4(sc->bcw_btag, sc->bcw_bhandle, BCW_FILT_CTL,
-// bus_space_read_4(sc->bcw_btag, sc->bcw_bhandle,
-// BCW_FILT_CTL) | 1);
-// }
+ bus_space_write_4(sc->bcw_btag, sc->bcw_bhandle, BCW_FILT_CTL,
+ bus_space_read_4(sc->bcw_btag, sc->bcw_bhandle,
+ BCW_FILT_CTL) | 1);
+ }
+#endif
}
int
bcw_newstate(struct ieee80211com *ic, enum ieee80211_state nstate, int arg)
{
-// struct bcw_softc *sc = ic->ic_softc;
-// enum ieee80211_state ostate;
-// uint32_t tmp;
+#if 0
+ struct bcw_softc *sc = ic->ic_softc;
+ enum ieee80211_state ostate;
+ uint32_t tmp;
-// ostate = ic->ic_state;
- return 0;
+ ostate = ic->ic_state;
+#endif
+ return (0);
}
int
@@ -1653,7 +1667,7 @@ bcw_media_change(struct ifnet *ifp)
if ((ifp->if_flags & (IFF_UP | IFF_RUNNING)) == (IFF_UP | IFF_RUNNING))
bcw_init(ifp);
- return 0;
+ return (0);
}
void
@@ -1661,7 +1675,7 @@ bcw_media_status(struct ifnet *ifp, struct ifmediareq *imr)
{
struct bcw_softc *sc = ifp->if_softc;
struct ieee80211com *ic = &sc->bcw_ic;
-// uint32_t val;
+ //uint32_t val;
int rate;
imr->ifm_status = IFM_AVALID;
@@ -1672,9 +1686,9 @@ bcw_media_status(struct ifnet *ifp, struct ifmediareq *imr)
/*
* XXX Read current transmission rate from the adapter.
*/
-// val = CSR_READ_4(sc, IWI_CSR_CURRENT_TX_RATE);
+ //val = CSR_READ_4(sc, IWI_CSR_CURRENT_TX_RATE);
/* convert PLCP signal to 802.11 rate */
-// rate = bcw_rate(val);
+ //rate = bcw_rate(val);
rate = 0;
imr->ifm_active |= ieee80211_rate2media(ic, rate, ic->ic_curmode);
@@ -1698,17 +1712,16 @@ bcw_media_status(struct ifnet *ifp, struct ifmediareq *imr)
void
bcw_tick(void *v)
{
-// struct bcw_softc *sc = v;
-// http://bcm-specs.sipsolutions.net/PeriodicTasks
-// timeout_add(&sc->bcw_timeout, hz);
-
-
+#if 0
+ struct bcw_softc *sc = v;
+ /* http://bcm-specs.sipsolutions.net/PeriodicTasks */
+ timeout_add(&sc->bcw_timeout, hz);
+#endif
}
/*
* Validate Chip Access
*/
-
int
bcw_validatechipaccess(struct bcw_softc *sc)
{
@@ -1736,10 +1749,9 @@ bcw_validatechipaccess(struct bcw_softc *sc)
DPRINTF(("Read test 1, "));
if (val != 0xaa5555aa) {
DPRINTF(("Failed test 1\n"));
- return 1;
- } else {
+ return (1);
+ } else
DPRINTF(("Passed test 1\n"));
- }
/* write 2nd test value */
BCW_WRITE32(regs, BCW_SHM_CONTROL, (BCW_SHM_CONTROL_SHARED << 16) + 0);
@@ -1752,9 +1764,8 @@ bcw_validatechipaccess(struct bcw_softc *sc)
if (val != 0x55aaaa55) {
DPRINTF(("Failed test 2\n"));
return 2;
- } else {
+ } else
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);
@@ -1785,23 +1796,23 @@ bcw_validatechipaccess(struct bcw_softc *sc)
printf("%s: Warning, SBF is 0x%x, expected 0x80000400\n",
sc->bcw_dev.dv_xname,val);
/* May not be a critical failure, just warn for now */
- //return 5;
+ //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));
- return 6;
+ return (6);
}
/* Above G means it's unsupported currently, like N */
if (sc->bcw_phy_type > BCW_PHY_TYPEG) {
DPRINTF(("PHY type %d greater than supported type %d\n",
sc->bcw_phy_type, BCW_PHY_TYPEG));
- return 7;
+ return (7);
}
- return 0;
+ return (0);
}