2025-05-10 21:58:58 +08:00

478 lines
13 KiB
C
Executable File

/******************************************************************************
*
* Copyright(c) 2019 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.
*
*****************************************************************************/
#ifndef _HAL_API_TMP_H_
#define _HAL_API_TMP_H_
/**** may be get from hal_com **********************************/
#define H2C_MSR_ROLE_RSVD 0
#define H2C_MSR_ROLE_STA 1
#define H2C_MSR_ROLE_AP 2
#define H2C_MSR_ROLE_GC 3
#define H2C_MSR_ROLE_GO 4
#define H2C_MSR_ROLE_TDLS 5
#define H2C_MSR_ROLE_ADHOC 6
#define H2C_MSR_ROLE_MESH 7
#define H2C_MSR_ROLE_MAX 8
/*************************************************************************************/
typedef enum _HW_VARIABLES {
HW_VAR_NET_TYPE,
HW_VAR_SET_OPMODE,
HW_VAR_MAC_ADDR,
HW_VAR_BSSID,
HW_VAR_BASIC_RATE,
HW_VAR_TXPAUSE,
HW_VAR_BCN_FUNC,
HW_VAR_CORRECT_TSF,
HW_VAR_RCR,
HW_VAR_MLME_DISCONNECT,
HW_VAR_MLME_SITESURVEY,
HW_VAR_MLME_JOIN,
HW_VAR_ON_RCR_AM,
HW_VAR_OFF_RCR_AM,
HW_VAR_BEACON_INTERVAL,
HW_VAR_SLOT_TIME,
HW_VAR_RESP_SIFS,
HW_VAR_ACK_PREAMBLE,
HW_VAR_SEC_CFG,
HW_VAR_SEC_DK_CFG,
HW_VAR_BCN_VALID,
HW_VAR_FREECNT,
HW_VAR_STOP_BCN,
HW_VAR_RESUME_BCN,
/* PHYDM odm->SupportAbility */
HW_VAR_CAM_EMPTY_ENTRY,
HW_VAR_CAM_INVALID_ALL,
HW_VAR_AC_PARAM_VO,
HW_VAR_AC_PARAM_VI,
HW_VAR_AC_PARAM_BE,
HW_VAR_AC_PARAM_BK,
HW_VAR_ACM_CTRL,
#ifdef CONFIG_WMMPS_STA
HW_VAR_UAPSD_TID,
#endif /* CONFIG_WMMPS_STA */
HW_VAR_AMPDU_MIN_SPACE,
#ifdef CONFIG_80211N_HT
HW_VAR_AMPDU_FACTOR,
#endif /* CONFIG_80211N_HT */
HW_VAR_RXDMA_AGG_PG_TH,
HW_VAR_SET_RPWM,
HW_VAR_CPWM,
HW_VAR_H2C_FW_PWRMODE,
HW_VAR_H2C_INACTIVE_IPS,
HW_VAR_H2C_FW_JOINBSSRPT,
HW_VAR_FWLPS_RF_ON,
HW_VAR_H2C_FW_P2P_PS_OFFLOAD,
#ifdef CONFIG_LPS_PG
HW_VAR_LPS_PG_HANDLE,
#endif
HW_VAR_TRIGGER_GPIO_0,
HW_VAR_BT_SET_COEXIST,
HW_VAR_BT_ISSUE_DELBA,
HW_VAR_FIFO_CLEARN_UP,
HW_VAR_RESTORE_HW_SEQ,
HW_VAR_CHECK_TXBUF,
HW_VAR_PCIE_STOP_TX_DMA,
HW_VAR_APFM_ON_MAC, /* Auto FSM to Turn On, include clock, isolation, power control for MAC only */
/* The valid upper nav range for the HW updating, if the true value is larger than the upper range, the HW won't update it. */
/* Unit in microsecond. 0 means disable this function. */
#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
HW_VAR_WOWLAN,
HW_VAR_WAKEUP_REASON,
#endif
HW_VAR_RPWM_TOG,
#ifdef CONFIG_GPIO_WAKEUP
HW_VAR_WOW_OUTPUT_GPIO,
HW_VAR_WOW_INPUT_GPIO,
HW_SET_GPIO_WL_CTRL,
#endif
HW_VAR_SYS_CLKR,
HW_VAR_NAV_UPPER,
HW_VAR_CHK_HI_QUEUE_EMPTY,
HW_VAR_CHK_MGQ_CPU_EMPTY,
HW_VAR_DL_BCN_SEL,
HW_VAR_AMPDU_MAX_TIME,
HW_VAR_WIRELESS_MODE,
HW_VAR_USB_MODE,
HW_VAR_PORT_SWITCH,
HW_VAR_PORT_CFG,
HW_VAR_DM_IN_LPS_LCLK,/*flag CONFIG_LPS_LCLK_WD_TIMER*/
#ifdef DBG_CHECK_FW_PS_STATE
HW_VAR_FW_PS_STATE,
#endif
HW_VAR_SOUNDING_ENTER,
HW_VAR_SOUNDING_LEAVE,
HW_VAR_SOUNDING_RATE,
HW_VAR_SOUNDING_STATUS,
HW_VAR_SOUNDING_FW_NDPA,
HW_VAR_SOUNDING_CLK,
HW_VAR_SOUNDING_SET_GID_TABLE,
HW_VAR_SOUNDING_CSI_REPORT,
HW_VAR_DL_RSVD_PAGE,
HW_VAR_DUMP_MAC_QUEUE_INFO,
HW_VAR_ASIX_IOT,
HW_VAR_CH_SW_NEED_TO_TAKE_CARE_IQK_INFO,
HW_VAR_CH_SW_IQK_INFO_BACKUP,
HW_VAR_CH_SW_IQK_INFO_RESTORE,
HW_VAR_DBI,
HW_VAR_MDIO,
HW_VAR_L1OFF_CAPABILITY,
HW_VAR_L1OFF_NIC_SUPPORT,
#ifdef CONFIG_TDLS
#ifdef CONFIG_TDLS_CH_SW
HW_VAR_TDLS_BCN_EARLY_C2H_RPT,
#endif
#endif
HW_VAR_DUMP_MAC_TXFIFO,
HW_VAR_PWR_CMD,
HW_VAR_SET_SOML_PARAM,
HW_VAR_ENABLE_RX_BAR,
HW_VAR_TSF_AUTO_SYNC,
HW_VAR_LPS_STATE_CHK,
#ifdef CONFIG_RTS_FULL_BW
HW_VAR_SET_RTS_BW,
#endif
#if defined(CONFIG_PCI_HCI)
HW_VAR_ENSWBCN,
#endif
HW_VAR_ACKTO,
HW_VAR_ACKTO_CCK,
} HW_VARIABLES;
static inline u8 rtw_hal_set_hwreg(_adapter *padapter, u8 var, u8 *val)
{
return 0;
}
static inline void rtw_hal_get_hwreg(_adapter *padapter, u8 var, u8 *val)
{}
typedef enum _HAL_DEF_VARIABLE {
HAL_DEF_IS_SUPPORT_ANT_DIV,
HAL_DEF_DBG_DUMP_RXPKT,/* for dbg */
HAL_DEF_BEAMFORMER_CAP,
HAL_DEF_BEAMFORMEE_CAP,
HW_VAR_MAX_RX_AMPDU_FACTOR,
HW_DEF_RA_INFO_DUMP,
HAL_DEF_DBG_DUMP_TXPKT,
HAL_DEF_TX_PAGE_SIZE,
HW_VAR_BEST_AMPDU_DENSITY,
} HAL_DEF_VARIABLE;
static inline u8 rtw_hal_set_def_var(_adapter *padapter, HAL_DEF_VARIABLE def_var, void *val)
{
return 0;
}
u8 rtw_hal_get_def_var(struct _ADAPTER *a,
enum _HAL_DEF_VARIABLE def_var, void *val);
static inline u8 rtw_hal_check_ips_status(_adapter *padapter)
{
return 0;
}
static inline void rtw_hal_sec_read_cam_ent(_adapter *adapter, u8 id, u8 *ctrl, u8 *mac, u8 *key)
{}
static inline void rtw_hal_sec_write_cam_ent(_adapter *adapter, u8 id, u16 ctrl, u8 *mac, u8 *key)
{}
static inline void rtw_hal_sec_clr_cam_ent(_adapter *adapter, u8 id)
{}
static inline bool rtw_hal_sec_read_cam_is_gk(_adapter *adapter, u8 id)
{
return _TRUE;
}
static inline u8 rtw_hal_get_current_tx_rate(_adapter *adapter, struct sta_info *psta)
{
return 0;
}
static u8 rtw_get_current_tx_sgi(_adapter *padapter, struct sta_info *psta)
{
return 0;
}
static inline void rtw_hal_linked_info_dump(_adapter *padapter, u8 benable)
{}
static inline bool rtw_hal_get_phy_edcca_flag(_adapter *adapter)
{
return _TRUE;
}
static inline u64 rtw_hal_get_tsftr_by_port(_adapter *adapter, u8 port)
{
return 1;
}
static inline void rtw_hal_dump_rsvd_page(void *sel, _adapter *adapter, u8 page_offset, u8 page_num)
{}
/*u8 beamforming_get_htndp_tx_rate(void *dm_void, u8 bfer_str_num);*/
static inline u8 rtw_hal_get_htndp_tx_rate(_adapter *adapter, u8 bfer_str_num)
{
return 0;
}
/*u8 beamforming_get_vht_ndp_tx_rate(void *dm_void, u8 bfer_str_num);*/
static inline u8 rtw_hal_get_vht_ndp_tx_rate(_adapter *adapter, u8 bfer_str_num)
{
return 0;
}
static inline u8 rtw_hal_get_sounding_info(_adapter *adapter,u16 *throughput,
u8 total_bfee_num, u8 *tx_rate)
{
return 0;
}
static inline void rtw_hal_dump_target_tx_power(void *sel, _adapter *adapter)
{}
static inline void rtw_hal_dump_tx_power_by_rate(void *sel, _adapter *adapter)
{}
static inline void rtw_hal_dump_macaddr(void *sel, _adapter *adapter)
{}
static inline void rtw_hal_dump_trx_mode(void *sel, _adapter *adapter)
{}
static inline void rtw_hal_phy_adaptivity_parm_msg(void *sel, _adapter *adapter)
{}
#if defined(CONFIG_RTW_LED) && defined(CONFIG_RTW_SW_LED)
#ifndef CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
#define CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY 0
#endif
#if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
void rtw_sw_led_blink_uc_trx_only(LED_DATA *led);
void rtw_sw_led_ctl_mode_uc_trx_only(_adapter *adapter, LED_CTL_MODE ctl);
#endif
void rtw_led_control(_adapter *adapter, LED_CTL_MODE ctl);
void rtw_led_tx_control(_adapter *adapter, const u8 *da);
void rtw_led_rx_control(_adapter *adapter, const u8 *da);
void rtw_led_set_iface_en(_adapter *adapter, u8 en);
void rtw_led_set_iface_en_mask(_adapter *adapter, u8 mask);
void rtw_led_set_ctl_en_mask(_adapter *adapter, u32 ctl_mask);
void rtw_led_set_ctl_en_mask_primary(_adapter *adapter);
void rtw_led_set_ctl_en_mask_virtual(_adapter *adapter);
#else
#define rtw_led_control(adapter, ctl) do {} while (0)
#define rtw_led_tx_control(adapter, da) do {} while (0)
#define rtw_led_rx_control(adapter, da) do {} while (0)
#define rtw_led_set_iface_en(adapter, en) do {} while (0)
#define rtw_led_set_iface_en_mask(adapter, mask) do {} while (0)
#define rtw_led_set_ctl_en_mask(adapter, ctl_mask) do {} while (0)
#define rtw_led_set_ctl_en_mask_primary(adapter) do {} while (0)
#define rtw_led_set_ctl_en_mask_virtual(adapter) do {} while (0)
#endif /* defined(CONFIG_RTW_LED) && defined(CONFIG_RTW_SW_LED) */
#ifdef CONFIG_PCI_HCI
static inline void rtw_hal_irp_reset(_adapter *padapter)
{}
static inline void rtw_hal_pci_dbi_write(_adapter *padapter, u16 addr, u8 data)
{}
static inline u8 rtw_hal_pci_dbi_read(_adapter *padapter, u16 addr)
{ return 0;}
static inline void rtw_hal_pci_mdio_write(_adapter *padapter, u8 addr, u16 data)
{}
static inline u16 rtw_hal_pci_mdio_read(_adapter *padapter, u8 addr)
{ return 0;}
static inline u8 rtw_hal_pci_l1off_nic_support(_adapter *padapter)
{ return 0;}
static inline u8 rtw_hal_pci_l1off_capability(_adapter *padapter)
{ return 0;}
static inline void rtw_hal_unmap_beacon_icf(_adapter *padapter)
{
//hal->hal_ops.unmap_beacon_icf(padapter);
}
#endif
#if defined(CONFIG_PCI_HCI)
static inline u8 rtw_hal_check_nic_enough_desc_all(_adapter *padapter)
{ return _SUCCESS;}
static s32 rtw_hal_dump_xframe(_adapter *adapter, struct xmit_frame *pxmitframe)
{ return _SUCCESS;}
#endif
static inline s32 rtw_hal_macid_sleep(_adapter *adapter, u8 macid)
{ return 0;}
static inline s32 rtw_hal_macid_wakeup(_adapter *adapter, u8 macid)
{ return 0;}
static inline s32 rtw_hal_macid_sleep_all_used(_adapter *adapter)
{ return 0;}
static inline s32 rtw_hal_macid_wakeup_all_used(_adapter *adapter)
{ return 0;}
static void rtw_hal_c2h_pkt_hdl(_adapter *adapter, u8 *buf, u16 len)
{
//adapter->dvobj->hal_func.hal_mac_c2h_handler(adapter, buf, len);
}
static inline s32 rtw_hal_fill_h2c_cmd(_adapter *padapter, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer)
{
/*
_adapter *pri_adapter = GET_PRIMARY_ADAPTER(padapter);
if (GET_PHL_COM(pri_adapter)->fw_ready == _TRUE)
return hal->hal_ops.fill_h2c_cmd(padapter, ElementID, CmdLen, pCmdBuffer);
else if (padapter->registrypriv.mp_mode == 0)
RTW_PRINT(FUNC_ADPT_FMT" FW doesn't exit when no MP mode, by pass H2C id:0x%02x\n"
, FUNC_ADPT_ARG(padapter), ElementID);
*/
return 0;
}
#ifdef CONFIG_DFS_MASTER
static inline void rtw_odm_radar_detect_reset(_adapter *adapter)
{
//phydm_radar_detect_reset(adapter_to_phydm(adapter));
}
static inline void rtw_odm_radar_detect_disable(_adapter *adapter)
{
//phydm_radar_detect_disable(adapter_to_phydm(adapter));
}
/* called after ch, bw is set */
static inline void rtw_odm_radar_detect_enable(_adapter *adapter)
{
//phydm_radar_detect_enable(adapter_to_phydm(adapter));
}
static inline BOOLEAN rtw_odm_radar_detect(_adapter *adapter)
{
return 0;//phydm_radar_detect(adapter_to_phydm(adapter));
}
static inline u8 rtw_odm_radar_detect_polling_int_ms(struct dvobj_priv *dvobj)
{
return 0;//phydm_dfs_polling_time(dvobj_to_phydm(dvobj));
}
#endif /* CONFIG_DFS_MASTER */
static inline void rtw_hal_reqtxrpt(_adapter *padapter, u8 macid)
{
//if (hal->hal_ops.reqtxrpt)
//hal->hal_ops.reqtxrpt(padapter, macid);
}
static inline u8 rtw_hal_get_port(_adapter *adapter)
{ return 0;}
static inline void rtw_hal_read_edca(_adapter *adapter, u16 *vo_params, u16 *vi_params,
u16 *be_params, u16 *bk_params)
{
//hal->hal_func.read_wmmedca_reg(padapter, vo_params, vi_params, be_params, bk_params);
}
static inline void rtw_hal_update_iqk_fw_offload_cap(_adapter *adapter)
{}
static inline void rtw_hal_dump_sta_traffic(void *sel, _adapter *adapter, struct sta_info *psta)
{}
static inline s32 rtw_hal_set_FwMediaStatusRpt_single_cmd
(_adapter *adapter, bool opmode, bool miracast, bool miracast_sink, u8 role, u8 macid)
{ return 0;}
static inline void rtw_hal_rcr_set_chk_bssid(_adapter *adapter, u8 self_action)
{}
enum QSEL_ID {
QSLT_BK_ID,
QSLT_BE_ID,
QSLT_VI_ID,
QSLT_VO_ID,
QSLT_BEACON_ID,
QSLT_HIGH_ID,
QSLT_MGNT_ID,
QSLT_CMD_ID
};
static inline u8 rtw_hal_get_qsel(_adapter *adapter, enum QSEL_ID qsel)
{
/*QSLT_HIGH*/
return 0;
}
/************************ xmit *******************/
static inline void rtw_hal_bcn_param_setting(_adapter *padapter)
{
//hal->hal_ops.set_beacon_param_handler(padapter);
}
static inline void rtw_hal_set_tx_power_level(_adapter *adapter, u8 channel)
{}
/****************** GEORGIA_TODO_REDEFINE_IO ************************/
static inline u32 rtw_hal_get_htsf(_adapter *adapter)/*get tst high 4 bytes */
{
return 0;
}
static inline u32 rtw_hal_get_ltsf(_adapter *adapter)/*get tst low 4 bytes */
{
return 0;
}
static inline u32 rtw_hal_get_dma_statu(_adapter *adapter)
{
return 0;
}
#ifdef DBG_TXBD_DESC_DUMP
static inline u32 rtw_hal_get_txbd_rwreg(_adapter *adapter)
{
return 0;
}
#endif
#ifdef RTW_SUPPORT_PLATFORM_SHUTDOWN
static inline u8 rtw_hal_sdio_leave_suspend(_adapter *adapter)
{
return 0;
}
#endif
#if defined(CONFIG_FWLPS_IN_IPS)
static inline void rtw_hal_set_fw_in_ips_mode(_adapter *padapter, u8 enable)
{}
#endif
#ifdef CONFIG_LPS_RPWM_TIMER
static inline bool rtw_hal_is_leave_ps(_adapter *padapter)
{
return _FALSE;
}
#endif
static inline void rtw_hal_get_version(char *str, u32 len)
{
//get hal version
//rtw_halmac_get_version(str, 30);
// get fw version
// get phy (bb/rf) version
// get btc version
}
#endif /*_HAL_API_TMP_H_*/