diff mbox

[RFC,15/15] mac80211: create and pass the ies for each band in periodic scans

Message ID 1288612336-2830-16-git-send-email-luciano.coelho@nokia.com (mailing list archive)
State Not Applicable, archived
Headers show

Commit Message

Luciano Coelho Nov. 1, 2010, 11:52 a.m. UTC
None
diff mbox

Patch

diff --git a/net/mac80211/scan.c b/net/mac80211/scan.c
index fda8d41..2e7661f 100644
--- a/net/mac80211/scan.c
+++ b/net/mac80211/scan.c
@@ -828,7 +828,7 @@  int ieee80211_request_periodic_start(struct ieee80211_sub_if_data *sdata,
 				     struct cfg80211_periodic_request *req)
 {
 	struct ieee80211_local *local = sdata->local;
-	int ret;
+	int ret, i;
 
 	mutex_lock(&sdata->local->mtx);
 
@@ -844,6 +844,16 @@  int ieee80211_request_periodic_start(struct ieee80211_sub_if_data *sdata,
 		goto out;
 	}
 
+	for (i = 0; i < IEEE80211_NUM_BANDS; i++) {
+		req->ie[i] = kzalloc(2 + IEEE80211_MAX_SSID_LEN +
+				     local->scan_ies_len, GFP_KERNEL);
+
+		req->ie_len[i] = ieee80211_build_preq_ies(local,
+							  (u8 *) req->ie[i],
+							  NULL, 0, i,
+							  (u32) -1, 0);
+	}
+
 	local->periodic_req = req;
 
 	ret = drv_periodic_start(local, sdata, req);
@@ -860,7 +870,7 @@  out:
 int ieee80211_request_periodic_stop(struct ieee80211_sub_if_data *sdata)
 {
 	struct ieee80211_local *local = sdata->local;
-	int ret = 0;
+	int ret = 0, i;
 
 	mutex_lock(&sdata->local->mtx);
 
@@ -870,6 +880,9 @@  int ieee80211_request_periodic_stop(struct ieee80211_sub_if_data *sdata)
 	}
 
 	if (local->periodic_req) {
+		for (i = 0; i < IEEE80211_NUM_BANDS; i++)
+			kfree(local->periodic_req->ie[i]);
+
 		ret = drv_periodic_stop(local, sdata);
 		local->periodic_req = NULL;
 		__clear_bit(SCAN_PERIODIC_SCANNING, &local->scanning);