diff options
author | Johannes Berg <johannes.berg@intel.com> | 2015-01-15 10:14:02 -0500 |
---|---|---|
committer | Johannes Berg <johannes.berg@intel.com> | 2015-01-15 16:41:32 -0500 |
commit | b51f3beecfbbfc946749a91fb444cb8917cf444f (patch) | |
tree | 68ecd024ca26b392b48599dc3725e4416d053d1f /net/wireless/util.c | |
parent | 97d910d0aaa619ca530d08e2b1125b8014ccb030 (diff) |
cfg80211: change bandwidth reporting to explicit field
For some reason, we made the bandwidth separate flags, which
is rather confusing - a single rate cannot have different
bandwidths at the same time.
Change this to no longer be flags but use a separate field
for the bandwidth ('bw') instead.
While at it, add support for 5 and 10 MHz rates - these are
reported as regular legacy rates with their real bitrate,
but tagged as 5/10 now to make it easier to distinguish them.
In the nl80211 API, the flags are preserved, but the code
now can also clearly only set a single one of the flags.
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
Diffstat (limited to 'net/wireless/util.c')
-rw-r--r-- | net/wireless/util.c | 24 |
1 files changed, 19 insertions, 5 deletions
diff --git a/net/wireless/util.c b/net/wireless/util.c index 6942d48f1ac5..3535e8ade48f 100644 --- a/net/wireless/util.c +++ b/net/wireless/util.c | |||
@@ -1073,9 +1073,24 @@ 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 ? 3 : | 1076 | switch (rate->bw) { |
1077 | rate->flags & RATE_INFO_FLAGS_80_MHZ_WIDTH ? 2 : | 1077 | case RATE_INFO_BW_160: |
1078 | rate->flags & RATE_INFO_FLAGS_40_MHZ_WIDTH ? 1 : 0; | 1078 | idx = 3; |
1079 | break; | ||
1080 | case RATE_INFO_BW_80: | ||
1081 | idx = 2; | ||
1082 | break; | ||
1083 | case RATE_INFO_BW_40: | ||
1084 | idx = 1; | ||
1085 | break; | ||
1086 | case RATE_INFO_BW_5: | ||
1087 | case RATE_INFO_BW_10: | ||
1088 | default: | ||
1089 | WARN_ON(1); | ||
1090 | /* fall through */ | ||
1091 | case RATE_INFO_BW_20: | ||
1092 | idx = 0; | ||
1093 | } | ||
1079 | 1094 | ||
1080 | bitrate = base[idx][rate->mcs]; | 1095 | bitrate = base[idx][rate->mcs]; |
1081 | bitrate *= rate->nss; | 1096 | bitrate *= rate->nss; |
@@ -1106,8 +1121,7 @@ u32 cfg80211_calculate_bitrate(struct rate_info *rate) | |||
1106 | modulation = rate->mcs & 7; | 1121 | modulation = rate->mcs & 7; |
1107 | streams = (rate->mcs >> 3) + 1; | 1122 | streams = (rate->mcs >> 3) + 1; |
1108 | 1123 | ||
1109 | bitrate = (rate->flags & RATE_INFO_FLAGS_40_MHZ_WIDTH) ? | 1124 | bitrate = (rate->bw == RATE_INFO_BW_40) ? 13500000 : 6500000; |
1110 | 13500000 : 6500000; | ||
1111 | 1125 | ||
1112 | if (modulation < 4) | 1126 | if (modulation < 4) |
1113 | bitrate *= (modulation + 1); | 1127 | bitrate *= (modulation + 1); |