xref: /OK3568_Linux_fs/external/rkwifibt/drivers/rtl8822cs/include/osdep_intf.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
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 
16*4882a593Smuzhiyun #ifndef __OSDEP_INTF_H_
17*4882a593Smuzhiyun #define __OSDEP_INTF_H_
18*4882a593Smuzhiyun 
19*4882a593Smuzhiyun 
20*4882a593Smuzhiyun struct intf_priv {
21*4882a593Smuzhiyun 
22*4882a593Smuzhiyun 	u8 *intf_dev;
23*4882a593Smuzhiyun 	u32	max_iosz;	/* USB2.0: 128, USB1.1: 64, SDIO:64 */
24*4882a593Smuzhiyun 	u32	max_xmitsz; /* USB2.0: unlimited, SDIO:512 */
25*4882a593Smuzhiyun 	u32	max_recvsz; /* USB2.0: unlimited, SDIO:512 */
26*4882a593Smuzhiyun 
27*4882a593Smuzhiyun 	volatile u8 *io_rwmem;
28*4882a593Smuzhiyun 	volatile u8 *allocated_io_rwmem;
29*4882a593Smuzhiyun 	u32	io_wsz; /* unit: 4bytes */
30*4882a593Smuzhiyun 	u32	io_rsz;/* unit: 4bytes */
31*4882a593Smuzhiyun 	u8 intf_status;
32*4882a593Smuzhiyun 
33*4882a593Smuzhiyun 	void (*_bus_io)(u8 *priv);
34*4882a593Smuzhiyun 
35*4882a593Smuzhiyun 	/*
36*4882a593Smuzhiyun 	Under Sync. IRP (SDIO/USB)
37*4882a593Smuzhiyun 	A protection mechanism is necessary for the io_rwmem(read/write protocol)
38*4882a593Smuzhiyun 
39*4882a593Smuzhiyun 	Under Async. IRP (SDIO/USB)
40*4882a593Smuzhiyun 	The protection mechanism is through the pending queue.
41*4882a593Smuzhiyun 	*/
42*4882a593Smuzhiyun 
43*4882a593Smuzhiyun 	_mutex ioctl_mutex;
44*4882a593Smuzhiyun 
45*4882a593Smuzhiyun 
46*4882a593Smuzhiyun #ifdef PLATFORM_LINUX
47*4882a593Smuzhiyun #ifdef CONFIG_USB_HCI
48*4882a593Smuzhiyun 	/* when in USB, IO is through interrupt in/out endpoints */
49*4882a593Smuzhiyun 	struct usb_device	*udev;
50*4882a593Smuzhiyun 	PURB	piorw_urb;
51*4882a593Smuzhiyun 	u8 io_irp_cnt;
52*4882a593Smuzhiyun 	u8 bio_irp_pending;
53*4882a593Smuzhiyun 	_sema io_retevt;
54*4882a593Smuzhiyun 	_timer	io_timer;
55*4882a593Smuzhiyun 	u8 bio_irp_timeout;
56*4882a593Smuzhiyun 	u8 bio_timer_cancel;
57*4882a593Smuzhiyun #endif
58*4882a593Smuzhiyun #endif
59*4882a593Smuzhiyun 
60*4882a593Smuzhiyun };
61*4882a593Smuzhiyun 
62*4882a593Smuzhiyun struct dvobj_priv *devobj_init(void);
63*4882a593Smuzhiyun void devobj_deinit(struct dvobj_priv *pdvobj);
64*4882a593Smuzhiyun 
65*4882a593Smuzhiyun u8 rtw_init_drv_sw(_adapter *padapter);
66*4882a593Smuzhiyun u8 rtw_free_drv_sw(_adapter *padapter);
67*4882a593Smuzhiyun u8 rtw_reset_drv_sw(_adapter *padapter);
68*4882a593Smuzhiyun void rtw_dev_unload(PADAPTER padapter);
69*4882a593Smuzhiyun 
70*4882a593Smuzhiyun u32 rtw_start_drv_threads(_adapter *padapter);
71*4882a593Smuzhiyun void rtw_stop_drv_threads(_adapter *padapter);
72*4882a593Smuzhiyun #if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
73*4882a593Smuzhiyun void rtw_cancel_dynamic_chk_timer(_adapter *padapter);
74*4882a593Smuzhiyun #endif
75*4882a593Smuzhiyun void rtw_cancel_all_timer(_adapter *padapter);
76*4882a593Smuzhiyun 
77*4882a593Smuzhiyun uint loadparam(_adapter *adapter);
78*4882a593Smuzhiyun 
79*4882a593Smuzhiyun #ifdef PLATFORM_LINUX
80*4882a593Smuzhiyun int rtw_ioctl(struct net_device *dev, struct ifreq *rq, int cmd);
81*4882a593Smuzhiyun 
82*4882a593Smuzhiyun int rtw_init_netdev_name(struct net_device *pnetdev, const char *ifname);
83*4882a593Smuzhiyun struct net_device *rtw_init_netdev(_adapter *padapter);
84*4882a593Smuzhiyun 
85*4882a593Smuzhiyun void rtw_os_ndev_free(_adapter *adapter);
86*4882a593Smuzhiyun int rtw_os_ndev_init(_adapter *adapter, const char *name);
87*4882a593Smuzhiyun void rtw_os_ndev_deinit(_adapter *adapter);
88*4882a593Smuzhiyun void rtw_os_ndev_unregister(_adapter *adapter);
89*4882a593Smuzhiyun void rtw_os_ndevs_unregister(struct dvobj_priv *dvobj);
90*4882a593Smuzhiyun int rtw_os_ndevs_init(struct dvobj_priv *dvobj);
91*4882a593Smuzhiyun void rtw_os_ndevs_deinit(struct dvobj_priv *dvobj);
92*4882a593Smuzhiyun 
93*4882a593Smuzhiyun u16 rtw_os_recv_select_queue(u8 *msdu, enum rtw_rx_llc_hdl llc_hdl);
94*4882a593Smuzhiyun 
95*4882a593Smuzhiyun int rtw_ndev_notifier_register(void);
96*4882a593Smuzhiyun void rtw_ndev_notifier_unregister(void);
97*4882a593Smuzhiyun void rtw_inetaddr_notifier_register(void);
98*4882a593Smuzhiyun void rtw_inetaddr_notifier_unregister(void);
99*4882a593Smuzhiyun 
100*4882a593Smuzhiyun #include "../os_dep/linux/rtw_proc.h"
101*4882a593Smuzhiyun #include "../os_dep/linux/nlrtw.h"
102*4882a593Smuzhiyun #ifdef CONFIG_PLATFORM_CMAP_INTFS
103*4882a593Smuzhiyun #include "../os_dep/linux/custom_multiap_intfs/custom_multiap_intfs.h"
104*4882a593Smuzhiyun #endif
105*4882a593Smuzhiyun 
106*4882a593Smuzhiyun #ifdef CONFIG_IOCTL_CFG80211
107*4882a593Smuzhiyun 	#include "../os_dep/linux/ioctl_cfg80211.h"
108*4882a593Smuzhiyun #endif /* CONFIG_IOCTL_CFG80211 */
109*4882a593Smuzhiyun 
110*4882a593Smuzhiyun u8 rtw_rtnl_lock_needed(struct dvobj_priv *dvobj);
111*4882a593Smuzhiyun void rtw_set_rtnl_lock_holder(struct dvobj_priv *dvobj, _thread_hdl_ thd_hdl);
112*4882a593Smuzhiyun 
113*4882a593Smuzhiyun #endif /* PLATFORM_LINUX */
114*4882a593Smuzhiyun 
115*4882a593Smuzhiyun 
116*4882a593Smuzhiyun #ifdef PLATFORM_FREEBSD
117*4882a593Smuzhiyun extern int rtw_ioctl(struct ifnet *ifp, u_long cmd, caddr_t data);
118*4882a593Smuzhiyun #endif
119*4882a593Smuzhiyun 
120*4882a593Smuzhiyun void rtw_ips_dev_unload(_adapter *padapter);
121*4882a593Smuzhiyun 
122*4882a593Smuzhiyun #ifdef CONFIG_IPS
123*4882a593Smuzhiyun int rtw_ips_pwr_up(_adapter *padapter);
124*4882a593Smuzhiyun void rtw_ips_pwr_down(_adapter *padapter);
125*4882a593Smuzhiyun #endif
126*4882a593Smuzhiyun 
127*4882a593Smuzhiyun #ifdef CONFIG_CONCURRENT_MODE
128*4882a593Smuzhiyun struct _io_ops;
129*4882a593Smuzhiyun struct dvobj_priv;
130*4882a593Smuzhiyun _adapter *rtw_drv_add_vir_if(_adapter *primary_padapter, void (*set_intf_ops)(_adapter *primary_padapter, struct _io_ops *pops));
131*4882a593Smuzhiyun void rtw_drv_stop_vir_ifaces(struct dvobj_priv *dvobj);
132*4882a593Smuzhiyun void rtw_drv_free_vir_ifaces(struct dvobj_priv *dvobj);
133*4882a593Smuzhiyun #endif
134*4882a593Smuzhiyun 
135*4882a593Smuzhiyun void rtw_ndev_destructor(_nic_hdl ndev);
136*4882a593Smuzhiyun #ifdef CONFIG_ARP_KEEP_ALIVE
137*4882a593Smuzhiyun int rtw_gw_addr_query(_adapter *padapter);
138*4882a593Smuzhiyun #endif
139*4882a593Smuzhiyun 
140*4882a593Smuzhiyun int rtw_suspend_common(_adapter *padapter);
141*4882a593Smuzhiyun int rtw_resume_common(_adapter *padapter);
142*4882a593Smuzhiyun 
143*4882a593Smuzhiyun #endif /* _OSDEP_INTF_H_ */
144