qcacmn: Avoid setting SOURCE_DRIVER for non-BDF CC event

Firmware could send same channel list for each pdev. Since SOURCE DRIVER
is default, it would be set for the second event. Avoid that. Remember the
source of the first event itself.

Change-Id: Ib9db58da1fa27673b04a4c62e10f2a05702348ad
CRs-Fixed: 2352151
This commit is contained in:
Amar Singhal
2018-11-12 11:24:10 -08:00
committed by nshrivas
父節點 3ccfa6a645
當前提交 64ea8064b1

查看文件

@@ -3220,12 +3220,8 @@ QDF_STATUS reg_process_master_chan_list(struct cur_regulatory_info
soc_reg->user_ctry_set = false;
reg_run_11d_state_machine(psoc);
} else {
soc_reg->cc_src = SOURCE_DRIVER;
if (reg_is_world_alpha2(regulat_info->alpha2)) {
soc_reg->cc_src = SOURCE_CORE;
reg_run_11d_state_machine(psoc);
}
if (soc_reg->cc_src == SOURCE_UNKNOWN)
soc_reg->cc_src = SOURCE_DRIVER;
qdf_mem_copy(soc_reg->mas_chan_params[phy_id].default_country,
regulat_info->alpha2,
@@ -3236,12 +3232,20 @@ QDF_STATUS reg_process_master_chan_list(struct cur_regulatory_info
soc_reg->mas_chan_params[phy_id].def_region_domain =
regulat_info->reg_dmn_pair;
qdf_mem_copy(soc_reg->def_country,
regulat_info->alpha2,
REG_ALPHA2_LEN + 1);
if (soc_reg->cc_src == SOURCE_DRIVER) {
qdf_mem_copy(soc_reg->def_country,
regulat_info->alpha2,
REG_ALPHA2_LEN + 1);
soc_reg->def_country_code = regulat_info->ctry_code;
soc_reg->def_region_domain = regulat_info->reg_dmn_pair;
soc_reg->def_country_code = regulat_info->ctry_code;
soc_reg->def_region_domain =
regulat_info->reg_dmn_pair;
}
if (reg_is_world_alpha2(regulat_info->alpha2)) {
soc_reg->cc_src = SOURCE_CORE;
reg_run_11d_state_machine(psoc);
}
}
pdev = wlan_objmgr_get_pdev_by_id(psoc, phy_id, dbg_id);