Orange Pi5 kernel

Deprecated Linux kernel 5.10.110 for OrangePi 5/5B/5+ boards

3 Commits   0 Branches   0 Tags
/* SPDX-License-Identifier: GPL-2.0 */
/* Copyright(c) 2007 - 2017 Realtek Corporation */

#ifndef __HAL_INTF_H__
#define __HAL_INTF_H__


enum RTL871X_HCI_TYPE {
	RTW_PCIE	= BIT0,
	RTW_USB	= BIT1,
	RTW_SDIO	= BIT2,
	RTW_GSPI	= BIT3,
};

enum _CHIP_TYPE {

	NULL_CHIP_TYPE,
	RTL8188E,
	RTL8192E,
	RTL8812,
	RTL8821, /* RTL8811 */
	RTL8723B,
	RTL8814A,
	RTL8703B,
	RTL8188F,
	RTL8822B,
	RTL8723D,
	RTL8821C,
	MAX_CHIP_TYPE
};

extern const u32 _chip_type_to_odm_ic_type[];
#define chip_type_to_odm_ic_type(chip_type) (((chip_type) >= MAX_CHIP_TYPE) ? _chip_type_to_odm_ic_type[MAX_CHIP_TYPE] : _chip_type_to_odm_ic_type[(chip_type)])

enum hal_hw_timer_type {
	HAL_TIMER_NONE = 0,
	HAL_TIMER_TXBF = 1,
	HAL_TIMER_EARLYMODE = 2,
};


enum hw_variables {
	HW_VAR_MEDIA_STATUS,
	HW_VAR_SET_OPMODE,
	HW_VAR_MAC_ADDR,
	HW_VAR_BSSID,
	HW_VAR_INIT_RTS_RATE,
	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_RF_TYPE,
	HW_VAR_TSF,
	HW_VAR_FREECNT,

	/* 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,
	HW_VAR_AMPDU_MIN_SPACE,
	HW_VAR_AMPDU_FACTOR,
	HW_VAR_RXDMA_AGG_PG_TH,
	HW_VAR_SET_RPWM,
	HW_VAR_CPWM,
	HW_VAR_H2C_FW_PWRMODE,
	HW_VAR_H2C_PS_TUNE_PARAM,
	HW_VAR_H2C_FW_JOINBSSRPT,
	HW_VAR_FWLPS_RF_ON,
	HW_VAR_H2C_FW_P2P_PS_OFFLOAD,
	HW_VAR_TRIGGER_GPIO_0,
	HW_VAR_BT_SET_COEXIST,
	HW_VAR_BT_ISSUE_DELBA,
	HW_VAR_SWITCH_EPHY_WoWLAN,
	HW_VAR_EFUSE_USAGE,
	HW_VAR_EFUSE_BYTES,
	HW_VAR_EFUSE_BT_USAGE,
	HW_VAR_EFUSE_BT_BYTES,
	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 */
	HW_VAR_HCI_SUS_STATE,
	/* 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. */
	HW_VAR_RPWM_TOG,
	HW_VAR_SYS_CLKR,
	HW_VAR_NAV_UPPER,
	HW_VAR_RPT_TIMER_SETTING,
	HW_VAR_TX_RPT_MAX_MACID,
	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_DO_IQK,
	HW_VAR_DM_IN_LPS_LCLK,
	HW_VAR_SET_REQ_FW_PS,
	HW_VAR_FW_PS_STATE,
	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,
	/*Add by YuChen for TXBF HW timer*/
	HW_VAR_HW_REG_TIMER_INIT,
	HW_VAR_HW_REG_TIMER_RESTART,
	HW_VAR_HW_REG_TIMER_START,
	HW_VAR_HW_REG_TIMER_STOP,
	/*Add by YuChen for TXBF HW timer*/
	HW_VAR_DL_RSVD_PAGE,
	HW_VAR_MACID_LINK,
	HW_VAR_MACID_NOLINK,
	HW_VAR_DUMP_MAC_QUEUE_INFO,
	HW_VAR_ASIX_IOT,
#ifdef CONFIG_MI_WITH_MBSSID_CAM
	HW_VAR_MBSSID_CAM_WRITE,
	HW_VAR_MBSSID_CAM_CLEAR,
	HW_VAR_RCR_MBSSID_EN,
#endif
	HW_VAR_EN_HW_UPDATE_TSF,
	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,
	HW_VAR_DUMP_MAC_TXFIFO,
	HW_VAR_PWR_CMD,
	HW_VAR_ENABLE_RX_BAR,
	HW_VAR_TSF_AUTO_SYNC,
};

