提交 c5ca038f 编写于 作者: N nohee ko 提交者: Greg Kroah-Hartman

staging: brcm80211: brcmfmac: enable passive, active scan selection

Enable passive, active scan selection.
Previously it did active scan and reported
probe response result regardless of active_scan
flag
Signed-off-by: NNohee Ko <noheek@broadcom.com>
Signed-off-by: NGreg Kroah-Hartman <gregkh@suse.de>
上级 f49200c3
...@@ -732,6 +732,7 @@ static s32 wl_do_iscan(struct wl_priv *wl) ...@@ -732,6 +732,7 @@ static s32 wl_do_iscan(struct wl_priv *wl)
struct wl_iscan_ctrl *iscan = wl_to_iscan(wl); struct wl_iscan_ctrl *iscan = wl_to_iscan(wl);
struct net_device *ndev = wl_to_ndev(wl); struct net_device *ndev = wl_to_ndev(wl);
struct wlc_ssid ssid; struct wlc_ssid ssid;
s32 passive_scan;
s32 err = 0; s32 err = 0;
/* Broadcast scan by default */ /* Broadcast scan by default */
...@@ -739,15 +740,12 @@ static s32 wl_do_iscan(struct wl_priv *wl) ...@@ -739,15 +740,12 @@ static s32 wl_do_iscan(struct wl_priv *wl)
iscan->state = WL_ISCAN_STATE_SCANING; iscan->state = WL_ISCAN_STATE_SCANING;
if (wl->active_scan) { passive_scan = wl->active_scan ? 0 : 1;
s32 passive_scan = 0; err = wl_dev_ioctl(wl_to_ndev(wl), WLC_SET_PASSIVE_SCAN,
/* make it active scan */ &passive_scan, sizeof(passive_scan));
err = wl_dev_ioctl(wl_to_ndev(wl), WLC_SET_PASSIVE_SCAN, if (unlikely(err)) {
&passive_scan, sizeof(passive_scan)); WL_DBG(("error (%d)\n", err));
if (unlikely(err)) { return err;
WL_DBG(("error (%d)\n", err));
return err;
}
} }
wl_set_mpc(ndev, 0); wl_set_mpc(ndev, 0);
wl->iscan_kickstart = true; wl->iscan_kickstart = true;
...@@ -766,6 +764,7 @@ __wl_cfg80211_scan(struct wiphy *wiphy, struct net_device *ndev, ...@@ -766,6 +764,7 @@ __wl_cfg80211_scan(struct wiphy *wiphy, struct net_device *ndev,
struct wl_priv *wl = ndev_to_wl(ndev); struct wl_priv *wl = ndev_to_wl(ndev);
struct cfg80211_ssid *ssids; struct cfg80211_ssid *ssids;
struct wl_scan_req *sr = wl_to_sr(wl); struct wl_scan_req *sr = wl_to_sr(wl);
s32 passive_scan;
bool iscan_req; bool iscan_req;
bool spec_scan; bool spec_scan;
s32 err = 0; s32 err = 0;
...@@ -823,16 +822,12 @@ __wl_cfg80211_scan(struct wiphy *wiphy, struct net_device *ndev, ...@@ -823,16 +822,12 @@ __wl_cfg80211_scan(struct wiphy *wiphy, struct net_device *ndev,
WL_DBG(("Broadcast scan\n")); WL_DBG(("Broadcast scan\n"));
} }
WL_DBG(("sr->ssid.SSID_len (%d)\n", sr->ssid.SSID_len)); WL_DBG(("sr->ssid.SSID_len (%d)\n", sr->ssid.SSID_len));
if (wl->active_scan) { passive_scan = wl->active_scan ? 0 : 1;
s32 pssive_scan = 0; err = wl_dev_ioctl(ndev, WLC_SET_PASSIVE_SCAN,
/* make it active scan */ &passive_scan, sizeof(passive_scan));
err = wl_dev_ioctl(ndev, WLC_SET_PASSIVE_SCAN, if (unlikely(err)) {
&pssive_scan, sizeof(pssive_scan)); WL_ERR(("WLC_SET_PASSIVE_SCAN error (%d)\n", err));
if (unlikely(err)) { goto scan_out;
WL_ERR(("WLC_SET_PASSIVE_SCAN error (%d)\n",
err));
goto scan_out;
}
} }
wl_set_mpc(ndev, 0); wl_set_mpc(ndev, 0);
err = wl_dev_ioctl(ndev, WLC_SCAN, &sr->ssid, err = wl_dev_ioctl(ndev, WLC_SCAN, &sr->ssid,
...@@ -2264,6 +2259,8 @@ static s32 wl_inform_single_bss(struct wl_priv *wl, struct wl_bss_info *bi) ...@@ -2264,6 +2259,8 @@ static s32 wl_inform_single_bss(struct wl_priv *wl, struct wl_bss_info *bi)
struct ieee80211_supported_band *band; struct ieee80211_supported_band *band;
struct wl_cfg80211_bss_info *notif_bss_info; struct wl_cfg80211_bss_info *notif_bss_info;
struct wl_scan_req *sr = wl_to_sr(wl); struct wl_scan_req *sr = wl_to_sr(wl);
struct beacon_proberesp *beacon_proberesp;
s32 mgmt_type;
u32 signal; u32 signal;
u32 freq; u32 freq;
s32 err = 0; s32 err = 0;
...@@ -2289,13 +2286,18 @@ static s32 wl_inform_single_bss(struct wl_priv *wl, struct wl_bss_info *bi) ...@@ -2289,13 +2286,18 @@ static s32 wl_inform_single_bss(struct wl_priv *wl, struct wl_bss_info *bi)
band = wiphy->bands[IEEE80211_BAND_5GHZ]; band = wiphy->bands[IEEE80211_BAND_5GHZ];
notif_bss_info->rssi = bi->RSSI; notif_bss_info->rssi = bi->RSSI;
memcpy(mgmt->bssid, &bi->BSSID, ETHER_ADDR_LEN); memcpy(mgmt->bssid, &bi->BSSID, ETHER_ADDR_LEN);
mgmt_type = wl->active_scan ?
IEEE80211_STYPE_PROBE_RESP : IEEE80211_STYPE_BEACON;
if (!memcmp(bi->SSID, sr->ssid.SSID, bi->SSID_len)) { if (!memcmp(bi->SSID, sr->ssid.SSID, bi->SSID_len)) {
mgmt->frame_control = cpu_to_le16(IEEE80211_FTYPE_MGMT | mgmt->frame_control = cpu_to_le16(IEEE80211_FTYPE_MGMT |
IEEE80211_STYPE_PROBE_RESP); mgmt_type);
} }
mgmt->u.probe_resp.timestamp = 0; beacon_proberesp = wl->active_scan ?
mgmt->u.probe_resp.beacon_int = cpu_to_le16(bi->beacon_period); (struct beacon_proberesp *)&mgmt->u.probe_resp :
mgmt->u.probe_resp.capab_info = cpu_to_le16(bi->capability); (struct beacon_proberesp *)&mgmt->u.beacon;
beacon_proberesp->timestamp = 0;
beacon_proberesp->beacon_int = cpu_to_le16(bi->beacon_period);
beacon_proberesp->capab_info = cpu_to_le16(bi->capability);
wl_rst_ie(wl); wl_rst_ie(wl);
/* /*
* wl_add_ie is not necessary because it can only add duplicated * wl_add_ie is not necessary because it can only add duplicated
...@@ -2307,18 +2309,18 @@ static s32 wl_inform_single_bss(struct wl_priv *wl, struct wl_bss_info *bi) ...@@ -2307,18 +2309,18 @@ static s32 wl_inform_single_bss(struct wl_priv *wl, struct wl_bss_info *bi)
* bi->rateset.rates); * bi->rateset.rates);
*/ */
wl_mrg_ie(wl, ((u8 *) bi) + bi->ie_offset, bi->ie_length); wl_mrg_ie(wl, ((u8 *) bi) + bi->ie_offset, bi->ie_length);
wl_cp_ie(wl, mgmt->u.probe_resp.variable, WL_BSS_INFO_MAX - wl_cp_ie(wl, beacon_proberesp->variable, WL_BSS_INFO_MAX -
offsetof(struct wl_cfg80211_bss_info, frame_buf)); offsetof(struct wl_cfg80211_bss_info, frame_buf));
notif_bss_info->frame_len = notif_bss_info->frame_len =
offsetof(struct ieee80211_mgmt, offsetof(struct ieee80211_mgmt,
u.probe_resp.variable) + wl_get_ielen(wl); u.beacon.variable) + wl_get_ielen(wl);
freq = ieee80211_channel_to_frequency(notif_bss_info->channel); freq = ieee80211_channel_to_frequency(notif_bss_info->channel);
channel = ieee80211_get_channel(wiphy, freq); channel = ieee80211_get_channel(wiphy, freq);
WL_DBG(("SSID : \"%s\", rssi %d, channel %d, capability : 0x04%x, bssid %pM\n", WL_DBG(("SSID : \"%s\", rssi %d, channel %d, capability : 0x04%x, bssid %pM\n",
bi->SSID, bi->SSID,
notif_bss_info->rssi, notif_bss_info->channel, notif_bss_info->rssi, notif_bss_info->channel,
mgmt->u.probe_resp.capab_info, &bi->BSSID)); mgmt->u.beacon.capab_info, &bi->BSSID));
signal = notif_bss_info->rssi * 100; signal = notif_bss_info->rssi * 100;
if (unlikely(!cfg80211_inform_bss_frame(wiphy, channel, mgmt, if (unlikely(!cfg80211_inform_bss_frame(wiphy, channel, mgmt,
......
...@@ -151,6 +151,14 @@ enum wl_fw_status { ...@@ -151,6 +151,14 @@ enum wl_fw_status {
WL_NVRAM_LOADING_DONE WL_NVRAM_LOADING_DONE
}; };
/* beacon / probe_response */
struct beacon_proberesp {
__le64 timestamp;
__le16 beacon_int;
__le16 capab_info;
u8 variable[0];
} __attribute__ ((packed));
/* dongle configuration */ /* dongle configuration */
struct wl_conf { struct wl_conf {
u32 mode; /* adhoc , infrastructure or ap */ u32 mode; /* adhoc , infrastructure or ap */
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册