b43: fix the wrong assignment of status.freq in b43_rx()
Use the right function to update frequency value.
If rx skb is probe response or beacon, the wrong frequency value can
cause problem that bss info can't be updated when it should be.
Cc: <stable@vger.kernel.org>
Fixes: 8318d78a44
("cfg80211 API for channels/bitrates, mac80211
and driver conversion")
Signed-off-by: ZHAO Gang <gamerh2o@gmail.com>
Acked-by: Larry Finger <Larry.Finger@lwfinger.net>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
This commit is contained in:
parent
09e65f5b2b
commit
64e5acb09c
|
@ -821,10 +821,10 @@ void b43_rx(struct b43_wldev *dev, struct sk_buff *skb, const void *_rxhdr)
|
||||||
* channel number in b43. */
|
* channel number in b43. */
|
||||||
if (chanstat & B43_RX_CHAN_5GHZ) {
|
if (chanstat & B43_RX_CHAN_5GHZ) {
|
||||||
status.band = IEEE80211_BAND_5GHZ;
|
status.band = IEEE80211_BAND_5GHZ;
|
||||||
status.freq = b43_freq_to_channel_5ghz(chanid);
|
status.freq = b43_channel_to_freq_5ghz(chanid);
|
||||||
} else {
|
} else {
|
||||||
status.band = IEEE80211_BAND_2GHZ;
|
status.band = IEEE80211_BAND_2GHZ;
|
||||||
status.freq = b43_freq_to_channel_2ghz(chanid);
|
status.freq = b43_channel_to_freq_2ghz(chanid);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
|
Loading…
Reference in New Issue