| /* |
| * Copyright (c) 2017-2018 The Linux Foundation. All rights reserved. |
| * |
| * Permission to use, copy, modify, and/or distribute this software for |
| * any purpose with or without fee is hereby granted, provided that the |
| * above copyright notice and this permission notice appear in all |
| * copies. |
| * |
| * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL |
| * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED |
| * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE |
| * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL |
| * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR |
| * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER |
| * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR |
| * PERFORMANCE OF THIS SOFTWARE. |
| */ |
| |
| #ifndef __WMA_HE_H |
| #define __WMA_HE_H |
| |
| #include "wma.h" |
| #include "sir_api.h" |
| #include "target_if.h" |
| |
| #ifdef WLAN_FEATURE_11AX |
| /** |
| * wma_print_he_cap() - Print HE capabilities |
| * @he_cap: pointer to HE Capability |
| * |
| * Received HE capabilities are converted into dot11f structure. |
| * This function will print all the HE capabilities as stored |
| * in the dot11f structure. |
| * |
| * Return: None |
| */ |
| void wma_print_he_cap(tDot11fIEhe_cap *he_cap); |
| |
| /** |
| * wma_print_he_ppet() - Prints HE PPE Threshold |
| * @he_ppet: PPE Threshold |
| * |
| * This function prints HE PPE Threshold as received from FW. |
| * Refer to the definition of wmi_ppe_threshold to understand |
| * how PPE thresholds are packed by FW for a given NSS and RU. |
| * |
| * Return: none |
| */ |
| void wma_print_he_ppet(void *ppet); |
| |
| /** |
| * wma_print_he_phy_cap() - Print HE PHY Capability |
| * @phy_cap: pointer to PHY Capability |
| * |
| * This function prints HE PHY Capability received from FW. |
| * |
| * Return: none |
| */ |
| void wma_print_he_phy_cap(uint32_t *phy_cap); |
| |
| /** |
| * wma_print_he_mac_cap_w1() - Print HE MAC Capability |
| * @mac_cap: MAC Capability |
| * |
| * This function prints HE MAC Capability received from FW. |
| * |
| * Return: none |
| */ |
| void wma_print_he_mac_cap_w1(uint32_t mac_cap); |
| |
| /** |
| * wma_print_he_mac_cap_w2() - Print HE MAC Capability |
| * @mac_cap: MAC Capability |
| * |
| * This function prints HE MAC Capability received from FW. |
| * |
| * Return: none |
| */ |
| void wma_print_he_mac_cap_w2(uint32_t mac_cap); |
| |
| /** |
| * wma_print_he_op() - Print HE Operation |
| * @he_cap: pointer to HE Operation |
| * |
| * Print HE operation stored as dot11f structure |
| * |
| * Return: None |
| */ |
| void wma_print_he_op(tDot11fIEhe_op *he_ops); |
| |
| /** |
| * wma_update_target_ext_he_cap() - Update HE caps with given extended cap |
| * @tgt_hdl: target psoc information |
| * @tgt_cfg: Target config |
| * |
| * This function loop through each hardware mode and for each hardware mode |
| * again it loop through each MAC/PHY and pull the caps 2G and 5G specific |
| * HE caps and derives the final cap. |
| * |
| * Return: None |
| */ |
| void wma_update_target_ext_he_cap(struct target_psoc_info *tgt_hdl, |
| struct wma_tgt_cfg *tgt_cfg); |
| |
| /* |
| * wma_he_update_tgt_services() - update tgt cfg to indicate 11ax support |
| * @wmi_handle: pointer to WMI handle |
| * @cfg: pointer to WMA target services |
| * |
| * Based on WMI SERVICES information, enable 11ax support and set DOT11AX bit |
| * in feature caps bitmap. |
| * |
| * Return: None |
| */ |
| void wma_he_update_tgt_services(struct wmi_unified *wmi_handle, |
| struct wma_tgt_services *cfg); |
| |
| /** |
| * wma_populate_peer_he_cap() - populate peer HE capabilities in peer assoc cmd |
| * @peer: pointer to peer assoc params |
| * @params: pointer to ADD STA params |
| * |
| * Return: None |
| */ |
| void wma_populate_peer_he_cap(struct peer_assoc_params *peer, |
| tpAddStaParams params); |
| |
| /** |
| * wma_update_vdev_he_ops() - update he ops in vdev start request |
| * @req: pointer to vdev start request |
| * @add_bss: pointer to ADD BSS params |
| * |
| * Return: None |
| */ |
| void wma_update_vdev_he_ops(struct wma_vdev_start_req *req, |
| tpAddBssParams add_bss); |
| |
| /** |
| * wma_copy_txrxnode_he_ops() - copy HE ops from vdev start req to txrx node |
| * @node: pointer to txrx node |
| * @req: pointer to vdev start request |
| * |
| * Return: None |
| */ |
| void wma_copy_txrxnode_he_ops(struct wma_txrx_node *node, |
| struct wma_vdev_start_req *req); |
| |
| /** |
| * wma_copy_vdev_start_he_ops() - copy HE ops from vdev start req to vdev start |
| * @params: pointer to vdev_start_params |
| * @req: pointer to vdev start request |
| * |
| * Return: None |
| */ |
| void wma_copy_vdev_start_he_ops(struct vdev_start_params *params, |
| struct wma_vdev_start_req *req); |
| |
| /** |
| * wma_vdev_set_he_bss_params() - set HE OPs in vdev start |
| * @wma: pointer to wma handle |
| * @vdev_id: VDEV id |
| * @req: pointer to vdev start request |
| * |
| * Return: None |
| */ |
| void wma_vdev_set_he_bss_params(tp_wma_handle wma, uint8_t vdev_id, |
| struct wma_vdev_start_req *req); |
| |
| /** |
| * wma_vdev_set_he_config() - set HE Config in vdev start |
| * @wma: pointer to wma handle |
| * @vdev_id: VDEV id |
| * @add_bss: BSS params |
| * |
| * Return: None |
| */ |
| void wma_vdev_set_he_config(tp_wma_handle wma, uint8_t vdev_id, |
| tpAddBssParams add_bss); |
| |
| static inline bool wma_is_peer_he_capable(tpAddStaParams params) |
| { |
| return params->he_capable; |
| } |
| |
| /** |
| * wma_update_vdev_he_capable() - update vdev start request he capability |
| * @req: pointer to vdev start request |
| * @params: pointer to chan switch params |
| * |
| * Return: None |
| */ |
| void wma_update_vdev_he_capable(struct wma_vdev_start_req *req, |
| tpSwitchChannelParams params); |
| |
| /** |
| * wma_update_he_ops_ie() - update the HE OPS IE to firmware |
| * @wma: pointer to wma context |
| * @vdev_id: vdev id |
| * @he_ops: 32bit value of HE ops |
| * |
| * This API is used to send updated HE operational IE to firmware, so that |
| * firmware can be in sync with host |
| * |
| * Return: QDF_STATUS |
| */ |
| QDF_STATUS wma_update_he_ops_ie(tp_wma_handle wma, uint8_t vdev_id, |
| tDot11fIEhe_op *he_ops); |
| |
| /** |
| * wma_get_he_capabilities() - Get HE capabilities from WMA |
| * @he_cap: Pointer to HE capabilities |
| * |
| * Currently HE capabilities are not updated in wma_handle. This |
| * is an interface for upper layer to query capabilities from WMA. |
| * When the real use case arise, update wma_handle with HE capabilities |
| * as required. |
| * |
| * Return: QDF_STATUS |
| */ |
| QDF_STATUS wma_get_he_capabilities(struct he_capability *he_cap); |
| |
| /** |
| * wma_set_he_vdev_param() - update he vdev param in wma |
| * @intr: pointer to wma_txrx_node |
| * @param_id: vdev param id |
| * @value: value of vdev param |
| * |
| * Result: None |
| */ |
| void wma_set_he_vdev_param(struct wma_txrx_node *intr, WMI_VDEV_PARAM param_id, |
| uint32_t value); |
| |
| /** |
| * wma_get_he_vdev_param() - retrieve he vdev param from wma |
| * @intr: pointer to wma_txrx_node |
| * @param_id: vdev param id |
| * |
| * Result: param value |
| */ |
| uint32_t wma_get_he_vdev_param(struct wma_txrx_node *intr, |
| WMI_VDEV_PARAM param_id); |
| |
| #else |
| static inline void wma_print_he_cap(tDot11fIEhe_cap *he_cap) |
| { |
| } |
| |
| static inline void wma_print_he_ppet(void *ppet) |
| { |
| } |
| |
| static inline void wma_print_he_phy_cap(uint32_t *phy_cap) |
| { |
| } |
| |
| static inline void wma_print_he_mac_cap_w1(uint32_t mac_cap) |
| { |
| } |
| |
| static inline void wma_print_he_mac_cap_w2(uint32_t mac_cap) |
| { |
| } |
| |
| static inline void wma_print_he_op(tDot11fIEhe_op *he_ops) |
| { |
| } |
| |
| static inline void wma_update_target_ext_he_cap(struct |
| target_psoc_info *tgt_hdl, |
| struct wma_tgt_cfg *tgt_cfg) |
| { |
| } |
| |
| static inline void wma_he_update_tgt_services(struct wmi_unified *wmi_handle, |
| struct wma_tgt_services *cfg) |
| { |
| cfg->en_11ax = false; |
| return; |
| } |
| |
| static inline void wma_populate_peer_he_cap(struct peer_assoc_params *peer, |
| tpAddStaParams params) |
| { |
| } |
| |
| static inline void wma_update_vdev_he_ops(struct wma_vdev_start_req *req, |
| tpAddBssParams add_bss) |
| { |
| } |
| static inline void wma_copy_txrxnode_he_ops(struct wma_txrx_node *intr, |
| struct wma_vdev_start_req *req) |
| { |
| } |
| |
| static inline void wma_copy_vdev_start_he_ops(struct vdev_start_params *params, |
| struct wma_vdev_start_req *req) |
| { |
| } |
| |
| static inline QDF_STATUS wma_update_he_ops_ie(tp_wma_handle wma, |
| uint8_t vdev_id, tDot11fIEhe_op *he_ops) |
| { |
| return QDF_STATUS_SUCCESS; |
| } |
| |
| static inline void wma_vdev_set_he_bss_params(tp_wma_handle wma, |
| uint8_t vdev_id, struct wma_vdev_start_req *req) |
| { |
| } |
| |
| static inline void wma_vdev_set_he_config(tp_wma_handle wma, uint8_t vdev_id, |
| tpAddBssParams add_bss) |
| { |
| } |
| |
| static inline bool wma_is_peer_he_capable(tpAddStaParams params) |
| { |
| return false; |
| } |
| |
| static inline void wma_update_vdev_he_capable(struct wma_vdev_start_req *req, |
| tpSwitchChannelParams params) |
| { |
| } |
| |
| static inline void wma_set_he_vdev_param(struct wma_txrx_node *intr, |
| WMI_VDEV_PARAM param_id, uint32_t value) |
| { |
| WMA_LOGI(FL("Unable to update WMI_VDEV_PARAM: %0x"), param_id); |
| } |
| |
| static inline uint32_t wma_get_he_vdev_param(struct wma_txrx_node *intr, |
| WMI_VDEV_PARAM param_id) |
| { |
| WMA_LOGI(FL("Unable to update WMI_VDEV_PARAM: %0x"), param_id); |
| return 0; |
| } |
| |
| #endif |
| |
| #endif /* __WMA_HE_H */ |