svn commit: r279762 - head/sys/dev/wpi
Adrian Chadd
adrian at FreeBSD.org
Sun Mar 8 01:44:58 UTC 2015
Author: adrian
Date: Sun Mar 8 01:44:57 2015
New Revision: 279762
URL: https://svnweb.freebsd.org/changeset/base/279762
Log:
Use the correct mac addresses when initialising things.
PR: kern/197143
Submitted by: Andriy Voskoboinyk <s3rios at gmail.com>
Modified:
head/sys/dev/wpi/if_wpi.c
Modified: head/sys/dev/wpi/if_wpi.c
==============================================================================
--- head/sys/dev/wpi/if_wpi.c Sun Mar 8 00:47:50 2015 (r279761)
+++ head/sys/dev/wpi/if_wpi.c Sun Mar 8 01:44:57 2015 (r279762)
@@ -2926,7 +2926,7 @@ wpi_add_node(struct wpi_softc *sc, struc
return EINVAL;
memset(&node, 0, sizeof node);
- IEEE80211_ADDR_COPY(node.macaddr, ni->ni_bssid);
+ IEEE80211_ADDR_COPY(node.macaddr, ni->ni_macaddr);
node.id = wn->id;
node.plcp = (ic->ic_curmode == IEEE80211_MODE_11A) ?
wpi_ridx_to_plcp[WPI_RIDX_OFDM6] : wpi_ridx_to_plcp[WPI_RIDX_CCK1];
@@ -2993,7 +2993,7 @@ wpi_del_node(struct wpi_softc *sc, struc
}
memset(&node, 0, sizeof node);
- IEEE80211_ADDR_COPY(node.macaddr, ni->ni_bssid);
+ IEEE80211_ADDR_COPY(node.macaddr, ni->ni_macaddr);
node.count = 1;
error = wpi_cmd(sc, WPI_CMD_DEL_NODE, &node, sizeof node, 1);
@@ -3404,6 +3404,7 @@ wpi_config(struct wpi_softc *sc)
{
struct ifnet *ifp = sc->sc_ifp;
struct ieee80211com *ic = ifp->if_l2com;
+ struct ieee80211vap *vap = TAILQ_FIRST(&ic->ic_vaps);
uint32_t flags;
int error;
@@ -3425,7 +3426,7 @@ wpi_config(struct wpi_softc *sc)
/* Configure adapter. */
memset(&sc->rxon, 0, sizeof (struct wpi_rxon));
- IEEE80211_ADDR_COPY(sc->rxon.myaddr, IF_LLADDR(ifp));
+ IEEE80211_ADDR_COPY(sc->rxon.myaddr, vap->iv_myaddr);
/* Set default channel. */
sc->rxon.chan = ieee80211_chan2ieee(ic, ic->ic_curchan);
@@ -3559,6 +3560,7 @@ wpi_scan(struct wpi_softc *sc, struct ie
struct ifnet *ifp = sc->sc_ifp;
struct ieee80211com *ic = ifp->if_l2com;
struct ieee80211_scan_state *ss = ic->ic_scan;
+ struct ieee80211vap *vap = ss->ss_vap;
struct wpi_scan_hdr *hdr;
struct wpi_cmd_data *tx;
struct wpi_scan_essid *essids;
@@ -3645,7 +3647,7 @@ wpi_scan(struct wpi_softc *sc, struct ie
IEEE80211_FC0_SUBTYPE_PROBE_REQ;
wh->i_fc[1] = IEEE80211_FC1_DIR_NODS;
IEEE80211_ADDR_COPY(wh->i_addr1, ifp->if_broadcastaddr);
- IEEE80211_ADDR_COPY(wh->i_addr2, IF_LLADDR(ifp));
+ IEEE80211_ADDR_COPY(wh->i_addr2, vap->iv_myaddr);
IEEE80211_ADDR_COPY(wh->i_addr3, ifp->if_broadcastaddr);
*(uint16_t *)&wh->i_dur[0] = 0; /* filled by h/w */
*(uint16_t *)&wh->i_seq[0] = 0; /* filled by h/w */
More information about the svn-src-all
mailing list