summaryrefslogtreecommitdiff
path: root/sys/dev/pci
diff options
context:
space:
mode:
Diffstat (limited to 'sys/dev/pci')
-rw-r--r--sys/dev/pci/if_ipw.c68
-rw-r--r--sys/dev/pci/if_ipwreg.h14
2 files changed, 40 insertions, 42 deletions
diff --git a/sys/dev/pci/if_ipw.c b/sys/dev/pci/if_ipw.c
index ad834ef122d..ccf77ce3f72 100644
--- a/sys/dev/pci/if_ipw.c
+++ b/sys/dev/pci/if_ipw.c
@@ -1,4 +1,4 @@
-/* $Id: if_ipw.c,v 1.30 2004/12/05 17:46:07 damien Exp $ */
+/* $Id: if_ipw.c,v 1.31 2004/12/05 19:39:22 damien Exp $ */
/*-
* Copyright (c) 2004
@@ -831,7 +831,7 @@ ipw_data_intr(struct ipw_softc *sc, struct ipw_status *status,
ni = ieee80211_find_rxnode(ic, wh);
- /* Send it up to the upper layer */
+ /* Send the frame to the upper layer */
ieee80211_input(ifp, m, ni, status->rssi, 0);
if (ni == ic->ic_bss)
@@ -856,7 +856,7 @@ ipw_data_intr(struct ipw_softc *sc, struct ipw_status *status,
error = bus_dmamap_load(sc->sc_dmat, sbuf->map, mtod(m, void *),
MCLBYTES, NULL, BUS_DMA_NOWAIT);
if (error != 0) {
- printf("%s: could not map rxbuf dma memory\n",
+ printf("%s: could not map rx DMA memory\n",
sc->sc_dev.dv_xname);
m_freem(m);
return;
@@ -1038,7 +1038,7 @@ ipw_cmd(struct ipw_softc *sc, u_int32_t type, void *data, u_int32_t len)
error = bus_dmamap_load(sc->sc_dmat, sc->cmd_map, &sc->cmd,
sizeof (struct ipw_cmd), NULL, BUS_DMA_NOWAIT);
if (error != 0) {
- printf("%s: could not map cmd dma memory\n",
+ printf("%s: could not map command DMA memory\n",
sc->sc_dev.dv_xname);
return error;
}
@@ -1130,10 +1130,6 @@ ipw_tx_start(struct ifnet *ifp, struct mbuf *m, struct ieee80211_node *ni)
/* trim IEEE802.11 header */
m_adj(m, sizeof (struct ieee80211_frame));
- /*
- * We need to map the mbuf first to know how many buffer descriptors
- * are needed for this transfer.
- */
error = bus_dmamap_load_mbuf(sc->sc_dmat, sbuf->map, m, BUS_DMA_NOWAIT);
if (error != 0) {
printf("%s: could not map mbuf (error %d)\n",
@@ -1145,7 +1141,7 @@ ipw_tx_start(struct ifnet *ifp, struct mbuf *m, struct ieee80211_node *ni)
error = bus_dmamap_load(sc->sc_dmat, shdr->map, &shdr->hdr,
sizeof (struct ipw_hdr), NULL, BUS_DMA_NOWAIT);
if (error != 0) {
- printf("%s: could not map header (error %d)\n",
+ printf("%s: could not map header DMA memory (error %d)\n",
sc->sc_dev.dv_xname, error);
bus_dmamap_unload(sc->sc_dmat, sbuf->map);
m_freem(m);
@@ -1293,11 +1289,11 @@ ipw_get_table1(struct ipw_softc *sc, u_int32_t *tbl)
CSR_WRITE_4(sc, IPW_CSR_AUTOINC_ADDR, sc->table1_base);
- size = CSR_READ_4(sc, IPW_CSR_AUTOINC_DATA);
+ size = min(CSR_READ_4(sc, IPW_CSR_AUTOINC_DATA), 256);
for (i = 1; i < size; i++)
buf[i] = MEM_READ_4(sc, CSR_READ_4(sc, IPW_CSR_AUTOINC_DATA));
- return copyout(buf, tbl, size * sizeof (u_int32_t));
+ return copyout(buf, tbl, sizeof buf);
}
int
@@ -1658,7 +1654,7 @@ ipw_config(struct ipw_softc *sc)
data = htole32(IPW_MODE_MONITOR);
break;
}
- DPRINTF(("Setting adapter mode to %u\n", data));
+ DPRINTF(("Setting mode to %u\n", letoh32(data)));
error = ipw_cmd(sc, IPW_CMD_SET_MODE, &data, sizeof data);
if (error != 0)
return error;
@@ -1666,7 +1662,7 @@ ipw_config(struct ipw_softc *sc)
if (ic->ic_opmode == IEEE80211_M_IBSS ||
ic->ic_opmode == IEEE80211_M_MONITOR) {
data = htole32(ieee80211_chan2ieee(ic, ic->ic_ibss_chan));
- DPRINTF(("Setting adapter channel to %u\n", data));
+ DPRINTF(("Setting channel to %u\n", letoh32(data)));
error = ipw_cmd(sc, IPW_CMD_SET_CHANNEL, &data, sizeof data);
if (error != 0)
return error;
@@ -1677,48 +1673,48 @@ ipw_config(struct ipw_softc *sc)
return ipw_cmd(sc, IPW_CMD_ENABLE, NULL, 0);
}
- DPRINTF(("Setting adapter MAC to %s\n", ether_sprintf(ic->ic_myaddr)));
IEEE80211_ADDR_COPY(((struct arpcom *)ifp)->ac_enaddr, ic->ic_myaddr);
IEEE80211_ADDR_COPY(LLADDR(ifp->if_sadl), ic->ic_myaddr);
+ DPRINTF(("Setting MAC address to %s\n", ether_sprintf(ic->ic_myaddr)));
error = ipw_cmd(sc, IPW_CMD_SET_MAC_ADDRESS, ic->ic_myaddr,
IEEE80211_ADDR_LEN);
if (error != 0)
return error;
config.flags = htole32(IPW_CFG_BSS_MASK | IPW_CFG_IBSS_MASK |
- IPW_CFG_PREAMBLE_LEN | IPW_CFG_802_1x_ENABLE);
+ IPW_CFG_PREAMBLE_AUTO | IPW_CFG_802_1x_ENABLE);
if (ic->ic_opmode == IEEE80211_M_IBSS)
config.flags |= htole32(IPW_CFG_IBSS_AUTO_START);
if (ifp->if_flags & IFF_PROMISC)
config.flags |= htole32(IPW_CFG_PROMISCUOUS);
- config.channels = htole32(0x3fff); /* channels 1-14 */
- config.ibss_chan = htole32(0x7ff);
- DPRINTF(("Setting adapter configuration 0x%08x\n", config.flags));
+ config.bss_chan = htole32(0x3fff); /* channels 1-14 */
+ config.ibss_chan = htole32(0x7ff); /* channels 1-11 */
+ DPRINTF(("Setting configuration 0x%x\n", config.flags));
error = ipw_cmd(sc, IPW_CMD_SET_CONFIGURATION, &config, sizeof config);
if (error != 0)
return error;
data = htole32(0x3); /* 1, 2 */
- DPRINTF(("Setting adapter basic tx rates to 0x%x\n", data));
+ DPRINTF(("Setting basic tx rates to 0x%x\n", letoh32(data)));
error = ipw_cmd(sc, IPW_CMD_SET_BASIC_TX_RATES, &data, sizeof data);
if (error != 0)
return error;
data = htole32(0xf); /* 1, 2, 5.5, 11 */
- DPRINTF(("Setting adapter tx rates to 0x%x\n", data));
+ DPRINTF(("Setting tx rates to 0x%x\n", letoh32(data)));
error = ipw_cmd(sc, IPW_CMD_SET_TX_RATES, &data, sizeof data);
if (error != 0)
return error;
data = htole32(IPW_POWER_MODE_CAM);
- DPRINTF(("Setting adapter power mode to %u\n", data));
+ DPRINTF(("Setting power mode to %u\n", letoh32(data)));
error = ipw_cmd(sc, IPW_CMD_SET_POWER_MODE, &data, sizeof data);
if (error != 0)
return error;
if (ic->ic_opmode == IEEE80211_M_IBSS) {
- data = htole32(ic->ic_txpower);
- DPRINTF(("Setting adapter tx power index to %u\n", data));
+ data = htole32(32); /* default value */
+ DPRINTF(("Setting tx power index to %u\n", letoh32(data)));
error = ipw_cmd(sc, IPW_CMD_SET_TX_POWER_INDEX, &data,
sizeof data);
if (error != 0)
@@ -1726,20 +1722,20 @@ ipw_config(struct ipw_softc *sc)
}
data = htole32(ic->ic_rtsthreshold);
- DPRINTF(("Setting adapter RTS threshold to %u\n", data));
+ DPRINTF(("Setting RTS threshold to %u\n", letoh32(data)));
error = ipw_cmd(sc, IPW_CMD_SET_RTS_THRESHOLD, &data, sizeof data);
if (error != 0)
return error;
data = htole32(ic->ic_fragthreshold);
- DPRINTF(("Setting adapter frag threshold to %u\n", data));
+ DPRINTF(("Setting frag threshold to %u\n", letoh32(data)));
error = ipw_cmd(sc, IPW_CMD_SET_FRAG_THRESHOLD, &data, sizeof data);
if (error != 0)
return error;
#ifdef IPW_DEBUG
if (ipw_debug > 0) {
- printf("Setting adapter ESSID to ");
+ printf("Setting ESSID to ");
ieee80211_print_essid(ic->ic_des_essid, ic->ic_des_esslen);
printf("\n");
}
@@ -1750,12 +1746,13 @@ ipw_config(struct ipw_softc *sc)
return error;
/* no mandatory BSSID */
+ DPRINTF(("Setting mandatory BSSID to null\n"));
error = ipw_cmd(sc, IPW_CMD_SET_MANDATORY_BSSID, NULL, 0);
if (error != 0)
return error;
if (ic->ic_flags & IEEE80211_F_DESBSSID) {
- DPRINTF(("Setting adapter desired BSSID to %s\n",
+ DPRINTF(("Setting adapter BSSID to %s\n",
ether_sprintf(ic->ic_des_bssid)));
error = ipw_cmd(sc, IPW_CMD_SET_DESIRED_BSSID,
ic->ic_des_bssid, IEEE80211_ADDR_LEN);
@@ -1763,13 +1760,11 @@ ipw_config(struct ipw_softc *sc)
return error;
}
+ bzero(&security, sizeof security);
security.authmode = (sc->authmode == IEEE80211_AUTH_SHARED) ?
IPW_AUTH_SHARED : IPW_AUTH_OPEN;
security.ciphers = htole32(IPW_CIPHER_NONE);
- security.version = htole16(0);
- security.replay_counters_number = 0;
- security.unicast_using_group = 0;
- DPRINTF(("Setting adapter authmode to %u\n", security.authmode));
+ DPRINTF(("Setting authmode to %u\n", security.authmode));
error = ipw_cmd(sc, IPW_CMD_SET_SECURITY_INFORMATION, &security,
sizeof security);
if (error != 0)
@@ -1785,7 +1780,7 @@ ipw_config(struct ipw_softc *sc)
wepkey.len = k->wk_len;
bzero(wepkey.key, sizeof wepkey.key);
bcopy(k->wk_key, wepkey.key, k->wk_len);
- DPRINTF(("Setting wep key index %d len %d\n",
+ DPRINTF(("Setting wep key index %u len %u\n",
wepkey.idx, wepkey.len));
error = ipw_cmd(sc, IPW_CMD_SET_WEP_KEY, &wepkey,
sizeof wepkey);
@@ -1794,15 +1789,15 @@ ipw_config(struct ipw_softc *sc)
}
data = htole32(ic->ic_wep_txkey);
- DPRINTF(("Setting adapter tx key index to %u\n", data));
+ DPRINTF(("Setting wep tx key index to %u\n", letoh32(data)));
error = ipw_cmd(sc, IPW_CMD_SET_WEP_KEY_INDEX, &data,
sizeof data);
if (error != 0)
return error;
}
- data = htole32((sc->sc_ic.ic_flags & IEEE80211_F_WEPON) ? 0x8 : 0);
- DPRINTF(("Setting adapter wep flags to 0x%x\n", data));
+ data = htole32((ic->ic_flags & IEEE80211_F_WEPON) ? IPW_WEPON : 0);
+ DPRINTF(("Setting wep flags to 0x%x\n", letoh32(data)));
error = ipw_cmd(sc, IPW_CMD_SET_WEP_FLAGS, &data, sizeof data);
if (error != 0)
return error;
@@ -1810,7 +1805,7 @@ ipw_config(struct ipw_softc *sc)
if (ic->ic_opmode == IEEE80211_M_IBSS ||
ic->ic_opmode == IEEE80211_M_HOSTAP) {
data = htole32(ic->ic_lintval);
- DPRINTF(("Setting adapter beacon interval to %u\n", data));
+ DPRINTF(("Setting beacon interval to %u\n", letoh32(data)));
error = ipw_cmd(sc, IPW_CMD_SET_BEACON_INTERVAL, &data,
sizeof data);
if (error != 0)
@@ -1819,6 +1814,7 @@ ipw_config(struct ipw_softc *sc)
options.flags = htole32(0);
options.channels = htole32(0x3fff); /* scan channels 1-14 */
+ DPRINTF(("Setting scan options to 0x%x\n", letoh32(options.flags)));
error = ipw_cmd(sc, IPW_CMD_SET_SCAN_OPTIONS, &options, sizeof options);
if (error != 0)
return error;
diff --git a/sys/dev/pci/if_ipwreg.h b/sys/dev/pci/if_ipwreg.h
index ec525836c27..3db0a39f64c 100644
--- a/sys/dev/pci/if_ipwreg.h
+++ b/sys/dev/pci/if_ipwreg.h
@@ -1,4 +1,4 @@
-/* $Id: if_ipwreg.h,v 1.7 2004/12/05 17:46:07 damien Exp $ */
+/* $Id: if_ipwreg.h,v 1.8 2004/12/05 19:39:22 damien Exp $ */
/*-
* Copyright (c) 2004
@@ -208,6 +208,9 @@ struct ipw_cmd {
#define IPW_MODE_IBSS 1
#define IPW_MODE_MONITOR 2
+/* possible flags for command IPW_CMD_SET_WEP_FLAGS */
+#define IPW_WEPON 0x8
+
/* structure for command IPW_CMD_SET_WEP_KEY */
struct ipw_wep_key {
u_int8_t idx;
@@ -221,12 +224,11 @@ struct ipw_security {
#define IPW_CIPHER_NONE 0x00000001
#define IPW_CIPHER_WEP40 0x00000002
#define IPW_CIPHER_WEP104 0x00000020
- u_int16_t version;
+ u_int16_t reserved1;
u_int8_t authmode;
#define IPW_AUTH_OPEN 0
#define IPW_AUTH_SHARED 1
- u_int8_t replay_counters_number;
- u_int8_t unicast_using_group;
+ u_int16_t reserved2;
} __attribute__((__packed__));
/* structure for command IPW_CMD_SET_SCAN_OPTIONS */
@@ -241,12 +243,12 @@ struct ipw_scan_options {
struct ipw_configuration {
u_int32_t flags;
#define IPW_CFG_PROMISCUOUS 0x00000004
-#define IPW_CFG_PREAMBLE_LEN 0x00000010
+#define IPW_CFG_PREAMBLE_AUTO 0x00000010
#define IPW_CFG_IBSS_AUTO_START 0x00000020
#define IPW_CFG_802_1x_ENABLE 0x00004000
#define IPW_CFG_BSS_MASK 0x00008000
#define IPW_CFG_IBSS_MASK 0x00010000
- u_int32_t channels;
+ u_int32_t bss_chan;
u_int32_t ibss_chan;
} __attribute__((__packed__));