|
@@ -1291,29 +1291,35 @@ static void ieee80211_rx_mgmt_assoc_resp(struct ieee80211_sub_if_data *sdata,
|
|
|
|
|
|
for (i = 0; i < elems.supp_rates_len; i++) {
|
|
|
int rate = (elems.supp_rates[i] & 0x7f) * 5;
|
|
|
+ bool is_basic = !!(elems.supp_rates[i] & 0x80);
|
|
|
|
|
|
if (rate > 110)
|
|
|
have_higher_than_11mbit = true;
|
|
|
|
|
|
for (j = 0; j < sband->n_bitrates; j++) {
|
|
|
- if (sband->bitrates[j].bitrate == rate)
|
|
|
+ if (sband->bitrates[j].bitrate == rate) {
|
|
|
rates |= BIT(j);
|
|
|
- if (elems.supp_rates[i] & 0x80)
|
|
|
- basic_rates |= BIT(j);
|
|
|
+ if (is_basic)
|
|
|
+ basic_rates |= BIT(j);
|
|
|
+ break;
|
|
|
+ }
|
|
|
}
|
|
|
}
|
|
|
|
|
|
for (i = 0; i < elems.ext_supp_rates_len; i++) {
|
|
|
int rate = (elems.ext_supp_rates[i] & 0x7f) * 5;
|
|
|
+ bool is_basic = !!(elems.supp_rates[i] & 0x80);
|
|
|
|
|
|
if (rate > 110)
|
|
|
have_higher_than_11mbit = true;
|
|
|
|
|
|
for (j = 0; j < sband->n_bitrates; j++) {
|
|
|
- if (sband->bitrates[j].bitrate == rate)
|
|
|
+ if (sband->bitrates[j].bitrate == rate) {
|
|
|
rates |= BIT(j);
|
|
|
- if (elems.ext_supp_rates[i] & 0x80)
|
|
|
- basic_rates |= BIT(j);
|
|
|
+ if (is_basic)
|
|
|
+ basic_rates |= BIT(j);
|
|
|
+ break;
|
|
|
+ }
|
|
|
}
|
|
|
}
|
|
|
|