1*4882a593Smuzhiyun /****************************************************************************** 2*4882a593Smuzhiyun * 3*4882a593Smuzhiyun * Copyright(c) 2007 - 2017 Realtek Corporation. 4*4882a593Smuzhiyun * 5*4882a593Smuzhiyun * This program is free software; you can redistribute it and/or modify it 6*4882a593Smuzhiyun * under the terms of version 2 of the GNU General Public License as 7*4882a593Smuzhiyun * published by the Free Software Foundation. 8*4882a593Smuzhiyun * 9*4882a593Smuzhiyun * This program is distributed in the hope that it will be useful, but WITHOUT 10*4882a593Smuzhiyun * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 11*4882a593Smuzhiyun * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for 12*4882a593Smuzhiyun * more details. 13*4882a593Smuzhiyun * 14*4882a593Smuzhiyun *****************************************************************************/ 15*4882a593Smuzhiyun #ifndef __HAL_SDIO_H_ 16*4882a593Smuzhiyun #define __HAL_SDIO_H_ 17*4882a593Smuzhiyun 18*4882a593Smuzhiyun #define ffaddr2deviceId(pdvobj, addr) (pdvobj->Queue2Pipe[addr]) 19*4882a593Smuzhiyun 20*4882a593Smuzhiyun #ifndef RTW_HALMAC 21*4882a593Smuzhiyun extern const char *_sdio_tx_queue_str[]; 22*4882a593Smuzhiyun #define sdio_tx_queue_str(_page_idx) (_page_idx >= SDIO_MAX_TX_QUEUE ? "UNKNOWN" : _sdio_tx_queue_str[_page_idx]) 23*4882a593Smuzhiyun #endif 24*4882a593Smuzhiyun 25*4882a593Smuzhiyun u8 rtw_hal_sdio_max_txoqt_free_space(_adapter *padapter); 26*4882a593Smuzhiyun u8 rtw_hal_sdio_query_tx_freepage(_adapter *padapter, u8 PageIdx, u8 RequiredPageNum); 27*4882a593Smuzhiyun void rtw_hal_sdio_update_tx_freepage(_adapter *padapter, u8 PageIdx, u8 RequiredPageNum); 28*4882a593Smuzhiyun void rtw_hal_set_sdio_tx_max_length(PADAPTER padapter, u8 numHQ, u8 numNQ, u8 numLQ, u8 numPubQ, u8 div_num); 29*4882a593Smuzhiyun u32 rtw_hal_get_sdio_tx_max_length(PADAPTER padapter, u8 queue_idx); 30*4882a593Smuzhiyun bool sdio_power_on_check(PADAPTER padapter); 31*4882a593Smuzhiyun 32*4882a593Smuzhiyun #ifdef CONFIG_SDIO_TX_ENABLE_AVAL_INT 33*4882a593Smuzhiyun #if defined(CONFIG_RTL8188F) || defined(CONFIG_RTL8188GTV) ||defined(CONFIG_RTL8188E) || defined(CONFIG_RTL8821A) || defined(CONFIG_RTL8192F) || defined(CONFIG_RTL8723D) 34*4882a593Smuzhiyun void rtw_hal_sdio_avail_page_threshold_init(_adapter *adapter); 35*4882a593Smuzhiyun void rtw_hal_sdio_avail_page_threshold_en(_adapter *adapter, u8 qidx, u8 pg_num); 36*4882a593Smuzhiyun #endif 37*4882a593Smuzhiyun #endif /* CONFIG_SDIO_TX_ENABLE_AVAL_INT */ 38*4882a593Smuzhiyun 39*4882a593Smuzhiyun #ifdef CONFIG_FW_C2H_REG 40*4882a593Smuzhiyun void sd_c2h_hisr_hdl(_adapter *adapter); 41*4882a593Smuzhiyun #endif 42*4882a593Smuzhiyun 43*4882a593Smuzhiyun #if defined(CONFIG_RTL8188F) || defined (CONFIG_RTL8188GTV) || defined (CONFIG_RTL8192F) || defined(CONFIG_RTL8723D) 44*4882a593Smuzhiyun #define SDIO_LOCAL_CMD_ADDR(addr) ((SDIO_LOCAL_DEVICE_ID << 13) | ((addr) & SDIO_LOCAL_MSK)) 45*4882a593Smuzhiyun #endif 46*4882a593Smuzhiyun 47*4882a593Smuzhiyun #ifdef CONFIG_SDIO_CHK_HCI_RESUME 48*4882a593Smuzhiyun bool sdio_chk_hci_resume(struct intf_hdl *pintfhdl); 49*4882a593Smuzhiyun void sdio_chk_hci_suspend(struct intf_hdl *pintfhdl); 50*4882a593Smuzhiyun #else 51*4882a593Smuzhiyun #define sdio_chk_hci_resume(pintfhdl) _FALSE 52*4882a593Smuzhiyun #define sdio_chk_hci_suspend(pintfhdl) do {} while (0) 53*4882a593Smuzhiyun #endif /* CONFIG_SDIO_CHK_HCI_RESUME */ 54*4882a593Smuzhiyun 55*4882a593Smuzhiyun #ifdef CONFIG_SDIO_INDIRECT_ACCESS 56*4882a593Smuzhiyun /* program indirect access register in sdio local to read/write page0 registers */ 57*4882a593Smuzhiyun s32 sdio_iread(PADAPTER padapter, u32 addr, u8 size, u8 *v); 58*4882a593Smuzhiyun s32 sdio_iwrite(PADAPTER padapter, u32 addr, u8 size, u8 *v); 59*4882a593Smuzhiyun u8 sdio_iread8(struct intf_hdl *pintfhdl, u32 addr); 60*4882a593Smuzhiyun u16 sdio_iread16(struct intf_hdl *pintfhdl, u32 addr); 61*4882a593Smuzhiyun u32 sdio_iread32(struct intf_hdl *pintfhdl, u32 addr); 62*4882a593Smuzhiyun s32 sdio_iwrite8(struct intf_hdl *pintfhdl, u32 addr, u8 val); 63*4882a593Smuzhiyun s32 sdio_iwrite16(struct intf_hdl *pintfhdl, u32 addr, u16 val); 64*4882a593Smuzhiyun s32 sdio_iwrite32(struct intf_hdl *pintfhdl, u32 addr, u32 val); 65*4882a593Smuzhiyun #endif /* CONFIG_SDIO_INDIRECT_ACCESS */ 66*4882a593Smuzhiyun u32 cmd53_4byte_alignment(struct intf_hdl *pintfhdl, u32 addr); 67*4882a593Smuzhiyun 68*4882a593Smuzhiyun #ifndef CONFIG_SDIO_TX_TASKLET 69*4882a593Smuzhiyun #ifdef SDIO_FREE_XMIT_BUF_SEMA 70*4882a593Smuzhiyun void _rtw_sdio_free_xmitbuf_sema_up(struct xmit_priv *xmit); 71*4882a593Smuzhiyun void _rtw_sdio_free_xmitbuf_sema_down(struct xmit_priv *xmit); 72*4882a593Smuzhiyun #ifdef DBG_SDIO_FREE_XMIT_BUF_SEMA 73*4882a593Smuzhiyun void dbg_rtw_sdio_free_xmitbuf_sema_up(struct xmit_priv *xmit, const char *caller); 74*4882a593Smuzhiyun void dbg_rtw_sdio_free_xmitbuf_sema_down(struct xmit_priv *xmit, const char *caller); 75*4882a593Smuzhiyun #define rtw_sdio_free_xmitbuf_sema_up(_xmit) dbg_rtw_sdio_free_xmitbuf_sema_up(_xmit, __func__) 76*4882a593Smuzhiyun #define rtw_sdio_free_xmitbuf_sema_down(_xmit) dbg_rtw_sdio_free_xmitbuf_sema_down(_xmit, __func__) 77*4882a593Smuzhiyun #else 78*4882a593Smuzhiyun #define rtw_sdio_free_xmitbuf_sema_up(_xmit) _rtw_sdio_free_xmitbuf_sema_up(_xmit) 79*4882a593Smuzhiyun #define rtw_sdio_free_xmitbuf_sema_down(_xmit) _rtw_sdio_free_xmitbuf_sema_down(_xmit) 80*4882a593Smuzhiyun #endif /* DBG_SDIO_FREE_XMIT_BUF_SEMA */ 81*4882a593Smuzhiyun #endif /* SDIO_FREE_XMIT_BUF_SEMA */ 82*4882a593Smuzhiyun #endif /* !CONFIG_SDIO_TX_TASKLET */ 83*4882a593Smuzhiyun 84*4882a593Smuzhiyun s32 sdio_initrecvbuf(struct recv_buf *recvbuf, _adapter *adapter); 85*4882a593Smuzhiyun void sdio_freerecvbuf(struct recv_buf *recvbuf); 86*4882a593Smuzhiyun 87*4882a593Smuzhiyun #ifdef CONFIG_SDIO_RECVBUF_PWAIT 88*4882a593Smuzhiyun void dump_recvbuf_pwait_conf(void *sel, struct recv_priv *recvpriv); 89*4882a593Smuzhiyun #ifdef CONFIG_SDIO_RECVBUF_PWAIT_RUNTIME_ADJUST 90*4882a593Smuzhiyun int recvbuf_pwait_config_req(struct recv_priv *recvpriv, enum rtw_pwait_type type, s32 time, s32 cnt_lmt); 91*4882a593Smuzhiyun int recvbuf_pwait_config_hdl(struct recv_priv *recvpriv, struct recv_buf *rbuf); 92*4882a593Smuzhiyun #endif /* CONFIG_SDIO_RECVBUF_PWAIT_RUNTIME_ADJUST */ 93*4882a593Smuzhiyun #endif /* CONFIG_SDIO_RECVBUF_PWAIT */ 94*4882a593Smuzhiyun 95*4882a593Smuzhiyun #endif /* __HAL_SDIO_H_ */ 96