enum hal_def_variable {
	HAL_DEF_UNDERCORATEDSMOOTHEDPWDB,
	HAL_DEF_IS_SUPPORT_ANT_DIV,
	HAL_DEF_DRVINFO_SZ,
	HAL_DEF_MAX_RECVBUF_SZ,
	HAL_DEF_RX_PACKET_OFFSET,
	HAL_DEF_RX_DMA_SZ_WOW,
	HAL_DEF_RX_DMA_SZ,
	HAL_DEF_RX_PAGE_SIZE,
	HAL_DEF_DBG_DUMP_RXPKT,/* for dbg */
	HAL_DEF_RA_DECISION_RATE,
	HAL_DEF_RA_SGI,
	HAL_DEF_PT_PWR_STATUS,
	HAL_DEF_TX_LDPC,				/* LDPC support */
	HAL_DEF_RX_LDPC,				/* LDPC support */
	HAL_DEF_TX_STBC,				/* TX STBC support */
	HAL_DEF_RX_STBC,				/* RX STBC support */
	HAL_DEF_EXPLICIT_BEAMFORMER,/* Explicit  Compressed Steering Capable */
	HAL_DEF_EXPLICIT_BEAMFORMEE,/* Explicit Compressed Beamforming Feedback Capable */
	HAL_DEF_VHT_MU_BEAMFORMER,	/* VHT MU Beamformer support */
	HAL_DEF_VHT_MU_BEAMFORMEE,	/* VHT MU Beamformee support */
	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,
	HAL_DEF_TX_PAGE_BOUNDARY,
	HAL_DEF_TX_PAGE_BOUNDARY_WOWLAN,
	HAL_DEF_ANT_DETECT,/* to do for 8723a */
	HAL_DEF_PCI_SUUPORT_L1_BACKDOOR, /* Determine if the L1 Backdoor setting is turned on. */
	HAL_DEF_PCI_AMD_L1_SUPPORT,
	HAL_DEF_PCI_ASPM_OSC, /* Support for ASPM OSC, added by Roger, 2013.03.27. */
	HAL_DEF_DBG_DIS_PWT, /* disable Tx power training or not. */
	HAL_DEF_EFUSE_USAGE,	/* Get current EFUSE utilization. 2008.12.19. Added by Roger. */
	HAL_DEF_EFUSE_BYTES,
	HW_VAR_BEST_AMPDU_DENSITY,
};

enum hal_odm_variable {
	HAL_ODM_STA_INFO,
	HAL_ODM_P2P_STATE,
	HAL_ODM_WIFI_DISPLAY_STATE,
	HAL_ODM_REGULATION,
	HAL_ODM_INITIAL_GAIN,
	HAL_ODM_RX_INFO_DUMP,
	HAL_ODM_RX_Dframe_INFO,
};

enum hal_intf_ps_func {
	HAL_USB_SELECT_SUSPEND,
	HAL_MAX_ID,
};

typedef int(*c2h_id_filter)(struct adapter *adapter, u8 id, u8 seq, u8 plen, u8 *payload);

struct txpwr_idx_comp;

struct hal_ops {
	/*** initialize section ***/
	void	(*read_chip_version)(struct adapter *adapt);
	void	(*init_default_value)(struct adapter *adapt);
	void	(*intf_chip_configure)(struct adapter *adapt);
	u8	(*read_adapter_info)(struct adapter *adapt);
	u32(*hal_power_on)(struct adapter *adapt);
	void	(*hal_power_off)(struct adapter *adapt);
	u32(*hal_init)(struct adapter *adapt);
	u32(*hal_deinit)(struct adapter *adapt);
	void	(*dm_init)(struct adapter *adapt);
	void	(*dm_deinit)(struct adapter *adapt);

