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 <[email protected]>

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 */
_______________________________________________
[email protected] mailing list
http://lists.freebsd.org/mailman/listinfo/svn-src-head
To unsubscribe, send any mail to "[email protected]"

Reply via email to