qcacmn: Append 6g reg rules to main list
Currently, there are separate list for 2g/5g and 6g reg rules. Only one list is sent north from pdev, so append the corresponding rules to the existing list in the pdev only. Change-Id: I28e68f345ae6faad3ac2d929dac3922e9389d53e CRs-fixed: 2860702
Este commit está contenido en:
@@ -1072,7 +1072,15 @@ void reg_reset_reg_rules(struct reg_rule_info *reg_rules)
|
||||
qdf_mem_zero(reg_rules, sizeof(*reg_rules));
|
||||
}
|
||||
|
||||
#ifdef CONFIG_REG_CLIENT
|
||||
#ifdef CONFIG_BAND_6GHZ
|
||||
/**
|
||||
* reg_copy_6g_reg_rules() - Copy the 6G reg rules from PSOC to PDEV
|
||||
* @pdev_reg_rules: Pointer to pdev reg rules
|
||||
* @psoc_reg_rules: Pointer to psoc reg rules
|
||||
*
|
||||
* Return: void
|
||||
*/
|
||||
static void reg_copy_6g_reg_rules(struct reg_rule_info *pdev_reg_rules,
|
||||
struct reg_rule_info *psoc_reg_rules)
|
||||
{
|
||||
@@ -1098,12 +1106,45 @@ static void reg_copy_6g_reg_rules(struct reg_rule_info *pdev_reg_rules,
|
||||
reg_rule_len_6g_client);
|
||||
}
|
||||
}
|
||||
#else
|
||||
|
||||
/**
|
||||
* reg_append_6g_reg_rules_in_pdev() - Append the 6G reg rules to the reg rules
|
||||
* list in pdev so that all currently used reg rules are in one common list
|
||||
* @pdev_priv_obj: Pointer to pdev private object
|
||||
*
|
||||
* Return: void
|
||||
*/
|
||||
static void reg_append_6g_reg_rules_in_pdev(
|
||||
struct wlan_regulatory_pdev_priv_obj *pdev_priv_obj)
|
||||
{
|
||||
struct reg_rule_info *pdev_reg_rules;
|
||||
enum reg_6g_ap_type cur_pwr_type;
|
||||
uint8_t num_reg_rules;
|
||||
|
||||
pdev_reg_rules = &pdev_priv_obj->reg_rules;
|
||||
cur_pwr_type = pdev_priv_obj->reg_cur_6g_ap_pwr_type;
|
||||
|
||||
num_reg_rules = pdev_reg_rules->num_of_reg_rules;
|
||||
pdev_reg_rules->num_of_reg_rules +=
|
||||
pdev_reg_rules->num_of_6g_client_reg_rules[cur_pwr_type];
|
||||
|
||||
qdf_mem_copy(&pdev_reg_rules->reg_rules[num_reg_rules],
|
||||
pdev_reg_rules->reg_rules_6g_client[cur_pwr_type],
|
||||
pdev_reg_rules->num_of_6g_client_reg_rules[cur_pwr_type] *
|
||||
sizeof(struct cur_reg_rule));
|
||||
}
|
||||
|
||||
#else /* CONFIG_BAND_6GHZ */
|
||||
static inline void reg_copy_6g_reg_rules(struct reg_rule_info *pdev_reg_rules,
|
||||
struct reg_rule_info *psoc_reg_rules)
|
||||
{
|
||||
}
|
||||
#endif
|
||||
|
||||
static inline void reg_append_6g_reg_rules_in_pdev(
|
||||
struct wlan_regulatory_pdev_priv_obj *pdev_priv_obj)
|
||||
{
|
||||
}
|
||||
#endif /* CONFIG_BAND_6GHZ */
|
||||
|
||||
void reg_save_reg_rules_to_pdev(
|
||||
struct reg_rule_info *psoc_reg_rules,
|
||||
@@ -1130,6 +1171,7 @@ void reg_save_reg_rules_to_pdev(
|
||||
reg_rule_len);
|
||||
|
||||
reg_copy_6g_reg_rules(pdev_reg_rules, psoc_reg_rules);
|
||||
reg_append_6g_reg_rules_in_pdev(pdev_priv_obj);
|
||||
|
||||
qdf_mem_copy(pdev_reg_rules->alpha2, pdev_priv_obj->current_country,
|
||||
REG_ALPHA2_LEN + 1);
|
||||
@@ -1137,6 +1179,7 @@ void reg_save_reg_rules_to_pdev(
|
||||
|
||||
qdf_spin_unlock_bh(&pdev_priv_obj->reg_rules_lock);
|
||||
}
|
||||
#endif /* CONFIG_REG_CLIENT */
|
||||
|
||||
void reg_propagate_mas_chan_list_to_pdev(struct wlan_objmgr_psoc *psoc,
|
||||
void *object, void *arg)
|
||||
|
@@ -46,6 +46,7 @@ void reg_init_pdev_mas_chan_list(
|
||||
struct wlan_regulatory_pdev_priv_obj *pdev_priv_obj,
|
||||
struct mas_chan_params *mas_chan_params);
|
||||
|
||||
#ifdef CONFIG_REG_CLIENT
|
||||
/**
|
||||
* reg_save_reg_rules_to_pdev() - Save psoc reg-rules to pdev.
|
||||
* @pdev_priv_obj: Pointer to regdb pdev private object.
|
||||
@@ -53,6 +54,13 @@ void reg_init_pdev_mas_chan_list(
|
||||
void reg_save_reg_rules_to_pdev(
|
||||
struct reg_rule_info *psoc_reg_rules,
|
||||
struct wlan_regulatory_pdev_priv_obj *pdev_priv_obj);
|
||||
#else
|
||||
static inline void
|
||||
reg_save_reg_rules_to_pdev(struct reg_rule_info *psoc_reg_rules,
|
||||
struct wlan_regulatory_pdev_priv_obj *pdev_priv_obj)
|
||||
{
|
||||
}
|
||||
#endif
|
||||
|
||||
/**
|
||||
* reg_compute_pdev_current_chan_list() - Compute pdev current channel list.
|
||||
|
Referencia en una nueva incidencia
Block a user