	/*** xmit section ***/
	int(*init_xmit_priv)(struct adapter *adapt);
	void	(*free_xmit_priv)(struct adapter *adapt);
	int(*hal_xmit)(struct adapter *adapt, struct xmit_frame *pxmitframe);
	/*
	 * mgnt_xmit should be implemented to run in interrupt context
	 */
	int(*mgnt_xmit)(struct adapter *adapt, struct xmit_frame *pmgntframe);
	int(*hal_xmitframe_enqueue)(struct adapter *adapt, struct xmit_frame *pxmitframe);
	void	(*run_thread)(struct adapter *adapt);
	void	(*cancel_thread)(struct adapter *adapt);

	/*** recv section ***/
	int(*init_recv_priv)(struct adapter *adapt);
	void	(*free_recv_priv)(struct adapter *adapt);
	u32(*inirp_init)(struct adapter *adapt);
	u32(*inirp_deinit)(struct adapter *adapt);
	/*** interrupt hdl section ***/
	void	(*enable_interrupt)(struct adapter *adapt);
	void	(*disable_interrupt)(struct adapter *adapt);
	u8(*check_ips_status)(struct adapter *adapt);

	/*** DM section ***/
	void	(*InitSwLeds)(struct adapter *adapt);
	void	(*DeInitSwLeds)(struct adapter *adapt);
	void	(*set_chnl_bw_handler)(struct adapter *adapt, u8 channel, enum channel_width Bandwidth, u8 Offset40, u8 Offset80);

	void	(*set_tx_power_level_handler)(struct adapter *adapt, u8 channel);
	void	(*get_tx_power_level_handler)(struct adapter *adapt, int *powerlevel);

	void (*set_tx_power_index_handler)(struct adapter *adapt, u32 powerindex, enum rf_path rfpath, u8 rate);
	u8 (*get_tx_power_index_handler)(struct adapter *adapt, enum rf_path rfpath, u8 rate, u8 bandwidth, u8 channel, struct txpwr_idx_comp *tic);

	void	(*hal_dm_watchdog)(struct adapter *adapt);

	u8	(*set_hw_reg_handler)(struct adapter *adapt, u8	variable, u8 *val);

	void	(*GetHwRegHandler)(struct adapter *adapt, u8	variable, u8 *val);

	u8 (*get_hal_def_var_handler)(struct adapter *adapt, enum hal_def_variable eVariable, void * pValue);

	u8 (*SetHalDefVarHandler)(struct adapter *adapt, enum hal_def_variable eVariable, void * pValue);

	void	(*GetHalODMVarHandler)(struct adapter *adapt, enum hal_odm_variable eVariable, void * pValue1, void * pValue2);
	void	(*SetHalODMVarHandler)(struct adapter *adapt, enum hal_odm_variable eVariable, void * pValue1, bool bSet);

	void	(*SetBeaconRelatedRegistersHandler)(struct adapter *adapt);

	u8 (*interface_ps_func)(struct adapter *adapt, enum hal_intf_ps_func efunc_id, u8 *val);

	u32 (*read_bbreg)(struct adapter *adapt, u32 RegAddr, u32 BitMask);
	void	(*write_bbreg)(struct adapter *adapt, u32 RegAddr, u32 BitMask, u32 Data);
	u32 (*read_rfreg)(struct adapter *adapt, enum rf_path eRFPath, u32 RegAddr, u32 BitMask);
	void	(*write_rfreg)(struct adapter *adapt, enum rf_path eRFPath, u32 RegAddr, u32 BitMask, u32 Data);

