1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20#ifndef _GELIC_WIRELESS_H
21#define _GELIC_WIRELESS_H
22
23#include <linux/wireless.h>
24#include <net/iw_handler.h>
25
26
27
28enum gelic_lv1_wl_event {
29 GELIC_LV1_WL_EVENT_DEVICE_READY = 0x01,
30 GELIC_LV1_WL_EVENT_SCAN_COMPLETED = 0x02,
31 GELIC_LV1_WL_EVENT_DEAUTH = 0x04,
32 GELIC_LV1_WL_EVENT_BEACON_LOST = 0x08,
33 GELIC_LV1_WL_EVENT_CONNECTED = 0x10,
34 GELIC_LV1_WL_EVENT_WPA_CONNECTED = 0x20,
35 GELIC_LV1_WL_EVENT_WPA_ERROR = 0x40,
36};
37
38
39enum gelic_eurus_command {
40 GELIC_EURUS_CMD_ASSOC = 1,
41 GELIC_EURUS_CMD_DISASSOC = 2,
42 GELIC_EURUS_CMD_START_SCAN = 3,
43 GELIC_EURUS_CMD_GET_SCAN = 4,
44 GELIC_EURUS_CMD_SET_COMMON_CFG = 5,
45 GELIC_EURUS_CMD_GET_COMMON_CFG = 6,
46 GELIC_EURUS_CMD_SET_WEP_CFG = 7,
47 GELIC_EURUS_CMD_GET_WEP_CFG = 8,
48 GELIC_EURUS_CMD_SET_WPA_CFG = 9,
49 GELIC_EURUS_CMD_GET_WPA_CFG = 10,
50 GELIC_EURUS_CMD_GET_RSSI_CFG = 11,
51 GELIC_EURUS_CMD_MAX_INDEX
52};
53
54
55enum gelic_eurus_bss_type {
56 GELIC_EURUS_BSS_INFRA = 0,
57 GELIC_EURUS_BSS_ADHOC = 1,
58};
59
60enum gelic_eurus_auth_method {
61 GELIC_EURUS_AUTH_OPEN = 0,
62 GELIC_EURUS_AUTH_SHARED = 1,
63};
64
65enum gelic_eurus_opmode {
66 GELIC_EURUS_OPMODE_11BG = 0,
67 GELIC_EURUS_OPMODE_11B = 1,
68 GELIC_EURUS_OPMODE_11G = 2,
69};
70
71struct gelic_eurus_common_cfg {
72
73 u16 scan_index;
74 u16 bss_type;
75 u16 auth_method;
76 u16 op_mode;
77} __packed;
78
79
80
81enum gelic_eurus_wep_security {
82 GELIC_EURUS_WEP_SEC_NONE = 0,
83 GELIC_EURUS_WEP_SEC_40BIT = 1,
84 GELIC_EURUS_WEP_SEC_104BIT = 2,
85};
86
87struct gelic_eurus_wep_cfg {
88
89 u16 security;
90 u8 key[4][16];
91} __packed;
92
93
94enum gelic_eurus_wpa_security {
95 GELIC_EURUS_WPA_SEC_NONE = 0x0000,
96
97 GELIC_EURUS_WPA_SEC_WPA_TKIP_TKIP = 0x0001,
98
99 GELIC_EURUS_WPA_SEC_WPA_AES_AES = 0x0002,
100
101 GELIC_EURUS_WPA_SEC_WPA2_TKIP_TKIP = 0x0004,
102
103 GELIC_EURUS_WPA_SEC_WPA2_AES_AES = 0x0008,
104
105 GELIC_EURUS_WPA_SEC_WPA_TKIP_AES = 0x0010,
106
107 GELIC_EURUS_WPA_SEC_WPA2_TKIP_AES = 0x0020,
108};
109
110enum gelic_eurus_wpa_psk_type {
111 GELIC_EURUS_WPA_PSK_PASSPHRASE = 0,
112 GELIC_EURUS_WPA_PSK_BIN = 1,
113};
114
115#define GELIC_WL_EURUS_PSK_MAX_LEN 64
116#define WPA_PSK_LEN 32
117
118struct gelic_eurus_wpa_cfg {
119
120 u16 security;
121 u16 psk_type;
122 u8 psk[GELIC_WL_EURUS_PSK_MAX_LEN];
123} __packed;
124
125
126enum gelic_eurus_scan_capability {
127 GELIC_EURUS_SCAN_CAP_ADHOC = 0x0000,
128 GELIC_EURUS_SCAN_CAP_INFRA = 0x0001,
129 GELIC_EURUS_SCAN_CAP_MASK = 0x0001,
130};
131
132enum gelic_eurus_scan_sec_type {
133 GELIC_EURUS_SCAN_SEC_NONE = 0x0000,
134 GELIC_EURUS_SCAN_SEC_WEP = 0x0100,
135 GELIC_EURUS_SCAN_SEC_WPA = 0x0200,
136 GELIC_EURUS_SCAN_SEC_WPA2 = 0x0400,
137 GELIC_EURUS_SCAN_SEC_MASK = 0x0f00,
138};
139
140enum gelic_eurus_scan_sec_wep_type {
141 GELIC_EURUS_SCAN_SEC_WEP_UNKNOWN = 0x0000,
142 GELIC_EURUS_SCAN_SEC_WEP_40 = 0x0001,
143 GELIC_EURUS_SCAN_SEC_WEP_104 = 0x0002,
144 GELIC_EURUS_SCAN_SEC_WEP_MASK = 0x0003,
145};
146
147enum gelic_eurus_scan_sec_wpa_type {
148 GELIC_EURUS_SCAN_SEC_WPA_UNKNOWN = 0x0000,
149 GELIC_EURUS_SCAN_SEC_WPA_TKIP = 0x0001,
150 GELIC_EURUS_SCAN_SEC_WPA_AES = 0x0002,
151 GELIC_EURUS_SCAN_SEC_WPA_MASK = 0x0003,
152};
153
154
155
156
157struct gelic_eurus_scan_info {
158
159 __be16 size;
160 __be16 rssi;
161 __be16 channel;
162 __be16 beacon_period;
163 __be16 capability;
164 __be16 security;
165 u8 bssid[8];
166 u8 essid[32];
167 u8 rate[16];
168 u8 ext_rate[16];
169 __be32 reserved1;
170 __be32 reserved2;
171 __be32 reserved3;
172 __be32 reserved4;
173 u8 elements[0];
174} __packed;
175
176
177#define GELIC_EURUS_MAX_SCAN (16)
178struct gelic_wl_scan_info {
179 struct list_head list;
180 struct gelic_eurus_scan_info *hwinfo;
181
182 int valid;
183
184 unsigned int eurus_index;
185 unsigned long last_scanned;
186
187 unsigned int rate_len;
188 unsigned int rate_ext_len;
189 unsigned int essid_len;
190};
191
192
193struct gelic_eurus_rssi_info {
194
195 __be16 rssi;
196} __packed;
197
198
199
200enum gelic_wl_info_status_bit {
201 GELIC_WL_STAT_CONFIGURED,
202 GELIC_WL_STAT_CH_INFO,
203 GELIC_WL_STAT_ESSID_SET,
204 GELIC_WL_STAT_BSSID_SET,
205 GELIC_WL_STAT_WPA_PSK_SET,
206 GELIC_WL_STAT_WPA_LEVEL_SET,
207};
208
209
210enum gelic_wl_scan_state {
211
212 GELIC_WL_SCAN_STAT_INIT,
213
214 GELIC_WL_SCAN_STAT_SCANNING,
215
216 GELIC_WL_SCAN_STAT_GOT_LIST,
217};
218
219
220enum gelic_wl_cipher_method {
221 GELIC_WL_CIPHER_NONE,
222 GELIC_WL_CIPHER_WEP,
223 GELIC_WL_CIPHER_TKIP,
224 GELIC_WL_CIPHER_AES,
225};
226
227
228enum gelic_wl_wpa_level {
229 GELIC_WL_WPA_LEVEL_NONE,
230 GELIC_WL_WPA_LEVEL_WPA,
231 GELIC_WL_WPA_LEVEL_WPA2,
232};
233
234
235enum gelic_wl_assoc_state {
236 GELIC_WL_ASSOC_STAT_DISCONN,
237 GELIC_WL_ASSOC_STAT_ASSOCIATING,
238 GELIC_WL_ASSOC_STAT_ASSOCIATED,
239};
240
241#define GELIC_WEP_KEYS 4
242struct gelic_wl_info {
243
244 struct mutex scan_lock;
245 struct list_head network_list;
246 struct list_head network_free_list;
247 struct gelic_wl_scan_info *networks;
248
249 unsigned long scan_age;
250 enum gelic_wl_scan_state scan_stat;
251 struct completion scan_done;
252
253
254 struct workqueue_struct *eurus_cmd_queue;
255 struct completion cmd_done_intr;
256
257
258 struct workqueue_struct *event_queue;
259 struct delayed_work event_work;
260
261
262 unsigned long stat;
263 enum gelic_eurus_auth_method auth_method;
264 enum gelic_wl_cipher_method group_cipher_method;
265 enum gelic_wl_cipher_method pairwise_cipher_method;
266 enum gelic_wl_wpa_level wpa_level;
267
268
269 struct mutex assoc_stat_lock;
270 struct delayed_work assoc_work;
271 enum gelic_wl_assoc_state assoc_stat;
272 struct completion assoc_done;
273
274 spinlock_t lock;
275 u16 ch_info;
276
277 u8 key[GELIC_WEP_KEYS][IW_ENCODING_TOKEN_MAX];
278 unsigned long key_enabled;
279 unsigned int key_len[GELIC_WEP_KEYS];
280 unsigned int current_key;
281
282 u8 psk[GELIC_WL_EURUS_PSK_MAX_LEN];
283 enum gelic_eurus_wpa_psk_type psk_type;
284 unsigned int psk_len;
285
286 u8 essid[IW_ESSID_MAX_SIZE];
287 u8 bssid[ETH_ALEN];
288 u8 active_bssid[ETH_ALEN];
289 unsigned int essid_len;
290
291 struct iw_public_data wireless_data;
292 struct iw_statistics iwstat;
293};
294
295#define GELIC_WL_BSS_MAX_ENT 32
296#define GELIC_WL_ASSOC_RETRY 50
297static inline struct gelic_port *wl_port(struct gelic_wl_info *wl)
298{
299 return container_of((void *)wl, struct gelic_port, priv);
300}
301static inline struct gelic_wl_info *port_wl(struct gelic_port *port)
302{
303 return port_priv(port);
304}
305
306struct gelic_eurus_cmd {
307 struct work_struct work;
308 struct gelic_wl_info *wl;
309 unsigned int cmd;
310 u64 tag;
311 u64 size;
312 void *buffer;
313 unsigned int buf_size;
314 struct completion done;
315 int status;
316 u64 cmd_status;
317};
318
319
320#define GELIC_WL_PRIV_SET_PSK (SIOCIWFIRSTPRIV + 0)
321#define GELIC_WL_PRIV_GET_PSK (SIOCIWFIRSTPRIV + 1)
322
323extern int gelic_wl_driver_probe(struct gelic_card *card);
324extern int gelic_wl_driver_remove(struct gelic_card *card);
325extern void gelic_wl_interrupt(struct net_device *netdev, u64 status);
326#endif
327