mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-09-04 20:19:47 +08:00
ath10k: update available channel list for 5G radio
If a 5 GHz radio is calibrated for operation in both the low band (channels 36 to 64) and high band(channels 100 to 169), hardware allows operations in all the listed channels. However, if the chip has been calibrated only for the low/high band and a high/low band channel is configured, due to lack of calibration there will be potentially invalid signal on those non calibrated channels. To avoid this problem this patch sets IEEE80211_CHAN_DISABLED flag for those non calibrated channels by using low_5ghz_chan and high_5ghz_chan values which we get from target through wmi service ready event. Driver initialized flags are getting re initialized in handle_channel in cfg80211. So calling the function to disable the non supported channel from reg_notifier(). Signed-off-by: Tamizh chelvam <c_traja@qti.qualcomm.com> Signed-off-by: Kalle Valo <kvalo@qca.qualcomm.com>
This commit is contained in:
parent
ca07baab0b
commit
523f6701db
@ -775,6 +775,8 @@ struct ath10k {
|
|||||||
u32 num_rf_chains;
|
u32 num_rf_chains;
|
||||||
u32 max_spatial_stream;
|
u32 max_spatial_stream;
|
||||||
/* protected by conf_mutex */
|
/* protected by conf_mutex */
|
||||||
|
u32 low_5ghz_chan;
|
||||||
|
u32 high_5ghz_chan;
|
||||||
bool ani_enabled;
|
bool ani_enabled;
|
||||||
|
|
||||||
bool p2p;
|
bool p2p;
|
||||||
|
@ -3126,6 +3126,21 @@ static void ath10k_regd_update(struct ath10k *ar)
|
|||||||
ath10k_warn(ar, "failed to set pdev regdomain: %d\n", ret);
|
ath10k_warn(ar, "failed to set pdev regdomain: %d\n", ret);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void ath10k_mac_update_channel_list(struct ath10k *ar,
|
||||||
|
struct ieee80211_supported_band *band)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
|
||||||
|
if (ar->low_5ghz_chan && ar->high_5ghz_chan) {
|
||||||
|
for (i = 0; i < band->n_channels; i++) {
|
||||||
|
if (band->channels[i].center_freq < ar->low_5ghz_chan ||
|
||||||
|
band->channels[i].center_freq > ar->high_5ghz_chan)
|
||||||
|
band->channels[i].flags |=
|
||||||
|
IEEE80211_CHAN_DISABLED;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static void ath10k_reg_notifier(struct wiphy *wiphy,
|
static void ath10k_reg_notifier(struct wiphy *wiphy,
|
||||||
struct regulatory_request *request)
|
struct regulatory_request *request)
|
||||||
{
|
{
|
||||||
@ -3149,6 +3164,10 @@ static void ath10k_reg_notifier(struct wiphy *wiphy,
|
|||||||
if (ar->state == ATH10K_STATE_ON)
|
if (ar->state == ATH10K_STATE_ON)
|
||||||
ath10k_regd_update(ar);
|
ath10k_regd_update(ar);
|
||||||
mutex_unlock(&ar->conf_mutex);
|
mutex_unlock(&ar->conf_mutex);
|
||||||
|
|
||||||
|
if (ar->phy_capability & WHAL_WLAN_11A_CAPABILITY)
|
||||||
|
ath10k_mac_update_channel_list(ar,
|
||||||
|
ar->hw->wiphy->bands[NL80211_BAND_5GHZ]);
|
||||||
}
|
}
|
||||||
|
|
||||||
/***************/
|
/***************/
|
||||||
|
@ -4593,6 +4593,8 @@ ath10k_wmi_main_op_pull_svc_rdy_ev(struct ath10k *ar, struct sk_buff *skb,
|
|||||||
arg->phy_capab = ev->phy_capability;
|
arg->phy_capab = ev->phy_capability;
|
||||||
arg->num_rf_chains = ev->num_rf_chains;
|
arg->num_rf_chains = ev->num_rf_chains;
|
||||||
arg->eeprom_rd = ev->hal_reg_capabilities.eeprom_rd;
|
arg->eeprom_rd = ev->hal_reg_capabilities.eeprom_rd;
|
||||||
|
arg->low_5ghz_chan = ev->hal_reg_capabilities.low_5ghz_chan;
|
||||||
|
arg->high_5ghz_chan = ev->hal_reg_capabilities.high_5ghz_chan;
|
||||||
arg->num_mem_reqs = ev->num_mem_reqs;
|
arg->num_mem_reqs = ev->num_mem_reqs;
|
||||||
arg->service_map = ev->wmi_service_bitmap;
|
arg->service_map = ev->wmi_service_bitmap;
|
||||||
arg->service_map_len = sizeof(ev->wmi_service_bitmap);
|
arg->service_map_len = sizeof(ev->wmi_service_bitmap);
|
||||||
@ -4629,6 +4631,8 @@ ath10k_wmi_10x_op_pull_svc_rdy_ev(struct ath10k *ar, struct sk_buff *skb,
|
|||||||
arg->phy_capab = ev->phy_capability;
|
arg->phy_capab = ev->phy_capability;
|
||||||
arg->num_rf_chains = ev->num_rf_chains;
|
arg->num_rf_chains = ev->num_rf_chains;
|
||||||
arg->eeprom_rd = ev->hal_reg_capabilities.eeprom_rd;
|
arg->eeprom_rd = ev->hal_reg_capabilities.eeprom_rd;
|
||||||
|
arg->low_5ghz_chan = ev->hal_reg_capabilities.low_5ghz_chan;
|
||||||
|
arg->high_5ghz_chan = ev->hal_reg_capabilities.high_5ghz_chan;
|
||||||
arg->num_mem_reqs = ev->num_mem_reqs;
|
arg->num_mem_reqs = ev->num_mem_reqs;
|
||||||
arg->service_map = ev->wmi_service_bitmap;
|
arg->service_map = ev->wmi_service_bitmap;
|
||||||
arg->service_map_len = sizeof(ev->wmi_service_bitmap);
|
arg->service_map_len = sizeof(ev->wmi_service_bitmap);
|
||||||
@ -4682,6 +4686,8 @@ static void ath10k_wmi_event_service_ready_work(struct work_struct *work)
|
|||||||
ar->phy_capability = __le32_to_cpu(arg.phy_capab);
|
ar->phy_capability = __le32_to_cpu(arg.phy_capab);
|
||||||
ar->num_rf_chains = __le32_to_cpu(arg.num_rf_chains);
|
ar->num_rf_chains = __le32_to_cpu(arg.num_rf_chains);
|
||||||
ar->hw_eeprom_rd = __le32_to_cpu(arg.eeprom_rd);
|
ar->hw_eeprom_rd = __le32_to_cpu(arg.eeprom_rd);
|
||||||
|
ar->low_5ghz_chan = __le32_to_cpu(arg.low_5ghz_chan);
|
||||||
|
ar->high_5ghz_chan = __le32_to_cpu(arg.high_5ghz_chan);
|
||||||
|
|
||||||
ath10k_dbg_dump(ar, ATH10K_DBG_WMI, NULL, "wmi svc: ",
|
ath10k_dbg_dump(ar, ATH10K_DBG_WMI, NULL, "wmi svc: ",
|
||||||
arg.service_map, arg.service_map_len);
|
arg.service_map, arg.service_map_len);
|
||||||
|
@ -6335,6 +6335,8 @@ struct wmi_svc_rdy_ev_arg {
|
|||||||
__le32 num_rf_chains;
|
__le32 num_rf_chains;
|
||||||
__le32 eeprom_rd;
|
__le32 eeprom_rd;
|
||||||
__le32 num_mem_reqs;
|
__le32 num_mem_reqs;
|
||||||
|
__le32 low_5ghz_chan;
|
||||||
|
__le32 high_5ghz_chan;
|
||||||
const __le32 *service_map;
|
const __le32 *service_map;
|
||||||
size_t service_map_len;
|
size_t service_map_len;
|
||||||
const struct wlan_host_mem_req *mem_reqs[WMI_MAX_MEM_REQS];
|
const struct wlan_host_mem_req *mem_reqs[WMI_MAX_MEM_REQS];
|
||||||
|
Loading…
Reference in New Issue
Block a user