	void (*EfusePowerSwitch)(struct adapter *adapt, u8 bWrite, u8 PwrState);
	void (*BTEfusePowerSwitch)(struct adapter *adapt, u8 bWrite, u8 PwrState);
	void (*ReadEFuse)(struct adapter *adapt, u8 efuseType, u16 _offset, u16 _size_byte, u8 *pbuf, bool bPseudoTest);
	void (*EFUSEGetEfuseDefinition)(struct adapter *adapt, u8 efuseType, u8 type, void *pOut, bool bPseudoTest);
	u16 (*EfuseGetCurrentSize)(struct adapter *adapt, u8 efuseType, bool bPseudoTest);
	bool	(*Efuse_PgPacketRead)(struct adapter *adapt, u8 offset, u8 *data, bool bPseudoTest);
	bool	(*Efuse_PgPacketWrite)(struct adapter *adapt, u8 offset, u8 word_en, u8 *data, bool bPseudoTest);
	u8 (*Efuse_WordEnableDataWrite)(struct adapter *adapt, u16 efuse_addr, u8 word_en, u8 *data, bool bPseudoTest);
	bool (*Efuse_PgPacketWrite_BT)(struct adapter *adapt, u8 offset, u8 word_en, u8 *data, bool bPseudoTest);

	void (*hal_notch_filter)(struct adapter *adapter, bool enable);
	int (*c2h_handler)(struct adapter *adapter, u8 id, u8 seq, u8 plen, u8 *payload);
	void (*reqtxrpt)(struct adapter *adapt, u8 macid);
	int (*fill_h2c_cmd)(struct adapter *, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer);
	void (*fill_fake_txdesc)(struct adapter *, u8 *pDesc, u32 BufferLen,
				 u8 IsPsPoll, u8 IsBTQosNull, u8 bDataFrame);
	int (*fw_dl)(struct adapter *adapter, bool wowlan);

	u8 (*hal_get_tx_buff_rsvd_page_num)(struct adapter *adapter, bool wowlan);
	void (*fw_correct_bcn)(struct adapter * adapt);
};

enum prt_eeprom_type {
	EEPROM_93C46,
	EEPROM_93C56,
	EEPROM_BOOT_EFUSE,
};



#define RF_CHANGE_BY_INIT	0
#define RF_CHANGE_BY_IPS	BIT28
#define RF_CHANGE_BY_PS	BIT29
#define RF_CHANGE_BY_HW	BIT30
#define RF_CHANGE_BY_SW	BIT31

enum hardware_type {
	HARDWARE_TYPE_RTL8188EE,
	HARDWARE_TYPE_RTL8188EU,
	HARDWARE_TYPE_RTL8188ES,
	/*	NEW_GENERATION_IC */
	HARDWARE_TYPE_RTL8192EE,
	HARDWARE_TYPE_RTL8192EU,
	HARDWARE_TYPE_RTL8192ES,
	HARDWARE_TYPE_RTL8812E,
	HARDWARE_TYPE_RTL8812AU,
	HARDWARE_TYPE_RTL8811AU,
	HARDWARE_TYPE_RTL8821E,
	HARDWARE_TYPE_RTL8821U,
	HARDWARE_TYPE_RTL8821S,
	HARDWARE_TYPE_RTL8723BE,
	HARDWARE_TYPE_RTL8723BU,
	HARDWARE_TYPE_RTL8723BS,
	HARDWARE_TYPE_RTL8814AE,
	HARDWARE_TYPE_RTL8814AU,
	HARDWARE_TYPE_RTL8814AS,
	HARDWARE_TYPE_RTL8821BE,
	HARDWARE_TYPE_RTL8821BU,
	HARDWARE_TYPE_RTL8821BS,
	HARDWARE_TYPE_RTL8822BE,
	HARDWARE_TYPE_RTL8822BU,
	HARDWARE_TYPE_RTL8822BS,
	HARDWARE_TYPE_RTL8703BE,
	HARDWARE_TYPE_RTL8703BU,
	HARDWARE_TYPE_RTL8703BS,
	HARDWARE_TYPE_RTL8188FE,
	HARDWARE_TYPE_RTL8188FU,
	HARDWARE_TYPE_RTL8188FS,
	HARDWARE_TYPE_RTL8723DE,
	HARDWARE_TYPE_RTL8723DU,
	HARDWARE_TYPE_RTL8723DS,
	HARDWARE_TYPE_RTL8821CE,
	HARDWARE_TYPE_RTL8821CU,
	HARDWARE_TYPE_RTL8821CS,
	HARDWARE_TYPE_MAX,
};

