summaryrefslogtreecommitdiffstats
path: root/sys/dev/if_ndis
diff options
context:
space:
mode:
authorsam <sam@FreeBSD.org>2004-12-08 17:36:51 +0000
committersam <sam@FreeBSD.org>2004-12-08 17:36:51 +0000
commitdb6535c8766930b500333ae4fc743c5da7814928 (patch)
tree456a8adcebe60aa5acdc41fc83efd45d43311043 /sys/dev/if_ndis
parent0c82ed616510db58f8cd9df461314ab8010dbd72 (diff)
downloadFreeBSD-src-db6535c8766930b500333ae4fc743c5da7814928.zip
FreeBSD-src-db6535c8766930b500333ae4fc743c5da7814928.tar.gz
Update for net80211 changes.
Diffstat (limited to 'sys/dev/if_ndis')
-rw-r--r--sys/dev/if_ndis/if_ndis.c31
-rw-r--r--sys/dev/if_ndis/if_ndisvar.h3
2 files changed, 17 insertions, 17 deletions
diff --git a/sys/dev/if_ndis/if_ndis.c b/sys/dev/if_ndis/if_ndis.c
index 1dd892a..af9a54f 100644
--- a/sys/dev/if_ndis/if_ndis.c
+++ b/sys/dev/if_ndis/if_ndis.c
@@ -508,6 +508,7 @@ ndis_attach(dev)
uint32_t arg;
int r;
+ ic->ic_ifp = ifp;
ic->ic_phytype = IEEE80211_T_DS;
ic->ic_opmode = IEEE80211_M_STA;
ic->ic_caps = IEEE80211_C_IBSS;
@@ -672,8 +673,8 @@ nonettypes:
if (r == 0)
ic->ic_caps |= IEEE80211_C_PMGT;
bcopy(eaddr, &ic->ic_myaddr, sizeof(eaddr));
- ieee80211_ifattach(ifp);
- ieee80211_media_init(ifp, ieee80211_media_change,
+ ieee80211_ifattach(ic);
+ ieee80211_media_init(ic, ieee80211_media_change,
ndis_media_status);
ic->ic_ibss_chan = IEEE80211_CHAN_ANYC;
ic->ic_bss->ni_chan = ic->ic_ibss_chan;
@@ -730,7 +731,7 @@ ndis_detach(dev)
NDIS_UNLOCK(sc);
ndis_stop(sc);
if (sc->ndis_80211)
- ieee80211_ifdetach(ifp);
+ ieee80211_ifdetach(&sc->ic);
else
ether_ifdetach(ifp);
} else
@@ -1478,7 +1479,7 @@ ndis_setstate_80211(sc)
struct ifnet *ifp;
ic = &sc->ic;
- ifp = &sc->ic.ic_ac.ac_if;
+ ifp = &sc->arpcom.ac_if;
if (!NDIS_INITIALIZED(sc))
return;
@@ -1498,27 +1499,27 @@ ndis_setstate_80211(sc)
/* Set WEP */
-#ifdef IEEE80211_F_WEPON
- if (ic->ic_flags & IEEE80211_F_WEPON) {
+#ifdef IEEE80211_F_PRIVACY
+ if (ic->ic_flags & IEEE80211_F_PRIVACY) {
#else
if (ic->ic_wep_mode >= IEEE80211_WEP_ON) {
#endif
for (i = 0; i < IEEE80211_WEP_NKID; i++) {
- if (ic->ic_nw_keys[i].wk_len) {
+ if (ic->ic_nw_keys[i].wk_keylen) {
bzero((char *)&wep, sizeof(wep));
- wep.nw_keylen = ic->ic_nw_keys[i].wk_len;
+ wep.nw_keylen = ic->ic_nw_keys[i].wk_keylen;
#ifdef notdef
/* 5 and 13 are the only valid key lengths */
- if (ic->ic_nw_keys[i].wk_len < 5)
+ if (ic->ic_nw_keys[i].wk_keylen < 5)
wep.nw_keylen = 5;
- else if (ic->ic_nw_keys[i].wk_len > 5 &&
- ic->ic_nw_keys[i].wk_len < 13)
+ else if (ic->ic_nw_keys[i].wk_keylen > 5 &&
+ ic->ic_nw_keys[i].wk_keylen < 13)
wep.nw_keylen = 13;
#endif
wep.nw_keyidx = i;
wep.nw_length = (sizeof(uint32_t) * 3)
+ wep.nw_keylen;
- if (i == ic->ic_wep_txkey)
+ if (i == ic->ic_def_txkey)
wep.nw_keyidx |= NDIS_80211_WEPKEY_TX;
bcopy(ic->ic_nw_keys[i].wk_key,
wep.nw_keydata, wep.nw_length);
@@ -1777,7 +1778,7 @@ ndis_getstate_80211(sc)
struct ifnet *ifp;
ic = &sc->ic;
- ifp = &sc->ic.ic_ac.ac_if;
+ ifp = &sc->arpcom.ac_if;
if (!NDIS_INITIALIZED(sc))
return;
@@ -1952,7 +1953,7 @@ ndis_ioctl(ifp, command, data)
case SIOCGIFMEDIA:
case SIOCSIFMEDIA:
if (sc->ndis_80211) {
- error = ieee80211_ioctl(ifp, command, data);
+ error = ieee80211_ioctl(&sc->ic, command, data);
if (error == ENETRESET) {
ndis_setstate_80211(sc);
/*ndis_init(sc);*/
@@ -1983,7 +1984,7 @@ ndis_ioctl(ifp, command, data)
default:
sc->ndis_skip = 1;
if (sc->ndis_80211) {
- error = ieee80211_ioctl(ifp, command, data);
+ error = ieee80211_ioctl(&sc->ic, command, data);
if (error == ENETRESET) {
ndis_setstate_80211(sc);
error = 0;
diff --git a/sys/dev/if_ndis/if_ndisvar.h b/sys/dev/if_ndis/if_ndisvar.h
index 0e60744..339d965 100644
--- a/sys/dev/if_ndis/if_ndisvar.h
+++ b/sys/dev/if_ndis/if_ndisvar.h
@@ -67,9 +67,8 @@ TAILQ_HEAD(nch, ndis_cfglist);
#define NDIS_INC(x) \
(x)->ndis_txidx = ((x)->ndis_txidx + 1) % (x)->ndis_maxpkts
-#define arpcom ic.ic_ac
-
struct ndis_softc {
+ struct arpcom arpcom;
struct ieee80211com ic; /* interface info */
#ifdef notdef
struct ieee80211com arpcom; /* interface info */
OpenPOWER on IntegriCloud