Commit 6f466168 authored by Ajay Singh's avatar Ajay Singh Committed by Greg Kroah-Hartman

staging: wilc1000: refactor scan() cfg80211 ops callback

Refactor scan() cfg80211 callback function and use correct value for
valid channel number limit.
Signed-off-by: default avatarAjay Singh <ajay.kathat@microchip.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 0ae6cb7a
...@@ -18,7 +18,7 @@ enum { ...@@ -18,7 +18,7 @@ enum {
}; };
#define WILC_MAX_NUM_STA 9 #define WILC_MAX_NUM_STA 9
#define MAX_NUM_SCANNED_NETWORKS 100 #define WILC_MAX_NUM_SCANNED_CH 14
#define WILC_MAX_NUM_PROBED_SSID 10 #define WILC_MAX_NUM_PROBED_SSID 10
#define TX_MIC_KEY_LEN 8 #define TX_MIC_KEY_LEN 8
......
...@@ -266,42 +266,41 @@ static int scan(struct wiphy *wiphy, struct cfg80211_scan_request *request) ...@@ -266,42 +266,41 @@ static int scan(struct wiphy *wiphy, struct cfg80211_scan_request *request)
struct wilc_vif *vif = netdev_priv(priv->dev); struct wilc_vif *vif = netdev_priv(priv->dev);
u32 i; u32 i;
int ret = 0; int ret = 0;
u8 scan_ch_list[MAX_NUM_SCANNED_NETWORKS]; u8 scan_ch_list[WILC_MAX_NUM_SCANNED_CH];
struct wilc_probe_ssid probe_ssid; struct wilc_probe_ssid probe_ssid;
priv->scan_req = request; if (request->n_channels > WILC_MAX_NUM_SCANNED_CH) {
netdev_err(priv->dev, "Requested scanned channels over\n");
return -EINVAL;
}
priv->scan_req = request;
priv->cfg_scanning = true; priv->cfg_scanning = true;
if (request->n_channels <= MAX_NUM_SCANNED_NETWORKS) { for (i = 0; i < request->n_channels; i++) {
for (i = 0; i < request->n_channels; i++) { u16 freq = request->channels[i]->center_freq;
u16 freq = request->channels[i]->center_freq;
scan_ch_list[i] = ieee80211_frequency_to_channel(freq);
}
if (request->n_ssids >= 1) { scan_ch_list[i] = ieee80211_frequency_to_channel(freq);
if (wilc_wfi_cfg_alloc_fill_ssid(request, }
&probe_ssid)) {
ret = -ENOMEM;
goto out;
}
ret = wilc_scan(vif, WILC_FW_USER_SCAN, if (request->n_ssids >= 1) {
WILC_FW_ACTIVE_SCAN, scan_ch_list, if (wilc_wfi_cfg_alloc_fill_ssid(request, &probe_ssid)) {
request->n_channels, ret = -ENOMEM;
(const u8 *)request->ie, goto out;
request->ie_len, cfg_scan_result,
(void *)priv, &probe_ssid);
} else {
ret = wilc_scan(vif, WILC_FW_USER_SCAN,
WILC_FW_ACTIVE_SCAN, scan_ch_list,
request->n_channels,
(const u8 *)request->ie,
request->ie_len, cfg_scan_result,
(void *)priv, NULL);
} }
ret = wilc_scan(vif, WILC_FW_USER_SCAN,
WILC_FW_ACTIVE_SCAN, scan_ch_list,
request->n_channels,
(const u8 *)request->ie,
request->ie_len, cfg_scan_result,
(void *)priv, &probe_ssid);
} else { } else {
netdev_err(priv->dev, "Requested scanned channels over\n"); ret = wilc_scan(vif, WILC_FW_USER_SCAN,
WILC_FW_ACTIVE_SCAN, scan_ch_list,
request->n_channels,
(const u8 *)request->ie,
request->ie_len, cfg_scan_result,
(void *)priv, NULL);
} }
out: out:
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment