aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJohannes Berg <johannes.berg@intel.com>2015-01-15 10:05:21 -0500
committerJohannes Berg <johannes.berg@intel.com>2015-01-15 10:05:21 -0500
commit97d910d0aaa619ca530d08e2b1125b8014ccb030 (patch)
tree625396ac9ea52d46b9153f334ed7dcec77db8ee3
parentf89903d53f4d39577be98940f7cfa49d66f86db5 (diff)
cfg80211: remove 80+80 MHz rate reporting
These rates are treated the same as 160 MHz in the spec, so it makes no sense to distinguish them. As no driver uses them yet, this is also not a problem, just remove them. In the userspace API the field remains reserved to preserve API and ABI. Signed-off-by: Johannes Berg <johannes.berg@intel.com>
-rw-r--r--include/net/cfg80211.h8
-rw-r--r--include/uapi/linux/nl80211.h3
-rw-r--r--net/wireless/nl80211.c3
-rw-r--r--net/wireless/util.c3
4 files changed, 6 insertions, 11 deletions
diff --git a/include/net/cfg80211.h b/include/net/cfg80211.h
index 38abc07503fd..0322048fddab 100644
--- a/include/net/cfg80211.h
+++ b/include/net/cfg80211.h
@@ -875,7 +875,6 @@ int cfg80211_check_station_change(struct wiphy *wiphy,
875 * @RATE_INFO_FLAGS_VHT_MCS: mcs field filled with VHT MCS 875 * @RATE_INFO_FLAGS_VHT_MCS: mcs field filled with VHT MCS
876 * @RATE_INFO_FLAGS_40_MHZ_WIDTH: 40 MHz width transmission 876 * @RATE_INFO_FLAGS_40_MHZ_WIDTH: 40 MHz width transmission
877 * @RATE_INFO_FLAGS_80_MHZ_WIDTH: 80 MHz width transmission 877 * @RATE_INFO_FLAGS_80_MHZ_WIDTH: 80 MHz width transmission
878 * @RATE_INFO_FLAGS_80P80_MHZ_WIDTH: 80+80 MHz width transmission
879 * @RATE_INFO_FLAGS_160_MHZ_WIDTH: 160 MHz width transmission 878 * @RATE_INFO_FLAGS_160_MHZ_WIDTH: 160 MHz width transmission
880 * @RATE_INFO_FLAGS_SHORT_GI: 400ns guard interval 879 * @RATE_INFO_FLAGS_SHORT_GI: 400ns guard interval
881 * @RATE_INFO_FLAGS_60G: 60GHz MCS 880 * @RATE_INFO_FLAGS_60G: 60GHz MCS
@@ -885,10 +884,9 @@ enum rate_info_flags {
885 RATE_INFO_FLAGS_VHT_MCS = BIT(1), 884 RATE_INFO_FLAGS_VHT_MCS = BIT(1),
886 RATE_INFO_FLAGS_40_MHZ_WIDTH = BIT(2), 885 RATE_INFO_FLAGS_40_MHZ_WIDTH = BIT(2),
887 RATE_INFO_FLAGS_80_MHZ_WIDTH = BIT(3), 886 RATE_INFO_FLAGS_80_MHZ_WIDTH = BIT(3),
888 RATE_INFO_FLAGS_80P80_MHZ_WIDTH = BIT(4), 887 RATE_INFO_FLAGS_160_MHZ_WIDTH = BIT(4),
889 RATE_INFO_FLAGS_160_MHZ_WIDTH = BIT(5), 888 RATE_INFO_FLAGS_SHORT_GI = BIT(5),
890 RATE_INFO_FLAGS_SHORT_GI = BIT(6), 889 RATE_INFO_FLAGS_60G = BIT(6),
891 RATE_INFO_FLAGS_60G = BIT(7),
892}; 890};
893 891
894/** 892/**
diff --git a/include/uapi/linux/nl80211.h b/include/uapi/linux/nl80211.h
index b6c1a00bd8d2..11cdb85ac646 100644
--- a/include/uapi/linux/nl80211.h
+++ b/include/uapi/linux/nl80211.h
@@ -2278,7 +2278,8 @@ struct nl80211_sta_flag_update {
2278 * @NL80211_RATE_INFO_VHT_MCS: MCS index for VHT (u8) 2278 * @NL80211_RATE_INFO_VHT_MCS: MCS index for VHT (u8)
2279 * @NL80211_RATE_INFO_VHT_NSS: number of streams in VHT (u8) 2279 * @NL80211_RATE_INFO_VHT_NSS: number of streams in VHT (u8)
2280 * @NL80211_RATE_INFO_80_MHZ_WIDTH: 80 MHz VHT rate 2280 * @NL80211_RATE_INFO_80_MHZ_WIDTH: 80 MHz VHT rate
2281 * @NL80211_RATE_INFO_80P80_MHZ_WIDTH: 80+80 MHz VHT rate 2281 * @NL80211_RATE_INFO_80P80_MHZ_WIDTH: unused - 80+80 is treated the
2282 * same as 160 for purposes of the bitrates
2282 * @NL80211_RATE_INFO_160_MHZ_WIDTH: 160 MHz VHT rate 2283 * @NL80211_RATE_INFO_160_MHZ_WIDTH: 160 MHz VHT rate
2283 * @__NL80211_RATE_INFO_AFTER_LAST: internal use 2284 * @__NL80211_RATE_INFO_AFTER_LAST: internal use
2284 */ 2285 */
diff --git a/net/wireless/nl80211.c b/net/wireless/nl80211.c
index 380784378df8..8998484ea970 100644
--- a/net/wireless/nl80211.c
+++ b/net/wireless/nl80211.c
@@ -3614,9 +3614,6 @@ static bool nl80211_put_sta_rate(struct sk_buff *msg, struct rate_info *info,
3614 if (info->flags & RATE_INFO_FLAGS_80_MHZ_WIDTH && 3614 if (info->flags & RATE_INFO_FLAGS_80_MHZ_WIDTH &&
3615 nla_put_flag(msg, NL80211_RATE_INFO_80_MHZ_WIDTH)) 3615 nla_put_flag(msg, NL80211_RATE_INFO_80_MHZ_WIDTH))
3616 return false; 3616 return false;
3617 if (info->flags & RATE_INFO_FLAGS_80P80_MHZ_WIDTH &&
3618 nla_put_flag(msg, NL80211_RATE_INFO_80P80_MHZ_WIDTH))
3619 return false;
3620 if (info->flags & RATE_INFO_FLAGS_160_MHZ_WIDTH && 3617 if (info->flags & RATE_INFO_FLAGS_160_MHZ_WIDTH &&
3621 nla_put_flag(msg, NL80211_RATE_INFO_160_MHZ_WIDTH)) 3618 nla_put_flag(msg, NL80211_RATE_INFO_160_MHZ_WIDTH))
3622 return false; 3619 return false;
diff --git a/net/wireless/util.c b/net/wireless/util.c
index d0ac795445b7..6942d48f1ac5 100644
--- a/net/wireless/util.c
+++ b/net/wireless/util.c
@@ -1073,8 +1073,7 @@ static u32 cfg80211_calculate_bitrate_vht(struct rate_info *rate)
1073 if (WARN_ON_ONCE(rate->mcs > 9)) 1073 if (WARN_ON_ONCE(rate->mcs > 9))
1074 return 0; 1074 return 0;
1075 1075
1076 idx = rate->flags & (RATE_INFO_FLAGS_160_MHZ_WIDTH | 1076 idx = rate->flags & RATE_INFO_FLAGS_160_MHZ_WIDTH ? 3 :
1077 RATE_INFO_FLAGS_80P80_MHZ_WIDTH) ? 3 :
1078 rate->flags & RATE_INFO_FLAGS_80_MHZ_WIDTH ? 2 : 1077 rate->flags & RATE_INFO_FLAGS_80_MHZ_WIDTH ? 2 :
1079 rate->flags & RATE_INFO_FLAGS_40_MHZ_WIDTH ? 1 : 0; 1078 rate->flags & RATE_INFO_FLAGS_40_MHZ_WIDTH ? 1 : 0;
1080 1079