aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--include/net/mac80211.h7
-rw-r--r--net/mac80211/ieee80211_i.h2
-rw-r--r--net/mac80211/mlme.c40
-rw-r--r--net/mac80211/trace.h4
4 files changed, 53 insertions, 0 deletions
diff --git a/include/net/mac80211.h b/include/net/mac80211.h
index dfa589b721b6..23803addca3c 100644
--- a/include/net/mac80211.h
+++ b/include/net/mac80211.h
@@ -208,6 +208,8 @@ struct ieee80211_chanctx_conf {
208 * @BSS_CHANGED_AP_PROBE_RESP: Probe Response changed for this BSS (AP mode) 208 * @BSS_CHANGED_AP_PROBE_RESP: Probe Response changed for this BSS (AP mode)
209 * @BSS_CHANGED_PS: PS changed for this BSS (STA mode) 209 * @BSS_CHANGED_PS: PS changed for this BSS (STA mode)
210 * @BSS_CHANGED_TXPOWER: TX power setting changed for this interface 210 * @BSS_CHANGED_TXPOWER: TX power setting changed for this interface
211 * @BSS_CHANGED_P2P_PS: P2P powersave settings (CTWindow, opportunistic PS)
212 * changed (currently only in P2P client mode, GO mode will be later)
211 */ 213 */
212enum ieee80211_bss_change { 214enum ieee80211_bss_change {
213 BSS_CHANGED_ASSOC = 1<<0, 215 BSS_CHANGED_ASSOC = 1<<0,
@@ -229,6 +231,7 @@ enum ieee80211_bss_change {
229 BSS_CHANGED_AP_PROBE_RESP = 1<<16, 231 BSS_CHANGED_AP_PROBE_RESP = 1<<16,
230 BSS_CHANGED_PS = 1<<17, 232 BSS_CHANGED_PS = 1<<17,
231 BSS_CHANGED_TXPOWER = 1<<18, 233 BSS_CHANGED_TXPOWER = 1<<18,
234 BSS_CHANGED_P2P_PS = 1<<19,
232 235
233 /* when adding here, make sure to change ieee80211_reconfig */ 236 /* when adding here, make sure to change ieee80211_reconfig */
234}; 237};
@@ -312,6 +315,8 @@ enum ieee80211_rssi_event {
312 * @ssid_len: Length of SSID given in @ssid. 315 * @ssid_len: Length of SSID given in @ssid.
313 * @hidden_ssid: The SSID of the current vif is hidden. Only valid in AP-mode. 316 * @hidden_ssid: The SSID of the current vif is hidden. Only valid in AP-mode.
314 * @txpower: TX power in dBm 317 * @txpower: TX power in dBm
318 * @p2p_ctwindow: P2P CTWindow, only for P2P client interfaces
319 * @p2p_oppps: P2P opportunistic PS is enabled
315 */ 320 */
316struct ieee80211_bss_conf { 321struct ieee80211_bss_conf {
317 const u8 *bssid; 322 const u8 *bssid;
@@ -345,6 +350,8 @@ struct ieee80211_bss_conf {
345 size_t ssid_len; 350 size_t ssid_len;
346 bool hidden_ssid; 351 bool hidden_ssid;
347 int txpower; 352 int txpower;
353 u8 p2p_ctwindow;
354 bool p2p_oppps;
348}; 355};
349 356
350/** 357/**
diff --git a/net/mac80211/ieee80211_i.h b/net/mac80211/ieee80211_i.h
index d272e0cabc37..e1fb97cc9a41 100644
--- a/net/mac80211/ieee80211_i.h
+++ b/net/mac80211/ieee80211_i.h
@@ -473,6 +473,8 @@ struct ieee80211_if_managed {
473 473
474 u8 use_4addr; 474 u8 use_4addr;
475 475
476 u8 p2p_noa_index;
477
476 /* Signal strength from the last Beacon frame in the current BSS. */ 478 /* Signal strength from the last Beacon frame in the current BSS. */
477 int last_beacon_signal; 479 int last_beacon_signal;
478 480
diff --git a/net/mac80211/mlme.c b/net/mac80211/mlme.c
index 02ffe8738243..61614461e089 100644
--- a/net/mac80211/mlme.c
+++ b/net/mac80211/mlme.c
@@ -1365,6 +1365,22 @@ static void ieee80211_set_associated(struct ieee80211_sub_if_data *sdata,
1365 1365
1366 sdata->u.mgd.flags |= IEEE80211_STA_RESET_SIGNAL_AVE; 1366 sdata->u.mgd.flags |= IEEE80211_STA_RESET_SIGNAL_AVE;
1367 1367
1368 if (sdata->vif.p2p) {
1369 u8 noa[2];
1370 int ret;
1371
1372 ret = cfg80211_get_p2p_attr(cbss->information_elements,
1373 cbss->len_information_elements,
1374 IEEE80211_P2P_ATTR_ABSENCE_NOTICE,
1375 noa, sizeof(noa));
1376 if (ret >= 2) {
1377 bss_conf->p2p_oppps = noa[1] & 0x80;
1378 bss_conf->p2p_ctwindow = noa[1] & 0x7f;
1379 bss_info_changed |= BSS_CHANGED_P2P_PS;
1380 sdata->u.mgd.p2p_noa_index = noa[0];
1381 }
1382 }
1383
1368 /* just to be sure */ 1384 /* just to be sure */
1369 ieee80211_stop_poll(sdata); 1385 ieee80211_stop_poll(sdata);
1370 1386
@@ -1487,6 +1503,9 @@ static void ieee80211_set_disassoc(struct ieee80211_sub_if_data *sdata,
1487 changed |= BSS_CHANGED_ASSOC; 1503 changed |= BSS_CHANGED_ASSOC;
1488 sdata->vif.bss_conf.assoc = false; 1504 sdata->vif.bss_conf.assoc = false;
1489 1505
1506 sdata->vif.bss_conf.p2p_ctwindow = 0;
1507 sdata->vif.bss_conf.p2p_oppps = false;
1508
1490 /* on the next assoc, re-program HT parameters */ 1509 /* on the next assoc, re-program HT parameters */
1491 memset(&ifmgd->ht_capa, 0, sizeof(ifmgd->ht_capa)); 1510 memset(&ifmgd->ht_capa, 0, sizeof(ifmgd->ht_capa));
1492 memset(&ifmgd->ht_capa_mask, 0, sizeof(ifmgd->ht_capa_mask)); 1511 memset(&ifmgd->ht_capa_mask, 0, sizeof(ifmgd->ht_capa_mask));
@@ -2594,6 +2613,27 @@ static void ieee80211_rx_mgmt_beacon(struct ieee80211_sub_if_data *sdata,
2594 } 2613 }
2595 } 2614 }
2596 2615
2616 if (sdata->vif.p2p) {
2617 u8 noa[2];
2618 int ret;
2619
2620 ret = cfg80211_get_p2p_attr(mgmt->u.beacon.variable,
2621 len - baselen,
2622 IEEE80211_P2P_ATTR_ABSENCE_NOTICE,
2623 noa, sizeof(noa));
2624 if (ret >= 2 && sdata->u.mgd.p2p_noa_index != noa[0]) {
2625 bss_conf->p2p_oppps = noa[1] & 0x80;
2626 bss_conf->p2p_ctwindow = noa[1] & 0x7f;
2627 changed |= BSS_CHANGED_P2P_PS;
2628 sdata->u.mgd.p2p_noa_index = noa[0];
2629 /*
2630 * make sure we update all information, the CRC
2631 * mechanism doesn't look at P2P attributes.
2632 */
2633 ifmgd->beacon_crc_valid = false;
2634 }
2635 }
2636
2597 if (ncrc == ifmgd->beacon_crc && ifmgd->beacon_crc_valid) 2637 if (ncrc == ifmgd->beacon_crc && ifmgd->beacon_crc_valid)
2598 return; 2638 return;
2599 ifmgd->beacon_crc = ncrc; 2639 ifmgd->beacon_crc = ncrc;
diff --git a/net/mac80211/trace.h b/net/mac80211/trace.h
index eeebbd9cb888..7794e533989a 100644
--- a/net/mac80211/trace.h
+++ b/net/mac80211/trace.h
@@ -343,6 +343,8 @@ TRACE_EVENT(drv_bss_info_changed,
343 __dynamic_array(u8, ssid, info->ssid_len); 343 __dynamic_array(u8, ssid, info->ssid_len);
344 __field(bool, hidden_ssid); 344 __field(bool, hidden_ssid);
345 __field(int, txpower) 345 __field(int, txpower)
346 __field(u8, p2p_ctwindow)
347 __field(bool, p2p_oppps)
346 ), 348 ),
347 349
348 TP_fast_assign( 350 TP_fast_assign(
@@ -378,6 +380,8 @@ TRACE_EVENT(drv_bss_info_changed,
378 memcpy(__get_dynamic_array(ssid), info->ssid, info->ssid_len); 380 memcpy(__get_dynamic_array(ssid), info->ssid, info->ssid_len);
379 __entry->hidden_ssid = info->hidden_ssid; 381 __entry->hidden_ssid = info->hidden_ssid;
380 __entry->txpower = info->txpower; 382 __entry->txpower = info->txpower;
383 __entry->p2p_ctwindow = info->p2p_ctwindow;
384 __entry->p2p_oppps = info->p2p_oppps;
381 ), 385 ),
382 386
383 TP_printk( 387 TP_printk(