qcacmn: FW-Host Handshake for REG_CHAN_LIST_CC_EVENT

In order to support different power levels of 6G AP and client,
the channel list event from FW namely "REG_CHAN_LIST_CC_EVENTID"
is modified to add few parameters specific to 6GHZ devices.
Hence the existing event is replaced by REG_CHAN_LIST_CC_EVENT_EXT for
all 2G/5G/6G pdevs in FW. Therefore, after the service ready event, FW
sends the channel list for the configured country/regdomain via
REG_CHAN_LIST_CC_EVENT_EXT. This mandates that all host software need
to have the processing capability of REG_CHAN_LIST_CC_EVENT_EXT to bring
up the AP.

As there can be host software which has not yet implemented the
version of "REG_CHAN_LIST_CC_EVENT_EXT", backward compatibility is lost
if "ONLY REG_CHAN_LIST_CC_EVENT_EXT" is sent by FW.
Hence a 3 way handshake between host and FW is established.

1. FW advertises its capability of processing REG_CHAN_LIST_CC_EVENT_EXT
id via wmi service bit 'wmi_service_reg_cc_ext_event_support'.
2. If the host is capable of processing the "REG_CHAN_LIST_CC_EVENT_EXT"
event id (which is done based on registration of this event), host
sends the capability in WMI_INIT_CMDID setting a bit in host_service_flags.
3. Based on host capability advertised in WMI_INIT_CMDID, FW decides to
send the old event ("REG_CHAN_LIST_CC_EVENTID") or the new event
("REG_CHAN_LIST_CC_EVENT_EXT").
4. If there is no flag indicated by host to FW in WMI_INIT_CMDID, FW
by default sends the old event ("REG_CHAN_LIST_CC_EVENTID").

CRs-Fixed: 2876360
Change-Id: Ibe95f414ad9fff0e5641bcc6e60450ef9afe245b
Tento commit je obsažen v:
Priyadarshnee Srinivasan
2021-02-16 18:02:50 +05:30
odevzdal AnjaneeDevi Kapparapu
rodič 7fe3773331
revize d617a3a77f
8 změnil soubory, kde provedl 89 přidání a 2 odebrání

Zobrazit soubor

@@ -2573,4 +2573,15 @@ static inline enum QDF_GLOBAL_MODE target_psoc_get_device_mode
return psoc_info->info.device_mode;
}
/**
* target_if_set_reg_cc_ext_supp() - Set reg_cc_ext_supp capability
* in WMI_INIT_CMD based on host capability of reg_cc_ext_event.
*
* @tgt_hdl: Pointer to struct target_psoc_info.
* @psoc: Pointer to struct wlan_objmgr_psoc.
*
*/
void target_if_set_reg_cc_ext_supp(struct target_psoc_info *tgt_hdl,
struct wlan_objmgr_psoc *psoc);
#endif

Zobrazit soubor

@@ -844,3 +844,17 @@ target_pdev_scan_radio_is_dfs_enabled(struct wlan_objmgr_pdev *pdev,
return QDF_STATUS_E_INVAL;
}
void target_if_set_reg_cc_ext_supp(struct target_psoc_info *tgt_hdl,
struct wlan_objmgr_psoc *psoc)
{
struct tgt_info *info;
if (!tgt_hdl)
return;
info = (&tgt_hdl->info);
info->wlan_res_cfg.is_reg_cc_ext_event_supported =
target_if_reg_is_reg_cc_ext_event_host_supported(psoc);
}

Zobrazit soubor

