162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0 */ 262306a36Sopenharmony_ci/* Copyright(c) 2009-2012 Realtek Corporation.*/ 362306a36Sopenharmony_ci 462306a36Sopenharmony_ci#ifndef __RTL92C_DM_H__ 562306a36Sopenharmony_ci#define __RTL92C_DM_H__ 662306a36Sopenharmony_ci 762306a36Sopenharmony_ci#define HAL_DM_DIG_DISABLE BIT(0) 862306a36Sopenharmony_ci#define HAL_DM_HIPWR_DISABLE BIT(1) 962306a36Sopenharmony_ci 1062306a36Sopenharmony_ci#define OFDM_TABLE_LENGTH 37 1162306a36Sopenharmony_ci#define OFDM_TABLE_SIZE_92D 43 1262306a36Sopenharmony_ci#define CCK_TABLE_LENGTH 33 1362306a36Sopenharmony_ci 1462306a36Sopenharmony_ci#define CCK_TABLE_SIZE 33 1562306a36Sopenharmony_ci 1662306a36Sopenharmony_ci#define BW_AUTO_SWITCH_HIGH_LOW 25 1762306a36Sopenharmony_ci#define BW_AUTO_SWITCH_LOW_HIGH 30 1862306a36Sopenharmony_ci 1962306a36Sopenharmony_ci#define DM_DIG_FA_UPPER 0x32 2062306a36Sopenharmony_ci#define DM_DIG_FA_LOWER 0x20 2162306a36Sopenharmony_ci#define DM_DIG_FA_TH0 0x100 2262306a36Sopenharmony_ci#define DM_DIG_FA_TH1 0x400 2362306a36Sopenharmony_ci#define DM_DIG_FA_TH2 0x600 2462306a36Sopenharmony_ci 2562306a36Sopenharmony_ci#define RXPATHSELECTION_SS_TH_LOW 30 2662306a36Sopenharmony_ci#define RXPATHSELECTION_DIFF_TH 18 2762306a36Sopenharmony_ci 2862306a36Sopenharmony_ci#define DM_RATR_STA_INIT 0 2962306a36Sopenharmony_ci#define DM_RATR_STA_HIGH 1 3062306a36Sopenharmony_ci#define DM_RATR_STA_MIDDLE 2 3162306a36Sopenharmony_ci#define DM_RATR_STA_LOW 3 3262306a36Sopenharmony_ci 3362306a36Sopenharmony_ci#define CTS2SELF_THVAL 30 3462306a36Sopenharmony_ci#define REGC38_TH 20 3562306a36Sopenharmony_ci 3662306a36Sopenharmony_ci#define WAIOTTHVAL 25 3762306a36Sopenharmony_ci 3862306a36Sopenharmony_ci#define TXHIGHPWRLEVEL_NORMAL 0 3962306a36Sopenharmony_ci#define TXHIGHPWRLEVEL_LEVEL1 1 4062306a36Sopenharmony_ci#define TXHIGHPWRLEVEL_LEVEL2 2 4162306a36Sopenharmony_ci#define TXHIGHPWRLEVEL_BT1 3 4262306a36Sopenharmony_ci#define TXHIGHPWRLEVEL_BT2 4 4362306a36Sopenharmony_ci 4462306a36Sopenharmony_ci#define DM_TYPE_BYFW 0 4562306a36Sopenharmony_ci#define DM_TYPE_BYDRIVER 1 4662306a36Sopenharmony_ci 4762306a36Sopenharmony_ci#define TX_POWER_NEAR_FIELD_THRESH_LVL2 74 4862306a36Sopenharmony_ci#define TX_POWER_NEAR_FIELD_THRESH_LVL1 67 4962306a36Sopenharmony_ci#define INDEX_MAPPING_NUM 13 5062306a36Sopenharmony_ci 5162306a36Sopenharmony_cistruct swat { 5262306a36Sopenharmony_ci u8 failure_cnt; 5362306a36Sopenharmony_ci u8 try_flag; 5462306a36Sopenharmony_ci u8 stop_trying; 5562306a36Sopenharmony_ci long pre_rssi; 5662306a36Sopenharmony_ci long trying_threshold; 5762306a36Sopenharmony_ci u8 cur_antenna; 5862306a36Sopenharmony_ci u8 pre_antenna; 5962306a36Sopenharmony_ci}; 6062306a36Sopenharmony_ci 6162306a36Sopenharmony_cienum tag_dynamic_init_gain_operation_type_definition { 6262306a36Sopenharmony_ci DIG_TYPE_THRESH_HIGH = 0, 6362306a36Sopenharmony_ci DIG_TYPE_THRESH_LOW = 1, 6462306a36Sopenharmony_ci DIG_TYPE_BACKOFF = 2, 6562306a36Sopenharmony_ci DIG_TYPE_RX_GAIN_MIN = 3, 6662306a36Sopenharmony_ci DIG_TYPE_RX_GAIN_MAX = 4, 6762306a36Sopenharmony_ci DIG_TYPE_ENABLE = 5, 6862306a36Sopenharmony_ci DIG_TYPE_DISABLE = 6, 6962306a36Sopenharmony_ci DIG_OP_TYPE_MAX 7062306a36Sopenharmony_ci}; 7162306a36Sopenharmony_ci 7262306a36Sopenharmony_cienum dm_1r_cca { 7362306a36Sopenharmony_ci CCA_1R = 0, 7462306a36Sopenharmony_ci CCA_2R = 1, 7562306a36Sopenharmony_ci CCA_MAX = 2, 7662306a36Sopenharmony_ci}; 7762306a36Sopenharmony_ci 7862306a36Sopenharmony_cienum dm_rf { 7962306a36Sopenharmony_ci RF_SAVE = 0, 8062306a36Sopenharmony_ci RF_NORMAL = 1, 8162306a36Sopenharmony_ci RF_MAX = 2, 8262306a36Sopenharmony_ci}; 8362306a36Sopenharmony_ci 8462306a36Sopenharmony_cienum dm_sw_ant_switch { 8562306a36Sopenharmony_ci ANS_ANTENNA_B = 1, 8662306a36Sopenharmony_ci ANS_ANTENNA_A = 2, 8762306a36Sopenharmony_ci ANS_ANTENNA_MAX = 3, 8862306a36Sopenharmony_ci}; 8962306a36Sopenharmony_ci 9062306a36Sopenharmony_civoid rtl92d_dm_init(struct ieee80211_hw *hw); 9162306a36Sopenharmony_civoid rtl92d_dm_watchdog(struct ieee80211_hw *hw); 9262306a36Sopenharmony_civoid rtl92d_dm_init_edca_turbo(struct ieee80211_hw *hw); 9362306a36Sopenharmony_civoid rtl92d_dm_write_dig(struct ieee80211_hw *hw); 9462306a36Sopenharmony_civoid rtl92d_dm_check_txpower_tracking_thermal_meter(struct ieee80211_hw *hw); 9562306a36Sopenharmony_civoid rtl92d_dm_init_rate_adaptive_mask(struct ieee80211_hw *hw); 9662306a36Sopenharmony_ci 9762306a36Sopenharmony_ci#endif 98