ARM64: DTS: Add rk3399-firefly uart4 device, node as /dev/ttyS1
[firefly-linux-kernel-4.4.55.git] / drivers / net / wireless / rockchip_wlan / rtl8723bs / include / hal_intf.h
1 /******************************************************************************
2  *
3  * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
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  * You should have received a copy of the GNU General Public License along with
15  * this program; if not, write to the Free Software Foundation, Inc.,
16  * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
17  *
18  *
19  ******************************************************************************/
20 #ifndef __HAL_INTF_H__
21 #define __HAL_INTF_H__
22
23
24 enum RTL871X_HCI_TYPE {
25         RTW_PCIE        = BIT0,
26         RTW_USB         = BIT1,
27         RTW_SDIO        = BIT2,
28         RTW_GSPI        = BIT3,
29 };
30
31 enum _CHIP_TYPE {
32
33         NULL_CHIP_TYPE, 
34         RTL8188C_8192C,
35         RTL8192D,
36         RTL8723A,
37         RTL8188E,
38         RTL8192E,
39         RTL8812,
40         RTL8821, //RTL8811
41         RTL8723B,
42         MAX_CHIP_TYPE
43 };
44
45
46 typedef enum _HW_VARIABLES{
47         HW_VAR_MEDIA_STATUS,
48         HW_VAR_MEDIA_STATUS1,
49         HW_VAR_SET_OPMODE,
50         HW_VAR_MAC_ADDR,
51         HW_VAR_BSSID,
52         HW_VAR_INIT_RTS_RATE,
53         HW_VAR_BASIC_RATE,
54         HW_VAR_TXPAUSE,
55         HW_VAR_BCN_FUNC,
56         HW_VAR_CORRECT_TSF,
57         HW_VAR_CHECK_BSSID,
58         HW_VAR_MLME_DISCONNECT,
59         HW_VAR_MLME_SITESURVEY,
60         HW_VAR_MLME_JOIN,
61         HW_VAR_ON_RCR_AM,
62        HW_VAR_OFF_RCR_AM,
63         HW_VAR_BEACON_INTERVAL,
64         HW_VAR_SLOT_TIME,
65         HW_VAR_RESP_SIFS,
66         HW_VAR_ACK_PREAMBLE,
67         HW_VAR_SEC_CFG,
68         HW_VAR_SEC_DK_CFG,
69         HW_VAR_BCN_VALID,
70         HW_VAR_RF_TYPE,
71         HW_VAR_DM_FLAG,
72         HW_VAR_DM_FUNC_OP,
73         HW_VAR_DM_FUNC_SET,
74         HW_VAR_DM_FUNC_CLR,
75         HW_VAR_CAM_EMPTY_ENTRY,
76         HW_VAR_CAM_INVALID_ALL,
77         HW_VAR_CAM_WRITE,
78         HW_VAR_CAM_READ,
79         HW_VAR_AC_PARAM_VO,
80         HW_VAR_AC_PARAM_VI,
81         HW_VAR_AC_PARAM_BE,
82         HW_VAR_AC_PARAM_BK,
83         HW_VAR_ACM_CTRL,
84         HW_VAR_AMPDU_MIN_SPACE,
85         HW_VAR_AMPDU_FACTOR,
86         HW_VAR_RXDMA_AGG_PG_TH,
87         HW_VAR_SET_RPWM,
88         HW_VAR_CPWM,
89         HW_VAR_H2C_FW_PWRMODE,
90         HW_VAR_H2C_PS_TUNE_PARAM,
91         HW_VAR_H2C_FW_JOINBSSRPT,
92         HW_VAR_FWLPS_RF_ON,
93         HW_VAR_H2C_FW_P2P_PS_OFFLOAD,
94         HW_VAR_TDLS_WRCR,
95         HW_VAR_TDLS_INIT_CH_SEN,
96         HW_VAR_TDLS_RS_RCR,
97         HW_VAR_TDLS_DONE_CH_SEN,
98         HW_VAR_INITIAL_GAIN,
99         HW_VAR_TRIGGER_GPIO_0,
100         HW_VAR_BT_SET_COEXIST,
101         HW_VAR_BT_ISSUE_DELBA,  
102         HW_VAR_CURRENT_ANTENNA,
103         HW_VAR_ANTENNA_DIVERSITY_LINK,
104         HW_VAR_ANTENNA_DIVERSITY_SELECT,
105         HW_VAR_SWITCH_EPHY_WoWLAN,
106         HW_VAR_EFUSE_USAGE,
107         HW_VAR_EFUSE_BYTES,
108         HW_VAR_EFUSE_BT_USAGE,
109         HW_VAR_EFUSE_BT_BYTES,
110         HW_VAR_FIFO_CLEARN_UP,
111         HW_VAR_CHECK_TXBUF,
112         HW_VAR_PCIE_STOP_TX_DMA,
113         HW_VAR_APFM_ON_MAC, //Auto FSM to Turn On, include clock, isolation, power control for MAC only
114         // 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.
115         // Unit in microsecond. 0 means disable this function.
116 #ifdef CONFIG_WOWLAN
117         HW_VAR_WOWLAN,
118         HW_VAR_WAKEUP_REASON,
119         HW_VAR_RPWM_TOG,
120 #endif
121 #ifdef CONFIG_AP_WOWLAN
122         HW_VAR_AP_WOWLAN,
123 #endif
124         HW_VAR_SYS_CLKR,
125         HW_VAR_NAV_UPPER,
126         HW_VAR_C2H_HANDLE,
127         HW_VAR_RPT_TIMER_SETTING,
128         HW_VAR_TX_RPT_MAX_MACID,        
129         HW_VAR_H2C_MEDIA_STATUS_RPT,
130         HW_VAR_CHK_HI_QUEUE_EMPTY,
131         HW_VAR_DL_BCN_SEL,
132         HW_VAR_AMPDU_MAX_TIME,
133         HW_VAR_WIRELESS_MODE,
134         HW_VAR_USB_MODE,
135         HW_VAR_PORT_SWITCH,
136         HW_VAR_DO_IQK,
137         HW_VAR_DM_IN_LPS,
138         HW_VAR_SET_REQ_FW_PS,
139         HW_VAR_FW_PS_STATE,
140         HW_VAR_SOUNDING_ENTER,
141         HW_VAR_SOUNDING_LEAVE,
142         HW_VAR_SOUNDING_RATE,
143         HW_VAR_SOUNDING_STATUS,
144         HW_VAR_SOUNDING_FW_NDPA,
145         HW_VAR_SOUNDING_CLK,
146         HW_VAR_DL_RSVD_PAGE,
147         HW_VAR_MACID_SLEEP,
148         HW_VAR_MACID_WAKEUP,
149         HW_VAR_DUMP_MAC_QUEUE_INFO,
150         HW_VAR_ASIX_IOT,
151 }HW_VARIABLES;
152
153 typedef enum _HAL_DEF_VARIABLE{
154         HAL_DEF_UNDERCORATEDSMOOTHEDPWDB,
155         HAL_DEF_IS_SUPPORT_ANT_DIV,
156         HAL_DEF_CURRENT_ANTENNA,
157         HAL_DEF_DRVINFO_SZ,
158         HAL_DEF_MAX_RECVBUF_SZ,
159         HAL_DEF_RX_PACKET_OFFSET,
160         HAL_DEF_DBG_DUMP_RXPKT,//for dbg
161         HAL_DEF_DBG_DM_FUNC,//for dbg
162         HAL_DEF_RA_DECISION_RATE,
163         HAL_DEF_RA_SGI,
164         HAL_DEF_PT_PWR_STATUS,
165         HAL_DEF_TX_LDPC,                                // LDPC support
166         HAL_DEF_RX_LDPC,                                // LDPC support
167         HAL_DEF_TX_STBC,                                // TX STBC support
168         HAL_DEF_RX_STBC,                                // RX STBC support
169         HAL_DEF_EXPLICIT_BEAMFORMER,// Explicit  Compressed Steering Capable
170         HAL_DEF_EXPLICIT_BEAMFORMEE,// Explicit Compressed Beamforming Feedback Capable
171         HW_VAR_MAX_RX_AMPDU_FACTOR,
172         HW_DEF_RA_INFO_DUMP,
173         HAL_DEF_DBG_DUMP_TXPKT,
174         HW_DEF_FA_CNT_DUMP,
175         HW_DEF_ODM_DBG_FLAG,
176         HW_DEF_ODM_DBG_LEVEL,
177         HAL_DEF_TX_PAGE_SIZE,
178         HAL_DEF_TX_PAGE_BOUNDARY,
179         HAL_DEF_TX_PAGE_BOUNDARY_WOWLAN,
180         HAL_DEF_ANT_DETECT,//to do for 8723a
181         HAL_DEF_PCI_SUUPORT_L1_BACKDOOR, // Determine if the L1 Backdoor setting is turned on.
182         HAL_DEF_PCI_AMD_L1_SUPPORT,
183         HAL_DEF_PCI_ASPM_OSC, // Support for ASPM OSC, added by Roger, 2013.03.27.
184         HAL_DEF_MACID_SLEEP, // Support for MACID sleep
185         HAL_DEF_DBG_RX_INFO_DUMP,
186         HAL_DEF_DBG_DIS_PWT, //disable Tx power training or not.
187 }HAL_DEF_VARIABLE;
188
189 typedef enum _HAL_ODM_VARIABLE{
190         HAL_ODM_STA_INFO,       
191         HAL_ODM_P2P_STATE,
192         HAL_ODM_WIFI_DISPLAY_STATE,
193         HAL_ODM_NOISE_MONITOR,
194         HAL_ODM_REGULATION,
195 }HAL_ODM_VARIABLE;
196
197 typedef enum _HAL_INTF_PS_FUNC{
198         HAL_USB_SELECT_SUSPEND,
199         HAL_MAX_ID,
200 }HAL_INTF_PS_FUNC;
201
202 typedef s32 (*c2h_id_filter)(u8 *c2h_evt);
203
204 struct hal_ops {
205         u32     (*hal_power_on)(_adapter *padapter);
206         void    (*hal_power_off)(_adapter *padapter);
207         u32     (*hal_init)(_adapter *padapter);
208         u32     (*hal_deinit)(_adapter *padapter);
209
210         void    (*free_hal_data)(_adapter *padapter);
211
212         u32     (*inirp_init)(_adapter *padapter);
213         u32     (*inirp_deinit)(_adapter *padapter);
214         void    (*irp_reset)(_adapter *padapter);
215
216         s32     (*init_xmit_priv)(_adapter *padapter);
217         void    (*free_xmit_priv)(_adapter *padapter);
218
219         s32     (*init_recv_priv)(_adapter *padapter);
220         void    (*free_recv_priv)(_adapter *padapter);
221
222         void    (*InitSwLeds)(_adapter *padapter);
223         void    (*DeInitSwLeds)(_adapter *padapter);
224
225         void    (*dm_init)(_adapter *padapter);
226         void    (*dm_deinit)(_adapter *padapter);
227         void    (*read_chip_version)(_adapter *padapter);
228
229         void    (*init_default_value)(_adapter *padapter);
230
231         void    (*intf_chip_configure)(_adapter *padapter);
232
233         void    (*read_adapter_info)(_adapter *padapter);
234
235         void    (*enable_interrupt)(_adapter *padapter);
236         void    (*disable_interrupt)(_adapter *padapter);
237         u8              (*check_ips_status)(_adapter *padapter);
238         s32             (*interrupt_handler)(_adapter *padapter);
239         void    (*clear_interrupt)(_adapter *padapter);
240         void    (*set_bwmode_handler)(_adapter *padapter, CHANNEL_WIDTH Bandwidth, u8 Offset);
241         void    (*set_channel_handler)(_adapter *padapter, u8 channel);
242         void    (*set_chnl_bw_handler)(_adapter *padapter, u8 channel, CHANNEL_WIDTH Bandwidth, u8 Offset40, u8 Offset80);
243
244         void    (*set_tx_power_level_handler)(_adapter *padapter, u8 channel);
245         void    (*get_tx_power_level_handler)(_adapter *padapter, s32 *powerlevel);
246
247         void    (*hal_dm_watchdog)(_adapter *padapter);
248         void    (*hal_dm_watchdog_in_lps)(_adapter *padapter);
249         
250
251         void    (*SetHwRegHandler)(_adapter *padapter, u8       variable,u8* val);
252         void    (*GetHwRegHandler)(_adapter *padapter, u8       variable,u8* val);
253
254 #ifdef CONFIG_C2H_PACKET_EN
255                 void    (*SetHwRegHandlerWithBuf)(_adapter *padapter, u8 variable, u8* pbuf, int len);
256 #endif
257
258         u8      (*GetHalDefVarHandler)(_adapter *padapter, HAL_DEF_VARIABLE eVariable, PVOID pValue);
259         u8      (*SetHalDefVarHandler)(_adapter *padapter, HAL_DEF_VARIABLE eVariable, PVOID pValue);
260
261         void    (*GetHalODMVarHandler)(_adapter *padapter, HAL_ODM_VARIABLE eVariable, PVOID pValue1,PVOID pValue2);
262         void    (*SetHalODMVarHandler)(_adapter *padapter, HAL_ODM_VARIABLE eVariable, PVOID pValue1,BOOLEAN bSet);
263
264         void    (*UpdateRAMaskHandler)(_adapter *padapter, u32 mac_id, u8 rssi_level);
265         void    (*SetBeaconRelatedRegistersHandler)(_adapter *padapter);
266
267         void    (*Add_RateATid)(_adapter *padapter, u32 bitmap, u8* arg, u8 rssi_level);
268
269         void    (*run_thread)(_adapter *padapter);
270         void    (*cancel_thread)(_adapter *padapter);
271
272 #ifdef CONFIG_ANTENNA_DIVERSITY
273         u8      (*AntDivBeforeLinkHandler)(_adapter *padapter);
274         void    (*AntDivCompareHandler)(_adapter *padapter, WLAN_BSSID_EX *dst, WLAN_BSSID_EX *src);
275 #endif
276         u8      (*interface_ps_func)(_adapter *padapter,HAL_INTF_PS_FUNC efunc_id, u8* val);
277
278         s32     (*hal_xmit)(_adapter *padapter, struct xmit_frame *pxmitframe);
279         /*
280          * mgnt_xmit should be implemented to run in interrupt context
281          */
282         s32 (*mgnt_xmit)(_adapter *padapter, struct xmit_frame *pmgntframe);
283         s32     (*hal_xmitframe_enqueue)(_adapter *padapter, struct xmit_frame *pxmitframe);
284
285         u32     (*read_bbreg)(_adapter *padapter, u32 RegAddr, u32 BitMask);
286         void    (*write_bbreg)(_adapter *padapter, u32 RegAddr, u32 BitMask, u32 Data);
287         u32     (*read_rfreg)(_adapter *padapter, u8 eRFPath, u32 RegAddr, u32 BitMask);
288         void    (*write_rfreg)(_adapter *padapter, u8 eRFPath, u32 RegAddr, u32 BitMask, u32 Data);
289
290 #ifdef CONFIG_HOSTAPD_MLME
291         s32     (*hostap_mgnt_xmit_entry)(_adapter *padapter, _pkt *pkt);
292 #endif
293
294         void (*EfusePowerSwitch)(_adapter *padapter, u8 bWrite, u8 PwrState);
295         void (*BTEfusePowerSwitch)(_adapter *padapter, u8 bWrite, u8 PwrState);
296         void (*ReadEFuse)(_adapter *padapter, u8 efuseType, u16 _offset, u16 _size_byte, u8 *pbuf, BOOLEAN bPseudoTest);
297         void (*EFUSEGetEfuseDefinition)(_adapter *padapter, u8 efuseType, u8 type, void *pOut, BOOLEAN bPseudoTest);
298         u16     (*EfuseGetCurrentSize)(_adapter *padapter, u8 efuseType, BOOLEAN bPseudoTest);
299         int     (*Efuse_PgPacketRead)(_adapter *padapter, u8 offset, u8 *data, BOOLEAN bPseudoTest);
300         int     (*Efuse_PgPacketWrite)(_adapter *padapter, u8 offset, u8 word_en, u8 *data, BOOLEAN bPseudoTest);
301         u8      (*Efuse_WordEnableDataWrite)(_adapter *padapter, u16 efuse_addr, u8 word_en, u8 *data, BOOLEAN bPseudoTest);
302         BOOLEAN (*Efuse_PgPacketWrite_BT)(_adapter *padapter, u8 offset, u8 word_en, u8 *data, BOOLEAN bPseudoTest);
303         
304 #ifdef DBG_CONFIG_ERROR_DETECT
305         void (*sreset_init_value)(_adapter *padapter);
306         void (*sreset_reset_value)(_adapter *padapter);         
307         void (*silentreset)(_adapter *padapter);
308         void (*sreset_xmit_status_check)(_adapter *padapter);
309         void (*sreset_linked_status_check) (_adapter *padapter);
310         u8 (*sreset_get_wifi_status)(_adapter *padapter);
311         bool (*sreset_inprogress)(_adapter *padapter);
312 #endif
313
314 #ifdef CONFIG_IOL
315         int (*IOL_exec_cmds_sync)(_adapter *padapter, struct xmit_frame *xmit_frame, u32 max_wating_ms, u32 bndy_cnt);
316 #endif
317
318 #ifdef CONFIG_XMIT_THREAD_MODE
319         s32 (*xmit_thread_handler)(_adapter *padapter);
320 #endif
321         void (*hal_notch_filter)(_adapter * adapter, bool enable);
322         void (*hal_reset_security_engine)(_adapter * adapter);
323         s32 (*c2h_handler)(_adapter *padapter, u8 *c2h_evt);
324         c2h_id_filter c2h_id_filter_ccx;
325         s32 (*fill_h2c_cmd)(PADAPTER, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer);
326 #if defined(CONFIG_RTL8188E) || defined(CONFIG_RTL8723A) || defined(CONFIG_RTL8723B)
327         void (*hal_cal_txdesc_chksum)(struct tx_desc *ptxdesc);
328 #else
329         void (*hal_cal_txdesc_chksum)(u8 *ptxdesc);
330 #endif
331 #ifdef CONFIG_WOWLAN
332         void (*hal_set_wowlan_fw)(_adapter *adapter, u8 sleep);
333 #endif //CONFIG_WOWLAN
334         u8 (*hal_get_tx_buff_rsvd_page_num)(_adapter *adapter, bool wowlan);
335 };
336
337 typedef enum _RT_EEPROM_TYPE{
338         EEPROM_93C46,
339         EEPROM_93C56,
340         EEPROM_BOOT_EFUSE,
341 }RT_EEPROM_TYPE,*PRT_EEPROM_TYPE;
342
343
344
345 #define RF_CHANGE_BY_INIT       0
346 #define RF_CHANGE_BY_IPS        BIT28
347 #define RF_CHANGE_BY_PS         BIT29
348 #define RF_CHANGE_BY_HW         BIT30
349 #define RF_CHANGE_BY_SW         BIT31
350
351 typedef enum _HARDWARE_TYPE{
352         HARDWARE_TYPE_RTL8180,
353         HARDWARE_TYPE_RTL8185,
354         HARDWARE_TYPE_RTL8187,
355         HARDWARE_TYPE_RTL8188,
356         HARDWARE_TYPE_RTL8190P,
357         HARDWARE_TYPE_RTL8192E,
358         HARDWARE_TYPE_RTL819xU,
359         HARDWARE_TYPE_RTL8192SE,
360         HARDWARE_TYPE_RTL8192SU,
361         HARDWARE_TYPE_RTL8192CE,
362         HARDWARE_TYPE_RTL8192CU,
363         HARDWARE_TYPE_RTL8192DE,
364         HARDWARE_TYPE_RTL8192DU,
365         HARDWARE_TYPE_RTL8723AE,
366         HARDWARE_TYPE_RTL8723AU,
367         HARDWARE_TYPE_RTL8723AS,
368         HARDWARE_TYPE_RTL8188EE,
369         HARDWARE_TYPE_RTL8188EU,
370         HARDWARE_TYPE_RTL8188ES,
371 //      NEW_GENERATION_IC
372         HARDWARE_TYPE_RTL8192EE,
373         HARDWARE_TYPE_RTL8192EU,
374         HARDWARE_TYPE_RTL8192ES,
375         HARDWARE_TYPE_RTL8812E,
376         HARDWARE_TYPE_RTL8812AU,
377         HARDWARE_TYPE_RTL8811AU,
378         HARDWARE_TYPE_RTL8821E,
379         HARDWARE_TYPE_RTL8821U,
380         HARDWARE_TYPE_RTL8821S,
381         HARDWARE_TYPE_RTL8723BE,
382         HARDWARE_TYPE_RTL8723BU,
383         HARDWARE_TYPE_RTL8723BS,
384         HARDWARE_TYPE_RTL8813AE,
385         HARDWARE_TYPE_RTL8813AU,
386         HARDWARE_TYPE_RTL8813AS,
387
388         HARDWARE_TYPE_MAX,
389 }HARDWARE_TYPE;
390
391 #define IS_NEW_GENERATION_IC(_Adapter)  (((PADAPTER)_Adapter)->HardwareType >=HARDWARE_TYPE_RTL8192EE)
392 //
393 // RTL8192C Series
394 //
395 #define IS_HARDWARE_TYPE_8192CE(_Adapter)       (((PADAPTER)_Adapter)->HardwareType==HARDWARE_TYPE_RTL8192CE)
396 #define IS_HARDWARE_TYPE_8192CU(_Adapter)       (((PADAPTER)_Adapter)->HardwareType==HARDWARE_TYPE_RTL8192CU)
397 #define IS_HARDWARE_TYPE_8192C(_Adapter)                        \
398 (IS_HARDWARE_TYPE_8192CE(_Adapter) || IS_HARDWARE_TYPE_8192CU(_Adapter))
399
400 //
401 // RTL8192D Series
402 //
403 #define IS_HARDWARE_TYPE_8192DE(_Adapter)       (((PADAPTER)_Adapter)->HardwareType==HARDWARE_TYPE_RTL8192DE)
404 #define IS_HARDWARE_TYPE_8192DU(_Adapter)       (((PADAPTER)_Adapter)->HardwareType==HARDWARE_TYPE_RTL8192DU)
405 #define IS_HARDWARE_TYPE_8192D(_Adapter)                        \
406 (IS_HARDWARE_TYPE_8192DE(_Adapter) || IS_HARDWARE_TYPE_8192DU(_Adapter))
407
408 #define IS_HARDWARE_TYPE_OLDER_THAN_8723A(_Adapter)     \
409 (IS_HARDWARE_TYPE_8192D(_Adapter) || IS_HARDWARE_TYPE_8192C(_Adapter))
410
411 //
412 // RTL8723A Series
413 //
414 #define IS_HARDWARE_TYPE_8723AE(_Adapter)       (((PADAPTER)_Adapter)->HardwareType==HARDWARE_TYPE_RTL8723AE)
415 #define IS_HARDWARE_TYPE_8723AU(_Adapter)       (((PADAPTER)_Adapter)->HardwareType==HARDWARE_TYPE_RTL8723AU)
416 #define IS_HARDWARE_TYPE_8723AS(_Adapter)       (((PADAPTER)_Adapter)->HardwareType==HARDWARE_TYPE_RTL8723AS)
417 #define IS_HARDWARE_TYPE_8723A(_Adapter)        \
418 (IS_HARDWARE_TYPE_8723AE(_Adapter) || IS_HARDWARE_TYPE_8723AU(_Adapter) || IS_HARDWARE_TYPE_8723AS(_Adapter))
419
420 //
421 // RTL8188E Series
422 //
423 #define IS_HARDWARE_TYPE_8188EE(_Adapter)       (((PADAPTER)_Adapter)->HardwareType==HARDWARE_TYPE_RTL8188EE)
424 #define IS_HARDWARE_TYPE_8188EU(_Adapter)       (((PADAPTER)_Adapter)->HardwareType==HARDWARE_TYPE_RTL8188EU)
425 #define IS_HARDWARE_TYPE_8188ES(_Adapter)       (((PADAPTER)_Adapter)->HardwareType==HARDWARE_TYPE_RTL8188ES)
426 #define IS_HARDWARE_TYPE_8188E(_Adapter)        \
427 (IS_HARDWARE_TYPE_8188EE(_Adapter) || IS_HARDWARE_TYPE_8188EU(_Adapter) || IS_HARDWARE_TYPE_8188ES(_Adapter))
428
429
430 #define IS_HARDWARE_TYPE_8188E_before(_Adapter)                 \
431 (IS_HARDWARE_TYPE_8192C(_Adapter) ||IS_HARDWARE_TYPE_8192D(_Adapter) ||IS_HARDWARE_TYPE_8723A(_Adapter))
432
433
434 #define IS_HARDWARE_TYPE_OLDER_THAN_8812A(_Adapter)     \
435 (IS_HARDWARE_TYPE_8192D(_Adapter) || IS_HARDWARE_TYPE_8192C(_Adapter) ||\
436  IS_HARDWARE_TYPE_8723AE(_Adapter) || IS_HARDWARE_TYPE_8723AU(_Adapter) || IS_HARDWARE_TYPE_8723AS(_Adapter) ||\
437  IS_HARDWARE_TYPE_8188EE(_Adapter) || IS_HARDWARE_TYPE_8188EU(_Adapter) || IS_HARDWARE_TYPE_8188ES(_Adapter)\
438 )
439
440 // RTL8812 Series
441 #define IS_HARDWARE_TYPE_8812E(_Adapter)                (((PADAPTER)_Adapter)->HardwareType==HARDWARE_TYPE_RTL8812E)
442 #define IS_HARDWARE_TYPE_8812AU(_Adapter)       (((PADAPTER)_Adapter)->HardwareType==HARDWARE_TYPE_RTL8812AU)
443 #define IS_HARDWARE_TYPE_8812(_Adapter)                 \
444 (IS_HARDWARE_TYPE_8812E(_Adapter) || IS_HARDWARE_TYPE_8812AU(_Adapter))
445
446 // RTL8821 Series
447 #define IS_HARDWARE_TYPE_8821E(_Adapter)                (((PADAPTER)_Adapter)->HardwareType==HARDWARE_TYPE_RTL8821E)
448 #define IS_HARDWARE_TYPE_8811AU(_Adapter)               (((PADAPTER)_Adapter)->HardwareType==HARDWARE_TYPE_RTL8811AU)
449 #define IS_HARDWARE_TYPE_8821U(_Adapter)                (((PADAPTER)_Adapter)->HardwareType==HARDWARE_TYPE_RTL8821U ||\
450                                                                                  ((PADAPTER)_Adapter)->HardwareType==HARDWARE_TYPE_RTL8811AU)
451 #define IS_HARDWARE_TYPE_8821S(_Adapter)                (((PADAPTER)_Adapter)->HardwareType==HARDWARE_TYPE_RTL8821S)
452 #define IS_HARDWARE_TYPE_8821(_Adapter)                 \
453 (IS_HARDWARE_TYPE_8821E(_Adapter) || IS_HARDWARE_TYPE_8821U(_Adapter)|| IS_HARDWARE_TYPE_8821S(_Adapter))
454
455 #define IS_HARDWARE_TYPE_JAGUAR(_Adapter)               \
456 (IS_HARDWARE_TYPE_8812(_Adapter) || IS_HARDWARE_TYPE_8821(_Adapter))
457
458 //RTL8192E Series
459 #define IS_HARDWARE_TYPE_8192EE(_Adapter)               (((PADAPTER)_Adapter)->HardwareType==HARDWARE_TYPE_RTL8192EE)
460 #define IS_HARDWARE_TYPE_8192EU(_Adapter)               (((PADAPTER)_Adapter)->HardwareType==HARDWARE_TYPE_RTL8192EU)
461 #define IS_HARDWARE_TYPE_8192ES(_Adapter)               (((PADAPTER)_Adapter)->HardwareType==HARDWARE_TYPE_RTL8192ES)
462
463 #define IS_HARDWARE_TYPE_8192E(_Adapter)                \
464 (IS_HARDWARE_TYPE_8192EE(_Adapter) || IS_HARDWARE_TYPE_8192EU(_Adapter) ||IS_HARDWARE_TYPE_8192ES(_Adapter))
465
466 #define IS_HARDWARE_TYPE_8723BE(_Adapter)               (((PADAPTER)_Adapter)->HardwareType==HARDWARE_TYPE_RTL8723BE)
467 #define IS_HARDWARE_TYPE_8723BU(_Adapter)               (((PADAPTER)_Adapter)->HardwareType==HARDWARE_TYPE_RTL8723BU)
468 #define IS_HARDWARE_TYPE_8723BS(_Adapter)               (((PADAPTER)_Adapter)->HardwareType==HARDWARE_TYPE_RTL8723BS)
469
470
471 #define IS_HARDWARE_TYPE_8723B(_Adapter) \
472         (IS_HARDWARE_TYPE_8723BE(_Adapter) || IS_HARDWARE_TYPE_8723BU(_Adapter) ||IS_HARDWARE_TYPE_8723BS(_Adapter))
473
474 //RTL8813A Series
475 #define IS_HARDWARE_TYPE_8813AE(_Adapter)               (((PADAPTER)_Adapter)->HardwareType==HARDWARE_TYPE_RTL8813AE)
476 #define IS_HARDWARE_TYPE_8813AU(_Adapter)               (((PADAPTER)_Adapter)->HardwareType==HARDWARE_TYPE_RTL8813AU)
477 #define IS_HARDWARE_TYPE_8813AS(_Adapter)               (((PADAPTER)_Adapter)->HardwareType==HARDWARE_TYPE_RTL8813AS)
478
479 #define IS_HARDWARE_TYPE_8813A(_Adapter)                \
480 (IS_HARDWARE_TYPE_8813AE(_Adapter) || IS_HARDWARE_TYPE_8813AU(_Adapter) ||IS_HARDWARE_TYPE_8813AS(_Adapter))
481
482
483 typedef struct eeprom_priv EEPROM_EFUSE_PRIV, *PEEPROM_EFUSE_PRIV;
484 #define GET_EEPROM_EFUSE_PRIV(adapter) (&adapter->eeprompriv)
485 #define is_boot_from_eeprom(adapter) (adapter->eeprompriv.EepromOrEfuse)
486
487 typedef enum _wowlan_subcode{
488         WOWLAN_PATTERN_MATCH    = 1,
489         WOWLAN_MAGIC_PACKET             = 2,
490         WOWLAN_UNICAST                  = 3,
491         WOWLAN_SET_PATTERN              = 4,
492         WOWLAN_DUMP_REG                 = 5,
493         WOWLAN_ENABLE                   = 6,
494         WOWLAN_DISABLE                  = 7,
495         WOWLAN_STATUS                   = 8,
496         WOWLAN_DEBUG_RELOAD_FW  = 9,
497         WOWLAN_DEBUG_1                  =10,
498         WOWLAN_DEBUG_2                  =11,
499         WOWLAN_AP_ENABLE                =12,
500         WOWLAN_AP_DISABLE               =13
501 }wowlan_subcode;
502
503 struct wowlan_ioctl_param{
504         unsigned int subcode;
505         unsigned int subcode_value;
506         unsigned int wakeup_reason;
507         unsigned int len;
508         unsigned char pattern[0];
509 };
510
511 #define Rx_Pairwisekey                  0x01
512 #define Rx_GTK                                  0x02
513 #define Rx_DisAssoc                             0x04
514 #define Rx_DeAuth                               0x08
515 #define Rx_ARPReq                               0x09
516 #define FWDecisionDisconnect    0x10
517 #define Rx_MagicPkt                             0x21
518 #define Rx_UnicastPkt                   0x22
519 #define Rx_PatternPkt                   0x23
520 #define RX_PNOWakeUp                    0x55
521 #define AP_WakeUp                       0x66
522
523 void rtw_hal_def_value_init(_adapter *padapter);
524
525 void    rtw_hal_free_data(_adapter *padapter);
526
527 void rtw_hal_dm_init(_adapter *padapter);
528 void rtw_hal_dm_deinit(_adapter *padapter);
529 void rtw_hal_sw_led_init(_adapter *padapter);
530 void rtw_hal_sw_led_deinit(_adapter *padapter);
531
532 u32 rtw_hal_power_on(_adapter *padapter);
533 void rtw_hal_power_off(_adapter *padapter);
534 uint rtw_hal_init(_adapter *padapter);
535 uint rtw_hal_deinit(_adapter *padapter);
536 void rtw_hal_stop(_adapter *padapter);
537 void rtw_hal_set_hwreg(PADAPTER padapter, u8 variable, u8 *val);
538 void rtw_hal_get_hwreg(PADAPTER padapter, u8 variable, u8 *val);
539
540 #ifdef CONFIG_C2H_PACKET_EN
541 void rtw_hal_set_hwreg_with_buf(_adapter *padapter, u8 variable, u8 *pbuf, int len);
542 #endif
543
544 void rtw_hal_chip_configure(_adapter *padapter);
545 void rtw_hal_read_chip_info(_adapter *padapter);
546 void rtw_hal_read_chip_version(_adapter *padapter);
547
548 u8 rtw_hal_set_def_var(_adapter *padapter, HAL_DEF_VARIABLE eVariable, PVOID pValue);
549 u8 rtw_hal_get_def_var(_adapter *padapter, HAL_DEF_VARIABLE eVariable, PVOID pValue);
550
551 void rtw_hal_set_odm_var(_adapter *padapter, HAL_ODM_VARIABLE eVariable, PVOID pValue1,BOOLEAN bSet);
552 void    rtw_hal_get_odm_var(_adapter *padapter, HAL_ODM_VARIABLE eVariable, PVOID pValue1,PVOID pValue2);
553         
554 void rtw_hal_enable_interrupt(_adapter *padapter);
555 void rtw_hal_disable_interrupt(_adapter *padapter);
556
557 u8 rtw_hal_check_ips_status(_adapter *padapter);
558
559 u32     rtw_hal_inirp_init(_adapter *padapter);
560 u32     rtw_hal_inirp_deinit(_adapter *padapter);
561
562 void    rtw_hal_irp_reset(_adapter *padapter);
563
564 u8      rtw_hal_intf_ps_func(_adapter *padapter,HAL_INTF_PS_FUNC efunc_id, u8* val);
565
566 s32     rtw_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe);
567 s32     rtw_hal_xmit(_adapter *padapter, struct xmit_frame *pxmitframe);
568 s32     rtw_hal_mgnt_xmit(_adapter *padapter, struct xmit_frame *pmgntframe);
569
570 s32     rtw_hal_init_xmit_priv(_adapter *padapter);
571 void    rtw_hal_free_xmit_priv(_adapter *padapter);
572
573 s32     rtw_hal_init_recv_priv(_adapter *padapter);
574 void    rtw_hal_free_recv_priv(_adapter *padapter);
575
576 void rtw_hal_update_ra_mask(struct sta_info *psta, u8 rssi_level);
577 void    rtw_hal_add_ra_tid(_adapter *padapter, u32 bitmap, u8* arg, u8 rssi_level);
578
579 void    rtw_hal_start_thread(_adapter *padapter);
580 void    rtw_hal_stop_thread(_adapter *padapter);
581
582 void rtw_hal_bcn_related_reg_setting(_adapter *padapter);
583
584 u32     rtw_hal_read_bbreg(_adapter *padapter, u32 RegAddr, u32 BitMask);
585 void    rtw_hal_write_bbreg(_adapter *padapter, u32 RegAddr, u32 BitMask, u32 Data);
586 u32     rtw_hal_read_rfreg(_adapter *padapter, u32 eRFPath, u32 RegAddr, u32 BitMask);
587 void    rtw_hal_write_rfreg(_adapter *padapter, u32 eRFPath, u32 RegAddr, u32 BitMask, u32 Data);
588
589 #define PHY_QueryBBReg(Adapter, RegAddr, BitMask) rtw_hal_read_bbreg((Adapter), (RegAddr), (BitMask))
590 #define PHY_SetBBReg(Adapter, RegAddr, BitMask, Data) rtw_hal_write_bbreg((Adapter), (RegAddr), (BitMask), (Data))
591 #define PHY_QueryRFReg(Adapter, eRFPath, RegAddr, BitMask) rtw_hal_read_rfreg((Adapter), (eRFPath), (RegAddr), (BitMask))
592 #define PHY_SetRFReg(Adapter, eRFPath, RegAddr, BitMask, Data) rtw_hal_write_rfreg((Adapter), (eRFPath), (RegAddr), (BitMask), (Data))
593
594 #define PHY_SetMacReg   PHY_SetBBReg
595 #define PHY_QueryMacReg PHY_QueryBBReg
596
597 s32     rtw_hal_interrupt_handler(_adapter *padapter);
598
599 void    rtw_hal_set_bwmode(_adapter *padapter, CHANNEL_WIDTH Bandwidth, u8 Offset);
600 void    rtw_hal_set_chan(_adapter *padapter, u8 channel);
601 void    rtw_hal_set_chnl_bw(_adapter *padapter, u8 channel, CHANNEL_WIDTH Bandwidth, u8 Offset40, u8 Offset80);
602 void    rtw_hal_dm_watchdog(_adapter *padapter);
603 void    rtw_hal_dm_watchdog_in_lps(_adapter *padapter);
604
605 void    rtw_hal_set_tx_power_level(_adapter *padapter, u8 channel);
606 void    rtw_hal_get_tx_power_level(_adapter *padapter, s32 *powerlevel);
607
608 #ifdef CONFIG_ANTENNA_DIVERSITY
609 u8      rtw_hal_antdiv_before_linked(_adapter *padapter);
610 void    rtw_hal_antdiv_rssi_compared(_adapter *padapter, WLAN_BSSID_EX *dst, WLAN_BSSID_EX *src);
611 #endif
612
613 #ifdef CONFIG_HOSTAPD_MLME
614 s32     rtw_hal_hostap_mgnt_xmit_entry(_adapter *padapter, _pkt *pkt);
615 #endif
616
617 #ifdef DBG_CONFIG_ERROR_DETECT
618 void rtw_hal_sreset_init(_adapter *padapter);
619 void rtw_hal_sreset_reset(_adapter *padapter);
620 void rtw_hal_sreset_reset_value(_adapter *padapter);
621 void rtw_hal_sreset_xmit_status_check(_adapter *padapter);
622 void rtw_hal_sreset_linked_status_check (_adapter *padapter);
623 u8   rtw_hal_sreset_get_wifi_status(_adapter *padapter);
624 bool rtw_hal_sreset_inprogress(_adapter *padapter);
625 #endif
626
627 #ifdef CONFIG_IOL
628 int rtw_hal_iol_cmd(ADAPTER *adapter, struct xmit_frame *xmit_frame, u32 max_wating_ms, u32 bndy_cnt);
629 #endif
630
631 #ifdef CONFIG_XMIT_THREAD_MODE
632 s32 rtw_hal_xmit_thread_handler(_adapter *padapter);
633 #endif
634
635 void rtw_hal_notch_filter(_adapter * adapter, bool enable);
636 void rtw_hal_reset_security_engine(_adapter * adapter);
637
638 bool rtw_hal_c2h_valid(_adapter *adapter, u8 *buf);
639 s32 rtw_hal_c2h_evt_read(_adapter *adapter, u8 *buf);
640 s32 rtw_hal_c2h_handler(_adapter *adapter, u8 *c2h_evt);
641 c2h_id_filter rtw_hal_c2h_id_filter_ccx(_adapter *adapter);
642
643 s32 rtw_hal_is_disable_sw_channel_plan(PADAPTER padapter);
644
645 s32 rtw_hal_macid_sleep(PADAPTER padapter, u8 macid);
646 s32 rtw_hal_macid_wakeup(PADAPTER padapter, u8 macid);
647
648 s32 rtw_hal_fill_h2c_cmd(PADAPTER, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer);
649
650 #endif //__HAL_INTF_H__
651