Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 1276c9ef authored by Edward Lu's avatar Edward Lu Committed by Kalle Valo
Browse files

ath6kl: Support channel set request for startscan command

parent b84da8c7
Loading
Loading
Loading
Loading
+21 −1
Original line number Original line Diff line number Diff line
@@ -748,6 +748,8 @@ static int ath6kl_cfg80211_scan(struct wiphy *wiphy, struct net_device *ndev,
				struct cfg80211_scan_request *request)
				struct cfg80211_scan_request *request)
{
{
	struct ath6kl *ar = (struct ath6kl *)ath6kl_priv(ndev);
	struct ath6kl *ar = (struct ath6kl *)ath6kl_priv(ndev);
	s8 n_channels = 0;
	u16 *channels = NULL;
	int ret = 0;
	int ret = 0;


	if (!ath6kl_cfg80211_ready(ar))
	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,
	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");
		ath6kl_err("wmi_startscan_cmd failed\n");
		ret = -EIO;
		ret = -EIO;
	}
	}


	ar->scan_req = request;
	ar->scan_req = request;


	kfree(channels);

	return ret;
	return ret;
}
}


+3 −3
Original line number Original line Diff line number Diff line
@@ -1709,7 +1709,7 @@ int ath6kl_wmi_startscan_cmd(struct wmi *wmi, enum wmi_scan_type scan_type,
	struct sk_buff *skb;
	struct sk_buff *skb;
	struct wmi_start_scan_cmd *sc;
	struct wmi_start_scan_cmd *sc;
	s8 size;
	s8 size;
	int ret;
	int i, ret;


	size = sizeof(struct wmi_start_scan_cmd);
	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->force_scan_intvl = cpu_to_le32(force_scan_interval);
	sc->num_ch = num_chan;
	sc->num_ch = num_chan;


	if (num_chan)
	for (i = 0; i < num_chan; i++)
		memcpy(sc->ch_list, ch_list, num_chan * sizeof(u16));
		sc->ch_list[i] = cpu_to_le16(ch_list[i]);


	ret = ath6kl_wmi_cmd_send(wmi, skb, WMI_START_SCAN_CMDID,
	ret = ath6kl_wmi_cmd_send(wmi, skb, WMI_START_SCAN_CMDID,
				  NO_SYNC_WMIFLAG);
				  NO_SYNC_WMIFLAG);