enum wowlan_subcode {
	WOWLAN_ENABLE			= 0,
	WOWLAN_DISABLE			= 1,
	WOWLAN_AP_ENABLE		= 2,
	WOWLAN_AP_DISABLE		= 3,
	WOWLAN_PATTERN_CLEAN		= 4
};

struct wowlan_ioctl_param {
	unsigned int subcode;
	unsigned int subcode_value;
	unsigned int wakeup_reason;
};

u8 rtw_hal_data_init(struct adapter *adapt);
void rtw_hal_data_deinit(struct adapter *adapt);

void rtw_hal_def_value_init(struct adapter *adapt);

void	rtw_hal_free_data(struct adapter *adapt);

void rtw_hal_dm_init(struct adapter *adapt);
void rtw_hal_dm_deinit(struct adapter *adapt);
void rtw_hal_sw_led_init(struct adapter *adapt);
void rtw_hal_sw_led_deinit(struct adapter *adapt);
u32 rtw_hal_power_on(struct adapter *adapt);
void rtw_hal_power_off(struct adapter *adapt);

uint rtw_hal_init(struct adapter *adapt);
uint rtw_hal_deinit(struct adapter *adapt);
void rtw_hal_stop(struct adapter *adapt);
u8 rtw_hal_set_hwreg(struct adapter * adapt, u8 variable, u8 *val);
void rtw_hal_get_hwreg(struct adapter * adapt, u8 variable, u8 *val);

void rtw_hal_chip_configure(struct adapter *adapt);
u8 rtw_hal_read_chip_info(struct adapter *adapt);
void rtw_hal_read_chip_version(struct adapter *adapt);

u8 rtw_hal_set_def_var(struct adapter *adapt, enum hal_def_variable eVariable, void * pValue);
u8 rtw_hal_get_def_var(struct adapter *adapt, enum hal_def_variable eVariable, void * pValue);

void rtw_hal_set_odm_var(struct adapter *adapt, enum hal_odm_variable eVariable, void * pValue1, bool bSet);
void	rtw_hal_get_odm_var(struct adapter *adapt, enum hal_odm_variable eVariable, void * pValue1, void * pValue2);

void rtw_hal_enable_interrupt(struct adapter *adapt);
void rtw_hal_disable_interrupt(struct adapter *adapt);

u8 rtw_hal_check_ips_status(struct adapter *adapt);

u32	rtw_hal_inirp_init(struct adapter *adapt);
u32	rtw_hal_inirp_deinit(struct adapter *adapt);

u8	rtw_hal_intf_ps_func(struct adapter *adapt, enum hal_intf_ps_func efunc_id, u8 *val);

int	rtw_hal_xmitframe_enqueue(struct adapter *adapt, struct xmit_frame *pxmitframe);
int	rtw_hal_xmit(struct adapter *adapt, struct xmit_frame *pxmitframe);
int	rtw_hal_mgnt_xmit(struct adapter *adapt, struct xmit_frame *pmgntframe);

int	rtw_hal_init_xmit_priv(struct adapter *adapt);
void	rtw_hal_free_xmit_priv(struct adapter *adapt);

int	rtw_hal_init_recv_priv(struct adapter *adapt);
void	rtw_hal_free_recv_priv(struct adapter *adapt);

void rtw_hal_update_ra_mask(struct sta_info *psta);

void	rtw_hal_start_thread(struct adapter *adapt);
void	rtw_hal_stop_thread(struct adapter *adapt);

void rtw_hal_bcn_related_reg_setting(struct adapter *adapt);

u32	rtw_hal_read_bbreg(struct adapter *adapt, u32 RegAddr, u32 BitMask);
void	rtw_hal_write_bbreg(struct adapter *adapt, u32 RegAddr, u32 BitMask, u32 Data);
u32	rtw_hal_read_rfreg(struct adapter *adapt, enum rf_path eRFPath, u32 RegAddr, u32 BitMask);
void	rtw_hal_write_rfreg(struct adapter *adapt, enum rf_path eRFPath, u32 RegAddr, u32 BitMask, u32 Data);


