When operating as AP, save SSID data as part of the ieee80211_bss_conf struct. Allow low level drivers to receive notifications about SSID changes. Signed-off-by: Arik Nemtsov <arik@xxxxxxxxxx> --- include/net/mac80211.h | 6 ++++++ net/mac80211/cfg.c | 7 +++++++ net/mac80211/util.c | 7 ++++++- 3 files changed, 19 insertions(+), 1 deletions(-) diff --git a/include/net/mac80211.h b/include/net/mac80211.h index 62c0ce2..ff3bad1 100644 --- a/include/net/mac80211.h +++ b/include/net/mac80211.h @@ -164,6 +164,7 @@ struct ieee80211_low_level_stats { * @BSS_CHANGED_QOS: QoS for this association was enabled/disabled. Note * that it is only ever disabled for station mode. * @BSS_CHANGED_IDLE: Idle changed for this BSS/interface. + * @BSS_CHANGED_SSID: SSID changed for this BSS (AP mode) */ enum ieee80211_bss_change { BSS_CHANGED_ASSOC = 1<<0, @@ -181,6 +182,7 @@ enum ieee80211_bss_change { BSS_CHANGED_ARP_FILTER = 1<<12, BSS_CHANGED_QOS = 1<<13, BSS_CHANGED_IDLE = 1<<14, + BSS_CHANGED_SSID = 1<<15, /* when adding here, make sure to change ieee80211_reconfig */ }; @@ -243,6 +245,8 @@ enum ieee80211_bss_change { * @idle: This interface is idle. There's also a global idle flag in the * hardware config which may be more appropriate depending on what * your driver/device needs to do. + * @ssid_len: Length of @ssid in octets (in AP mode) + * @ssid: SSID for this BSS (in AP mode) */ struct ieee80211_bss_conf { const u8 *bssid; @@ -269,6 +273,8 @@ struct ieee80211_bss_conf { bool arp_filter_enabled; bool qos; bool idle; + u8 ssid_len; + u8 ssid[IEEE80211_MAX_SSID_LEN]; }; /** diff --git a/net/mac80211/cfg.c b/net/mac80211/cfg.c index 4bc8a92..a2a75e9 100644 --- a/net/mac80211/cfg.c +++ b/net/mac80211/cfg.c @@ -1172,6 +1172,13 @@ static int ieee80211_change_bss(struct wiphy *wiphy, changed |= BSS_CHANGED_HT; } + if (params->ssid_len > 0) { + memcpy(sdata->vif.bss_conf.ssid, params->ssid, + params->ssid_len); + sdata->vif.bss_conf.ssid_len = params->ssid_len; + changed |= BSS_CHANGED_SSID; + } + ieee80211_bss_info_change_notify(sdata, changed); return 0; diff --git a/net/mac80211/util.c b/net/mac80211/util.c index cf68700..a2d2f73 100644 --- a/net/mac80211/util.c +++ b/net/mac80211/util.c @@ -1212,10 +1212,15 @@ int ieee80211_reconfig(struct ieee80211_local *local) changed |= BSS_CHANGED_ASSOC; ieee80211_bss_info_change_notify(sdata, changed); break; + case NL80211_IFTYPE_AP: + changed |= BSS_CHANGED_SSID | + BSS_CHANGED_BEACON | + BSS_CHANGED_BEACON_ENABLED; + ieee80211_bss_info_change_notify(sdata, changed); + break; case NL80211_IFTYPE_ADHOC: changed |= BSS_CHANGED_IBSS; /* fall through */ - case NL80211_IFTYPE_AP: case NL80211_IFTYPE_MESH_POINT: changed |= BSS_CHANGED_BEACON | BSS_CHANGED_BEACON_ENABLED; -- 1.7.1 -- 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