diff options
author | Thadeu Lima de Souza Cascardo <cascardo@holoscopio.com> | 2010-02-12 09:34:50 -0500 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2010-02-15 16:12:52 -0500 |
commit | 0e956c132f822d414a4ce84726ac1d1294364581 (patch) | |
tree | f5c0d031606d3aa4abb6ac2468ce5263d1e17993 | |
parent | 2f5265e6e785b2a666dd985ea157bc8c260be8fa (diff) |
nl80211: does not allow NEW_STATION and DEL_STATION for mesh
As discussed in linux-wireless mailing list, adding and removing
stations for mesh topologies is not necessary. Since doing it triggers
bugs, the sugestion was to simply disable it.
Tested using a custom iw command "station new". Works only after using
hostapd. "station del" command also works.
Signed-off-by: Thadeu Lima de Souza Cascardo <cascardo@holoscopio.com>
Cc: Johannes Berg <johannes@sipsolutions.net>
Cc: Simon Raffeiner <sturmflut@lieberbiber.de>
Cc: Andrey Yurovsky <andrey@cozybit.com>
Cc: Javier Cardona <javier@cozybit.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
-rw-r--r-- | net/wireless/nl80211.c | 49 |
1 files changed, 13 insertions, 36 deletions
diff --git a/net/wireless/nl80211.c b/net/wireless/nl80211.c index 5b79ecf17bea..a95ab9e4c19e 100644 --- a/net/wireless/nl80211.c +++ b/net/wireless/nl80211.c | |||
@@ -2010,6 +2010,9 @@ static int nl80211_new_station(struct sk_buff *skb, struct genl_info *info) | |||
2010 | if (!info->attrs[NL80211_ATTR_STA_SUPPORTED_RATES]) | 2010 | if (!info->attrs[NL80211_ATTR_STA_SUPPORTED_RATES]) |
2011 | return -EINVAL; | 2011 | return -EINVAL; |
2012 | 2012 | ||
2013 | if (!info->attrs[NL80211_ATTR_STA_AID]) | ||
2014 | return -EINVAL; | ||
2015 | |||
2013 | mac_addr = nla_data(info->attrs[NL80211_ATTR_MAC]); | 2016 | mac_addr = nla_data(info->attrs[NL80211_ATTR_MAC]); |
2014 | params.supported_rates = | 2017 | params.supported_rates = |
2015 | nla_data(info->attrs[NL80211_ATTR_STA_SUPPORTED_RATES]); | 2018 | nla_data(info->attrs[NL80211_ATTR_STA_SUPPORTED_RATES]); |
@@ -2018,11 +2021,9 @@ static int nl80211_new_station(struct sk_buff *skb, struct genl_info *info) | |||
2018 | params.listen_interval = | 2021 | params.listen_interval = |
2019 | nla_get_u16(info->attrs[NL80211_ATTR_STA_LISTEN_INTERVAL]); | 2022 | nla_get_u16(info->attrs[NL80211_ATTR_STA_LISTEN_INTERVAL]); |
2020 | 2023 | ||
2021 | if (info->attrs[NL80211_ATTR_STA_AID]) { | 2024 | params.aid = nla_get_u16(info->attrs[NL80211_ATTR_STA_AID]); |
2022 | params.aid = nla_get_u16(info->attrs[NL80211_ATTR_STA_AID]); | 2025 | if (!params.aid || params.aid > IEEE80211_MAX_AID) |
2023 | if (!params.aid || params.aid > IEEE80211_MAX_AID) | 2026 | return -EINVAL; |
2024 | return -EINVAL; | ||
2025 | } | ||
2026 | 2027 | ||
2027 | if (info->attrs[NL80211_ATTR_HT_CAPABILITY]) | 2028 | if (info->attrs[NL80211_ATTR_HT_CAPABILITY]) |
2028 | params.ht_capa = | 2029 | params.ht_capa = |
@@ -2037,6 +2038,12 @@ static int nl80211_new_station(struct sk_buff *skb, struct genl_info *info) | |||
2037 | if (err) | 2038 | if (err) |
2038 | goto out_rtnl; | 2039 | goto out_rtnl; |
2039 | 2040 | ||
2041 | if (dev->ieee80211_ptr->iftype != NL80211_IFTYPE_AP && | ||
2042 | dev->ieee80211_ptr->iftype != NL80211_IFTYPE_AP_VLAN) { | ||
2043 | err = -EINVAL; | ||
2044 | goto out; | ||
2045 | } | ||
2046 | |||
2040 | err = get_vlan(info, rdev, ¶ms.vlan); | 2047 | err = get_vlan(info, rdev, ¶ms.vlan); |
2041 | if (err) | 2048 | if (err) |
2042 | goto out; | 2049 | goto out; |
@@ -2044,35 +2051,6 @@ static int nl80211_new_station(struct sk_buff *skb, struct genl_info *info) | |||
2044 | /* validate settings */ | 2051 | /* validate settings */ |
2045 | err = 0; | 2052 | err = 0; |
2046 | 2053 | ||
2047 | switch (dev->ieee80211_ptr->iftype) { | ||
2048 | case NL80211_IFTYPE_AP: | ||
2049 | case NL80211_IFTYPE_AP_VLAN: | ||
2050 | /* all ok but must have AID */ | ||
2051 | if (!params.aid) | ||
2052 | err = -EINVAL; | ||
2053 | break; | ||
2054 | case NL80211_IFTYPE_MESH_POINT: | ||
2055 | /* disallow things mesh doesn't support */ | ||
2056 | if (params.vlan) | ||
2057 | err = -EINVAL; | ||
2058 | if (params.aid) | ||
2059 | err = -EINVAL; | ||
2060 | if (params.ht_capa) | ||
2061 | err = -EINVAL; | ||
2062 | if (params.listen_interval >= 0) | ||
2063 | err = -EINVAL; | ||
2064 | if (params.supported_rates) | ||
2065 | err = -EINVAL; | ||
2066 | if (params.sta_flags_mask) | ||
2067 | err = -EINVAL; | ||
2068 | break; | ||
2069 | default: | ||
2070 | err = -EINVAL; | ||
2071 | } | ||
2072 | |||
2073 | if (err) | ||
2074 | goto out; | ||
2075 | |||
2076 | if (!rdev->ops->add_station) { | 2054 | if (!rdev->ops->add_station) { |
2077 | err = -EOPNOTSUPP; | 2055 | err = -EOPNOTSUPP; |
2078 | goto out; | 2056 | goto out; |
@@ -2113,8 +2091,7 @@ static int nl80211_del_station(struct sk_buff *skb, struct genl_info *info) | |||
2113 | goto out_rtnl; | 2091 | goto out_rtnl; |
2114 | 2092 | ||
2115 | if (dev->ieee80211_ptr->iftype != NL80211_IFTYPE_AP && | 2093 | if (dev->ieee80211_ptr->iftype != NL80211_IFTYPE_AP && |
2116 | dev->ieee80211_ptr->iftype != NL80211_IFTYPE_AP_VLAN && | 2094 | dev->ieee80211_ptr->iftype != NL80211_IFTYPE_AP_VLAN) { |
2117 | dev->ieee80211_ptr->iftype != NL80211_IFTYPE_MESH_POINT) { | ||
2118 | err = -EINVAL; | 2095 | err = -EINVAL; |
2119 | goto out; | 2096 | goto out; |
2120 | } | 2097 | } |