Rename definition of IEEE80211_FC1_WEP to IEEE80211_FC1_PROTECTED.
The origin of WEP comes from IEEE Std 802.11-1997 where it defines whether the frame body of MAC frame has been encrypted using WEP algorithm or not. IEEE Std. 802.11-2007 changes WEP to Protected Frame, indicates whether the frame is protected by a cryptographic encapsulation algorithm. Reviewed by: adrian, rpaulo
This commit is contained in:
parent
14f4ecfafa
commit
5945b5f5ab
@ -90,7 +90,7 @@
|
||||
#define IEEE80211_FC1_RETRY 0x08
|
||||
#define IEEE80211_FC1_PWR_MGT 0x10
|
||||
#define IEEE80211_FC1_MORE_DATA 0x20
|
||||
#define IEEE80211_FC1_WEP 0x40
|
||||
#define IEEE80211_FC1_PROTECTED 0x40
|
||||
#define IEEE80211_FC1_ORDER 0x80
|
||||
|
||||
#define IEEE80211_SEQ_FRAG_MASK 0x000f
|
||||
|
@ -236,7 +236,7 @@ For receive, drivers mark frames with the
|
||||
.Dv M_WEP
|
||||
mbuf flag to indicate the hardware has decrypted the payload.
|
||||
If frames have the
|
||||
.Dv IEEE80211_FC1_WEP
|
||||
.Dv IEEE80211_FC1_PROTECTED
|
||||
bit marked in their 802.11 header and are not tagged with
|
||||
.Dv M_WEP
|
||||
then decryption is done in software.
|
||||
|
@ -1586,7 +1586,7 @@ ath_tx_normal_setup(struct ath_softc *sc, struct ieee80211_node *ni,
|
||||
ATH_TX_LOCK_ASSERT(sc);
|
||||
|
||||
wh = mtod(m0, struct ieee80211_frame *);
|
||||
iswep = wh->i_fc[1] & IEEE80211_FC1_WEP;
|
||||
iswep = wh->i_fc[1] & IEEE80211_FC1_PROTECTED;
|
||||
ismcast = IEEE80211_IS_MULTICAST(wh->i_addr1);
|
||||
isfrag = m0->m_flags & M_FRAG;
|
||||
hdrlen = ieee80211_anyhdrsize(wh);
|
||||
@ -2216,7 +2216,7 @@ ath_tx_raw_start(struct ath_softc *sc, struct ieee80211_node *ni,
|
||||
|
||||
sc->sc_tx_th.wt_tsf = htole64(tsf);
|
||||
sc->sc_tx_th.wt_flags = sc->sc_hwmap[rix].txflags;
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP)
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED)
|
||||
sc->sc_tx_th.wt_flags |= IEEE80211_RADIOTAP_F_WEP;
|
||||
if (m0->m_flags & M_FRAG)
|
||||
sc->sc_tx_th.wt_flags |= IEEE80211_RADIOTAP_F_FRAG;
|
||||
|
@ -1396,7 +1396,7 @@ bwi_start_locked(struct ifnet *ifp)
|
||||
|
||||
ni = (struct ieee80211_node *) m->m_pkthdr.rcvif;
|
||||
wh = mtod(m, struct ieee80211_frame *);
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP) {
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) {
|
||||
k = ieee80211_crypto_encap(ni, m);
|
||||
if (k == NULL) {
|
||||
ieee80211_free_node(ni);
|
||||
@ -3001,7 +3001,7 @@ bwi_encap(struct bwi_softc *sc, int idx, struct mbuf *m,
|
||||
*/
|
||||
if (ieee80211_radiotap_active_vap(vap)) {
|
||||
sc->sc_tx_th.wt_flags = 0;
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP)
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED)
|
||||
sc->sc_tx_th.wt_flags |= IEEE80211_RADIOTAP_F_WEP;
|
||||
if (ieee80211_rate2phytype(sc->sc_rates, rate) == IEEE80211_T_DS &&
|
||||
(ic->ic_flags & IEEE80211_F_SHPREAMBLE) &&
|
||||
@ -3184,7 +3184,7 @@ bwi_encap_raw(struct bwi_softc *sc, int idx, struct mbuf *m,
|
||||
if (ieee80211_radiotap_active_vap(vap)) {
|
||||
sc->sc_tx_th.wt_flags = 0;
|
||||
/* XXX IEEE80211_BPF_CRYPTO */
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP)
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED)
|
||||
sc->sc_tx_th.wt_flags |= IEEE80211_RADIOTAP_F_WEP;
|
||||
if (params->ibp_flags & IEEE80211_BPF_SHORTPRE)
|
||||
sc->sc_tx_th.wt_flags |= IEEE80211_RADIOTAP_F_SHORTPRE;
|
||||
@ -3820,7 +3820,7 @@ bwi_rx_radiotap(struct bwi_softc *sc, struct mbuf *m,
|
||||
sc->sc_rx_th.wr_flags |= IEEE80211_RADIOTAP_F_SHORTPRE;
|
||||
|
||||
wh = mtod(m, const struct ieee80211_frame_min *);
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP)
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED)
|
||||
sc->sc_rx_th.wr_flags |= IEEE80211_RADIOTAP_F_WEP;
|
||||
|
||||
sc->sc_rx_th.wr_tsf = hdr->rxh_tsf; /* No endian convertion */
|
||||
|
@ -1317,7 +1317,7 @@ bwn_start_locked(struct ifnet *ifp)
|
||||
}
|
||||
KASSERT(ni != NULL, ("%s:%d: fail", __func__, __LINE__));
|
||||
wh = mtod(m, struct ieee80211_frame *);
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP) {
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) {
|
||||
k = ieee80211_crypto_encap(ni, m);
|
||||
if (k == NULL) {
|
||||
ieee80211_free_node(ni);
|
||||
@ -9781,7 +9781,7 @@ bwn_set_txhdr(struct bwn_mac *mac, struct ieee80211_node *ni,
|
||||
*/
|
||||
if (ieee80211_radiotap_active_vap(vap)) {
|
||||
sc->sc_tx_th.wt_flags = 0;
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP)
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED)
|
||||
sc->sc_tx_th.wt_flags |= IEEE80211_RADIOTAP_F_WEP;
|
||||
if (isshort &&
|
||||
(rate == BWN_CCK_RATE_2MB || rate == BWN_CCK_RATE_5MB ||
|
||||
@ -10320,7 +10320,7 @@ bwn_rx_radiotap(struct bwn_mac *mac, struct mbuf *m,
|
||||
sc->sc_rx_th.wr_flags |= IEEE80211_RADIOTAP_F_SHORTPRE;
|
||||
|
||||
wh = mtod(m, const struct ieee80211_frame_min *);
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP)
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED)
|
||||
sc->sc_rx_th.wr_flags |= IEEE80211_RADIOTAP_F_WEP;
|
||||
|
||||
bwn_tsf_read(mac, &tsf);
|
||||
|
@ -1597,7 +1597,7 @@ ipw_tx_start(struct ifnet *ifp, struct mbuf *m0, struct ieee80211_node *ni)
|
||||
|
||||
wh = mtod(m0, struct ieee80211_frame *);
|
||||
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP) {
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) {
|
||||
k = ieee80211_crypto_encap(ni, m0);
|
||||
if (k == NULL) {
|
||||
m_freem(m0);
|
||||
@ -1621,7 +1621,7 @@ ipw_tx_start(struct ifnet *ifp, struct mbuf *m0, struct ieee80211_node *ni)
|
||||
|
||||
shdr->hdr.type = htole32(IPW_HDR_TYPE_SEND);
|
||||
shdr->hdr.subtype = 0;
|
||||
shdr->hdr.encrypted = (wh->i_fc[1] & IEEE80211_FC1_WEP) ? 1 : 0;
|
||||
shdr->hdr.encrypted = (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) ? 1 : 0;
|
||||
shdr->hdr.encrypt = 0;
|
||||
shdr->hdr.keyidx = 0;
|
||||
shdr->hdr.keysz = 0;
|
||||
|
@ -1846,7 +1846,7 @@ iwi_tx_start(struct ifnet *ifp, struct mbuf *m0, struct ieee80211_node *ni,
|
||||
} else
|
||||
staid = 0;
|
||||
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP) {
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) {
|
||||
k = ieee80211_crypto_encap(ni, m0);
|
||||
if (k == NULL) {
|
||||
m_freem(m0);
|
||||
|
@ -4137,7 +4137,7 @@ iwn_tx_data(struct iwn_softc *sc, struct mbuf *m, struct ieee80211_node *ni)
|
||||
}
|
||||
|
||||
/* Encrypt the frame if need be. */
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP) {
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) {
|
||||
/* Retrieve key for TX. */
|
||||
k = ieee80211_crypto_encap(ni, m);
|
||||
if (k == NULL) {
|
||||
|
@ -1102,7 +1102,7 @@ malo_tx_start(struct malo_softc *sc, struct ieee80211_node *ni,
|
||||
uint16_t qos;
|
||||
|
||||
wh = mtod(m0, struct ieee80211_frame *);
|
||||
iswep = wh->i_fc[1] & IEEE80211_FC1_WEP;
|
||||
iswep = wh->i_fc[1] & IEEE80211_FC1_PROTECTED;
|
||||
ismcast = IEEE80211_IS_MULTICAST(wh->i_addr1);
|
||||
copyhdrlen = hdrlen = ieee80211_anyhdrsize(wh);
|
||||
pktlen = m0->m_pkthdr.len;
|
||||
|
@ -2886,12 +2886,13 @@ mwl_rx_proc(void *arg, int npending)
|
||||
* upper layer to put a station in power save
|
||||
* (except when configured with MWL_HOST_PS_SUPPORT).
|
||||
*/
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP)
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED)
|
||||
m->m_flags |= M_WEP;
|
||||
#ifdef MWL_HOST_PS_SUPPORT
|
||||
wh->i_fc[1] &= ~IEEE80211_FC1_WEP;
|
||||
wh->i_fc[1] &= ~IEEE80211_FC1_PROTECTED;
|
||||
#else
|
||||
wh->i_fc[1] &= ~(IEEE80211_FC1_WEP | IEEE80211_FC1_PWR_MGT);
|
||||
wh->i_fc[1] &= ~(IEEE80211_FC1_PROTECTED |
|
||||
IEEE80211_FC1_PWR_MGT);
|
||||
#endif
|
||||
|
||||
if (ieee80211_radiotap_active(ic)) {
|
||||
@ -3205,7 +3206,7 @@ mwl_tx_start(struct mwl_softc *sc, struct ieee80211_node *ni, struct mwl_txbuf *
|
||||
#endif
|
||||
|
||||
wh = mtod(m0, struct ieee80211_frame *);
|
||||
iswep = wh->i_fc[1] & IEEE80211_FC1_WEP;
|
||||
iswep = wh->i_fc[1] & IEEE80211_FC1_PROTECTED;
|
||||
ismcast = IEEE80211_IS_MULTICAST(wh->i_addr1);
|
||||
hdrlen = ieee80211_anyhdrsize(wh);
|
||||
copyhdrlen = hdrlen;
|
||||
|
@ -1558,7 +1558,7 @@ rt2560_tx_mgt(struct rt2560_softc *sc, struct mbuf *m0,
|
||||
|
||||
wh = mtod(m0, struct ieee80211_frame *);
|
||||
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP) {
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) {
|
||||
k = ieee80211_crypto_encap(ni, m0);
|
||||
if (k == NULL) {
|
||||
m_freem(m0);
|
||||
@ -1804,7 +1804,7 @@ rt2560_tx_data(struct rt2560_softc *sc, struct mbuf *m0,
|
||||
rate = ni->ni_txrate;
|
||||
}
|
||||
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP) {
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) {
|
||||
k = ieee80211_crypto_encap(ni, m0);
|
||||
if (k == NULL) {
|
||||
m_freem(m0);
|
||||
|
@ -1319,7 +1319,7 @@ rt2661_tx_mgt(struct rt2661_softc *sc, struct mbuf *m0,
|
||||
|
||||
wh = mtod(m0, struct ieee80211_frame *);
|
||||
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP) {
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) {
|
||||
k = ieee80211_crypto_encap(ni, m0);
|
||||
if (k == NULL) {
|
||||
m_freem(m0);
|
||||
@ -1494,7 +1494,7 @@ rt2661_tx_data(struct rt2661_softc *sc, struct mbuf *m0,
|
||||
noack = cap->cap_wmeParams[ac].wmep_noackPolicy;
|
||||
}
|
||||
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP) {
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) {
|
||||
k = ieee80211_crypto_encap(ni, m0);
|
||||
if (k == NULL) {
|
||||
m_freem(m0);
|
||||
|
@ -1285,9 +1285,9 @@ rt2860_rx_intr(struct rt2860_softc *sc)
|
||||
|
||||
wh = mtod(m, struct ieee80211_frame *);
|
||||
#ifdef HW_CRYPTO
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP) {
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) {
|
||||
/* frame is decrypted by hardware */
|
||||
wh->i_fc[1] &= ~IEEE80211_FC1_WEP;
|
||||
wh->i_fc[1] &= ~IEEE80211_FC1_PROTECTED;
|
||||
}
|
||||
#endif
|
||||
|
||||
@ -1493,7 +1493,7 @@ rt2860_tx(struct rt2860_softc *sc, struct mbuf *m, struct ieee80211_node *ni)
|
||||
|
||||
wh = mtod(m, struct ieee80211_frame *);
|
||||
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP) {
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) {
|
||||
k = ieee80211_crypto_encap(ni, m);
|
||||
if (k == NULL) {
|
||||
m_freem(m);
|
||||
|
@ -1670,7 +1670,7 @@ rsu_tx_start(struct rsu_softc *sc, struct ieee80211_node *ni,
|
||||
wh = mtod(m0, struct ieee80211_frame *);
|
||||
type = wh->i_fc[0] & IEEE80211_FC0_TYPE_MASK;
|
||||
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP) {
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) {
|
||||
k = ieee80211_crypto_encap(ni, m0);
|
||||
if (k == NULL) {
|
||||
device_printf(sc->sc_dev,
|
||||
|
@ -1121,7 +1121,7 @@ rum_tx_mgt(struct rum_softc *sc, struct mbuf *m0, struct ieee80211_node *ni)
|
||||
sc->tx_nfree--;
|
||||
|
||||
wh = mtod(m0, struct ieee80211_frame *);
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP) {
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) {
|
||||
k = ieee80211_crypto_encap(ni, m0);
|
||||
if (k == NULL) {
|
||||
m_freem(m0);
|
||||
@ -1239,7 +1239,7 @@ rum_tx_data(struct rum_softc *sc, struct mbuf *m0, struct ieee80211_node *ni)
|
||||
else
|
||||
rate = ni->ni_txrate;
|
||||
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP) {
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) {
|
||||
k = ieee80211_crypto_encap(ni, m0);
|
||||
if (k == NULL) {
|
||||
m_freem(m0);
|
||||
|
@ -2807,8 +2807,8 @@ run_rx_frame(struct run_softc *sc, struct mbuf *m, uint32_t dmalen)
|
||||
|
||||
wh = mtod(m, struct ieee80211_frame *);
|
||||
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP) {
|
||||
wh->i_fc[1] &= ~IEEE80211_FC1_WEP;
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) {
|
||||
wh->i_fc[1] &= ~IEEE80211_FC1_PROTECTED;
|
||||
m->m_flags |= M_WEP;
|
||||
}
|
||||
|
||||
|
@ -1626,7 +1626,7 @@ uath_tx_start(struct uath_softc *sc, struct mbuf *m0, struct ieee80211_node *ni,
|
||||
}
|
||||
|
||||
wh = mtod(m0, struct ieee80211_frame *);
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP) {
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) {
|
||||
k = ieee80211_crypto_encap(ni, m0);
|
||||
if (k == NULL) {
|
||||
m_freem(m0);
|
||||
|
@ -2223,7 +2223,7 @@ upgt_tx_start(struct upgt_softc *sc, struct mbuf *m, struct ieee80211_node *ni,
|
||||
* Software crypto.
|
||||
*/
|
||||
wh = mtod(m, struct ieee80211_frame *);
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP) {
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) {
|
||||
k = ieee80211_crypto_encap(ni, m);
|
||||
if (k == NULL) {
|
||||
device_printf(sc->sc_dev,
|
||||
|
@ -1120,7 +1120,7 @@ ural_tx_mgt(struct ural_softc *sc, struct mbuf *m0, struct ieee80211_node *ni)
|
||||
tp = &vap->iv_txparms[ieee80211_chan2mode(ic->ic_curchan)];
|
||||
|
||||
wh = mtod(m0, struct ieee80211_frame *);
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP) {
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) {
|
||||
k = ieee80211_crypto_encap(ni, m0);
|
||||
if (k == NULL) {
|
||||
m_freem(m0);
|
||||
@ -1289,7 +1289,7 @@ ural_tx_data(struct ural_softc *sc, struct mbuf *m0, struct ieee80211_node *ni)
|
||||
else
|
||||
rate = ni->ni_txrate;
|
||||
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP) {
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) {
|
||||
k = ieee80211_crypto_encap(ni, m0);
|
||||
if (k == NULL) {
|
||||
m_freem(m0);
|
||||
|
@ -1697,7 +1697,7 @@ urtw_tx_start(struct urtw_softc *sc, struct ieee80211_node *ni, struct mbuf *m0,
|
||||
/*
|
||||
* Software crypto.
|
||||
*/
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP) {
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) {
|
||||
k = ieee80211_crypto_encap(ni, m0);
|
||||
if (k == NULL) {
|
||||
device_printf(sc->sc_dev,
|
||||
|
@ -1600,7 +1600,7 @@ urtwn_tx_start(struct urtwn_softc *sc, struct ieee80211_node *ni,
|
||||
* Software crypto.
|
||||
*/
|
||||
wh = mtod(m0, struct ieee80211_frame *);
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP) {
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) {
|
||||
k = ieee80211_crypto_encap(ni, m0);
|
||||
if (k == NULL) {
|
||||
device_printf(sc->sc_dev,
|
||||
|
@ -2507,7 +2507,7 @@ zyd_tx_start(struct zyd_softc *sc, struct mbuf *m0, struct ieee80211_node *ni)
|
||||
}
|
||||
}
|
||||
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP) {
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) {
|
||||
k = ieee80211_crypto_encap(ni, m0);
|
||||
if (k == NULL) {
|
||||
m_freem(m0);
|
||||
|
@ -1004,7 +1004,7 @@ wi_start_locked(struct ifnet *ifp)
|
||||
mtod(m0, const uint8_t *) + ieee80211_hdrsize(wh));
|
||||
frmhdr.wi_ehdr.ether_type = llc->llc_snap.ether_type;
|
||||
frmhdr.wi_tx_ctl = htole16(WI_ENC_TX_802_11|WI_TXCNTL_TX_EX);
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP) {
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) {
|
||||
k = ieee80211_crypto_encap(ni, m0);
|
||||
if (k == NULL) {
|
||||
ieee80211_free_node(ni);
|
||||
@ -1107,7 +1107,7 @@ wi_raw_xmit(struct ieee80211_node *ni, struct mbuf *m0,
|
||||
frmhdr.wi_tx_ctl = htole16(WI_ENC_TX_802_11|WI_TXCNTL_TX_EX);
|
||||
if (params && (params->ibp_flags & IEEE80211_BPF_NOACK))
|
||||
frmhdr.wi_tx_ctl |= htole16(WI_TXCNTL_ALTRTRY);
|
||||
if ((wh->i_fc[1] & IEEE80211_FC1_WEP) &&
|
||||
if ((wh->i_fc[1] & IEEE80211_FC1_PROTECTED) &&
|
||||
(!params || (params && (params->ibp_flags & IEEE80211_BPF_CRYPTO)))) {
|
||||
k = ieee80211_crypto_encap(ni, m0);
|
||||
if (k == NULL) {
|
||||
|
@ -1882,7 +1882,7 @@ wpi_tx_data(struct wpi_softc *sc, struct mbuf *m0, struct ieee80211_node *ni,
|
||||
hdrlen = ieee80211_hdrsize(wh);
|
||||
ismcast = IEEE80211_IS_MULTICAST(wh->i_addr1);
|
||||
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP) {
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) {
|
||||
k = ieee80211_crypto_encap(ni, m0);
|
||||
if (k == NULL) {
|
||||
m_freem(m0);
|
||||
@ -1951,7 +1951,7 @@ wpi_tx_data(struct wpi_softc *sc, struct mbuf *m0, struct ieee80211_node *ni,
|
||||
tap->wt_flags = 0;
|
||||
tap->wt_rate = rate;
|
||||
tap->wt_hwqueue = ac;
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP)
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED)
|
||||
tap->wt_flags |= IEEE80211_RADIOTAP_F_WEP;
|
||||
|
||||
ieee80211_radiotap_tx(vap, m0);
|
||||
|
@ -166,7 +166,7 @@ struct ieee80211_qosframe_addr4 {
|
||||
#define IEEE80211_FC1_RETRY 0x08
|
||||
#define IEEE80211_FC1_PWR_MGT 0x10
|
||||
#define IEEE80211_FC1_MORE_DATA 0x20
|
||||
#define IEEE80211_FC1_WEP 0x40
|
||||
#define IEEE80211_FC1_PROTECTED 0x40
|
||||
#define IEEE80211_FC1_ORDER 0x80
|
||||
|
||||
#define IEEE80211_SEQ_FRAG_MASK 0x000f
|
||||
|
@ -475,7 +475,7 @@ adhoc_input(struct ieee80211_node *ni, struct mbuf *m, int rssi, int nf)
|
||||
* crypto cipher modules used to do delayed update
|
||||
* of replay sequence numbers.
|
||||
*/
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP) {
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) {
|
||||
if ((vap->iv_flags & IEEE80211_F_PRIVACY) == 0) {
|
||||
/*
|
||||
* Discard encrypted frames when privacy is off.
|
||||
@ -493,7 +493,7 @@ adhoc_input(struct ieee80211_node *ni, struct mbuf *m, int rssi, int nf)
|
||||
goto out;
|
||||
}
|
||||
wh = mtod(m, struct ieee80211_frame *);
|
||||
wh->i_fc[1] &= ~IEEE80211_FC1_WEP;
|
||||
wh->i_fc[1] &= ~IEEE80211_FC1_PROTECTED;
|
||||
} else {
|
||||
/* XXX M_WEP and IEEE80211_F_PRIVACY */
|
||||
key = NULL;
|
||||
@ -631,7 +631,7 @@ adhoc_input(struct ieee80211_node *ni, struct mbuf *m, int rssi, int nf)
|
||||
ether_sprintf(wh->i_addr2), rssi);
|
||||
}
|
||||
#endif
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP) {
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) {
|
||||
IEEE80211_DISCARD(vap, IEEE80211_MSG_INPUT,
|
||||
wh, NULL, "%s", "WEP set but not permitted");
|
||||
vap->iv_stats.is_rx_mgtdiscard++; /* XXX */
|
||||
|
@ -694,7 +694,7 @@ hostap_input(struct ieee80211_node *ni, struct mbuf *m, int rssi, int nf)
|
||||
* crypto cipher modules used to do delayed update
|
||||
* of replay sequence numbers.
|
||||
*/
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP) {
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) {
|
||||
if ((vap->iv_flags & IEEE80211_F_PRIVACY) == 0) {
|
||||
/*
|
||||
* Discard encrypted frames when privacy is off.
|
||||
@ -712,7 +712,7 @@ hostap_input(struct ieee80211_node *ni, struct mbuf *m, int rssi, int nf)
|
||||
goto out;
|
||||
}
|
||||
wh = mtod(m, struct ieee80211_frame *);
|
||||
wh->i_fc[1] &= ~IEEE80211_FC1_WEP;
|
||||
wh->i_fc[1] &= ~IEEE80211_FC1_PROTECTED;
|
||||
} else {
|
||||
/* XXX M_WEP and IEEE80211_F_PRIVACY */
|
||||
key = NULL;
|
||||
@ -856,7 +856,7 @@ hostap_input(struct ieee80211_node *ni, struct mbuf *m, int rssi, int nf)
|
||||
ether_sprintf(wh->i_addr2), rssi);
|
||||
}
|
||||
#endif
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP) {
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) {
|
||||
if (subtype != IEEE80211_FC0_SUBTYPE_AUTH) {
|
||||
/*
|
||||
* Only shared key auth frames with a challenge
|
||||
@ -884,7 +884,7 @@ hostap_input(struct ieee80211_node *ni, struct mbuf *m, int rssi, int nf)
|
||||
goto out;
|
||||
}
|
||||
wh = mtod(m, struct ieee80211_frame *);
|
||||
wh->i_fc[1] &= ~IEEE80211_FC1_WEP;
|
||||
wh->i_fc[1] &= ~IEEE80211_FC1_PROTECTED;
|
||||
}
|
||||
/*
|
||||
* Pass the packet to radiotap before calling iv_recv_mgmt().
|
||||
|
@ -1825,7 +1825,7 @@ mesh_input(struct ieee80211_node *ni, struct mbuf *m, int rssi, int nf)
|
||||
ether_sprintf(wh->i_addr2), rssi);
|
||||
}
|
||||
#endif
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP) {
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) {
|
||||
IEEE80211_DISCARD(vap, IEEE80211_MSG_INPUT,
|
||||
wh, NULL, "%s", "WEP set but not permitted");
|
||||
vap->iv_stats.is_rx_mgtdiscard++; /* XXX */
|
||||
|
@ -772,7 +772,7 @@ ieee80211_mgmt_output(struct ieee80211_node *ni, struct mbuf *m, int type,
|
||||
if (params->ibp_flags & IEEE80211_BPF_CRYPTO) {
|
||||
IEEE80211_NOTE_MAC(vap, IEEE80211_MSG_AUTH, wh->i_addr1,
|
||||
"encrypting frame (%s)", __func__);
|
||||
wh->i_fc[1] |= IEEE80211_FC1_WEP;
|
||||
wh->i_fc[1] |= IEEE80211_FC1_PROTECTED;
|
||||
}
|
||||
m->m_flags |= M_ENCAP; /* mark encapsulated */
|
||||
|
||||
@ -1497,7 +1497,7 @@ ieee80211_encap(struct ieee80211vap *vap, struct ieee80211_node *ni,
|
||||
(vap->iv_opmode == IEEE80211_M_STA ?
|
||||
!IEEE80211_KEY_UNDEFINED(key) :
|
||||
!IEEE80211_KEY_UNDEFINED(&ni->ni_ucastkey)))) {
|
||||
wh->i_fc[1] |= IEEE80211_FC1_WEP;
|
||||
wh->i_fc[1] |= IEEE80211_FC1_PROTECTED;
|
||||
if (!ieee80211_crypto_enmic(vap, key, m, txfrag)) {
|
||||
IEEE80211_NOTE_MAC(vap, IEEE80211_MSG_OUTPUT,
|
||||
eh.ether_dhost,
|
||||
|
@ -448,7 +448,7 @@ ieee80211_dump_pkt(struct ieee80211com *ic,
|
||||
printf(" QoS [TID %u%s]", qwh->i_qos[0] & IEEE80211_QOS_TID,
|
||||
qwh->i_qos[0] & IEEE80211_QOS_ACKPOLICY ? " ACM" : "");
|
||||
}
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP) {
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) {
|
||||
int off;
|
||||
|
||||
off = ieee80211_anyhdrspace(ic, wh);
|
||||
|
@ -728,7 +728,7 @@ sta_input(struct ieee80211_node *ni, struct mbuf *m, int rssi, int nf)
|
||||
* crypto cipher modules used to do delayed update
|
||||
* of replay sequence numbers.
|
||||
*/
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP) {
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) {
|
||||
if ((vap->iv_flags & IEEE80211_F_PRIVACY) == 0) {
|
||||
/*
|
||||
* Discard encrypted frames when privacy is off.
|
||||
@ -746,7 +746,7 @@ sta_input(struct ieee80211_node *ni, struct mbuf *m, int rssi, int nf)
|
||||
goto out;
|
||||
}
|
||||
wh = mtod(m, struct ieee80211_frame *);
|
||||
wh->i_fc[1] &= ~IEEE80211_FC1_WEP;
|
||||
wh->i_fc[1] &= ~IEEE80211_FC1_PROTECTED;
|
||||
} else {
|
||||
/* XXX M_WEP and IEEE80211_F_PRIVACY */
|
||||
key = NULL;
|
||||
@ -881,7 +881,7 @@ sta_input(struct ieee80211_node *ni, struct mbuf *m, int rssi, int nf)
|
||||
ether_sprintf(wh->i_addr2), rssi);
|
||||
}
|
||||
#endif
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP) {
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) {
|
||||
if (subtype != IEEE80211_FC0_SUBTYPE_AUTH) {
|
||||
/*
|
||||
* Only shared key auth frames with a challenge
|
||||
@ -910,7 +910,7 @@ sta_input(struct ieee80211_node *ni, struct mbuf *m, int rssi, int nf)
|
||||
goto out;
|
||||
}
|
||||
wh = mtod(m, struct ieee80211_frame *);
|
||||
wh->i_fc[1] &= ~IEEE80211_FC1_WEP;
|
||||
wh->i_fc[1] &= ~IEEE80211_FC1_PROTECTED;
|
||||
}
|
||||
vap->iv_recv_mgmt(ni, m, subtype, rssi, nf);
|
||||
goto out;
|
||||
|
@ -557,7 +557,7 @@ wds_input(struct ieee80211_node *ni, struct mbuf *m, int rssi, int nf)
|
||||
* crypto cipher modules used to do delayed update
|
||||
* of replay sequence numbers.
|
||||
*/
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP) {
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) {
|
||||
if ((vap->iv_flags & IEEE80211_F_PRIVACY) == 0) {
|
||||
/*
|
||||
* Discard encrypted frames when privacy is off.
|
||||
@ -575,7 +575,7 @@ wds_input(struct ieee80211_node *ni, struct mbuf *m, int rssi, int nf)
|
||||
goto out;
|
||||
}
|
||||
wh = mtod(m, struct ieee80211_frame *);
|
||||
wh->i_fc[1] &= ~IEEE80211_FC1_WEP;
|
||||
wh->i_fc[1] &= ~IEEE80211_FC1_PROTECTED;
|
||||
} else {
|
||||
/* XXX M_WEP and IEEE80211_F_PRIVACY */
|
||||
key = NULL;
|
||||
@ -709,7 +709,7 @@ wds_input(struct ieee80211_node *ni, struct mbuf *m, int rssi, int nf)
|
||||
ether_sprintf(wh->i_addr2), rssi);
|
||||
}
|
||||
#endif
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP) {
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) {
|
||||
IEEE80211_DISCARD(vap, IEEE80211_MSG_INPUT,
|
||||
wh, NULL, "%s", "WEP set but not permitted");
|
||||
vap->iv_stats.is_rx_mgtdiscard++; /* XXX */
|
||||
|
@ -711,7 +711,7 @@ int get_packet_info(struct ieee80211_frame* wh,
|
||||
else if (type == IEEE80211_FC0_TYPE_DATA &&
|
||||
stype == IEEE80211_FC0_SUBTYPE_DATA) {
|
||||
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP) {
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) {
|
||||
unsigned char* iv;
|
||||
|
||||
node->wep = CRYPT_WEP;
|
||||
|
@ -509,7 +509,7 @@ void read_real_data(struct params *p, struct ieee80211_frame *wh, int len)
|
||||
memcpy(dst, wh->i_addr3, 6);
|
||||
|
||||
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP) {
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) {
|
||||
if (!p->wep_len) {
|
||||
printf("Got wep but i aint wep\n");
|
||||
return;
|
||||
@ -737,7 +737,7 @@ void read_tap(struct params *p)
|
||||
wh->i_fc[0] |= IEEE80211_FC0_TYPE_DATA;
|
||||
wh->i_fc[1] |= IEEE80211_FC1_DIR_FROMDS;
|
||||
if (p->wep_len)
|
||||
wh->i_fc[1] |= IEEE80211_FC1_WEP;
|
||||
wh->i_fc[1] |= IEEE80211_FC1_PROTECTED;
|
||||
|
||||
/* LLC & SNAP */
|
||||
ptr = (char*) (wh+1);
|
||||
|
@ -368,7 +368,7 @@ void generic_process(struct ieee80211_frame *wh, struct params *p, int len)
|
||||
|
||||
ptr = (char*) (wh + 1);
|
||||
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_WEP) {
|
||||
if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) {
|
||||
if (!p->wep_len) {
|
||||
char srca[3*6];
|
||||
char dsta[3*6];
|
||||
@ -676,7 +676,7 @@ void read_tap(struct params *p)
|
||||
wh->i_fc[0] |= IEEE80211_FC0_TYPE_DATA;
|
||||
wh->i_fc[1] |= IEEE80211_FC1_DIR_TODS;
|
||||
if (p->wep_len)
|
||||
wh->i_fc[1] |= IEEE80211_FC1_WEP;
|
||||
wh->i_fc[1] |= IEEE80211_FC1_PROTECTED;
|
||||
|
||||
/* LLC & SNAP */
|
||||
ptr = (char*) (wh+1);
|
||||
|
@ -99,7 +99,7 @@ int wanted(struct params *p, struct ieee80211_frame *wh, int len)
|
||||
if (memcmp(bssid, p->ap, 6) != 0)
|
||||
return 0;
|
||||
|
||||
if (!(wh->i_fc[1] & IEEE80211_FC1_WEP)) {
|
||||
if (!(wh->i_fc[1] & IEEE80211_FC1_PROTECTED)) {
|
||||
printf("Got non WEP packet...\n");
|
||||
return 0;
|
||||
}
|
||||
@ -197,7 +197,7 @@ void send_mcast(struct params *p, unsigned char x)
|
||||
wh->i_fc[0] |= IEEE80211_FC0_TYPE_DATA;
|
||||
wh->i_fc[0] |= IEEE80211_FC0_SUBTYPE_DATA;
|
||||
wh->i_fc[1] |= IEEE80211_FC1_DIR_TODS;
|
||||
wh->i_fc[1] |= IEEE80211_FC1_WEP;
|
||||
wh->i_fc[1] |= IEEE80211_FC1_PROTECTED;
|
||||
|
||||
wh->i_dur[0] = 0x69;
|
||||
|
||||
|
@ -190,7 +190,7 @@ void get_prga(struct params *p)
|
||||
if (memcmp(p->ap, bssid, 6) != 0)
|
||||
return;
|
||||
|
||||
if (!(wh->i_fc[1] & IEEE80211_FC1_WEP)) {
|
||||
if (!(wh->i_fc[1] & IEEE80211_FC1_PROTECTED)) {
|
||||
printf("Packet not WEP!\n");
|
||||
return;
|
||||
}
|
||||
@ -281,7 +281,7 @@ void send_frag(struct params *p)
|
||||
/* 802.11 */
|
||||
wh->i_fc[0] |= IEEE80211_FC0_TYPE_DATA;
|
||||
wh->i_fc[0] |= IEEE80211_FC0_SUBTYPE_DATA;
|
||||
wh->i_fc[1] |= IEEE80211_FC1_WEP;
|
||||
wh->i_fc[1] |= IEEE80211_FC1_PROTECTED;
|
||||
wh->i_fc[1] |= IEEE80211_FC1_DIR_TODS;
|
||||
if (!last)
|
||||
wh->i_fc[1] |= IEEE80211_FC1_MORE_FRAG;
|
||||
@ -527,7 +527,7 @@ void read_tap(struct params *p)
|
||||
wh = (struct ieee80211_frame*) p->packet;
|
||||
wh->i_fc[0] |= IEEE80211_FC0_TYPE_DATA;
|
||||
wh->i_fc[0] |= IEEE80211_FC0_SUBTYPE_DATA;
|
||||
wh->i_fc[1] |= IEEE80211_FC1_WEP;
|
||||
wh->i_fc[1] |= IEEE80211_FC1_PROTECTED;
|
||||
wh->i_fc[1] |= IEEE80211_FC1_DIR_TODS;
|
||||
|
||||
wh->i_dur[0] = 0x69;
|
||||
|
@ -140,7 +140,7 @@ int wanted(struct params *p, struct ieee80211_frame *wh, int len)
|
||||
if (memcmp(bssid, p->ap, 6) != 0)
|
||||
return 0;
|
||||
|
||||
if (!(wh->i_fc[1] & IEEE80211_FC1_WEP)) {
|
||||
if (!(wh->i_fc[1] & IEEE80211_FC1_PROTECTED)) {
|
||||
printf("Got non WEP packet...\n");
|
||||
return 0;
|
||||
}
|
||||
@ -268,7 +268,7 @@ void send_header(struct params *p, struct queue *q)
|
||||
wh->i_fc[0] |= IEEE80211_FC0_TYPE_DATA;
|
||||
wh->i_fc[0] |= IEEE80211_FC0_SUBTYPE_DATA;
|
||||
wh->i_fc[1] |= IEEE80211_FC1_DIR_TODS;
|
||||
wh->i_fc[1] |= IEEE80211_FC1_WEP;
|
||||
wh->i_fc[1] |= IEEE80211_FC1_PROTECTED;
|
||||
wh->i_fc[1] |= IEEE80211_FC1_MORE_FRAG;
|
||||
|
||||
wh->i_dur[0] = 0x69;
|
||||
@ -345,7 +345,7 @@ void send_data(struct params *p)
|
||||
wh->i_fc[0] |= IEEE80211_FC0_TYPE_DATA;
|
||||
wh->i_fc[0] |= IEEE80211_FC0_SUBTYPE_DATA;
|
||||
wh->i_fc[1] |= IEEE80211_FC1_DIR_TODS;
|
||||
wh->i_fc[1] |= IEEE80211_FC1_WEP;
|
||||
wh->i_fc[1] |= IEEE80211_FC1_PROTECTED;
|
||||
|
||||
wh->i_dur[0] = 0x69;
|
||||
|
||||
|
@ -1093,13 +1093,13 @@ void stuff_for_us(struct ieee80211_frame* wh, int len) {
|
||||
int dlen;
|
||||
dlen = len - sizeof(*wh) - 4 -4;
|
||||
|
||||
if (!( wh->i_fc[1] & IEEE80211_FC1_WEP)) {
|
||||
if (!( wh->i_fc[1] & IEEE80211_FC1_PROTECTED)) {
|
||||
time_print("WARNING: Got NON wep packet from %s dlen %d stype=%x\n",
|
||||
mac2str(wh->i_addr2), dlen, stype);
|
||||
return;
|
||||
}
|
||||
|
||||
assert (wh->i_fc[1] & IEEE80211_FC1_WEP);
|
||||
assert (wh->i_fc[1] & IEEE80211_FC1_PROTECTED);
|
||||
|
||||
if ((dlen == 36 || dlen == PADDED_ARPLEN) && rtrmac == (unsigned char*) 1) {
|
||||
rtrmac = (unsigned char *) malloc(6);
|
||||
@ -1577,7 +1577,8 @@ void stuff_for_net(struct ieee80211_frame* wh, int rd) {
|
||||
}
|
||||
|
||||
// wep data!
|
||||
if ( (wh->i_fc[1] & IEEE80211_FC1_WEP) && dlen > (4+8+4)) {
|
||||
if ( (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) &&
|
||||
dlen > (4+8+4)) {
|
||||
got_wep(wh, rd);
|
||||
}
|
||||
}
|
||||
@ -1768,7 +1769,7 @@ void prepare_fragstate(struct frag_state* fs, int pad) {
|
||||
fs->wh.i_fc[0] |= IEEE80211_FC0_TYPE_DATA;
|
||||
fs->wh.i_fc[1] |= IEEE80211_FC1_DIR_TODS |
|
||||
IEEE80211_FC1_MORE_FRAG |
|
||||
IEEE80211_FC1_WEP;
|
||||
IEEE80211_FC1_PROTECTED;
|
||||
|
||||
memset(&fs->data[8+8+20], 0, pad);
|
||||
}
|
||||
@ -1858,7 +1859,7 @@ void flood_inet(tx) {
|
||||
fill_basic(wh);
|
||||
|
||||
wh->i_fc[0] |= IEEE80211_FC0_TYPE_DATA;
|
||||
wh->i_fc[1] |= IEEE80211_FC1_WEP | IEEE80211_FC1_DIR_TODS;
|
||||
wh->i_fc[1] |= IEEE80211_FC1_PROTECTED | IEEE80211_FC1_DIR_TODS;
|
||||
memset(wh->i_addr3, 0xff, 6);
|
||||
|
||||
body = (unsigned char*) wh + sizeof(*wh);
|
||||
@ -1880,7 +1881,7 @@ void flood_inet(tx) {
|
||||
fill_basic(wh);
|
||||
|
||||
wh->i_fc[0] |= IEEE80211_FC0_TYPE_DATA;
|
||||
wh->i_fc[1] |= IEEE80211_FC1_WEP | IEEE80211_FC1_DIR_TODS;
|
||||
wh->i_fc[1] |= IEEE80211_FC1_PROTECTED | IEEE80211_FC1_DIR_TODS;
|
||||
memcpy(wh->i_addr3, rtrmac, 6);
|
||||
|
||||
body = (unsigned char*) wh + sizeof(*wh);
|
||||
@ -1975,7 +1976,7 @@ void send_arp(int tx, unsigned short op, unsigned char* srcip,
|
||||
fill_basic(wh);
|
||||
|
||||
wh->i_fc[0] |= IEEE80211_FC0_TYPE_DATA;
|
||||
wh->i_fc[1] |= IEEE80211_FC1_WEP | IEEE80211_FC1_DIR_TODS;
|
||||
wh->i_fc[1] |= IEEE80211_FC1_PROTECTED | IEEE80211_FC1_DIR_TODS;
|
||||
memset(wh->i_addr3, 0xff, 6);
|
||||
|
||||
body = (unsigned char*) wh + sizeof(*wh);
|
||||
@ -2254,7 +2255,7 @@ void read_tap() {
|
||||
fill_basic(wh);
|
||||
|
||||
wh->i_fc[0] |= IEEE80211_FC0_TYPE_DATA;
|
||||
wh->i_fc[1] |= IEEE80211_FC1_WEP | IEEE80211_FC1_DIR_TODS;
|
||||
wh->i_fc[1] |= IEEE80211_FC1_PROTECTED | IEEE80211_FC1_DIR_TODS;
|
||||
|
||||
memcpy(wh->i_addr2, eh->ether_shost, 6);
|
||||
memcpy(wh->i_addr3, eh->ether_dhost, 6);
|
||||
|
@ -600,7 +600,7 @@ int main(int argc, char *argv[])
|
||||
break;
|
||||
|
||||
case 'w':
|
||||
wh->i_fc[1] |= IEEE80211_FC1_WEP;
|
||||
wh->i_fc[1] |= IEEE80211_FC1_PROTECTED;
|
||||
break;
|
||||
|
||||
case 'o':
|
||||
|
Loading…
x
Reference in New Issue
Block a user