Commit e841b7b1 authored by Arend Van Spriel's avatar Arend Van Spriel Committed by Johannes Berg

nl80211: add FILS related parameters to ROAM event

In case of FILS shared key offload the parameters can change
upon roaming of which user-space needs to be notified.
Reviewed-by: default avatarJithu Jance <jithu.jance@broadcom.com>
Reviewed-by: default avatarEylon Pedinovsky <eylon.pedinovsky@broadcom.com>
Signed-off-by: default avatarArend van Spriel <arend.vanspriel@broadcom.com>
Signed-off-by: default avatarJohannes Berg <johannes.berg@intel.com>
parent 76804d28
...@@ -5624,6 +5624,7 @@ cfg80211_connect_timeout(struct net_device *dev, const u8 *bssid, ...@@ -5624,6 +5624,7 @@ cfg80211_connect_timeout(struct net_device *dev, const u8 *bssid,
* @req_ie_len: association request IEs length * @req_ie_len: association request IEs length
* @resp_ie: association response IEs (may be %NULL) * @resp_ie: association response IEs (may be %NULL)
* @resp_ie_len: assoc response IEs length * @resp_ie_len: assoc response IEs length
* @fils: FILS related roaming information.
*/ */
struct cfg80211_roam_info { struct cfg80211_roam_info {
struct ieee80211_channel *channel; struct ieee80211_channel *channel;
...@@ -5633,6 +5634,7 @@ struct cfg80211_roam_info { ...@@ -5633,6 +5634,7 @@ struct cfg80211_roam_info {
size_t req_ie_len; size_t req_ie_len;
const u8 *resp_ie; const u8 *resp_ie;
size_t resp_ie_len; size_t resp_ie_len;
struct cfg80211_fils_resp_params fils;
}; };
/** /**
......
...@@ -215,7 +215,8 @@ ...@@ -215,7 +215,8 @@
* as specified in IETF RFC 6696. * as specified in IETF RFC 6696.
* *
* When FILS shared key authentication is completed, driver needs to provide the * When FILS shared key authentication is completed, driver needs to provide the
* below additional parameters to userspace. * below additional parameters to userspace, which can be either after setting
* up a connection or after roaming.
* %NL80211_ATTR_FILS_KEK - used for key renewal * %NL80211_ATTR_FILS_KEK - used for key renewal
* %NL80211_ATTR_FILS_ERP_NEXT_SEQ_NUM - used in further EAP-RP exchanges * %NL80211_ATTR_FILS_ERP_NEXT_SEQ_NUM - used in further EAP-RP exchanges
* %NL80211_ATTR_PMKID - used to identify the PMKSA used/generated * %NL80211_ATTR_PMKID - used to identify the PMKSA used/generated
......
...@@ -14264,7 +14264,9 @@ void nl80211_send_roamed(struct cfg80211_registered_device *rdev, ...@@ -14264,7 +14264,9 @@ void nl80211_send_roamed(struct cfg80211_registered_device *rdev,
void *hdr; void *hdr;
const u8 *bssid = info->bss ? info->bss->bssid : info->bssid; const u8 *bssid = info->bss ? info->bss->bssid : info->bssid;
msg = nlmsg_new(100 + info->req_ie_len + info->resp_ie_len, gfp); msg = nlmsg_new(100 + info->req_ie_len + info->resp_ie_len +
info->fils.kek_len + info->fils.pmk_len +
(info->fils.pmkid ? WLAN_PMKID_LEN : 0), gfp);
if (!msg) if (!msg)
return; return;
...@@ -14282,7 +14284,17 @@ void nl80211_send_roamed(struct cfg80211_registered_device *rdev, ...@@ -14282,7 +14284,17 @@ void nl80211_send_roamed(struct cfg80211_registered_device *rdev,
info->req_ie)) || info->req_ie)) ||
(info->resp_ie && (info->resp_ie &&
nla_put(msg, NL80211_ATTR_RESP_IE, info->resp_ie_len, nla_put(msg, NL80211_ATTR_RESP_IE, info->resp_ie_len,
info->resp_ie))) info->resp_ie)) ||
(info->fils.update_erp_next_seq_num &&
nla_put_u16(msg, NL80211_ATTR_FILS_ERP_NEXT_SEQ_NUM,
info->fils.erp_next_seq_num)) ||
(info->fils.kek &&
nla_put(msg, NL80211_ATTR_FILS_KEK, info->fils.kek_len,
info->fils.kek)) ||
(info->fils.pmk &&
nla_put(msg, NL80211_ATTR_PMK, info->fils.pmk_len, info->fils.pmk)) ||
(info->fils.pmkid &&
nla_put(msg, NL80211_ATTR_PMKID, WLAN_PMKID_LEN, info->fils.pmkid)))
goto nla_put_failure; goto nla_put_failure;
genlmsg_end(msg, hdr); genlmsg_end(msg, hdr);
......
...@@ -932,6 +932,7 @@ void cfg80211_roamed(struct net_device *dev, struct cfg80211_roam_info *info, ...@@ -932,6 +932,7 @@ void cfg80211_roamed(struct net_device *dev, struct cfg80211_roam_info *info,
struct cfg80211_registered_device *rdev = wiphy_to_rdev(wdev->wiphy); struct cfg80211_registered_device *rdev = wiphy_to_rdev(wdev->wiphy);
struct cfg80211_event *ev; struct cfg80211_event *ev;
unsigned long flags; unsigned long flags;
u8 *next;
if (!info->bss) { if (!info->bss) {
info->bss = cfg80211_get_bss(wdev->wiphy, info->channel, info->bss = cfg80211_get_bss(wdev->wiphy, info->channel,
...@@ -944,19 +945,52 @@ void cfg80211_roamed(struct net_device *dev, struct cfg80211_roam_info *info, ...@@ -944,19 +945,52 @@ void cfg80211_roamed(struct net_device *dev, struct cfg80211_roam_info *info,
if (WARN_ON(!info->bss)) if (WARN_ON(!info->bss))
return; return;
ev = kzalloc(sizeof(*ev) + info->req_ie_len + info->resp_ie_len, gfp); ev = kzalloc(sizeof(*ev) + info->req_ie_len + info->resp_ie_len +
info->fils.kek_len + info->fils.pmk_len +
(info->fils.pmkid ? WLAN_PMKID_LEN : 0), gfp);
if (!ev) { if (!ev) {
cfg80211_put_bss(wdev->wiphy, info->bss); cfg80211_put_bss(wdev->wiphy, info->bss);
return; return;
} }
ev->type = EVENT_ROAMED; ev->type = EVENT_ROAMED;
ev->rm.req_ie = ((u8 *)ev) + sizeof(*ev); next = ((u8 *)ev) + sizeof(*ev);
ev->rm.req_ie_len = info->req_ie_len; if (info->req_ie_len) {
memcpy((void *)ev->rm.req_ie, info->req_ie, info->req_ie_len); ev->rm.req_ie = next;
ev->rm.resp_ie = ((u8 *)ev) + sizeof(*ev) + info->req_ie_len; ev->rm.req_ie_len = info->req_ie_len;
ev->rm.resp_ie_len = info->resp_ie_len; memcpy((void *)ev->rm.req_ie, info->req_ie, info->req_ie_len);
memcpy((void *)ev->rm.resp_ie, info->resp_ie, info->resp_ie_len); next += info->req_ie_len;
}
if (info->resp_ie_len) {
ev->rm.resp_ie = next;
ev->rm.resp_ie_len = info->resp_ie_len;
memcpy((void *)ev->rm.resp_ie, info->resp_ie,
info->resp_ie_len);
next += info->resp_ie_len;
}
if (info->fils.kek_len) {
ev->rm.fils.kek = next;
ev->rm.fils.kek_len = info->fils.kek_len;
memcpy((void *)ev->rm.fils.kek, info->fils.kek,
info->fils.kek_len);
next += info->fils.kek_len;
}
if (info->fils.pmk_len) {
ev->rm.fils.pmk = next;
ev->rm.fils.pmk_len = info->fils.pmk_len;
memcpy((void *)ev->rm.fils.pmk, info->fils.pmk,
info->fils.pmk_len);
next += info->fils.pmk_len;
}
if (info->fils.pmkid) {
ev->rm.fils.pmkid = next;
memcpy((void *)ev->rm.fils.pmkid, info->fils.pmkid,
WLAN_PMKID_LEN);
next += WLAN_PMKID_LEN;
}
ev->rm.fils.update_erp_next_seq_num = info->fils.update_erp_next_seq_num;
if (info->fils.update_erp_next_seq_num)
ev->rm.fils.erp_next_seq_num = info->fils.erp_next_seq_num;
ev->rm.bss = info->bss; ev->rm.bss = info->bss;
spin_lock_irqsave(&wdev->event_lock, flags); spin_lock_irqsave(&wdev->event_lock, flags);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment