Search Linux Wireless

Re: [PATCH 11/20] ath6kl: Support channel set request for startscan command

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Monday 29 August 2011 05:53 PM, Jouni Malinen wrote:
From: Edward Lu<elu@xxxxxxxxxxxxxxxx>

Signed-off-by: Edward Lu<elu@xxxxxxxxxxxxxxxx>
Signed-off-by: Jouni Malinen<jouni@xxxxxxxxxxxxxxxx>
---
  drivers/net/wireless/ath/ath6kl/cfg80211.c |   23 ++++++++++++++++++++++-
  drivers/net/wireless/ath/ath6kl/wmi.c      |    8 +++++---
  2 files changed, 27 insertions(+), 4 deletions(-)

diff --git a/drivers/net/wireless/ath/ath6kl/cfg80211.c b/drivers/net/wireless/ath/ath6kl/cfg80211.c
index d287f0a..e78d332 100644
--- a/drivers/net/wireless/ath/ath6kl/cfg80211.c
+++ b/drivers/net/wireless/ath/ath6kl/cfg80211.c
@@ -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))
@@ -785,14 +787,33 @@ static int ath6kl_cfg80211_scan(struct wiphy *wiphy, struct net_device *ndev,
  		}
  	}

+	if (request->n_channels>  0) {
+		u8 i;
+
+		n_channels = (request->n_channels>  127) ?
+				127 : request->n_channels;
+
+		channels = kzalloc(n_channels * sizeof(u16), GFP_KERNEL);
+		if (channels == NULL) {
+			ath6kl_err("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");

kfree(channels) for failure cases ??

  		ret = -EIO;
  	}

  	ar->scan_req = request;

+	kfree(channels);
+
  	return ret;
  }

diff --git a/drivers/net/wireless/ath/ath6kl/wmi.c b/drivers/net/wireless/ath/ath6kl/wmi.c
index 2d80bdb..87e4d65 100644
--- a/drivers/net/wireless/ath/ath6kl/wmi.c
+++ b/drivers/net/wireless/ath/ath6kl/wmi.c
@@ -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,10 @@ 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));
+	if (num_chan) {
+		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);
--
To unsubscribe from this list: send the line "unsubscribe linux-wireless" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Linux Host AP]     [ATH6KL]     [Linux Bluetooth]     [Linux Netdev]     [Kernel Newbies]     [Linux Kernel]     [IDE]     [Security]     [Git]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux ATA RAID]     [Samba]     [Device Mapper]
  Powered by Linux