summaryrefslogtreecommitdiffstats
path: root/net/wireless/nl80211.c
diff options
context:
space:
mode:
authorArunk Khandavalli <akhandav@codeaurora.org>2018-08-29 23:40:16 +0200
committerJohannes Berg <johannes.berg@intel.com>2018-08-30 09:58:21 +0200
commit4f0223bfe9c3e62d8f45a85f1ef1b18a8a263ef9 (patch)
tree3c5f43900e57afe26cec4f45eec5c9b4e5ff45ab /net/wireless/nl80211.c
parentmac80211: avoid kernel panic when building AMSDU from non-linear SKB (diff)
downloadlinux-4f0223bfe9c3e62d8f45a85f1ef1b18a8a263ef9.tar.xz
linux-4f0223bfe9c3e62d8f45a85f1ef1b18a8a263ef9.zip
cfg80211: nl80211_update_ft_ies() to validate NL80211_ATTR_IE
nl80211_update_ft_ies() tried to validate NL80211_ATTR_IE with is_valid_ie_attr() before dereferencing it, but that helper function returns true in case of NULL pointer (i.e., attribute not included). This can result to dereferencing a NULL pointer. Fix that by explicitly checking that NL80211_ATTR_IE is included. Fixes: 355199e02b83 ("cfg80211: Extend support for IEEE 802.11r Fast BSS Transition") Signed-off-by: Arunk Khandavalli <akhandav@codeaurora.org> Signed-off-by: Jouni Malinen <jouni@codeaurora.org> Signed-off-by: Johannes Berg <johannes.berg@intel.com>
Diffstat (limited to '')
-rw-r--r--net/wireless/nl80211.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/net/wireless/nl80211.c b/net/wireless/nl80211.c
index ce0149a86c13..733ccf867972 100644
--- a/net/wireless/nl80211.c
+++ b/net/wireless/nl80211.c
@@ -12099,6 +12099,7 @@ static int nl80211_update_ft_ies(struct sk_buff *skb, struct genl_info *info)
return -EOPNOTSUPP;
if (!info->attrs[NL80211_ATTR_MDID] ||
+ !info->attrs[NL80211_ATTR_IE] ||
!is_valid_ie_attr(info->attrs[NL80211_ATTR_IE]))
return -EINVAL;