1 /******************************************************************************
2 *
3 * Copyright(c) 2007 - 2017 Realtek Corporation.
4 *
5 * This program is free software; you can redistribute it and/or modify it
6 * under the terms of version 2 of the GNU General Public License as
7 * published by the Free Software Foundation.
8 *
9 * This program is distributed in the hope that it will be useful, but WITHOUT
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
12 * more details.
13 *
14 *****************************************************************************/
15 #ifndef __SDIO_OPS_H__
16 #define __SDIO_OPS_H__
17
18
19 /* Follow mac team suggestion, default I/O fail return value is 0xFF */
20 #define SDIO_ERR_VAL8 0xFF
21 #define SDIO_ERR_VAL16 0xFFFF
22 #define SDIO_ERR_VAL32 0xFFFFFFFF
23
24 #ifdef PLATFORM_LINUX
25 #include <sdio_ops_linux.h>
26 #endif
27
28 extern void sdio_set_intf_ops(_adapter *padapter, struct _io_ops *pops);
29 void dump_sdio_card_info(void *sel, struct dvobj_priv *dvobj);
30
31 u32 sdio_init(struct dvobj_priv *dvobj);
32 void sdio_deinit(struct dvobj_priv *dvobj);
33 int sdio_alloc_irq(struct dvobj_priv *dvobj);
34 void sdio_free_irq(struct dvobj_priv *dvobj);
35 u8 sdio_get_num_of_func(struct dvobj_priv *dvobj);
36
37 #if 0
38 extern void sdio_func1cmd52_read(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *rmem);
39 extern void sdio_func1cmd52_write(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *wmem);
40 #endif
41 extern u8 SdioLocalCmd52Read1Byte(PADAPTER padapter, u32 addr);
42 extern void SdioLocalCmd52Write1Byte(PADAPTER padapter, u32 addr, u8 v);
43 extern s32 _sdio_local_read(PADAPTER padapter, u32 addr, u32 cnt, u8 *pbuf);
44 extern s32 sdio_local_read(PADAPTER padapter, u32 addr, u32 cnt, u8 *pbuf);
45 extern s32 _sdio_local_write(PADAPTER padapter, u32 addr, u32 cnt, u8 *pbuf);
46 extern s32 sdio_local_write(PADAPTER padapter, u32 addr, u32 cnt, u8 *pbuf);
47
48 u32 _sdio_read32(PADAPTER padapter, u32 addr);
49 s32 _sdio_write32(PADAPTER padapter, u32 addr, u32 val);
50
51 extern void sd_int_hdl(PADAPTER padapter);
52 extern u8 CheckIPSStatus(PADAPTER padapter);
53
54 #ifdef CONFIG_RTL8188E
55 extern void InitInterrupt8188ESdio(PADAPTER padapter);
56 extern void EnableInterrupt8188ESdio(PADAPTER padapter);
57 extern void DisableInterrupt8188ESdio(PADAPTER padapter);
58 extern void UpdateInterruptMask8188ESdio(PADAPTER padapter, u32 AddMSR, u32 RemoveMSR);
59 extern u8 HalQueryTxBufferStatus8189ESdio(PADAPTER padapter);
60 extern u8 HalQueryTxOQTBufferStatus8189ESdio(PADAPTER padapter);
61 extern void ClearInterrupt8188ESdio(PADAPTER padapter);
62 #endif /* CONFIG_RTL8188E */
63
64 #ifdef CONFIG_RTL8821A
65 extern void InitInterrupt8821AS(PADAPTER padapter);
66 extern void EnableInterrupt8821AS(PADAPTER padapter);
67 extern void DisableInterrupt8821AS(PADAPTER padapter);
68 extern u8 HalQueryTxBufferStatus8821AS(PADAPTER padapter);
69 extern u8 HalQueryTxOQTBufferStatus8821ASdio(PADAPTER padapter);
70 #if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
71 void ClearInterrupt8821AS(PADAPTER padapter);
72 #endif /* defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN) */
73 #endif /* CONFIG_RTL8821A */
74
75 #if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
76 #if defined(CONFIG_RTL8821C) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8822C)
77 u8 rtw_hal_enable_cpwm2(_adapter *adapter);
78 #endif
79 extern u8 RecvOnePkt(PADAPTER padapter);
80 #endif /* CONFIG_WOWLAN */
81 #ifdef CONFIG_RTL8723B
82 extern void InitInterrupt8723BSdio(PADAPTER padapter);
83 extern void InitSysInterrupt8723BSdio(PADAPTER padapter);
84 extern void EnableInterrupt8723BSdio(PADAPTER padapter);
85 extern void DisableInterrupt8723BSdio(PADAPTER padapter);
86 extern u8 HalQueryTxBufferStatus8723BSdio(PADAPTER padapter);
87 extern u8 HalQueryTxOQTBufferStatus8723BSdio(PADAPTER padapter);
88 #if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
89 extern void DisableInterruptButCpwm28723BSdio(PADAPTER padapter);
90 extern void ClearInterrupt8723BSdio(PADAPTER padapter);
91 #endif /* CONFIG_WOWLAN */
92 #endif
93
94
95 #ifdef CONFIG_RTL8192E
96 extern void InitInterrupt8192ESdio(PADAPTER padapter);
97 extern void EnableInterrupt8192ESdio(PADAPTER padapter);
98 extern void DisableInterrupt8192ESdio(PADAPTER padapter);
99 extern void UpdateInterruptMask8192ESdio(PADAPTER padapter, u32 AddMSR, u32 RemoveMSR);
100 extern u8 HalQueryTxBufferStatus8192ESdio(PADAPTER padapter);
101 extern u8 HalQueryTxOQTBufferStatus8192ESdio(PADAPTER padapter);
102 extern void ClearInterrupt8192ESdio(PADAPTER padapter);
103 #endif /* CONFIG_RTL8192E */
104
105 #ifdef CONFIG_RTL8703B
106 extern void InitInterrupt8703BSdio(PADAPTER padapter);
107 extern void InitSysInterrupt8703BSdio(PADAPTER padapter);
108 extern void EnableInterrupt8703BSdio(PADAPTER padapter);
109 extern void DisableInterrupt8703BSdio(PADAPTER padapter);
110 extern u8 HalQueryTxBufferStatus8703BSdio(PADAPTER padapter);
111 extern u8 HalQueryTxOQTBufferStatus8703BSdio(PADAPTER padapter);
112 #if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
113 extern void DisableInterruptButCpwm28703BSdio(PADAPTER padapter);
114 extern void ClearInterrupt8703BSdio(PADAPTER padapter);
115 #endif /* CONFIG_WOWLAN */
116 #endif
117
118 #ifdef CONFIG_RTL8723D
119 extern void InitInterrupt8723DSdio(PADAPTER padapter);
120 extern void InitSysInterrupt8723DSdio(PADAPTER padapter);
121 extern void EnableInterrupt8723DSdio(PADAPTER padapter);
122 extern void DisableInterrupt8723DSdio(PADAPTER padapter);
123 extern u8 HalQueryTxBufferStatus8723DSdio(PADAPTER padapter);
124 extern u8 HalQueryTxOQTBufferStatus8723DSdio(PADAPTER padapter);
125 #if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
126 extern void DisableInterruptButCpwm28723dSdio(PADAPTER padapter);
127 extern void ClearInterrupt8723DSdio(PADAPTER padapter);
128 #endif /* CONFIG_WOWLAN */
129 #endif
130
131 #ifdef CONFIG_RTL8192F
132 extern void InitInterrupt8192FSdio(PADAPTER padapter);
133 extern void InitSysInterrupt8192FSdio(PADAPTER padapter);
134 extern void EnableInterrupt8192FSdio(PADAPTER padapter);
135 extern void DisableInterrupt8192FSdio(PADAPTER padapter);
136 extern void UpdateInterruptMask8192FSdio(PADAPTER padapter, u32 AddMSR, u32 RemoveMSR);
137 extern u8 HalQueryTxBufferStatus8192FSdio(PADAPTER padapter);
138 extern u8 HalQueryTxOQTBufferStatus8192FSdio(PADAPTER padapter);
139 #if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
140 extern void DisableInterruptButCpwm2192fSdio(PADAPTER padapter);
141 extern void ClearInterrupt8192FSdio(PADAPTER padapter);
142 #endif /* CONFIG_WOWLAN */
143 #endif
144
145 #ifdef CONFIG_RTL8188F
146 extern void InitInterrupt8188FSdio(PADAPTER padapter);
147 extern void InitSysInterrupt8188FSdio(PADAPTER padapter);
148 extern void EnableInterrupt8188FSdio(PADAPTER padapter);
149 extern void DisableInterrupt8188FSdio(PADAPTER padapter);
150 extern u8 HalQueryTxBufferStatus8188FSdio(PADAPTER padapter);
151 extern u8 HalQueryTxOQTBufferStatus8188FSdio(PADAPTER padapter);
152 #if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
153 extern void DisableInterruptButCpwm28188FSdio(PADAPTER padapter);
154 extern void ClearInterrupt8188FSdio(PADAPTER padapter);
155 #endif /* defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN) */
156 #endif
157
158 #ifdef CONFIG_RTL8188GTV
159 extern void InitInterrupt8188GTVSdio(PADAPTER padapter);
160 extern void InitSysInterrupt8188GTVSdio(PADAPTER padapter);
161 extern void EnableInterrupt8188GTVSdio(PADAPTER padapter);
162 extern void DisableInterrupt8188GTVSdio(PADAPTER padapter);
163 extern u8 HalQueryTxBufferStatus8188GTVSdio(PADAPTER padapter);
164 extern u8 HalQueryTxOQTBufferStatus8188GTVSdio(PADAPTER padapter);
165 #if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
166 extern void DisableInterruptButCpwm28188GTVSdio(PADAPTER padapter);
167 extern void ClearInterrupt8188GTVSdio(PADAPTER padapter);
168 #endif /* defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN) */
169 #endif
170
171 /**
172 * rtw_sdio_get_block_size() - Get block size of SDIO transfer
173 * @d struct dvobj_priv*
174 *
175 * The unit of return value is byte.
176 */
rtw_sdio_get_block_size(struct dvobj_priv * d)177 static inline u32 rtw_sdio_get_block_size(struct dvobj_priv *d)
178 {
179 return d->intf_data.block_transfer_len;
180 }
181
182 /**
183 * rtw_sdio_cmd53_align_size() - Align size to one CMD53 could complete
184 * @d struct dvobj_priv*
185 * @len length to align
186 *
187 * Adjust len to align block size, and the new size could be transfered by one
188 * CMD53.
189 * If len < block size, it would keep original value, otherwise the value
190 * would be rounded up by block size.
191 *
192 * Return adjusted length.
193 */
rtw_sdio_cmd53_align_size(struct dvobj_priv * d,size_t len)194 static inline size_t rtw_sdio_cmd53_align_size(struct dvobj_priv *d, size_t len)
195 {
196 u32 blk_sz;
197
198
199 blk_sz = rtw_sdio_get_block_size(d);
200 if (len <= blk_sz)
201 return len;
202
203 return _RND(len, blk_sz);
204 }
205
206 #endif /* !__SDIO_OPS_H__ */
207