[PATCH] libertas: fix deadlock SIOCGIWSCAN handler
[linux-2.6] / drivers / net / wireless / libertas / dev.h
1 /**
2   * This file contains definitions and data structures specific
3   * to Marvell 802.11 NIC. It contains the Device Information
4   * structure wlan_adapter.
5   */
6 #ifndef _WLAN_DEV_H_
7 #define _WLAN_DEV_H_
8
9 #include <linux/netdevice.h>
10 #include <linux/wireless.h>
11 #include <linux/ethtool.h>
12 #include <linux/debugfs.h>
13 #include <net/ieee80211.h>
14
15 #include "defs.h"
16 #include "scan.h"
17 #include "thread.h"
18
19 extern struct ethtool_ops libertas_ethtool_ops;
20
21 #define MAX_BSSID_PER_CHANNEL           16
22
23 #define NR_TX_QUEUE                     3
24
25 /* For the extended Scan */
26 #define MAX_EXTENDED_SCAN_BSSID_LIST    MAX_BSSID_PER_CHANNEL * \
27                                                 MRVDRV_MAX_CHANNEL_SIZE + 1
28
29 #define MAX_REGION_CHANNEL_NUM  2
30
31 /** Chan-freq-TxPower mapping table*/
32 struct chan_freq_power {
33         /** channel Number              */
34         u16 channel;
35         /** frequency of this channel   */
36         u32 freq;
37         /** Max allowed Tx power level  */
38         u16 maxtxpower;
39         /** TRUE:channel unsupported;  FLASE:supported*/
40         u8 unsupported;
41 };
42
43 /** region-band mapping table*/
44 struct region_channel {
45         /** TRUE if this entry is valid              */
46         u8 valid;
47         /** region code for US, Japan ...            */
48         u8 region;
49         /** band B/G/A, used for BAND_CONFIG cmd             */
50         u8 band;
51         /** Actual No. of elements in the array below */
52         u8 nrcfp;
53         /** chan-freq-txpower mapping table*/
54         struct chan_freq_power *CFP;
55 };
56
57 struct wlan_802_11_security {
58         u8 WPAenabled;
59         u8 WPA2enabled;
60         u8 wep_enabled;
61         u8 auth_mode;
62 };
63
64 /** Current Basic Service Set State Structure */
65 struct current_bss_params {
66         /** bssid */
67         u8 bssid[ETH_ALEN];
68         /** ssid */
69         struct WLAN_802_11_SSID ssid;
70
71         /** band */
72         u8 band;
73         /** channel */
74         u8 channel;
75         /** number of rates supported */
76         int numofrates;
77         /** supported rates*/
78         u8 datarates[WLAN_SUPPORTED_RATES];
79 };
80
81 /** sleep_params */
82 struct sleep_params {
83         u16 sp_error;
84         u16 sp_offset;
85         u16 sp_stabletime;
86         u8 sp_calcontrol;
87         u8 sp_extsleepclk;
88         u16 sp_reserved;
89 };
90
91 /* Mesh statistics */
92 struct wlan_mesh_stats {
93         u32     fwd_bcast_cnt;          /* Fwd: Broadcast counter */
94         u32     fwd_unicast_cnt;        /* Fwd: Unicast counter */
95         u32     fwd_drop_ttl;           /* Fwd: TTL zero */
96         u32     fwd_drop_rbt;           /* Fwd: Recently Broadcasted */
97         u32     fwd_drop_noroute;       /* Fwd: No route to Destination */
98         u32     fwd_drop_nobuf;         /* Fwd: Run out of internal buffers */
99         u32     drop_blind;             /* Rx:  Dropped by blinding table */
100         u32     tx_failed_cnt;          /* Tx:  Failed transmissions */
101 };
102
103 /** Private structure for the MV device */
104 struct _wlan_private {
105         int open;
106         int mesh_open;
107         int infra_open;
108
109         char name[DEV_NAME_LEN];
110
111         void *card;
112         wlan_adapter *adapter;
113         struct net_device *dev;
114
115         struct net_device_stats stats;
116         struct net_device *mesh_dev ; /* Virtual device */
117
118         struct iw_statistics wstats;
119         struct wlan_mesh_stats mstats;
120         struct dentry *debugfs_dir;
121         struct dentry *debugfs_debug;
122         struct dentry *debugfs_files[6];
123
124         struct dentry *events_dir;
125         struct dentry *debugfs_events_files[6];
126
127         struct dentry *regs_dir;
128         struct dentry *debugfs_regs_files[6];
129
130         u32 mac_offset;
131         u32 bbp_offset;
132         u32 rf_offset;
133
134         /** Upload length */
135         u32 upld_len;
136         /* Upload buffer */
137         u8 upld_buf[WLAN_UPLD_SIZE];
138         /* Download sent:
139            bit0 1/0=data_sent/data_tx_done,
140            bit1 1/0=cmd_sent/cmd_tx_done,
141            all other bits reserved 0 */
142         u8 dnld_sent;
143
144         const struct firmware *firmware;
145         struct device *hotplug_device;
146
147         /** thread to service interrupts */
148         struct wlan_thread mainthread;
149
150         struct delayed_work assoc_work;
151         struct workqueue_struct *assoc_thread;
152
153         /** Hardware access */
154         int (*hw_register_dev) (wlan_private * priv);
155         int (*hw_unregister_dev) (wlan_private *);
156         int (*hw_prog_firmware) (wlan_private *);
157         int (*hw_host_to_card) (wlan_private * priv, u8 type, u8 * payload, u16 nb);
158         int (*hw_get_int_status) (wlan_private * priv, u8 *);
159         int (*hw_read_event_cause) (wlan_private *);
160 };
161
162 /** Association request
163  *
164  * Encapsulates all the options that describe a specific assocation request
165  * or configuration of the wireless card's radio, mode, and security settings.
166  */
167 struct assoc_request {
168 #define ASSOC_FLAG_SSID                 1
169 #define ASSOC_FLAG_CHANNEL              2
170 #define ASSOC_FLAG_BAND                 3
171 #define ASSOC_FLAG_MODE                 4
172 #define ASSOC_FLAG_BSSID                5
173 #define ASSOC_FLAG_WEP_KEYS             6
174 #define ASSOC_FLAG_WEP_TX_KEYIDX        7
175 #define ASSOC_FLAG_WPA_MCAST_KEY        8
176 #define ASSOC_FLAG_WPA_UCAST_KEY        9
177 #define ASSOC_FLAG_SECINFO              10
178 #define ASSOC_FLAG_WPA_IE               11
179         unsigned long flags;
180
181         struct WLAN_802_11_SSID ssid;
182         u8 channel;
183         u8 band;
184         u8 mode;
185         u8 bssid[ETH_ALEN];
186
187         /** WEP keys */
188         struct WLAN_802_11_KEY wep_keys[4];
189         u16 wep_tx_keyidx;
190
191         /** WPA keys */
192         struct WLAN_802_11_KEY wpa_mcast_key;
193         struct WLAN_802_11_KEY wpa_unicast_key;
194
195         struct wlan_802_11_security secinfo;
196
197         /** WPA Information Elements*/
198         u8 wpa_ie[MAX_WPA_IE_LEN];
199         u8 wpa_ie_len;
200
201         /* BSS to associate with for infrastructure of Ad-Hoc join */
202         struct bss_descriptor bss;
203 };
204
205 /** Wlan adapter data structure*/
206 struct _wlan_adapter {
207         /** STATUS variables */
208         u32 fwreleasenumber;
209         u32 fwcapinfo;
210         /* protected with big lock */
211
212         struct mutex lock;
213
214         u8 tmptxbuf[WLAN_UPLD_SIZE];
215         /* protected by hard_start_xmit serialization */
216
217         /** command-related variables */
218         u16 seqnum;
219         /* protected by big lock */
220
221         struct cmd_ctrl_node *cmd_array;
222         /** Current command */
223         struct cmd_ctrl_node *cur_cmd;
224         int cur_cmd_retcode;
225         /** command Queues */
226         /** Free command buffers */
227         struct list_head cmdfreeq;
228         /** Pending command buffers */
229         struct list_head cmdpendingq;
230
231         wait_queue_head_t cmd_pending;
232         u8 nr_cmd_pending;
233         /* command related variables protected by adapter->driver_lock */
234
235         /** Async and Sync Event variables */
236         u32 intcounter;
237         u32 eventcause;
238         u8 nodename[16];        /* nickname */
239
240         /** spin locks */
241         spinlock_t driver_lock;
242
243         /** Timers */
244         struct timer_list command_timer;
245
246         /* TX queue used in PS mode */
247         spinlock_t txqueue_lock;
248         struct sk_buff *tx_queue_ps[NR_TX_QUEUE];
249         unsigned int tx_queue_idx;
250
251         u8 hisregcpy;
252
253         /** current ssid/bssid related parameters*/
254         struct current_bss_params curbssparams;
255
256         /* IW_MODE_* */
257         u8 mode;
258
259         struct WLAN_802_11_SSID previousssid;
260         u8 previousbssid[ETH_ALEN];
261
262         /* Scan results list */
263         struct list_head network_list;
264         struct list_head network_free_list;
265         struct bss_descriptor *networks;
266
267         u8 scantype;
268         u32 scanmode;
269
270         u16 beaconperiod;
271         u8 adhoccreate;
272
273         /** capability Info used in Association, start, join */
274         struct ieeetypes_capinfo capinfo;
275
276         /** MAC address information */
277         u8 current_addr[ETH_ALEN];
278         u8 multicastlist[MRVDRV_MAX_MULTICAST_LIST_SIZE][ETH_ALEN];
279         u32 nr_of_multicastmacaddr;
280
281         /** 802.11 statistics */
282 //      struct cmd_DS_802_11_GET_STAT wlan802_11Stat;
283
284         u16 enablehwauto;
285         u16 ratebitmap;
286         /** control G rates */
287         u8 adhoc_grate_enabled;
288
289         u32 txantenna;
290         u32 rxantenna;
291
292         u32 fragthsd;
293         u32 rtsthsd;
294
295         u32 datarate;
296         u8 is_datarate_auto;
297
298         u16 listeninterval;
299         u16 prescan;
300         u8 txretrycount;
301
302         /** Tx-related variables (for single packet tx) */
303         struct sk_buff *currenttxskb;
304         u16 TxLockFlag;
305
306         /** NIC Operation characteristics */
307         u16 currentpacketfilter;
308         u32 connect_status;
309         u16 regioncode;
310         u16 regiontableindex;
311         u16 txpowerlevel;
312
313         /** POWER MANAGEMENT AND PnP SUPPORT */
314         u8 surpriseremoved;
315         u16 atimwindow;
316
317         u16 psmode;             /* Wlan802_11PowermodeCAM=disable
318                                    Wlan802_11PowermodeMAX_PSP=enable */
319         u16 multipledtim;
320         u32 psstate;
321         u8 needtowakeup;
322
323         struct PS_CMD_ConfirmSleep libertas_ps_confirm_sleep;
324         u16 locallisteninterval;
325         u16 nullpktinterval;
326
327         struct assoc_request * pending_assoc_req;
328         struct assoc_request * in_progress_assoc_req;
329
330         /** Encryption parameter */
331         struct wlan_802_11_security secinfo;
332
333         /** WEP keys */
334         struct WLAN_802_11_KEY wep_keys[4];
335         u16 wep_tx_keyidx;
336
337         /** WPA keys */
338         struct WLAN_802_11_KEY wpa_mcast_key;
339         struct WLAN_802_11_KEY wpa_unicast_key;
340
341         /** WPA Information Elements*/
342         u8 wpa_ie[MAX_WPA_IE_LEN];
343         u8 wpa_ie_len;
344
345         u16 rxantennamode;
346         u16 txantennamode;
347
348         /** Requested Signal Strength*/
349         u16 bcn_avg_factor;
350         u16 data_avg_factor;
351         u16 SNR[MAX_TYPE_B][MAX_TYPE_AVG];
352         u16 NF[MAX_TYPE_B][MAX_TYPE_AVG];
353         u8 RSSI[MAX_TYPE_B][MAX_TYPE_AVG];
354         u8 rawSNR[DEFAULT_DATA_AVG_FACTOR];
355         u8 rawNF[DEFAULT_DATA_AVG_FACTOR];
356         u16 nextSNRNF;
357         u16 numSNRNF;
358         u16 rxpd_rate;
359
360         u8 radioon;
361         u32 preamble;
362
363         /** Multi bands Parameter*/
364         u8 libertas_supported_rates[G_SUPPORTED_RATES];
365
366         /** Blue Tooth Co-existence Arbitration */
367
368         /** sleep_params */
369         struct sleep_params sp;
370
371         /** RF calibration data */
372
373 #define MAX_REGION_CHANNEL_NUM  2
374         /** region channel data */
375         struct region_channel region_channel[MAX_REGION_CHANNEL_NUM];
376
377         struct region_channel universal_channel[MAX_REGION_CHANNEL_NUM];
378
379         /** 11D and Domain Regulatory Data */
380         struct wlan_802_11d_domain_reg domainreg;
381         struct parsed_region_chan_11d parsed_region_chan;
382
383         /** FSM variable for 11d support */
384         u32 enable11d;
385
386         /**     MISCELLANEOUS */
387         u8 *prdeeprom;
388         struct wlan_offset_value offsetvalue;
389
390         struct cmd_ds_802_11_get_log logmsg;
391         u16 scanprobes;
392
393         u32 pkttxctrl;
394
395         u16 txrate;
396         u32 linkmode;
397         u32 radiomode;
398         u32 debugmode;
399         u8 fw_ready;
400
401         u8 last_scanned_channel;
402 };
403
404 #endif                          /* _WLAN_DEV_H_ */