@@ -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);