#define phy_query_bb_reg(Adapter, RegAddr, BitMask) rtw_hal_read_bbreg((Adapter), (RegAddr), (BitMask))
#define phy_set_bb_reg(Adapter, RegAddr, BitMask, Data) rtw_hal_write_bbreg((Adapter), (RegAddr), (BitMask), (Data))
#define phy_query_rf_reg(Adapter, eRFPath, RegAddr, BitMask) rtw_hal_read_rfreg((Adapter), (eRFPath), (RegAddr), (BitMask))
#define phy_set_rf_reg(Adapter, eRFPath, RegAddr, BitMask, Data) rtw_hal_write_rfreg((Adapter), (eRFPath), (RegAddr), (BitMask), (Data))

#define phy_set_mac_reg	phy_set_bb_reg
#define phy_query_mac_reg phy_query_bb_reg

void	rtw_hal_set_chnl_bw(struct adapter *adapt, u8 channel, enum channel_width Bandwidth, u8 Offset40, u8 Offset80);
void	rtw_hal_dm_watchdog(struct adapter *adapt);
void	rtw_hal_dm_watchdog_in_lps(struct adapter *adapt);

void	rtw_hal_set_tx_power_level(struct adapter *adapt, u8 channel);
void	rtw_hal_get_tx_power_level(struct adapter *adapt, int *powerlevel);

void rtw_hal_notch_filter(struct adapter *adapter, bool enable);

#ifdef CONFIG_FW_C2H_REG
bool rtw_hal_c2h_reg_hdr_parse(struct adapter *adapter, u8 *buf, u8 *id, u8 *seq, u8 *plen, u8 **payload);
bool rtw_hal_c2h_valid(struct adapter *adapter, u8 *buf);
int rtw_hal_c2h_evt_read(struct adapter *adapter, u8 *buf);
#endif

bool rtw_hal_c2h_pkt_hdr_parse(struct adapter *adapter, u8 *buf, u16 len, u8 *id, u8 *seq, u8 *plen, u8 **payload);

int c2h_handler(struct adapter *adapter, u8 id, u8 seq, u8 plen, u8 *payload);
int rtw_hal_c2h_handler(struct adapter *adapter, u8 id, u8 seq, u8 plen, u8 *payload);
int rtw_hal_c2h_id_handle_directly(struct adapter *adapter, u8 id, u8 seq, u8 plen, u8 *payload);

int rtw_hal_is_disable_sw_channel_plan(struct adapter * adapt);

int rtw_hal_macid_sleep(struct adapter *adapter, u8 macid);
int rtw_hal_macid_wakeup(struct adapter *adapter, u8 macid);
int rtw_hal_macid_sleep_all_used(struct adapter *adapter);
int rtw_hal_macid_wakeup_all_used(struct adapter *adapter);

int rtw_hal_fill_h2c_cmd(struct adapter * adapt, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer);
void rtw_hal_fill_fake_txdesc(struct adapter *adapt, u8 *pDesc, u32 BufferLen,
			      u8 IsPsPoll, u8 IsBTQosNull, u8 bDataFrame);
u8 rtw_hal_get_txbuff_rsvd_page_num(struct adapter *adapter, bool wowlan);

void rtw_hal_fw_correct_bcn(struct adapter *adapt);
int rtw_hal_fw_dl(struct adapter *adapt, bool wowlan);

void rtw_hal_set_tx_power_index(struct adapter * adapter, u32 powerindex, enum rf_path rfpath, u8 rate);
u8 rtw_hal_get_tx_power_index(struct adapter * adapter, enum rf_path
	rfpath, u8 rate, u8 bandwidth, u8 channel, struct txpwr_idx_comp *tic);

u8 rtw_hal_ops_check(struct adapter *adapt);

#endif /* __HAL_INTF_H__ */