diff options
Diffstat (limited to 'sys/dev')
-rw-r--r-- | sys/dev/ic/bcw.c | 416 | ||||
-rw-r--r-- | sys/dev/ic/bcwreg.h | 10 |
2 files changed, 187 insertions, 239 deletions
diff --git a/sys/dev/ic/bcw.c b/sys/dev/ic/bcw.c index 2b6e90bd318..2031686b34e 100644 --- a/sys/dev/ic/bcw.c +++ b/sys/dev/ic/bcw.c @@ -1,4 +1,4 @@ -/* $OpenBSD: bcw.c,v 1.10 2006/12/08 01:28:40 mglocker Exp $ */ +/* $OpenBSD: bcw.c,v 1.11 2006/12/27 14:05:57 jsg Exp $ */ /* * Copyright (c) 2006 Jon Simola <jsimola@gmail.com> @@ -124,8 +124,8 @@ bcw_attach(struct bcw_softc *sc) * be powered on and the clock started. This may even need to go * before the initial chip reset above. */ - sc->sc_boardflags = bus_space_read_2(sc->sc_iot, sc->sc_ioh, - BCW_SPROM_BOARDFLAGS); + sc->sc_boardflags = BCW_READ16(sc, BCW_SPROM_BOARDFLAGS); + /* * Dell, Product ID 0x4301 Revision 0x74, set BCW_BF_BTCOEXIST * Apple Board Type 0x4e Revision > 0x40, set BCW_BF_PACTRL @@ -169,7 +169,7 @@ bcw_attach(struct bcw_softc *sc) * Core ID REG, this is either the default wireless core (0x812) or * a ChipCommon core that was successfully selected above */ - sbval = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_CIR_SBID_HI); + sbval = BCW_READ(sc, BCW_CIR_SBID_HI); DPRINTF(("%s: Got Core ID Reg 0x%x, type is 0x%x\n", sc->sc_dev.dv_xname, sbval, (sbval & 0x8ff0) >> 4)); @@ -177,8 +177,7 @@ bcw_attach(struct bcw_softc *sc) get the number of cores from the chipid reg */ if (((sbval & 0x00008ff0) >> 4) == BCW_CORE_COMMON) { sc->sc_havecommon = 1; - sbval = bus_space_read_4(sc->sc_iot, sc->sc_ioh, - BCW_CORE_COMMON_CHIPID); + sbval = BCW_READ(sc, BCW_CORE_COMMON_CHIPID); sc->sc_chipid = (sbval & 0x0000ffff); sc->sc_corerev = ((sbval & 0x00007000) >> 8 | (sbval & 0x0000000f)); @@ -274,8 +273,7 @@ bcw_attach(struct bcw_softc *sc) delay(10); } if (j < 10) { - sbval = bus_space_read_4(sc->sc_iot, - sc->sc_ioh, BCW_CIR_SBID_HI); + sbval = BCW_READ(sc, BCW_CIR_SBID_HI); DPRINTF(("%s: Found core %d of type 0x%x\n", sc->sc_dev.dv_xname, i, (sbval & 0x00008ff0) >> 4)); @@ -290,9 +288,9 @@ bcw_attach(struct bcw_softc *sc) // ??? if (!sc->sc_singlecore) { #if 0 if (sc->sc_havecommon == 1) { - sbval = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_PCICR); + sbval = BCW_READ(sc, BCW_PCICR); sbval |= 0x1 << 8; /* XXX hardcoded bitmask of single core */ - bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_PCICR, sbval); + BCW_WRITE(sc, BCW_PCICR, sbval); } #endif /* @@ -304,7 +302,7 @@ bcw_attach(struct bcw_softc *sc) (sc->sc_conf_write)(sc, BCW_ADDR_SPACE0, BCW_CORE_SELECT(i)); } - sbval = bus_space_read_2(sc->sc_iot, sc->sc_ioh, 0x3E0); + sbval = BCW_READ16(sc, 0x3E0); sc->sc_phy_version = (sbval&0xf000)>>12; sc->sc_phy_rev = sbval&0xf; sc->sc_phy_type = (sbval&0xf00)>>8; @@ -338,15 +336,11 @@ bcw_attach(struct bcw_softc *sc) * and the high data addresses. */ 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); + BCW_WRITE16(sc, BCW_RADIO_CONTROL, BCW_RADIO_ID); + sbval = BCW_READ16(sc, BCW_RADIO_DATAHIGH); sbval <<= 16; - 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); + BCW_WRITE16(sc, BCW_RADIO_CONTROL, BCW_RADIO_ID); + sc->sc_radioid = sbval | BCW_READ16(sc, BCW_RADIO_DATALOW); } else { switch (sc->sc_corerev) { case 0: @@ -443,64 +437,46 @@ bcw_attach(struct bcw_softc *sc) switch(sc->sc_phy_type) { case BCW_PHY_TYPEA: /* Magic unexplained values */ - 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); - 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); + BCW_WRITE16(sc, BCW_RADIO_CONTROL, 0x04); + BCW_WRITE16(sc, BCW_RADIO_DATALOW, 0xff); + BCW_WRITE16(sc, BCW_RADIO_CONTROL, 0x05); + BCW_WRITE16(sc, BCW_RADIO_DATALOW, 0xfb); + BCW_WRITE16(sc, BCW_PHY_CONTROL, 0x10); + + sbval16 = BCW_READ16(sc, BCW_PHY_DATA); sbval16 |= 0x8; - 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); + BCW_WRITE16(sc, BCW_PHY_CONTROL, 0x10); + BCW_WRITE16(sc, BCW_PHY_DATA, sbval16); + BCW_WRITE16(sc, BCW_PHY_CONTROL, 0x11); + + sbval16 = BCW_READ16(sc, BCW_PHY_DATA); sbval16 |= 0x8; - 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); + BCW_WRITE16(sc, BCW_PHY_CONTROL, 0x11); + BCW_WRITE16(sc, BCW_PHY_DATA, sbval16); break; case BCW_PHY_TYPEG: 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); + BCW_WRITE16(sc, BCW_PHY_CONTROL, 0x811); + sbval16 = BCW_READ16(sc, BCW_PHY_DATA); sbval16 |= 0x8c; - 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); + BCW_WRITE16(sc, BCW_PHY_CONTROL, 0x811); + BCW_WRITE16(sc, BCW_PHY_DATA, sbval16); + BCW_WRITE16(sc, BCW_PHY_CONTROL, 0x812); + sbval16 = BCW_READ16(sc, BCW_PHY_DATA); sbval16 &= 0xff73; - 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); + BCW_WRITE16(sc, BCW_PHY_CONTROL, 0x812); + + BCW_WRITE16(sc, BCW_PHY_DATA, sbval16); + } /* FALL-THROUGH */ default: - 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); + BCW_WRITE16(sc, BCW_PHY_CONTROL, 0x15); + BCW_WRITE16(sc, BCW_PHY_DATA, 0xaa00); } /* end of switch statement to turn off radio */ /* Read antenna gain from SPROM and multiply by 4 */ - sbval = bus_space_read_2(sc->sc_iot, sc->sc_ioh, BCW_SPROM_ANTGAIN); + sbval = BCW_READ16(sc, BCW_SPROM_ANTGAIN); /* If unset, assume 2 */ if ((sbval == 0) || (sbval == 0xffff)) sbval = 0x0202; @@ -514,21 +490,17 @@ bcw_attach(struct bcw_softc *sc) * 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->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); + sc->sc_radio_pa0b0 = BCW_READ16(sc, BCW_SPROM_PA0B0); + sc->sc_radio_pa0b1 = BCW_READ16(sc, BCW_SPROM_PA0B1); + + sc->sc_radio_pa0b2 = BCW_READ16(sc, BCW_SPROM_PA0B2); + sc->sc_radio_pa1b0 = BCW_READ16(sc, BCW_SPROM_PA1B0); + + sc->sc_radio_pa1b1 = BCW_READ16(sc, BCW_SPROM_PA1B1); + sc->sc_radio_pa1b2 = BCW_READ16(sc, BCW_SPROM_PA1B2); /* Get the idle TSSI */ - sbval = bus_space_read_2(sc->sc_iot, sc->sc_ioh, BCW_SPROM_IDLETSSI); + sbval = BCW_READ16(sc, BCW_SPROM_IDLETSSI); if (sc->sc_phy_type == BCW_PHY_TYPEA) sc->sc_idletssi = (sbval & 0xff); else @@ -574,12 +546,10 @@ bcw_attach(struct bcw_softc *sc) * This explanation could make more sense, but an SHM read/write * wrapper of some sort would be better. */ - bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_SHM_CONTROL, + BCW_WRITE(sc, BCW_SHM_CONTROL, (BCW_SHM_CONTROL_SHARED << 16) + BCW_SHM_MICROCODEFLAGSLOW - 2); - 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); + BCW_WRITE16(sc, BCW_SHM_DATAHIGH, sbval & 0x00ff); + BCW_WRITE16(sc, BCW_SHM_DATALOW, (sbval & 0xff00)>>16); /* * Initialize the TSSI to DBM table @@ -611,29 +581,28 @@ bcw_attach(struct bcw_softc *sc) /* MAC address */ if (sc->sc_phy_type == BCW_PHY_TYPEA) { - i = bus_space_read_2(sc->sc_iot, sc->sc_ioh, - BCW_SPROM_ET1MACADDR); + i = BCW_READ16(sc, BCW_SPROM_ET1MACADDR); ic->ic_myaddr[0] = (i & 0xff00) >> 8; ic->ic_myaddr[1] = i & 0xff; - i = bus_space_read_2(sc->sc_iot, sc->sc_ioh, - BCW_SPROM_ET1MACADDR + 2); + i = BCW_READ16(sc, BCW_SPROM_ET1MACADDR + 2); + ic->ic_myaddr[2] = (i & 0xff00) >> 8; ic->ic_myaddr[3] = i & 0xff; - i = bus_space_read_2(sc->sc_iot, sc->sc_ioh, - BCW_SPROM_ET1MACADDR + 4); + i = BCW_READ16(sc, BCW_SPROM_ET1MACADDR + 4); + ic->ic_myaddr[4] = (i & 0xff00) >> 8; ic->ic_myaddr[5] = i & 0xff; } else { /* assume B or G PHY */ - i = bus_space_read_2(sc->sc_iot, sc->sc_ioh, - BCW_SPROM_IL0MACADDR); + i = BCW_READ16(sc, BCW_SPROM_IL0MACADDR); + ic->ic_myaddr[0] = (i & 0xff00) >> 8; ic->ic_myaddr[1] = i & 0xff; - i = bus_space_read_2(sc->sc_iot, sc->sc_ioh, - BCW_SPROM_IL0MACADDR + 2); + i = BCW_READ16(sc, BCW_SPROM_IL0MACADDR + 2); + ic->ic_myaddr[2] = (i & 0xff00) >> 8; ic->ic_myaddr[3] = i & 0xff; - i = bus_space_read_2(sc->sc_iot, sc->sc_ioh, - BCW_SPROM_IL0MACADDR + 4); + i = BCW_READ16(sc, BCW_SPROM_IL0MACADDR + 4); + ic->ic_myaddr[4] = (i & 0xff00) >> 8; ic->ic_myaddr[5] = i & 0xff; } @@ -858,7 +827,7 @@ bcw_start(struct ifnet *ifp) BUS_DMASYNC_PREREAD | BUS_DMASYNC_PREWRITE); /* Give the packet to the chip. */ - bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_DMA_DPTR, + BCW_WRITE(sc, BCW_DMA_DPTR, sc->sc_txsnext * sizeof(struct bcw_dma_slot)); newpkts++; @@ -976,8 +945,7 @@ bcw_rxintr(struct bcw_softc *sc) int curr; /* get pointer to active receive slot */ - curr = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_DMA_RXSTATUS(0)) & - RS_CD_MASK; + curr = BCW_READ(sc, BCW_DMA_RXSTATUS(0)) & RS_CD_MASK; curr = curr / sizeof(struct bcw_dma_slot); if (curr >= BCW_RX_RING_COUNT) curr = BCW_RX_RING_COUNT - 1; @@ -1072,8 +1040,7 @@ bcw_rxintr(struct bcw_softc *sc) //ether_input_mbuf(ifp, m); /* re-check current in case it changed */ - curr = (bus_space_read_4(sc->sc_iot, sc->sc_ioh, - BCW_DMA_RXSTATUS) & RS_CD_MASK) / + curr = (BCW_READ(sc, BCW_DMA_RXSTATUS) & RS_CD_MASK) / sizeof(struct bcw_dma_slot); if (curr >= BCW_NRXDESC) curr = BCW_NRXDESC - 1; @@ -1097,7 +1064,7 @@ bcw_txintr(struct bcw_softc *sc) * Go through the Tx list and free mbufs for those * frames which have been transmitted. */ - curr = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_DMA_TXSTATUS) & RS_CD_MASK; + curr = BCW_READ(sc, BCW_DMA_TXSTATUS) & RS_CD_MASK; curr = curr / sizeof(struct bcw_dma_slot); if (curr >= BCW_NTXDESC) curr = BCW_NTXDESC - 1; @@ -1147,23 +1114,20 @@ bcw_init(struct ifnet *ifp) /* remap the pci registers to the Sonics config registers */ /* save the current map, so it can be restored */ - reg_win = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_REG0_WIN); + reg_win = BCW_READ(sc, BCW_REG0_WIN); /* set register window to Sonics registers */ - bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_REG0_WIN, BCW_SONICS_WIN); + BCW_WRITE(sc, BCW_REG0_WIN, BCW_SONICS_WIN); /* enable SB to PCI interrupt */ - 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); + BCW_WRITE(sc, BCW_SBINTVEC, BCW_READ(sc, BCW_SBINTVEC) | SBIV_ENET0); /* enable prefetch and bursts for sonics-to-pci translation 2 */ - 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); + BCW_WRITE(sc, BCW_SPCI_TR2, + BCW_READ(sc, BCW_SPCI_TR2) | SBTOPCI_PREF | SBTOPCI_BURST); /* restore to ethernet register space */ - bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_REG0_WIN, reg_win); + BCW_WRITE(sc, BCW_REG0_WIN, reg_win); /* Reset the chip to a known state. */ bcw_reset(sc); @@ -1176,32 +1140,27 @@ bcw_init(struct ifnet *ifp) #endif /* enable crc32 generation and set proper LED modes */ - 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); - + BCW_WRITE(sc, BCW_MACCTL, + BCW_READ(sc, BCW_MACCTL) | BCW_EMC_CRC32_ENAB | BCW_EMC_LED); + /* reset or clear powerdown control bit */ - 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); + BCW_WRITE(sc, BCW_MACCTL, BCW_READ(sc, BCW_MACCTL) & ~BCW_EMC_PDOWN); /* setup DMA interrupt control */ - bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_DMAI_CTL, 1 << 24); /* MAGIC */ + BCW_WRITE(sc, BCW_DMAI_CTL, 1 << 24); /* MAGIC */ /* setup packet filter */ bcw_set_filter(ifp); /* set max frame length, account for possible VLAN tag */ - bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_RX_MAX, - ETHER_MAX_LEN + ETHER_VLAN_ENCAP_LEN); - bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_TX_MAX, - ETHER_MAX_LEN + ETHER_VLAN_ENCAP_LEN); + BCW_WRITE(sc, BCW_RX_MAX, ETHER_MAX_LEN + ETHER_VLAN_ENCAP_LEN); + BCW_WRITE(sc, BCW_TX_MAX, ETHER_MAX_LEN + ETHER_VLAN_ENCAP_LEN); /* set tx watermark */ - bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_TX_WATER, 56); + BCW_WRITE(sc, BCW_TX_WATER, 56); /* enable transmit */ - bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_DMA_TXCTL, XC_XE); + BCW_WRITE(sc, BCW_DMA_TXCTL, XC_XE); /* * Give the receive ring to the chip, and @@ -1210,19 +1169,18 @@ bcw_init(struct ifnet *ifp) sc->sc_rxin = 0; /* enable receive */ - bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_DMA_RXCTL, - BCW_PREPKT_HEADER_SIZE << 1 | 1); + BCW_WRITE(sc, BCW_DMA_RXCTL, BCW_PREPKT_HEADER_SIZE << 1 | 1); /* Enable interrupts */ sc->sc_intmask = I_XI | I_RI | I_XU | I_RO | I_RU | I_DE | I_PD | I_PC | I_TO; - bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_INT_MASK, - sc->sc_intmask); + BCW_WRITE(sc, BCW_INT_MASK, sc->sc_intmask); + #if 0 /* FIXME */ /* start the receive dma */ - bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_DMA_RXDPTR, - BCW_NRXDESC * sizeof(struct bcw_dma_slot)); + BCW_WRITE(sc, BCW_DMA_RXDPTR, BCW_NRXDESC * sizeof(struct bcw_dma_slot)); + #endif /* set media */ @@ -1230,9 +1188,8 @@ bcw_init(struct ifnet *ifp) #if 0 /* turn on the ethernet mac */ - 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); + BCW_WRITE(sc, BCW_ENET_CTL, BCW_READ(sc, BCW_ENET_CTL) | EC_EE); + #endif /* start timer */ @@ -1318,24 +1275,24 @@ bcw_stop(struct ifnet *ifp, int disable) ifp->if_timer = 0; /* Disable interrupts. */ - bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_INT_MASK, 0); + BCW_WRITE(sc, BCW_INT_MASK, 0); sc->sc_intmask = 0; delay(10); /* Disable emac */ #if 0 - bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_ENET_CTL, EC_ED); + BCW_WRITE(sc, BCW_ENET_CTL, EC_ED); for (i = 0; i < 200; i++) { - val = bus_space_read_4(sc->sc_iot, sc->sc_ioh, - BCW_ENET_CTL); + val = BCW_READ(sc, BCW_ENET_CTL); + if (!(val & EC_ED)) break; delay(10); } #endif /* Stop the DMA */ - 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); + BCW_WRITE(sc, BCW_DMA_RXCONTROL(0), 0); + BCW_WRITE(sc, BCW_DMA_TXCONTROL(0), 0); delay(10); #if 0 /* FIXME */ @@ -1369,7 +1326,7 @@ bcw_reset(struct bcw_softc *sc) for (i=0xe00; i<0x1000; i+=4) { if ((i % 16) == 0) DPRINTF(("%s: 0x%04x - ",sc->sc_dev.dv_xname, i)); - DPRINTF(("0x%08x ",bus_space_read_4(sc->sc_iot, sc->sc_ioh,i))); + DPRINTF(("0x%08x ", BCW_READ(sc, i))); if ((i % 16) == 12) DPRINTF(("\n")); } #endif @@ -1378,7 +1335,7 @@ bcw_reset(struct bcw_softc *sc) * of the Reject bit changed. Save the revision in the softc, and * use the local variable 'reject' in all the bit banging. */ - sbval = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_CIR_SBID_LO); + sbval = BCW_READ(sc, BCW_CIR_SBID_LO); sc->sc_sbrev = (sbval & SBREV_MASK) >> SBREV_MASK_SHIFT; switch (sc->sc_sbrev) { @@ -1392,7 +1349,7 @@ bcw_reset(struct bcw_softc *sc) reject = SBTML_REJ22 | SBTML_REJ23; } - sbval = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_SBTMSTATELOW); + sbval = BCW_READ(sc, BCW_SBTMSTATELOW); /* * If the 802.11 core is enabled, only clock of clock,reset,reject @@ -1408,21 +1365,19 @@ bcw_reset(struct bcw_softc *sc) if (!(sbval & SBTML_RESET)) { /* if the core is not enabled, the clock won't be enabled */ if (!(sbval & SBTML_CLK)) { - bus_space_write_4(sc->sc_iot, sc->sc_ioh, - BCW_SBTMSTATELOW, SBTML_RESET | reject | + BCW_WRITE(sc, BCW_SBTMSTATELOW, SBTML_RESET | reject | SBTML_80211FLAG | SBTML_80211PHY ); delay(1); - sbval = bus_space_read_4(sc->sc_iot, sc->sc_ioh, - BCW_SBTMSTATELOW); + sbval = BCW_READ(sc, BCW_SBTMSTATELOW); goto disabled; - bus_space_write_4(sc->sc_iot, sc->sc_ioh, - BCW_SBTMSTATELOW, reject); + BCW_WRITE(sc, BCW_SBTMSTATELOW, reject); + delay(1); /* wait until busy is clear */ for (i = 0; i < 10000; i++) { - val = bus_space_read_4(sc->sc_iot, sc->sc_ioh, - BCW_SBTMSTATEHI); + val = BCW_READ(sc, BCW_SBTMSTATEHI); + if (!(val & SBTMH_BUSY)) break; delay(10); @@ -1431,21 +1386,22 @@ bcw_reset(struct bcw_softc *sc) printf("%s: while resetting core, busy did " "not clear\n", sc->sc_dev.dv_xname); - val = bus_space_read_4(sc->sc_iot, sc->sc_ioh, - BCW_CIR_SBID_LO); + val = BCW_READ(sc, BCW_CIR_SBID_LO); + if (val & BCW_CIR_SBID_LO_INITIATOR) { - sbval = bus_space_read_4(sc->sc_iot, sc->sc_ioh, - BCW_SBIMSTATE); - bus_space_write_4(sc->sc_iot, sc->sc_ioh, - BCW_SBIMSTATE, sbval | SBIM_REJECT); - sbval = bus_space_read_4(sc->sc_iot, sc->sc_ioh, + sbval = BCW_READ(sc, BCW_SBIMSTATE); + BCW_WRITE(sc, BCW_SBIMSTATE, sbval | + SBIM_REJECT); + + sbval = BCW_READ(sc, BCW_SBIMSTATE); + delay(1); /* wait until busy is clear */ for (i = 0; i < 10000; i++) { - val = bus_space_read_4(sc->sc_iot, - sc->sc_ioh, BCW_SBTMSTATEHI); + val = BCW_READ(sc, BCW_SBTMSTATEHI); + if (!(val & SBTMH_BUSY)) break; delay(10); @@ -1457,28 +1413,27 @@ bcw_reset(struct bcw_softc *sc) } /* end initiator check */ /* set reset and reject while enabling the clocks */ - bus_space_write_4(sc->sc_iot, sc->sc_ioh, - BCW_SBTMSTATELOW, SBTML_FGC | SBTML_CLK | + BCW_WRITE(sc, BCW_SBTMSTATELOW, SBTML_FGC | SBTML_CLK | SBTML_RESET | SBTML_80211FLAG | SBTML_80211PHY); - val = bus_space_read_4(sc->sc_iot, sc->sc_ioh, - BCW_SBTMSTATELOW); + val = BCW_READ(sc, BCW_SBTMSTATELOW); + delay(10); - val = bus_space_read_4(sc->sc_iot, sc->sc_ioh, - BCW_CIR_SBID_LO); + val = BCW_READ(sc, BCW_CIR_SBID_LO); + if (val & BCW_CIR_SBID_LO_INITIATOR) { - sbval = bus_space_read_4(sc->sc_iot, sc->sc_ioh, - BCW_SBIMSTATE); - bus_space_write_4(sc->sc_iot, sc->sc_ioh, - BCW_SBIMSTATE, sbval & ~SBIM_REJECT); - sbval = bus_space_read_4(sc->sc_iot, sc->sc_ioh, - BCW_SBIMSTATE); + sbval = BCW_READ(sc, BCW_SBIMSTATE); + + BCW_WRITE(sc, BCW_SBIMSTATE, sbval & + ~SBIM_REJECT); + + sbval = BCW_READ(sc, BCW_SBIMSTATE); delay(1); /* wait until busy is clear */ for (i = 0; i < 10000; i++) { - val = bus_space_read_4(sc->sc_iot, - sc->sc_ioh, BCW_SBTMSTATEHI); + val = BCW_READ(sc, BCW_SBTMSTATEHI); + if (!(val & SBTMH_BUSY)) break; delay(10); @@ -1489,8 +1444,7 @@ bcw_reset(struct bcw_softc *sc) sc->sc_dev.dv_xname); } /* end initiator check */ - bus_space_write_4(sc->sc_iot, sc->sc_ioh, - BCW_SBTMSTATELOW, SBTML_RESET | reject | + BCW_WRITE(sc, BCW_SBTMSTATELOW, SBTML_RESET | reject | SBTML_80211FLAG | SBTML_80211PHY); delay(1); } @@ -1500,42 +1454,43 @@ disabled: /* This is enabling/resetting the core */ /* enable clock */ - bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_SBTMSTATELOW, + BCW_WRITE(sc, BCW_SBTMSTATELOW, SBTML_FGC | SBTML_CLK | SBTML_RESET | SBTML_80211FLAG | SBTML_80211PHY ); - val = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_SBTMSTATELOW); + val = BCW_READ(sc, BCW_SBTMSTATELOW); delay(1); /* clear any error bits that may be on */ - val = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_SBTMSTATEHI); + val = BCW_READ(sc, BCW_SBTMSTATEHI); if (val & SBTMH_SERR) - 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); + BCW_WRITE(sc, BCW_SBTMSTATEHI, 0); + val = BCW_READ(sc, BCW_SBIMSTATE); if (val & (SBIM_INBANDERR | SBIM_TIMEOUT)) - bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_SBIMSTATE, + BCW_WRITE(sc, BCW_SBIMSTATE, val & ~(SBIM_INBANDERR | SBIM_TIMEOUT)); - + /* clear reset and allow it to propagate throughout the core */ - bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_SBTMSTATELOW, + BCW_WRITE(sc, BCW_SBTMSTATELOW, SBTML_FGC | SBTML_CLK | SBTML_80211FLAG | SBTML_80211PHY ); - val = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_SBTMSTATELOW); + val = BCW_READ(sc, BCW_SBTMSTATELOW); delay(1); /* leave clock enabled */ - bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_SBTMSTATELOW, - SBTML_CLK | SBTML_80211FLAG | SBTML_80211PHY); - val = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_SBTMSTATELOW); + BCW_WRITE(sc, BCW_SBTMSTATELOW, SBTML_CLK | SBTML_80211FLAG | + SBTML_80211PHY); + + val = BCW_READ(sc, BCW_SBTMSTATELOW); delay(1); /* XXX update PHYConnected to requested value */ /* Clear Baseband Attenuation, might only work for B/G rev < 0 */ - bus_space_write_2(sc->sc_iot, sc->sc_ioh, BCW_RADIO_BASEBAND, 0); + BCW_WRITE16(sc, BCW_RADIO_BASEBAND, 0); /* Set 0x400 in the MMIO StatusBitField reg */ - sbval=bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_SBF); + sbval = BCW_READ(sc, BCW_SBF); sbval |= BCW_SBF_400_MAGIC; - bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_SBF, sbval); + BCW_WRITE(sc, BCW_SBF, sbval); /* XXX Clear saved interrupt status for DMA controllers */ @@ -1550,44 +1505,35 @@ bcw_set_filter(struct ifnet *ifp) 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); + BCW_WRITE(sc, BCW_RX_CTL, BCW_READ(sc, 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); + BCW_WRITE(sc, BCW_RX_CTL, BCW_READ(sc, 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); + BCW_WRITE(sc, + BCW_RX_CTL, BCW_READ(sc, 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); + BCW_WRITE(sc, + BCW_RX_CTL, BCW_READ(sc, BCW_RX_CTL) | ERC_DB); + sc->bcw_bhandle, /* disable the filter */ - bus_space_write_4(sc->bcw_btag, sc->bcw_bhandle, BCW_FILT_CTL, - 0); + BCW_WRITE(sc, BCW_FILT_CTL, 0); /* add our own address */ // 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); + BCW_WRITE(sc, BCW_RX_CTL, BCW_READ(sc, 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); + BCW_WRITE(sc, BCW_FILT_CTL, BCW_READ(sc, BCW_FILT_CTL) | 1); } #endif } @@ -1684,36 +1630,32 @@ bcw_validatechipaccess(struct bcw_softc *sc) */ /* Backup SHM uCode Revision before we clobber it */ - bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_SHM_CONTROL, - (BCW_SHM_CONTROL_SHARED << 16) + 0); - save = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_SHM_DATA); + BCW_WRITE(sc, BCW_SHM_CONTROL, (BCW_SHM_CONTROL_SHARED << 16) + 0); + save = BCW_READ(sc, BCW_SHM_DATA); /* write test value */ - 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); + BCW_WRITE(sc, BCW_SHM_CONTROL, (BCW_SHM_CONTROL_SHARED << 16) + 0); + BCW_WRITE(sc, BCW_SHM_DATA, 0xaa5555aa); /* Read it back */ - 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); + BCW_WRITE(sc, BCW_SHM_CONTROL, (BCW_SHM_CONTROL_SHARED << 16) + 0); + + val = BCW_READ(sc, BCW_SHM_DATA); if (val != 0xaa5555aa) return (1); /* write 2nd test value */ - 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); + BCW_WRITE(sc, BCW_SHM_CONTROL, (BCW_SHM_CONTROL_SHARED << 16) + 0); + BCW_WRITE(sc, BCW_SHM_DATA, 0x55aaaa55); /* Read it back */ - 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); + BCW_WRITE(sc, BCW_SHM_CONTROL, (BCW_SHM_CONTROL_SHARED << 16) + 0); + + val = BCW_READ(sc, BCW_SHM_DATA); if (val != 0x55aaaa55) return 2; /* Restore the saved value now that we're done */ - 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); + BCW_WRITE(sc, BCW_SHM_CONTROL, (BCW_SHM_CONTROL_SHARED << 16) + 0); + BCW_WRITE(sc, BCW_SHM_DATA, save); if (sc->sc_corerev >= 3) { /* do some test writes and reads against the TSF */ @@ -1723,18 +1665,18 @@ bcw_validatechipaccess(struct bcw_softc *sc) * say that we're reading/writing silly places, so these regs * are not quite documented yet */ - 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); + BCW_WRITE16(sc, 0x18c, 0xaaaa); + BCW_WRITE(sc, 0x18c, 0xccccbbbb); + val = BCW_READ16(sc, 0x604); if (val != 0xbbbb) return 3; - val = bus_space_read_2(sc->sc_iot, sc->sc_ioh, 0x606); + val = BCW_READ16(sc, 0x606); if (val != 0xcccc) return 4; /* re-clear the TSF since we just filled it with garbage */ - bus_space_write_4(sc->sc_iot, sc->sc_ioh, 0x18c, 0x0); + BCW_WRITE(sc, 0x18c, 0x0); } /* Check the Status Bit Field for some unknown bits */ - val = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_SBF); + val = BCW_READ(sc, BCW_SBF); if ((val | 0x80000000) != 0x80000400 ) { printf("%s: Warning, SBF is 0x%x, expected 0x80000400\n", sc->sc_dev.dv_xname, val); @@ -1742,7 +1684,7 @@ bcw_validatechipaccess(struct bcw_softc *sc) //return (5); } /* Verify there are no interrupts active on the core */ - val = bus_space_read_4(sc->sc_iot, sc->sc_ioh, BCW_GIR); + val = BCW_READ(sc, BCW_GIR); if (val != 0) { DPRINTF(("Failed Pending Interrupt test with val=0x%x\n", val)); return (6); @@ -1868,8 +1810,7 @@ bcw_alloc_rx_ring(struct bcw_softc *sc, struct bcw_rx_ring *ring, int count) goto fail; } - bus_space_write_4(sc->sc_iot, sc->sc_ioh, BCW_DMA_RXADDR, - ring->physaddr + 0x40000000); + BCW_WRITE(sc, BCW_DMA_RXADDR, ring->physaddr + 0x40000000); /* * Pre-allocate Rx buffers and populate Rx ring. @@ -2020,8 +1961,7 @@ bcw_alloc_tx_ring(struct bcw_softc *sc, struct bcw_tx_ring *ring, 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); + BCW_WRITE(sc, BCW_DMA_TXADDR, ring->physaddr + 0x40000000); ring->data = malloc(count * sizeof(struct bcw_tx_data), M_DEVBUF, M_NOWAIT); diff --git a/sys/dev/ic/bcwreg.h b/sys/dev/ic/bcwreg.h index 19b17661ad1..aba45e6cff8 100644 --- a/sys/dev/ic/bcwreg.h +++ b/sys/dev/ic/bcwreg.h @@ -1,4 +1,4 @@ -/* $OpenBSD: bcwreg.h,v 1.5 2006/12/06 19:21:45 mglocker Exp $ */ +/* $OpenBSD: bcwreg.h,v 1.6 2006/12/27 14:05:57 jsg Exp $ */ /* * Copyright (c) 2006 Jon Simola <jsimola@gmail.com> @@ -323,3 +323,11 @@ #define BCW_PHY_TYPEG 0x2 /* 802.11g PHY */ #define BCW_PHY_TYPEN 0x4 /* 802.11n PHY */ +#define BCW_READ16(sc, reg) \ + bus_space_read_2((sc)->sc_iot, (sc)->sc_ioh, (reg)) +#define BCW_READ(sc, reg) \ + bus_space_read_4((sc)->sc_iot, (sc)->sc_ioh, (reg)) +#define BCW_WRITE16(sc, reg, val) \ + bus_space_write_2((sc)->sc_iot, (sc)->sc_ioh, (reg), (val)) +#define BCW_WRITE(sc, reg, val) \ + bus_space_write_4((sc)->sc_iot, (sc)->sc_ioh, (reg), (val)) |