From: Purushottam Kushwaha Date: Thu, 11 Aug 2016 09:44:02 +0000 (+0530) Subject: cfg80211: identically validate beacon interval for AP/MESH/IBSS X-Git-Url: http://git.osdn.net/view?a=commitdiff_plain;h=9a27bdb53fe5b7a0cf07c4aa3226ce8b9c9a14ad;p=sagit-ice-cold%2Fkernel_xiaomi_msm8998.git cfg80211: identically validate beacon interval for AP/MESH/IBSS Beacon interval interface combinations validation was missing for MESH/IBSS join, add those. Johannes: also move the beacon interval check disallowing really tiny and really big intervals into the common function, which adds it for AP mode. CRs-Fixed: 1087922 Change-Id: I282300533dcd80f65c9ba366246d028a6130ffff Signed-off-by: Purushottam Kushwaha Signed-off-by: Johannes Berg Git-repo: git://git.kernel.org/pub/scm/linux/kernel/git/kvalo/ath.git Git-commit: 12d20fc9186a742d40e824f575df5aa62be31d69 [liord@codeaurora.org: fix conflicts and trivial compile errors] Signed-off-by: Lior David --- diff --git a/net/wireless/nl80211.c b/net/wireless/nl80211.c index 862c26bb63d2..375d6c1732fa 100644 --- a/net/wireless/nl80211.c +++ b/net/wireless/nl80211.c @@ -7770,12 +7770,14 @@ static int nl80211_join_ibss(struct sk_buff *skb, struct genl_info *info) ibss.beacon_interval = 100; - if (info->attrs[NL80211_ATTR_BEACON_INTERVAL]) { + if (info->attrs[NL80211_ATTR_BEACON_INTERVAL]) ibss.beacon_interval = nla_get_u32(info->attrs[NL80211_ATTR_BEACON_INTERVAL]); - if (ibss.beacon_interval < 1 || ibss.beacon_interval > 10000) - return -EINVAL; - } + + err = cfg80211_validate_beacon_int(rdev, NL80211_IFTYPE_ADHOC, + ibss.beacon_interval); + if (err) + return err; if (!rdev->ops->join_ibss) return -EOPNOTSUPP; @@ -9013,9 +9015,12 @@ static int nl80211_join_mesh(struct sk_buff *skb, struct genl_info *info) if (info->attrs[NL80211_ATTR_BEACON_INTERVAL]) { setup.beacon_interval = nla_get_u32(info->attrs[NL80211_ATTR_BEACON_INTERVAL]); - if (setup.beacon_interval < 10 || - setup.beacon_interval > 10000) - return -EINVAL; + + err = cfg80211_validate_beacon_int(rdev, + NL80211_IFTYPE_MESH_POINT, + setup.beacon_interval); + if (err) + return err; } if (info->attrs[NL80211_ATTR_DTIM_PERIOD]) { diff --git a/net/wireless/util.c b/net/wireless/util.c index 71fcbcbb9caa..5fdeb1107fe6 100644 --- a/net/wireless/util.c +++ b/net/wireless/util.c @@ -1490,7 +1490,7 @@ int cfg80211_validate_beacon_int(struct cfg80211_registered_device *rdev, .beacon_int_gcd = beacon_int, /* GCD(n) = n */ }; - if (!beacon_int) + if (beacon_int < 10 || beacon_int > 10000) return -EINVAL; params.iftype_num[iftype] = 1;