mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-08-05 16:54:27 +00:00
ath6kl: Support channel set request for startscan command
Signed-off-by: Edward Lu <elu@qca.qualcomm.com> Signed-off-by: Jouni Malinen <jouni@qca.qualcomm.com> Signed-off-by: Kalle Valo <kvalo@qca.qualcomm.com>
This commit is contained in:
parent
b84da8c738
commit
1276c9ef6d
2 changed files with 24 additions and 4 deletions
|
@ -748,6 +748,8 @@ static int ath6kl_cfg80211_scan(struct wiphy *wiphy, struct net_device *ndev,
|
|||
struct cfg80211_scan_request *request)
|
||||
{
|
||||
struct ath6kl *ar = (struct ath6kl *)ath6kl_priv(ndev);
|
||||
s8 n_channels = 0;
|
||||
u16 *channels = NULL;
|
||||
int ret = 0;
|
||||
|
||||
if (!ath6kl_cfg80211_ready(ar))
|
||||
|
@ -786,14 +788,32 @@ static int ath6kl_cfg80211_scan(struct wiphy *wiphy, struct net_device *ndev,
|
|||
}
|
||||
}
|
||||
|
||||
if (request->n_channels > 0) {
|
||||
u8 i;
|
||||
|
||||
n_channels = min(127U, request->n_channels);
|
||||
|
||||
channels = kzalloc(n_channels * sizeof(u16), GFP_KERNEL);
|
||||
if (channels == NULL) {
|
||||
ath6kl_warn("failed to set scan channels, "
|
||||
"scan all channels");
|
||||
n_channels = 0;
|
||||
}
|
||||
|
||||
for (i = 0; i < n_channels; i++)
|
||||
channels[i] = request->channels[i]->center_freq;
|
||||
}
|
||||
|
||||
if (ath6kl_wmi_startscan_cmd(ar->wmi, WMI_LONG_SCAN, 0,
|
||||
false, 0, 0, 0, NULL) != 0) {
|
||||
false, 0, 0, n_channels, channels) != 0) {
|
||||
ath6kl_err("wmi_startscan_cmd failed\n");
|
||||
ret = -EIO;
|
||||
}
|
||||
|
||||
ar->scan_req = request;
|
||||
|
||||
kfree(channels);
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
|
|
|
@ -1709,7 +1709,7 @@ int ath6kl_wmi_startscan_cmd(struct wmi *wmi, enum wmi_scan_type scan_type,
|
|||
struct sk_buff *skb;
|
||||
struct wmi_start_scan_cmd *sc;
|
||||
s8 size;
|
||||
int ret;
|
||||
int i, ret;
|
||||
|
||||
size = sizeof(struct wmi_start_scan_cmd);
|
||||
|
||||
|
@ -1734,8 +1734,8 @@ int ath6kl_wmi_startscan_cmd(struct wmi *wmi, enum wmi_scan_type scan_type,
|
|||
sc->force_scan_intvl = cpu_to_le32(force_scan_interval);
|
||||
sc->num_ch = num_chan;
|
||||
|
||||
if (num_chan)
|
||||
memcpy(sc->ch_list, ch_list, num_chan * sizeof(u16));
|
||||
for (i = 0; i < num_chan; i++)
|
||||
sc->ch_list[i] = cpu_to_le16(ch_list[i]);
|
||||
|
||||
ret = ath6kl_wmi_cmd_send(wmi, skb, WMI_START_SCAN_CMDID,
|
||||
NO_SYNC_WMIFLAG);
|
||||
|
|
Loading…
Add table
Reference in a new issue