SAMA5D4 Xplained Ultra Board BSP
guowenxue
2019-08-19 2e7235d10c6dbff81960282e1a1e2e798f9b8db8
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
/******************************************************************************
 *
 * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
 *
 * This program is free software; you can redistribute it and/or modify it
 * under the terms of version 2 of the GNU General Public License as
 * published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
 * more details.
 *
 * You should have received a copy of the GNU General Public License along with
 * this program; if not, write to the Free Software Foundation, Inc.,
 * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
 *
 *
 ******************************************************************************/
 
#ifndef __OSDEP_INTF_H_
#define __OSDEP_INTF_H_
 
 
struct intf_priv {
 
    u8 *intf_dev;
    u32    max_iosz;    /* USB2.0: 128, USB1.1: 64, SDIO:64 */
    u32    max_xmitsz; /* USB2.0: unlimited, SDIO:512 */
    u32    max_recvsz; /* USB2.0: unlimited, SDIO:512 */
 
    volatile u8 *io_rwmem;
    volatile u8 *allocated_io_rwmem;
    u32    io_wsz; /* unit: 4bytes */
    u32    io_rsz;/* unit: 4bytes */
    u8 intf_status;
 
    void (*_bus_io)(u8 *priv);
 
    /*
    Under Sync. IRP (SDIO/USB)
    A protection mechanism is necessary for the io_rwmem(read/write protocol)
 
    Under Async. IRP (SDIO/USB)
    The protection mechanism is through the pending queue.
    */
 
    _mutex ioctl_mutex;
 
 
#ifdef PLATFORM_LINUX
#ifdef CONFIG_USB_HCI
    /* when in USB, IO is through interrupt in/out endpoints */
    struct usb_device    *udev;
    PURB    piorw_urb;
    u8 io_irp_cnt;
    u8 bio_irp_pending;
    _sema io_retevt;
    _timer    io_timer;
    u8 bio_irp_timeout;
    u8 bio_timer_cancel;
#endif
#endif
 
#ifdef PLATFORM_OS_XP
#ifdef CONFIG_SDIO_HCI
    /* below is for io_rwmem... */
    PMDL pmdl;
    PSDBUS_REQUEST_PACKET  sdrp;
    PSDBUS_REQUEST_PACKET  recv_sdrp;
    PSDBUS_REQUEST_PACKET  xmit_sdrp;
 
    PIRP        piorw_irp;
 
#endif
#ifdef CONFIG_USB_HCI
    PURB    piorw_urb;
    PIRP        piorw_irp;
    u8 io_irp_cnt;
    u8 bio_irp_pending;
    _sema io_retevt;
#endif
#endif
 
};
 
 
#ifdef CONFIG_R871X_TEST
    int rtw_start_pseudo_adhoc(_adapter *padapter);
    int rtw_stop_pseudo_adhoc(_adapter *padapter);
#endif
 
struct dvobj_priv *devobj_init(void);
void devobj_deinit(struct dvobj_priv *pdvobj);
 
u8 rtw_init_drv_sw(_adapter *padapter);
u8 rtw_free_drv_sw(_adapter *padapter);
u8 rtw_reset_drv_sw(_adapter *padapter);
void rtw_dev_unload(PADAPTER padapter);
 
u32 rtw_start_drv_threads(_adapter *padapter);
void rtw_stop_drv_threads(_adapter *padapter);
#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
void rtw_cancel_dynamic_chk_timer(_adapter *padapter);
#endif
void rtw_cancel_all_timer(_adapter *padapter);
 
uint loadparam(_adapter *adapter);
 
#ifdef PLATFORM_LINUX
int rtw_ioctl(struct net_device *dev, struct ifreq *rq, int cmd);
 
int rtw_init_netdev_name(struct net_device *pnetdev, const char *ifname);
struct net_device *rtw_init_netdev(_adapter *padapter);
 
void rtw_os_ndev_free(_adapter *adapter);
int rtw_os_ndev_init(_adapter *adapter, const char *name);
void rtw_os_ndev_deinit(_adapter *adapter);
void rtw_os_ndev_unregister(_adapter *adapter);
void rtw_os_ndevs_unregister(struct dvobj_priv *dvobj);
int rtw_os_ndevs_init(struct dvobj_priv *dvobj);
void rtw_os_ndevs_deinit(struct dvobj_priv *dvobj);
 
#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
u16 rtw_recv_select_queue(struct sk_buff *skb);
#endif /* LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35) */
 
int rtw_ndev_notifier_register(void);
void rtw_ndev_notifier_unregister(void);
 
#include "../os_dep/linux/rtw_proc.h"
 
#ifdef CONFIG_IOCTL_CFG80211
    #include "../os_dep/linux/ioctl_cfg80211.h"
#endif /* CONFIG_IOCTL_CFG80211 */
 
u8 rtw_rtnl_lock_needed(struct dvobj_priv *dvobj);
void rtw_set_rtnl_lock_holder(struct dvobj_priv *dvobj, _thread_hdl_ thd_hdl);
 
#endif /* PLATFORM_LINUX */
 
 
#ifdef PLATFORM_FREEBSD
extern int rtw_ioctl(struct ifnet *ifp, u_long cmd, caddr_t data);
#endif
 
void rtw_ips_dev_unload(_adapter *padapter);
 
#ifdef CONFIG_IPS
int rtw_ips_pwr_up(_adapter *padapter);
void rtw_ips_pwr_down(_adapter *padapter);
#endif
 
#ifdef CONFIG_CONCURRENT_MODE
struct _io_ops;
struct dvobj_priv;
_adapter *rtw_drv_add_vir_if(_adapter *primary_padapter, void (*set_intf_ops)(_adapter *primary_padapter, struct _io_ops *pops));
void rtw_drv_stop_vir_ifaces(struct dvobj_priv *dvobj);
void rtw_drv_free_vir_ifaces(struct dvobj_priv *dvobj);
#endif
 
void rtw_ndev_destructor(_nic_hdl ndev);
 
#ifdef CONFIG_ARP_KEEP_ALIVE
int    rtw_gw_addr_query(_adapter *padapter);
#endif
 
int rtw_suspend_common(_adapter *padapter);
int rtw_resume_common(_adapter *padapter);
 
#endif /* _OSDEP_INTF_H_ */