2 * @file wilc_wfi_netdevice.h
3 * @brief Definitions for the network module
8 #ifndef WILC_WFI_NETDEVICE
9 #define WILC_WFI_NETDEVICE
11 /* These are the flags in the statusword */
12 #define WILC_WFI_RX_INTR 0x0001
13 #define WILC_WFI_TX_INTR 0x0002
15 /* Default timeout period */
16 #define WILC_WFI_TIMEOUT 5 /* In jiffies */
17 #define WILC_MAX_NUM_PMKIDS 16
20 #define NUM_STA_ASSOCIATED 8
22 #include <linux/module.h>
23 #include <linux/init.h>
24 #include <linux/moduleparam.h>
25 #include <linux/sched.h>
26 #include <linux/kernel.h>
27 #include <linux/slab.h> /* kmalloc() */
28 #include <linux/errno.h> /* error codes */
29 #include <linux/types.h> /* size_t */
30 #include <linux/interrupt.h> /* mark_bh */
31 #include <linux/time.h>
33 #include <linux/netdevice.h> /* struct device, and other headers */
34 #include <linux/etherdevice.h> /* eth_type_trans */
35 #include <linux/ip.h> /* struct iphdr */
36 #include <linux/tcp.h> /* struct tcphdr */
37 #include <linux/skbuff.h>
38 #include <linux/ieee80211.h>
39 #include <net/cfg80211.h>
40 #include <linux/ieee80211.h>
41 #include <net/cfg80211.h>
42 #include <net/ieee80211_radiotap.h>
43 #include <linux/if_arp.h>
44 #include <linux/in6.h>
45 #include <asm/checksum.h>
46 #include "host_interface.h"
47 #include "wilc_wlan.h"
48 #include <linux/wireless.h> /* tony, 2013-06-12 */
50 #define FLOW_CONTROL_LOWER_THRESHOLD 128
51 #define FLOW_CONTROL_UPPER_THRESHOLD 256
55 WILC_WFI_RX_PKT
= 1 << 0,
56 WILC_WFI_TX_PKT
= 1 << 1,
59 struct WILC_WFI_stats
{
60 unsigned long rx_packets
;
61 unsigned long tx_packets
;
62 unsigned long rx_bytes
;
63 unsigned long tx_bytes
;
70 * This structure is private to each device. It is used to pass
71 * packets in and out, so there is place for a packet
74 #define RX_BH_KTHREAD 0
75 #define RX_BH_WORK_QUEUE 1
76 #define RX_BH_THREADED_IRQ 2
77 #define num_reg_frame 2
79 * If you use RX_BH_WORK_QUEUE on LPC3131: You may lose the first interrupt on
80 * LPC3131 which is important to get the MAC start status when you are blocked
81 * inside linux_wlan_firmware_download() which blocks mac_open().
83 #if defined(NM73131_0_BOARD)
84 #define RX_BH_TYPE RX_BH_KTHREAD
85 #elif defined(PANDA_BOARD)
86 #define RX_BH_TYPE RX_BH_THREADED_IRQ
88 #define RX_BH_TYPE RX_BH_KTHREAD
99 struct wilc_wfi_wep_key
{
106 u8 au8Sta_AssociatedBss
[MAX_NUM_STA
][ETH_ALEN
];
110 /*Parameters needed for host interface for remaining on channel*/
111 struct wilc_wfi_p2pListenParams
{
112 struct ieee80211_channel
*pstrListenChan
;
113 enum nl80211_channel_type tenuChannelType
;
114 u32 u32ListenDuration
;
116 u32 u32ListenSessionID
;
121 struct WILC_WFI_priv
{
122 struct wireless_dev
*wdev
;
123 struct cfg80211_scan_request
*pstrScanReq
;
126 struct wilc_wfi_p2pListenParams strRemainOnChanParams
;
133 u8 au8AssociatedBss
[ETH_ALEN
];
134 struct sta_info assoc_stainfo
;
135 struct net_device_stats stats
;
138 struct WILC_WFI_packet
*ppool
;
139 struct WILC_WFI_packet
*rx_queue
; /* List of incoming packets */
145 struct net_device
*dev
;
146 struct napi_struct napi
;
147 tstrWILC_WFIDrv
*hWILCWFIDrv
;
148 WILC_WFIDrvHandle hWILCWFIDrv_2
;
149 tstrHostIFpmkidAttr pmkid_list
;
150 struct WILC_WFI_stats netstats
;
151 u8 WILC_WFI_wep_default
;
152 u8 WILC_WFI_wep_key
[4][WLAN_KEY_LEN_WEP104
];
153 u8 WILC_WFI_wep_key_len
[4];
154 /* The real interface that the monitor is on */
155 struct net_device
*real_ndev
;
156 struct wilc_wfi_key
*wilc_gtk
[MAX_NUM_STA
];
157 struct wilc_wfi_key
*wilc_ptk
[MAX_NUM_STA
];
160 struct semaphore SemHandleUpdateStats
;
161 struct semaphore hSemScanReq
;
163 bool gbAutoRateAdjusted
;
165 bool bInP2PlistenState
;
175 #define NUM_CONCURRENT_IFC 2
177 uint8_t aSrcAddress
[ETH_ALEN
];
178 uint8_t aBSSID
[ETH_ALEN
];
179 tstrWILC_WFIDrv
*drvHandler
;
180 struct net_device
*wilc_netdev
;
184 int wilc1000_initialized
;
185 #if (!defined WILC_SDIO) || (defined WILC_SDIO_IRQ_GPIO)
186 unsigned short dev_irq_num
;
191 tstrInterfaceInfo strInterfaceInfo
[NUM_CONCURRENT_IFC
];
195 /*Added by Amr - BugID_4720*/
196 struct mutex txq_add_to_head_cs
;
197 spinlock_t txq_spinlock
;
202 /* struct mutex txq_event; */
203 struct semaphore rxq_event
;
204 struct semaphore cfg_event
;
205 struct semaphore sync_event
;
207 struct semaphore txq_event
;
208 /* struct completion txq_event; */
210 #if (RX_BH_TYPE == RX_BH_WORK_QUEUE)
211 struct work_struct rx_work_queue
;
212 #elif (RX_BH_TYPE == RX_BH_KTHREAD)
213 struct task_struct
*rx_bh_thread
;
214 struct semaphore rx_sem
;
216 struct semaphore rxq_thread_started
;
217 struct semaphore txq_thread_started
;
219 struct task_struct
*rxq_thread
;
220 struct task_struct
*txq_thread
;
222 unsigned char eth_src_address
[NUM_CONCURRENT_IFC
][6];
223 /* unsigned char eth_dst_address[6]; */
225 const struct firmware
*wilc_firmware
; /* Bug 4703 */
227 struct net_device
*real_ndev
;
230 struct sdio_func
*wilc_sdio_func
;
232 struct spi_device
*wilc_spidev
;
243 struct_frame_reg g_struct_frame_reg
[num_reg_frame
];
245 struct net_device
*wilc_netdev
;
246 struct net_device_stats netstats
;
248 } perInterface_wlan_t
;
250 struct WILC_WFI_mon_priv
{
251 struct net_device
*real_ndev
;
254 extern struct net_device
*WILC_WFI_devs
[];