summaryrefslogtreecommitdiff
path: root/sys/dev
diff options
context:
space:
mode:
authorDamien Bergamini <damien@cvs.openbsd.org>2006-05-17 19:50:36 +0000
committerDamien Bergamini <damien@cvs.openbsd.org>2006-05-17 19:50:36 +0000
commitd4f194a03060a14434ffd84acfef9f900c752b48 (patch)
treeb679fdf332857863fc6c6faf3351828f213ad26c /sys/dev
parent12be27a6bfe8e288d68009b7d31dcd947e60c007 (diff)
mega-commit of unrelated changes:
- factor out contiguous DMA allocations (the same code was duplicated in several places and was sometimes incorrect) - s/EIO/ETIMEDOUT where it makes sense - s/memset/bzero/g - don't always bzero the ring descriptors - scan channels 1-14 instead of 1-13 - remove the auhmode stuff since mgt frames are sent by net80211 - remove the SCANALL flag since the f/w notifies us when it switches to another channel - don't re-enable interrupts on f/w panics - KASSERT that commands fit in a descriptor
Diffstat (limited to 'sys/dev')
-rw-r--r--sys/dev/pci/if_wpi.c297
-rw-r--r--sys/dev/pci/if_wpivar.h23
2 files changed, 118 insertions, 202 deletions
diff --git a/sys/dev/pci/if_wpi.c b/sys/dev/pci/if_wpi.c
index aa271402989..1a032d13f72 100644
--- a/sys/dev/pci/if_wpi.c
+++ b/sys/dev/pci/if_wpi.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_wpi.c,v 1.2 2006/05/16 05:57:44 miod Exp $ */
+/* $OpenBSD: if_wpi.c,v 1.3 2006/05/17 19:50:35 damien Exp $ */
/*-
* Copyright (c) 2006
@@ -91,6 +91,9 @@ int wpi_match(struct device *, void *, void *);
void wpi_attach(struct device *, struct device *, void *);
int wpi_detach(struct device *, int);
void wpi_power(int, void *);
+int wpi_dma_contig_alloc(struct wpi_softc *, struct wpi_dma_info *,
+ void **, bus_size_t, bus_size_t, int);
+void wpi_dma_contig_free(struct wpi_softc *, struct wpi_dma_info *);
int wpi_alloc_shared(struct wpi_softc *);
void wpi_free_shared(struct wpi_softc *);
int wpi_alloc_rx_ring(struct wpi_softc *, struct wpi_rx_ring *);
@@ -266,7 +269,6 @@ wpi_attach(struct device *parent, struct device *self, void *aux)
/* set device capabilities */
ic->ic_caps =
- IEEE80211_C_SCANALL | /* h/w scan */
IEEE80211_C_WEP | /* s/w WEP */
IEEE80211_C_MONITOR | /* monitor mode supported */
IEEE80211_C_TXPMGT | /* tx power management */
@@ -410,116 +412,113 @@ wpi_power(int why, void *arg)
}
}
-/*
- * Allocate a shared page between host and NIC.
- */
int
-wpi_alloc_shared(struct wpi_softc *sc)
+wpi_dma_contig_alloc(struct wpi_softc *sc, struct wpi_dma_info *dma,
+ void **kvap, bus_size_t size, bus_size_t alignment, int flags)
{
int nsegs, error;
- error = bus_dmamap_create(sc->sc_dmat, sizeof (struct wpi_shared), 1,
- sizeof (struct wpi_shared), 0, BUS_DMA_NOWAIT, &sc->shmap);
+ dma->size = size;
+
+ error = bus_dmamap_create(sc->sc_dmat, dma->size, 1, dma->size, 0,
+ flags, &dma->map);
if (error != 0) {
- printf("%s: could not create shared area DMA map\n",
- sc->sc_dev.dv_xname);
+ printf("%s: could not create DMA map\n", sc->sc_dev.dv_xname);
goto fail;
}
- /* must be aligned on a 4K-page boundary */
- error = bus_dmamem_alloc(sc->sc_dmat, sizeof (struct wpi_shared),
- PAGE_SIZE, 0, &sc->shseg, 1, &nsegs, BUS_DMA_NOWAIT);
+ error = bus_dmamem_alloc(sc->sc_dmat, dma->size, alignment, 0,
+ &dma->seg, 1, &nsegs, flags);
if (error != 0) {
- printf("%s: could not allocate shared area DMA memory\n",
+ printf("%s: could not allocate DMA memory\n",
sc->sc_dev.dv_xname);
goto fail;
}
- error = bus_dmamem_map(sc->sc_dmat, &sc->shseg, nsegs,
- sizeof (struct wpi_shared), (caddr_t *)&sc->shared,
- BUS_DMA_NOWAIT);
+ error = bus_dmamem_map(sc->sc_dmat, &dma->seg, 1, dma->size,
+ &dma->vaddr, flags);
if (error != 0) {
- printf("%s: could not map shared area DMA memory\n",
- sc->sc_dev.dv_xname);
+ printf("%s: could not map DMA memory\n", sc->sc_dev.dv_xname);
goto fail;
}
- error = bus_dmamap_load(sc->sc_dmat, sc->shmap, sc->shared,
- sizeof (struct wpi_shared), NULL, BUS_DMA_NOWAIT);
+ error = bus_dmamap_load_raw(sc->sc_dmat, dma->map, &dma->seg, 1,
+ dma->size, flags);
if (error != 0) {
- printf("%s: could not load shared area DMA map\n",
- sc->sc_dev.dv_xname);
+ printf("%s: could not load DMA memory\n", sc->sc_dev.dv_xname);
goto fail;
}
- bzero(sc->shared, sizeof (struct wpi_shared));
+ bzero(dma->vaddr, dma->size);
+
+ dma->paddr = dma->map->dm_segs[0].ds_addr;
+ *kvap = dma->vaddr;
return 0;
-fail: wpi_free_shared(sc);
+fail: wpi_dma_contig_free(sc, dma);
+ return error;
+}
+
+void
+wpi_dma_contig_free(struct wpi_softc *sc, struct wpi_dma_info *dma)
+{
+ if (dma->map != NULL) {
+ if (dma->vaddr != NULL) {
+ bus_dmamap_unload(sc->sc_dmat, dma->map);
+ bus_dmamem_unmap(sc->sc_dmat, dma->vaddr, dma->size);
+ bus_dmamem_free(sc->sc_dmat, &dma->seg, 1);
+ dma->vaddr = NULL;
+ }
+ bus_dmamap_destroy(sc->sc_dmat, dma->map);
+ dma->map = NULL;
+ }
+}
+
+/*
+ * Allocate a shared page between host and NIC.
+ */
+int
+wpi_alloc_shared(struct wpi_softc *sc)
+{
+ int error;
+
+ /* must be aligned on a 4K-page boundary */
+ error = wpi_dma_contig_alloc(sc, &sc->shared_dma,
+ (void **)&sc->shared, sizeof (struct wpi_shared), PAGE_SIZE,
+ BUS_DMA_NOWAIT);
+ if (error != 0) {
+ printf("%s: could not allocate shared area DMA memory\n",
+ sc->sc_dev.dv_xname);
+ }
+
return error;
}
void
wpi_free_shared(struct wpi_softc *sc)
{
- if (sc->shared != NULL) {
- bus_dmamap_unload(sc->sc_dmat, sc->shmap);
- bus_dmamem_unmap(sc->sc_dmat, (caddr_t)sc->shared,
- sizeof (struct wpi_shared));
- bus_dmamem_free(sc->sc_dmat, &sc->shseg, 1);
- }
- if (sc->shmap != NULL)
- bus_dmamap_destroy(sc->sc_dmat, sc->shmap);
+ wpi_dma_contig_free(sc, &sc->shared_dma);
}
int
wpi_alloc_rx_ring(struct wpi_softc *sc, struct wpi_rx_ring *ring)
{
struct wpi_rx_data *data;
- int i, nsegs, error;
+ int i, error;
ring->cur = 0;
- error = bus_dmamap_create(sc->sc_dmat,
- WPI_RX_RING_COUNT * sizeof (struct wpi_rx_desc), 1,
- WPI_RX_RING_COUNT * sizeof (struct wpi_rx_desc), 0, BUS_DMA_NOWAIT,
- &ring->map);
- if (error != 0) {
- printf("%s: could not create rx ring DMA map\n",
- sc->sc_dev.dv_xname);
- goto fail;
- }
-
- error = bus_dmamem_alloc(sc->sc_dmat,
+ error = wpi_dma_contig_alloc(sc, &ring->desc_dma,
+ (void **)&ring->desc,
WPI_RX_RING_COUNT * sizeof (struct wpi_rx_desc),
- WPI_RING_DMA_ALIGN, 0, &ring->seg, 1, &nsegs, BUS_DMA_NOWAIT);
+ WPI_RING_DMA_ALIGN, BUS_DMA_NOWAIT);
if (error != 0) {
printf("%s: could not allocate rx ring DMA memory\n",
sc->sc_dev.dv_xname);
goto fail;
}
- error = bus_dmamem_map(sc->sc_dmat, &ring->seg, nsegs,
- WPI_RX_RING_COUNT * sizeof (struct wpi_rx_desc),
- (caddr_t *)&ring->desc, BUS_DMA_NOWAIT);
- if (error != 0) {
- printf("%s: could not map rx ring DMA memory\n",
- sc->sc_dev.dv_xname);
- goto fail;
- }
-
- error = bus_dmamap_load(sc->sc_dmat, ring->map, ring->desc,
- WPI_RX_RING_COUNT * sizeof (struct wpi_rx_desc), NULL,
- BUS_DMA_NOWAIT);
- if (error != 0) {
- printf("%s: could not load rx ring DMA map\n",
- sc->sc_dev.dv_xname);
- goto fail;
- }
-
- bzero(ring->desc, WPI_RX_RING_COUNT * sizeof (struct wpi_rx_desc));
-
/*
* Allocate Rx buffers.
*/
@@ -598,14 +597,7 @@ wpi_free_rx_ring(struct wpi_softc *sc, struct wpi_rx_ring *ring)
struct wpi_rx_data *data;
int i;
- if (ring->desc != NULL) {
- bus_dmamap_unload(sc->sc_dmat, ring->map);
- bus_dmamem_unmap(sc->sc_dmat, (caddr_t)ring->desc,
- WPI_RX_RING_COUNT * sizeof (struct wpi_rx_desc));
- bus_dmamem_free(sc->sc_dmat, &ring->seg, 1);
- }
- if (ring->map != NULL)
- bus_dmamap_destroy(sc->sc_dmat, ring->map);
+ wpi_dma_contig_free(sc, &ring->desc_dma);
for (i = 0; i < WPI_RX_RING_COUNT; i++) {
data = &ring->data[i];
@@ -623,92 +615,33 @@ wpi_alloc_tx_ring(struct wpi_softc *sc, struct wpi_tx_ring *ring, int count,
int qid)
{
struct wpi_tx_data *data;
- int i, nsegs, error;
+ int i, error;
ring->qid = qid;
ring->count = count;
ring->queued = 0;
ring->cur = 0;
- error = bus_dmamap_create(sc->sc_dmat,
- count * sizeof (struct wpi_tx_desc), 1,
- count * sizeof (struct wpi_tx_desc), 0, BUS_DMA_NOWAIT,
- &ring->map);
- if (error != 0) {
- printf("%s: could not create tx ring DMA map\n",
- sc->sc_dev.dv_xname);
- goto fail;
- }
-
- error = bus_dmamem_alloc(sc->sc_dmat,
- count * sizeof (struct wpi_tx_desc), WPI_RING_DMA_ALIGN, 0,
- &ring->seg, 1, &nsegs, BUS_DMA_NOWAIT);
+ error = wpi_dma_contig_alloc(sc, &ring->desc_dma,
+ (void **)&ring->desc, count * sizeof (struct wpi_tx_desc),
+ WPI_RING_DMA_ALIGN, BUS_DMA_NOWAIT);
if (error != 0) {
printf("%s: could not allocate tx ring DMA memory\n",
sc->sc_dev.dv_xname);
goto fail;
}
- error = bus_dmamem_map(sc->sc_dmat, &ring->seg, nsegs,
- count * sizeof (struct wpi_tx_desc), (caddr_t *)&ring->desc,
- BUS_DMA_NOWAIT);
- if (error != 0) {
- printf("%s: could not map tx ring DMA memory\n",
- sc->sc_dev.dv_xname);
- goto fail;
- }
-
- error = bus_dmamap_load(sc->sc_dmat, ring->map, ring->desc,
- count * sizeof (struct wpi_tx_desc), NULL, BUS_DMA_NOWAIT);
- if (error != 0) {
- printf("%s: could not load tx ring DMA map\n",
- sc->sc_dev.dv_xname);
- goto fail;
- }
-
- bzero(ring->desc, count * sizeof (struct wpi_tx_desc));
-
/* update shared page with ring's base address */
- sc->shared->txbase[qid] = htole32(ring->map->dm_segs[0].ds_addr);
-
- error = bus_dmamap_create(sc->sc_dmat,
- count * sizeof (struct wpi_tx_cmd), 1,
- count * sizeof (struct wpi_tx_cmd), 0, BUS_DMA_NOWAIT,
- &ring->cmd_map);
- if (error != 0) {
- printf("%s: could not create tx cmd DMA map\n",
- sc->sc_dev.dv_xname);
- goto fail;
- }
+ sc->shared->txbase[qid] = htole32(ring->desc_dma.paddr);
- error = bus_dmamem_alloc(sc->sc_dmat,
- count * sizeof (struct wpi_tx_cmd), PAGE_SIZE, 0, &ring->cmd_seg,
- 1, &nsegs, BUS_DMA_NOWAIT);
+ error = wpi_dma_contig_alloc(sc, &ring->cmd_dma, (void **)&ring->cmd,
+ count * sizeof (struct wpi_tx_cmd), 4, BUS_DMA_NOWAIT);
if (error != 0) {
printf("%s: could not allocate tx cmd DMA memory\n",
sc->sc_dev.dv_xname);
goto fail;
}
- error = bus_dmamem_map(sc->sc_dmat, &ring->cmd_seg, nsegs,
- count * sizeof (struct wpi_tx_cmd), (caddr_t *)&ring->cmd,
- BUS_DMA_NOWAIT);
- if (error != 0) {
- printf("%s: could not map tx cmd DMA memory\n",
- sc->sc_dev.dv_xname);
- goto fail;
- }
-
- error = bus_dmamap_load(sc->sc_dmat, ring->cmd_map, ring->cmd,
- count * sizeof (struct wpi_tx_cmd), NULL, BUS_DMA_NOWAIT);
- if (error != 0) {
- printf("%s: could not load tx ring DMA map\n",
- sc->sc_dev.dv_xname);
- goto fail;
- }
-
- bzero(ring->cmd, count * sizeof (struct wpi_tx_cmd));
-
ring->data = malloc(count * sizeof (struct wpi_tx_data), M_DEVBUF,
M_NOWAIT);
if (ring->data == NULL) {
@@ -780,23 +713,8 @@ wpi_free_tx_ring(struct wpi_softc *sc, struct wpi_tx_ring *ring)
struct wpi_tx_data *data;
int i;
- if (ring->desc != NULL) {
- bus_dmamap_unload(sc->sc_dmat, ring->map);
- bus_dmamem_unmap(sc->sc_dmat, (caddr_t)ring->desc,
- WPI_RX_RING_COUNT * sizeof (struct wpi_rx_desc));
- bus_dmamem_free(sc->sc_dmat, &ring->seg, 1);
- }
- if (ring->map != NULL)
- bus_dmamap_destroy(sc->sc_dmat, ring->map);
-
- if (ring->cmd != NULL) {
- bus_dmamap_unload(sc->sc_dmat, ring->cmd_map);
- bus_dmamem_unmap(sc->sc_dmat, (caddr_t)ring->cmd,
- ring->count * sizeof (struct wpi_tx_cmd));
- bus_dmamem_free(sc->sc_dmat, &ring->cmd_seg, 1);
- }
- if (ring->cmd_map != NULL)
- bus_dmamap_destroy(sc->sc_dmat, ring->cmd_map);
+ wpi_dma_contig_free(sc, &ring->desc_dma);
+ wpi_dma_contig_free(sc, &ring->cmd_dma);
if (ring->data != NULL) {
for (i = 0; i < ring->count; i++) {
@@ -936,6 +854,10 @@ wpi_mem_write_region_4(struct wpi_softc *sc, uint16_t addr,
wpi_mem_write(sc, addr, *data);
}
+/*
+ * Read 16 bits from the EEPROM. We access EEPROM through the MAC instead of
+ * using the traditional bit-bang method.
+ */
uint16_t
wpi_read_prom_word(struct wpi_softc *sc, uint32_t addr)
{
@@ -1078,7 +1000,7 @@ wpi_load_firmware(struct wpi_softc *sc, uint32_t target, const char *fw,
if (ntries == 100) {
printf("%s: timeout transferring firmware\n",
sc->sc_dev.dv_xname);
- error = EIO;
+ error = ETIMEDOUT;
}
WPI_WRITE(sc, WPI_TX_CREDIT(6), 0);
@@ -1121,7 +1043,7 @@ wpi_rx_intr(struct wpi_softc *sc, struct wpi_rx_desc *desc,
tail = (struct wpi_rx_tail *)((caddr_t)(head + 1) + letoh16(head->len));
DPRINTFN(4, ("rx intr: idx=%d len=%d stat len=%d rssi=%d rate=%x "
- "chan=%d tstamp=%lld\n", ring->cur, letoh32(desc->len),
+ "chan=%d tstamp=%llu\n", ring->cur, letoh32(desc->len),
letoh16(head->len), (int8_t)stat->rssi, head->rate, head->chan,
letoh64(tail->tstamp)));
@@ -1231,7 +1153,10 @@ wpi_tx_intr(struct wpi_softc *sc, struct wpi_rx_desc *desc,
ieee80211_release_node(ic, txdata->ni);
txdata->ni = NULL;
- ifp->if_opackets++;
+ if ((letoh32(stat->status) & 0xff) != 1)
+ ifp->if_oerrors++;
+ else
+ ifp->if_opackets++;
ring->queued--;
sc->sc_tx_timer = 0;
@@ -1305,6 +1230,7 @@ wpi_notif_intr(struct wpi_softc *sc)
DPRINTF(("state changed to %x\n", letoh32(*status)));
if (letoh32(*status) & 1) {
+ /* the radio button has to be pushed */
printf("%s: Radio transmitter is off\n",
sc->sc_dev.dv_xname);
}
@@ -1317,6 +1243,9 @@ wpi_notif_intr(struct wpi_softc *sc)
DPRINTFN(2, ("scanning channel %d status %x\n",
scan->chan, letoh32(scan->status)));
+
+ /* fix current channel */
+ ic->ic_bss->ni_chan = &ic->ic_channels[scan->chan];
break;
}
case WPI_STOP_SCAN:
@@ -1355,7 +1284,7 @@ wpi_intr(void *arg)
printf("%s: fatal firmware error\n", sc->sc_dev.dv_xname);
ifp->if_flags &= ~IFF_UP;
wpi_stop(ifp, 1);
- r = 0; /* don't process any other interrupt */
+ return 1;
}
if (r & WPI_RX_INTR)
@@ -1523,19 +1452,17 @@ wpi_tx_data(struct wpi_softc *sc, struct mbuf *m0, struct ieee80211_node *ni,
ring->qid, ring->cur, m0->m_pkthdr.len, data->map->dm_nsegs));
/* first scatter/gather segment is used by the tx data command */
- memset(desc, 0, sizeof (struct wpi_tx_desc));
- desc->segs[0].physaddr = htole32(ring->cmd_map->dm_segs[0].ds_addr +
+ desc->flags = htole32(WPI_PAD32(m0->m_pkthdr.len) << 28 |
+ (1 + data->map->dm_nsegs) << 24);
+ desc->segs[0].physaddr = htole32(ring->cmd_dma.paddr +
ring->cur * sizeof (struct wpi_tx_cmd));
- desc->segs[0].len = htole32(
- (4 + sizeof (struct wpi_cmd_data) + 3) & ~3);
+ desc->segs[0].len = htole32(4 + sizeof (struct wpi_cmd_data));
for (i = 1; i <= data->map->dm_nsegs; i++) {
desc->segs[i].physaddr =
htole32(data->map->dm_segs[i - 1].ds_addr);
desc->segs[i].len =
htole32(data->map->dm_segs[i - 1].ds_len);
}
- desc->flags = htole32(WPI_PAD32(m0->m_pkthdr.len) << 28 |
- (1 + data->map->dm_nsegs) << 24);
ring->queued++;
@@ -1677,18 +1604,6 @@ wpi_ioctl(struct ifnet *ifp, u_long cmd, caddr_t data)
error = 0;
break;
- case SIOCG80211AUTH:
- ((struct ieee80211_auth *)data)->i_authtype = sc->authmode;
- break;
-
- case SIOCS80211AUTH:
- /* only super-user can do that! */
- if ((error = suser(curproc, 0)) != 0)
- break;
-
- sc->authmode = ((struct ieee80211_auth *)data)->i_authtype;
- break;
-
default:
error = ieee80211_ioctl(ifp, cmd, data);
}
@@ -1714,6 +1629,8 @@ wpi_cmd(struct wpi_softc *sc, int code, const void *buf, int size, int async)
struct wpi_tx_desc *desc;
struct wpi_tx_cmd *cmd;
+ KASSERT(size <= sizeof cmd->data);
+
desc = &ring->desc[ring->cur];
cmd = &ring->cmd[ring->cur];
@@ -1723,9 +1640,8 @@ wpi_cmd(struct wpi_softc *sc, int code, const void *buf, int size, int async)
cmd->idx = ring->cur;
bcopy(buf, cmd->data, size);
- bzero(desc, sizeof (struct wpi_tx_desc));
desc->flags = htole32(WPI_PAD32(size) << 28 | 1 << 24);
- desc->segs[0].physaddr = htole32(ring->cmd_map->dm_segs[0].ds_addr +
+ desc->segs[0].physaddr = htole32(ring->cmd_dma.paddr +
ring->cur * sizeof (struct wpi_tx_cmd));
desc->segs[0].len = htole32(4 + size);
@@ -1804,7 +1720,7 @@ wpi_enable_tsf(struct wpi_softc *sc, struct ieee80211_node *ni)
{
struct wpi_cmd_tsf tsf;
- memset(&tsf, 0, sizeof tsf);
+ bzero(&tsf, sizeof tsf);
tsf.tstamp = 0;
tsf.bintval = htole16(ni->ni_intval);
tsf.binitval = htole32(102400); /* XXX */
@@ -1837,7 +1753,7 @@ wpi_auth(struct wpi_softc *sc)
}
/* add default node */
- memset(&node, 0, sizeof node);
+ bzero(&node, sizeof node);
IEEE80211_ADDR_COPY(node.bssid, ni->ni_bssid);
node.id = WPI_ID_BSSID;
node.rate = 10; /* 1Mb/s */
@@ -1903,9 +1819,9 @@ wpi_scan(struct wpi_softc *sc)
cmd->idx = ring->cur;
hdr = (struct wpi_scan_hdr *)cmd->data;
- memset(hdr, 0, sizeof (struct wpi_scan_hdr));
+ bzero(hdr, sizeof (struct wpi_scan_hdr));
hdr->first = 1;
- hdr->nchan = 13;
+ hdr->nchan = 14;
hdr->len = hdr->nchan * sizeof (struct wpi_scan_chan);
hdr->quiet = htole16(5);
hdr->threshold = htole16(1);
@@ -2195,7 +2111,6 @@ wpi_init(struct ifnet *ifp)
u_char *fw;
size_t size;
uint32_t tmp;
- bus_addr_t pshared;
int i, qid, ntries, error;
wpi_reset(sc);
@@ -2210,13 +2125,11 @@ wpi_init(struct ifnet *ifp)
wpi_power_up(sc);
wpi_hw_config(sc);
- pshared = sc->shmap->dm_segs[0].ds_addr;
-
/* init Rx ring */
wpi_mem_lock(sc);
- WPI_WRITE(sc, WPI_RX_BASE, sc->rxq.map->dm_segs[0].ds_addr);
+ WPI_WRITE(sc, WPI_RX_BASE, sc->rxq.desc_dma.paddr);
WPI_WRITE(sc, WPI_RX_RIDX_PTR,
- (uint32_t)&((struct wpi_shared *)pshared)->next);
+ (uint32_t)&((struct wpi_shared *)sc->shared_dma.paddr)->next);
WPI_WRITE(sc, WPI_RX_WIDX, (WPI_RX_RING_COUNT - 1) & ~7);
WPI_WRITE(sc, WPI_RX_CONFIG, 0xa9601010);
wpi_mem_unlock(sc);
@@ -2231,7 +2144,7 @@ wpi_init(struct ifnet *ifp)
wpi_mem_write(sc, WPI_MEM_MAGIC4, 4);
wpi_mem_write(sc, WPI_MEM_MAGIC5, 5);
- WPI_WRITE(sc, WPI_TX_BASE_PTR, pshared);
+ WPI_WRITE(sc, WPI_TX_BASE_PTR, sc->shared_dma.paddr);
WPI_WRITE(sc, WPI_MSG_CONFIG, 0xffff05a5);
for (qid = 0; qid < 6; qid++) {
@@ -2329,7 +2242,7 @@ wpi_init(struct ifnet *ifp)
if (ntries == 1000) {
printf("%s: timeout waiting for thermal sensors calibration\n",
sc->sc_dev.dv_xname);
- error = EIO;
+ error = ETIMEDOUT;
goto fail1;
}
DPRINTF(("temperature %d\n", (int)WPI_READ(sc, WPI_TEMPERATURE)));
diff --git a/sys/dev/pci/if_wpivar.h b/sys/dev/pci/if_wpivar.h
index 29dd6ee84df..ebe83eb20c7 100644
--- a/sys/dev/pci/if_wpivar.h
+++ b/sys/dev/pci/if_wpivar.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_wpivar.h,v 1.1 2006/05/14 19:00:48 damien Exp $ */
+/* $OpenBSD: if_wpivar.h,v 1.2 2006/05/17 19:50:35 damien Exp $ */
/*-
* Copyright (c) 2006
@@ -41,6 +41,14 @@ struct wpi_tx_radiotap_header {
((1 << IEEE80211_RADIOTAP_FLAGS) | \
(1 << IEEE80211_RADIOTAP_CHANNEL))
+struct wpi_dma_info {
+ bus_dmamap_t map;
+ bus_dma_segment_t seg;
+ bus_addr_t paddr;
+ caddr_t vaddr;
+ bus_size_t size;
+};
+
struct wpi_tx_data {
bus_dmamap_t map;
struct mbuf *m;
@@ -48,10 +56,8 @@ struct wpi_tx_data {
};
struct wpi_tx_ring {
- bus_dmamap_t map;
- bus_dma_segment_t seg;
- bus_dmamap_t cmd_map;
- bus_dma_segment_t cmd_seg;
+ struct wpi_dma_info desc_dma;
+ struct wpi_dma_info cmd_dma;
struct wpi_tx_desc *desc;
struct wpi_tx_cmd *cmd;
struct wpi_tx_data *data;
@@ -67,8 +73,7 @@ struct wpi_rx_data {
};
struct wpi_rx_ring {
- bus_dmamap_t map;
- bus_dma_segment_t seg;
+ struct wpi_dma_info desc_dma;
uint32_t *desc;
struct wpi_rx_data data[WPI_RX_RING_COUNT];
int cur;
@@ -87,8 +92,7 @@ struct wpi_softc {
bus_dma_tag_t sc_dmat;
/* shared area */
- bus_dmamap_t shmap;
- bus_dma_segment_t shseg;
+ struct wpi_dma_info shared_dma;
struct wpi_shared *shared;
struct wpi_tx_ring txq[4];
@@ -107,7 +111,6 @@ struct wpi_softc {
uint16_t calib1[14];
uint16_t calib2[14];
- int authmode;
int sc_tx_timer;
void *powerhook;