@@ -274,6 +274,10 @@ static int init_deinit_service_ext2_ready_event_handler(ol_scn_t scn_handle,
if (err_code)
goto exit;
if (wmi_service_enabled(wmi_handle,
wmi_service_reg_cc_ext_event_support))
target_if_set_reg_cc_ext_supp(tgt_hdl, psoc);
/* dbr_ring_caps could have already come as part of EXT event */
if (info->service_ext2_param.num_dbr_ring_caps) {
err_code = init_deinit_populate_dbr_ring_cap_ext2(psoc,

Zobrazit soubor

@@ -64,6 +64,16 @@ QDF_STATUS target_if_reg_set_6ghz_info(struct wlan_objmgr_psoc *psoc);
*/
QDF_STATUS target_if_reg_set_5dot9_ghz_info(struct wlan_objmgr_psoc *psoc);
/**
* target_if_reg_is_reg_cc_ext_event_host_supported() - Populate if reg_cc_ext
* event is supported by host.
* @psoc: psoc pointer
*
* Return: True if host supports, false otherwise.
*/
bool
target_if_reg_is_reg_cc_ext_event_host_supported(struct wlan_objmgr_psoc *psoc);
/**
* target_if_regulatory_get_rx_ops() - Get regdb rx ops
* @psoc: pointer to psoc object
@@ -81,4 +91,13 @@ target_if_regulatory_get_rx_ops(struct wlan_objmgr_psoc *psoc);
* Return: Success or Failure
*/
QDF_STATUS target_if_regulatory_set_ext_tpc(struct wlan_objmgr_psoc *psoc);
/**
* target_if_regulatory_get_tx_ops() - Get regdb tx ops
* @psoc: pointer to psoc object
*
* Return: Reg tx_ops
*/
struct wlan_lmac_if_reg_tx_ops *
target_if_regulatory_get_tx_ops(struct wlan_objmgr_psoc *psoc);
#endif /* __TARGET_IF_REG_H__ */

Zobrazit soubor

@@ -144,6 +144,20 @@ target_if_regulatory_get_rx_ops(struct wlan_objmgr_psoc *psoc)
return &rx_ops->reg_rx_ops;
}
struct wlan_lmac_if_reg_tx_ops *
target_if_regulatory_get_tx_ops(struct wlan_objmgr_psoc *psoc)
{
struct wlan_lmac_if_tx_ops *tx_ops;
tx_ops = wlan_psoc_get_lmac_if_txops(psoc);
if (!tx_ops) {
target_if_err("tx_ops is NULL");
return NULL;
}
return &tx_ops->reg_ops;
}
QDF_STATUS target_if_reg_set_offloaded_info(struct wlan_objmgr_psoc *psoc)
{
struct wlan_lmac_if_reg_rx_ops *reg_rx_ops;
@@ -202,6 +216,24 @@ QDF_STATUS target_if_reg_set_5dot9_ghz_info(struct wlan_objmgr_psoc *psoc)
return QDF_STATUS_SUCCESS;
}
bool
target_if_reg_is_reg_cc_ext_event_host_supported(struct wlan_objmgr_psoc *psoc)
{
struct wlan_lmac_if_reg_tx_ops *reg_tx_ops;
bool reg_ext_cc_supp = false;
reg_tx_ops = target_if_regulatory_get_tx_ops(psoc);
if (!reg_tx_ops) {
target_if_err("reg_tx_ops is NULL");
return reg_ext_cc_supp;
}
if (reg_tx_ops->register_master_ext_handler)
reg_ext_cc_supp = true;
return reg_ext_cc_supp;
}
/**
* tgt_reg_chan_list_update_handler() - Channel list update handler
* @handle: scn handle

Zobrazit soubor

@@ -861,12 +861,10 @@ struct wlan_lmac_if_reg_tx_ops {
void *arg);
QDF_STATUS (*unregister_master_handler)(struct wlan_objmgr_psoc *psoc,
void *arg);
#ifdef CONFIG_BAND_6GHZ
QDF_STATUS (*register_master_ext_handler)(struct wlan_objmgr_psoc *psoc,
void *arg);
QDF_STATUS (*unregister_master_ext_handler)
(struct wlan_objmgr_psoc *psoc, void *arg);
#endif
QDF_STATUS (*set_country_code)(struct wlan_objmgr_psoc *psoc,
void *arg);
QDF_STATUS (*fill_umac_legacy_chanlist)(struct wlan_objmgr_pdev *pdev,

Zobrazit soubor

@@ -5108,6 +5108,7 @@ typedef enum {
wmi_service_go_connected_d3_wow,
wmi_service_ext_tpc_reg_support,
wmi_service_ndi_txbf_support,
wmi_service_reg_cc_ext_event_support,
wmi_services_max,
} wmi_conv_service_ids;
#define WMI_SERVICE_UNAVAILABLE 0xFFFF
@@ -5247,6 +5248,7 @@ struct wmi_host_fw_abi_ver {
* @ast_tid_low_mask_enable: enable tid valid mask for low priority flow
* @nan_separate_iface_support: Separate iface creation for NAN
* @time_sync_ftm: enable ftm based time sync
* @is_reg_cc_ext_event_supported: Flag to indicate if reg_cc_ext is supported
* @max_rnr_neighbours: Max supported RNR neighbors in multisoc APs
* @ema_max_vap_cnt: Number of maximum EMA tx-vaps at any instance of time
* @ema_max_profile_period: Maximum EMA profile periodicity on any pdev
@@ -5354,6 +5356,7 @@ typedef struct {
ast_tid_low_mask_enable:8;
bool nan_separate_iface_support;
bool time_sync_ftm;
bool is_reg_cc_ext_event_supported;
uint32_t max_rnr_neighbours;
uint32_t ema_max_vap_cnt;
uint32_t ema_max_profile_period;

Zobrazit soubor

@@ -7339,6 +7339,10 @@ void wmi_copy_resource_config(wmi_resource_config *resource_cfg,
if (tgt_res_cfg->is_go_connected_d3wow_enabled)
WMI_RSRC_CFG_FLAGS2_IS_GO_CONNECTED_D3WOW_ENABLED_SET(
resource_cfg->flags2, 1);
WMI_RSRC_CFG_HOST_SERVICE_FLAG_REG_CC_EXT_SUPPORT_SET(
resource_cfg->host_service_flags,
tgt_res_cfg->is_reg_cc_ext_event_supported);
}
/* copy_hw_mode_id_in_init_cmd() - Helper routine to copy hw_mode in init cmd
@@ -15762,6 +15766,8 @@ static void populate_tlv_service(uint32_t *wmi_service)
WMI_SERVICE_EXT_TPC_REG_SUPPORT;
wmi_service[wmi_service_ndi_txbf_support] =
WMI_SERVICE_NDI_TXBF_SUPPORT;
wmi_service[wmi_service_reg_cc_ext_event_support] =
WMI_SERVICE_REG_CC_EXT_EVENT_SUPPORT;
}
/**