/* SPDX-License-Identifier: BSD-3-Clause-Clear */ /* * Copyright (c) 2019-2021 The Linux Foundation. All rights reserved. * Copyright (c) 2021-2022 Qualcomm Innovation Center, Inc. All rights reserved. */ #ifndef ATH12K_REG_H #define ATH12K_REG_H #include #include struct ath12k_base; struct ath12k; /* DFS regdomains supported by Firmware */ enum ath12k_dfs_region { ATH12K_DFS_REG_UNSET, ATH12K_DFS_REG_FCC, ATH12K_DFS_REG_ETSI, ATH12K_DFS_REG_MKK, ATH12K_DFS_REG_CN, ATH12K_DFS_REG_KR, ATH12K_DFS_REG_MKK_N, ATH12K_DFS_REG_UNDEF, }; enum ath12k_reg_cc_code { REG_SET_CC_STATUS_PASS = 0, REG_CURRENT_ALPHA2_NOT_FOUND = 1, REG_INIT_ALPHA2_NOT_FOUND = 2, REG_SET_CC_CHANGE_NOT_ALLOWED = 3, REG_SET_CC_STATUS_NO_MEMORY = 4, REG_SET_CC_STATUS_FAIL = 5, }; struct ath12k_reg_rule { u16 start_freq; u16 end_freq; u16 max_bw; u8 reg_power; u8 ant_gain; u16 flags; bool psd_flag; u16 psd_eirp; }; struct ath12k_reg_info { enum ath12k_reg_cc_code status_code; u8 num_phy; u8 phy_id; u16 reg_dmn_pair; u16 ctry_code; u8 alpha2[REG_ALPHA2_LEN + 1]; u32 dfs_region; u32 phybitmap; bool is_ext_reg_event; u32 min_bw_2g; u32 max_bw_2g; u32 min_bw_5g; u32 max_bw_5g; u32 num_2g_reg_rules; u32 num_5g_reg_rules; struct ath12k_reg_rule *reg_rules_2g_ptr; struct ath12k_reg_rule *reg_rules_5g_ptr; enum wmi_reg_6g_client_type client_type; bool rnr_tpe_usable; bool unspecified_ap_usable; /* TODO: All 6G related info can be stored only for required * combination instead of all types, to optimize memory usage. */ u8 domain_code_6g_ap[WMI_REG_CURRENT_MAX_AP_TYPE]; u8 domain_code_6g_client[WMI_REG_CURRENT_MAX_AP_TYPE][WMI_REG_MAX_CLIENT_TYPE]; u32 domain_code_6g_super_id; u32 min_bw_6g_ap[WMI_REG_CURRENT_MAX_AP_TYPE]; u32 max_bw_6g_ap[WMI_REG_CURRENT_MAX_AP_TYPE]; u32 min_bw_6g_client[WMI_REG_CURRENT_MAX_AP_TYPE][WMI_REG_MAX_CLIENT_TYPE]; u32 max_bw_6g_client[WMI_REG_CURRENT_MAX_AP_TYPE][WMI_REG_MAX_CLIENT_TYPE]; u32 num_6g_reg_rules_ap[WMI_REG_CURRENT_MAX_AP_TYPE]; u32 num_6g_reg_rules_cl[WMI_REG_CURRENT_MAX_AP_TYPE][WMI_REG_MAX_CLIENT_TYPE]; struct ath12k_reg_rule *reg_rules_6g_ap_ptr[WMI_REG_CURRENT_MAX_AP_TYPE]; struct ath12k_reg_rule *reg_rules_6g_client_ptr [WMI_REG_CURRENT_MAX_AP_TYPE][WMI_REG_MAX_CLIENT_TYPE]; }; /* Phy bitmaps */ enum ath12k_reg_phy_bitmap { ATH12K_REG_PHY_BITMAP_NO11AX = BIT(5), ATH12K_REG_PHY_BITMAP_NO11BE = BIT(6), }; void ath12k_reg_init(struct ath12k *ar); void ath12k_reg_free(struct ath12k_base *ab); void ath12k_regd_update_work(struct work_struct *work); struct ieee80211_regdomain *ath12k_reg_build_regd(struct ath12k_base *ab, struct ath12k_reg_info *reg_info, bool intersect); int ath12k_regd_update(struct ath12k *ar, bool init); int ath12k_reg_update_chan_list(struct ath12k *ar); #endif