diff options
| author | Kalle Valo <kvalo@qca.qualcomm.com> | 2012-07-12 12:13:12 +0300 | 
|---|---|---|
| committer | Kalle Valo <kvalo@qca.qualcomm.com> | 2012-10-24 11:49:37 +0300 | 
| commit | f8c0305383121817c77d400c788d82ca1a74582c (patch) | |
| tree | a07ce429132a6afc06c46298d11737d1927798af | |
| parent | 84841ba29b1f55fb09703408477f097c7f8952f8 (diff) | |
| download | olio-linux-3.10-f8c0305383121817c77d400c788d82ca1a74582c.tar.xz olio-linux-3.10-f8c0305383121817c77d400c788d82ca1a74582c.zip  | |
ath6kl: fix incorrect use of IEEE80211_NUM_BANDS
ath6kl was incorrectly assuming that IEEE80211_NUM_BANDS will always be 2
and used that also in the firmware WMI interface definitions. But after
the support for 60 GHz was added to cfg80211 IEEE80211_NUM_BANDS changed to 3
and this can cause all sort of problems, possibly even memory corruption.
I only found this during code review and didn't notice any bugs, but I'm
sure there are a few lurking somewhere.
To fix this rename unused A_NUM_BANDS to ATH6KL_NUM_BANDS, which is
always defined to be 2, and use that in WMI.
Signed-off-by: Kalle Valo <kvalo@qca.qualcomm.com>
| -rw-r--r-- | drivers/net/wireless/ath/ath6kl/wmi.c | 12 | ||||
| -rw-r--r-- | drivers/net/wireless/ath/ath6kl/wmi.h | 4 | 
2 files changed, 10 insertions, 6 deletions
diff --git a/drivers/net/wireless/ath/ath6kl/wmi.c b/drivers/net/wireless/ath/ath6kl/wmi.c index cf91348fdbd..d485a7c3428 100644 --- a/drivers/net/wireless/ath/ath6kl/wmi.c +++ b/drivers/net/wireless/ath/ath6kl/wmi.c @@ -2695,11 +2695,13 @@ static int ath6kl_set_bitrate_mask64(struct wmi *wmi, u8 if_idx,  {  	struct sk_buff *skb;  	int ret, mode, band; -	u64 mcsrate, ratemask[IEEE80211_NUM_BANDS]; +	u64 mcsrate, ratemask[ATH6KL_NUM_BANDS];  	struct wmi_set_tx_select_rates64_cmd *cmd;  	memset(&ratemask, 0, sizeof(ratemask)); -	for (band = 0; band < IEEE80211_NUM_BANDS; band++) { + +	/* only check 2.4 and 5 GHz bands, skip the rest */ +	for (band = 0; band <= IEEE80211_BAND_5GHZ; band++) {  		/* copy legacy rate mask */  		ratemask[band] = mask->control[band].legacy;  		if (band == IEEE80211_BAND_5GHZ) @@ -2745,11 +2747,13 @@ static int ath6kl_set_bitrate_mask32(struct wmi *wmi, u8 if_idx,  {  	struct sk_buff *skb;  	int ret, mode, band; -	u32 mcsrate, ratemask[IEEE80211_NUM_BANDS]; +	u32 mcsrate, ratemask[ATH6KL_NUM_BANDS];  	struct wmi_set_tx_select_rates32_cmd *cmd;  	memset(&ratemask, 0, sizeof(ratemask)); -	for (band = 0; band < IEEE80211_NUM_BANDS; band++) { + +	/* only check 2.4 and 5 GHz bands, skip the rest */ +	for (band = 0; band <= IEEE80211_BAND_5GHZ; band++) {  		/* copy legacy rate mask */  		ratemask[band] = mask->control[band].legacy;  		if (band == IEEE80211_BAND_5GHZ) diff --git a/drivers/net/wireless/ath/ath6kl/wmi.h b/drivers/net/wireless/ath/ath6kl/wmi.h index 1d510bae155..9c73ae73f26 100644 --- a/drivers/net/wireless/ath/ath6kl/wmi.h +++ b/drivers/net/wireless/ath/ath6kl/wmi.h @@ -48,7 +48,7 @@  #define A_BAND_24GHZ           0  #define A_BAND_5GHZ            1 -#define A_NUM_BANDS            2 +#define ATH6KL_NUM_BANDS       2  /* in ms */  #define WMI_IMPLICIT_PSTREAM_INACTIVITY_INT 5000 @@ -853,7 +853,7 @@ struct wmi_begin_scan_cmd {  	u8 scan_type;  	/* Supported rates to advertise in the probe request frames */ -	struct wmi_supp_rates supp_rates[IEEE80211_NUM_BANDS]; +	struct wmi_supp_rates supp_rates[ATH6KL_NUM_BANDS];  	/* how many channels follow */  	u8 num_ch;  |