diff --git a/wmi/inc/wmi_unified_api.h b/wmi/inc/wmi_unified_api.h index 721fdb78fa..e85f3d1b55 100644 --- a/wmi/inc/wmi_unified_api.h +++ b/wmi/inc/wmi_unified_api.h @@ -873,6 +873,19 @@ QDF_STATUS wmi_unified_pdev_get_tpc_config_cmd_send(void *wmi_hdl, QDF_STATUS wmi_unified_set_bwf_cmd_send(void *wmi_hdl, struct set_bwf_params *param); +QDF_STATUS wmi_send_get_user_position_cmd(void *wmi_hdl, uint32_t value); + +QDF_STATUS wmi_send_get_peer_mumimo_tx_count_cmd(void *wmi_hdl, uint32_t value); + +QDF_STATUS wmi_send_reset_peer_mumimo_tx_count_cmd(void *wmi_hdl, + uint32_t value); + +QDF_STATUS wmi_send_pdev_caldata_version_check_cmd(void *wmi_hdl, + uint32_t value); + +QDF_STATUS wmi_unified_send_btcoex_wlan_priority_cmd(void *wmi_hdl, + int value); + QDF_STATUS wmi_unified_set_atf_cmd_send(void *wmi_hdl, struct set_atf_params *param); @@ -1157,6 +1170,18 @@ QDF_STATUS wmi_extract_vdev_scan_ev_param(void *wmi_hdl, void *evt_buf, QDF_STATUS wmi_extract_mu_ev_param(void *wmi_hdl, void *evt_buf, wmi_host_mu_report_event *param); +QDF_STATUS wmi_extract_mu_db_entry(void *wmi_hdl, void *evt_buf, + uint8_t idx, wmi_host_mu_db_entry *param); + +QDF_STATUS wmi_extract_mumimo_tx_count_ev_param(void *wmi_hdl, void *evt_buf, + wmi_host_peer_txmu_cnt_event *param); + +QDF_STATUS wmi_extract_peer_gid_userpos_list_ev_param(void *wmi_hdl, + void *evt_buf, wmi_host_peer_gid_userpos_list_event *param); + +QDF_STATUS wmi_extract_pdev_caldata_version_check_ev_param(void *wmi_hdl, + void *evt_buf, wmi_host_pdev_check_cal_version_event *param); + QDF_STATUS wmi_extract_pdev_tpc_config_ev_param(void *wmi_hdl, void *evt_buf, wmi_host_pdev_tpc_config_event *param); @@ -1269,6 +1294,12 @@ QDF_STATUS wmi_extract_peer_stats(void *wmi_hdl, void *evt_buf, QDF_STATUS wmi_extract_tx_data_traffic_ctrl_ev(void *wmi_hdl, void *evt_buf, wmi_host_tx_data_traffic_ctrl_event *ev); +QDF_STATUS wmi_extract_atf_peer_stats_ev(void *wmi_hdl, void *evt_buf, + wmi_host_atf_peer_stats_event *ev); + +QDF_STATUS wmi_extract_atf_token_info_ev(void *wmi_hdl, void *evt_buf, + uint8_t idx, wmi_host_atf_peer_stats_info *atf_token_info); + QDF_STATUS wmi_extract_vdev_stats(void *wmi_hdl, void *evt_buf, uint32_t index, wmi_host_vdev_stats *vdev_stats); diff --git a/wmi/inc/wmi_unified_non_tlv.h b/wmi/inc/wmi_unified_non_tlv.h index c32eb09af7..6550ab3a12 100644 --- a/wmi/inc/wmi_unified_non_tlv.h +++ b/wmi/inc/wmi_unified_non_tlv.h @@ -124,3 +124,16 @@ QDF_STATUS send_scan_stop_cmd_non_tlv(wmi_unified_t wmi_handle, QDF_STATUS send_scan_chan_list_cmd_non_tlv(wmi_unified_t wmi_handle, struct scan_chan_list_params *param); +QDF_STATUS send_get_user_position_cmd_non_tlv(wmi_unified_t wmi_handle, + uint32_t value); + +QDF_STATUS send_reset_peer_mumimo_tx_count_cmd_non_tlv(wmi_unified_t wmi_handle, + uint32_t value); + +QDF_STATUS send_get_peer_mumimo_tx_count_cmd_non_tlv(wmi_unified_t wmi_handle); + +QDF_STATUS send_pdev_caldata_version_check_cmd_non_tlv(wmi_unified_t wmi_handle, + uint32_t value); + +QDF_STATUS send_btcoex_wlan_priority_cmd_non_tlv(wmi_unified_t wmi_handle, + int value); diff --git a/wmi/inc/wmi_unified_param.h b/wmi/inc/wmi_unified_param.h index 6e7e4b69ff..e2970fb12c 100644 --- a/wmi/inc/wmi_unified_param.h +++ b/wmi/inc/wmi_unified_param.h @@ -127,6 +127,9 @@ #define MAX_SUPPORTED_RATES 128 #define WMI_HOST_MAX_BUFFER_SIZE 1712 #define WMI_HAL_MAX_SANTENNA 4 +#define WMI_HOST_PDEV_VI_PRIORITY_BIT (1<<2) +#define WMI_HOST_PDEV_BEACON_PRIORITY_BIT (1<<4) +#define WMI_HOST_PDEV_MGMT_PRIORITY_BIT (1<<5) #ifdef CONFIG_WIN #if ATH_SUPPORT_FIPS @@ -145,6 +148,17 @@ (_var) |= (((_v) << (_f##_S)) & (_f)); \ } while (0) +/* vdev capabilities bit mask */ +#define WMI_HOST_VDEV_BEACON_SUPPORT 0x1 +#define WMI_HOST_VDEV_WDS_LRN_ENABLED 0x2 +#define WMI_HOST_VDEV_VOW_ENABLED 0x4 +#define WMI_HOST_VDEV_IS_BEACON_SUPPORTED(param) \ + ((param) & WMI_HOST_VDEV_BEACON_SUPPORT) +#define WMI_HOST_VDEV_IS_WDS_LRN_ENABLED(param) \ + ((param) & WMI_HOST_VDEV_WDS_LRN_ENABLED) +#define WMI_HOST_VDEV_IS_VOW_ENABLED(param) \ + ((param) & WMI_HOST_VDEV_VOW_ENABLED) + /* TXBF capabilities masks */ #define WMI_HOST_TXBF_CONF_SU_TX_BFEE_S 0 #define WMI_HOST_TXBF_CONF_SU_TX_BFEE_M 0x1 @@ -1051,6 +1065,8 @@ struct scan_start_params { uint16_t uie_fieldOffset; uint8_t mac_add_bytes[IEEE80211_ADDR_LEN]; #ifndef CONFIG_MCL + bool half_rate; + bool quarter_rate; bool is_strict_pscan_en; bool is_promiscous_mode; bool is_phy_error; @@ -3353,6 +3369,18 @@ typedef struct { */ uint32_t fw_feature_bitmap; + /* WLAN priority GPIO number + * The target uses a GPIO pin to indicate when it is transmitting + * high-priority traffic (e.g. beacon, management, or AC_VI) or + * low-priority traffic (e.g. AC_BE, AC_BK). The HW uses this + * WLAN GPIO pin to determine whether to abort WLAN tx in favor of + * BT activity. + * Which GPIO is used for this WLAN tx traffic priority specification + * varies between platforms, so the host needs to indicate to the + * target which GPIO to use. + */ + uint32_t wlan_priority_gpio; + /* add new members here */ } wmi_host_ext_resource_config; @@ -3733,6 +3761,11 @@ struct mu_scan_params { uint8_t type; uint32_t duration; uint32_t lteu_tx_power; + uint32_t rssi_thr_bssid; + uint32_t rssi_thr_sta; + uint32_t rssi_thr_sc; + uint32_t plmn_id; + uint32_t alpha_num_bssid; }; /** @@ -3757,6 +3790,7 @@ struct lteu_config_params { uint32_t lteu_scan_timeout; uint32_t alpha_num_bssid; uint32_t wifi_tx_power; + uint32_t allow_err_packets; }; struct wmi_macaddr_t { @@ -4831,6 +4865,10 @@ typedef enum { wmi_soc_hw_mode_transition_event_id, wmi_soc_set_dual_mac_config_resp_event_id, wmi_tx_data_traffic_ctrl_event_id, + wmi_peer_tx_mu_txmit_count_event_id, + wmi_peer_gid_userpos_list_event_id, + wmi_pdev_check_cal_version_event_id, + wmi_atf_peer_stats_event_id, wmi_events_max, } wmi_conv_event_id; @@ -4969,6 +5007,8 @@ typedef enum { wmi_pdev_param_rx_chain_mask_5g, wmi_pdev_param_tx_chain_mask_cck, wmi_pdev_param_tx_chain_mask_1ss, + wmi_pdev_param_enable_btcoex, + wmi_pdev_param_atf_peer_stats, wmi_pdev_param_max, } wmi_conv_pdev_params_id; @@ -5073,6 +5113,9 @@ typedef enum { wmi_vdev_param_mcc_rtscts_protection_enable, wmi_vdev_param_mcc_broadcast_probe_enable, wmi_vdev_param_capabilities, + wmi_vdev_param_mgmt_tx_power, + wmi_vdev_param_atf_ssid_sched_policy, + wmi_vdev_param_disable_dyn_bw_rts, wmi_vdev_param_max, } wmi_conv_vdev_param_id; @@ -5182,6 +5225,7 @@ typedef enum { wmi_service_tx_mode_push_only, wmi_service_tx_mode_push_pull, wmi_service_tx_mode_dynamic, + wmi_service_check_cal_version, wmi_services_max, } wmi_conv_service_ids; @@ -5649,18 +5693,40 @@ typedef enum { /* max MU alg combinations supported by target */ #define WMI_HOST_MU_MAX_ALGO_TYPE 3 +/** + * struct wmi_host_mu_db_entry + * @event_type: 0=AP, 1=STA, 2=Small Cell(SC) + * @bssid_mac_addr: Transmitter MAC if entry is WiFi node. PLMNID if SC + * @tx_addr: Transmitter MAC if entry is WiFi node. PLMNID if SC + * @avg_duration_us: Avg. duration for which node was transmitting + * @avg_rssi: Avg. RSSI of all TX packets by node. Unit dBm + * @mu_percent: % medium utilization by node + */ +typedef struct { + uint32_t entry_type; + wmi_host_mac_addr bssid_mac_addr; + wmi_host_mac_addr tx_addr; + uint32_t avg_duration_us; + uint32_t avg_rssi; + uint32_t mu_percent; +} wmi_host_mu_db_entry; + /** * struct wmi_host_mu_report_event - WMI_MU_REPORT_EVENTID * @mu_request_id: request id * @status_reason: MU_STATUS_REASON * @total_mu: MU_ALG_TYPE combinations * @num_active_bssid: number of active bssid + * @hidden_node_mu : hidden node algo MU per bin + * @num_TA_entries : No. of entries found in MU db report */ typedef struct { uint32_t mu_request_id; uint32_t status_reason; uint32_t total_mu[WMI_HOST_MU_MAX_ALGO_TYPE]; uint32_t num_active_bssid; + uint32_t hidden_node_mu[LTEU_MAX_BINS]; + uint32_t num_TA_entries; } wmi_host_mu_report_event; /** @@ -6572,6 +6638,65 @@ typedef struct { uint32_t ctrl_cmd; } wmi_host_tx_data_traffic_ctrl_event; +enum { + WMI_HOST_ATF_PEER_STATS_DISABLED = 0, + WMI_HOST_ATF_PEER_STATS_ENABLED = 1, +}; + +#define WMI_HOST_ATF_PEER_STATS_GET_PEER_AST_IDX(token_info) \ + (token_info.field1 & 0xffff) + +#define WMI_HOST_ATF_PEER_STATS_GET_USED_TOKENS(token_info) \ + ((token_info.field2 & 0xffff0000) >> 16) + +#define WMI_HOST_ATF_PEER_STATS_GET_UNUSED_TOKENS(token_info) \ + (token_info.field2 & 0xffff) + +#define WMI_HOST_ATF_PEER_STATS_SET_PEER_AST_IDX(token_info, peer_ast_idx) \ + do { \ + token_info.field1 &= 0xffff0000; \ + token_info.field1 |= ((peer_ast_idx) & 0xffff); \ + } while (0) + +#define WMI_HOST_ATF_PEER_STATS_SET_USED_TOKENS(token_info, used_token) \ + do { \ + token_info.field2 &= 0x0000ffff; \ + token_info.field2 |= (((used_token) & 0xffff) << 16); \ + } while (0) + +#define WMI_HOST_ATF_PEER_STATS_SET_UNUSED_TOKENS(token_info, unused_token) \ + do { \ + token_info.field2 &= 0xffff0000; \ + token_info.field2 |= ((unused_token) & 0xffff); \ + } while (0) + +typedef struct { + /** + * field1 contains: + * bits 15:0 peer_ast_index WMI_ATF_PEER_STATS_GET_PEER_AST_IDX + * WMI_ATF_PEER_STATS_SET_PEER_AST_IDX + * bits 31:16 reserved + * + * field2 contains: + * bits 15:0 used tokens WMI_ATF_PEER_STATS_GET_USED_TOKENS + * WMI_ATF_PEER_STATS_SET_USED_TOKENS + * bits 31:16 unused tokens WMI_ATF_PEER_STATS_GET_UNUSED_TOKENS + * WMI_ATF_PEER_STATS_SET_UNUSED_TOKENS + * + * field3 for future use + */ + uint32_t field1; + uint32_t field2; + uint32_t field3; +} wmi_host_atf_peer_stats_info; + +typedef struct { + uint32_t num_atf_peers; /** number of peers in token_info_list */ + uint32_t comp_usable_airtime; /** computed usable airtime in tokens */ + uint32_t reserved[4]; /** reserved for future use */ + wmi_host_atf_peer_stats_info token_info_list[1/*num_atf_peers*/]; +} wmi_host_atf_peer_stats_event; + /** * struct wmi_host_ath_dcs_cw_int * @channel: either number or freq in mhz @@ -6841,5 +6966,43 @@ struct WMI_HOST_HAL_REG_CAPABILITIES_EXT { uint32_t low_5ghz_chan; uint32_t high_5ghz_chan; }; -#endif /* _WMI_UNIFIED_PARAM_H_ */ +/* + * struct wmi_host_peer_txmu_cnt_event + * @tx_mu_transmitted - MU-MIMO tx count + */ +typedef struct { + uint32_t tx_mu_transmitted; +} wmi_host_peer_txmu_cnt_event; + +/* + * struct wmi_peer_gid_userpos_list_event + * @usr_list - User list + */ +#define GID_OVERLOAD_GROUP_COUNT 15 +typedef struct { + uint32_t usr_list[GID_OVERLOAD_GROUP_COUNT]; +} wmi_host_peer_gid_userpos_list_event; + +#define WMI_HOST_BOARD_MCN_STRING_MAX_SIZE 19 +#define WMI_HOST_BOARD_MCN_STRING_BUF_SIZE \ + (WMI_HOST_BOARD_MCN_STRING_MAX_SIZE+1) /* null-terminator */ + +typedef struct { + uint32_t software_cal_version; + uint32_t board_cal_version; + /* board_mcn_detail: + * Provide a calibration message string for the host to display. + * Note: on a big-endian host, the 4 bytes within each A_UINT32 portion + * of a WMI message will be automatically byteswapped by the copy engine + * as the messages are transferred between host and target, to convert + * between the target's little-endianness and the host's big-endianness. + * Consequently, a big-endian host should manually unswap the bytes + * within the board_mcn_detail string buffer to get the bytes back into + * the desired natural order. + */ + uint8_t board_mcn_detail[WMI_HOST_BOARD_MCN_STRING_BUF_SIZE]; + uint32_t cal_ok; /* filled with CALIBRATION_STATUS enum value */ +} wmi_host_pdev_check_cal_version_event; + +#endif /* _WMI_UNIFIED_PARAM_H_ */ diff --git a/wmi/inc/wmi_unified_priv.h b/wmi/inc/wmi_unified_priv.h index 918f083bfd..c82e044535 100644 --- a/wmi/inc/wmi_unified_priv.h +++ b/wmi/inc/wmi_unified_priv.h @@ -971,6 +971,23 @@ QDF_STATUS (*send_set_atf_grouping_cmd)(wmi_unified_t wmi_handle, struct atf_grouping_params *param); +QDF_STATUS (*send_get_user_position_cmd)(wmi_unified_t wmi_handle, + uint32_t value); + +QDF_STATUS +(*send_reset_peer_mumimo_tx_count_cmd)(wmi_unified_t wmi_handle, + uint32_t value); + +QDF_STATUS (*send_get_peer_mumimo_tx_count_cmd)(wmi_unified_t wmi_handle, + uint32_t value); + +QDF_STATUS +(*send_pdev_caldata_version_check_cmd)(wmi_unified_t wmi_handle, + uint32_t value); + +QDF_STATUS +(*send_btcoex_wlan_priority_cmd)(wmi_unified_t wmi_handle, int value); + QDF_STATUS (*extract_wds_addr_event)(wmi_unified_t wmi_handle, void *evt_buf, uint16_t len, wds_addr_event_t *wds_ev); @@ -1009,6 +1026,19 @@ QDF_STATUS (*extract_vdev_scan_ev_param)(wmi_unified_t wmi_handle, QDF_STATUS (*extract_mu_ev_param)(wmi_unified_t wmi_handle, void *evt_buf, wmi_host_mu_report_event *param); +QDF_STATUS (*extract_mu_db_entry)(wmi_unified_t wmi_hdl, void *evt_buf, + uint8_t idx, wmi_host_mu_db_entry *param); + +QDF_STATUS (*extract_mumimo_tx_count_ev_param)(wmi_unified_t wmi_handle, + void *evt_buf, wmi_host_peer_txmu_cnt_event *param); + +QDF_STATUS (*extract_peer_gid_userpos_list_ev_param)(wmi_unified_t wmi_handle, + void *evt_buf, wmi_host_peer_gid_userpos_list_event *param); + +QDF_STATUS (*extract_pdev_caldata_version_check_ev_param)( + wmi_unified_t wmi_handle, + void *evt_buf, wmi_host_pdev_check_cal_version_event *param); + QDF_STATUS (*extract_pdev_tpc_config_ev_param)(wmi_unified_t wmi_handle, void *evt_buf, wmi_host_pdev_tpc_config_event *param); @@ -1122,6 +1152,14 @@ QDF_STATUS (*extract_inst_rssi_stats_event)(wmi_unified_t wmi_handle, QDF_STATUS (*extract_tx_data_traffic_ctrl_ev)(wmi_unified_t wmi_handle, void *evt_buf, wmi_host_tx_data_traffic_ctrl_event *ev); +QDF_STATUS (*extract_atf_peer_stats_ev)(wmi_unified_t wmi_handle, + void *evt_buf, wmi_host_atf_peer_stats_event *ev); + +QDF_STATUS (*extract_atf_token_info_ev)(wmi_unified_t wmi_handle, + void *evt_buf, + uint8_t idx, + wmi_host_atf_peer_stats_info *atf_token_info); + QDF_STATUS (*extract_vdev_extd_stats)(wmi_unified_t wmi_handle, void *evt_buf, uint32_t index, wmi_host_vdev_extd_stats *vdev_extd_stats); diff --git a/wmi/src/wmi_unified_api.c b/wmi/src/wmi_unified_api.c index 660348b5b3..41bbf2bb21 100644 --- a/wmi/src/wmi_unified_api.c +++ b/wmi/src/wmi_unified_api.c @@ -5072,6 +5072,82 @@ wmi_send_set_atf_grouping_cmd(void *wmi_hdl, } +/** + * wmi_send_get_user_position_cmd() - send get user position command to fw + * @wmi_handle: wmi handle + * + * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure + */ +QDF_STATUS +wmi_send_get_user_position_cmd(void *wmi_hdl, uint32_t value) +{ + wmi_unified_t wmi_handle = (wmi_unified_t) wmi_hdl; + + if (wmi_handle->ops->send_get_user_position_cmd) + return wmi_handle->ops->send_get_user_position_cmd(wmi_handle, + value); + + return QDF_STATUS_E_FAILURE; +} + +/** + * wmi_send_get_peer_mumimo_tx_count_cmd() - send get mumio tx count + * command to fw + * @wmi_handle: wmi handle + * @value: user pos value + * + * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure + */ +QDF_STATUS +wmi_send_get_peer_mumimo_tx_count_cmd(void *wmi_hdl, uint32_t value) +{ + wmi_unified_t wmi = (wmi_unified_t) wmi_hdl; + + if (wmi->ops->send_get_peer_mumimo_tx_count_cmd) + return wmi->ops->send_get_peer_mumimo_tx_count_cmd(wmi, value); + + return QDF_STATUS_E_FAILURE; +} + +/** + * wmi_send_reset_peer_mumimo_tx_count_cmd() - send reset peer mumimo + * tx count to fw + * @wmi_handle: wmi handle + * @value: reset tx count value + * + * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure + */ +QDF_STATUS +wmi_send_reset_peer_mumimo_tx_count_cmd(void *wmi_hdl, uint32_t value) +{ + wmi_unified_t wmi = (wmi_unified_t) wmi_hdl; + + if (wmi->ops->send_reset_peer_mumimo_tx_count_cmd) + return wmi->ops->send_reset_peer_mumimo_tx_count_cmd(wmi, + value); + + return QDF_STATUS_E_FAILURE; +} + +/** + * wmi_send_pdev_caldata_version_check_cmd() - send reset peer mumimo + * tx count to fw + * @wmi_handle: wmi handle + * @value: value + * + * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure + */ +QDF_STATUS +wmi_send_pdev_caldata_version_check_cmd(void *wmi_hdl, uint32_t value) +{ + wmi_unified_t wmi = (wmi_unified_t) wmi_hdl; + + if (wmi->ops->send_pdev_caldata_version_check_cmd) + return wmi->ops->send_pdev_caldata_version_check_cmd(wmi, + value); + + return QDF_STATUS_E_FAILURE; +} /* Extract - APIs */ /** @@ -5338,6 +5414,90 @@ QDF_STATUS wmi_extract_mu_ev_param(void *wmi_hdl, void *evt_buf, return QDF_STATUS_E_FAILURE; } +/** + * wmi_extract_mu_db_entry() - extract mu db entry from event + * @wmi_handle: wmi handle + * @param evt_buf: pointer to event buffer + * @param param: Pointer to hold mu db entry + * + * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure + */ +QDF_STATUS wmi_extract_mu_db_entry(void *wmi_hdl, void *evt_buf, + uint8_t idx, wmi_host_mu_db_entry *param) +{ + wmi_unified_t wmi_handle = (wmi_unified_t) wmi_hdl; + + if (wmi_handle->ops->extract_mu_db_entry) + return wmi_handle->ops->extract_mu_db_entry(wmi_handle, evt_buf, + idx, param); + + return QDF_STATUS_E_FAILURE; +} + +/** + * wmi_extract_mumimo_tx_count_ev_param() - extract mumimo tx count from event + * @wmi_handle: wmi handle + * @param evt_buf: pointer to event buffer + * @param param: Pointer to hold mumimo tx count + * + * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure + */ +QDF_STATUS wmi_extract_mumimo_tx_count_ev_param(void *wmi_hdl, void *evt_buf, + wmi_host_peer_txmu_cnt_event *param) +{ + wmi_unified_t wmi = (wmi_unified_t) wmi_hdl; + + if (wmi->ops->extract_mumimo_tx_count_ev_param) + return wmi->ops->extract_mumimo_tx_count_ev_param(wmi, + evt_buf, param); + + return QDF_STATUS_E_FAILURE; +} + +/** + * wmi_extract_peer_gid_userpos_list_ev_param() - extract peer userpos list + * from event + * @wmi_handle: wmi handle + * @param evt_buf: pointer to event buffer + * @param param: Pointer to hold peer gid userposition list + * + * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure + */ +QDF_STATUS wmi_extract_peer_gid_userpos_list_ev_param(void *wmi_hdl, + void *evt_buf, + wmi_host_peer_gid_userpos_list_event *param) +{ + wmi_unified_t wmi = (wmi_unified_t) wmi_hdl; + + if (wmi->ops->extract_peer_gid_userpos_list_ev_param) + return wmi->ops->extract_peer_gid_userpos_list_ev_param(wmi, + evt_buf, param); + + return QDF_STATUS_E_FAILURE; +} + +/** + * wmi_extract_pdev_caldata_version_check_ev_param() - extract caldata + * from event + * @wmi_handle: wmi handle + * @param evt_buf: pointer to event buffer + * @param param: Pointer to hold caldata version data + * + * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure + */ +QDF_STATUS wmi_extract_pdev_caldata_version_check_ev_param(void *wmi_hdl, + void *evt_buf, + wmi_host_pdev_check_cal_version_event *param) +{ + wmi_unified_t wmi = (wmi_unified_t) wmi_hdl; + + if (wmi->ops->extract_pdev_caldata_version_check_ev_param) + return wmi->ops->extract_pdev_caldata_version_check_ev_param( + wmi, evt_buf, param); + + return QDF_STATUS_E_FAILURE; +} + /** * wmi_extract_pdev_tpc_config_ev_param() - extract pdev tpc configuration * param from event @@ -6084,7 +6244,6 @@ QDF_STATUS wmi_extract_inst_rssi_stats_event(void *wmi_hdl, void *evt_buf, * from event * @wmi_handle: wmi handle * @param evt_buf: pointer to event buffer - * @param index: Index into chan stats * @param ev: Pointer to hold data traffic control * * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure @@ -6101,6 +6260,49 @@ QDF_STATUS wmi_extract_tx_data_traffic_ctrl_ev(void *wmi_hdl, void *evt_buf, return QDF_STATUS_E_FAILURE; } +/** + * wmi_extract_atf_peer_stats_ev() - extract atf peer stats + * from event + * @wmi_handle: wmi handle + * @param evt_buf: pointer to event buffer + * @param ev: Pointer to hold atf peer stats + * + * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure + */ +QDF_STATUS wmi_extract_atf_peer_stats_ev(void *wmi_hdl, void *evt_buf, + wmi_host_atf_peer_stats_event *ev) +{ + wmi_unified_t wmi = (wmi_unified_t) wmi_hdl; + + if (wmi->ops->extract_atf_peer_stats_ev) + return wmi->ops->extract_atf_peer_stats_ev(wmi, + evt_buf, ev); + + return QDF_STATUS_E_FAILURE; +} + +/** + * wmi_extract_atf_token_info_ev() - extract atf token info + * from event + * @wmi_handle: wmi handle + * @param evt_buf: pointer to event buffer + * @param idx: Index indicating the peer number + * @param ev: Pointer to hold atf token info + * + * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure + */ +QDF_STATUS wmi_extract_atf_token_info_ev(void *wmi_hdl, void *evt_buf, + uint8_t idx, wmi_host_atf_peer_stats_info *ev) +{ + wmi_unified_t wmi = (wmi_unified_t) wmi_hdl; + + if (wmi->ops->extract_atf_token_info_ev) + return wmi->ops->extract_atf_token_info_ev(wmi, + evt_buf, idx, ev); + + return QDF_STATUS_E_FAILURE; +} + /** * wmi_extract_vdev_extd_stats() - extract extended vdev stats from event * @wmi_handle: wmi handle @@ -6179,6 +6381,26 @@ QDF_STATUS wmi_unified_encrypt_decrypt_send_cmd(void *wmi_hdl, return wmi_handle->ops->send_encrypt_decrypt_send_cmd( wmi_handle, params); + return QDF_STATUS_E_FAILURE; +} + +/* + * wmi_unified_send_btcoex_wlan_priority_cmd() - send btcoex priority commands + * @wmi_handle: wmi handle + * @value: Priority value + * + * Send WMI_BTCOEX_CFG_CMDID parameters to fw. + * + * Return: QDF_STATUS_SUCCESS on success, QDF_STATUS_E_** on error + */ +QDF_STATUS wmi_unified_send_btcoex_wlan_priority_cmd(void *wmi_hdl, + int value) +{ + wmi_unified_t wmi = (wmi_unified_t) wmi_hdl; + + if (wmi->ops->send_btcoex_wlan_priority_cmd) + return wmi->ops->send_btcoex_wlan_priority_cmd(wmi, + value); return QDF_STATUS_E_FAILURE; } diff --git a/wmi/src/wmi_unified_non_tlv.c b/wmi/src/wmi_unified_non_tlv.c index e7bccf01cd..d72aabc755 100644 --- a/wmi/src/wmi_unified_non_tlv.c +++ b/wmi/src/wmi_unified_non_tlv.c @@ -1922,7 +1922,7 @@ QDF_STATUS send_scan_start_cmd_non_tlv(wmi_unified_t wmi_handle, WMI_SCAN_EVENT_FOREIGN_CHANNEL | WMI_SCAN_EVENT_DEQUEUED #if QCA_LTEU_SUPPORT - | WMI_SCAN_EVENT_INVALID + | WMI_SCAN_EVENT_GPIO_TIMEOUT; #endif ; @@ -1945,8 +1945,15 @@ QDF_STATUS send_scan_start_cmd_non_tlv(wmi_unified_t wmi_handle, if (param->is_phy_error) cmd->scan_ctrl_flags |= WMI_SCAN_CAPTURE_PHY_ERROR; + if (param->half_rate) + cmd->scan_ctrl_flags |= WMI_SCAN_FLAG_HALF_RATE_SUPPORT; + + if (param->quarter_rate) + cmd->scan_ctrl_flags |= WMI_SCAN_FLAG_QUARTER_RATE_SUPPORT; + /** send multiple braodcast probe req with this delay in between */ cmd->repeat_probe_time = param->repeat_probe_time; + cmd->probe_spacing_time = param->probe_spacing_time; /** delay between channel change and first probe request */ cmd->probe_delay = param->probe_delay; /** idle time on channel for which if no traffic is seen @@ -3157,6 +3164,11 @@ send_mu_scan_cmd_non_tlv(wmi_unified_t wmi_handle, cmd->mu_duration = param->duration; cmd->mu_type = param->type; cmd->lteu_tx_power = param->lteu_tx_power; + cmd->rssi_thr_bssid = param->rssi_thr_bssid; + cmd->rssi_thr_sta = param->rssi_thr_sta; + cmd->rssi_thr_sc = param->rssi_thr_sc; + cmd->plmn_id = param->plmn_id; + cmd->alpha_num_bssid = param->alpha_num_bssid; return wmi_unified_cmd_send(wmi_handle, buf, sizeof(wmi_mu_start_cmd), WMI_MU_CAL_START_CMDID); @@ -3193,6 +3205,7 @@ send_lteu_config_cmd_non_tlv(wmi_unified_t wmi_handle, cmd->alpha_num_bssid = param->alpha_num_bssid; cmd->use_actual_nf = param->use_actual_nf; cmd->wifi_tx_power = param->wifi_tx_power; + cmd->allow_err_packets = param->allow_err_packets; return wmi_unified_cmd_send(wmi_handle, buf, sizeof(wmi_set_lteu_config), WMI_SET_LTEU_CONFIG_CMDID); @@ -4337,7 +4350,8 @@ send_pdev_set_chan_cmd_non_tlv(wmi_unified_t wmi_handle, if (param->quarter_rate) WMI_SET_CHANNEL_FLAG(&cmd->chan, WMI_CHAN_FLAG_QUARTER); - if (param->phy_mode == MODE_11AC_VHT80_80) { + if ((param->phy_mode == MODE_11AC_VHT80_80) || + (param->phy_mode == MODE_11AC_VHT160)) { qdf_print( "WMI channel freq=%d, mode=%x band_center_freq1=%d band_center_freq2=%d\n", cmd->chan.mhz, @@ -5066,6 +5080,162 @@ send_start_oem_data_cmd_non_tlv(wmi_unified_t wmi_handle, return QDF_STATUS_SUCCESS; } +/** + * send_get_user_position_cmd_non_tlv() - send cmd get user position from fw + * @wmi_handle: wmi handle + * @value: user pos value + * + * Return: 0 for success or error code + */ +QDF_STATUS +send_get_user_position_cmd_non_tlv(wmi_unified_t wmi_handle, uint32_t value) +{ + wmi_buf_t buf; + wmi_peer_gid_userpos_list_cmd *cmd; + + buf = wmi_buf_alloc(wmi_handle, sizeof(wmi_peer_gid_userpos_list_cmd)); + if (!buf) { + qdf_print("No WMI resource!"); + return QDF_STATUS_E_FAILURE; + } + qdf_nbuf_put_tail(buf, sizeof(wmi_peer_gid_userpos_list_cmd)); + cmd = (wmi_peer_gid_userpos_list_cmd *)(wmi_buf_data(buf)); + cmd->aid = value; + + if (wmi_unified_cmd_send(wmi_handle, buf, + sizeof(wmi_peer_gid_userpos_list_cmd), + WMI_PEER_GID_USERPOS_LIST_CMDID)) { + wmi_buf_free(buf); + return QDF_STATUS_E_FAILURE; + } + + return QDF_STATUS_SUCCESS; +} + +/** + * send_reset_peer_mumimo_tx_count_cmd_non_tlv() - send mumimo reset tx count fw + * @wmi_handle: wmi handle + * @value: reset tx count + * + * Return: 0 for success or error code + */ +QDF_STATUS +send_reset_peer_mumimo_tx_count_cmd_non_tlv(wmi_unified_t wmi_handle, + uint32_t value) +{ + wmi_buf_t buf; + wmi_peer_txmu_rstcnt_cmd *cmd; + + buf = wmi_buf_alloc(wmi_handle, sizeof(wmi_peer_txmu_rstcnt_cmd)); + if (!buf) { + qdf_print("No WMI resource!"); + return QDF_STATUS_E_FAILURE; + } + qdf_nbuf_put_tail(buf, sizeof(wmi_peer_txmu_rstcnt_cmd)); + cmd = (wmi_peer_txmu_rstcnt_cmd *)(wmi_buf_data(buf)); + cmd->aid = value; + + if (wmi_unified_cmd_send(wmi_handle, buf, + sizeof(wmi_peer_txmu_rstcnt_cmd), + WMI_PEER_TX_MU_TXMIT_RSTCNT_CMDID)) { + wmi_buf_free(buf); + return QDF_STATUS_E_FAILURE; + } + + return QDF_STATUS_SUCCESS; +} + +/** + * send_get_peer_mumimo_tx_count_cmd_non_tlv() - send cmd to get mumimo tx count from fw + * @wmi_handle: wmi handle + * + * Return: 0 for success or error code + */ +QDF_STATUS +send_get_peer_mumimo_tx_count_cmd_non_tlv(wmi_unified_t wmi_handle, + uint32_t value) +{ + wmi_buf_t buf; + wmi_peer_txmu_cnt_cmd *cmd; + + buf = wmi_buf_alloc(wmi_handle, sizeof(wmi_peer_txmu_cnt_cmd)); + if (!buf) { + qdf_print("No WMI resource!"); + return QDF_STATUS_E_FAILURE; + } + qdf_nbuf_put_tail(buf, sizeof(wmi_peer_txmu_cnt_cmd)); + cmd = (wmi_peer_txmu_cnt_cmd *)(wmi_buf_data(buf)); + cmd->aid = value; + + if (wmi_unified_cmd_send(wmi_handle, buf, + sizeof(wmi_peer_txmu_cnt_cmd), + WMI_PEER_TX_MU_TXMIT_COUNT_CMDID)) { + wmi_buf_free(buf); + return QDF_STATUS_E_FAILURE; + } + + return QDF_STATUS_SUCCESS; +} + +/** + * send_pdev_caldata_version_check_cmd_non_tlv() - send caldata check cmd to fw + * @wmi_handle: wmi handle + * @param: reserved param + * + * Return: 0 for success or error code + */ +QDF_STATUS +send_pdev_caldata_version_check_cmd_non_tlv(wmi_unified_t wmi_handle, + uint32_t param) +{ + wmi_pdev_check_cal_version_cmd *cmd; + wmi_buf_t buf; + int32_t len = sizeof(wmi_pdev_check_cal_version_cmd); + + buf = wmi_buf_alloc(wmi_handle, len); + if (!buf) { + qdf_print("%s:wmi_buf_alloc failed\n", __func__); + return QDF_STATUS_E_FAILURE; + } + cmd = (wmi_pdev_check_cal_version_cmd *)wmi_buf_data(buf); + cmd->reserved = param; /* set to 0x0 as expected from FW */ + if (wmi_unified_cmd_send(wmi_handle, buf, len, + WMI_PDEV_CHECK_CAL_VERSION_CMDID)) { + wmi_buf_free(buf); + return QDF_STATUS_E_FAILURE; + } + + return QDF_STATUS_SUCCESS; +} + +/** + * send_btcoex_wlan_priority_cmd_non_tlv() - send btcoex wlan priority fw + * @wmi_handle: wmi handle + * @value: priority value + * + * Return: 0 for success or error code + */ +QDF_STATUS +send_btcoex_wlan_priority_cmd_non_tlv(wmi_unified_t wmi_handle, int value) +{ + wmi_buf_t buf; + wmi_btcoex_cfg_cmd *cmd; + int len = sizeof(wmi_btcoex_cfg_cmd); + + buf = wmi_buf_alloc(wmi_handle, len); + if (!buf) { + qdf_print("%s:wmi_buf_alloc failed\n", __func__); + return QDF_STATUS_E_FAILURE; + } + cmd = (wmi_btcoex_cfg_cmd *) wmi_buf_data(buf); + cmd->btcoex_wlan_priority_bitmap = value; + if (wmi_unified_cmd_send(wmi_handle, buf, len, WMI_BTCOEX_CFG_CMDID)) { + wmi_buf_free(buf); + return QDF_STATUS_E_FAILURE; + } + + return QDF_STATUS_SUCCESS; +} /** * wmi_copy_resource_config_non_tlv() - copy resource configuration function * @param resource_cfg: pointer to resource configuration @@ -5849,6 +6019,99 @@ QDF_STATUS extract_mu_ev_param_non_tlv(wmi_unified_t wmi_handle, void *evt_buf, param->status_reason = event->status_reason; qdf_mem_copy(param->total_mu, event->total_mu, sizeof(param->total_mu)); param->num_active_bssid = event->num_active_bssid; + qdf_mem_copy(param->hidden_node_mu, event->hidden_node_mu, + sizeof(param->hidden_node_mu)); + param->num_TA_entries = event->num_TA_entries; + + return QDF_STATUS_SUCCESS; +} + +/** + * extract_mu_db_entry_non_tlv() - extract mu db entry from event + * @wmi_handle: wmi handle + * @param evt_buf: pointer to event buffer + * @param profile_data: Pointer to hold mu_db_entry + * + * Return: 0 for success or error code + */ +QDF_STATUS extract_mu_db_entry_non_tlv(wmi_unified_t wmi_handle, + void *evt_buf, uint8_t idx, + wmi_host_mu_db_entry *db_entry) +{ + wmi_mu_report_event *event = (wmi_mu_report_event *)evt_buf; + + if (idx > event->num_TA_entries) + return QDF_STATUS_E_INVAL; + + qdf_mem_copy(db_entry, &event->mu_entry[idx], + sizeof(wmi_host_mu_db_entry)); + + return QDF_STATUS_SUCCESS; +} + + +/** + * extract_mumimo_tx_count_ev_param_non_tlv() - extract mumimo tx count from event + * @wmi_handle: wmi handle + * @param evt_buf: pointer to event buffer + * @param param: Pointer to hold mu report + * + * Return: 0 for success or error code + */ +QDF_STATUS extract_mumimo_tx_count_ev_param_non_tlv(wmi_unified_t wmi_handle, + void *evt_buf, wmi_host_peer_txmu_cnt_event *param) +{ + wmi_peer_txmu_cnt_event *event = (wmi_peer_txmu_cnt_event *)evt_buf; + + param->tx_mu_transmitted = event->tx_mu_transmitted; + + return QDF_STATUS_SUCCESS; +} + +/** + * extract_peer_gid_userpos_list_ev_param_non_tlv() - extract gid user position + * from event + * @wmi_handle: wmi handle + * @param evt_buf: pointer to event buffer + * @param param: Pointer to hold peer user position list + * + * Return: 0 for success or error code + */ +QDF_STATUS extract_peer_gid_userpos_list_ev_param_non_tlv( + wmi_unified_t wmi_handle, + void *evt_buf, + wmi_host_peer_gid_userpos_list_event *param) +{ + wmi_peer_gid_userpos_list_event *event = + (wmi_peer_gid_userpos_list_event *)evt_buf; + + qdf_mem_copy(param->usr_list, event->usr_list, sizeof(param->usr_list)); + + return QDF_STATUS_SUCCESS; +} + +/** + * extract_pdev_caldata_version_check_ev_param_non_tlv() - extract caldata from event + * @wmi_handle: wmi handle + * @param evt_buf: pointer to event buffer + * @param param: Pointer to hold peer caldata version data + * + * Return: 0 for success or error code + */ +QDF_STATUS extract_pdev_caldata_version_check_ev_param_non_tlv( + wmi_unified_t wmi_handle, + void *evt_buf, + wmi_host_pdev_check_cal_version_event *param) +{ + wmi_pdev_check_cal_version_event *event = + (wmi_pdev_check_cal_version_event *)evt_buf; + + param->software_cal_version = event->software_cal_version; + param->board_cal_version = event->board_cal_version; + param->cal_ok = event->cal_ok; + + qdf_mem_copy(param->board_mcn_detail, event->board_mcn_detail, + sizeof(param->board_mcn_detail)); return QDF_STATUS_SUCCESS; } @@ -7397,7 +7660,6 @@ static QDF_STATUS extract_inst_rssi_stats_event_non_tlv( * from event * @wmi_handle: wmi handle * @param evt_buf: pointer to event buffer - * @param index: Index into chan stats * @param ev: Pointer to hold data traffic control * * Return: 0 for success or error code @@ -7416,6 +7678,57 @@ static QDF_STATUS extract_tx_data_traffic_ctrl_ev_non_tlv( return QDF_STATUS_SUCCESS; } +/** + * extract_atf_peer_stats_ev_non_tlv() - extract atf peer stats + * from event + * @wmi_handle: wmi handle + * @param evt_buf: pointer to event buffer + * @param ev: Pointer to hold atf stats event data + * + * Return: 0 for success or error code + */ +static QDF_STATUS extract_atf_peer_stats_ev_non_tlv( + wmi_unified_t wmi_handle, void *evt_buf, + wmi_host_atf_peer_stats_event *ev) +{ + wmi_atf_peer_stats_event *evt = + (wmi_atf_peer_stats_event *)evt_buf; + + ev->num_atf_peers = evt->num_atf_peers; + ev->comp_usable_airtime = evt->comp_usable_airtime; + qdf_mem_copy(&ev->reserved[0], &evt->reserved[0], + sizeof(evt->reserved)); + + return QDF_STATUS_SUCCESS; +} + +/** + * extract_atf_token_info_ev_non_tlv() - extract atf token info + * from event + * @wmi_handle: wmi handle + * @param evt_buf: pointer to event buffer + * @idx: Index indicating the peer number + * @param atf_token_info: Pointer to hold atf token info + * + * Return: 0 for success or error code + */ +static QDF_STATUS extract_atf_token_info_ev_non_tlv( + wmi_unified_t wmi_handle, void *evt_buf, + uint8_t idx, wmi_host_atf_peer_stats_info *atf_token_info) +{ + wmi_atf_peer_stats_event *evt = + (wmi_atf_peer_stats_event *)evt_buf; + + if (idx > evt->num_atf_peers) + return QDF_STATUS_E_INVAL; + + atf_token_info->field1 = evt->token_info_list[idx].field1; + atf_token_info->field2 = evt->token_info_list[idx].field2; + atf_token_info->field3 = evt->token_info_list[idx].field3; + + return QDF_STATUS_SUCCESS; +} + #ifdef WMI_INTERFACE_EVENT_LOGGING static bool is_management_record_non_tlv(uint32_t cmd_id) { @@ -7555,6 +7868,14 @@ struct wmi_ops non_tlv_ops = { .send_rtt_keepalive_req_cmd = send_rtt_keepalive_req_cmd_non_tlv, .send_periodic_chan_stats_config_cmd = send_periodic_chan_stats_config_cmd_non_tlv, + .send_get_user_position_cmd = send_get_user_position_cmd_non_tlv, + .send_reset_peer_mumimo_tx_count_cmd = + send_reset_peer_mumimo_tx_count_cmd_non_tlv, + .send_get_peer_mumimo_tx_count_cmd = + send_get_peer_mumimo_tx_count_cmd_non_tlv, + .send_pdev_caldata_version_check_cmd = + send_pdev_caldata_version_check_cmd_non_tlv, + .send_btcoex_wlan_priority_cmd = send_btcoex_wlan_priority_cmd_non_tlv, .get_target_cap_from_service_ready = extract_service_ready_non_tlv, .extract_fw_version = extract_fw_version_non_tlv, @@ -7625,6 +7946,16 @@ struct wmi_ops non_tlv_ops = { .extract_fips_event_data = extract_fips_event_data_non_tlv, .extract_fips_event_error_status = extract_fips_event_error_status_non_tlv, + .extract_mumimo_tx_count_ev_param = + extract_mumimo_tx_count_ev_param_non_tlv, + .extract_peer_gid_userpos_list_ev_param = + extract_peer_gid_userpos_list_ev_param_non_tlv, + .extract_pdev_caldata_version_check_ev_param = + extract_pdev_caldata_version_check_ev_param_non_tlv, + .extract_mu_db_entry = extract_mu_db_entry_non_tlv, + .extract_atf_peer_stats_ev = extract_atf_peer_stats_ev_non_tlv, + .extract_atf_token_info_ev = extract_atf_token_info_ev_non_tlv, + }; /** @@ -7703,6 +8034,8 @@ static void populate_non_tlv_service(uint32_t *wmi_service) wmi_service[wmi_service_tx_mode_push_pull] = WMI_SERVICE_TX_MODE_PUSH_PULL; wmi_service[wmi_service_tx_mode_dynamic] = WMI_SERVICE_TX_MODE_DYNAMIC; + wmi_service[wmi_service_check_cal_version] = + WMI_SERVICE_CHECK_CAL_VERSION; wmi_service[wmi_service_roam_scan_offload] = WMI_SERVICE_UNAVAILABLE; wmi_service[wmi_service_arpns_offload] = WMI_SERVICE_UNAVAILABLE; @@ -7851,6 +8184,14 @@ static void populate_non_tlv_events_id(uint32_t *event_ids) event_ids[wmi_tx_data_traffic_ctrl_event_id] = WMI_TX_DATA_TRAFFIC_CTRL_EVENTID; event_ids[wmi_pdev_utf_event_id] = WMI_PDEV_UTF_EVENTID; + event_ids[wmi_peer_tx_mu_txmit_count_event_id] = + WMI_PEER_TX_MU_TXMIT_COUNT_EVENTID; + event_ids[wmi_peer_gid_userpos_list_event_id] = + WMI_PEER_GID_USERPOS_LIST_EVENTID; + event_ids[wmi_pdev_check_cal_version_event_id] = + WMI_PDEV_CHECK_CAL_VERSION_EVENTID; + event_ids[wmi_atf_peer_stats_event_id] = + WMI_ATF_PEER_STATS_EVENTID; } /** @@ -8034,6 +8375,10 @@ static void populate_pdev_param_non_tlv(uint32_t *pdev_param) WMI_PDEV_PARAM_ATF_DYNAMIC_ENABLE; pdev_param[wmi_pdev_param_atf_ssid_group_policy] = WMI_PDEV_PARAM_ATF_SSID_GROUP_POLICY; + pdev_param[wmi_pdev_param_enable_btcoex] = + WMI_PDEV_PARAM_ENABLE_BTCOEX; + pdev_param[wmi_pdev_param_atf_peer_stats] = + WMI_PDEV_PARAM_ATF_PEER_STATS; pdev_param[wmi_pdev_param_rfkill_enable] = WMI_UNAVAILABLE_PARAM; pdev_param[wmi_pdev_param_hw_rfkill_config] = WMI_UNAVAILABLE_PARAM; pdev_param[wmi_pdev_param_low_power_rf_enable] = WMI_UNAVAILABLE_PARAM; @@ -8195,6 +8540,11 @@ static void populate_vdev_param_non_tlv(uint32_t *vdev_param) vdev_param[wmi_vdev_param_sta_kickout] = WMI_VDEV_PARAM_STA_KICKOUT; vdev_param[wmi_vdev_param_capabilities] = WMI_VDEV_PARAM_CAPABILITIES; + vdev_param[wmi_vdev_param_mgmt_tx_power] = WMI_VDEV_PARAM_MGMT_TX_POWER; + vdev_param[wmi_vdev_param_atf_ssid_sched_policy] = + WMI_VDEV_PARAM_ATF_SSID_SCHED_POLICY; + vdev_param[wmi_vdev_param_disable_dyn_bw_rts] = + WMI_VDEV_PARAM_DISABLE_DYN_BW_RTS; } #endif