/******************************************************************************
|
*
|
* Copyright(c) 2007 - 2020 Realtek Corporation.
|
*
|
* This program is free software; you can redistribute it and/or modify it
|
* under the terms of version 2 of the GNU General Public License as
|
* published by the Free Software Foundation.
|
*
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
* more details.
|
*
|
* The full GNU General Public License is included in this distribution in the
|
* file called LICENSE.
|
*
|
* Contact Information:
|
* wlanfae <wlanfae@realtek.com>
|
* Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
|
* Hsinchu 300, Taiwan.
|
*
|
* Larry Finger <Larry.Finger@lwfinger.net>
|
*
|
*****************************************************************************/
|
#ifndef __HALRF_IQK_8852BH__
|
#define __HALRF_IQK_8852BH__
|
#ifdef RF_8852B_SUPPORT
|
|
#define iqk_version_8852b 0x17
|
#define ss_8852b 2
|
#define mac_reg_num_8852b 2
|
#define bb_reg_num_8852b 1
|
#define rf_reg_num_8852b 6
|
#define iqk_delay_8852b 1
|
#define iqk_step_8852b 2
|
#define rxk_step_8852b 4
|
#define path_baseaddr 0x8
|
#define txagck 0
|
#define lok 1
|
#define txk 2
|
#define rxk 3
|
#define IQK_THR_ReK 8
|
|
|
void halrf_iqk_8852b(struct rf_info *rf, enum phl_phy_idx phy_idx, bool force);
|
|
//cv b
|
void iqk_init_8852b(struct rf_info *rf);
|
void halrf_iqk_8852b(struct rf_info *rf, enum phl_phy_idx phy_idx, bool force);
|
void halrf_doiqk_8852b(struct rf_info *rf, bool force,
|
enum phl_phy_idx phy_idx, u8 path);
|
void iqk_get_ch_info_8852b(struct rf_info *rf, enum phl_phy_idx phy, u8 path);
|
bool iqk_mcc_page_sel_8852b(struct rf_info *rf, enum phl_phy_idx phy, u8 path);
|
void iqk_macbb_setting_8852b(struct rf_info *rf, enum phl_phy_idx phy_idx, u8 path);
|
void iqk_preset_8852b(struct rf_info *rf, u8 path);
|
void iqk_start_iqk_8852b(struct rf_info *rf, enum phl_phy_idx phy_idx,
|
u8 path);
|
void iqk_restore_8852b(struct rf_info *rf, u8 path);
|
void iqk_afebb_restore_8852b(struct rf_info *rf, enum phl_phy_idx phy_idx, u8 path);
|
void halrf_iqk_reload_8852b(struct rf_info *rf, u8 path);
|
void halrf_nbiqk_enable_8852b(struct rf_info *rf, bool nbiqk_en);
|
void halrf_iqk_toneleakage_8852b(struct rf_info *rf, u8 path);
|
void halrf_iqk_sram_enable_8852b(struct rf_info *rf, bool iqk_sram_en);
|
void halrf_iqk_xym_enable_8852b(struct rf_info *rf, bool iqk_xym_en);
|
void halrf_iqk_fft_enable_8852b(struct rf_info *rf, bool iqk_fft_en);
|
void halrf_iqk_cfir_enable_8852b(struct rf_info *rf, bool iqk_cfir_en);
|
void halrf_iqk_onoff_8852b(struct rf_info *rf, bool is_enable);
|
void halrf_iqk_lok_bypass_8852b(struct rf_info *rf, u8 path);
|
void halrf_iqk_rx_bypass_8852b(struct rf_info *rf, u8 path);
|
void halrf_iqk_tx_bypass_8852b(struct rf_info *rf, u8 path);
|
|
void iqk_backup_mac_bb_8852b(struct rf_info *rf, u8 path,
|
u32 backup_mac[mac_reg_num_8852b],
|
u32 backup_bb[bb_reg_num_8852b],
|
u32 backup_mac_reg[mac_reg_num_8852b],
|
u32 backup_bb_reg[bb_reg_num_8852b]);
|
void iqk_backup_rf_8852b(struct rf_info *rf, u8 path,
|
u32 backup_rf[][rf_reg_num_8852b],
|
u32 backup_rf_reg[][rf_reg_num_8852b]);
|
void iqk_restore_mac_bb_8852b(struct rf_info *rf, u8 path,
|
u32 backup_mac[mac_reg_num_8852b],
|
u32 backup_bb[bb_reg_num_8852b],
|
u32 backup_mac_reg[mac_reg_num_8852b],
|
u32 backup_bb_reg[bb_reg_num_8852b]);
|
void iqk_restore_rf_8852b(struct rf_info *rf, u8 path,
|
u32 backup_rf[][rf_reg_num_8852b],
|
u32 backup_rf_reg[][rf_reg_num_8852b]);
|
|
void halrf_iqk_track_8852b(struct rf_info *rf);
|
|
bool halrf_iqk_get_ther_rek_8852b(struct rf_info *rf );
|
void halrf_iqk_dbcc_8852b(struct rf_info *rf, u8 path);
|
u8 halrf_iqk_get_mcc_ch0_8852b(struct rf_info *rf );
|
u8 halrf_iqk_get_mcc_ch1_8852b(struct rf_info *rf );
|
bool halrf_check_fwiqk_done_8852b(struct rf_info *rf);
|
void iqk_set_info_8852b(struct rf_info *rf, enum phl_phy_idx phy_idx, u8 path);
|
void halrf_enable_fw_iqk_8852b(struct rf_info *rf, bool is_fw_iqk);
|
u8 halrf_get_iqk_times_8852b(struct rf_info *rf) ;
|
u32 halrf_get_iqk_ver_8852b(void);
|
u8 halrf_iqk_get_rxevm_8852b(struct rf_info *rf);
|
u32 halrf_iqk_get_rximr_8852b(struct rf_info *rf, u8 path, u32 idx);
|
|
|
#endif
|
#endif /* __HALRF_IQK_8852BH__ */
|