]> git.proxmox.com Git - mirror_ubuntu-hirsute-kernel.git/blame - drivers/staging/wilc1000/host_interface.c
staging: wilc1000: rename IEsLen of struct scan_attr
[mirror_ubuntu-hirsute-kernel.git] / drivers / staging / wilc1000 / host_interface.c
CommitLineData
e215a871
CL
1#include <linux/slab.h>
2#include <linux/time.h>
3#include <linux/kthread.h>
4#include <linux/delay.h>
c5c77ba1 5#include "host_interface.h"
c5c77ba1 6#include "coreconfigurator.h"
5366012d 7#include "wilc_wlan_if.h"
f23eb98b 8#include "wilc_msgqueue.h"
281dd5ac 9#include <linux/etherdevice.h>
c5c77ba1 10
63d03e47 11extern u8 connecting;
c5c77ba1 12
da711eb6 13extern struct timer_list hDuringIpTimer;
c5c77ba1 14
63d03e47 15extern u8 g_wilc_initialized;
c5c77ba1 16
9eac3a15
CL
17#define HOST_IF_MSG_SCAN 0
18#define HOST_IF_MSG_CONNECT 1
19#define HOST_IF_MSG_RCVD_GNRL_ASYNC_INFO 2
20#define HOST_IF_MSG_KEY 3
21#define HOST_IF_MSG_RCVD_NTWRK_INFO 4
22#define HOST_IF_MSG_RCVD_SCAN_COMPLETE 5
23#define HOST_IF_MSG_CFG_PARAMS 6
24#define HOST_IF_MSG_SET_CHANNEL 7
25#define HOST_IF_MSG_DISCONNECT 8
26#define HOST_IF_MSG_GET_RSSI 9
27#define HOST_IF_MSG_GET_CHNL 10
28#define HOST_IF_MSG_ADD_BEACON 11
29#define HOST_IF_MSG_DEL_BEACON 12
30#define HOST_IF_MSG_ADD_STATION 13
31#define HOST_IF_MSG_DEL_STATION 14
32#define HOST_IF_MSG_EDIT_STATION 15
33#define HOST_IF_MSG_SCAN_TIMER_FIRED 16
34#define HOST_IF_MSG_CONNECT_TIMER_FIRED 17
35#define HOST_IF_MSG_POWER_MGMT 18
36#define HOST_IF_MSG_GET_INACTIVETIME 19
37#define HOST_IF_MSG_REMAIN_ON_CHAN 20
38#define HOST_IF_MSG_REGISTER_FRAME 21
39#define HOST_IF_MSG_LISTEN_TIMER_FIRED 22
40#define HOST_IF_MSG_GET_LINKSPEED 23
41#define HOST_IF_MSG_SET_WFIDRV_HANDLER 24
42#define HOST_IF_MSG_SET_MAC_ADDRESS 25
43#define HOST_IF_MSG_GET_MAC_ADDRESS 26
44#define HOST_IF_MSG_SET_OPERATION_MODE 27
45#define HOST_IF_MSG_SET_IPADDRESS 28
46#define HOST_IF_MSG_GET_IPADDRESS 29
47#define HOST_IF_MSG_FLUSH_CONNECT 30
48#define HOST_IF_MSG_GET_STATISTICS 31
49#define HOST_IF_MSG_SET_MULTICAST_FILTER 32
50#define HOST_IF_MSG_ADD_BA_SESSION 33
51#define HOST_IF_MSG_DEL_BA_SESSION 34
52#define HOST_IF_MSG_Q_IDLE 35
53#define HOST_IF_MSG_DEL_ALL_STA 36
54#define HOST_IF_MSG_DEL_ALL_RX_BA_SESSIONS 34
55#define HOST_IF_MSG_EXIT 100
d85f5326 56
e54d5b75
CL
57#define HOST_IF_SCAN_TIMEOUT 4000
58#define HOST_IF_CONNECT_TIMEOUT 9500
c5c77ba1 59
e54d5b75
CL
60#define BA_SESSION_DEFAULT_BUFFER_SIZE 16
61#define BA_SESSION_DEFAULT_TIMEOUT 1000
62#define BLOCK_ACK_REQ_SIZE 0x14
c5c77ba1 63
361ff841 64struct cfg_param_attr {
221371e5 65 struct cfg_param_val cfg_attr_info;
361ff841 66};
c5c77ba1 67
4372d3d3 68struct host_if_wpa_attr {
124968fc 69 u8 *key;
248080aa 70 const u8 *mac_addr;
0e74c009 71 u8 *seq;
dacc594d 72 u8 seq_len;
e2dfbac5 73 u8 index;
6acf2919 74 u8 key_len;
7b2ebb28 75 u8 mode;
4372d3d3 76};
c5c77ba1 77
c276c44a 78struct host_if_wep_attr {
e5538d34 79 u8 *key;
d520e355 80 u8 key_len;
259b3aa6 81 u8 index;
b5eaff12 82 u8 mode;
7fa252e7 83 enum AUTHTYPE auth_type;
c276c44a 84};
c5c77ba1 85
40cc2c90 86union host_if_key_attr {
2ed7a2fb 87 struct host_if_wep_attr wep;
e3501a4d 88 struct host_if_wpa_attr wpa;
610e3868 89 struct host_if_pmkid_attr pmkid;
40cc2c90 90};
c5c77ba1 91
c98387a5 92struct key_attr {
8e9f427a 93 enum KEY_TYPE type;
0d17e382 94 u8 action;
73b2e381 95 union host_if_key_attr attr;
c98387a5 96};
c5c77ba1 97
c476feb8 98struct scan_attr {
42568898 99 u8 src;
1e276c88 100 u8 type;
82eeb0ad 101 u8 *ch_freq_list;
f97bd9ca 102 u8 ch_list_len;
d6f19aa5 103 u8 *ies;
7b1f76cd 104 size_t ies_len;
ba1d1a69 105 wilc_scan_result pfScanResult;
c5c77ba1 106 void *pvUserArg;
607db447 107 struct hidden_network strHiddenNetwork;
c476feb8 108};
c5c77ba1 109
120ae593 110struct connect_attr {
63d03e47
GKH
111 u8 *pu8bssid;
112 u8 *pu8ssid;
c5c77ba1 113 size_t ssidLen;
63d03e47 114 u8 *pu8IEs;
c5c77ba1 115 size_t IEsLen;
63d03e47 116 u8 u8security;
b6ab85fe 117 wilc_connect_result pfConnectResult;
c5c77ba1 118 void *pvUserArg;
841dfc42 119 enum AUTHTYPE tenuAuth_type;
63d03e47 120 u8 u8channel;
c5c77ba1 121 void *pJoinParams;
120ae593 122};
c5c77ba1 123
f23a9eab 124struct rcvd_async_info {
63d03e47 125 u8 *pu8Buffer;
4e4467fd 126 u32 u32Length;
f23a9eab 127};
c5c77ba1 128
94bdfe42 129struct channel_attr {
63d03e47 130 u8 u8SetChan;
326b323d 131};
c5c77ba1 132
7f33fecd 133struct beacon_attr {
ae4dfa57
LK
134 u32 u32Interval;
135 u32 u32DTIMPeriod;
136 u32 u32HeadLen;
137 u8 *pu8Head;
138 u32 u32TailLen;
139 u8 *pu8Tail;
902362b1 140};
c5c77ba1 141
641210ac 142struct set_multicast {
72ed4dc7 143 bool bIsEnabled;
4e4467fd 144 u32 u32count;
641210ac 145};
c5c77ba1 146
b4e644e4 147struct del_all_sta {
63d03e47
GKH
148 u8 au8Sta_DelAllSta[MAX_NUM_STA][ETH_ALEN];
149 u8 u8Num_AssocSta;
b4e644e4 150};
c5c77ba1 151
fb93a1e1 152struct del_sta {
63d03e47 153 u8 au8MacAddr[ETH_ALEN];
fb93a1e1 154};
c5c77ba1 155
5a008f1c 156struct power_mgmt_param {
c5c77ba1 157
72ed4dc7 158 bool bIsEnabled;
4e4467fd 159 u32 u32Timeout;
5a008f1c 160};
c5c77ba1 161
15191eaf 162struct set_ip_addr {
63d03e47
GKH
163 u8 *au8IPAddr;
164 u8 idx;
15191eaf 165};
c5c77ba1 166
3d1eac04 167struct sta_inactive_t {
63d03e47 168 u8 mac[6];
3d1eac04 169};
ae4dfa57 170
dfc7663b 171union message_body {
4528bdb5 172 struct scan_attr scan_info;
3f501971 173 struct connect_attr con_info;
02d19460 174 struct rcvd_net_info net_info;
66add622 175 struct rcvd_async_info async_info;
18990bfe 176 struct key_attr key_info;
a2340c36 177 struct cfg_param_attr cfg_info;
ffd6dbc8 178 struct channel_attr channel_info;
a98491e5 179 struct beacon_attr beacon_info;
ca8f47f8 180 struct add_sta_param add_sta_info;
889c25be 181 struct del_sta del_sta_info;
4a930962 182 struct add_sta_param edit_sta_info;
49e1f81b 183 struct power_mgmt_param pwr_mgmt_info;
66bac7f2 184 struct sta_inactive_t mac_info;
fb2d65ed 185 struct set_ip_addr ip_info;
5e4377e6 186 struct drv_handler drv;
a079cf4d 187 struct set_multicast multicast_info;
00c4630e 188 struct op_mode mode;
15326e28 189 struct set_mac_addr set_mac_info;
a5848695 190 struct get_mac_addr get_mac_info;
c833b474 191 struct ba_session_info session_info;
070d365c 192 struct remain_ch remain_on_ch;
5c4008db 193 struct reg_frame reg_frame;
e60831e9 194 char *data;
b0c1e80e 195 struct del_all_sta del_all_sta_info;
dfc7663b 196};
c5c77ba1 197
3a8c41b5 198struct host_if_msg {
ae4dfa57
LK
199 u16 id;
200 union message_body body;
2482a79f 201 struct host_if_drv *drv;
3a8c41b5 202};
c5c77ba1 203
e0a12217 204struct join_bss_param {
c5c77ba1 205 BSSTYPE_T bss_type;
63d03e47 206 u8 dtim_period;
d85f5326
CL
207 u16 beacon_period;
208 u16 cap_info;
63d03e47 209 u8 au8bssid[6];
576917ad 210 char ssid[MAX_SSID_LEN];
63d03e47
GKH
211 u8 ssidLen;
212 u8 supp_rates[MAX_RATES_SUPPORTED + 1];
213 u8 ht_capable;
214 u8 wmm_cap;
215 u8 uapsd_cap;
72ed4dc7 216 bool rsn_found;
63d03e47
GKH
217 u8 rsn_grp_policy;
218 u8 mode_802_11i;
219 u8 rsn_pcip_policy[3];
220 u8 rsn_auth_policy[3];
221 u8 rsn_cap[2];
4e4467fd 222 u32 tsf;
63d03e47
GKH
223 u8 u8NoaEnbaled;
224 u8 u8OppEnable;
225 u8 u8CtWindow;
226 u8 u8Count;
227 u8 u8Index;
228 u8 au8Duration[4];
229 u8 au8Interval[4];
230 u8 au8StartTime[4];
e0a12217 231};
c5c77ba1 232
7696edf4 233enum scan_conn_timer {
c5c77ba1
JK
234 SCAN_TIMER = 0,
235 CONNECT_TIMER = 1,
236 SCAN_CONNECT_TIMER_FORCE_32BIT = 0xFFFFFFFF
7696edf4 237};
c5c77ba1 238
441dc609
LK
239static struct host_if_drv *wfidrv_list[NUM_CONCURRENT_IFC + 1];
240struct host_if_drv *terminated_handle;
241struct host_if_drv *gWFiDrvHandle;
72ed4dc7 242bool g_obtainingIP = false;
63d03e47 243u8 P2P_LISTEN_STATE;
1999bd52 244static struct task_struct *HostIFthreadHandler;
c5c77ba1 245static WILC_MsgQueueHandle gMsgQHostIF;
83383ea3 246static struct semaphore hSemHostIFthrdEnd;
c5c77ba1 247
83383ea3
AB
248struct semaphore hSemDeinitDrvHandle;
249static struct semaphore hWaitResponse;
250struct semaphore hSemHostIntDeinit;
da711eb6 251struct timer_list g_hPeriodicRSSI;
c5c77ba1
JK
252
253
254
63d03e47 255u8 gau8MulticastMacAddrList[WILC_MULTICAST_TABLE_SIZE][ETH_ALEN];
c5c77ba1 256
63d03e47 257static u8 gapu8RcvdAssocResp[MAX_ASSOC_RESP_FRAME_SIZE];
c5c77ba1 258
72ed4dc7 259bool gbScanWhileConnected = false;
c5c77ba1 260
ca356ada
CL
261static s8 gs8Rssi;
262static s8 gs8lnkspd;
63d03e47
GKH
263static u8 gu8Chnl;
264static u8 gs8SetIP[2][4];
265static u8 gs8GetIP[2][4];
4e4467fd 266static u32 gu32InactiveTime;
63d03e47 267static u8 gu8DelBcn;
4e4467fd 268static u32 gu32WidConnRstHack;
c5c77ba1 269
63d03e47
GKH
270u8 *gu8FlushedJoinReq;
271u8 *gu8FlushedInfoElemAsoc;
272u8 gu8Flushed11iMode;
273u8 gu8FlushedAuthType;
4e4467fd
CL
274u32 gu32FlushedJoinReqSize;
275u32 gu32FlushedInfoElemAsocSize;
441dc609 276struct host_if_drv *gu8FlushedJoinReqDrvHandler;
c5c77ba1
JK
277#define REAL_JOIN_REQ 0
278#define FLUSHED_JOIN_REQ 1
ae4dfa57 279#define FLUSHED_BYTE_POS 79
c5c77ba1 280
c5c77ba1 281static void *host_int_ParseJoinBssParam(tstrNetworkInfo *ptstrNetworkInfo);
c5c77ba1 282
4e4467fd 283extern void chip_sleep_manually(u32 u32SleepTime);
c5c77ba1
JK
284extern int linux_wlan_get_num_conn_ifcs(void);
285
441dc609 286static int add_handler_in_list(struct host_if_drv *handler)
d42ab083
JK
287{
288 int i;
289
290 for (i = 1; i < ARRAY_SIZE(wfidrv_list); i++) {
291 if (!wfidrv_list[i]) {
292 wfidrv_list[i] = handler;
293 return 0;
294 }
295 }
296
297 return -ENOBUFS;
298}
299
441dc609 300static int remove_handler_in_list(struct host_if_drv *handler)
d42ab083
JK
301{
302 int i;
303
304 for (i = 1; i < ARRAY_SIZE(wfidrv_list); i++) {
305 if (wfidrv_list[i] == handler) {
306 wfidrv_list[i] = NULL;
307 return 0;
308 }
309 }
310
311 return -EINVAL;
312}
313
441dc609 314static int get_id_from_handler(struct host_if_drv *handler)
d42ab083
JK
315{
316 int i;
317
318 if (!handler)
319 return 0;
320
321 for (i = 1; i < ARRAY_SIZE(wfidrv_list); i++) {
322 if (wfidrv_list[i] == handler)
323 return i;
324 }
325
326 return 0;
327}
328
441dc609 329static struct host_if_drv *get_handler_from_id(int id)
d42ab083 330{
6ae9ac0b 331 if (id <= 0 || id >= ARRAY_SIZE(wfidrv_list))
d42ab083
JK
332 return NULL;
333 return wfidrv_list[id];
334}
335
a4ab1ade 336static s32 Handle_SetChannel(struct host_if_drv *hif_drv,
94bdfe42 337 struct channel_attr *pstrHostIFSetChan)
c5c77ba1
JK
338{
339
e6e12661 340 s32 s32Error = 0;
e9e0c260 341 struct wid strWID;
c5c77ba1 342
daaf16ba 343 strWID.id = (u16)WID_CURRENT_CHANNEL;
416d8321 344 strWID.type = WID_CHAR;
900bb4a6 345 strWID.val = (char *)&(pstrHostIFSetChan->u8SetChan);
2fd3e443 346 strWID.size = sizeof(char);
c5c77ba1
JK
347
348 PRINT_D(HOSTINF_DBG, "Setting channel\n");
ae4dfa57 349
03362286 350 s32Error = send_config_pkt(SET_CFG, &strWID, 1,
a4ab1ade 351 get_id_from_handler(hif_drv));
c5c77ba1
JK
352 if (s32Error) {
353 PRINT_ER("Failed to set channel\n");
24db713f 354 return -EINVAL;
c5c77ba1
JK
355 }
356
357 return s32Error;
358}
ae4dfa57 359
a4ab1ade 360static s32 Handle_SetWfiDrvHandler(struct host_if_drv *hif_drv,
127f9d94 361 struct drv_handler *pstrHostIfSetDrvHandler)
c5c77ba1
JK
362{
363
e6e12661 364 s32 s32Error = 0;
e9e0c260 365 struct wid strWID;
c5c77ba1 366
daaf16ba 367 strWID.id = (u16)WID_SET_DRV_HANDLER;
416d8321 368 strWID.type = WID_INT;
900bb4a6 369 strWID.val = (s8 *)&(pstrHostIfSetDrvHandler->u32Address);
2fd3e443 370 strWID.size = sizeof(u32);
c5c77ba1 371
03362286 372 s32Error = send_config_pkt(SET_CFG, &strWID, 1,
cf32c3c4 373 pstrHostIfSetDrvHandler->u32Address);
c5c77ba1 374
a4ab1ade 375 if (!hif_drv)
83383ea3 376 up(&hSemDeinitDrvHandle);
c5c77ba1
JK
377
378
379 if (s32Error) {
380 PRINT_ER("Failed to set driver handler\n");
24db713f 381 return -EINVAL;
c5c77ba1
JK
382 }
383
384 return s32Error;
385}
386
a4ab1ade 387static s32 Handle_SetOperationMode(struct host_if_drv *hif_drv,
801bee52 388 struct op_mode *pstrHostIfSetOperationMode)
c5c77ba1
JK
389{
390
e6e12661 391 s32 s32Error = 0;
e9e0c260 392 struct wid strWID;
c5c77ba1 393
daaf16ba 394 strWID.id = (u16)WID_SET_OPERATION_MODE;
416d8321 395 strWID.type = WID_INT;
900bb4a6 396 strWID.val = (s8 *)&(pstrHostIfSetOperationMode->u32Mode);
2fd3e443 397 strWID.size = sizeof(u32);
c5c77ba1 398
03362286 399 s32Error = send_config_pkt(SET_CFG, &strWID, 1,
a4ab1ade 400 get_id_from_handler(hif_drv));
c5c77ba1
JK
401
402
c590b9a4 403 if ((pstrHostIfSetOperationMode->u32Mode) == IDLE_MODE)
83383ea3 404 up(&hSemDeinitDrvHandle);
c5c77ba1
JK
405
406
407 if (s32Error) {
408 PRINT_ER("Failed to set driver handler\n");
24db713f 409 return -EINVAL;
c5c77ba1
JK
410 }
411
412 return s32Error;
413}
414
a4ab1ade 415s32 Handle_set_IPAddress(struct host_if_drv *hif_drv, u8 *pu8IPAddr, u8 idx)
c5c77ba1
JK
416{
417
e6e12661 418 s32 s32Error = 0;
e9e0c260 419 struct wid strWID;
c5c77ba1 420 char firmwareIPAddress[4] = {0};
c5c77ba1
JK
421
422 if (pu8IPAddr[0] < 192)
423 pu8IPAddr[0] = 0;
424
b3a02832 425 PRINT_INFO(HOSTINF_DBG, "Indx = %d, Handling set IP = %pI4\n", idx, pu8IPAddr);
c5c77ba1 426
d00d2ba3 427 memcpy(gs8SetIP[idx], pu8IPAddr, IP_ALEN);
c5c77ba1 428
daaf16ba 429 strWID.id = (u16)WID_IP_ADDRESS;
416d8321 430 strWID.type = WID_STR;
900bb4a6 431 strWID.val = (u8 *)pu8IPAddr;
2fd3e443 432 strWID.size = IP_ALEN;
c5c77ba1 433
03362286 434 s32Error = send_config_pkt(SET_CFG, &strWID, 1,
a4ab1ade 435 get_id_from_handler(hif_drv));
c5c77ba1
JK
436
437
a4ab1ade 438 host_int_get_ipaddress(hif_drv, firmwareIPAddress, idx);
c5c77ba1
JK
439
440 if (s32Error) {
24db713f
LK
441 PRINT_ER("Failed to set IP address\n");
442 return -EINVAL;
c5c77ba1
JK
443 }
444
24db713f 445 PRINT_INFO(HOSTINF_DBG, "IP address set\n");
c5c77ba1
JK
446
447 return s32Error;
448}
449
a4ab1ade 450s32 Handle_get_IPAddress(struct host_if_drv *hif_drv, u8 *pu8IPAddr, u8 idx)
c5c77ba1
JK
451{
452
e6e12661 453 s32 s32Error = 0;
e9e0c260 454 struct wid strWID;
c5c77ba1 455
daaf16ba 456 strWID.id = (u16)WID_IP_ADDRESS;
416d8321 457 strWID.type = WID_STR;
900bb4a6 458 strWID.val = kmalloc(IP_ALEN, GFP_KERNEL);
2fd3e443 459 strWID.size = IP_ALEN;
c5c77ba1 460
03362286 461 s32Error = send_config_pkt(GET_CFG, &strWID, 1,
a4ab1ade 462 get_id_from_handler(hif_drv));
c5c77ba1 463
900bb4a6 464 PRINT_INFO(HOSTINF_DBG, "%pI4\n", strWID.val);
c5c77ba1 465
900bb4a6 466 memcpy(gs8GetIP[idx], strWID.val, IP_ALEN);
c5c77ba1 467
900bb4a6 468 kfree(strWID.val);
c5c77ba1 469
1a646e7e 470 if (memcmp(gs8GetIP[idx], gs8SetIP[idx], IP_ALEN) != 0)
a4ab1ade 471 host_int_setup_ipaddress(hif_drv, gs8SetIP[idx], idx);
c5c77ba1 472
e6e12661 473 if (s32Error != 0) {
c5c77ba1 474 PRINT_ER("Failed to get IP address\n");
24db713f 475 return -EINVAL;
c5c77ba1
JK
476 }
477
24db713f
LK
478 PRINT_INFO(HOSTINF_DBG, "IP address retrieved:: u8IfIdx = %d\n", idx);
479 PRINT_INFO(HOSTINF_DBG, "%pI4\n", gs8GetIP[idx]);
480 PRINT_INFO(HOSTINF_DBG, "\n");
c5c77ba1
JK
481
482 return s32Error;
483}
484
a4ab1ade 485static s32 Handle_SetMacAddress(struct host_if_drv *hif_drv,
b7611a87 486 struct set_mac_addr *pstrHostIfSetMacAddress)
c5c77ba1
JK
487{
488
e6e12661 489 s32 s32Error = 0;
e9e0c260 490 struct wid strWID;
f3052587 491 u8 *mac_buf = kmalloc(ETH_ALEN, GFP_KERNEL);
78c87591 492
c5c77ba1
JK
493 if (mac_buf == NULL) {
494 PRINT_ER("No buffer to send mac address\n");
e6e12661 495 return -EFAULT;
c5c77ba1 496 }
d00d2ba3 497 memcpy(mac_buf, pstrHostIfSetMacAddress->u8MacAddress, ETH_ALEN);
c5c77ba1 498
daaf16ba 499 strWID.id = (u16)WID_MAC_ADDR;
416d8321 500 strWID.type = WID_STR;
900bb4a6 501 strWID.val = mac_buf;
2fd3e443 502 strWID.size = ETH_ALEN;
900bb4a6 503 PRINT_D(GENERIC_DBG, "mac addr = :%pM\n", strWID.val);
ae4dfa57 504
03362286 505 s32Error = send_config_pkt(SET_CFG, &strWID, 1,
a4ab1ade 506 get_id_from_handler(hif_drv));
c5c77ba1
JK
507 if (s32Error) {
508 PRINT_ER("Failed to set mac address\n");
24db713f 509 s32Error = -EFAULT;
c5c77ba1
JK
510 }
511
49188af2 512 kfree(mac_buf);
c5c77ba1
JK
513 return s32Error;
514}
515
a4ab1ade 516static s32 Handle_GetMacAddress(struct host_if_drv *hif_drv,
fcd27c5f 517 struct get_mac_addr *pstrHostIfGetMacAddress)
c5c77ba1
JK
518{
519
e6e12661 520 s32 s32Error = 0;
e9e0c260 521 struct wid strWID;
c5c77ba1 522
daaf16ba 523 strWID.id = (u16)WID_MAC_ADDR;
416d8321 524 strWID.type = WID_STR;
900bb4a6 525 strWID.val = pstrHostIfGetMacAddress->u8MacAddress;
2fd3e443 526 strWID.size = ETH_ALEN;
c5c77ba1 527
03362286 528 s32Error = send_config_pkt(GET_CFG, &strWID, 1,
a4ab1ade 529 get_id_from_handler(hif_drv));
c5c77ba1
JK
530 if (s32Error) {
531 PRINT_ER("Failed to get mac address\n");
24db713f 532 s32Error = -EFAULT;
c5c77ba1 533 }
83383ea3 534 up(&hWaitResponse);
c5c77ba1
JK
535
536 return s32Error;
537}
538
a4ab1ade 539static s32 Handle_CfgParam(struct host_if_drv *hif_drv,
361ff841 540 struct cfg_param_attr *strHostIFCfgParamAttr)
c5c77ba1 541{
e6e12661 542 s32 s32Error = 0;
e9e0c260 543 struct wid strWIDList[32];
63d03e47 544 u8 u8WidCnt = 0;
c5c77ba1 545
a4ab1ade 546 down(&hif_drv->gtOsCfgValuesSem);
c5c77ba1
JK
547
548
549 PRINT_D(HOSTINF_DBG, "Setting CFG params\n");
550
87c05b28 551 if (strHostIFCfgParamAttr->cfg_attr_info.flag & BSS_TYPE) {
221371e5 552 if (strHostIFCfgParamAttr->cfg_attr_info.bss_type < 6) {
daaf16ba 553 strWIDList[u8WidCnt].id = WID_BSS_TYPE;
221371e5 554 strWIDList[u8WidCnt].val = (s8 *)&strHostIFCfgParamAttr->cfg_attr_info.bss_type;
416d8321 555 strWIDList[u8WidCnt].type = WID_CHAR;
2fd3e443 556 strWIDList[u8WidCnt].size = sizeof(char);
221371e5 557 hif_drv->strCfgValues.bss_type = (u8)strHostIFCfgParamAttr->cfg_attr_info.bss_type;
c5c77ba1 558 } else {
24db713f
LK
559 PRINT_ER("check value 6 over\n");
560 s32Error = -EINVAL;
561 goto ERRORHANDLER;
c5c77ba1
JK
562 }
563 u8WidCnt++;
564 }
87c05b28 565 if (strHostIFCfgParamAttr->cfg_attr_info.flag & AUTH_TYPE) {
221371e5 566 if ((strHostIFCfgParamAttr->cfg_attr_info.auth_type) == 1 || (strHostIFCfgParamAttr->cfg_attr_info.auth_type) == 2 || (strHostIFCfgParamAttr->cfg_attr_info.auth_type) == 5) {
daaf16ba 567 strWIDList[u8WidCnt].id = WID_AUTH_TYPE;
221371e5 568 strWIDList[u8WidCnt].val = (s8 *)&strHostIFCfgParamAttr->cfg_attr_info.auth_type;
416d8321 569 strWIDList[u8WidCnt].type = WID_CHAR;
2fd3e443 570 strWIDList[u8WidCnt].size = sizeof(char);
221371e5 571 hif_drv->strCfgValues.auth_type = (u8)strHostIFCfgParamAttr->cfg_attr_info.auth_type;
c5c77ba1 572 } else {
24db713f
LK
573 PRINT_ER("Impossible value \n");
574 s32Error = -EINVAL;
575 goto ERRORHANDLER;
c5c77ba1
JK
576 }
577 u8WidCnt++;
578 }
87c05b28 579 if (strHostIFCfgParamAttr->cfg_attr_info.flag & AUTHEN_TIMEOUT) {
221371e5 580 if (strHostIFCfgParamAttr->cfg_attr_info.auth_timeout > 0 && strHostIFCfgParamAttr->cfg_attr_info.auth_timeout < 65536) {
daaf16ba 581 strWIDList[u8WidCnt].id = WID_AUTH_TIMEOUT;
221371e5 582 strWIDList[u8WidCnt].val = (s8 *)&strHostIFCfgParamAttr->cfg_attr_info.auth_timeout;
416d8321 583 strWIDList[u8WidCnt].type = WID_SHORT;
2fd3e443 584 strWIDList[u8WidCnt].size = sizeof(u16);
221371e5 585 hif_drv->strCfgValues.auth_timeout = strHostIFCfgParamAttr->cfg_attr_info.auth_timeout;
c5c77ba1 586 } else {
24db713f
LK
587 PRINT_ER("Range(1 ~ 65535) over\n");
588 s32Error = -EINVAL;
589 goto ERRORHANDLER;
c5c77ba1
JK
590 }
591 u8WidCnt++;
592 }
87c05b28 593 if (strHostIFCfgParamAttr->cfg_attr_info.flag & POWER_MANAGEMENT) {
221371e5 594 if (strHostIFCfgParamAttr->cfg_attr_info.power_mgmt_mode < 5) {
daaf16ba 595 strWIDList[u8WidCnt].id = WID_POWER_MANAGEMENT;
221371e5 596 strWIDList[u8WidCnt].val = (s8 *)&strHostIFCfgParamAttr->cfg_attr_info.power_mgmt_mode;
416d8321 597 strWIDList[u8WidCnt].type = WID_CHAR;
2fd3e443 598 strWIDList[u8WidCnt].size = sizeof(char);
221371e5 599 hif_drv->strCfgValues.power_mgmt_mode = (u8)strHostIFCfgParamAttr->cfg_attr_info.power_mgmt_mode;
c5c77ba1 600 } else {
24db713f
LK
601 PRINT_ER("Invalide power mode\n");
602 s32Error = -EINVAL;
603 goto ERRORHANDLER;
c5c77ba1
JK
604 }
605 u8WidCnt++;
606 }
87c05b28 607 if (strHostIFCfgParamAttr->cfg_attr_info.flag & RETRY_SHORT) {
221371e5 608 if ((strHostIFCfgParamAttr->cfg_attr_info.short_retry_limit > 0) && (strHostIFCfgParamAttr->cfg_attr_info.short_retry_limit < 256)) {
daaf16ba 609 strWIDList[u8WidCnt].id = WID_SHORT_RETRY_LIMIT;
221371e5 610 strWIDList[u8WidCnt].val = (s8 *)&strHostIFCfgParamAttr->cfg_attr_info.short_retry_limit;
416d8321 611 strWIDList[u8WidCnt].type = WID_SHORT;
2fd3e443 612 strWIDList[u8WidCnt].size = sizeof(u16);
221371e5 613 hif_drv->strCfgValues.short_retry_limit = strHostIFCfgParamAttr->cfg_attr_info.short_retry_limit;
c5c77ba1 614 } else {
24db713f
LK
615 PRINT_ER("Range(1~256) over\n");
616 s32Error = -EINVAL;
617 goto ERRORHANDLER;
c5c77ba1
JK
618 }
619 u8WidCnt++;
620 }
87c05b28 621 if (strHostIFCfgParamAttr->cfg_attr_info.flag & RETRY_LONG) {
221371e5 622 if ((strHostIFCfgParamAttr->cfg_attr_info.long_retry_limit > 0) && (strHostIFCfgParamAttr->cfg_attr_info.long_retry_limit < 256)) {
daaf16ba 623 strWIDList[u8WidCnt].id = WID_LONG_RETRY_LIMIT;
221371e5 624 strWIDList[u8WidCnt].val = (s8 *)&strHostIFCfgParamAttr->cfg_attr_info.long_retry_limit;
c5c77ba1 625
416d8321 626 strWIDList[u8WidCnt].type = WID_SHORT;
2fd3e443 627 strWIDList[u8WidCnt].size = sizeof(u16);
221371e5 628 hif_drv->strCfgValues.long_retry_limit = strHostIFCfgParamAttr->cfg_attr_info.long_retry_limit;
c5c77ba1 629 } else {
24db713f
LK
630 PRINT_ER("Range(1~256) over\n");
631 s32Error = -EINVAL;
632 goto ERRORHANDLER;
c5c77ba1
JK
633 }
634 u8WidCnt++;
635 }
87c05b28 636 if (strHostIFCfgParamAttr->cfg_attr_info.flag & FRAG_THRESHOLD) {
c5c77ba1 637
221371e5 638 if (strHostIFCfgParamAttr->cfg_attr_info.frag_threshold > 255 && strHostIFCfgParamAttr->cfg_attr_info.frag_threshold < 7937) {
daaf16ba 639 strWIDList[u8WidCnt].id = WID_FRAG_THRESHOLD;
221371e5 640 strWIDList[u8WidCnt].val = (s8 *)&strHostIFCfgParamAttr->cfg_attr_info.frag_threshold;
416d8321 641 strWIDList[u8WidCnt].type = WID_SHORT;
2fd3e443 642 strWIDList[u8WidCnt].size = sizeof(u16);
221371e5 643 hif_drv->strCfgValues.frag_threshold = strHostIFCfgParamAttr->cfg_attr_info.frag_threshold;
c5c77ba1 644 } else {
24db713f
LK
645 PRINT_ER("Threshold Range fail\n");
646 s32Error = -EINVAL;
647 goto ERRORHANDLER;
c5c77ba1
JK
648 }
649 u8WidCnt++;
650 }
87c05b28 651 if (strHostIFCfgParamAttr->cfg_attr_info.flag & RTS_THRESHOLD) {
221371e5 652 if (strHostIFCfgParamAttr->cfg_attr_info.rts_threshold > 255 && strHostIFCfgParamAttr->cfg_attr_info.rts_threshold < 65536) {
daaf16ba 653 strWIDList[u8WidCnt].id = WID_RTS_THRESHOLD;
221371e5 654 strWIDList[u8WidCnt].val = (s8 *)&strHostIFCfgParamAttr->cfg_attr_info.rts_threshold;
416d8321 655 strWIDList[u8WidCnt].type = WID_SHORT;
2fd3e443 656 strWIDList[u8WidCnt].size = sizeof(u16);
221371e5 657 hif_drv->strCfgValues.rts_threshold = strHostIFCfgParamAttr->cfg_attr_info.rts_threshold;
c5c77ba1 658 } else {
24db713f
LK
659 PRINT_ER("Threshold Range fail\n");
660 s32Error = -EINVAL;
661 goto ERRORHANDLER;
c5c77ba1
JK
662 }
663 u8WidCnt++;
664 }
87c05b28 665 if (strHostIFCfgParamAttr->cfg_attr_info.flag & PREAMBLE) {
221371e5 666 if (strHostIFCfgParamAttr->cfg_attr_info.preamble_type < 3) {
daaf16ba 667 strWIDList[u8WidCnt].id = WID_PREAMBLE;
221371e5 668 strWIDList[u8WidCnt].val = (s8 *)&strHostIFCfgParamAttr->cfg_attr_info.preamble_type;
416d8321 669 strWIDList[u8WidCnt].type = WID_CHAR;
2fd3e443 670 strWIDList[u8WidCnt].size = sizeof(char);
221371e5 671 hif_drv->strCfgValues.preamble_type = strHostIFCfgParamAttr->cfg_attr_info.preamble_type;
c5c77ba1 672 } else {
24db713f
LK
673 PRINT_ER("Preamle Range(0~2) over\n");
674 s32Error = -EINVAL;
675 goto ERRORHANDLER;
c5c77ba1
JK
676 }
677 u8WidCnt++;
678 }
87c05b28 679 if (strHostIFCfgParamAttr->cfg_attr_info.flag & SHORT_SLOT_ALLOWED) {
221371e5 680 if (strHostIFCfgParamAttr->cfg_attr_info.short_slot_allowed < 2) {
daaf16ba 681 strWIDList[u8WidCnt].id = WID_SHORT_SLOT_ALLOWED;
221371e5 682 strWIDList[u8WidCnt].val = (s8 *)&strHostIFCfgParamAttr->cfg_attr_info.short_slot_allowed;
416d8321 683 strWIDList[u8WidCnt].type = WID_CHAR;
2fd3e443 684 strWIDList[u8WidCnt].size = sizeof(char);
221371e5 685 hif_drv->strCfgValues.short_slot_allowed = (u8)strHostIFCfgParamAttr->cfg_attr_info.short_slot_allowed;
c5c77ba1 686 } else {
24db713f
LK
687 PRINT_ER("Short slot(2) over\n");
688 s32Error = -EINVAL;
689 goto ERRORHANDLER;
c5c77ba1
JK
690 }
691 u8WidCnt++;
692 }
87c05b28 693 if (strHostIFCfgParamAttr->cfg_attr_info.flag & TXOP_PROT_DISABLE) {
221371e5 694 if (strHostIFCfgParamAttr->cfg_attr_info.txop_prot_disabled < 2) {
daaf16ba 695 strWIDList[u8WidCnt].id = WID_11N_TXOP_PROT_DISABLE;
221371e5 696 strWIDList[u8WidCnt].val = (s8 *)&strHostIFCfgParamAttr->cfg_attr_info.txop_prot_disabled;
416d8321 697 strWIDList[u8WidCnt].type = WID_CHAR;
2fd3e443 698 strWIDList[u8WidCnt].size = sizeof(char);
221371e5 699 hif_drv->strCfgValues.txop_prot_disabled = (u8)strHostIFCfgParamAttr->cfg_attr_info.txop_prot_disabled;
c5c77ba1 700 } else {
24db713f
LK
701 PRINT_ER("TXOP prot disable\n");
702 s32Error = -EINVAL;
703 goto ERRORHANDLER;
c5c77ba1
JK
704 }
705 u8WidCnt++;
706 }
87c05b28 707 if (strHostIFCfgParamAttr->cfg_attr_info.flag & BEACON_INTERVAL) {
221371e5 708 if (strHostIFCfgParamAttr->cfg_attr_info.beacon_interval > 0 && strHostIFCfgParamAttr->cfg_attr_info.beacon_interval < 65536) {
daaf16ba 709 strWIDList[u8WidCnt].id = WID_BEACON_INTERVAL;
221371e5 710 strWIDList[u8WidCnt].val = (s8 *)&strHostIFCfgParamAttr->cfg_attr_info.beacon_interval;
416d8321 711 strWIDList[u8WidCnt].type = WID_SHORT;
2fd3e443 712 strWIDList[u8WidCnt].size = sizeof(u16);
221371e5 713 hif_drv->strCfgValues.beacon_interval = strHostIFCfgParamAttr->cfg_attr_info.beacon_interval;
c5c77ba1 714 } else {
24db713f
LK
715 PRINT_ER("Beacon interval(1~65535) fail\n");
716 s32Error = -EINVAL;
717 goto ERRORHANDLER;
c5c77ba1
JK
718 }
719 u8WidCnt++;
720 }
87c05b28 721 if (strHostIFCfgParamAttr->cfg_attr_info.flag & DTIM_PERIOD) {
221371e5 722 if (strHostIFCfgParamAttr->cfg_attr_info.dtim_period > 0 && strHostIFCfgParamAttr->cfg_attr_info.dtim_period < 256) {
daaf16ba 723 strWIDList[u8WidCnt].id = WID_DTIM_PERIOD;
221371e5 724 strWIDList[u8WidCnt].val = (s8 *)&strHostIFCfgParamAttr->cfg_attr_info.dtim_period;
416d8321 725 strWIDList[u8WidCnt].type = WID_CHAR;
2fd3e443 726 strWIDList[u8WidCnt].size = sizeof(char);
221371e5 727 hif_drv->strCfgValues.dtim_period = strHostIFCfgParamAttr->cfg_attr_info.dtim_period;
c5c77ba1 728 } else {
24db713f
LK
729 PRINT_ER("DTIM range(1~255) fail\n");
730 s32Error = -EINVAL;
731 goto ERRORHANDLER;
c5c77ba1
JK
732 }
733 u8WidCnt++;
734 }
87c05b28 735 if (strHostIFCfgParamAttr->cfg_attr_info.flag & SITE_SURVEY) {
221371e5 736 if (strHostIFCfgParamAttr->cfg_attr_info.site_survey_enabled < 3) {
daaf16ba 737 strWIDList[u8WidCnt].id = WID_SITE_SURVEY;
221371e5 738 strWIDList[u8WidCnt].val = (s8 *)&strHostIFCfgParamAttr->cfg_attr_info.site_survey_enabled;
416d8321 739 strWIDList[u8WidCnt].type = WID_CHAR;
2fd3e443 740 strWIDList[u8WidCnt].size = sizeof(char);
221371e5 741 hif_drv->strCfgValues.site_survey_enabled = (u8)strHostIFCfgParamAttr->cfg_attr_info.site_survey_enabled;
c5c77ba1 742 } else {
24db713f
LK
743 PRINT_ER("Site survey disable\n");
744 s32Error = -EINVAL;
745 goto ERRORHANDLER;
c5c77ba1
JK
746 }
747 u8WidCnt++;
748 }
87c05b28 749 if (strHostIFCfgParamAttr->cfg_attr_info.flag & SITE_SURVEY_SCAN_TIME) {
221371e5 750 if (strHostIFCfgParamAttr->cfg_attr_info.site_survey_scan_time > 0 && strHostIFCfgParamAttr->cfg_attr_info.site_survey_scan_time < 65536) {
daaf16ba 751 strWIDList[u8WidCnt].id = WID_SITE_SURVEY_SCAN_TIME;
221371e5 752 strWIDList[u8WidCnt].val = (s8 *)&strHostIFCfgParamAttr->cfg_attr_info.site_survey_scan_time;
416d8321 753 strWIDList[u8WidCnt].type = WID_SHORT;
2fd3e443 754 strWIDList[u8WidCnt].size = sizeof(u16);
221371e5 755 hif_drv->strCfgValues.site_survey_scan_time = strHostIFCfgParamAttr->cfg_attr_info.site_survey_scan_time;
c5c77ba1 756 } else {
24db713f
LK
757 PRINT_ER("Site survey scan time(1~65535) over\n");
758 s32Error = -EINVAL;
759 goto ERRORHANDLER;
c5c77ba1
JK
760 }
761 u8WidCnt++;
762 }
87c05b28 763 if (strHostIFCfgParamAttr->cfg_attr_info.flag & ACTIVE_SCANTIME) {
221371e5 764 if (strHostIFCfgParamAttr->cfg_attr_info.active_scan_time > 0 && strHostIFCfgParamAttr->cfg_attr_info.active_scan_time < 65536) {
daaf16ba 765 strWIDList[u8WidCnt].id = WID_ACTIVE_SCAN_TIME;
221371e5 766 strWIDList[u8WidCnt].val = (s8 *)&strHostIFCfgParamAttr->cfg_attr_info.active_scan_time;
416d8321 767 strWIDList[u8WidCnt].type = WID_SHORT;
2fd3e443 768 strWIDList[u8WidCnt].size = sizeof(u16);
221371e5 769 hif_drv->strCfgValues.active_scan_time = strHostIFCfgParamAttr->cfg_attr_info.active_scan_time;
c5c77ba1 770 } else {
24db713f
LK
771 PRINT_ER("Active scan time(1~65535) over\n");
772 s32Error = -EINVAL;
773 goto ERRORHANDLER;
c5c77ba1
JK
774 }
775 u8WidCnt++;
776 }
87c05b28 777 if (strHostIFCfgParamAttr->cfg_attr_info.flag & PASSIVE_SCANTIME) {
221371e5 778 if (strHostIFCfgParamAttr->cfg_attr_info.passive_scan_time > 0 && strHostIFCfgParamAttr->cfg_attr_info.passive_scan_time < 65536) {
daaf16ba 779 strWIDList[u8WidCnt].id = WID_PASSIVE_SCAN_TIME;
221371e5 780 strWIDList[u8WidCnt].val = (s8 *)&strHostIFCfgParamAttr->cfg_attr_info.passive_scan_time;
416d8321 781 strWIDList[u8WidCnt].type = WID_SHORT;
2fd3e443 782 strWIDList[u8WidCnt].size = sizeof(u16);
221371e5 783 hif_drv->strCfgValues.passive_scan_time = strHostIFCfgParamAttr->cfg_attr_info.passive_scan_time;
c5c77ba1 784 } else {
24db713f
LK
785 PRINT_ER("Passive scan time(1~65535) over\n");
786 s32Error = -EINVAL;
787 goto ERRORHANDLER;
c5c77ba1
JK
788 }
789 u8WidCnt++;
790 }
87c05b28 791 if (strHostIFCfgParamAttr->cfg_attr_info.flag & CURRENT_TX_RATE) {
221371e5 792 enum CURRENT_TXRATE curr_tx_rate = strHostIFCfgParamAttr->cfg_attr_info.curr_tx_rate;
c5c77ba1
JK
793 if (curr_tx_rate == AUTORATE || curr_tx_rate == MBPS_1
794 || curr_tx_rate == MBPS_2 || curr_tx_rate == MBPS_5_5
795 || curr_tx_rate == MBPS_11 || curr_tx_rate == MBPS_6
796 || curr_tx_rate == MBPS_9 || curr_tx_rate == MBPS_12
797 || curr_tx_rate == MBPS_18 || curr_tx_rate == MBPS_24
798 || curr_tx_rate == MBPS_36 || curr_tx_rate == MBPS_48 || curr_tx_rate == MBPS_54) {
daaf16ba 799 strWIDList[u8WidCnt].id = WID_CURRENT_TX_RATE;
900bb4a6 800 strWIDList[u8WidCnt].val = (s8 *)&curr_tx_rate;
416d8321 801 strWIDList[u8WidCnt].type = WID_SHORT;
2fd3e443 802 strWIDList[u8WidCnt].size = sizeof(u16);
a4ab1ade 803 hif_drv->strCfgValues.curr_tx_rate = (u8)curr_tx_rate;
c5c77ba1 804 } else {
24db713f
LK
805 PRINT_ER("out of TX rate\n");
806 s32Error = -EINVAL;
807 goto ERRORHANDLER;
c5c77ba1
JK
808 }
809 u8WidCnt++;
810 }
03362286 811 s32Error = send_config_pkt(SET_CFG, strWIDList, u8WidCnt,
a4ab1ade 812 get_id_from_handler(hif_drv));
c5c77ba1 813
2b9d5b48 814 if (s32Error)
c5c77ba1
JK
815 PRINT_ER("Error in setting CFG params\n");
816
24db713f 817ERRORHANDLER:
a4ab1ade 818 up(&hif_drv->gtOsCfgValuesSem);
c5c77ba1
JK
819 return s32Error;
820}
821
fb4ec9ca 822static s32 Handle_wait_msg_q_empty(void)
c5c77ba1 823{
c5c77ba1 824 g_wilc_initialized = 0;
83383ea3 825 up(&hWaitResponse);
b68d820b 826 return 0;
c5c77ba1
JK
827}
828
a4ab1ade 829static s32 Handle_Scan(struct host_if_drv *hif_drv,
c476feb8 830 struct scan_attr *pstrHostIFscanAttr)
c5c77ba1 831{
e6e12661 832 s32 s32Error = 0;
e9e0c260 833 struct wid strWIDList[5];
4e4467fd
CL
834 u32 u32WidsCount = 0;
835 u32 i;
63d03e47
GKH
836 u8 *pu8Buffer;
837 u8 valuesize = 0;
838 u8 *pu8HdnNtwrksWidVal = NULL;
c5c77ba1
JK
839
840 PRINT_D(HOSTINF_DBG, "Setting SCAN params\n");
a4ab1ade 841 PRINT_D(HOSTINF_DBG, "Scanning: In [%d] state\n", hif_drv->enuHostIFstate);
c5c77ba1 842
a4ab1ade
TC
843 hif_drv->strWILC_UsrScanReq.pfUserScanResult = pstrHostIFscanAttr->pfScanResult;
844 hif_drv->strWILC_UsrScanReq.u32UserScanPvoid = pstrHostIFscanAttr->pvUserArg;
c5c77ba1 845
a4ab1ade 846 if ((hif_drv->enuHostIFstate >= HOST_IF_SCANNING) && (hif_drv->enuHostIFstate < HOST_IF_CONNECTED)) {
a4ab1ade 847 PRINT_D(GENERIC_DBG, "Don't scan we are already in [%d] state\n", hif_drv->enuHostIFstate);
24db713f
LK
848 PRINT_ER("Already scan\n");
849 s32Error = -EBUSY;
850 goto ERRORHANDLER;
c5c77ba1
JK
851 }
852
c5c77ba1
JK
853 if (g_obtainingIP || connecting) {
854 PRINT_D(GENERIC_DBG, "[handle_scan]: Don't do obss scan until IP adresss is obtained\n");
24db713f
LK
855 PRINT_ER("Don't do obss scan\n");
856 s32Error = -EBUSY;
857 goto ERRORHANDLER;
c5c77ba1 858 }
c5c77ba1
JK
859
860 PRINT_D(HOSTINF_DBG, "Setting SCAN params\n");
861
862
a4ab1ade 863 hif_drv->strWILC_UsrScanReq.u32RcvdChCount = 0;
c5c77ba1 864
daaf16ba 865 strWIDList[u32WidsCount].id = (u16)WID_SSID_PROBE_REQ;
416d8321 866 strWIDList[u32WidsCount].type = WID_STR;
c5c77ba1 867
2b9d5b48 868 for (i = 0; i < pstrHostIFscanAttr->strHiddenNetwork.u8ssidnum; i++)
c5c77ba1 869 valuesize += ((pstrHostIFscanAttr->strHiddenNetwork.pstrHiddenNetworkInfo[i].u8ssidlen) + 1);
f3052587 870 pu8HdnNtwrksWidVal = kmalloc(valuesize + 1, GFP_KERNEL);
900bb4a6
LK
871 strWIDList[u32WidsCount].val = pu8HdnNtwrksWidVal;
872 if (strWIDList[u32WidsCount].val != NULL) {
873 pu8Buffer = strWIDList[u32WidsCount].val;
c5c77ba1
JK
874
875 *pu8Buffer++ = pstrHostIFscanAttr->strHiddenNetwork.u8ssidnum;
876
877 PRINT_D(HOSTINF_DBG, "In Handle_ProbeRequest number of ssid %d\n", pstrHostIFscanAttr->strHiddenNetwork.u8ssidnum);
878
879 for (i = 0; i < pstrHostIFscanAttr->strHiddenNetwork.u8ssidnum; i++) {
880 *pu8Buffer++ = pstrHostIFscanAttr->strHiddenNetwork.pstrHiddenNetworkInfo[i].u8ssidlen;
d00d2ba3 881 memcpy(pu8Buffer, pstrHostIFscanAttr->strHiddenNetwork.pstrHiddenNetworkInfo[i].pu8ssid, pstrHostIFscanAttr->strHiddenNetwork.pstrHiddenNetworkInfo[i].u8ssidlen);
c5c77ba1
JK
882 pu8Buffer += pstrHostIFscanAttr->strHiddenNetwork.pstrHiddenNetworkInfo[i].u8ssidlen;
883 }
884
885
886
2fd3e443 887 strWIDList[u32WidsCount].size = (s32)(valuesize + 1);
c5c77ba1
JK
888 u32WidsCount++;
889 }
890
c5c77ba1 891 {
daaf16ba 892 strWIDList[u32WidsCount].id = WID_INFO_ELEMENT_PROBE;
416d8321 893 strWIDList[u32WidsCount].type = WID_BIN_DATA;
d6f19aa5 894 strWIDList[u32WidsCount].val = pstrHostIFscanAttr->ies;
7b1f76cd 895 strWIDList[u32WidsCount].size = pstrHostIFscanAttr->ies_len;
c5c77ba1
JK
896 u32WidsCount++;
897 }
898
daaf16ba 899 strWIDList[u32WidsCount].id = WID_SCAN_TYPE;
416d8321 900 strWIDList[u32WidsCount].type = WID_CHAR;
2fd3e443 901 strWIDList[u32WidsCount].size = sizeof(char);
1e276c88 902 strWIDList[u32WidsCount].val = (s8 *)(&(pstrHostIFscanAttr->type));
c5c77ba1
JK
903 u32WidsCount++;
904
daaf16ba 905 strWIDList[u32WidsCount].id = WID_SCAN_CHANNEL_LIST;
416d8321 906 strWIDList[u32WidsCount].type = WID_BIN_DATA;
c5c77ba1 907
f97bd9ca 908 if (pstrHostIFscanAttr->ch_freq_list != NULL && pstrHostIFscanAttr->ch_list_len > 0) {
c5c77ba1
JK
909 int i;
910
f97bd9ca 911 for (i = 0; i < pstrHostIFscanAttr->ch_list_len; i++) {
82eeb0ad
LK
912 if (pstrHostIFscanAttr->ch_freq_list[i] > 0)
913 pstrHostIFscanAttr->ch_freq_list[i] = pstrHostIFscanAttr->ch_freq_list[i] - 1;
c5c77ba1
JK
914 }
915 }
916
82eeb0ad 917 strWIDList[u32WidsCount].val = pstrHostIFscanAttr->ch_freq_list;
f97bd9ca 918 strWIDList[u32WidsCount].size = pstrHostIFscanAttr->ch_list_len;
c5c77ba1
JK
919 u32WidsCount++;
920
daaf16ba 921 strWIDList[u32WidsCount].id = WID_START_SCAN_REQ;
416d8321 922 strWIDList[u32WidsCount].type = WID_CHAR;
2fd3e443 923 strWIDList[u32WidsCount].size = sizeof(char);
42568898 924 strWIDList[u32WidsCount].val = (s8 *)(&(pstrHostIFscanAttr->src));
c5c77ba1
JK
925 u32WidsCount++;
926
a4ab1ade 927 if (hif_drv->enuHostIFstate == HOST_IF_CONNECTED)
72ed4dc7 928 gbScanWhileConnected = true;
a4ab1ade 929 else if (hif_drv->enuHostIFstate == HOST_IF_IDLE)
72ed4dc7 930 gbScanWhileConnected = false;
c5c77ba1 931
03362286 932 s32Error = send_config_pkt(SET_CFG, strWIDList, u32WidsCount,
a4ab1ade 933 get_id_from_handler(hif_drv));
c5c77ba1 934
24db713f 935 if (s32Error)
c5c77ba1 936 PRINT_ER("Failed to send scan paramters config packet\n");
24db713f 937 else
c5c77ba1 938 PRINT_D(HOSTINF_DBG, "Successfully sent SCAN params config packet\n");
c5c77ba1 939
24db713f
LK
940ERRORHANDLER:
941 if (s32Error) {
a4ab1ade 942 del_timer(&hif_drv->hScanTimer);
a4ab1ade 943 Handle_ScanDone(hif_drv, SCAN_EVENT_ABORTED);
c5c77ba1
JK
944 }
945
82eeb0ad
LK
946 if (pstrHostIFscanAttr->ch_freq_list != NULL) {
947 kfree(pstrHostIFscanAttr->ch_freq_list);
948 pstrHostIFscanAttr->ch_freq_list = NULL;
c5c77ba1
JK
949 }
950
d6f19aa5
LK
951 if (pstrHostIFscanAttr->ies != NULL) {
952 kfree(pstrHostIFscanAttr->ies);
953 pstrHostIFscanAttr->ies = NULL;
c5c77ba1
JK
954 }
955 if (pstrHostIFscanAttr->strHiddenNetwork.pstrHiddenNetworkInfo != NULL) {
49188af2 956 kfree(pstrHostIFscanAttr->strHiddenNetwork.pstrHiddenNetworkInfo);
c5c77ba1
JK
957 pstrHostIFscanAttr->strHiddenNetwork.pstrHiddenNetworkInfo = NULL;
958 }
959
2b9d5b48 960 if (pu8HdnNtwrksWidVal != NULL)
49188af2 961 kfree(pu8HdnNtwrksWidVal);
c5c77ba1
JK
962
963 return s32Error;
964}
965
a4ab1ade
TC
966static s32 Handle_ScanDone(struct host_if_drv *hif_drv,
967 enum scan_event enuEvent)
c5c77ba1 968{
e6e12661 969 s32 s32Error = 0;
63d03e47 970 u8 u8abort_running_scan;
e9e0c260 971 struct wid strWID;
c5c77ba1
JK
972
973
974 PRINT_D(HOSTINF_DBG, "in Handle_ScanDone()\n");
975
c5c77ba1
JK
976 if (enuEvent == SCAN_EVENT_ABORTED) {
977 PRINT_D(GENERIC_DBG, "Abort running scan\n");
978 u8abort_running_scan = 1;
daaf16ba 979 strWID.id = (u16)WID_ABORT_RUNNING_SCAN;
416d8321 980 strWID.type = WID_CHAR;
900bb4a6 981 strWID.val = (s8 *)&u8abort_running_scan;
2fd3e443 982 strWID.size = sizeof(char);
c5c77ba1 983
03362286 984 s32Error = send_config_pkt(SET_CFG, &strWID, 1,
a4ab1ade 985 get_id_from_handler(hif_drv));
24db713f 986 if (s32Error) {
c5c77ba1 987 PRINT_ER("Failed to set abort running scan\n");
24db713f 988 s32Error = -EFAULT;
c5c77ba1
JK
989 }
990 }
991
a4ab1ade 992 if (!hif_drv) {
c5c77ba1
JK
993 PRINT_ER("Driver handler is NULL\n");
994 return s32Error;
995 }
996
a4ab1ade
TC
997 if (hif_drv->strWILC_UsrScanReq.pfUserScanResult) {
998 hif_drv->strWILC_UsrScanReq.pfUserScanResult(enuEvent, NULL,
999 hif_drv->strWILC_UsrScanReq.u32UserScanPvoid, NULL);
a4ab1ade 1000 hif_drv->strWILC_UsrScanReq.pfUserScanResult = NULL;
c5c77ba1
JK
1001 }
1002
1003 return s32Error;
1004}
1005
63d03e47 1006u8 u8ConnectedSSID[6] = {0};
a4ab1ade 1007static s32 Handle_Connect(struct host_if_drv *hif_drv,
120ae593 1008 struct connect_attr *pstrHostIFconnectAttr)
c5c77ba1 1009{
e6e12661 1010 s32 s32Error = 0;
e9e0c260 1011 struct wid strWIDList[8];
4e4467fd 1012 u32 u32WidsCount = 0, dummyval = 0;
63d03e47 1013 u8 *pu8CurrByte = NULL;
e0a12217 1014 struct join_bss_param *ptstrJoinBssParam;
c5c77ba1
JK
1015
1016 PRINT_D(GENERIC_DBG, "Handling connect request\n");
1017
1a646e7e 1018 if (memcmp(pstrHostIFconnectAttr->pu8bssid, u8ConnectedSSID, ETH_ALEN) == 0) {
c5c77ba1 1019
e6e12661 1020 s32Error = 0;
c5c77ba1
JK
1021 PRINT_ER("Trying to connect to an already connected AP, Discard connect request\n");
1022 return s32Error;
1023 }
1024
1025 PRINT_INFO(HOSTINF_DBG, "Saving connection parameters in global structure\n");
1026
e0a12217 1027 ptstrJoinBssParam = (struct join_bss_param *)pstrHostIFconnectAttr->pJoinParams;
c5c77ba1
JK
1028 if (ptstrJoinBssParam == NULL) {
1029 PRINT_ER("Required BSSID not found\n");
24db713f
LK
1030 s32Error = -ENOENT;
1031 goto ERRORHANDLER;
c5c77ba1 1032 }
c5c77ba1 1033
c5c77ba1 1034 if (pstrHostIFconnectAttr->pu8bssid != NULL) {
a4ab1ade
TC
1035 hif_drv->strWILC_UsrConnReq.pu8bssid = kmalloc(6, GFP_KERNEL);
1036 memcpy(hif_drv->strWILC_UsrConnReq.pu8bssid, pstrHostIFconnectAttr->pu8bssid, 6);
c5c77ba1
JK
1037 }
1038
a4ab1ade 1039 hif_drv->strWILC_UsrConnReq.ssidLen = pstrHostIFconnectAttr->ssidLen;
c5c77ba1 1040 if (pstrHostIFconnectAttr->pu8ssid != NULL) {
a4ab1ade
TC
1041 hif_drv->strWILC_UsrConnReq.pu8ssid = kmalloc(pstrHostIFconnectAttr->ssidLen + 1, GFP_KERNEL);
1042 memcpy(hif_drv->strWILC_UsrConnReq.pu8ssid, pstrHostIFconnectAttr->pu8ssid,
c5c77ba1 1043 pstrHostIFconnectAttr->ssidLen);
a4ab1ade 1044 hif_drv->strWILC_UsrConnReq.pu8ssid[pstrHostIFconnectAttr->ssidLen] = '\0';
c5c77ba1
JK
1045 }
1046
a4ab1ade 1047 hif_drv->strWILC_UsrConnReq.ConnReqIEsLen = pstrHostIFconnectAttr->IEsLen;
c5c77ba1 1048 if (pstrHostIFconnectAttr->pu8IEs != NULL) {
a4ab1ade
TC
1049 hif_drv->strWILC_UsrConnReq.pu8ConnReqIEs = kmalloc(pstrHostIFconnectAttr->IEsLen, GFP_KERNEL);
1050 memcpy(hif_drv->strWILC_UsrConnReq.pu8ConnReqIEs, pstrHostIFconnectAttr->pu8IEs,
c5c77ba1
JK
1051 pstrHostIFconnectAttr->IEsLen);
1052 }
1053
a4ab1ade
TC
1054 hif_drv->strWILC_UsrConnReq.u8security = pstrHostIFconnectAttr->u8security;
1055 hif_drv->strWILC_UsrConnReq.tenuAuth_type = pstrHostIFconnectAttr->tenuAuth_type;
1056 hif_drv->strWILC_UsrConnReq.pfUserConnectResult = pstrHostIFconnectAttr->pfConnectResult;
1057 hif_drv->strWILC_UsrConnReq.u32UserConnectPvoid = pstrHostIFconnectAttr->pvUserArg;
c5c77ba1 1058
daaf16ba 1059 strWIDList[u32WidsCount].id = WID_SUCCESS_FRAME_COUNT;
416d8321 1060 strWIDList[u32WidsCount].type = WID_INT;
2fd3e443 1061 strWIDList[u32WidsCount].size = sizeof(u32);
900bb4a6 1062 strWIDList[u32WidsCount].val = (s8 *)(&(dummyval));
c5c77ba1
JK
1063 u32WidsCount++;
1064
daaf16ba 1065 strWIDList[u32WidsCount].id = WID_RECEIVED_FRAGMENT_COUNT;
416d8321 1066 strWIDList[u32WidsCount].type = WID_INT;
2fd3e443 1067 strWIDList[u32WidsCount].size = sizeof(u32);
900bb4a6 1068 strWIDList[u32WidsCount].val = (s8 *)(&(dummyval));
c5c77ba1
JK
1069 u32WidsCount++;
1070
daaf16ba 1071 strWIDList[u32WidsCount].id = WID_FAILED_COUNT;
416d8321 1072 strWIDList[u32WidsCount].type = WID_INT;
2fd3e443 1073 strWIDList[u32WidsCount].size = sizeof(u32);
900bb4a6 1074 strWIDList[u32WidsCount].val = (s8 *)(&(dummyval));
c5c77ba1
JK
1075 u32WidsCount++;
1076
c5c77ba1 1077 {
daaf16ba 1078 strWIDList[u32WidsCount].id = WID_INFO_ELEMENT_ASSOCIATE;
416d8321 1079 strWIDList[u32WidsCount].type = WID_BIN_DATA;
a4ab1ade
TC
1080 strWIDList[u32WidsCount].val = hif_drv->strWILC_UsrConnReq.pu8ConnReqIEs;
1081 strWIDList[u32WidsCount].size = hif_drv->strWILC_UsrConnReq.ConnReqIEsLen;
c5c77ba1
JK
1082 u32WidsCount++;
1083
1a646e7e 1084 if (memcmp("DIRECT-", pstrHostIFconnectAttr->pu8ssid, 7)) {
c5c77ba1 1085
a4ab1ade 1086 gu32FlushedInfoElemAsocSize = hif_drv->strWILC_UsrConnReq.ConnReqIEsLen;
f3052587 1087 gu8FlushedInfoElemAsoc = kmalloc(gu32FlushedInfoElemAsocSize, GFP_KERNEL);
a4ab1ade 1088 memcpy(gu8FlushedInfoElemAsoc, hif_drv->strWILC_UsrConnReq.pu8ConnReqIEs,
c5c77ba1
JK
1089 gu32FlushedInfoElemAsocSize);
1090 }
1091 }
daaf16ba 1092 strWIDList[u32WidsCount].id = (u16)WID_11I_MODE;
416d8321 1093 strWIDList[u32WidsCount].type = WID_CHAR;
2fd3e443 1094 strWIDList[u32WidsCount].size = sizeof(char);
a4ab1ade 1095 strWIDList[u32WidsCount].val = (s8 *)(&(hif_drv->strWILC_UsrConnReq.u8security));
c5c77ba1
JK
1096 u32WidsCount++;
1097
1a646e7e 1098 if (memcmp("DIRECT-", pstrHostIFconnectAttr->pu8ssid, 7))
a4ab1ade 1099 gu8Flushed11iMode = hif_drv->strWILC_UsrConnReq.u8security;
c5c77ba1 1100
a4ab1ade 1101 PRINT_INFO(HOSTINF_DBG, "Encrypt Mode = %x\n", hif_drv->strWILC_UsrConnReq.u8security);
c5c77ba1
JK
1102
1103
daaf16ba 1104 strWIDList[u32WidsCount].id = (u16)WID_AUTH_TYPE;
416d8321 1105 strWIDList[u32WidsCount].type = WID_CHAR;
2fd3e443 1106 strWIDList[u32WidsCount].size = sizeof(char);
a4ab1ade 1107 strWIDList[u32WidsCount].val = (s8 *)(&hif_drv->strWILC_UsrConnReq.tenuAuth_type);
c5c77ba1
JK
1108 u32WidsCount++;
1109
1a646e7e 1110 if (memcmp("DIRECT-", pstrHostIFconnectAttr->pu8ssid, 7))
a4ab1ade 1111 gu8FlushedAuthType = (u8)hif_drv->strWILC_UsrConnReq.tenuAuth_type;
c5c77ba1 1112
a4ab1ade 1113 PRINT_INFO(HOSTINF_DBG, "Authentication Type = %x\n", hif_drv->strWILC_UsrConnReq.tenuAuth_type);
c5c77ba1 1114 PRINT_D(HOSTINF_DBG, "Connecting to network of SSID %s on channel %d\n",
a4ab1ade 1115 hif_drv->strWILC_UsrConnReq.pu8ssid, pstrHostIFconnectAttr->u8channel);
c5c77ba1 1116
daaf16ba 1117 strWIDList[u32WidsCount].id = (u16)WID_JOIN_REQ_EXTENDED;
416d8321 1118 strWIDList[u32WidsCount].type = WID_STR;
ae4dfa57 1119 strWIDList[u32WidsCount].size = 112;
900bb4a6 1120 strWIDList[u32WidsCount].val = kmalloc(strWIDList[u32WidsCount].size, GFP_KERNEL);
c5c77ba1 1121
1a646e7e 1122 if (memcmp("DIRECT-", pstrHostIFconnectAttr->pu8ssid, 7)) {
2fd3e443 1123 gu32FlushedJoinReqSize = strWIDList[u32WidsCount].size;
f3052587 1124 gu8FlushedJoinReq = kmalloc(gu32FlushedJoinReqSize, GFP_KERNEL);
c5c77ba1 1125 }
900bb4a6 1126 if (strWIDList[u32WidsCount].val == NULL) {
24db713f
LK
1127 s32Error = -EFAULT;
1128 goto ERRORHANDLER;
1129 }
c5c77ba1 1130
900bb4a6 1131 pu8CurrByte = strWIDList[u32WidsCount].val;
c5c77ba1
JK
1132
1133
1134 if (pstrHostIFconnectAttr->pu8ssid != NULL) {
d00d2ba3 1135 memcpy(pu8CurrByte, pstrHostIFconnectAttr->pu8ssid, pstrHostIFconnectAttr->ssidLen);
c5c77ba1
JK
1136 pu8CurrByte[pstrHostIFconnectAttr->ssidLen] = '\0';
1137 }
1138 pu8CurrByte += MAX_SSID_LEN;
c5c77ba1 1139 *(pu8CurrByte++) = INFRASTRUCTURE;
ae4dfa57 1140
c5c77ba1
JK
1141 if ((pstrHostIFconnectAttr->u8channel >= 1) && (pstrHostIFconnectAttr->u8channel <= 14)) {
1142 *(pu8CurrByte++) = pstrHostIFconnectAttr->u8channel;
1143 } else {
1144 PRINT_ER("Channel out of range\n");
1145 *(pu8CurrByte++) = 0xFF;
1146 }
c5c77ba1
JK
1147 *(pu8CurrByte++) = (ptstrJoinBssParam->cap_info) & 0xFF;
1148 *(pu8CurrByte++) = ((ptstrJoinBssParam->cap_info) >> 8) & 0xFF;
1149 PRINT_D(HOSTINF_DBG, "* Cap Info %0x*\n", (*(pu8CurrByte - 2) | ((*(pu8CurrByte - 1)) << 8)));
1150
2b9d5b48 1151 if (pstrHostIFconnectAttr->pu8bssid != NULL)
d00d2ba3 1152 memcpy(pu8CurrByte, pstrHostIFconnectAttr->pu8bssid, 6);
c5c77ba1
JK
1153 pu8CurrByte += 6;
1154
2b9d5b48 1155 if (pstrHostIFconnectAttr->pu8bssid != NULL)
d00d2ba3 1156 memcpy(pu8CurrByte, pstrHostIFconnectAttr->pu8bssid, 6);
c5c77ba1
JK
1157 pu8CurrByte += 6;
1158
c5c77ba1
JK
1159 *(pu8CurrByte++) = (ptstrJoinBssParam->beacon_period) & 0xFF;
1160 *(pu8CurrByte++) = ((ptstrJoinBssParam->beacon_period) >> 8) & 0xFF;
1161 PRINT_D(HOSTINF_DBG, "* Beacon Period %d*\n", (*(pu8CurrByte - 2) | ((*(pu8CurrByte - 1)) << 8)));
c5c77ba1
JK
1162 *(pu8CurrByte++) = ptstrJoinBssParam->dtim_period;
1163 PRINT_D(HOSTINF_DBG, "* DTIM Period %d*\n", (*(pu8CurrByte - 1)));
ae4dfa57 1164
d00d2ba3 1165 memcpy(pu8CurrByte, ptstrJoinBssParam->supp_rates, MAX_RATES_SUPPORTED + 1);
c5c77ba1
JK
1166 pu8CurrByte += (MAX_RATES_SUPPORTED + 1);
1167
c5c77ba1
JK
1168 *(pu8CurrByte++) = ptstrJoinBssParam->wmm_cap;
1169 PRINT_D(HOSTINF_DBG, "* wmm cap%d*\n", (*(pu8CurrByte - 1)));
c5c77ba1
JK
1170 *(pu8CurrByte++) = ptstrJoinBssParam->uapsd_cap;
1171
c5c77ba1 1172 *(pu8CurrByte++) = ptstrJoinBssParam->ht_capable;
a4ab1ade 1173 hif_drv->strWILC_UsrConnReq.IsHTCapable = ptstrJoinBssParam->ht_capable;
c5c77ba1 1174
c5c77ba1
JK
1175 *(pu8CurrByte++) = ptstrJoinBssParam->rsn_found;
1176 PRINT_D(HOSTINF_DBG, "* rsn found %d*\n", *(pu8CurrByte - 1));
c5c77ba1
JK
1177 *(pu8CurrByte++) = ptstrJoinBssParam->rsn_grp_policy;
1178 PRINT_D(HOSTINF_DBG, "* rsn group policy %0x*\n", (*(pu8CurrByte - 1)));
c5c77ba1
JK
1179 *(pu8CurrByte++) = ptstrJoinBssParam->mode_802_11i;
1180 PRINT_D(HOSTINF_DBG, "* mode_802_11i %d*\n", (*(pu8CurrByte - 1)));
ae4dfa57 1181
d00d2ba3 1182 memcpy(pu8CurrByte, ptstrJoinBssParam->rsn_pcip_policy, sizeof(ptstrJoinBssParam->rsn_pcip_policy));
c5c77ba1
JK
1183 pu8CurrByte += sizeof(ptstrJoinBssParam->rsn_pcip_policy);
1184
d00d2ba3 1185 memcpy(pu8CurrByte, ptstrJoinBssParam->rsn_auth_policy, sizeof(ptstrJoinBssParam->rsn_auth_policy));
c5c77ba1
JK
1186 pu8CurrByte += sizeof(ptstrJoinBssParam->rsn_auth_policy);
1187
d00d2ba3 1188 memcpy(pu8CurrByte, ptstrJoinBssParam->rsn_cap, sizeof(ptstrJoinBssParam->rsn_cap));
c5c77ba1
JK
1189 pu8CurrByte += sizeof(ptstrJoinBssParam->rsn_cap);
1190
c5c77ba1
JK
1191 *(pu8CurrByte++) = REAL_JOIN_REQ;
1192
c5c77ba1
JK
1193 *(pu8CurrByte++) = ptstrJoinBssParam->u8NoaEnbaled;
1194 if (ptstrJoinBssParam->u8NoaEnbaled) {
1195 PRINT_D(HOSTINF_DBG, "NOA present\n");
1196
1197 *(pu8CurrByte++) = (ptstrJoinBssParam->tsf) & 0xFF;
1198 *(pu8CurrByte++) = ((ptstrJoinBssParam->tsf) >> 8) & 0xFF;
1199 *(pu8CurrByte++) = ((ptstrJoinBssParam->tsf) >> 16) & 0xFF;
1200 *(pu8CurrByte++) = ((ptstrJoinBssParam->tsf) >> 24) & 0xFF;
1201
1202 *(pu8CurrByte++) = ptstrJoinBssParam->u8Index;
1203
1204 *(pu8CurrByte++) = ptstrJoinBssParam->u8OppEnable;
1205
1206 if (ptstrJoinBssParam->u8OppEnable)
1207 *(pu8CurrByte++) = ptstrJoinBssParam->u8CtWindow;
1208
1209 *(pu8CurrByte++) = ptstrJoinBssParam->u8Count;
1210
d00d2ba3 1211 memcpy(pu8CurrByte, ptstrJoinBssParam->au8Duration, sizeof(ptstrJoinBssParam->au8Duration));
c5c77ba1
JK
1212
1213 pu8CurrByte += sizeof(ptstrJoinBssParam->au8Duration);
1214
d00d2ba3 1215 memcpy(pu8CurrByte, ptstrJoinBssParam->au8Interval, sizeof(ptstrJoinBssParam->au8Interval));
c5c77ba1
JK
1216
1217 pu8CurrByte += sizeof(ptstrJoinBssParam->au8Interval);
1218
d00d2ba3 1219 memcpy(pu8CurrByte, ptstrJoinBssParam->au8StartTime, sizeof(ptstrJoinBssParam->au8StartTime));
c5c77ba1
JK
1220
1221 pu8CurrByte += sizeof(ptstrJoinBssParam->au8StartTime);
1222
1223 } else
1224 PRINT_D(HOSTINF_DBG, "NOA not present\n");
c5c77ba1 1225
900bb4a6 1226 pu8CurrByte = strWIDList[u32WidsCount].val;
c5c77ba1 1227 u32WidsCount++;
c5c77ba1 1228 gu32WidConnRstHack = 0;
c5c77ba1 1229
1a646e7e 1230 if (memcmp("DIRECT-", pstrHostIFconnectAttr->pu8ssid, 7)) {
c5c77ba1 1231 memcpy(gu8FlushedJoinReq, pu8CurrByte, gu32FlushedJoinReqSize);
a4ab1ade 1232 gu8FlushedJoinReqDrvHandler = hif_drv;
c5c77ba1
JK
1233 }
1234
1235 PRINT_D(GENERIC_DBG, "send HOST_IF_WAITING_CONN_RESP\n");
1236
1237 if (pstrHostIFconnectAttr->pu8bssid != NULL) {
d00d2ba3 1238 memcpy(u8ConnectedSSID, pstrHostIFconnectAttr->pu8bssid, ETH_ALEN);
c5c77ba1 1239
310a28fd
AK
1240 PRINT_D(GENERIC_DBG, "save Bssid = %pM\n", pstrHostIFconnectAttr->pu8bssid);
1241 PRINT_D(GENERIC_DBG, "save bssid = %pM\n", u8ConnectedSSID);
c5c77ba1
JK
1242 }
1243
03362286 1244 s32Error = send_config_pkt(SET_CFG, strWIDList, u32WidsCount,
a4ab1ade 1245 get_id_from_handler(hif_drv));
c5c77ba1 1246 if (s32Error) {
24db713f
LK
1247 PRINT_ER("failed to send config packet\n");
1248 s32Error = -EFAULT;
1249 goto ERRORHANDLER;
c5c77ba1
JK
1250 } else {
1251 PRINT_D(GENERIC_DBG, "set HOST_IF_WAITING_CONN_RESP\n");
a4ab1ade 1252 hif_drv->enuHostIFstate = HOST_IF_WAITING_CONN_RESP;
c5c77ba1 1253 }
c5c77ba1 1254
24db713f
LK
1255ERRORHANDLER:
1256 if (s32Error) {
c5c77ba1
JK
1257 tstrConnectInfo strConnectInfo;
1258
a4ab1ade 1259 del_timer(&hif_drv->hConnectTimer);
c5c77ba1
JK
1260
1261 PRINT_D(HOSTINF_DBG, "could not start connecting to the required network\n");
1262
2cc46837 1263 memset(&strConnectInfo, 0, sizeof(tstrConnectInfo));
c5c77ba1
JK
1264
1265 if (pstrHostIFconnectAttr->pfConnectResult != NULL) {
2b9d5b48 1266 if (pstrHostIFconnectAttr->pu8bssid != NULL)
d00d2ba3 1267 memcpy(strConnectInfo.au8bssid, pstrHostIFconnectAttr->pu8bssid, 6);
c5c77ba1
JK
1268
1269 if (pstrHostIFconnectAttr->pu8IEs != NULL) {
1270 strConnectInfo.ReqIEsLen = pstrHostIFconnectAttr->IEsLen;
f3052587 1271 strConnectInfo.pu8ReqIEs = kmalloc(pstrHostIFconnectAttr->IEsLen, GFP_KERNEL);
d00d2ba3 1272 memcpy(strConnectInfo.pu8ReqIEs,
c5c77ba1
JK
1273 pstrHostIFconnectAttr->pu8IEs,
1274 pstrHostIFconnectAttr->IEsLen);
1275 }
1276
1277 pstrHostIFconnectAttr->pfConnectResult(CONN_DISCONN_EVENT_CONN_RESP,
1278 &strConnectInfo,
1279 MAC_DISCONNECTED,
1280 NULL,
1281 pstrHostIFconnectAttr->pvUserArg);
a4ab1ade 1282 hif_drv->enuHostIFstate = HOST_IF_IDLE;
c5c77ba1 1283 if (strConnectInfo.pu8ReqIEs != NULL) {
49188af2 1284 kfree(strConnectInfo.pu8ReqIEs);
c5c77ba1
JK
1285 strConnectInfo.pu8ReqIEs = NULL;
1286 }
1287
1288 } else {
03b2d5e7 1289 PRINT_ER("Connect callback function pointer is NULL\n");
c5c77ba1
JK
1290 }
1291 }
1292
1293 PRINT_D(HOSTINF_DBG, "Deallocating connection parameters\n");
c5c77ba1 1294 if (pstrHostIFconnectAttr->pu8bssid != NULL) {
49188af2 1295 kfree(pstrHostIFconnectAttr->pu8bssid);
c5c77ba1
JK
1296 pstrHostIFconnectAttr->pu8bssid = NULL;
1297 }
1298
c5c77ba1 1299 if (pstrHostIFconnectAttr->pu8ssid != NULL) {
49188af2 1300 kfree(pstrHostIFconnectAttr->pu8ssid);
c5c77ba1
JK
1301 pstrHostIFconnectAttr->pu8ssid = NULL;
1302 }
1303
c5c77ba1 1304 if (pstrHostIFconnectAttr->pu8IEs != NULL) {
49188af2 1305 kfree(pstrHostIFconnectAttr->pu8IEs);
c5c77ba1
JK
1306 pstrHostIFconnectAttr->pu8IEs = NULL;
1307 }
1308
2b9d5b48 1309 if (pu8CurrByte != NULL)
49188af2 1310 kfree(pu8CurrByte);
c5c77ba1
JK
1311 return s32Error;
1312}
1313
a4ab1ade 1314static s32 Handle_FlushConnect(struct host_if_drv *hif_drv)
c5c77ba1 1315{
e6e12661 1316 s32 s32Error = 0;
e9e0c260 1317 struct wid strWIDList[5];
4e4467fd 1318 u32 u32WidsCount = 0;
63d03e47 1319 u8 *pu8CurrByte = NULL;
c5c77ba1 1320
daaf16ba 1321 strWIDList[u32WidsCount].id = WID_INFO_ELEMENT_ASSOCIATE;
416d8321 1322 strWIDList[u32WidsCount].type = WID_BIN_DATA;
900bb4a6 1323 strWIDList[u32WidsCount].val = gu8FlushedInfoElemAsoc;
2fd3e443 1324 strWIDList[u32WidsCount].size = gu32FlushedInfoElemAsocSize;
c5c77ba1
JK
1325 u32WidsCount++;
1326
daaf16ba 1327 strWIDList[u32WidsCount].id = (u16)WID_11I_MODE;
416d8321 1328 strWIDList[u32WidsCount].type = WID_CHAR;
2fd3e443 1329 strWIDList[u32WidsCount].size = sizeof(char);
900bb4a6 1330 strWIDList[u32WidsCount].val = (s8 *)(&(gu8Flushed11iMode));
c5c77ba1
JK
1331 u32WidsCount++;
1332
1333
1334
daaf16ba 1335 strWIDList[u32WidsCount].id = (u16)WID_AUTH_TYPE;
416d8321 1336 strWIDList[u32WidsCount].type = WID_CHAR;
2fd3e443 1337 strWIDList[u32WidsCount].size = sizeof(char);
900bb4a6 1338 strWIDList[u32WidsCount].val = (s8 *)(&gu8FlushedAuthType);
c5c77ba1
JK
1339 u32WidsCount++;
1340
daaf16ba 1341 strWIDList[u32WidsCount].id = (u16)WID_JOIN_REQ_EXTENDED;
416d8321 1342 strWIDList[u32WidsCount].type = WID_STR;
2fd3e443 1343 strWIDList[u32WidsCount].size = gu32FlushedJoinReqSize;
900bb4a6
LK
1344 strWIDList[u32WidsCount].val = (s8 *)gu8FlushedJoinReq;
1345 pu8CurrByte = strWIDList[u32WidsCount].val;
c5c77ba1
JK
1346
1347 pu8CurrByte += FLUSHED_BYTE_POS;
1348 *(pu8CurrByte) = FLUSHED_JOIN_REQ;
1349
1350 u32WidsCount++;
1351
03362286 1352 s32Error = send_config_pkt(SET_CFG, strWIDList, u32WidsCount,
cf32c3c4 1353 get_id_from_handler(gu8FlushedJoinReqDrvHandler));
c5c77ba1 1354 if (s32Error) {
24db713f
LK
1355 PRINT_ER("failed to send config packet\n");
1356 s32Error = -EINVAL;
c5c77ba1
JK
1357 }
1358
1359 return s32Error;
1360}
1361
a4ab1ade 1362static s32 Handle_ConnectTimeout(struct host_if_drv *hif_drv)
c5c77ba1 1363{
e6e12661 1364 s32 s32Error = 0;
c5c77ba1 1365 tstrConnectInfo strConnectInfo;
e9e0c260 1366 struct wid strWID;
d85f5326 1367 u16 u16DummyReasonCode = 0;
c5c77ba1 1368
a4ab1ade 1369 if (!hif_drv) {
c5c77ba1
JK
1370 PRINT_ER("Driver handler is NULL\n");
1371 return s32Error;
1372 }
1373
a4ab1ade 1374 hif_drv->enuHostIFstate = HOST_IF_IDLE;
c5c77ba1 1375
72ed4dc7 1376 gbScanWhileConnected = false;
c5c77ba1
JK
1377
1378
2cc46837 1379 memset(&strConnectInfo, 0, sizeof(tstrConnectInfo));
c5c77ba1 1380
a4ab1ade
TC
1381 if (hif_drv->strWILC_UsrConnReq.pfUserConnectResult != NULL) {
1382 if (hif_drv->strWILC_UsrConnReq.pu8bssid != NULL) {
d00d2ba3 1383 memcpy(strConnectInfo.au8bssid,
a4ab1ade 1384 hif_drv->strWILC_UsrConnReq.pu8bssid, 6);
c5c77ba1
JK
1385 }
1386
a4ab1ade
TC
1387 if (hif_drv->strWILC_UsrConnReq.pu8ConnReqIEs != NULL) {
1388 strConnectInfo.ReqIEsLen = hif_drv->strWILC_UsrConnReq.ConnReqIEsLen;
1389 strConnectInfo.pu8ReqIEs = kmalloc(hif_drv->strWILC_UsrConnReq.ConnReqIEsLen, GFP_KERNEL);
d00d2ba3 1390 memcpy(strConnectInfo.pu8ReqIEs,
a4ab1ade
TC
1391 hif_drv->strWILC_UsrConnReq.pu8ConnReqIEs,
1392 hif_drv->strWILC_UsrConnReq.ConnReqIEsLen);
c5c77ba1
JK
1393 }
1394
a4ab1ade 1395 hif_drv->strWILC_UsrConnReq.pfUserConnectResult(CONN_DISCONN_EVENT_CONN_RESP,
c5c77ba1
JK
1396 &strConnectInfo,
1397 MAC_DISCONNECTED,
1398 NULL,
a4ab1ade 1399 hif_drv->strWILC_UsrConnReq.u32UserConnectPvoid);
c5c77ba1 1400
c5c77ba1 1401 if (strConnectInfo.pu8ReqIEs != NULL) {
49188af2 1402 kfree(strConnectInfo.pu8ReqIEs);
c5c77ba1
JK
1403 strConnectInfo.pu8ReqIEs = NULL;
1404 }
1405 } else {
03b2d5e7 1406 PRINT_ER("Connect callback function pointer is NULL\n");
c5c77ba1
JK
1407 }
1408
daaf16ba 1409 strWID.id = (u16)WID_DISCONNECT;
416d8321 1410 strWID.type = WID_CHAR;
900bb4a6 1411 strWID.val = (s8 *)&u16DummyReasonCode;
2fd3e443 1412 strWID.size = sizeof(char);
c5c77ba1
JK
1413
1414 PRINT_D(HOSTINF_DBG, "Sending disconnect request\n");
1415
03362286 1416 s32Error = send_config_pkt(SET_CFG, &strWID, 1,
a4ab1ade 1417 get_id_from_handler(hif_drv));
2b9d5b48 1418 if (s32Error)
c5c77ba1 1419 PRINT_ER("Failed to send dissconect config packet\n");
c5c77ba1 1420
a4ab1ade
TC
1421 hif_drv->strWILC_UsrConnReq.ssidLen = 0;
1422 kfree(hif_drv->strWILC_UsrConnReq.pu8ssid);
1423 kfree(hif_drv->strWILC_UsrConnReq.pu8bssid);
1424 hif_drv->strWILC_UsrConnReq.ConnReqIEsLen = 0;
1425 kfree(hif_drv->strWILC_UsrConnReq.pu8ConnReqIEs);
c5c77ba1 1426
281dd5ac 1427 eth_zero_addr(u8ConnectedSSID);
ae4dfa57 1428
a4ab1ade 1429 if (gu8FlushedJoinReq != NULL && gu8FlushedJoinReqDrvHandler == hif_drv) {
49188af2 1430 kfree(gu8FlushedJoinReq);
c5c77ba1
JK
1431 gu8FlushedJoinReq = NULL;
1432 }
a4ab1ade 1433 if (gu8FlushedInfoElemAsoc != NULL && gu8FlushedJoinReqDrvHandler == hif_drv) {
49188af2 1434 kfree(gu8FlushedInfoElemAsoc);
c5c77ba1
JK
1435 gu8FlushedInfoElemAsoc = NULL;
1436 }
1437
1438 return s32Error;
1439}
1440
a4ab1ade 1441static s32 Handle_RcvdNtwrkInfo(struct host_if_drv *hif_drv,
3bbd59f5 1442 struct rcvd_net_info *pstrRcvdNetworkInfo)
c5c77ba1 1443{
4e4467fd 1444 u32 i;
72ed4dc7 1445 bool bNewNtwrkFound;
c5c77ba1
JK
1446
1447
1448
e6e12661 1449 s32 s32Error = 0;
c5c77ba1
JK
1450 tstrNetworkInfo *pstrNetworkInfo = NULL;
1451 void *pJoinParams = NULL;
1452
72ed4dc7 1453 bNewNtwrkFound = true;
c5c77ba1
JK
1454 PRINT_INFO(HOSTINF_DBG, "Handling received network info\n");
1455
a4ab1ade 1456 if (hif_drv->strWILC_UsrScanReq.pfUserScanResult) {
c5c77ba1 1457 PRINT_D(HOSTINF_DBG, "State: Scanning, parsing network information received\n");
a1f7f642 1458 parse_network_info(pstrRcvdNetworkInfo->pu8Buffer, &pstrNetworkInfo);
c5c77ba1 1459 if ((pstrNetworkInfo == NULL)
a4ab1ade 1460 || (hif_drv->strWILC_UsrScanReq.pfUserScanResult == NULL)) {
24db713f
LK
1461 PRINT_ER("driver is null\n");
1462 s32Error = -EINVAL;
1463 goto done;
c5c77ba1
JK
1464 }
1465
a4ab1ade 1466 for (i = 0; i < hif_drv->strWILC_UsrScanReq.u32RcvdChCount; i++) {
c5c77ba1 1467
a4ab1ade 1468 if ((hif_drv->strWILC_UsrScanReq.astrFoundNetworkInfo[i].au8bssid != NULL) &&
c5c77ba1 1469 (pstrNetworkInfo->au8bssid != NULL)) {
a4ab1ade 1470 if (memcmp(hif_drv->strWILC_UsrScanReq.astrFoundNetworkInfo[i].au8bssid,
c5c77ba1 1471 pstrNetworkInfo->au8bssid, 6) == 0) {
a4ab1ade 1472 if (pstrNetworkInfo->s8rssi <= hif_drv->strWILC_UsrScanReq.astrFoundNetworkInfo[i].s8rssi) {
c5c77ba1
JK
1473 PRINT_D(HOSTINF_DBG, "Network previously discovered\n");
1474 goto done;
1475 } else {
a4ab1ade 1476 hif_drv->strWILC_UsrScanReq.astrFoundNetworkInfo[i].s8rssi = pstrNetworkInfo->s8rssi;
72ed4dc7 1477 bNewNtwrkFound = false;
c5c77ba1
JK
1478 break;
1479 }
1480 }
1481 }
1482 }
1483
72ed4dc7 1484 if (bNewNtwrkFound == true) {
c5c77ba1
JK
1485 PRINT_D(HOSTINF_DBG, "New network found\n");
1486
a4ab1ade
TC
1487 if (hif_drv->strWILC_UsrScanReq.u32RcvdChCount < MAX_NUM_SCANNED_NETWORKS) {
1488 hif_drv->strWILC_UsrScanReq.astrFoundNetworkInfo[hif_drv->strWILC_UsrScanReq.u32RcvdChCount].s8rssi = pstrNetworkInfo->s8rssi;
c5c77ba1 1489
a4ab1ade 1490 if ((hif_drv->strWILC_UsrScanReq.astrFoundNetworkInfo[hif_drv->strWILC_UsrScanReq.u32RcvdChCount].au8bssid != NULL)
c5c77ba1 1491 && (pstrNetworkInfo->au8bssid != NULL)) {
a4ab1ade 1492 memcpy(hif_drv->strWILC_UsrScanReq.astrFoundNetworkInfo[hif_drv->strWILC_UsrScanReq.u32RcvdChCount].au8bssid,
c5c77ba1
JK
1493 pstrNetworkInfo->au8bssid, 6);
1494
a4ab1ade 1495 hif_drv->strWILC_UsrScanReq.u32RcvdChCount++;
c5c77ba1 1496
72ed4dc7 1497 pstrNetworkInfo->bNewNetwork = true;
c5c77ba1 1498 pJoinParams = host_int_ParseJoinBssParam(pstrNetworkInfo);
c5c77ba1 1499
a4ab1ade
TC
1500 hif_drv->strWILC_UsrScanReq.pfUserScanResult(SCAN_EVENT_NETWORK_FOUND, pstrNetworkInfo,
1501 hif_drv->strWILC_UsrScanReq.u32UserScanPvoid,
c5c77ba1
JK
1502 pJoinParams);
1503
1504
1505 }
1506 } else {
03b2d5e7 1507 PRINT_WRN(HOSTINF_DBG, "Discovered networks exceeded max. limit\n");
c5c77ba1
JK
1508 }
1509 } else {
72ed4dc7 1510 pstrNetworkInfo->bNewNetwork = false;
a4ab1ade
TC
1511 hif_drv->strWILC_UsrScanReq.pfUserScanResult(SCAN_EVENT_NETWORK_FOUND, pstrNetworkInfo,
1512 hif_drv->strWILC_UsrScanReq.u32UserScanPvoid, NULL);
c5c77ba1
JK
1513 }
1514 }
1515
c5c77ba1 1516done:
c5c77ba1 1517 if (pstrRcvdNetworkInfo->pu8Buffer != NULL) {
49188af2 1518 kfree(pstrRcvdNetworkInfo->pu8Buffer);
c5c77ba1
JK
1519 pstrRcvdNetworkInfo->pu8Buffer = NULL;
1520 }
1521
b1413b60 1522 if (pstrNetworkInfo != NULL) {
c5c77ba1 1523 DeallocateNetworkInfo(pstrNetworkInfo);
b1413b60 1524 pstrNetworkInfo = NULL;
c5c77ba1
JK
1525 }
1526
1527 return s32Error;
1528}
1529
a4ab1ade 1530static s32 Handle_RcvdGnrlAsyncInfo(struct host_if_drv *hif_drv,
f23a9eab 1531 struct rcvd_async_info *pstrRcvdGnrlAsyncInfo)
c5c77ba1 1532{
e6e12661 1533 s32 s32Error = 0;
63d03e47
GKH
1534 u8 u8MsgType = 0;
1535 u8 u8MsgID = 0;
d85f5326
CL
1536 u16 u16MsgLen = 0;
1537 u16 u16WidID = (u16)WID_NIL;
63d03e47
GKH
1538 u8 u8WidLen = 0;
1539 u8 u8MacStatus;
1540 u8 u8MacStatusReasonCode;
1541 u8 u8MacStatusAdditionalInfo;
c5c77ba1
JK
1542 tstrConnectInfo strConnectInfo;
1543 tstrDisconnectNotifInfo strDisconnectNotifInfo;
e6e12661 1544 s32 s32Err = 0;
78c87591 1545
a4ab1ade 1546 if (!hif_drv) {
c5c77ba1 1547 PRINT_ER("Driver handler is NULL\n");
234837de
LK
1548 return -ENODEV;
1549 }
a4ab1ade 1550 PRINT_D(GENERIC_DBG, "Current State = %d,Received state = %d\n", hif_drv->enuHostIFstate,
c5c77ba1
JK
1551 pstrRcvdGnrlAsyncInfo->pu8Buffer[7]);
1552
a4ab1ade
TC
1553 if ((hif_drv->enuHostIFstate == HOST_IF_WAITING_CONN_RESP) ||
1554 (hif_drv->enuHostIFstate == HOST_IF_CONNECTED) ||
1555 hif_drv->strWILC_UsrScanReq.pfUserScanResult) {
c5c77ba1 1556 if ((pstrRcvdGnrlAsyncInfo->pu8Buffer == NULL) ||
a4ab1ade 1557 (hif_drv->strWILC_UsrConnReq.pfUserConnectResult == NULL)) {
24db713f
LK
1558 PRINT_ER("driver is null\n");
1559 return -EINVAL;
c5c77ba1
JK
1560 }
1561
1562 u8MsgType = pstrRcvdGnrlAsyncInfo->pu8Buffer[0];
1563
c5c77ba1
JK
1564 if ('I' != u8MsgType) {
1565 PRINT_ER("Received Message format incorrect.\n");
24db713f 1566 return -EFAULT;
c5c77ba1
JK
1567 }
1568
c5c77ba1 1569 u8MsgID = pstrRcvdGnrlAsyncInfo->pu8Buffer[1];
c5c77ba1 1570 u16MsgLen = MAKE_WORD16(pstrRcvdGnrlAsyncInfo->pu8Buffer[2], pstrRcvdGnrlAsyncInfo->pu8Buffer[3]);
c5c77ba1 1571 u16WidID = MAKE_WORD16(pstrRcvdGnrlAsyncInfo->pu8Buffer[4], pstrRcvdGnrlAsyncInfo->pu8Buffer[5]);
c5c77ba1 1572 u8WidLen = pstrRcvdGnrlAsyncInfo->pu8Buffer[6];
c5c77ba1
JK
1573 u8MacStatus = pstrRcvdGnrlAsyncInfo->pu8Buffer[7];
1574 u8MacStatusReasonCode = pstrRcvdGnrlAsyncInfo->pu8Buffer[8];
1575 u8MacStatusAdditionalInfo = pstrRcvdGnrlAsyncInfo->pu8Buffer[9];
1576 PRINT_INFO(HOSTINF_DBG, "Recieved MAC status = %d with Reason = %d , Info = %d\n", u8MacStatus, u8MacStatusReasonCode, u8MacStatusAdditionalInfo);
a4ab1ade 1577 if (hif_drv->enuHostIFstate == HOST_IF_WAITING_CONN_RESP) {
4e4467fd 1578 u32 u32RcvdAssocRespInfoLen;
c5c77ba1
JK
1579 tstrConnectRespInfo *pstrConnectRespInfo = NULL;
1580
1581 PRINT_D(HOSTINF_DBG, "Recieved MAC status = %d with Reason = %d , Code = %d\n", u8MacStatus, u8MacStatusReasonCode, u8MacStatusAdditionalInfo);
1582
2cc46837 1583 memset(&strConnectInfo, 0, sizeof(tstrConnectInfo));
c5c77ba1
JK
1584
1585 if (u8MacStatus == MAC_CONNECTED) {
2cc46837 1586 memset(gapu8RcvdAssocResp, 0, MAX_ASSOC_RESP_FRAME_SIZE);
c5c77ba1 1587
a4ab1ade 1588 host_int_get_assoc_res_info(hif_drv,
c5c77ba1
JK
1589 gapu8RcvdAssocResp,
1590 MAX_ASSOC_RESP_FRAME_SIZE,
1591 &u32RcvdAssocRespInfoLen);
1592
1593 PRINT_INFO(HOSTINF_DBG, "Received association response with length = %d\n", u32RcvdAssocRespInfoLen);
1594
1595 if (u32RcvdAssocRespInfoLen != 0) {
1596
1597 PRINT_D(HOSTINF_DBG, "Parsing association response\n");
1598 s32Err = ParseAssocRespInfo(gapu8RcvdAssocResp, u32RcvdAssocRespInfoLen,
1599 &pstrConnectRespInfo);
1600 if (s32Err) {
03b2d5e7 1601 PRINT_ER("ParseAssocRespInfo() returned error %d\n", s32Err);
c5c77ba1 1602 } else {
c5c77ba1
JK
1603 strConnectInfo.u16ConnectStatus = pstrConnectRespInfo->u16ConnectStatus;
1604
1605 if (strConnectInfo.u16ConnectStatus == SUCCESSFUL_STATUSCODE) {
1606 PRINT_INFO(HOSTINF_DBG, "Association response received : Successful connection status\n");
1607 if (pstrConnectRespInfo->pu8RespIEs != NULL) {
1608 strConnectInfo.u16RespIEsLen = pstrConnectRespInfo->u16RespIEsLen;
1609
1610
f3052587 1611 strConnectInfo.pu8RespIEs = kmalloc(pstrConnectRespInfo->u16RespIEsLen, GFP_KERNEL);
d00d2ba3 1612 memcpy(strConnectInfo.pu8RespIEs, pstrConnectRespInfo->pu8RespIEs,
c5c77ba1
JK
1613 pstrConnectRespInfo->u16RespIEsLen);
1614 }
1615 }
1616
c5c77ba1
JK
1617 if (pstrConnectRespInfo != NULL) {
1618 DeallocateAssocRespInfo(pstrConnectRespInfo);
1619 pstrConnectRespInfo = NULL;
1620 }
1621 }
1622 }
1623 }
1624
c5c77ba1
JK
1625 if ((u8MacStatus == MAC_CONNECTED) &&
1626 (strConnectInfo.u16ConnectStatus != SUCCESSFUL_STATUSCODE)) {
03b2d5e7 1627 PRINT_ER("Received MAC status is MAC_CONNECTED while the received status code in Asoc Resp is not SUCCESSFUL_STATUSCODE\n");
281dd5ac 1628 eth_zero_addr(u8ConnectedSSID);
c5c77ba1
JK
1629
1630 } else if (u8MacStatus == MAC_DISCONNECTED) {
1631 PRINT_ER("Received MAC status is MAC_DISCONNECTED\n");
281dd5ac 1632 eth_zero_addr(u8ConnectedSSID);
c5c77ba1
JK
1633 }
1634
a4ab1ade 1635 if (hif_drv->strWILC_UsrConnReq.pu8bssid != NULL) {
c5c77ba1 1636 PRINT_D(HOSTINF_DBG, "Retrieving actual BSSID from AP\n");
a4ab1ade 1637 memcpy(strConnectInfo.au8bssid, hif_drv->strWILC_UsrConnReq.pu8bssid, 6);
c5c77ba1
JK
1638
1639 if ((u8MacStatus == MAC_CONNECTED) &&
1640 (strConnectInfo.u16ConnectStatus == SUCCESSFUL_STATUSCODE)) {
a4ab1ade
TC
1641 memcpy(hif_drv->au8AssociatedBSSID,
1642 hif_drv->strWILC_UsrConnReq.pu8bssid, ETH_ALEN);
c5c77ba1
JK
1643 }
1644 }
1645
1646
a4ab1ade
TC
1647 if (hif_drv->strWILC_UsrConnReq.pu8ConnReqIEs != NULL) {
1648 strConnectInfo.ReqIEsLen = hif_drv->strWILC_UsrConnReq.ConnReqIEsLen;
1649 strConnectInfo.pu8ReqIEs = kmalloc(hif_drv->strWILC_UsrConnReq.ConnReqIEsLen, GFP_KERNEL);
d00d2ba3 1650 memcpy(strConnectInfo.pu8ReqIEs,
a4ab1ade
TC
1651 hif_drv->strWILC_UsrConnReq.pu8ConnReqIEs,
1652 hif_drv->strWILC_UsrConnReq.ConnReqIEsLen);
c5c77ba1
JK
1653 }
1654
1655
a4ab1ade
TC
1656 del_timer(&hif_drv->hConnectTimer);
1657 hif_drv->strWILC_UsrConnReq.pfUserConnectResult(CONN_DISCONN_EVENT_CONN_RESP,
c5c77ba1
JK
1658 &strConnectInfo,
1659 u8MacStatus,
1660 NULL,
a4ab1ade 1661 hif_drv->strWILC_UsrConnReq.u32UserConnectPvoid);
c5c77ba1 1662
c5c77ba1
JK
1663 if ((u8MacStatus == MAC_CONNECTED) &&
1664 (strConnectInfo.u16ConnectStatus == SUCCESSFUL_STATUSCODE)) {
a4ab1ade 1665 host_int_set_power_mgmt(hif_drv, 0, 0);
c5c77ba1
JK
1666
1667 PRINT_D(HOSTINF_DBG, "MAC status : CONNECTED and Connect Status : Successful\n");
a4ab1ade 1668 hif_drv->enuHostIFstate = HOST_IF_CONNECTED;
c5c77ba1 1669
c5c77ba1 1670 PRINT_D(GENERIC_DBG, "Obtaining an IP, Disable Scan\n");
72ed4dc7 1671 g_obtainingIP = true;
9eb06643
GKH
1672 mod_timer(&hDuringIpTimer,
1673 jiffies + msecs_to_jiffies(10000));
c5c77ba1
JK
1674 } else {
1675 PRINT_D(HOSTINF_DBG, "MAC status : %d and Connect Status : %d\n", u8MacStatus, strConnectInfo.u16ConnectStatus);
a4ab1ade 1676 hif_drv->enuHostIFstate = HOST_IF_IDLE;
72ed4dc7 1677 gbScanWhileConnected = false;
c5c77ba1
JK
1678 }
1679
c5c77ba1 1680 if (strConnectInfo.pu8RespIEs != NULL) {
49188af2 1681 kfree(strConnectInfo.pu8RespIEs);
c5c77ba1
JK
1682 strConnectInfo.pu8RespIEs = NULL;
1683 }
1684
1685 if (strConnectInfo.pu8ReqIEs != NULL) {
49188af2 1686 kfree(strConnectInfo.pu8ReqIEs);
c5c77ba1
JK
1687 strConnectInfo.pu8ReqIEs = NULL;
1688 }
a4ab1ade
TC
1689 hif_drv->strWILC_UsrConnReq.ssidLen = 0;
1690 kfree(hif_drv->strWILC_UsrConnReq.pu8ssid);
1691 kfree(hif_drv->strWILC_UsrConnReq.pu8bssid);
1692 hif_drv->strWILC_UsrConnReq.ConnReqIEsLen = 0;
1693 kfree(hif_drv->strWILC_UsrConnReq.pu8ConnReqIEs);
c5c77ba1 1694 } else if ((u8MacStatus == MAC_DISCONNECTED) &&
a4ab1ade 1695 (hif_drv->enuHostIFstate == HOST_IF_CONNECTED)) {
c5c77ba1
JK
1696 PRINT_D(HOSTINF_DBG, "Received MAC_DISCONNECTED from the FW\n");
1697
2cc46837 1698 memset(&strDisconnectNotifInfo, 0, sizeof(tstrDisconnectNotifInfo));
c5c77ba1 1699
a4ab1ade 1700 if (hif_drv->strWILC_UsrScanReq.pfUserScanResult) {
03b2d5e7 1701 PRINT_D(HOSTINF_DBG, "\n\n<< Abort the running OBSS Scan >>\n\n");
a4ab1ade
TC
1702 del_timer(&hif_drv->hScanTimer);
1703 Handle_ScanDone((void *)hif_drv, SCAN_EVENT_ABORTED);
c5c77ba1
JK
1704 }
1705
1706 strDisconnectNotifInfo.u16reason = 0;
1707 strDisconnectNotifInfo.ie = NULL;
1708 strDisconnectNotifInfo.ie_len = 0;
1709
a4ab1ade 1710 if (hif_drv->strWILC_UsrConnReq.pfUserConnectResult != NULL) {
72ed4dc7 1711 g_obtainingIP = false;
a4ab1ade 1712 host_int_set_power_mgmt(hif_drv, 0, 0);
c5c77ba1 1713
a4ab1ade 1714 hif_drv->strWILC_UsrConnReq.pfUserConnectResult(CONN_DISCONN_EVENT_DISCONN_NOTIF,
c5c77ba1
JK
1715 NULL,
1716 0,
1717 &strDisconnectNotifInfo,
a4ab1ade 1718 hif_drv->strWILC_UsrConnReq.u32UserConnectPvoid);
c5c77ba1
JK
1719
1720 } else {
03b2d5e7 1721 PRINT_ER("Connect result callback function is NULL\n");
c5c77ba1
JK
1722 }
1723
a4ab1ade 1724 eth_zero_addr(hif_drv->au8AssociatedBSSID);
c5c77ba1 1725
a4ab1ade
TC
1726 hif_drv->strWILC_UsrConnReq.ssidLen = 0;
1727 kfree(hif_drv->strWILC_UsrConnReq.pu8ssid);
1728 kfree(hif_drv->strWILC_UsrConnReq.pu8bssid);
1729 hif_drv->strWILC_UsrConnReq.ConnReqIEsLen = 0;
1730 kfree(hif_drv->strWILC_UsrConnReq.pu8ConnReqIEs);
c5c77ba1 1731
a4ab1ade 1732 if (gu8FlushedJoinReq != NULL && gu8FlushedJoinReqDrvHandler == hif_drv) {
49188af2 1733 kfree(gu8FlushedJoinReq);
c5c77ba1
JK
1734 gu8FlushedJoinReq = NULL;
1735 }
a4ab1ade 1736 if (gu8FlushedInfoElemAsoc != NULL && gu8FlushedJoinReqDrvHandler == hif_drv) {
49188af2 1737 kfree(gu8FlushedInfoElemAsoc);
c5c77ba1
JK
1738 gu8FlushedInfoElemAsoc = NULL;
1739 }
1740
a4ab1ade 1741 hif_drv->enuHostIFstate = HOST_IF_IDLE;
72ed4dc7 1742 gbScanWhileConnected = false;
c5c77ba1
JK
1743
1744 } else if ((u8MacStatus == MAC_DISCONNECTED) &&
a4ab1ade 1745 (hif_drv->strWILC_UsrScanReq.pfUserScanResult != NULL)) {
c5c77ba1 1746 PRINT_D(HOSTINF_DBG, "Received MAC_DISCONNECTED from the FW while scanning\n");
03b2d5e7 1747 PRINT_D(HOSTINF_DBG, "\n\n<< Abort the running Scan >>\n\n");
ae4dfa57 1748
a4ab1ade
TC
1749 del_timer(&hif_drv->hScanTimer);
1750 if (hif_drv->strWILC_UsrScanReq.pfUserScanResult)
1751 Handle_ScanDone(hif_drv, SCAN_EVENT_ABORTED);
c5c77ba1 1752
c5c77ba1
JK
1753 }
1754
1755 }
1756
c5c77ba1 1757 if (pstrRcvdGnrlAsyncInfo->pu8Buffer != NULL) {
49188af2 1758 kfree(pstrRcvdGnrlAsyncInfo->pu8Buffer);
c5c77ba1
JK
1759 pstrRcvdGnrlAsyncInfo->pu8Buffer = NULL;
1760 }
1761
1762 return s32Error;
1763}
1764
a4ab1ade 1765static int Handle_Key(struct host_if_drv *hif_drv,
c98387a5 1766 struct key_attr *pstrHostIFkeyAttr)
c5c77ba1 1767{
e6e12661 1768 s32 s32Error = 0;
e9e0c260
LK
1769 struct wid strWID;
1770 struct wid strWIDList[5];
63d03e47
GKH
1771 u8 i;
1772 u8 *pu8keybuf;
ca356ada
CL
1773 s8 s8idxarray[1];
1774 s8 ret = 0;
c5c77ba1 1775
8e9f427a 1776 switch (pstrHostIFkeyAttr->type) {
c5c77ba1
JK
1777
1778
1779 case WEP:
1780
0d17e382 1781 if (pstrHostIFkeyAttr->action & ADDKEY_AP) {
c5c77ba1
JK
1782
1783 PRINT_D(HOSTINF_DBG, "Handling WEP key\n");
73b2e381 1784 PRINT_D(GENERIC_DBG, "ID Hostint is %d\n", (pstrHostIFkeyAttr->attr.wep.index));
daaf16ba 1785 strWIDList[0].id = (u16)WID_11I_MODE;
416d8321 1786 strWIDList[0].type = WID_CHAR;
2fd3e443 1787 strWIDList[0].size = sizeof(char);
73b2e381 1788 strWIDList[0].val = (s8 *)(&(pstrHostIFkeyAttr->attr.wep.mode));
c5c77ba1 1789
daaf16ba 1790 strWIDList[1].id = WID_AUTH_TYPE;
416d8321 1791 strWIDList[1].type = WID_CHAR;
2fd3e443 1792 strWIDList[1].size = sizeof(char);
73b2e381 1793 strWIDList[1].val = (s8 *)(&(pstrHostIFkeyAttr->attr.wep.auth_type));
c5c77ba1 1794
daaf16ba 1795 strWIDList[2].id = (u16)WID_KEY_ID;
416d8321 1796 strWIDList[2].type = WID_CHAR;
c5c77ba1 1797
73b2e381 1798 strWIDList[2].val = (s8 *)(&(pstrHostIFkeyAttr->attr.wep.index));
2fd3e443 1799 strWIDList[2].size = sizeof(char);
c5c77ba1 1800
73b2e381 1801 pu8keybuf = kmalloc(pstrHostIFkeyAttr->attr.wep.key_len, GFP_KERNEL);
c5c77ba1
JK
1802
1803 if (pu8keybuf == NULL) {
1804 PRINT_ER("No buffer to send Key\n");
1805 return -1;
1806 }
1807
73b2e381
LK
1808 memcpy(pu8keybuf, pstrHostIFkeyAttr->attr.wep.key,
1809 pstrHostIFkeyAttr->attr.wep.key_len);
c5c77ba1 1810
73b2e381 1811 kfree(pstrHostIFkeyAttr->attr.wep.key);
c5c77ba1 1812
daaf16ba 1813 strWIDList[3].id = (u16)WID_WEP_KEY_VALUE;
416d8321 1814 strWIDList[3].type = WID_STR;
73b2e381 1815 strWIDList[3].size = pstrHostIFkeyAttr->attr.wep.key_len;
900bb4a6 1816 strWIDList[3].val = (s8 *)pu8keybuf;
c5c77ba1
JK
1817
1818
03362286 1819 s32Error = send_config_pkt(SET_CFG, strWIDList, 4,
a4ab1ade 1820 get_id_from_handler(hif_drv));
49188af2 1821 kfree(pu8keybuf);
c5c77ba1
JK
1822
1823
1824 }
c5c77ba1 1825
0d17e382 1826 if (pstrHostIFkeyAttr->action & ADDKEY) {
c5c77ba1 1827 PRINT_D(HOSTINF_DBG, "Handling WEP key\n");
73b2e381 1828 pu8keybuf = kmalloc(pstrHostIFkeyAttr->attr.wep.key_len + 2, GFP_KERNEL);
c5c77ba1
JK
1829 if (pu8keybuf == NULL) {
1830 PRINT_ER("No buffer to send Key\n");
1831 return -1;
1832 }
73b2e381
LK
1833 pu8keybuf[0] = pstrHostIFkeyAttr->attr.wep.index;
1834 memcpy(pu8keybuf + 1, &pstrHostIFkeyAttr->attr.wep.key_len, 1);
1835 memcpy(pu8keybuf + 2, pstrHostIFkeyAttr->attr.wep.key,
1836 pstrHostIFkeyAttr->attr.wep.key_len);
1837 kfree(pstrHostIFkeyAttr->attr.wep.key);
c5c77ba1 1838
daaf16ba 1839 strWID.id = (u16)WID_ADD_WEP_KEY;
416d8321 1840 strWID.type = WID_STR;
900bb4a6 1841 strWID.val = (s8 *)pu8keybuf;
73b2e381 1842 strWID.size = pstrHostIFkeyAttr->attr.wep.key_len + 2;
c5c77ba1 1843
03362286 1844 s32Error = send_config_pkt(SET_CFG, &strWID, 1,
a4ab1ade 1845 get_id_from_handler(hif_drv));
49188af2 1846 kfree(pu8keybuf);
0d17e382 1847 } else if (pstrHostIFkeyAttr->action & REMOVEKEY) {
c5c77ba1
JK
1848
1849 PRINT_D(HOSTINF_DBG, "Removing key\n");
daaf16ba 1850 strWID.id = (u16)WID_REMOVE_WEP_KEY;
416d8321 1851 strWID.type = WID_STR;
c5c77ba1 1852
73b2e381 1853 s8idxarray[0] = (s8)pstrHostIFkeyAttr->attr.wep.index;
900bb4a6 1854 strWID.val = s8idxarray;
2fd3e443 1855 strWID.size = 1;
c5c77ba1 1856
03362286 1857 s32Error = send_config_pkt(SET_CFG, &strWID, 1,
a4ab1ade 1858 get_id_from_handler(hif_drv));
c5c77ba1 1859 } else {
daaf16ba 1860 strWID.id = (u16)WID_KEY_ID;
416d8321 1861 strWID.type = WID_CHAR;
73b2e381 1862 strWID.val = (s8 *)(&(pstrHostIFkeyAttr->attr.wep.index));
2fd3e443 1863 strWID.size = sizeof(char);
c5c77ba1
JK
1864
1865 PRINT_D(HOSTINF_DBG, "Setting default key index\n");
1866
03362286 1867 s32Error = send_config_pkt(SET_CFG, &strWID, 1,
a4ab1ade 1868 get_id_from_handler(hif_drv));
c5c77ba1 1869 }
a4ab1ade 1870 up(&hif_drv->hSemTestKeyBlock);
c5c77ba1
JK
1871 break;
1872
1873 case WPARxGtk:
0d17e382 1874 if (pstrHostIFkeyAttr->action & ADDKEY_AP) {
f3052587 1875 pu8keybuf = kmalloc(RX_MIC_KEY_MSG_LEN, GFP_KERNEL);
c5c77ba1
JK
1876 if (pu8keybuf == NULL) {
1877 PRINT_ER("No buffer to send RxGTK Key\n");
1878 ret = -1;
1879 goto _WPARxGtk_end_case_;
1880 }
1881
2cc46837 1882 memset(pu8keybuf, 0, RX_MIC_KEY_MSG_LEN);
c5c77ba1 1883
0e74c009
LK
1884 if (pstrHostIFkeyAttr->attr.wpa.seq != NULL)
1885 memcpy(pu8keybuf + 6, pstrHostIFkeyAttr->attr.wpa.seq, 8);
c5c77ba1 1886
e2dfbac5 1887 memcpy(pu8keybuf + 14, &pstrHostIFkeyAttr->attr.wpa.index, 1);
6acf2919 1888 memcpy(pu8keybuf + 15, &pstrHostIFkeyAttr->attr.wpa.key_len, 1);
124968fc 1889 memcpy(pu8keybuf + 16, pstrHostIFkeyAttr->attr.wpa.key,
6acf2919 1890 pstrHostIFkeyAttr->attr.wpa.key_len);
c5c77ba1 1891
daaf16ba 1892 strWIDList[0].id = (u16)WID_11I_MODE;
416d8321 1893 strWIDList[0].type = WID_CHAR;
2fd3e443 1894 strWIDList[0].size = sizeof(char);
7b2ebb28 1895 strWIDList[0].val = (s8 *)(&(pstrHostIFkeyAttr->attr.wpa.mode));
c5c77ba1 1896
daaf16ba 1897 strWIDList[1].id = (u16)WID_ADD_RX_GTK;
416d8321 1898 strWIDList[1].type = WID_STR;
900bb4a6 1899 strWIDList[1].val = (s8 *)pu8keybuf;
2fd3e443 1900 strWIDList[1].size = RX_MIC_KEY_MSG_LEN;
c5c77ba1 1901
03362286 1902 s32Error = send_config_pkt(SET_CFG, strWIDList, 2,
a4ab1ade 1903 get_id_from_handler(hif_drv));
c5c77ba1 1904
49188af2 1905 kfree(pu8keybuf);
a4ab1ade 1906 up(&hif_drv->hSemTestKeyBlock);
c5c77ba1
JK
1907 }
1908
0d17e382 1909 if (pstrHostIFkeyAttr->action & ADDKEY) {
c5c77ba1
JK
1910 PRINT_D(HOSTINF_DBG, "Handling group key(Rx) function\n");
1911
f3052587 1912 pu8keybuf = kmalloc(RX_MIC_KEY_MSG_LEN, GFP_KERNEL);
c5c77ba1
JK
1913 if (pu8keybuf == NULL) {
1914 PRINT_ER("No buffer to send RxGTK Key\n");
1915 ret = -1;
1916 goto _WPARxGtk_end_case_;
1917 }
1918
2cc46837 1919 memset(pu8keybuf, 0, RX_MIC_KEY_MSG_LEN);
c5c77ba1 1920
a4ab1ade
TC
1921 if (hif_drv->enuHostIFstate == HOST_IF_CONNECTED)
1922 memcpy(pu8keybuf, hif_drv->au8AssociatedBSSID, ETH_ALEN);
78174ada 1923 else
03b2d5e7 1924 PRINT_ER("Couldn't handle WPARxGtk while enuHostIFstate is not HOST_IF_CONNECTED\n");
c5c77ba1 1925
0e74c009 1926 memcpy(pu8keybuf + 6, pstrHostIFkeyAttr->attr.wpa.seq, 8);
e2dfbac5 1927 memcpy(pu8keybuf + 14, &pstrHostIFkeyAttr->attr.wpa.index, 1);
6acf2919 1928 memcpy(pu8keybuf + 15, &pstrHostIFkeyAttr->attr.wpa.key_len, 1);
124968fc 1929 memcpy(pu8keybuf + 16, pstrHostIFkeyAttr->attr.wpa.key,
6acf2919 1930 pstrHostIFkeyAttr->attr.wpa.key_len);
c5c77ba1 1931
daaf16ba 1932 strWID.id = (u16)WID_ADD_RX_GTK;
416d8321 1933 strWID.type = WID_STR;
900bb4a6 1934 strWID.val = (s8 *)pu8keybuf;
2fd3e443 1935 strWID.size = RX_MIC_KEY_MSG_LEN;
c5c77ba1 1936
03362286 1937 s32Error = send_config_pkt(SET_CFG, &strWID, 1,
a4ab1ade 1938 get_id_from_handler(hif_drv));
c5c77ba1 1939
49188af2 1940 kfree(pu8keybuf);
a4ab1ade 1941 up(&hif_drv->hSemTestKeyBlock);
c5c77ba1
JK
1942 }
1943_WPARxGtk_end_case_:
124968fc 1944 kfree(pstrHostIFkeyAttr->attr.wpa.key);
0e74c009 1945 kfree(pstrHostIFkeyAttr->attr.wpa.seq);
c5c77ba1
JK
1946 if (ret == -1)
1947 return ret;
1948
1949 break;
1950
1951 case WPAPtk:
0d17e382 1952 if (pstrHostIFkeyAttr->action & ADDKEY_AP) {
c5c77ba1
JK
1953
1954
f3052587 1955 pu8keybuf = kmalloc(PTK_KEY_MSG_LEN + 1, GFP_KERNEL);
c5c77ba1
JK
1956
1957
1958
1959 if (pu8keybuf == NULL) {
1960 PRINT_ER("No buffer to send PTK Key\n");
1961 ret = -1;
1962 goto _WPAPtk_end_case_;
1963
1964 }
1965
248080aa 1966 memcpy(pu8keybuf, pstrHostIFkeyAttr->attr.wpa.mac_addr, 6);
e2dfbac5 1967 memcpy(pu8keybuf + 6, &pstrHostIFkeyAttr->attr.wpa.index, 1);
6acf2919 1968 memcpy(pu8keybuf + 7, &pstrHostIFkeyAttr->attr.wpa.key_len, 1);
124968fc 1969 memcpy(pu8keybuf + 8, pstrHostIFkeyAttr->attr.wpa.key,
6acf2919 1970 pstrHostIFkeyAttr->attr.wpa.key_len);
c5c77ba1 1971
daaf16ba 1972 strWIDList[0].id = (u16)WID_11I_MODE;
416d8321 1973 strWIDList[0].type = WID_CHAR;
2fd3e443 1974 strWIDList[0].size = sizeof(char);
7b2ebb28 1975 strWIDList[0].val = (s8 *)(&(pstrHostIFkeyAttr->attr.wpa.mode));
c5c77ba1 1976
daaf16ba 1977 strWIDList[1].id = (u16)WID_ADD_PTK;
416d8321 1978 strWIDList[1].type = WID_STR;
900bb4a6 1979 strWIDList[1].val = (s8 *)pu8keybuf;
2fd3e443 1980 strWIDList[1].size = PTK_KEY_MSG_LEN + 1;
c5c77ba1 1981
03362286 1982 s32Error = send_config_pkt(SET_CFG, strWIDList, 2,
a4ab1ade 1983 get_id_from_handler(hif_drv));
49188af2 1984 kfree(pu8keybuf);
a4ab1ade 1985 up(&hif_drv->hSemTestKeyBlock);
c5c77ba1 1986 }
0d17e382 1987 if (pstrHostIFkeyAttr->action & ADDKEY) {
c5c77ba1
JK
1988
1989
f3052587 1990 pu8keybuf = kmalloc(PTK_KEY_MSG_LEN, GFP_KERNEL);
c5c77ba1
JK
1991
1992
1993
1994 if (pu8keybuf == NULL) {
1995 PRINT_ER("No buffer to send PTK Key\n");
1996 ret = -1;
1997 goto _WPAPtk_end_case_;
1998
1999 }
2000
248080aa 2001 memcpy(pu8keybuf, pstrHostIFkeyAttr->attr.wpa.mac_addr, 6);
6acf2919 2002 memcpy(pu8keybuf + 6, &pstrHostIFkeyAttr->attr.wpa.key_len, 1);
124968fc 2003 memcpy(pu8keybuf + 7, pstrHostIFkeyAttr->attr.wpa.key,
6acf2919 2004 pstrHostIFkeyAttr->attr.wpa.key_len);
c5c77ba1 2005
daaf16ba 2006 strWID.id = (u16)WID_ADD_PTK;
416d8321 2007 strWID.type = WID_STR;
900bb4a6 2008 strWID.val = (s8 *)pu8keybuf;
2fd3e443 2009 strWID.size = PTK_KEY_MSG_LEN;
c5c77ba1 2010
03362286 2011 s32Error = send_config_pkt(SET_CFG, &strWID, 1,
a4ab1ade 2012 get_id_from_handler(hif_drv));
49188af2 2013 kfree(pu8keybuf);
a4ab1ade 2014 up(&hif_drv->hSemTestKeyBlock);
c5c77ba1
JK
2015 }
2016
2017_WPAPtk_end_case_:
124968fc 2018 kfree(pstrHostIFkeyAttr->attr.wpa.key);
c5c77ba1
JK
2019 if (ret == -1)
2020 return ret;
2021
2022 break;
2023
2024
2025 case PMKSA:
2026
2027 PRINT_D(HOSTINF_DBG, "Handling PMKSA key\n");
2028
73b2e381 2029 pu8keybuf = kmalloc((pstrHostIFkeyAttr->attr.pmkid.numpmkid * PMKSA_KEY_LEN) + 1, GFP_KERNEL);
c5c77ba1
JK
2030 if (pu8keybuf == NULL) {
2031 PRINT_ER("No buffer to send PMKSA Key\n");
2032 return -1;
2033 }
2034
73b2e381 2035 pu8keybuf[0] = pstrHostIFkeyAttr->attr.pmkid.numpmkid;
c5c77ba1 2036
73b2e381
LK
2037 for (i = 0; i < pstrHostIFkeyAttr->attr.pmkid.numpmkid; i++) {
2038 memcpy(pu8keybuf + ((PMKSA_KEY_LEN * i) + 1), pstrHostIFkeyAttr->attr.pmkid.pmkidlist[i].bssid, ETH_ALEN);
2039 memcpy(pu8keybuf + ((PMKSA_KEY_LEN * i) + ETH_ALEN + 1), pstrHostIFkeyAttr->attr.pmkid.pmkidlist[i].pmkid, PMKID_LEN);
c5c77ba1
JK
2040 }
2041
daaf16ba 2042 strWID.id = (u16)WID_PMKID_INFO;
416d8321 2043 strWID.type = WID_STR;
900bb4a6 2044 strWID.val = (s8 *)pu8keybuf;
73b2e381 2045 strWID.size = (pstrHostIFkeyAttr->attr.pmkid.numpmkid * PMKSA_KEY_LEN) + 1;
c5c77ba1 2046
03362286 2047 s32Error = send_config_pkt(SET_CFG, &strWID, 1,
a4ab1ade 2048 get_id_from_handler(hif_drv));
c5c77ba1 2049
49188af2 2050 kfree(pu8keybuf);
c5c77ba1
JK
2051 break;
2052 }
2053
2054 if (s32Error)
2055 PRINT_ER("Failed to send key config packet\n");
2056
2057
2058 return s32Error;
2059}
2060
a4ab1ade 2061static void Handle_Disconnect(struct host_if_drv *hif_drv)
c5c77ba1 2062{
e9e0c260 2063 struct wid strWID;
c5c77ba1 2064
e6e12661 2065 s32 s32Error = 0;
d85f5326 2066 u16 u16DummyReasonCode = 0;
c5c77ba1 2067
daaf16ba 2068 strWID.id = (u16)WID_DISCONNECT;
416d8321 2069 strWID.type = WID_CHAR;
900bb4a6 2070 strWID.val = (s8 *)&u16DummyReasonCode;
2fd3e443 2071 strWID.size = sizeof(char);
c5c77ba1
JK
2072
2073
2074
2075 PRINT_D(HOSTINF_DBG, "Sending disconnect request\n");
2076
72ed4dc7 2077 g_obtainingIP = false;
a4ab1ade 2078 host_int_set_power_mgmt(hif_drv, 0, 0);
c5c77ba1 2079
281dd5ac 2080 eth_zero_addr(u8ConnectedSSID);
c5c77ba1 2081
03362286 2082 s32Error = send_config_pkt(SET_CFG, &strWID, 1,
a4ab1ade 2083 get_id_from_handler(hif_drv));
c5c77ba1
JK
2084
2085 if (s32Error) {
2086 PRINT_ER("Failed to send dissconect config packet\n");
c5c77ba1
JK
2087 } else {
2088 tstrDisconnectNotifInfo strDisconnectNotifInfo;
2089
2cc46837 2090 memset(&strDisconnectNotifInfo, 0, sizeof(tstrDisconnectNotifInfo));
c5c77ba1
JK
2091
2092 strDisconnectNotifInfo.u16reason = 0;
2093 strDisconnectNotifInfo.ie = NULL;
2094 strDisconnectNotifInfo.ie_len = 0;
2095
a4ab1ade
TC
2096 if (hif_drv->strWILC_UsrScanReq.pfUserScanResult) {
2097 del_timer(&hif_drv->hScanTimer);
2098 hif_drv->strWILC_UsrScanReq.pfUserScanResult(SCAN_EVENT_ABORTED, NULL,
2099 hif_drv->strWILC_UsrScanReq.u32UserScanPvoid, NULL);
c5c77ba1 2100
a4ab1ade 2101 hif_drv->strWILC_UsrScanReq.pfUserScanResult = NULL;
c5c77ba1
JK
2102 }
2103
a4ab1ade 2104 if (hif_drv->strWILC_UsrConnReq.pfUserConnectResult != NULL) {
a4ab1ade 2105 if (hif_drv->enuHostIFstate == HOST_IF_WAITING_CONN_RESP) {
c5c77ba1 2106 PRINT_D(HOSTINF_DBG, "Upper layer requested termination of connection\n");
a4ab1ade 2107 del_timer(&hif_drv->hConnectTimer);
c5c77ba1
JK
2108 }
2109
a4ab1ade
TC
2110 hif_drv->strWILC_UsrConnReq.pfUserConnectResult(CONN_DISCONN_EVENT_DISCONN_NOTIF, NULL,
2111 0, &strDisconnectNotifInfo, hif_drv->strWILC_UsrConnReq.u32UserConnectPvoid);
c5c77ba1 2112 } else {
03b2d5e7 2113 PRINT_ER("strWILC_UsrConnReq.pfUserConnectResult = NULL\n");
c5c77ba1
JK
2114 }
2115
72ed4dc7 2116 gbScanWhileConnected = false;
c5c77ba1 2117
a4ab1ade 2118 hif_drv->enuHostIFstate = HOST_IF_IDLE;
c5c77ba1 2119
a4ab1ade 2120 eth_zero_addr(hif_drv->au8AssociatedBSSID);
c5c77ba1 2121
a4ab1ade
TC
2122 hif_drv->strWILC_UsrConnReq.ssidLen = 0;
2123 kfree(hif_drv->strWILC_UsrConnReq.pu8ssid);
2124 kfree(hif_drv->strWILC_UsrConnReq.pu8bssid);
2125 hif_drv->strWILC_UsrConnReq.ConnReqIEsLen = 0;
2126 kfree(hif_drv->strWILC_UsrConnReq.pu8ConnReqIEs);
c5c77ba1 2127
a4ab1ade 2128 if (gu8FlushedJoinReq != NULL && gu8FlushedJoinReqDrvHandler == hif_drv) {
49188af2 2129 kfree(gu8FlushedJoinReq);
c5c77ba1
JK
2130 gu8FlushedJoinReq = NULL;
2131 }
a4ab1ade 2132 if (gu8FlushedInfoElemAsoc != NULL && gu8FlushedJoinReqDrvHandler == hif_drv) {
49188af2 2133 kfree(gu8FlushedInfoElemAsoc);
c5c77ba1
JK
2134 gu8FlushedInfoElemAsoc = NULL;
2135 }
2136
2137 }
2138
a4ab1ade 2139 up(&hif_drv->hSemTestDisconnectBlock);
c5c77ba1
JK
2140}
2141
2142
a4ab1ade 2143void resolve_disconnect_aberration(struct host_if_drv *hif_drv)
c5c77ba1 2144{
a4ab1ade 2145 if (!hif_drv)
c5c77ba1 2146 return;
a4ab1ade 2147 if ((hif_drv->enuHostIFstate == HOST_IF_WAITING_CONN_RESP) || (hif_drv->enuHostIFstate == HOST_IF_CONNECTING)) {
c5c77ba1 2148 PRINT_D(HOSTINF_DBG, "\n\n<< correcting Supplicant state machine >>\n\n");
a4ab1ade 2149 host_int_disconnect(hif_drv, 1);
c5c77ba1
JK
2150 }
2151}
c5c77ba1 2152
a4ab1ade 2153static s32 Handle_GetChnl(struct host_if_drv *hif_drv)
c5c77ba1
JK
2154{
2155
e6e12661 2156 s32 s32Error = 0;
e9e0c260 2157 struct wid strWID;
78c87591 2158
daaf16ba 2159 strWID.id = (u16)WID_CURRENT_CHANNEL;
416d8321 2160 strWID.type = WID_CHAR;
900bb4a6 2161 strWID.val = (s8 *)&gu8Chnl;
2fd3e443 2162 strWID.size = sizeof(char);
c5c77ba1
JK
2163
2164 PRINT_D(HOSTINF_DBG, "Getting channel value\n");
2165
03362286 2166 s32Error = send_config_pkt(GET_CFG, &strWID, 1,
a4ab1ade 2167 get_id_from_handler(hif_drv));
ae4dfa57 2168
c5c77ba1
JK
2169 if (s32Error) {
2170 PRINT_ER("Failed to get channel number\n");
24db713f 2171 s32Error = -EFAULT;
c5c77ba1
JK
2172 }
2173
a4ab1ade 2174 up(&hif_drv->hSemGetCHNL);
c5c77ba1
JK
2175
2176 return s32Error;
2177
2178
2179
2180}
2181
a4ab1ade 2182static void Handle_GetRssi(struct host_if_drv *hif_drv)
c5c77ba1 2183{
e6e12661 2184 s32 s32Error = 0;
e9e0c260 2185 struct wid strWID;
c5c77ba1 2186
daaf16ba 2187 strWID.id = (u16)WID_RSSI;
416d8321 2188 strWID.type = WID_CHAR;
900bb4a6 2189 strWID.val = &gs8Rssi;
2fd3e443 2190 strWID.size = sizeof(char);
c5c77ba1 2191
c5c77ba1
JK
2192 PRINT_D(HOSTINF_DBG, "Getting RSSI value\n");
2193
03362286 2194 s32Error = send_config_pkt(GET_CFG, &strWID, 1,
a4ab1ade 2195 get_id_from_handler(hif_drv));
c5c77ba1
JK
2196 if (s32Error) {
2197 PRINT_ER("Failed to get RSSI value\n");
24db713f 2198 s32Error = -EFAULT;
c5c77ba1
JK
2199 }
2200
a4ab1ade 2201 up(&hif_drv->hSemGetRSSI);
c5c77ba1
JK
2202
2203
2204}
2205
2206
a4ab1ade 2207static void Handle_GetLinkspeed(struct host_if_drv *hif_drv)
c5c77ba1 2208{
e6e12661 2209 s32 s32Error = 0;
e9e0c260 2210 struct wid strWID;
c5c77ba1
JK
2211
2212 gs8lnkspd = 0;
2213
daaf16ba 2214 strWID.id = (u16)WID_LINKSPEED;
416d8321 2215 strWID.type = WID_CHAR;
900bb4a6 2216 strWID.val = &gs8lnkspd;
2fd3e443 2217 strWID.size = sizeof(char);
ae4dfa57 2218
c5c77ba1
JK
2219 PRINT_D(HOSTINF_DBG, "Getting LINKSPEED value\n");
2220
03362286 2221 s32Error = send_config_pkt(GET_CFG, &strWID, 1,
a4ab1ade 2222 get_id_from_handler(hif_drv));
c5c77ba1
JK
2223 if (s32Error) {
2224 PRINT_ER("Failed to get LINKSPEED value\n");
24db713f 2225 s32Error = -EFAULT;
c5c77ba1
JK
2226 }
2227
a4ab1ade 2228 up(&(hif_drv->hSemGetLINKSPEED));
c5c77ba1
JK
2229
2230
2231}
2232
a4ab1ade 2233s32 Handle_GetStatistics(struct host_if_drv *hif_drv, struct rf_info *pstrStatistics)
c5c77ba1 2234{
e9e0c260 2235 struct wid strWIDList[5];
fbc2fe16 2236 u32 u32WidsCount = 0, s32Error = 0;
c5c77ba1 2237
daaf16ba 2238 strWIDList[u32WidsCount].id = WID_LINKSPEED;
416d8321 2239 strWIDList[u32WidsCount].type = WID_CHAR;
2fd3e443 2240 strWIDList[u32WidsCount].size = sizeof(char);
900bb4a6 2241 strWIDList[u32WidsCount].val = (s8 *)(&(pstrStatistics->u8LinkSpeed));
c5c77ba1
JK
2242 u32WidsCount++;
2243
daaf16ba 2244 strWIDList[u32WidsCount].id = WID_RSSI;
416d8321 2245 strWIDList[u32WidsCount].type = WID_CHAR;
2fd3e443 2246 strWIDList[u32WidsCount].size = sizeof(char);
900bb4a6 2247 strWIDList[u32WidsCount].val = (s8 *)(&(pstrStatistics->s8RSSI));
c5c77ba1
JK
2248 u32WidsCount++;
2249
daaf16ba 2250 strWIDList[u32WidsCount].id = WID_SUCCESS_FRAME_COUNT;
416d8321 2251 strWIDList[u32WidsCount].type = WID_INT;
2fd3e443 2252 strWIDList[u32WidsCount].size = sizeof(u32);
900bb4a6 2253 strWIDList[u32WidsCount].val = (s8 *)(&(pstrStatistics->u32TxCount));
c5c77ba1
JK
2254 u32WidsCount++;
2255
daaf16ba 2256 strWIDList[u32WidsCount].id = WID_RECEIVED_FRAGMENT_COUNT;
416d8321 2257 strWIDList[u32WidsCount].type = WID_INT;
2fd3e443 2258 strWIDList[u32WidsCount].size = sizeof(u32);
900bb4a6 2259 strWIDList[u32WidsCount].val = (s8 *)(&(pstrStatistics->u32RxCount));
c5c77ba1
JK
2260 u32WidsCount++;
2261
daaf16ba 2262 strWIDList[u32WidsCount].id = WID_FAILED_COUNT;
416d8321 2263 strWIDList[u32WidsCount].type = WID_INT;
2fd3e443 2264 strWIDList[u32WidsCount].size = sizeof(u32);
900bb4a6 2265 strWIDList[u32WidsCount].val = (s8 *)(&(pstrStatistics->u32TxFailureCount));
c5c77ba1
JK
2266 u32WidsCount++;
2267
03362286 2268 s32Error = send_config_pkt(GET_CFG, strWIDList, u32WidsCount,
a4ab1ade 2269 get_id_from_handler(hif_drv));
c5c77ba1 2270
24db713f 2271 if (s32Error)
c5c77ba1 2272 PRINT_ER("Failed to send scan paramters config packet\n");
24db713f 2273
83383ea3 2274 up(&hWaitResponse);
c5c77ba1
JK
2275 return 0;
2276
2277}
2278
a4ab1ade 2279static s32 Handle_Get_InActiveTime(struct host_if_drv *hif_drv,
3d1eac04 2280 struct sta_inactive_t *strHostIfStaInactiveT)
c5c77ba1
JK
2281{
2282
e6e12661 2283 s32 s32Error = 0;
63d03e47 2284 u8 *stamac;
e9e0c260 2285 struct wid strWID;
c5c77ba1 2286
daaf16ba 2287 strWID.id = (u16)WID_SET_STA_MAC_INACTIVE_TIME;
416d8321 2288 strWID.type = WID_STR;
2fd3e443 2289 strWID.size = ETH_ALEN;
900bb4a6 2290 strWID.val = kmalloc(strWID.size, GFP_KERNEL);
c5c77ba1
JK
2291
2292
900bb4a6 2293 stamac = strWID.val;
d00d2ba3 2294 memcpy(stamac, strHostIfStaInactiveT->mac, ETH_ALEN);
c5c77ba1
JK
2295
2296
2297 PRINT_D(CFG80211_DBG, "SETING STA inactive time\n");
2298
2299
03362286 2300 s32Error = send_config_pkt(SET_CFG, &strWID, 1,
a4ab1ade 2301 get_id_from_handler(hif_drv));
ae4dfa57 2302
c5c77ba1
JK
2303 if (s32Error) {
2304 PRINT_ER("Failed to SET incative time\n");
24db713f 2305 return -EFAULT;
c5c77ba1
JK
2306 }
2307
2308
daaf16ba 2309 strWID.id = (u16)WID_GET_INACTIVE_TIME;
416d8321 2310 strWID.type = WID_INT;
900bb4a6 2311 strWID.val = (s8 *)&gu32InactiveTime;
2fd3e443 2312 strWID.size = sizeof(u32);
c5c77ba1
JK
2313
2314
03362286 2315 s32Error = send_config_pkt(GET_CFG, &strWID, 1,
a4ab1ade 2316 get_id_from_handler(hif_drv));
ae4dfa57 2317
c5c77ba1
JK
2318 if (s32Error) {
2319 PRINT_ER("Failed to get incative time\n");
24db713f 2320 return -EFAULT;
c5c77ba1
JK
2321 }
2322
2323
2324 PRINT_D(CFG80211_DBG, "Getting inactive time : %d\n", gu32InactiveTime);
2325
a4ab1ade 2326 up(&hif_drv->hSemInactiveTime);
c5c77ba1
JK
2327
2328 return s32Error;
2329
2330
2331
2332}
2333
a4ab1ade 2334static void Handle_AddBeacon(struct host_if_drv *hif_drv,
7f33fecd 2335 struct beacon_attr *pstrSetBeaconParam)
c5c77ba1 2336{
e6e12661 2337 s32 s32Error = 0;
e9e0c260 2338 struct wid strWID;
63d03e47 2339 u8 *pu8CurrByte;
78c87591 2340
c5c77ba1
JK
2341 PRINT_D(HOSTINF_DBG, "Adding BEACON\n");
2342
daaf16ba 2343 strWID.id = (u16)WID_ADD_BEACON;
416d8321 2344 strWID.type = WID_BIN;
2fd3e443 2345 strWID.size = pstrSetBeaconParam->u32HeadLen + pstrSetBeaconParam->u32TailLen + 16;
900bb4a6
LK
2346 strWID.val = kmalloc(strWID.size, GFP_KERNEL);
2347 if (strWID.val == NULL)
24db713f 2348 goto ERRORHANDLER;
c5c77ba1 2349
900bb4a6 2350 pu8CurrByte = strWID.val;
c5c77ba1
JK
2351 *pu8CurrByte++ = (pstrSetBeaconParam->u32Interval & 0xFF);
2352 *pu8CurrByte++ = ((pstrSetBeaconParam->u32Interval >> 8) & 0xFF);
2353 *pu8CurrByte++ = ((pstrSetBeaconParam->u32Interval >> 16) & 0xFF);
2354 *pu8CurrByte++ = ((pstrSetBeaconParam->u32Interval >> 24) & 0xFF);
2355
2356 *pu8CurrByte++ = (pstrSetBeaconParam->u32DTIMPeriod & 0xFF);
2357 *pu8CurrByte++ = ((pstrSetBeaconParam->u32DTIMPeriod >> 8) & 0xFF);
2358 *pu8CurrByte++ = ((pstrSetBeaconParam->u32DTIMPeriod >> 16) & 0xFF);
2359 *pu8CurrByte++ = ((pstrSetBeaconParam->u32DTIMPeriod >> 24) & 0xFF);
2360
2361 *pu8CurrByte++ = (pstrSetBeaconParam->u32HeadLen & 0xFF);
2362 *pu8CurrByte++ = ((pstrSetBeaconParam->u32HeadLen >> 8) & 0xFF);
2363 *pu8CurrByte++ = ((pstrSetBeaconParam->u32HeadLen >> 16) & 0xFF);
2364 *pu8CurrByte++ = ((pstrSetBeaconParam->u32HeadLen >> 24) & 0xFF);
2365
2366 memcpy(pu8CurrByte, pstrSetBeaconParam->pu8Head, pstrSetBeaconParam->u32HeadLen);
2367 pu8CurrByte += pstrSetBeaconParam->u32HeadLen;
2368
2369 *pu8CurrByte++ = (pstrSetBeaconParam->u32TailLen & 0xFF);
2370 *pu8CurrByte++ = ((pstrSetBeaconParam->u32TailLen >> 8) & 0xFF);
2371 *pu8CurrByte++ = ((pstrSetBeaconParam->u32TailLen >> 16) & 0xFF);
2372 *pu8CurrByte++ = ((pstrSetBeaconParam->u32TailLen >> 24) & 0xFF);
2373
c5c77ba1
JK
2374 if (pstrSetBeaconParam->pu8Tail > 0)
2375 memcpy(pu8CurrByte, pstrSetBeaconParam->pu8Tail, pstrSetBeaconParam->u32TailLen);
2376 pu8CurrByte += pstrSetBeaconParam->u32TailLen;
2377
03362286 2378 s32Error = send_config_pkt(SET_CFG, &strWID, 1,
a4ab1ade 2379 get_id_from_handler(hif_drv));
24db713f 2380 if (s32Error)
c5c77ba1 2381 PRINT_ER("Failed to send add beacon config packet\n");
c5c77ba1 2382
24db713f 2383ERRORHANDLER:
900bb4a6 2384 kfree(strWID.val);
969effe9
GKH
2385 kfree(pstrSetBeaconParam->pu8Head);
2386 kfree(pstrSetBeaconParam->pu8Tail);
c5c77ba1
JK
2387}
2388
a4ab1ade 2389static void Handle_DelBeacon(struct host_if_drv *hif_drv)
c5c77ba1 2390{
e6e12661 2391 s32 s32Error = 0;
e9e0c260 2392 struct wid strWID;
63d03e47 2393 u8 *pu8CurrByte;
78c87591 2394
daaf16ba 2395 strWID.id = (u16)WID_DEL_BEACON;
416d8321 2396 strWID.type = WID_CHAR;
2fd3e443 2397 strWID.size = sizeof(char);
900bb4a6 2398 strWID.val = &gu8DelBcn;
c5c77ba1 2399
900bb4a6 2400 if (strWID.val == NULL)
24db713f 2401 return;
c5c77ba1 2402
900bb4a6 2403 pu8CurrByte = strWID.val;
c5c77ba1
JK
2404
2405 PRINT_D(HOSTINF_DBG, "Deleting BEACON\n");
c5c77ba1 2406
03362286 2407 s32Error = send_config_pkt(SET_CFG, &strWID, 1,
a4ab1ade 2408 get_id_from_handler(hif_drv));
24db713f 2409 if (s32Error)
c5c77ba1 2410 PRINT_ER("Failed to send delete beacon config packet\n");
c5c77ba1
JK
2411}
2412
6a89ba9c
TC
2413static u32 WILC_HostIf_PackStaParam(u8 *pu8Buffer,
2414 struct add_sta_param *pstrStationParam)
c5c77ba1 2415{
63d03e47 2416 u8 *pu8CurrByte;
c5c77ba1
JK
2417
2418 pu8CurrByte = pu8Buffer;
2419
2420 PRINT_D(HOSTINF_DBG, "Packing STA params\n");
d00d2ba3 2421 memcpy(pu8CurrByte, pstrStationParam->au8BSSID, ETH_ALEN);
c5c77ba1
JK
2422 pu8CurrByte += ETH_ALEN;
2423
2424 *pu8CurrByte++ = pstrStationParam->u16AssocID & 0xFF;
2425 *pu8CurrByte++ = (pstrStationParam->u16AssocID >> 8) & 0xFF;
2426
2427 *pu8CurrByte++ = pstrStationParam->u8NumRates;
2b9d5b48 2428 if (pstrStationParam->u8NumRates > 0)
d00d2ba3 2429 memcpy(pu8CurrByte, pstrStationParam->pu8Rates, pstrStationParam->u8NumRates);
c5c77ba1
JK
2430 pu8CurrByte += pstrStationParam->u8NumRates;
2431
2432 *pu8CurrByte++ = pstrStationParam->bIsHTSupported;
2433 *pu8CurrByte++ = pstrStationParam->u16HTCapInfo & 0xFF;
2434 *pu8CurrByte++ = (pstrStationParam->u16HTCapInfo >> 8) & 0xFF;
2435
2436 *pu8CurrByte++ = pstrStationParam->u8AmpduParams;
d00d2ba3 2437 memcpy(pu8CurrByte, pstrStationParam->au8SuppMCsSet, WILC_SUPP_MCS_SET_SIZE);
c5c77ba1
JK
2438 pu8CurrByte += WILC_SUPP_MCS_SET_SIZE;
2439
2440 *pu8CurrByte++ = pstrStationParam->u16HTExtParams & 0xFF;
2441 *pu8CurrByte++ = (pstrStationParam->u16HTExtParams >> 8) & 0xFF;
2442
2443 *pu8CurrByte++ = pstrStationParam->u32TxBeamformingCap & 0xFF;
2444 *pu8CurrByte++ = (pstrStationParam->u32TxBeamformingCap >> 8) & 0xFF;
2445 *pu8CurrByte++ = (pstrStationParam->u32TxBeamformingCap >> 16) & 0xFF;
2446 *pu8CurrByte++ = (pstrStationParam->u32TxBeamformingCap >> 24) & 0xFF;
2447
2448 *pu8CurrByte++ = pstrStationParam->u8ASELCap;
2449
2450 *pu8CurrByte++ = pstrStationParam->u16FlagsMask & 0xFF;
2451 *pu8CurrByte++ = (pstrStationParam->u16FlagsMask >> 8) & 0xFF;
2452
2453 *pu8CurrByte++ = pstrStationParam->u16FlagsSet & 0xFF;
2454 *pu8CurrByte++ = (pstrStationParam->u16FlagsSet >> 8) & 0xFF;
2455
2456 return pu8CurrByte - pu8Buffer;
2457}
2458
a4ab1ade 2459static void Handle_AddStation(struct host_if_drv *hif_drv,
6a89ba9c 2460 struct add_sta_param *pstrStationParam)
c5c77ba1 2461{
e6e12661 2462 s32 s32Error = 0;
e9e0c260 2463 struct wid strWID;
63d03e47 2464 u8 *pu8CurrByte;
78c87591 2465
c5c77ba1 2466 PRINT_D(HOSTINF_DBG, "Handling add station\n");
daaf16ba 2467 strWID.id = (u16)WID_ADD_STA;
416d8321 2468 strWID.type = WID_BIN;
2fd3e443 2469 strWID.size = WILC_ADD_STA_LENGTH + pstrStationParam->u8NumRates;
c5c77ba1 2470
900bb4a6
LK
2471 strWID.val = kmalloc(strWID.size, GFP_KERNEL);
2472 if (strWID.val == NULL)
24db713f 2473 goto ERRORHANDLER;
c5c77ba1 2474
900bb4a6 2475 pu8CurrByte = strWID.val;
c5c77ba1
JK
2476 pu8CurrByte += WILC_HostIf_PackStaParam(pu8CurrByte, pstrStationParam);
2477
03362286 2478 s32Error = send_config_pkt(SET_CFG, &strWID, 1,
a4ab1ade 2479 get_id_from_handler(hif_drv));
e6e12661 2480 if (s32Error != 0)
c5c77ba1 2481 PRINT_ER("Failed to send add station config packet\n");
c5c77ba1 2482
24db713f 2483ERRORHANDLER:
969effe9 2484 kfree(pstrStationParam->pu8Rates);
900bb4a6 2485 kfree(strWID.val);
c5c77ba1
JK
2486}
2487
a4ab1ade 2488static void Handle_DelAllSta(struct host_if_drv *hif_drv,
b4e644e4 2489 struct del_all_sta *pstrDelAllStaParam)
c5c77ba1 2490{
e6e12661 2491 s32 s32Error = 0;
78c87591 2492
e9e0c260 2493 struct wid strWID;
63d03e47 2494 u8 *pu8CurrByte;
63d03e47 2495 u8 i;
3703480b 2496 u8 au8Zero_Buff[6] = {0};
78c87591 2497
daaf16ba 2498 strWID.id = (u16)WID_DEL_ALL_STA;
416d8321 2499 strWID.type = WID_STR;
2fd3e443 2500 strWID.size = (pstrDelAllStaParam->u8Num_AssocSta * ETH_ALEN) + 1;
c5c77ba1 2501
03b2d5e7 2502 PRINT_D(HOSTINF_DBG, "Handling delete station\n");
c5c77ba1 2503
900bb4a6
LK
2504 strWID.val = kmalloc((pstrDelAllStaParam->u8Num_AssocSta * ETH_ALEN) + 1, GFP_KERNEL);
2505 if (strWID.val == NULL)
24db713f 2506 goto ERRORHANDLER;
c5c77ba1 2507
900bb4a6 2508 pu8CurrByte = strWID.val;
c5c77ba1
JK
2509
2510 *(pu8CurrByte++) = pstrDelAllStaParam->u8Num_AssocSta;
2511
2512 for (i = 0; i < MAX_NUM_STA; i++) {
2513 if (memcmp(pstrDelAllStaParam->au8Sta_DelAllSta[i], au8Zero_Buff, ETH_ALEN))
d00d2ba3 2514 memcpy(pu8CurrByte, pstrDelAllStaParam->au8Sta_DelAllSta[i], ETH_ALEN);
c5c77ba1
JK
2515 else
2516 continue;
2517
2518 pu8CurrByte += ETH_ALEN;
2519 }
2520
03362286 2521 s32Error = send_config_pkt(SET_CFG, &strWID, 1,
a4ab1ade 2522 get_id_from_handler(hif_drv));
24db713f 2523 if (s32Error)
83cc9be5 2524 PRINT_ER("Failed to send add station config packet\n");
c5c77ba1 2525
24db713f 2526ERRORHANDLER:
900bb4a6 2527 kfree(strWID.val);
c5c77ba1 2528
83383ea3 2529 up(&hWaitResponse);
c5c77ba1
JK
2530}
2531
a4ab1ade 2532static void Handle_DelStation(struct host_if_drv *hif_drv,
fb93a1e1 2533 struct del_sta *pstrDelStaParam)
c5c77ba1 2534{
e6e12661 2535 s32 s32Error = 0;
e9e0c260 2536 struct wid strWID;
63d03e47 2537 u8 *pu8CurrByte;
c5c77ba1 2538
daaf16ba 2539 strWID.id = (u16)WID_REMOVE_STA;
416d8321 2540 strWID.type = WID_BIN;
2fd3e443 2541 strWID.size = ETH_ALEN;
c5c77ba1 2542
03b2d5e7 2543 PRINT_D(HOSTINF_DBG, "Handling delete station\n");
c5c77ba1 2544
900bb4a6
LK
2545 strWID.val = kmalloc(strWID.size, GFP_KERNEL);
2546 if (strWID.val == NULL)
24db713f 2547 goto ERRORHANDLER;
c5c77ba1 2548
900bb4a6 2549 pu8CurrByte = strWID.val;
c5c77ba1 2550
d00d2ba3 2551 memcpy(pu8CurrByte, pstrDelStaParam->au8MacAddr, ETH_ALEN);
c5c77ba1 2552
03362286 2553 s32Error = send_config_pkt(SET_CFG, &strWID, 1,
a4ab1ade 2554 get_id_from_handler(hif_drv));
24db713f 2555 if (s32Error)
83cc9be5 2556 PRINT_ER("Failed to send add station config packet\n");
c5c77ba1 2557
24db713f 2558ERRORHANDLER:
900bb4a6 2559 kfree(strWID.val);
c5c77ba1
JK
2560}
2561
a4ab1ade 2562static void Handle_EditStation(struct host_if_drv *hif_drv,
6a89ba9c 2563 struct add_sta_param *pstrStationParam)
c5c77ba1 2564{
e6e12661 2565 s32 s32Error = 0;
e9e0c260 2566 struct wid strWID;
63d03e47 2567 u8 *pu8CurrByte;
c5c77ba1 2568
daaf16ba 2569 strWID.id = (u16)WID_EDIT_STA;
416d8321 2570 strWID.type = WID_BIN;
2fd3e443 2571 strWID.size = WILC_ADD_STA_LENGTH + pstrStationParam->u8NumRates;
c5c77ba1
JK
2572
2573 PRINT_D(HOSTINF_DBG, "Handling edit station\n");
900bb4a6
LK
2574 strWID.val = kmalloc(strWID.size, GFP_KERNEL);
2575 if (strWID.val == NULL)
24db713f 2576 goto ERRORHANDLER;
c5c77ba1 2577
900bb4a6 2578 pu8CurrByte = strWID.val;
c5c77ba1
JK
2579 pu8CurrByte += WILC_HostIf_PackStaParam(pu8CurrByte, pstrStationParam);
2580
03362286 2581 s32Error = send_config_pkt(SET_CFG, &strWID, 1,
a4ab1ade 2582 get_id_from_handler(hif_drv));
24db713f 2583 if (s32Error)
c5c77ba1 2584 PRINT_ER("Failed to send edit station config packet\n");
c5c77ba1 2585
24db713f 2586ERRORHANDLER:
969effe9 2587 kfree(pstrStationParam->pu8Rates);
900bb4a6 2588 kfree(strWID.val);
c5c77ba1 2589}
c5c77ba1 2590
a4ab1ade 2591static int Handle_RemainOnChan(struct host_if_drv *hif_drv,
2f9c03f5 2592 struct remain_ch *pstrHostIfRemainOnChan)
c5c77ba1 2593{
e6e12661 2594 s32 s32Error = 0;
63d03e47 2595 u8 u8remain_on_chan_flag;
e9e0c260 2596 struct wid strWID;
c5c77ba1 2597
a4ab1ade
TC
2598 if (!hif_drv->u8RemainOnChan_pendingreq) {
2599 hif_drv->strHostIfRemainOnChan.pVoid = pstrHostIfRemainOnChan->pVoid;
2600 hif_drv->strHostIfRemainOnChan.pRemainOnChanExpired = pstrHostIfRemainOnChan->pRemainOnChanExpired;
2601 hif_drv->strHostIfRemainOnChan.pRemainOnChanReady = pstrHostIfRemainOnChan->pRemainOnChanReady;
2602 hif_drv->strHostIfRemainOnChan.u16Channel = pstrHostIfRemainOnChan->u16Channel;
2603 hif_drv->strHostIfRemainOnChan.u32ListenSessionID = pstrHostIfRemainOnChan->u32ListenSessionID;
c5c77ba1 2604 } else {
a4ab1ade 2605 pstrHostIfRemainOnChan->u16Channel = hif_drv->strHostIfRemainOnChan.u16Channel;
c5c77ba1
JK
2606 }
2607
a4ab1ade 2608 if (hif_drv->strWILC_UsrScanReq.pfUserScanResult != NULL) {
c5c77ba1 2609 PRINT_INFO(GENERIC_DBG, "Required to remain on chan while scanning return\n");
a4ab1ade 2610 hif_drv->u8RemainOnChan_pendingreq = 1;
24db713f
LK
2611 s32Error = -EBUSY;
2612 goto ERRORHANDLER;
c5c77ba1 2613 }
a4ab1ade 2614 if (hif_drv->enuHostIFstate == HOST_IF_WAITING_CONN_RESP) {
c5c77ba1 2615 PRINT_INFO(GENERIC_DBG, "Required to remain on chan while connecting return\n");
24db713f
LK
2616 s32Error = -EBUSY;
2617 goto ERRORHANDLER;
c5c77ba1
JK
2618 }
2619
c5c77ba1
JK
2620 if (g_obtainingIP || connecting) {
2621 PRINT_D(GENERIC_DBG, "[handle_scan]: Don't do obss scan until IP adresss is obtained\n");
24db713f
LK
2622 s32Error = -EBUSY;
2623 goto ERRORHANDLER;
c5c77ba1 2624 }
c5c77ba1
JK
2625
2626 PRINT_D(HOSTINF_DBG, "Setting channel :%d\n", pstrHostIfRemainOnChan->u16Channel);
2627
72ed4dc7 2628 u8remain_on_chan_flag = true;
daaf16ba 2629 strWID.id = (u16)WID_REMAIN_ON_CHAN;
416d8321 2630 strWID.type = WID_STR;
2fd3e443 2631 strWID.size = 2;
900bb4a6 2632 strWID.val = kmalloc(strWID.size, GFP_KERNEL);
c5c77ba1 2633
900bb4a6 2634 if (strWID.val == NULL) {
24db713f
LK
2635 s32Error = -ENOMEM;
2636 goto ERRORHANDLER;
2637 }
c5c77ba1 2638
900bb4a6
LK
2639 strWID.val[0] = u8remain_on_chan_flag;
2640 strWID.val[1] = (s8)pstrHostIfRemainOnChan->u16Channel;
c5c77ba1 2641
03362286 2642 s32Error = send_config_pkt(SET_CFG, &strWID, 1,
a4ab1ade 2643 get_id_from_handler(hif_drv));
e6e12661 2644 if (s32Error != 0)
c5c77ba1 2645 PRINT_ER("Failed to set remain on channel\n");
c5c77ba1 2646
24db713f 2647ERRORHANDLER:
c5c77ba1
JK
2648 {
2649 P2P_LISTEN_STATE = 1;
a4ab1ade
TC
2650 hif_drv->hRemainOnChannel.data = (unsigned long)hif_drv;
2651 mod_timer(&hif_drv->hRemainOnChannel,
9eb06643
GKH
2652 jiffies +
2653 msecs_to_jiffies(pstrHostIfRemainOnChan->u32duration));
c5c77ba1 2654
a4ab1ade
TC
2655 if (hif_drv->strHostIfRemainOnChan.pRemainOnChanReady)
2656 hif_drv->strHostIfRemainOnChan.pRemainOnChanReady(hif_drv->strHostIfRemainOnChan.pVoid);
c5c77ba1 2657
a4ab1ade
TC
2658 if (hif_drv->u8RemainOnChan_pendingreq)
2659 hif_drv->u8RemainOnChan_pendingreq = 0;
c5c77ba1
JK
2660 }
2661 return s32Error;
2662}
2663
a4ab1ade 2664static int Handle_RegisterFrame(struct host_if_drv *hif_drv,
bc37c5df 2665 struct reg_frame *pstrHostIfRegisterFrame)
c5c77ba1 2666{
e6e12661 2667 s32 s32Error = 0;
e9e0c260 2668 struct wid strWID;
63d03e47 2669 u8 *pu8CurrByte;
c5c77ba1
JK
2670
2671 PRINT_D(HOSTINF_DBG, "Handling frame register Flag : %d FrameType: %d\n", pstrHostIfRegisterFrame->bReg, pstrHostIfRegisterFrame->u16FrameType);
2672
daaf16ba 2673 strWID.id = (u16)WID_REGISTER_FRAME;
416d8321 2674 strWID.type = WID_STR;
900bb4a6
LK
2675 strWID.val = kmalloc(sizeof(u16) + 2, GFP_KERNEL);
2676 if (strWID.val == NULL)
24db713f 2677 return -ENOMEM;
c5c77ba1 2678
900bb4a6 2679 pu8CurrByte = strWID.val;
c5c77ba1
JK
2680
2681 *pu8CurrByte++ = pstrHostIfRegisterFrame->bReg;
2682 *pu8CurrByte++ = pstrHostIfRegisterFrame->u8Regid;
d00d2ba3 2683 memcpy(pu8CurrByte, &(pstrHostIfRegisterFrame->u16FrameType), sizeof(u16));
c5c77ba1
JK
2684
2685
2fd3e443 2686 strWID.size = sizeof(u16) + 2;
c5c77ba1 2687
03362286 2688 s32Error = send_config_pkt(SET_CFG, &strWID, 1,
a4ab1ade 2689 get_id_from_handler(hif_drv));
c5c77ba1
JK
2690 if (s32Error) {
2691 PRINT_ER("Failed to frame register config packet\n");
24db713f 2692 s32Error = -EINVAL;
c5c77ba1
JK
2693 }
2694
2695 return s32Error;
2696
2697}
2698
c5c77ba1 2699#define FALSE_FRMWR_CHANNEL 100
a4ab1ade 2700static u32 Handle_ListenStateExpired(struct host_if_drv *hif_drv,
2f9c03f5 2701 struct remain_ch *pstrHostIfRemainOnChan)
c5c77ba1 2702{
63d03e47 2703 u8 u8remain_on_chan_flag;
e9e0c260 2704 struct wid strWID;
e6e12661 2705 s32 s32Error = 0;
c5c77ba1
JK
2706
2707 PRINT_D(HOSTINF_DBG, "CANCEL REMAIN ON CHAN\n");
2708
c5c77ba1 2709 if (P2P_LISTEN_STATE) {
72ed4dc7 2710 u8remain_on_chan_flag = false;
daaf16ba 2711 strWID.id = (u16)WID_REMAIN_ON_CHAN;
416d8321 2712 strWID.type = WID_STR;
2fd3e443 2713 strWID.size = 2;
900bb4a6 2714 strWID.val = kmalloc(strWID.size, GFP_KERNEL);
c5c77ba1 2715
900bb4a6 2716 if (strWID.val == NULL)
c5c77ba1 2717 PRINT_ER("Failed to allocate memory\n");
c5c77ba1 2718
900bb4a6
LK
2719 strWID.val[0] = u8remain_on_chan_flag;
2720 strWID.val[1] = FALSE_FRMWR_CHANNEL;
c5c77ba1 2721
03362286 2722 s32Error = send_config_pkt(SET_CFG, &strWID, 1,
a4ab1ade 2723 get_id_from_handler(hif_drv));
e6e12661 2724 if (s32Error != 0) {
c5c77ba1
JK
2725 PRINT_ER("Failed to set remain on channel\n");
2726 goto _done_;
2727 }
2728
a4ab1ade
TC
2729 if (hif_drv->strHostIfRemainOnChan.pRemainOnChanExpired) {
2730 hif_drv->strHostIfRemainOnChan.pRemainOnChanExpired(hif_drv->strHostIfRemainOnChan.pVoid
c5c77ba1
JK
2731 , pstrHostIfRemainOnChan->u32ListenSessionID);
2732 }
2733 P2P_LISTEN_STATE = 0;
2734 } else {
2735 PRINT_D(GENERIC_DBG, "Not in listen state\n");
e6e12661 2736 s32Error = -EFAULT;
c5c77ba1
JK
2737 }
2738
2739_done_:
2740 return s32Error;
2741}
2742
93dee8ee 2743static void ListenTimerCB(unsigned long arg)
c5c77ba1 2744{
e6e12661 2745 s32 s32Error = 0;
143eb95a 2746 struct host_if_msg msg;
a4ab1ade 2747 struct host_if_drv *hif_drv = (struct host_if_drv *)arg;
ae4dfa57 2748
a4ab1ade 2749 del_timer(&hif_drv->hRemainOnChannel);
c5c77ba1 2750
143eb95a 2751 memset(&msg, 0, sizeof(struct host_if_msg));
a9f812a6 2752 msg.id = HOST_IF_MSG_LISTEN_TIMER_FIRED;
a4ab1ade
TC
2753 msg.drv = hif_drv;
2754 msg.body.remain_on_ch.u32ListenSessionID = hif_drv->strHostIfRemainOnChan.u32ListenSessionID;
c5c77ba1 2755
143eb95a 2756 s32Error = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
2b9d5b48 2757 if (s32Error)
24db713f 2758 PRINT_ER("wilc_mq_send fail\n");
c5c77ba1 2759}
c5c77ba1 2760
a4ab1ade 2761static void Handle_PowerManagement(struct host_if_drv *hif_drv,
5a008f1c 2762 struct power_mgmt_param *strPowerMgmtParam)
c5c77ba1 2763{
e6e12661 2764 s32 s32Error = 0;
e9e0c260 2765 struct wid strWID;
ca356ada 2766 s8 s8PowerMode;
78c87591 2767
daaf16ba 2768 strWID.id = (u16)WID_POWER_MANAGEMENT;
c5c77ba1 2769
78174ada 2770 if (strPowerMgmtParam->bIsEnabled == true)
c5c77ba1 2771 s8PowerMode = MIN_FAST_PS;
78174ada 2772 else
c5c77ba1 2773 s8PowerMode = NO_POWERSAVE;
c5c77ba1 2774 PRINT_D(HOSTINF_DBG, "Handling power mgmt to %d\n", s8PowerMode);
900bb4a6 2775 strWID.val = &s8PowerMode;
2fd3e443 2776 strWID.size = sizeof(char);
c5c77ba1
JK
2777
2778 PRINT_D(HOSTINF_DBG, "Handling Power Management\n");
2779
03362286 2780 s32Error = send_config_pkt(SET_CFG, &strWID, 1,
a4ab1ade 2781 get_id_from_handler(hif_drv));
24db713f 2782 if (s32Error)
c5c77ba1 2783 PRINT_ER("Failed to send power management config packet\n");
c5c77ba1
JK
2784}
2785
a4ab1ade 2786static void Handle_SetMulticastFilter(struct host_if_drv *hif_drv,
641210ac 2787 struct set_multicast *strHostIfSetMulti)
c5c77ba1 2788{
e6e12661 2789 s32 s32Error = 0;
e9e0c260 2790 struct wid strWID;
63d03e47 2791 u8 *pu8CurrByte;
c5c77ba1
JK
2792
2793 PRINT_D(HOSTINF_DBG, "Setup Multicast Filter\n");
2794
daaf16ba 2795 strWID.id = (u16)WID_SETUP_MULTICAST_FILTER;
416d8321 2796 strWID.type = WID_BIN;
2fd3e443 2797 strWID.size = sizeof(struct set_multicast) + ((strHostIfSetMulti->u32count) * ETH_ALEN);
900bb4a6
LK
2798 strWID.val = kmalloc(strWID.size, GFP_KERNEL);
2799 if (strWID.val == NULL)
24db713f 2800 goto ERRORHANDLER;
c5c77ba1 2801
900bb4a6 2802 pu8CurrByte = strWID.val;
c5c77ba1
JK
2803 *pu8CurrByte++ = (strHostIfSetMulti->bIsEnabled & 0xFF);
2804 *pu8CurrByte++ = ((strHostIfSetMulti->bIsEnabled >> 8) & 0xFF);
2805 *pu8CurrByte++ = ((strHostIfSetMulti->bIsEnabled >> 16) & 0xFF);
2806 *pu8CurrByte++ = ((strHostIfSetMulti->bIsEnabled >> 24) & 0xFF);
2807
2808 *pu8CurrByte++ = (strHostIfSetMulti->u32count & 0xFF);
2809 *pu8CurrByte++ = ((strHostIfSetMulti->u32count >> 8) & 0xFF);
2810 *pu8CurrByte++ = ((strHostIfSetMulti->u32count >> 16) & 0xFF);
2811 *pu8CurrByte++ = ((strHostIfSetMulti->u32count >> 24) & 0xFF);
2812
2813 if ((strHostIfSetMulti->u32count) > 0)
2814 memcpy(pu8CurrByte, gau8MulticastMacAddrList, ((strHostIfSetMulti->u32count) * ETH_ALEN));
2815
03362286 2816 s32Error = send_config_pkt(SET_CFG, &strWID, 1,
a4ab1ade 2817 get_id_from_handler(hif_drv));
24db713f 2818 if (s32Error)
c5c77ba1 2819 PRINT_ER("Failed to send setup multicast config packet\n");
c5c77ba1 2820
24db713f 2821ERRORHANDLER:
900bb4a6 2822 kfree(strWID.val);
c5c77ba1
JK
2823
2824}
2825
a4ab1ade 2826static s32 Handle_AddBASession(struct host_if_drv *hif_drv,
54265472 2827 struct ba_session_info *strHostIfBASessionInfo)
c5c77ba1 2828{
e6e12661 2829 s32 s32Error = 0;
e9e0c260 2830 struct wid strWID;
c5c77ba1
JK
2831 int AddbaTimeout = 100;
2832 char *ptr = NULL;
c5c77ba1 2833
03b2d5e7 2834 PRINT_D(HOSTINF_DBG, "Opening Block Ack session with\nBSSID = %.2x:%.2x:%.2x\nTID=%d\nBufferSize == %d\nSessionTimeOut = %d\n",
c5c77ba1
JK
2835 strHostIfBASessionInfo->au8Bssid[0],
2836 strHostIfBASessionInfo->au8Bssid[1],
2837 strHostIfBASessionInfo->au8Bssid[2],
2838 strHostIfBASessionInfo->u16BufferSize,
2839 strHostIfBASessionInfo->u16SessionTimeout,
2840 strHostIfBASessionInfo->u8Ted);
2841
daaf16ba 2842 strWID.id = (u16)WID_11E_P_ACTION_REQ;
416d8321 2843 strWID.type = WID_STR;
900bb4a6 2844 strWID.val = kmalloc(BLOCK_ACK_REQ_SIZE, GFP_KERNEL);
2fd3e443 2845 strWID.size = BLOCK_ACK_REQ_SIZE;
900bb4a6 2846 ptr = strWID.val;
c5c77ba1
JK
2847 *ptr++ = 0x14;
2848 *ptr++ = 0x3;
2849 *ptr++ = 0x0;
d00d2ba3 2850 memcpy(ptr, strHostIfBASessionInfo->au8Bssid, ETH_ALEN);
c5c77ba1
JK
2851 ptr += ETH_ALEN;
2852 *ptr++ = strHostIfBASessionInfo->u8Ted;
c5c77ba1 2853 *ptr++ = 1;
c5c77ba1
JK
2854 *ptr++ = (strHostIfBASessionInfo->u16BufferSize & 0xFF);
2855 *ptr++ = ((strHostIfBASessionInfo->u16BufferSize >> 16) & 0xFF);
c5c77ba1
JK
2856 *ptr++ = (strHostIfBASessionInfo->u16SessionTimeout & 0xFF);
2857 *ptr++ = ((strHostIfBASessionInfo->u16SessionTimeout >> 16) & 0xFF);
c5c77ba1
JK
2858 *ptr++ = (AddbaTimeout & 0xFF);
2859 *ptr++ = ((AddbaTimeout >> 16) & 0xFF);
c5c77ba1 2860 *ptr++ = 8;
c5c77ba1
JK
2861 *ptr++ = 0;
2862
03362286 2863 s32Error = send_config_pkt(SET_CFG, &strWID, 1,
a4ab1ade 2864 get_id_from_handler(hif_drv));
c5c77ba1
JK
2865 if (s32Error)
2866 PRINT_D(HOSTINF_DBG, "Couldn't open BA Session\n");
2867
2868
daaf16ba 2869 strWID.id = (u16)WID_11E_P_ACTION_REQ;
416d8321 2870 strWID.type = WID_STR;
2fd3e443 2871 strWID.size = 15;
900bb4a6 2872 ptr = strWID.val;
c5c77ba1
JK
2873 *ptr++ = 15;
2874 *ptr++ = 7;
2875 *ptr++ = 0x2;
d00d2ba3 2876 memcpy(ptr, strHostIfBASessionInfo->au8Bssid, ETH_ALEN);
c5c77ba1 2877 ptr += ETH_ALEN;
c5c77ba1 2878 *ptr++ = strHostIfBASessionInfo->u8Ted;
c5c77ba1 2879 *ptr++ = 8;
c5c77ba1
JK
2880 *ptr++ = (strHostIfBASessionInfo->u16BufferSize & 0xFF);
2881 *ptr++ = ((strHostIfBASessionInfo->u16SessionTimeout >> 16) & 0xFF);
c5c77ba1 2882 *ptr++ = 3;
03362286 2883 s32Error = send_config_pkt(SET_CFG, &strWID, 1,
a4ab1ade 2884 get_id_from_handler(hif_drv));
c5c77ba1 2885
900bb4a6
LK
2886 if (strWID.val != NULL)
2887 kfree(strWID.val);
c5c77ba1
JK
2888
2889 return s32Error;
2890
2891}
2892
a4ab1ade 2893static s32 Handle_DelAllRxBASessions(struct host_if_drv *hif_drv,
54265472 2894 struct ba_session_info *strHostIfBASessionInfo)
c5c77ba1 2895{
e6e12661 2896 s32 s32Error = 0;
e9e0c260 2897 struct wid strWID;
c5c77ba1 2898 char *ptr = NULL;
c5c77ba1 2899
03b2d5e7 2900 PRINT_D(GENERIC_DBG, "Delete Block Ack session with\nBSSID = %.2x:%.2x:%.2x\nTID=%d\n",
c5c77ba1
JK
2901 strHostIfBASessionInfo->au8Bssid[0],
2902 strHostIfBASessionInfo->au8Bssid[1],
2903 strHostIfBASessionInfo->au8Bssid[2],
2904 strHostIfBASessionInfo->u8Ted);
2905
daaf16ba 2906 strWID.id = (u16)WID_DEL_ALL_RX_BA;
416d8321 2907 strWID.type = WID_STR;
900bb4a6 2908 strWID.val = kmalloc(BLOCK_ACK_REQ_SIZE, GFP_KERNEL);
2fd3e443 2909 strWID.size = BLOCK_ACK_REQ_SIZE;
900bb4a6 2910 ptr = strWID.val;
c5c77ba1
JK
2911 *ptr++ = 0x14;
2912 *ptr++ = 0x3;
2913 *ptr++ = 0x2;
d00d2ba3 2914 memcpy(ptr, strHostIfBASessionInfo->au8Bssid, ETH_ALEN);
c5c77ba1
JK
2915 ptr += ETH_ALEN;
2916 *ptr++ = strHostIfBASessionInfo->u8Ted;
c5c77ba1 2917 *ptr++ = 0;
ae4dfa57 2918 *ptr++ = 32;
c5c77ba1 2919
03362286 2920 s32Error = send_config_pkt(SET_CFG, &strWID, 1,
a4ab1ade 2921 get_id_from_handler(hif_drv));
c5c77ba1
JK
2922 if (s32Error)
2923 PRINT_D(HOSTINF_DBG, "Couldn't delete BA Session\n");
2924
2925
900bb4a6
LK
2926 if (strWID.val != NULL)
2927 kfree(strWID.val);
c5c77ba1 2928
83383ea3 2929 up(&hWaitResponse);
c5c77ba1
JK
2930
2931 return s32Error;
2932
2933}
2934
1999bd52 2935static int hostIFthread(void *pvArg)
c5c77ba1 2936{
4e4467fd 2937 u32 u32Ret;
143eb95a 2938 struct host_if_msg msg;
a4ab1ade 2939 struct host_if_drv *hif_drv;
c5c77ba1 2940
143eb95a 2941 memset(&msg, 0, sizeof(struct host_if_msg));
c5c77ba1
JK
2942
2943 while (1) {
143eb95a 2944 wilc_mq_recv(&gMsgQHostIF, &msg, sizeof(struct host_if_msg), &u32Ret);
a4ab1ade 2945 hif_drv = (struct host_if_drv *)msg.drv;
a9f812a6 2946 if (msg.id == HOST_IF_MSG_EXIT) {
c5c77ba1
JK
2947 PRINT_D(GENERIC_DBG, "THREAD: Exiting HostIfThread\n");
2948 break;
2949 }
2950
c5c77ba1
JK
2951 if ((!g_wilc_initialized)) {
2952 PRINT_D(GENERIC_DBG, "--WAIT--");
80e29c7a 2953 usleep_range(200 * 1000, 200 * 1000);
143eb95a 2954 wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
c5c77ba1
JK
2955 continue;
2956 }
2957
a4ab1ade 2958 if (msg.id == HOST_IF_MSG_CONNECT && hif_drv->strWILC_UsrScanReq.pfUserScanResult != NULL) {
c5c77ba1 2959 PRINT_D(HOSTINF_DBG, "Requeue connect request till scan done received\n");
143eb95a 2960 wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
80e29c7a 2961 usleep_range(2 * 1000, 2 * 1000);
c5c77ba1
JK
2962 continue;
2963 }
2964
a9f812a6 2965 switch (msg.id) {
c5c77ba1
JK
2966 case HOST_IF_MSG_Q_IDLE:
2967 Handle_wait_msg_q_empty();
2968 break;
2969
2970 case HOST_IF_MSG_SCAN:
2482a79f 2971 Handle_Scan(msg.drv, &msg.body.scan_info);
c5c77ba1
JK
2972 break;
2973
2974 case HOST_IF_MSG_CONNECT:
2482a79f 2975 Handle_Connect(msg.drv, &msg.body.con_info);
c5c77ba1
JK
2976 break;
2977
c5c77ba1 2978 case HOST_IF_MSG_FLUSH_CONNECT:
2482a79f 2979 Handle_FlushConnect(msg.drv);
c5c77ba1
JK
2980 break;
2981
2982 case HOST_IF_MSG_RCVD_NTWRK_INFO:
2482a79f 2983 Handle_RcvdNtwrkInfo(msg.drv, &msg.body.net_info);
c5c77ba1
JK
2984 break;
2985
2986 case HOST_IF_MSG_RCVD_GNRL_ASYNC_INFO:
2482a79f 2987 Handle_RcvdGnrlAsyncInfo(msg.drv, &msg.body.async_info);
c5c77ba1
JK
2988 break;
2989
2990 case HOST_IF_MSG_KEY:
2482a79f 2991 Handle_Key(msg.drv, &msg.body.key_info);
c5c77ba1
JK
2992 break;
2993
2994 case HOST_IF_MSG_CFG_PARAMS:
2995
2482a79f 2996 Handle_CfgParam(msg.drv, &msg.body.cfg_info);
c5c77ba1
JK
2997 break;
2998
2999 case HOST_IF_MSG_SET_CHANNEL:
2482a79f 3000 Handle_SetChannel(msg.drv, &msg.body.channel_info);
c5c77ba1
JK
3001 break;
3002
3003 case HOST_IF_MSG_DISCONNECT:
2482a79f 3004 Handle_Disconnect(msg.drv);
c5c77ba1
JK
3005 break;
3006
3007 case HOST_IF_MSG_RCVD_SCAN_COMPLETE:
a4ab1ade 3008 del_timer(&hif_drv->hScanTimer);
c5c77ba1
JK
3009 PRINT_D(HOSTINF_DBG, "scan completed successfully\n");
3010
2b9d5b48 3011 if (!linux_wlan_get_num_conn_ifcs())
c5c77ba1 3012 chip_sleep_manually(INFINITE_SLEEP_TIME);
c5c77ba1 3013
2482a79f 3014 Handle_ScanDone(msg.drv, SCAN_EVENT_DONE);
c5c77ba1 3015
a4ab1ade 3016 if (hif_drv->u8RemainOnChan_pendingreq)
2482a79f 3017 Handle_RemainOnChan(msg.drv, &msg.body.remain_on_ch);
c5c77ba1
JK
3018
3019 break;
3020
3021 case HOST_IF_MSG_GET_RSSI:
2482a79f 3022 Handle_GetRssi(msg.drv);
c5c77ba1
JK
3023 break;
3024
3025 case HOST_IF_MSG_GET_LINKSPEED:
2482a79f 3026 Handle_GetLinkspeed(msg.drv);
c5c77ba1
JK
3027 break;
3028
3029 case HOST_IF_MSG_GET_STATISTICS:
03e7b9c4 3030 Handle_GetStatistics(msg.drv, (struct rf_info *)msg.body.data);
c5c77ba1
JK
3031 break;
3032
3033 case HOST_IF_MSG_GET_CHNL:
2482a79f 3034 Handle_GetChnl(msg.drv);
c5c77ba1
JK
3035 break;
3036
c5c77ba1 3037 case HOST_IF_MSG_ADD_BEACON:
2482a79f 3038 Handle_AddBeacon(msg.drv, &msg.body.beacon_info);
c5c77ba1
JK
3039 break;
3040
3041 case HOST_IF_MSG_DEL_BEACON:
2482a79f 3042 Handle_DelBeacon(msg.drv);
c5c77ba1
JK
3043 break;
3044
3045 case HOST_IF_MSG_ADD_STATION:
2482a79f 3046 Handle_AddStation(msg.drv, &msg.body.add_sta_info);
c5c77ba1
JK
3047 break;
3048
3049 case HOST_IF_MSG_DEL_STATION:
2482a79f 3050 Handle_DelStation(msg.drv, &msg.body.del_sta_info);
c5c77ba1
JK
3051 break;
3052
3053 case HOST_IF_MSG_EDIT_STATION:
2482a79f 3054 Handle_EditStation(msg.drv, &msg.body.edit_sta_info);
c5c77ba1
JK
3055 break;
3056
3057 case HOST_IF_MSG_GET_INACTIVETIME:
2482a79f 3058 Handle_Get_InActiveTime(msg.drv, &msg.body.mac_info);
c5c77ba1
JK
3059 break;
3060
c5c77ba1
JK
3061 case HOST_IF_MSG_SCAN_TIMER_FIRED:
3062 PRINT_D(HOSTINF_DBG, "Scan Timeout\n");
3063
2482a79f 3064 Handle_ScanDone(msg.drv, SCAN_EVENT_ABORTED);
c5c77ba1
JK
3065 break;
3066
3067 case HOST_IF_MSG_CONNECT_TIMER_FIRED:
03b2d5e7 3068 PRINT_D(HOSTINF_DBG, "Connect Timeout\n");
2482a79f 3069 Handle_ConnectTimeout(msg.drv);
c5c77ba1
JK
3070 break;
3071
3072 case HOST_IF_MSG_POWER_MGMT:
2482a79f 3073 Handle_PowerManagement(msg.drv, &msg.body.pwr_mgmt_info);
c5c77ba1
JK
3074 break;
3075
3076 case HOST_IF_MSG_SET_WFIDRV_HANDLER:
2482a79f 3077 Handle_SetWfiDrvHandler(msg.drv,
5e4377e6 3078 &msg.body.drv);
c5c77ba1
JK
3079 break;
3080
3081 case HOST_IF_MSG_SET_OPERATION_MODE:
2482a79f 3082 Handle_SetOperationMode(msg.drv, &msg.body.mode);
c5c77ba1
JK
3083 break;
3084
3085 case HOST_IF_MSG_SET_IPADDRESS:
3086 PRINT_D(HOSTINF_DBG, "HOST_IF_MSG_SET_IPADDRESS\n");
2482a79f 3087 Handle_set_IPAddress(msg.drv, msg.body.ip_info.au8IPAddr, msg.body.ip_info.idx);
c5c77ba1
JK
3088 break;
3089
3090 case HOST_IF_MSG_GET_IPADDRESS:
3091 PRINT_D(HOSTINF_DBG, "HOST_IF_MSG_SET_IPADDRESS\n");
2482a79f 3092 Handle_get_IPAddress(msg.drv, msg.body.ip_info.au8IPAddr, msg.body.ip_info.idx);
c5c77ba1
JK
3093 break;
3094
c5c77ba1 3095 case HOST_IF_MSG_SET_MAC_ADDRESS:
2482a79f 3096 Handle_SetMacAddress(msg.drv, &msg.body.set_mac_info);
c5c77ba1
JK
3097 break;
3098
c5c77ba1 3099 case HOST_IF_MSG_GET_MAC_ADDRESS:
2482a79f 3100 Handle_GetMacAddress(msg.drv, &msg.body.get_mac_info);
c5c77ba1
JK
3101 break;
3102
c5c77ba1
JK
3103 case HOST_IF_MSG_REMAIN_ON_CHAN:
3104 PRINT_D(HOSTINF_DBG, "HOST_IF_MSG_REMAIN_ON_CHAN\n");
2482a79f 3105 Handle_RemainOnChan(msg.drv, &msg.body.remain_on_ch);
c5c77ba1
JK
3106 break;
3107
3108 case HOST_IF_MSG_REGISTER_FRAME:
3109 PRINT_D(HOSTINF_DBG, "HOST_IF_MSG_REGISTER_FRAME\n");
2482a79f 3110 Handle_RegisterFrame(msg.drv, &msg.body.reg_frame);
c5c77ba1
JK
3111 break;
3112
3113 case HOST_IF_MSG_LISTEN_TIMER_FIRED:
2482a79f 3114 Handle_ListenStateExpired(msg.drv, &msg.body.remain_on_ch);
c5c77ba1
JK
3115 break;
3116
c5c77ba1
JK
3117 case HOST_IF_MSG_SET_MULTICAST_FILTER:
3118 PRINT_D(HOSTINF_DBG, "HOST_IF_MSG_SET_MULTICAST_FILTER\n");
2482a79f 3119 Handle_SetMulticastFilter(msg.drv, &msg.body.multicast_info);
c5c77ba1
JK
3120 break;
3121
c5c77ba1 3122 case HOST_IF_MSG_ADD_BA_SESSION:
2482a79f 3123 Handle_AddBASession(msg.drv, &msg.body.session_info);
c5c77ba1
JK
3124 break;
3125
3126 case HOST_IF_MSG_DEL_ALL_RX_BA_SESSIONS:
2482a79f 3127 Handle_DelAllRxBASessions(msg.drv, &msg.body.session_info);
c5c77ba1
JK
3128 break;
3129
3130 case HOST_IF_MSG_DEL_ALL_STA:
2482a79f 3131 Handle_DelAllSta(msg.drv, &msg.body.del_all_sta_info);
c5c77ba1
JK
3132 break;
3133
3134 default:
03b2d5e7 3135 PRINT_ER("[Host Interface] undefined Received Msg ID\n");
c5c77ba1
JK
3136 break;
3137 }
3138 }
3139
3140 PRINT_D(HOSTINF_DBG, "Releasing thread exit semaphore\n");
83383ea3 3141 up(&hSemHostIFthrdEnd);
1999bd52 3142 return 0;
c5c77ba1
JK
3143}
3144
93dee8ee 3145static void TimerCB_Scan(unsigned long arg)
c5c77ba1 3146{
93dee8ee 3147 void *pvArg = (void *)arg;
143eb95a 3148 struct host_if_msg msg;
c5c77ba1 3149
143eb95a 3150 memset(&msg, 0, sizeof(struct host_if_msg));
2482a79f 3151 msg.drv = pvArg;
a9f812a6 3152 msg.id = HOST_IF_MSG_SCAN_TIMER_FIRED;
c5c77ba1 3153
143eb95a 3154 wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
c5c77ba1
JK
3155}
3156
93dee8ee 3157static void TimerCB_Connect(unsigned long arg)
c5c77ba1 3158{
93dee8ee 3159 void *pvArg = (void *)arg;
143eb95a 3160 struct host_if_msg msg;
c5c77ba1 3161
143eb95a 3162 memset(&msg, 0, sizeof(struct host_if_msg));
2482a79f 3163 msg.drv = pvArg;
a9f812a6 3164 msg.id = HOST_IF_MSG_CONNECT_TIMER_FIRED;
c5c77ba1 3165
143eb95a 3166 wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
c5c77ba1
JK
3167}
3168
a4ab1ade 3169s32 host_int_remove_key(struct host_if_drv *hif_drv, const u8 *pu8StaAddress)
c5c77ba1 3170{
e9e0c260 3171 struct wid strWID;
c5c77ba1 3172
daaf16ba 3173 strWID.id = (u16)WID_REMOVE_KEY;
416d8321 3174 strWID.type = WID_STR;
900bb4a6 3175 strWID.val = (s8 *)pu8StaAddress;
2fd3e443 3176 strWID.size = 6;
c5c77ba1 3177
b68d820b 3178 return 0;
c5c77ba1
JK
3179}
3180
a4ab1ade 3181int host_int_remove_wep_key(struct host_if_drv *hif_drv, u8 index)
c5c77ba1 3182{
9e5e8b44 3183 int result = 0;
143eb95a 3184 struct host_if_msg msg;
c5c77ba1 3185
a4ab1ade 3186 if (!hif_drv) {
9e5e8b44 3187 result = -EFAULT;
24db713f 3188 PRINT_ER("Failed to send setup multicast config packet\n");
9e5e8b44 3189 return result;
24db713f 3190 }
c5c77ba1 3191
143eb95a 3192 memset(&msg, 0, sizeof(struct host_if_msg));
c5c77ba1 3193
a9f812a6 3194 msg.id = HOST_IF_MSG_KEY;
8e9f427a 3195 msg.body.key_info.type = WEP;
0d17e382 3196 msg.body.key_info.action = REMOVEKEY;
a4ab1ade 3197 msg.drv = hif_drv;
73b2e381 3198 msg.body.key_info.attr.wep.index = index;
c5c77ba1 3199
9e5e8b44
CL
3200 result = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
3201 if (result)
03b2d5e7 3202 PRINT_ER("Error in sending message queue : Request to remove WEP key\n");
a4ab1ade 3203 down(&hif_drv->hSemTestKeyBlock);
c5c77ba1 3204
9e5e8b44 3205 return result;
c5c77ba1
JK
3206}
3207
a4ab1ade 3208s32 host_int_set_WEPDefaultKeyID(struct host_if_drv *hif_drv, u8 u8Index)
c5c77ba1 3209{
e6e12661 3210 s32 s32Error = 0;
143eb95a 3211 struct host_if_msg msg;
c5c77ba1
JK
3212
3213
a4ab1ade 3214 if (!hif_drv) {
24db713f
LK
3215 s32Error = -EFAULT;
3216 PRINT_ER("driver is null\n");
3217 return s32Error;
3218 }
c5c77ba1 3219
143eb95a 3220 memset(&msg, 0, sizeof(struct host_if_msg));
c5c77ba1
JK
3221
3222
a9f812a6 3223 msg.id = HOST_IF_MSG_KEY;
8e9f427a 3224 msg.body.key_info.type = WEP;
0d17e382 3225 msg.body.key_info.action = DEFAULTKEY;
a4ab1ade 3226 msg.drv = hif_drv;
73b2e381 3227 msg.body.key_info.attr.wep.index = u8Index;
c5c77ba1 3228
143eb95a 3229 s32Error = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
c5c77ba1
JK
3230 if (s32Error)
3231 PRINT_ER("Error in sending message queue : Default key index\n");
a4ab1ade 3232 down(&hif_drv->hSemTestKeyBlock);
c5c77ba1 3233
c5c77ba1
JK
3234 return s32Error;
3235}
3236
a4ab1ade
TC
3237s32 host_int_add_wep_key_bss_sta(struct host_if_drv *hif_drv,
3238 const u8 *pu8WepKey,
3239 u8 u8WepKeylen,
3240 u8 u8Keyidx)
c5c77ba1
JK
3241{
3242
e6e12661 3243 s32 s32Error = 0;
143eb95a 3244 struct host_if_msg msg;
c5c77ba1 3245
a4ab1ade 3246 if (!hif_drv) {
24db713f
LK
3247 s32Error = -EFAULT;
3248 PRINT_ER("driver is null\n");
3249 return s32Error;
3250 }
c5c77ba1 3251
143eb95a 3252 memset(&msg, 0, sizeof(struct host_if_msg));
c5c77ba1
JK
3253
3254
a9f812a6 3255 msg.id = HOST_IF_MSG_KEY;
8e9f427a 3256 msg.body.key_info.type = WEP;
0d17e382 3257 msg.body.key_info.action = ADDKEY;
a4ab1ade 3258 msg.drv = hif_drv;
73b2e381
LK
3259 msg.body.key_info.attr.wep.key = kmalloc(u8WepKeylen, GFP_KERNEL);
3260 memcpy(msg.body.key_info.attr.wep.key, pu8WepKey, u8WepKeylen);
3261 msg.body.key_info.attr.wep.key_len = (u8WepKeylen);
3262 msg.body.key_info.attr.wep.index = u8Keyidx;
c5c77ba1 3263
143eb95a 3264 s32Error = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
c5c77ba1
JK
3265 if (s32Error)
3266 PRINT_ER("Error in sending message queue :WEP Key\n");
a4ab1ade 3267 down(&hif_drv->hSemTestKeyBlock);
c5c77ba1 3268
c5c77ba1
JK
3269 return s32Error;
3270
3271}
3272
a4ab1ade
TC
3273s32 host_int_add_wep_key_bss_ap(struct host_if_drv *hif_drv,
3274 const u8 *pu8WepKey,
3275 u8 u8WepKeylen,
3276 u8 u8Keyidx,
3277 u8 u8mode,
3278 enum AUTHTYPE tenuAuth_type)
c5c77ba1
JK
3279{
3280
e6e12661 3281 s32 s32Error = 0;
143eb95a 3282 struct host_if_msg msg;
63d03e47 3283 u8 i;
c5c77ba1 3284
a4ab1ade 3285 if (!hif_drv) {
24db713f
LK
3286 s32Error = -EFAULT;
3287 PRINT_ER("driver is null\n");
3288 return s32Error;
3289 }
c5c77ba1 3290
143eb95a 3291 memset(&msg, 0, sizeof(struct host_if_msg));
c5c77ba1
JK
3292
3293 if (INFO) {
3294 for (i = 0; i < u8WepKeylen; i++)
3295 PRINT_INFO(HOSTAPD_DBG, "KEY is %x\n", pu8WepKey[i]);
3296 }
a9f812a6 3297 msg.id = HOST_IF_MSG_KEY;
8e9f427a 3298 msg.body.key_info.type = WEP;
0d17e382 3299 msg.body.key_info.action = ADDKEY_AP;
a4ab1ade 3300 msg.drv = hif_drv;
73b2e381
LK
3301 msg.body.key_info.attr.wep.key = kmalloc(u8WepKeylen, GFP_KERNEL);
3302 memcpy(msg.body.key_info.attr.wep.key, pu8WepKey, (u8WepKeylen));
3303 msg.body.key_info.attr.wep.key_len = (u8WepKeylen);
3304 msg.body.key_info.attr.wep.index = u8Keyidx;
3305 msg.body.key_info.attr.wep.mode = u8mode;
3306 msg.body.key_info.attr.wep.auth_type = tenuAuth_type;
ae4dfa57 3307
143eb95a 3308 s32Error = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
c5c77ba1
JK
3309
3310 if (s32Error)
3311 PRINT_ER("Error in sending message queue :WEP Key\n");
a4ab1ade 3312 down(&hif_drv->hSemTestKeyBlock);
c5c77ba1 3313
c5c77ba1
JK
3314 return s32Error;
3315
3316}
108b3439 3317
a4ab1ade
TC
3318s32 host_int_add_ptk(struct host_if_drv *hif_drv, const u8 *pu8Ptk,
3319 u8 u8PtkKeylen, const u8 *mac_addr,
3320 const u8 *pu8RxMic, const u8 *pu8TxMic,
3321 u8 mode, u8 u8Ciphermode, u8 u8Idx)
c5c77ba1 3322{
e6e12661 3323 s32 s32Error = 0;
143eb95a 3324 struct host_if_msg msg;
63d03e47 3325 u8 u8KeyLen = u8PtkKeylen;
4e4467fd 3326 u32 i;
78c87591 3327
a4ab1ade 3328 if (!hif_drv) {
24db713f
LK
3329 s32Error = -EFAULT;
3330 PRINT_ER("driver is null\n");
3331 return s32Error;
3332 }
2b9d5b48 3333 if (pu8RxMic != NULL)
c5c77ba1 3334 u8KeyLen += RX_MIC_KEY_LEN;
2b9d5b48 3335 if (pu8TxMic != NULL)
c5c77ba1 3336 u8KeyLen += TX_MIC_KEY_LEN;
c5c77ba1 3337
143eb95a 3338 memset(&msg, 0, sizeof(struct host_if_msg));
c5c77ba1
JK
3339
3340
a9f812a6 3341 msg.id = HOST_IF_MSG_KEY;
8e9f427a 3342 msg.body.key_info.type = WPAPtk;
c5c77ba1 3343 if (mode == AP_MODE) {
0d17e382 3344 msg.body.key_info.action = ADDKEY_AP;
e2dfbac5 3345 msg.body.key_info.attr.wpa.index = u8Idx;
c5c77ba1 3346 }
c5c77ba1 3347 if (mode == STATION_MODE)
0d17e382 3348 msg.body.key_info.action = ADDKEY;
c5c77ba1 3349
124968fc
LK
3350 msg.body.key_info.attr.wpa.key = kmalloc(u8PtkKeylen, GFP_KERNEL);
3351 memcpy(msg.body.key_info.attr.wpa.key, pu8Ptk, u8PtkKeylen);
c5c77ba1
JK
3352
3353 if (pu8RxMic != NULL) {
124968fc 3354 memcpy(msg.body.key_info.attr.wpa.key + 16, pu8RxMic, RX_MIC_KEY_LEN);
c5c77ba1
JK
3355 if (INFO) {
3356 for (i = 0; i < RX_MIC_KEY_LEN; i++)
3357 PRINT_INFO(CFG80211_DBG, "PairwiseRx[%d] = %x\n", i, pu8RxMic[i]);
3358 }
3359 }
3360 if (pu8TxMic != NULL) {
124968fc 3361 memcpy(msg.body.key_info.attr.wpa.key + 24, pu8TxMic, TX_MIC_KEY_LEN);
c5c77ba1
JK
3362 if (INFO) {
3363 for (i = 0; i < TX_MIC_KEY_LEN; i++)
3364 PRINT_INFO(CFG80211_DBG, "PairwiseTx[%d] = %x\n", i, pu8TxMic[i]);
3365 }
3366 }
3367
6acf2919 3368 msg.body.key_info.attr.wpa.key_len = u8KeyLen;
248080aa 3369 msg.body.key_info.attr.wpa.mac_addr = mac_addr;
7b2ebb28 3370 msg.body.key_info.attr.wpa.mode = u8Ciphermode;
a4ab1ade 3371 msg.drv = hif_drv;
c5c77ba1 3372
143eb95a 3373 s32Error = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
c5c77ba1
JK
3374
3375 if (s32Error)
3376 PRINT_ER("Error in sending message queue: PTK Key\n");
3377
a4ab1ade 3378 down(&hif_drv->hSemTestKeyBlock);
c5c77ba1 3379
c5c77ba1
JK
3380 return s32Error;
3381}
3382
a4ab1ade
TC
3383s32 host_int_add_rx_gtk(struct host_if_drv *hif_drv, const u8 *pu8RxGtk,
3384 u8 u8GtkKeylen, u8 u8KeyIdx,
3385 u32 u32KeyRSClen, const u8 *KeyRSC,
3386 const u8 *pu8RxMic, const u8 *pu8TxMic,
3387 u8 mode, u8 u8Ciphermode)
c5c77ba1 3388{
e6e12661 3389 s32 s32Error = 0;
143eb95a 3390 struct host_if_msg msg;
63d03e47 3391 u8 u8KeyLen = u8GtkKeylen;
c5c77ba1 3392
a4ab1ade 3393 if (!hif_drv) {
24db713f
LK
3394 s32Error = -EFAULT;
3395 PRINT_ER("driver is null\n");
3396 return s32Error;
3397 }
143eb95a 3398 memset(&msg, 0, sizeof(struct host_if_msg));
c5c77ba1
JK
3399
3400
2b9d5b48 3401 if (pu8RxMic != NULL)
c5c77ba1 3402 u8KeyLen += RX_MIC_KEY_LEN;
2b9d5b48 3403 if (pu8TxMic != NULL)
c5c77ba1 3404 u8KeyLen += TX_MIC_KEY_LEN;
c5c77ba1 3405 if (KeyRSC != NULL) {
0e74c009
LK
3406 msg.body.key_info.attr.wpa.seq = kmalloc(u32KeyRSClen, GFP_KERNEL);
3407 memcpy(msg.body.key_info.attr.wpa.seq, KeyRSC, u32KeyRSClen);
c5c77ba1
JK
3408 }
3409
3410
a9f812a6 3411 msg.id = HOST_IF_MSG_KEY;
8e9f427a 3412 msg.body.key_info.type = WPARxGtk;
a4ab1ade 3413 msg.drv = hif_drv;
c5c77ba1 3414
c5c77ba1 3415 if (mode == AP_MODE) {
0d17e382 3416 msg.body.key_info.action = ADDKEY_AP;
7b2ebb28 3417 msg.body.key_info.attr.wpa.mode = u8Ciphermode;
c5c77ba1 3418 }
c5c77ba1 3419 if (mode == STATION_MODE)
0d17e382 3420 msg.body.key_info.action = ADDKEY;
c5c77ba1 3421
124968fc
LK
3422 msg.body.key_info.attr.wpa.key = kmalloc(u8KeyLen, GFP_KERNEL);
3423 memcpy(msg.body.key_info.attr.wpa.key, pu8RxGtk, u8GtkKeylen);
c5c77ba1
JK
3424
3425 if (pu8RxMic != NULL) {
124968fc 3426 memcpy(msg.body.key_info.attr.wpa.key + 16, pu8RxMic, RX_MIC_KEY_LEN);
c5c77ba1
JK
3427 }
3428 if (pu8TxMic != NULL) {
124968fc 3429 memcpy(msg.body.key_info.attr.wpa.key + 24, pu8TxMic, TX_MIC_KEY_LEN);
c5c77ba1
JK
3430 }
3431
e2dfbac5 3432 msg.body.key_info.attr.wpa.index = u8KeyIdx;
6acf2919 3433 msg.body.key_info.attr.wpa.key_len = u8KeyLen;
dacc594d 3434 msg.body.key_info.attr.wpa.seq_len = u32KeyRSClen;
c5c77ba1 3435
143eb95a 3436 s32Error = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
c5c77ba1
JK
3437 if (s32Error)
3438 PRINT_ER("Error in sending message queue: RX GTK\n");
ae4dfa57 3439
a4ab1ade 3440 down(&hif_drv->hSemTestKeyBlock);
c5c77ba1 3441
c5c77ba1
JK
3442 return s32Error;
3443}
c5c77ba1 3444
a4ab1ade 3445s32 host_int_set_pmkid_info(struct host_if_drv *hif_drv, struct host_if_pmkid_attr *pu8PmkidInfoArray)
c5c77ba1 3446{
e6e12661 3447 s32 s32Error = 0;
143eb95a 3448 struct host_if_msg msg;
4e4467fd 3449 u32 i;
c5c77ba1
JK
3450
3451
a4ab1ade 3452 if (!hif_drv) {
24db713f
LK
3453 s32Error = -EFAULT;
3454 PRINT_ER("driver is null\n");
3455 return s32Error;
3456 }
c5c77ba1 3457
143eb95a 3458 memset(&msg, 0, sizeof(struct host_if_msg));
c5c77ba1 3459
a9f812a6 3460 msg.id = HOST_IF_MSG_KEY;
8e9f427a 3461 msg.body.key_info.type = PMKSA;
0d17e382 3462 msg.body.key_info.action = ADDKEY;
a4ab1ade 3463 msg.drv = hif_drv;
c5c77ba1
JK
3464
3465 for (i = 0; i < pu8PmkidInfoArray->numpmkid; i++) {
73b2e381 3466 memcpy(msg.body.key_info.attr.pmkid.pmkidlist[i].bssid, &pu8PmkidInfoArray->pmkidlist[i].bssid,
c5c77ba1 3467 ETH_ALEN);
73b2e381 3468 memcpy(msg.body.key_info.attr.pmkid.pmkidlist[i].pmkid, &pu8PmkidInfoArray->pmkidlist[i].pmkid,
c5c77ba1
JK
3469 PMKID_LEN);
3470 }
3471
143eb95a 3472 s32Error = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
c5c77ba1
JK
3473 if (s32Error)
3474 PRINT_ER(" Error in sending messagequeue: PMKID Info\n");
3475
c5c77ba1
JK
3476 return s32Error;
3477}
3478
a4ab1ade
TC
3479s32 host_int_get_pmkid_info(struct host_if_drv *hif_drv,
3480 u8 *pu8PmkidInfoArray,
3481 u32 u32PmkidInfoLen)
c5c77ba1 3482{
e9e0c260 3483 struct wid strWID;
c5c77ba1 3484
daaf16ba 3485 strWID.id = (u16)WID_PMKID_INFO;
416d8321 3486 strWID.type = WID_STR;
2fd3e443 3487 strWID.size = u32PmkidInfoLen;
900bb4a6 3488 strWID.val = pu8PmkidInfoArray;
c5c77ba1 3489
b68d820b 3490 return 0;
c5c77ba1
JK
3491}
3492
a4ab1ade
TC
3493s32 host_int_set_RSNAConfigPSKPassPhrase(struct host_if_drv *hif_drv,
3494 u8 *pu8PassPhrase,
3495 u8 u8Psklength)
c5c77ba1 3496{
e9e0c260 3497 struct wid strWID;
c5c77ba1 3498
c5c77ba1 3499 if ((u8Psklength > 7) && (u8Psklength < 65)) {
daaf16ba 3500 strWID.id = (u16)WID_11I_PSK;
416d8321 3501 strWID.type = WID_STR;
900bb4a6 3502 strWID.val = pu8PassPhrase;
2fd3e443 3503 strWID.size = u8Psklength;
c5c77ba1
JK
3504 }
3505
b68d820b 3506 return 0;
c5c77ba1 3507}
ae4dfa57 3508
a4ab1ade 3509s32 host_int_get_MacAddress(struct host_if_drv *hif_drv, u8 *pu8MacAddress)
c5c77ba1 3510{
e6e12661 3511 s32 s32Error = 0;
143eb95a 3512 struct host_if_msg msg;
c5c77ba1 3513
143eb95a 3514 memset(&msg, 0, sizeof(struct host_if_msg));
c5c77ba1 3515
a9f812a6 3516 msg.id = HOST_IF_MSG_GET_MAC_ADDRESS;
a5848695 3517 msg.body.get_mac_info.u8MacAddress = pu8MacAddress;
a4ab1ade 3518 msg.drv = hif_drv;
ae4dfa57 3519
143eb95a 3520 s32Error = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
c5c77ba1
JK
3521 if (s32Error) {
3522 PRINT_ER("Failed to send get mac address\n");
e6e12661 3523 return -EFAULT;
c5c77ba1
JK
3524 }
3525
83383ea3 3526 down(&hWaitResponse);
c5c77ba1
JK
3527 return s32Error;
3528}
3529
a4ab1ade 3530s32 host_int_set_MacAddress(struct host_if_drv *hif_drv, u8 *pu8MacAddress)
c5c77ba1 3531{
e6e12661 3532 s32 s32Error = 0;
143eb95a 3533 struct host_if_msg msg;
c5c77ba1
JK
3534
3535 PRINT_D(GENERIC_DBG, "mac addr = %x:%x:%x\n", pu8MacAddress[0], pu8MacAddress[1], pu8MacAddress[2]);
3536
143eb95a 3537 memset(&msg, 0, sizeof(struct host_if_msg));
a9f812a6 3538 msg.id = HOST_IF_MSG_SET_MAC_ADDRESS;
15326e28 3539 memcpy(msg.body.set_mac_info.u8MacAddress, pu8MacAddress, ETH_ALEN);
a4ab1ade 3540 msg.drv = hif_drv;
c5c77ba1 3541
143eb95a 3542 s32Error = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
24db713f 3543 if (s32Error)
c5c77ba1 3544 PRINT_ER("Failed to send message queue: Set mac address\n");
c5c77ba1
JK
3545
3546 return s32Error;
3547
3548}
3549
a4ab1ade
TC
3550s32 host_int_get_RSNAConfigPSKPassPhrase(struct host_if_drv *hif_drv,
3551 u8 *pu8PassPhrase, u8 u8Psklength)
c5c77ba1 3552{
e9e0c260 3553 struct wid strWID;
c5c77ba1 3554
daaf16ba 3555 strWID.id = (u16)WID_11I_PSK;
416d8321 3556 strWID.type = WID_STR;
2fd3e443 3557 strWID.size = u8Psklength;
900bb4a6 3558 strWID.val = pu8PassPhrase;
c5c77ba1 3559
b68d820b 3560 return 0;
c5c77ba1
JK
3561}
3562
a4ab1ade 3563s32 host_int_set_start_scan_req(struct host_if_drv *hif_drv, u8 scanSource)
c5c77ba1 3564{
e9e0c260 3565 struct wid strWID;
c5c77ba1 3566
daaf16ba 3567 strWID.id = (u16)WID_START_SCAN_REQ;
416d8321 3568 strWID.type = WID_CHAR;
900bb4a6 3569 strWID.val = (s8 *)&scanSource;
2fd3e443 3570 strWID.size = sizeof(char);
c5c77ba1 3571
b68d820b 3572 return 0;
c5c77ba1
JK
3573}
3574
a4ab1ade 3575s32 host_int_get_start_scan_req(struct host_if_drv *hif_drv, u8 *pu8ScanSource)
c5c77ba1 3576{
e9e0c260 3577 struct wid strWID;
c5c77ba1 3578
daaf16ba 3579 strWID.id = (u16)WID_START_SCAN_REQ;
416d8321 3580 strWID.type = WID_CHAR;
900bb4a6 3581 strWID.val = (s8 *)pu8ScanSource;
2fd3e443 3582 strWID.size = sizeof(char);
c5c77ba1 3583
b68d820b 3584 return 0;
c5c77ba1
JK
3585}
3586
a4ab1ade
TC
3587s32 host_int_set_join_req(struct host_if_drv *hif_drv, u8 *pu8bssid,
3588 const u8 *pu8ssid, size_t ssidLen,
3589 const u8 *pu8IEs, size_t IEsLen,
3590 wilc_connect_result pfConnectResult, void *pvUserArg,
3591 u8 u8security, enum AUTHTYPE tenuAuth_type,
3592 u8 u8channel, void *pJoinParams)
c5c77ba1 3593{
e6e12661 3594 s32 s32Error = 0;
143eb95a 3595 struct host_if_msg msg;
7696edf4 3596 enum scan_conn_timer enuScanConnTimer;
c5c77ba1 3597
a4ab1ade 3598 if (!hif_drv || pfConnectResult == NULL) {
24db713f
LK
3599 s32Error = -EFAULT;
3600 PRINT_ER("Driver is null\n");
3601 return s32Error;
3602 }
c5c77ba1 3603
a4ab1ade 3604 if (!hif_drv) {
24db713f
LK
3605 PRINT_ER("Driver is null\n");
3606 return -EFAULT;
c5c77ba1
JK
3607 }
3608
3609 if (pJoinParams == NULL) {
3610 PRINT_ER("Unable to Join - JoinParams is NULL\n");
24db713f 3611 return -EFAULT;
c5c77ba1 3612 }
24db713f 3613
143eb95a 3614 memset(&msg, 0, sizeof(struct host_if_msg));
c5c77ba1 3615
a9f812a6 3616 msg.id = HOST_IF_MSG_CONNECT;
c5c77ba1 3617
3f501971
TC
3618 msg.body.con_info.u8security = u8security;
3619 msg.body.con_info.tenuAuth_type = tenuAuth_type;
3620 msg.body.con_info.u8channel = u8channel;
3621 msg.body.con_info.pfConnectResult = pfConnectResult;
3622 msg.body.con_info.pvUserArg = pvUserArg;
3623 msg.body.con_info.pJoinParams = pJoinParams;
a4ab1ade 3624 msg.drv = hif_drv ;
c5c77ba1
JK
3625
3626 if (pu8bssid != NULL) {
ae4dfa57 3627 msg.body.con_info.pu8bssid = kmalloc(6, GFP_KERNEL);
3f501971 3628 memcpy(msg.body.con_info.pu8bssid,
c5c77ba1
JK
3629 pu8bssid, 6);
3630 }
3631
3632 if (pu8ssid != NULL) {
3f501971 3633 msg.body.con_info.ssidLen = ssidLen;
ae4dfa57 3634 msg.body.con_info.pu8ssid = kmalloc(ssidLen, GFP_KERNEL);
3f501971 3635 memcpy(msg.body.con_info.pu8ssid,
c5c77ba1
JK
3636
3637 pu8ssid, ssidLen);
3638 }
3639
3640 if (pu8IEs != NULL) {
3f501971 3641 msg.body.con_info.IEsLen = IEsLen;
ae4dfa57 3642 msg.body.con_info.pu8IEs = kmalloc(IEsLen, GFP_KERNEL);
3f501971 3643 memcpy(msg.body.con_info.pu8IEs,
c5c77ba1
JK
3644 pu8IEs, IEsLen);
3645 }
a4ab1ade
TC
3646 if (hif_drv->enuHostIFstate < HOST_IF_CONNECTING)
3647 hif_drv->enuHostIFstate = HOST_IF_CONNECTING;
78174ada 3648 else
a4ab1ade 3649 PRINT_D(GENERIC_DBG, "Don't set state to 'connecting' as state is %d\n", hif_drv->enuHostIFstate);
c5c77ba1 3650
143eb95a 3651 s32Error = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
c5c77ba1
JK
3652 if (s32Error) {
3653 PRINT_ER("Failed to send message queue: Set join request\n");
24db713f 3654 return -EFAULT;
c5c77ba1
JK
3655 }
3656
3657 enuScanConnTimer = CONNECT_TIMER;
a4ab1ade
TC
3658 hif_drv->hConnectTimer.data = (unsigned long)hif_drv;
3659 mod_timer(&hif_drv->hConnectTimer,
9eb06643 3660 jiffies + msecs_to_jiffies(HOST_IF_CONNECT_TIMEOUT));
c5c77ba1 3661
c5c77ba1
JK
3662 return s32Error;
3663}
3664
a4ab1ade 3665s32 host_int_flush_join_req(struct host_if_drv *hif_drv)
c5c77ba1 3666{
e6e12661 3667 s32 s32Error = 0;
143eb95a 3668 struct host_if_msg msg;
c5c77ba1
JK
3669
3670 if (!gu8FlushedJoinReq) {
e6e12661 3671 s32Error = -EFAULT;
c5c77ba1
JK
3672 return s32Error;
3673 }
3674
3675
a4ab1ade 3676 if (!hif_drv) {
24db713f
LK
3677 s32Error = -EFAULT;
3678 PRINT_ER("Driver is null\n");
3679 return s32Error;
3680 }
c5c77ba1 3681
a9f812a6 3682 msg.id = HOST_IF_MSG_FLUSH_CONNECT;
a4ab1ade 3683 msg.drv = hif_drv;
c5c77ba1 3684
143eb95a 3685 s32Error = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
c5c77ba1
JK
3686 if (s32Error) {
3687 PRINT_ER("Failed to send message queue: Flush join request\n");
24db713f 3688 return -EFAULT;
c5c77ba1
JK
3689 }
3690
c5c77ba1
JK
3691 return s32Error;
3692}
3693
a4ab1ade 3694s32 host_int_disconnect(struct host_if_drv *hif_drv, u16 u16ReasonCode)
c5c77ba1 3695{
e6e12661 3696 s32 s32Error = 0;
143eb95a 3697 struct host_if_msg msg;
c5c77ba1 3698
a4ab1ade 3699 if (!hif_drv) {
24db713f
LK
3700 PRINT_ER("Driver is null\n");
3701 return -EFAULT;
c5c77ba1
JK
3702 }
3703
143eb95a 3704 memset(&msg, 0, sizeof(struct host_if_msg));
c5c77ba1 3705
a9f812a6 3706 msg.id = HOST_IF_MSG_DISCONNECT;
a4ab1ade 3707 msg.drv = hif_drv;
c5c77ba1 3708
143eb95a 3709 s32Error = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
c5c77ba1
JK
3710 if (s32Error)
3711 PRINT_ER("Failed to send message queue: disconnect\n");
ae4dfa57 3712
a4ab1ade 3713 down(&hif_drv->hSemTestDisconnectBlock);
c5c77ba1 3714
c5c77ba1
JK
3715 return s32Error;
3716}
3717
a4ab1ade 3718s32 host_int_disconnect_station(struct host_if_drv *hif_drv, u8 assoc_id)
c5c77ba1 3719{
e9e0c260 3720 struct wid strWID;
c5c77ba1 3721
daaf16ba 3722 strWID.id = (u16)WID_DISCONNECT;
416d8321 3723 strWID.type = WID_CHAR;
900bb4a6 3724 strWID.val = (s8 *)&assoc_id;
2fd3e443 3725 strWID.size = sizeof(char);
c5c77ba1 3726
b68d820b 3727 return 0;
c5c77ba1
JK
3728}
3729
a4ab1ade 3730s32 host_int_get_assoc_req_info(struct host_if_drv *hif_drv, u8 *pu8AssocReqInfo,
4e4467fd 3731 u32 u32AssocReqInfoLen)
c5c77ba1 3732{
e9e0c260 3733 struct wid strWID;
c5c77ba1 3734
daaf16ba 3735 strWID.id = (u16)WID_ASSOC_REQ_INFO;
416d8321 3736 strWID.type = WID_STR;
900bb4a6 3737 strWID.val = pu8AssocReqInfo;
2fd3e443 3738 strWID.size = u32AssocReqInfoLen;
c5c77ba1 3739
b68d820b 3740 return 0;
c5c77ba1
JK
3741}
3742
a4ab1ade 3743s32 host_int_get_assoc_res_info(struct host_if_drv *hif_drv, u8 *pu8AssocRespInfo,
4e4467fd 3744 u32 u32MaxAssocRespInfoLen, u32 *pu32RcvdAssocRespInfoLen)
c5c77ba1 3745{
e6e12661 3746 s32 s32Error = 0;
e9e0c260 3747 struct wid strWID;
c5c77ba1 3748
a4ab1ade 3749 if (!hif_drv) {
24db713f
LK
3750 PRINT_ER("Driver is null\n");
3751 return -EFAULT;
c5c77ba1
JK
3752 }
3753
daaf16ba 3754 strWID.id = (u16)WID_ASSOC_RES_INFO;
416d8321 3755 strWID.type = WID_STR;
900bb4a6 3756 strWID.val = pu8AssocRespInfo;
2fd3e443 3757 strWID.size = u32MaxAssocRespInfoLen;
c5c77ba1 3758
03362286 3759 s32Error = send_config_pkt(GET_CFG, &strWID, 1,
a4ab1ade 3760 get_id_from_handler(hif_drv));
c5c77ba1 3761 if (s32Error) {
c5c77ba1 3762 *pu32RcvdAssocRespInfoLen = 0;
24db713f
LK
3763 PRINT_ER("Failed to send association response config packet\n");
3764 return -EINVAL;
c5c77ba1 3765 } else {
2fd3e443 3766 *pu32RcvdAssocRespInfoLen = strWID.size;
c5c77ba1
JK
3767 }
3768
c5c77ba1
JK
3769 return s32Error;
3770}
3771
a4ab1ade 3772s32 host_int_get_rx_power_level(struct host_if_drv *hif_drv, u8 *pu8RxPowerLevel,
4e4467fd 3773 u32 u32RxPowerLevelLen)
c5c77ba1 3774{
e9e0c260 3775 struct wid strWID;
c5c77ba1 3776
daaf16ba 3777 strWID.id = (u16)WID_RX_POWER_LEVEL;
416d8321 3778 strWID.type = WID_STR;
900bb4a6 3779 strWID.val = pu8RxPowerLevel;
2fd3e443 3780 strWID.size = u32RxPowerLevelLen;
c5c77ba1 3781
b68d820b 3782 return 0;
c5c77ba1
JK
3783}
3784
a4ab1ade 3785int host_int_set_mac_chnl_num(struct host_if_drv *hif_drv, u8 channel)
c5c77ba1 3786{
792fb25b 3787 int result;
143eb95a 3788 struct host_if_msg msg;
c5c77ba1 3789
a4ab1ade 3790 if (!hif_drv) {
24db713f
LK
3791 PRINT_ER("driver is null\n");
3792 return -EFAULT;
3793 }
c5c77ba1 3794
143eb95a 3795 memset(&msg, 0, sizeof(struct host_if_msg));
a9f812a6 3796 msg.id = HOST_IF_MSG_SET_CHANNEL;
1c5833ce 3797 msg.body.channel_info.u8SetChan = channel;
a4ab1ade 3798 msg.drv = hif_drv;
c5c77ba1 3799
1ef58e42
CL
3800 result = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
3801 if (result) {
24db713f 3802 PRINT_ER("wilc mq send fail\n");
792fb25b 3803 return -EINVAL;
c5c77ba1
JK
3804 }
3805
792fb25b 3806 return 0;
c5c77ba1
JK
3807}
3808
244efb1f 3809int host_int_wait_msg_queue_idle(void)
c5c77ba1 3810{
6d6c9bbb 3811 int result = 0;
c5c77ba1 3812
143eb95a 3813 struct host_if_msg msg;
143eb95a 3814 memset(&msg, 0, sizeof(struct host_if_msg));
a9f812a6 3815 msg.id = HOST_IF_MSG_Q_IDLE;
6d6c9bbb
CL
3816 result = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
3817 if (result) {
24db713f 3818 PRINT_ER("wilc mq send fail\n");
6d6c9bbb 3819 result = -EINVAL;
c5c77ba1
JK
3820 }
3821
83383ea3 3822 down(&hWaitResponse);
c5c77ba1 3823
6d6c9bbb 3824 return result;
c5c77ba1
JK
3825}
3826
a4ab1ade 3827int host_int_set_wfi_drv_handler(struct host_if_drv *hif_drv)
c5c77ba1 3828{
a094101c 3829 int result = 0;
c5c77ba1 3830
143eb95a 3831 struct host_if_msg msg;
143eb95a 3832 memset(&msg, 0, sizeof(struct host_if_msg));
a9f812a6 3833 msg.id = HOST_IF_MSG_SET_WFIDRV_HANDLER;
a4ab1ade
TC
3834 msg.body.drv.u32Address = get_id_from_handler(hif_drv);
3835 msg.drv = hif_drv;
c5c77ba1 3836
a094101c
CL
3837 result = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
3838 if (result) {
24db713f 3839 PRINT_ER("wilc mq send fail\n");
a094101c 3840 result = -EINVAL;
c5c77ba1
JK
3841 }
3842
a094101c 3843 return result;
c5c77ba1
JK
3844}
3845
a4ab1ade 3846int host_int_set_operation_mode(struct host_if_drv *hif_drv, u32 mode)
c5c77ba1 3847{
a0c1ee0c 3848 int result = 0;
c5c77ba1 3849
143eb95a 3850 struct host_if_msg msg;
143eb95a 3851 memset(&msg, 0, sizeof(struct host_if_msg));
a9f812a6 3852 msg.id = HOST_IF_MSG_SET_OPERATION_MODE;
49fb6f71 3853 msg.body.mode.u32Mode = mode;
a4ab1ade 3854 msg.drv = hif_drv;
c5c77ba1 3855
a0c1ee0c
CL
3856 result = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
3857 if (result) {
24db713f 3858 PRINT_ER("wilc mq send fail\n");
a0c1ee0c 3859 result = -EINVAL;
c5c77ba1
JK
3860 }
3861
a0c1ee0c 3862 return result;
c5c77ba1
JK
3863}
3864
a4ab1ade 3865s32 host_int_get_host_chnl_num(struct host_if_drv *hif_drv, u8 *pu8ChNo)
c5c77ba1 3866{
e6e12661 3867 s32 s32Error = 0;
143eb95a 3868 struct host_if_msg msg;
c5c77ba1 3869
a4ab1ade 3870 if (!hif_drv) {
24db713f
LK
3871 PRINT_ER("driver is null\n");
3872 return -EFAULT;
c5c77ba1
JK
3873 }
3874
143eb95a 3875 memset(&msg, 0, sizeof(struct host_if_msg));
c5c77ba1 3876
a9f812a6 3877 msg.id = HOST_IF_MSG_GET_CHNL;
a4ab1ade 3878 msg.drv = hif_drv;
c5c77ba1 3879
143eb95a 3880 s32Error = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
c5c77ba1 3881 if (s32Error)
24db713f 3882 PRINT_ER("wilc mq send fail\n");
a4ab1ade 3883 down(&hif_drv->hSemGetCHNL);
c5c77ba1
JK
3884
3885 *pu8ChNo = gu8Chnl;
3886
c5c77ba1
JK
3887 return s32Error;
3888
3889
3890}
3891
a4ab1ade
TC
3892s32 host_int_get_inactive_time(struct host_if_drv *hif_drv,
3893 const u8 *mac, u32 *pu32InactiveTime)
c5c77ba1 3894{
e6e12661 3895 s32 s32Error = 0;
143eb95a 3896 struct host_if_msg msg;
c5c77ba1 3897
a4ab1ade 3898 if (!hif_drv) {
24db713f
LK
3899 PRINT_ER("driver is null\n");
3900 return -EFAULT;
c5c77ba1
JK
3901 }
3902
143eb95a 3903 memset(&msg, 0, sizeof(struct host_if_msg));
c5c77ba1
JK
3904
3905
66bac7f2 3906 memcpy(msg.body.mac_info.mac,
c5c77ba1
JK
3907 mac, ETH_ALEN);
3908
a9f812a6 3909 msg.id = HOST_IF_MSG_GET_INACTIVETIME;
a4ab1ade 3910 msg.drv = hif_drv;
c5c77ba1 3911
143eb95a 3912 s32Error = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
c5c77ba1
JK
3913 if (s32Error)
3914 PRINT_ER("Failed to send get host channel param's message queue ");
3915
a4ab1ade 3916 down(&hif_drv->hSemInactiveTime);
c5c77ba1
JK
3917
3918 *pu32InactiveTime = gu32InactiveTime;
3919
c5c77ba1
JK
3920 return s32Error;
3921}
108b3439 3922
a4ab1ade 3923s32 host_int_test_get_int_wid(struct host_if_drv *hif_drv, u32 *pu32TestMemAddr)
c5c77ba1
JK
3924{
3925
e6e12661 3926 s32 s32Error = 0;
e9e0c260 3927 struct wid strWID;
c5c77ba1 3928
a4ab1ade 3929 if (!hif_drv) {
24db713f
LK
3930 PRINT_ER("driver is null\n");
3931 return -EFAULT;
c5c77ba1
JK
3932 }
3933
daaf16ba 3934 strWID.id = (u16)WID_MEMORY_ADDRESS;
416d8321 3935 strWID.type = WID_INT;
900bb4a6 3936 strWID.val = (s8 *)pu32TestMemAddr;
2fd3e443 3937 strWID.size = sizeof(u32);
c5c77ba1 3938
03362286 3939 s32Error = send_config_pkt(GET_CFG, &strWID, 1,
a4ab1ade 3940 get_id_from_handler(hif_drv));
ae4dfa57 3941
c5c77ba1 3942 if (s32Error) {
24db713f
LK
3943 PRINT_ER("Failed to get wid value\n");
3944 return -EINVAL;
c5c77ba1
JK
3945 } else {
3946 PRINT_D(HOSTINF_DBG, "Successfully got wid value\n");
3947
3948 }
3949
c5c77ba1
JK
3950 return s32Error;
3951}
3952
a4ab1ade 3953s32 host_int_get_rssi(struct host_if_drv *hif_drv, s8 *ps8Rssi)
c5c77ba1 3954{
e6e12661 3955 s32 s32Error = 0;
143eb95a 3956 struct host_if_msg msg;
143eb95a 3957 memset(&msg, 0, sizeof(struct host_if_msg));
c5c77ba1 3958
a9f812a6 3959 msg.id = HOST_IF_MSG_GET_RSSI;
a4ab1ade 3960 msg.drv = hif_drv;
c5c77ba1 3961
143eb95a 3962 s32Error = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
c5c77ba1
JK
3963 if (s32Error) {
3964 PRINT_ER("Failed to send get host channel param's message queue ");
e6e12661 3965 return -EFAULT;
c5c77ba1
JK
3966 }
3967
a4ab1ade 3968 down(&hif_drv->hSemGetRSSI);
c5c77ba1
JK
3969
3970
3971 if (ps8Rssi == NULL) {
3972 PRINT_ER("RSS pointer value is null");
e6e12661 3973 return -EFAULT;
c5c77ba1
JK
3974 }
3975
3976
3977 *ps8Rssi = gs8Rssi;
3978
3979
3980 return s32Error;
3981}
3982
a4ab1ade 3983s32 host_int_get_link_speed(struct host_if_drv *hif_drv, s8 *ps8lnkspd)
c5c77ba1 3984{
143eb95a 3985 struct host_if_msg msg;
e6e12661 3986 s32 s32Error = 0;
143eb95a 3987 memset(&msg, 0, sizeof(struct host_if_msg));
c5c77ba1 3988
a9f812a6 3989 msg.id = HOST_IF_MSG_GET_LINKSPEED;
a4ab1ade 3990 msg.drv = hif_drv;
c5c77ba1 3991
143eb95a 3992 s32Error = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
c5c77ba1
JK
3993 if (s32Error) {
3994 PRINT_ER("Failed to send GET_LINKSPEED to message queue ");
e6e12661 3995 return -EFAULT;
c5c77ba1
JK
3996 }
3997
a4ab1ade 3998 down(&hif_drv->hSemGetLINKSPEED);
c5c77ba1
JK
3999
4000
4001 if (ps8lnkspd == NULL) {
4002 PRINT_ER("LINKSPEED pointer value is null");
e6e12661 4003 return -EFAULT;
c5c77ba1
JK
4004 }
4005
4006
4007 *ps8lnkspd = gs8lnkspd;
4008
4009
4010 return s32Error;
4011}
4012
a4ab1ade 4013s32 host_int_get_statistics(struct host_if_drv *hif_drv, struct rf_info *pstrStatistics)
c5c77ba1 4014{
e6e12661 4015 s32 s32Error = 0;
143eb95a 4016 struct host_if_msg msg;
143eb95a 4017 memset(&msg, 0, sizeof(struct host_if_msg));
c5c77ba1 4018
a9f812a6 4019 msg.id = HOST_IF_MSG_GET_STATISTICS;
e60831e9 4020 msg.body.data = (char *)pstrStatistics;
a4ab1ade 4021 msg.drv = hif_drv;
ae4dfa57 4022
143eb95a 4023 s32Error = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
c5c77ba1
JK
4024 if (s32Error) {
4025 PRINT_ER("Failed to send get host channel param's message queue ");
e6e12661 4026 return -EFAULT;
c5c77ba1
JK
4027 }
4028
83383ea3 4029 down(&hWaitResponse);
c5c77ba1
JK
4030 return s32Error;
4031}
4032
a4ab1ade
TC
4033s32 host_int_scan(struct host_if_drv *hif_drv, u8 u8ScanSource,
4034 u8 u8ScanType, u8 *pu8ChnlFreqList,
4035 u8 u8ChnlListLen, const u8 *pu8IEs,
4036 size_t IEsLen, wilc_scan_result ScanResult,
4037 void *pvUserArg, struct hidden_network *pstrHiddenNetwork)
c5c77ba1 4038{
e6e12661 4039 s32 s32Error = 0;
143eb95a 4040 struct host_if_msg msg;
7696edf4 4041 enum scan_conn_timer enuScanConnTimer;
c5c77ba1 4042
a4ab1ade
TC
4043 if (!hif_drv || ScanResult == NULL) {
4044 PRINT_ER("hif_drv or ScanResult = NULL\n");
24db713f
LK
4045 return -EFAULT;
4046 }
c5c77ba1 4047
143eb95a 4048 memset(&msg, 0, sizeof(struct host_if_msg));
c5c77ba1 4049
a9f812a6 4050 msg.id = HOST_IF_MSG_SCAN;
c5c77ba1
JK
4051
4052 if (pstrHiddenNetwork != NULL) {
4528bdb5
TC
4053 msg.body.scan_info.strHiddenNetwork.pstrHiddenNetworkInfo = pstrHiddenNetwork->pstrHiddenNetworkInfo;
4054 msg.body.scan_info.strHiddenNetwork.u8ssidnum = pstrHiddenNetwork->u8ssidnum;
c5c77ba1
JK
4055
4056 } else
4057 PRINT_D(HOSTINF_DBG, "pstrHiddenNetwork IS EQUAL TO NULL\n");
4058
a4ab1ade 4059 msg.drv = hif_drv;
42568898 4060 msg.body.scan_info.src = u8ScanSource;
1e276c88 4061 msg.body.scan_info.type = u8ScanType;
4528bdb5
TC
4062 msg.body.scan_info.pfScanResult = ScanResult;
4063 msg.body.scan_info.pvUserArg = pvUserArg;
4064
f97bd9ca 4065 msg.body.scan_info.ch_list_len = u8ChnlListLen;
82eeb0ad
LK
4066 msg.body.scan_info.ch_freq_list = kmalloc(u8ChnlListLen, GFP_KERNEL);
4067 memcpy(msg.body.scan_info.ch_freq_list, pu8ChnlFreqList, u8ChnlListLen);
c5c77ba1 4068
7b1f76cd 4069 msg.body.scan_info.ies_len = IEsLen;
d6f19aa5
LK
4070 msg.body.scan_info.ies = kmalloc(IEsLen, GFP_KERNEL);
4071 memcpy(msg.body.scan_info.ies, pu8IEs, IEsLen);
c5c77ba1 4072
143eb95a 4073 s32Error = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
c5c77ba1 4074 if (s32Error) {
24db713f
LK
4075 PRINT_ER("Error in sending message queue\n");
4076 return -EINVAL;
c5c77ba1
JK
4077 }
4078
4079 enuScanConnTimer = SCAN_TIMER;
4080 PRINT_D(HOSTINF_DBG, ">> Starting the SCAN timer\n");
a4ab1ade
TC
4081 hif_drv->hScanTimer.data = (unsigned long)hif_drv;
4082 mod_timer(&hif_drv->hScanTimer,
9eb06643 4083 jiffies + msecs_to_jiffies(HOST_IF_SCAN_TIMEOUT));
c5c77ba1 4084
c5c77ba1
JK
4085 return s32Error;
4086
4087}
ae4dfa57 4088
a4ab1ade
TC
4089s32 hif_set_cfg(struct host_if_drv *hif_drv,
4090 struct cfg_param_val *pstrCfgParamVal)
c5c77ba1
JK
4091{
4092
e6e12661 4093 s32 s32Error = 0;
143eb95a 4094 struct host_if_msg msg;
c5c77ba1
JK
4095
4096
a4ab1ade
TC
4097 if (!hif_drv) {
4098 PRINT_ER("hif_drv NULL\n");
24db713f
LK
4099 return -EFAULT;
4100 }
ae4dfa57 4101
143eb95a 4102 memset(&msg, 0, sizeof(struct host_if_msg));
a9f812a6 4103 msg.id = HOST_IF_MSG_CFG_PARAMS;
221371e5 4104 msg.body.cfg_info.cfg_attr_info = *pstrCfgParamVal;
a4ab1ade 4105 msg.drv = hif_drv;
c5c77ba1 4106
143eb95a 4107 s32Error = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
c5c77ba1 4108
c5c77ba1
JK
4109 return s32Error;
4110
4111}
4112
a4ab1ade 4113s32 hif_get_cfg(struct host_if_drv *hif_drv, u16 u16WID, u16 *pu16WID_Value)
c5c77ba1 4114{
e6e12661 4115 s32 s32Error = 0;
c5c77ba1 4116
a4ab1ade 4117 down(&hif_drv->gtOsCfgValuesSem);
c5c77ba1 4118
a4ab1ade
TC
4119 if (!hif_drv) {
4120 PRINT_ER("hif_drv NULL\n");
24db713f 4121 return -EFAULT;
c5c77ba1
JK
4122 }
4123 PRINT_D(HOSTINF_DBG, "Getting configuration parameters\n");
4124 switch (u16WID) {
4125
4126 case WID_BSS_TYPE:
a4ab1ade 4127 *pu16WID_Value = (u16)hif_drv->strCfgValues.bss_type;
c5c77ba1
JK
4128 break;
4129
4130 case WID_AUTH_TYPE:
a4ab1ade 4131 *pu16WID_Value = (u16)hif_drv->strCfgValues.auth_type;
c5c77ba1
JK
4132 break;
4133
4134 case WID_AUTH_TIMEOUT:
a4ab1ade 4135 *pu16WID_Value = hif_drv->strCfgValues.auth_timeout;
c5c77ba1
JK
4136 break;
4137
4138 case WID_POWER_MANAGEMENT:
a4ab1ade 4139 *pu16WID_Value = (u16)hif_drv->strCfgValues.power_mgmt_mode;
c5c77ba1
JK
4140 break;
4141
4142 case WID_SHORT_RETRY_LIMIT:
a4ab1ade 4143 *pu16WID_Value = hif_drv->strCfgValues.short_retry_limit;
c5c77ba1
JK
4144 break;
4145
4146 case WID_LONG_RETRY_LIMIT:
a4ab1ade 4147 *pu16WID_Value = hif_drv->strCfgValues.long_retry_limit;
c5c77ba1
JK
4148 break;
4149
4150 case WID_FRAG_THRESHOLD:
a4ab1ade 4151 *pu16WID_Value = hif_drv->strCfgValues.frag_threshold;
c5c77ba1
JK
4152 break;
4153
4154 case WID_RTS_THRESHOLD:
a4ab1ade 4155 *pu16WID_Value = hif_drv->strCfgValues.rts_threshold;
c5c77ba1
JK
4156 break;
4157
4158 case WID_PREAMBLE:
a4ab1ade 4159 *pu16WID_Value = (u16)hif_drv->strCfgValues.preamble_type;
c5c77ba1
JK
4160 break;
4161
4162 case WID_SHORT_SLOT_ALLOWED:
a4ab1ade 4163 *pu16WID_Value = (u16) hif_drv->strCfgValues.short_slot_allowed;
c5c77ba1
JK
4164 break;
4165
4166 case WID_11N_TXOP_PROT_DISABLE:
a4ab1ade 4167 *pu16WID_Value = (u16)hif_drv->strCfgValues.txop_prot_disabled;
c5c77ba1
JK
4168 break;
4169
4170 case WID_BEACON_INTERVAL:
a4ab1ade 4171 *pu16WID_Value = hif_drv->strCfgValues.beacon_interval;
c5c77ba1
JK
4172 break;
4173
4174 case WID_DTIM_PERIOD:
a4ab1ade 4175 *pu16WID_Value = (u16)hif_drv->strCfgValues.dtim_period;
c5c77ba1
JK
4176 break;
4177
4178 case WID_SITE_SURVEY:
a4ab1ade 4179 *pu16WID_Value = (u16)hif_drv->strCfgValues.site_survey_enabled;
c5c77ba1
JK
4180 break;
4181
4182 case WID_SITE_SURVEY_SCAN_TIME:
a4ab1ade 4183 *pu16WID_Value = hif_drv->strCfgValues.site_survey_scan_time;
c5c77ba1
JK
4184 break;
4185
4186 case WID_ACTIVE_SCAN_TIME:
a4ab1ade 4187 *pu16WID_Value = hif_drv->strCfgValues.active_scan_time;
c5c77ba1
JK
4188 break;
4189
4190 case WID_PASSIVE_SCAN_TIME:
a4ab1ade 4191 *pu16WID_Value = hif_drv->strCfgValues.passive_scan_time;
c5c77ba1
JK
4192 break;
4193
4194 case WID_CURRENT_TX_RATE:
a4ab1ade 4195 *pu16WID_Value = hif_drv->strCfgValues.curr_tx_rate;
c5c77ba1
JK
4196 break;
4197
4198 default:
4199 break;
4200 }
4201
a4ab1ade 4202 up(&hif_drv->gtOsCfgValuesSem);
c5c77ba1 4203
c5c77ba1
JK
4204 return s32Error;
4205
4206}
4207
c5c77ba1 4208void host_int_send_join_leave_info_to_host
72ed4dc7 4209 (u16 assocId, u8 *stationAddr, bool joining)
c5c77ba1
JK
4210{
4211}
c5c77ba1 4212
93dee8ee 4213static void GetPeriodicRSSI(unsigned long arg)
c5c77ba1 4214{
a4ab1ade 4215 struct host_if_drv *hif_drv = (struct host_if_drv *)arg;
78c87591 4216
a4ab1ade 4217 if (!hif_drv) {
c5c77ba1
JK
4218 PRINT_ER("Driver handler is NULL\n");
4219 return;
4220 }
4221
a4ab1ade 4222 if (hif_drv->enuHostIFstate == HOST_IF_CONNECTED) {
e6e12661 4223 s32 s32Error = 0;
143eb95a 4224 struct host_if_msg msg;
c5c77ba1 4225
143eb95a 4226 memset(&msg, 0, sizeof(struct host_if_msg));
c5c77ba1 4227
a9f812a6 4228 msg.id = HOST_IF_MSG_GET_RSSI;
a4ab1ade 4229 msg.drv = hif_drv;
c5c77ba1 4230
143eb95a 4231 s32Error = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
c5c77ba1
JK
4232 if (s32Error) {
4233 PRINT_ER("Failed to send get host channel param's message queue ");
4234 return;
4235 }
4236 }
a4ab1ade 4237 g_hPeriodicRSSI.data = (unsigned long)hif_drv;
9eb06643 4238 mod_timer(&g_hPeriodicRSSI, jiffies + msecs_to_jiffies(5000));
c5c77ba1
JK
4239}
4240
4241
4242void host_int_send_network_info_to_host
ca356ada 4243 (u8 *macStartAddress, u16 u16RxFrameLen, s8 s8Rssi)
c5c77ba1
JK
4244{
4245}
ae4dfa57 4246
4e4467fd 4247static u32 clients_count;
c5c77ba1 4248
a4ab1ade 4249s32 host_int_init(struct host_if_drv **hif_drv_handler)
c5c77ba1 4250{
5b09bd32 4251 s32 result = 0;
a4ab1ade 4252 struct host_if_drv *hif_drv;
d42ab083 4253 int err;
c5c77ba1 4254
c5c77ba1
JK
4255 PRINT_D(HOSTINF_DBG, "Initializing host interface for client %d\n", clients_count + 1);
4256
72ed4dc7 4257 gbScanWhileConnected = false;
c5c77ba1 4258
83383ea3 4259 sema_init(&hWaitResponse, 0);
c5c77ba1 4260
a4ab1ade
TC
4261 hif_drv = kzalloc(sizeof(struct host_if_drv), GFP_KERNEL);
4262 if (!hif_drv) {
5b09bd32 4263 result = -ENOMEM;
17db84eb 4264 goto _fail_;
c5c77ba1 4265 }
a4ab1ade
TC
4266 *hif_drv_handler = hif_drv;
4267 err = add_handler_in_list(hif_drv);
d42ab083 4268 if (err) {
5b09bd32 4269 result = -EFAULT;
d42ab083
JK
4270 goto _fail_timer_2;
4271 }
c5c77ba1 4272
72ed4dc7 4273 g_obtainingIP = false;
c5c77ba1 4274
a4ab1ade 4275 PRINT_D(HOSTINF_DBG, "Global handle pointer value=%p\n", hif_drv);
c5c77ba1 4276 if (clients_count == 0) {
83383ea3
AB
4277 sema_init(&hSemHostIFthrdEnd, 0);
4278 sema_init(&hSemDeinitDrvHandle, 0);
83383ea3
AB
4279 sema_init(&hSemHostIntDeinit, 1);
4280 }
4281
a4ab1ade
TC
4282 sema_init(&hif_drv->hSemTestKeyBlock, 0);
4283 sema_init(&hif_drv->hSemTestDisconnectBlock, 0);
4284 sema_init(&hif_drv->hSemGetRSSI, 0);
4285 sema_init(&hif_drv->hSemGetLINKSPEED, 0);
4286 sema_init(&hif_drv->hSemGetCHNL, 0);
4287 sema_init(&hif_drv->hSemInactiveTime, 0);
c5c77ba1 4288
c5c77ba1
JK
4289 PRINT_D(HOSTINF_DBG, "INIT: CLIENT COUNT %d\n", clients_count);
4290
4291 if (clients_count == 0) {
5b09bd32 4292 result = wilc_mq_create(&gMsgQHostIF);
c5c77ba1 4293
5b09bd32 4294 if (result < 0) {
c5c77ba1
JK
4295 PRINT_ER("Failed to creat MQ\n");
4296 goto _fail_;
4297 }
1999bd52
AB
4298 HostIFthreadHandler = kthread_run(hostIFthread, NULL, "WILC_kthread");
4299 if (IS_ERR(HostIFthreadHandler)) {
c5c77ba1 4300 PRINT_ER("Failed to creat Thread\n");
5b09bd32 4301 result = -EFAULT;
c5c77ba1
JK
4302 goto _fail_mq_;
4303 }
507d7fc5 4304 setup_timer(&g_hPeriodicRSSI, GetPeriodicRSSI,
a4ab1ade 4305 (unsigned long)hif_drv);
9eb06643 4306 mod_timer(&g_hPeriodicRSSI, jiffies + msecs_to_jiffies(5000));
c5c77ba1
JK
4307 }
4308
a4ab1ade 4309 setup_timer(&hif_drv->hScanTimer, TimerCB_Scan, 0);
c5c77ba1 4310
a4ab1ade 4311 setup_timer(&hif_drv->hConnectTimer, TimerCB_Connect, 0);
c5c77ba1 4312
a4ab1ade 4313 setup_timer(&hif_drv->hRemainOnChannel, ListenTimerCB, 0);
c5c77ba1 4314
a4ab1ade
TC
4315 sema_init(&(hif_drv->gtOsCfgValuesSem), 1);
4316 down(&hif_drv->gtOsCfgValuesSem);
c5c77ba1 4317
a4ab1ade 4318 hif_drv->enuHostIFstate = HOST_IF_IDLE;
a4ab1ade
TC
4319 hif_drv->strCfgValues.site_survey_enabled = SITE_SURVEY_OFF;
4320 hif_drv->strCfgValues.scan_source = DEFAULT_SCAN;
4321 hif_drv->strCfgValues.active_scan_time = ACTIVE_SCAN_TIME;
4322 hif_drv->strCfgValues.passive_scan_time = PASSIVE_SCAN_TIME;
4323 hif_drv->strCfgValues.curr_tx_rate = AUTORATE;
c5c77ba1 4324
a4ab1ade 4325 hif_drv->u64P2p_MgmtTimeout = 0;
c5c77ba1 4326
c5c77ba1
JK
4327 PRINT_INFO(HOSTINF_DBG, "Initialization values, Site survey value: %d\n Scan source: %d\n Active scan time: %d\n Passive scan time: %d\nCurrent tx Rate = %d\n",
4328
a4ab1ade
TC
4329 hif_drv->strCfgValues.site_survey_enabled, hif_drv->strCfgValues.scan_source,
4330 hif_drv->strCfgValues.active_scan_time, hif_drv->strCfgValues.passive_scan_time,
4331 hif_drv->strCfgValues.curr_tx_rate);
c5c77ba1 4332
a4ab1ade 4333 up(&hif_drv->gtOsCfgValuesSem);
c5c77ba1 4334
ae4dfa57 4335 clients_count++;
c5c77ba1 4336
5b09bd32 4337 return result;
c5c77ba1 4338
c5c77ba1 4339_fail_timer_2:
a4ab1ade
TC
4340 up(&hif_drv->gtOsCfgValuesSem);
4341 del_timer_sync(&hif_drv->hConnectTimer);
4342 del_timer_sync(&hif_drv->hScanTimer);
1999bd52 4343 kthread_stop(HostIFthreadHandler);
c5c77ba1 4344_fail_mq_:
1b128f63 4345 wilc_mq_destroy(&gMsgQHostIF);
c5c77ba1 4346_fail_:
5b09bd32 4347 return result;
c5c77ba1 4348}
c5c77ba1 4349
a4ab1ade 4350s32 host_int_deinit(struct host_if_drv *hif_drv)
c5c77ba1 4351{
e6e12661 4352 s32 s32Error = 0;
143eb95a 4353 struct host_if_msg msg;
d42ab083 4354 int ret;
c5c77ba1 4355
a4ab1ade
TC
4356 if (!hif_drv) {
4357 PRINT_ER("hif_drv = NULL\n");
c5c77ba1
JK
4358 return 0;
4359 }
4360
83383ea3 4361 down(&hSemHostIntDeinit);
c5c77ba1 4362
a4ab1ade 4363 terminated_handle = hif_drv;
c5c77ba1
JK
4364 PRINT_D(HOSTINF_DBG, "De-initializing host interface for client %d\n", clients_count);
4365
a4ab1ade 4366 if (del_timer_sync(&hif_drv->hScanTimer)) {
03b2d5e7 4367 PRINT_D(HOSTINF_DBG, ">> Scan timer is active\n");
c5c77ba1
JK
4368 }
4369
a4ab1ade 4370 if (del_timer_sync(&hif_drv->hConnectTimer)) {
03b2d5e7 4371 PRINT_D(HOSTINF_DBG, ">> Connect timer is active\n");
c5c77ba1
JK
4372 }
4373
4374
4183e979 4375 if (del_timer_sync(&g_hPeriodicRSSI)) {
03b2d5e7 4376 PRINT_D(HOSTINF_DBG, ">> Connect timer is active\n");
c5c77ba1
JK
4377 }
4378
a4ab1ade 4379 del_timer_sync(&hif_drv->hRemainOnChannel);
c5c77ba1 4380
218dc407 4381 host_int_set_wfi_drv_handler(NULL);
83383ea3 4382 down(&hSemDeinitDrvHandle);
c5c77ba1 4383
a4ab1ade
TC
4384 if (hif_drv->strWILC_UsrScanReq.pfUserScanResult) {
4385 hif_drv->strWILC_UsrScanReq.pfUserScanResult(SCAN_EVENT_ABORTED, NULL,
4386 hif_drv->strWILC_UsrScanReq.u32UserScanPvoid, NULL);
c5c77ba1 4387
a4ab1ade 4388 hif_drv->strWILC_UsrScanReq.pfUserScanResult = NULL;
c5c77ba1 4389 }
c5c77ba1 4390
a4ab1ade 4391 hif_drv->enuHostIFstate = HOST_IF_IDLE;
c5c77ba1 4392
72ed4dc7 4393 gbScanWhileConnected = false;
c5c77ba1 4394
143eb95a 4395 memset(&msg, 0, sizeof(struct host_if_msg));
c5c77ba1
JK
4396
4397 if (clients_count == 1) {
4183e979 4398 if (del_timer_sync(&g_hPeriodicRSSI)) {
03b2d5e7 4399 PRINT_D(HOSTINF_DBG, ">> Connect timer is active\n");
c5c77ba1 4400 }
a9f812a6 4401 msg.id = HOST_IF_MSG_EXIT;
a4ab1ade 4402 msg.drv = hif_drv;
c5c77ba1
JK
4403
4404
143eb95a 4405 s32Error = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
e6e12661 4406 if (s32Error != 0)
c5c77ba1 4407 PRINT_ER("Error in sending deinit's message queue message function: Error(%d)\n", s32Error);
c5c77ba1 4408
83383ea3 4409 down(&hSemHostIFthrdEnd);
c5c77ba1 4410
1b128f63 4411 wilc_mq_destroy(&gMsgQHostIF);
c5c77ba1
JK
4412 }
4413
a4ab1ade 4414 down(&(hif_drv->gtOsCfgValuesSem));
c5c77ba1 4415
a4ab1ade 4416 ret = remove_handler_in_list(hif_drv);
d42ab083 4417 if (ret)
e6e12661 4418 s32Error = -ENOENT;
d42ab083 4419
a4ab1ade 4420 kfree(hif_drv);
c5c77ba1 4421
ae4dfa57 4422 clients_count--;
b1413b60 4423 terminated_handle = NULL;
83383ea3 4424 up(&hSemHostIntDeinit);
c5c77ba1
JK
4425 return s32Error;
4426}
4427
4e4467fd 4428void NetworkInfoReceived(u8 *pu8Buffer, u32 u32Length)
c5c77ba1 4429{
e6e12661 4430 s32 s32Error = 0;
143eb95a 4431 struct host_if_msg msg;
d42ab083 4432 int id;
a4ab1ade 4433 struct host_if_drv *hif_drv = NULL;
c5c77ba1 4434
d42ab083 4435 id = ((pu8Buffer[u32Length - 4]) | (pu8Buffer[u32Length - 3] << 8) | (pu8Buffer[u32Length - 2] << 16) | (pu8Buffer[u32Length - 1] << 24));
a4ab1ade 4436 hif_drv = get_handler_from_id(id);
c5c77ba1
JK
4437
4438
4439
4440
a4ab1ade
TC
4441 if (!hif_drv || hif_drv == terminated_handle) {
4442 PRINT_ER("NetworkInfo received but driver not init[%p]\n", hif_drv);
c5c77ba1
JK
4443 return;
4444 }
4445
143eb95a 4446 memset(&msg, 0, sizeof(struct host_if_msg));
c5c77ba1 4447
a9f812a6 4448 msg.id = HOST_IF_MSG_RCVD_NTWRK_INFO;
a4ab1ade 4449 msg.drv = hif_drv;
c5c77ba1 4450
02d19460 4451 msg.body.net_info.u32Length = u32Length;
ae4dfa57 4452 msg.body.net_info.pu8Buffer = kmalloc(u32Length, GFP_KERNEL);
02d19460 4453 memcpy(msg.body.net_info.pu8Buffer,
c5c77ba1
JK
4454 pu8Buffer, u32Length);
4455
143eb95a 4456 s32Error = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
2b9d5b48 4457 if (s32Error)
c5c77ba1 4458 PRINT_ER("Error in sending network info message queue message parameters: Error(%d)\n", s32Error);
c5c77ba1
JK
4459}
4460
4e4467fd 4461void GnrlAsyncInfoReceived(u8 *pu8Buffer, u32 u32Length)
c5c77ba1 4462{
e6e12661 4463 s32 s32Error = 0;
143eb95a 4464 struct host_if_msg msg;
d42ab083 4465 int id;
a4ab1ade 4466 struct host_if_drv *hif_drv = NULL;
c5c77ba1 4467
83383ea3 4468 down(&hSemHostIntDeinit);
c5c77ba1 4469
d42ab083 4470 id = ((pu8Buffer[u32Length - 4]) | (pu8Buffer[u32Length - 3] << 8) | (pu8Buffer[u32Length - 2] << 16) | (pu8Buffer[u32Length - 1] << 24));
a4ab1ade 4471 hif_drv = get_handler_from_id(id);
03b2d5e7 4472 PRINT_D(HOSTINF_DBG, "General asynchronous info packet received\n");
c5c77ba1
JK
4473
4474
a4ab1ade 4475 if (!hif_drv || hif_drv == terminated_handle) {
c5c77ba1 4476 PRINT_D(HOSTINF_DBG, "Wifi driver handler is equal to NULL\n");
83383ea3 4477 up(&hSemHostIntDeinit);
c5c77ba1
JK
4478 return;
4479 }
4480
a4ab1ade 4481 if (!hif_drv->strWILC_UsrConnReq.pfUserConnectResult) {
c5c77ba1 4482 PRINT_ER("Received mac status is not needed when there is no current Connect Reques\n");
83383ea3 4483 up(&hSemHostIntDeinit);
c5c77ba1
JK
4484 return;
4485 }
4486
143eb95a 4487 memset(&msg, 0, sizeof(struct host_if_msg));
c5c77ba1
JK
4488
4489
a9f812a6 4490 msg.id = HOST_IF_MSG_RCVD_GNRL_ASYNC_INFO;
a4ab1ade 4491 msg.drv = hif_drv;
c5c77ba1
JK
4492
4493
66add622 4494 msg.body.async_info.u32Length = u32Length;
ae4dfa57 4495 msg.body.async_info.pu8Buffer = kmalloc(u32Length, GFP_KERNEL);
66add622 4496 memcpy(msg.body.async_info.pu8Buffer,
c5c77ba1
JK
4497 pu8Buffer, u32Length);
4498
143eb95a 4499 s32Error = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
2b9d5b48 4500 if (s32Error)
c5c77ba1 4501 PRINT_ER("Error in sending message queue asynchronous message info: Error(%d)\n", s32Error);
c5c77ba1 4502
83383ea3 4503 up(&hSemHostIntDeinit);
c5c77ba1
JK
4504}
4505
4e4467fd 4506void host_int_ScanCompleteReceived(u8 *pu8Buffer, u32 u32Length)
c5c77ba1 4507{
e6e12661 4508 s32 s32Error = 0;
143eb95a 4509 struct host_if_msg msg;
d42ab083 4510 int id;
a4ab1ade 4511 struct host_if_drv *hif_drv = NULL;
78c87591 4512
d42ab083 4513 id = ((pu8Buffer[u32Length - 4]) | (pu8Buffer[u32Length - 3] << 8) | (pu8Buffer[u32Length - 2] << 16) | (pu8Buffer[u32Length - 1] << 24));
a4ab1ade 4514 hif_drv = get_handler_from_id(id);
c5c77ba1
JK
4515
4516
a4ab1ade 4517 PRINT_D(GENERIC_DBG, "Scan notification received %p\n", hif_drv);
c5c77ba1 4518
a4ab1ade 4519 if (!hif_drv || hif_drv == terminated_handle)
c5c77ba1 4520 return;
c5c77ba1 4521
a4ab1ade 4522 if (hif_drv->strWILC_UsrScanReq.pfUserScanResult) {
143eb95a 4523 memset(&msg, 0, sizeof(struct host_if_msg));
c5c77ba1 4524
a9f812a6 4525 msg.id = HOST_IF_MSG_RCVD_SCAN_COMPLETE;
a4ab1ade 4526 msg.drv = hif_drv;
c5c77ba1 4527
143eb95a 4528 s32Error = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
2b9d5b48 4529 if (s32Error)
c5c77ba1 4530 PRINT_ER("Error in sending message queue scan complete parameters: Error(%d)\n", s32Error);
c5c77ba1
JK
4531 }
4532
4533
4534 return;
4535
4536}
4537
a4ab1ade
TC
4538s32 host_int_remain_on_channel(struct host_if_drv *hif_drv, u32 u32SessionID,
4539 u32 u32duration, u16 chan,
4540 wilc_remain_on_chan_expired RemainOnChanExpired,
4541 wilc_remain_on_chan_ready RemainOnChanReady,
4542 void *pvUserArg)
c5c77ba1 4543{
e6e12661 4544 s32 s32Error = 0;
143eb95a 4545 struct host_if_msg msg;
c5c77ba1 4546
a4ab1ade 4547 if (!hif_drv) {
24db713f
LK
4548 PRINT_ER("driver is null\n");
4549 return -EFAULT;
4550 }
c5c77ba1 4551
143eb95a 4552 memset(&msg, 0, sizeof(struct host_if_msg));
c5c77ba1 4553
a9f812a6 4554 msg.id = HOST_IF_MSG_REMAIN_ON_CHAN;
070d365c
TC
4555 msg.body.remain_on_ch.u16Channel = chan;
4556 msg.body.remain_on_ch.pRemainOnChanExpired = RemainOnChanExpired;
4557 msg.body.remain_on_ch.pRemainOnChanReady = RemainOnChanReady;
4558 msg.body.remain_on_ch.pVoid = pvUserArg;
4559 msg.body.remain_on_ch.u32duration = u32duration;
4560 msg.body.remain_on_ch.u32ListenSessionID = u32SessionID;
a4ab1ade 4561 msg.drv = hif_drv;
143eb95a
TC
4562
4563 s32Error = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
2b9d5b48 4564 if (s32Error)
24db713f 4565 PRINT_ER("wilc mq send fail\n");
c5c77ba1
JK
4566
4567 return s32Error;
4568}
4569
a4ab1ade 4570s32 host_int_ListenStateExpired(struct host_if_drv *hif_drv, u32 u32SessionID)
c5c77ba1 4571{
e6e12661 4572 s32 s32Error = 0;
143eb95a 4573 struct host_if_msg msg;
c5c77ba1 4574
a4ab1ade 4575 if (!hif_drv) {
24db713f
LK
4576 PRINT_ER("driver is null\n");
4577 return -EFAULT;
4578 }
c5c77ba1 4579
a4ab1ade 4580 del_timer(&hif_drv->hRemainOnChannel);
c5c77ba1 4581
143eb95a 4582 memset(&msg, 0, sizeof(struct host_if_msg));
a9f812a6 4583 msg.id = HOST_IF_MSG_LISTEN_TIMER_FIRED;
a4ab1ade 4584 msg.drv = hif_drv;
070d365c 4585 msg.body.remain_on_ch.u32ListenSessionID = u32SessionID;
c5c77ba1 4586
143eb95a 4587 s32Error = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
2b9d5b48 4588 if (s32Error)
24db713f 4589 PRINT_ER("wilc mq send fail\n");
c5c77ba1 4590
c5c77ba1
JK
4591 return s32Error;
4592}
4593
a4ab1ade 4594s32 host_int_frame_register(struct host_if_drv *hif_drv, u16 u16FrameType, bool bReg)
c5c77ba1 4595{
e6e12661 4596 s32 s32Error = 0;
143eb95a 4597 struct host_if_msg msg;
c5c77ba1 4598
a4ab1ade 4599 if (!hif_drv) {
24db713f
LK
4600 PRINT_ER("driver is null\n");
4601 return -EFAULT;
4602 }
c5c77ba1 4603
143eb95a 4604 memset(&msg, 0, sizeof(struct host_if_msg));
c5c77ba1 4605
a9f812a6 4606 msg.id = HOST_IF_MSG_REGISTER_FRAME;
c5c77ba1
JK
4607 switch (u16FrameType) {
4608 case ACTION:
4609 PRINT_D(HOSTINF_DBG, "ACTION\n");
5c4008db 4610 msg.body.reg_frame.u8Regid = ACTION_FRM_IDX;
c5c77ba1
JK
4611 break;
4612
4613 case PROBE_REQ:
4614 PRINT_D(HOSTINF_DBG, "PROBE REQ\n");
5c4008db 4615 msg.body.reg_frame.u8Regid = PROBE_REQ_IDX;
c5c77ba1
JK
4616 break;
4617
4618 default:
4619 PRINT_D(HOSTINF_DBG, "Not valid frame type\n");
4620 break;
4621 }
5c4008db
TC
4622 msg.body.reg_frame.u16FrameType = u16FrameType;
4623 msg.body.reg_frame.bReg = bReg;
a4ab1ade 4624 msg.drv = hif_drv;
c5c77ba1 4625
143eb95a 4626 s32Error = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
2b9d5b48 4627 if (s32Error)
24db713f 4628 PRINT_ER("wilc mq send fail\n");
c5c77ba1
JK
4629
4630 return s32Error;
4631
4632
4633}
c5c77ba1 4634
a4ab1ade
TC
4635s32 host_int_add_beacon(struct host_if_drv *hif_drv, u32 u32Interval,
4636 u32 u32DTIMPeriod, u32 u32HeadLen, u8 *pu8Head,
4637 u32 u32TailLen, u8 *pu8Tail)
c5c77ba1 4638{
e6e12661 4639 s32 s32Error = 0;
143eb95a 4640 struct host_if_msg msg;
a98491e5 4641 struct beacon_attr *pstrSetBeaconParam = &msg.body.beacon_info;
c5c77ba1 4642
a4ab1ade 4643 if (!hif_drv) {
24db713f
LK
4644 PRINT_ER("driver is null\n");
4645 return -EFAULT;
4646 }
c5c77ba1 4647
143eb95a 4648 memset(&msg, 0, sizeof(struct host_if_msg));
c5c77ba1
JK
4649
4650 PRINT_D(HOSTINF_DBG, "Setting adding beacon message queue params\n");
4651
a9f812a6 4652 msg.id = HOST_IF_MSG_ADD_BEACON;
a4ab1ade 4653 msg.drv = hif_drv;
c5c77ba1
JK
4654 pstrSetBeaconParam->u32Interval = u32Interval;
4655 pstrSetBeaconParam->u32DTIMPeriod = u32DTIMPeriod;
4656 pstrSetBeaconParam->u32HeadLen = u32HeadLen;
f3052587 4657 pstrSetBeaconParam->pu8Head = kmalloc(u32HeadLen, GFP_KERNEL);
24db713f
LK
4658 if (pstrSetBeaconParam->pu8Head == NULL) {
4659 s32Error = -ENOMEM;
4660 goto ERRORHANDLER;
4661 }
d00d2ba3 4662 memcpy(pstrSetBeaconParam->pu8Head, pu8Head, u32HeadLen);
c5c77ba1
JK
4663 pstrSetBeaconParam->u32TailLen = u32TailLen;
4664
c5c77ba1 4665 if (u32TailLen > 0) {
f3052587 4666 pstrSetBeaconParam->pu8Tail = kmalloc(u32TailLen, GFP_KERNEL);
24db713f
LK
4667 if (pstrSetBeaconParam->pu8Tail == NULL) {
4668 s32Error = -ENOMEM;
4669 goto ERRORHANDLER;
4670 }
d00d2ba3 4671 memcpy(pstrSetBeaconParam->pu8Tail, pu8Tail, u32TailLen);
c5c77ba1
JK
4672 } else {
4673 pstrSetBeaconParam->pu8Tail = NULL;
4674 }
4675
143eb95a 4676 s32Error = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
2b9d5b48 4677 if (s32Error)
24db713f 4678 PRINT_ER("wilc mq send fail\n");
c5c77ba1 4679
24db713f
LK
4680ERRORHANDLER:
4681 if (s32Error) {
2b9d5b48 4682 if (pstrSetBeaconParam->pu8Head != NULL)
49188af2 4683 kfree(pstrSetBeaconParam->pu8Head);
c5c77ba1 4684
2b9d5b48 4685 if (pstrSetBeaconParam->pu8Tail != NULL)
49188af2 4686 kfree(pstrSetBeaconParam->pu8Tail);
c5c77ba1
JK
4687 }
4688
4689 return s32Error;
4690
4691}
4692
a4ab1ade 4693s32 host_int_del_beacon(struct host_if_drv *hif_drv)
c5c77ba1 4694{
e6e12661 4695 s32 s32Error = 0;
143eb95a 4696 struct host_if_msg msg;
c5c77ba1 4697
a4ab1ade 4698 if (!hif_drv) {
24db713f
LK
4699 PRINT_ER("driver is null\n");
4700 return -EFAULT;
4701 }
c5c77ba1 4702
a9f812a6 4703 msg.id = HOST_IF_MSG_DEL_BEACON;
a4ab1ade 4704 msg.drv = hif_drv;
c5c77ba1
JK
4705 PRINT_D(HOSTINF_DBG, "Setting deleting beacon message queue params\n");
4706
143eb95a 4707 s32Error = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
7dc1d0cc
LK
4708 if (s32Error)
4709 PRINT_ER("wilc_mq_send fail\n");
c5c77ba1 4710
c5c77ba1
JK
4711 return s32Error;
4712}
4713
a4ab1ade 4714s32 host_int_add_station(struct host_if_drv *hif_drv,
6a89ba9c 4715 struct add_sta_param *pstrStaParams)
c5c77ba1 4716{
e6e12661 4717 s32 s32Error = 0;
143eb95a 4718 struct host_if_msg msg;
ca8f47f8 4719 struct add_sta_param *pstrAddStationMsg = &msg.body.add_sta_info;
c5c77ba1
JK
4720
4721
a4ab1ade 4722 if (!hif_drv) {
24db713f
LK
4723 PRINT_ER("driver is null\n");
4724 return -EFAULT;
4725 }
c5c77ba1 4726
143eb95a 4727 memset(&msg, 0, sizeof(struct host_if_msg));
c5c77ba1
JK
4728
4729 PRINT_D(HOSTINF_DBG, "Setting adding station message queue params\n");
4730
a9f812a6 4731 msg.id = HOST_IF_MSG_ADD_STATION;
a4ab1ade 4732 msg.drv = hif_drv;
c5c77ba1 4733
6a89ba9c 4734 memcpy(pstrAddStationMsg, pstrStaParams, sizeof(struct add_sta_param));
c5c77ba1 4735 if (pstrAddStationMsg->u8NumRates > 0) {
f3052587 4736 u8 *rates = kmalloc(pstrAddStationMsg->u8NumRates, GFP_KERNEL);
78c87591 4737
7ae43363
LK
4738 if (!rates)
4739 return -ENOMEM;
c5c77ba1 4740
d00d2ba3 4741 memcpy(rates, pstrStaParams->pu8Rates, pstrAddStationMsg->u8NumRates);
057d1e97 4742 pstrAddStationMsg->pu8Rates = rates;
c5c77ba1
JK
4743 }
4744
4745
143eb95a 4746 s32Error = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
2b9d5b48 4747 if (s32Error)
24db713f 4748 PRINT_ER("wilc_mq_send fail\n");
c5c77ba1
JK
4749 return s32Error;
4750}
4751
a4ab1ade 4752s32 host_int_del_station(struct host_if_drv *hif_drv, const u8 *pu8MacAddr)
c5c77ba1 4753{
e6e12661 4754 s32 s32Error = 0;
143eb95a 4755 struct host_if_msg msg;
889c25be 4756 struct del_sta *pstrDelStationMsg = &msg.body.del_sta_info;
c5c77ba1 4757
a4ab1ade 4758 if (!hif_drv) {
24db713f
LK
4759 PRINT_ER("driver is null\n");
4760 return -EFAULT;
4761 }
c5c77ba1 4762
143eb95a 4763 memset(&msg, 0, sizeof(struct host_if_msg));
c5c77ba1
JK
4764
4765 PRINT_D(HOSTINF_DBG, "Setting deleting station message queue params\n");
4766
a9f812a6 4767 msg.id = HOST_IF_MSG_DEL_STATION;
a4ab1ade 4768 msg.drv = hif_drv;
c5c77ba1 4769
b1413b60 4770 if (pu8MacAddr == NULL)
2cc46837 4771 memset(pstrDelStationMsg->au8MacAddr, 255, ETH_ALEN);
c5c77ba1 4772 else
d00d2ba3 4773 memcpy(pstrDelStationMsg->au8MacAddr, pu8MacAddr, ETH_ALEN);
c5c77ba1 4774
143eb95a 4775 s32Error = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
2b9d5b48 4776 if (s32Error)
24db713f 4777 PRINT_ER("wilc_mq_send fail\n");
c5c77ba1
JK
4778 return s32Error;
4779}
ae4dfa57 4780
a4ab1ade 4781s32 host_int_del_allstation(struct host_if_drv *hif_drv,
441dc609 4782 u8 pu8MacAddr[][ETH_ALEN])
c5c77ba1 4783{
e6e12661 4784 s32 s32Error = 0;
143eb95a 4785 struct host_if_msg msg;
b0c1e80e 4786 struct del_all_sta *pstrDelAllStationMsg = &msg.body.del_all_sta_info;
63d03e47 4787 u8 au8Zero_Buff[ETH_ALEN] = {0};
4e4467fd 4788 u32 i;
63d03e47 4789 u8 u8AssocNumb = 0;
c5c77ba1
JK
4790
4791
a4ab1ade 4792 if (!hif_drv) {
24db713f
LK
4793 PRINT_ER("driver is null\n");
4794 return -EFAULT;
4795 }
c5c77ba1 4796
143eb95a 4797 memset(&msg, 0, sizeof(struct host_if_msg));
c5c77ba1
JK
4798
4799 PRINT_D(HOSTINF_DBG, "Setting deauthenticating station message queue params\n");
4800
a9f812a6 4801 msg.id = HOST_IF_MSG_DEL_ALL_STA;
a4ab1ade 4802 msg.drv = hif_drv;
c5c77ba1 4803
c5c77ba1
JK
4804 for (i = 0; i < MAX_NUM_STA; i++) {
4805 if (memcmp(pu8MacAddr[i], au8Zero_Buff, ETH_ALEN)) {
d00d2ba3 4806 memcpy(pstrDelAllStationMsg->au8Sta_DelAllSta[i], pu8MacAddr[i], ETH_ALEN);
c5c77ba1
JK
4807 PRINT_D(CFG80211_DBG, "BSSID = %x%x%x%x%x%x\n", pstrDelAllStationMsg->au8Sta_DelAllSta[i][0], pstrDelAllStationMsg->au8Sta_DelAllSta[i][1], pstrDelAllStationMsg->au8Sta_DelAllSta[i][2], pstrDelAllStationMsg->au8Sta_DelAllSta[i][3], pstrDelAllStationMsg->au8Sta_DelAllSta[i][4],
4808 pstrDelAllStationMsg->au8Sta_DelAllSta[i][5]);
4809 u8AssocNumb++;
4810 }
4811 }
4812 if (!u8AssocNumb) {
4813 PRINT_D(CFG80211_DBG, "NO ASSOCIATED STAS\n");
4814 return s32Error;
4815 }
4816
4817 pstrDelAllStationMsg->u8Num_AssocSta = u8AssocNumb;
143eb95a 4818 s32Error = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
c5c77ba1
JK
4819
4820
2b9d5b48 4821 if (s32Error)
24db713f 4822 PRINT_ER("wilc_mq_send fail\n");
c5c77ba1 4823
83383ea3 4824 down(&hWaitResponse);
c5c77ba1
JK
4825
4826 return s32Error;
4827
4828}
4829
a4ab1ade 4830s32 host_int_edit_station(struct host_if_drv *hif_drv,
6a89ba9c 4831 struct add_sta_param *pstrStaParams)
c5c77ba1 4832{
e6e12661 4833 s32 s32Error = 0;
143eb95a 4834 struct host_if_msg msg;
ca8f47f8 4835 struct add_sta_param *pstrAddStationMsg = &msg.body.add_sta_info;
c5c77ba1 4836
a4ab1ade 4837 if (!hif_drv) {
24db713f
LK
4838 PRINT_ER("driver is null\n");
4839 return -EFAULT;
4840 }
c5c77ba1
JK
4841
4842 PRINT_D(HOSTINF_DBG, "Setting editing station message queue params\n");
4843
143eb95a 4844 memset(&msg, 0, sizeof(struct host_if_msg));
c5c77ba1 4845
a9f812a6 4846 msg.id = HOST_IF_MSG_EDIT_STATION;
a4ab1ade 4847 msg.drv = hif_drv;
c5c77ba1 4848
6a89ba9c 4849 memcpy(pstrAddStationMsg, pstrStaParams, sizeof(struct add_sta_param));
c5c77ba1 4850 if (pstrAddStationMsg->u8NumRates > 0) {
f3052587 4851 u8 *rates = kmalloc(pstrAddStationMsg->u8NumRates, GFP_KERNEL);
78c87591 4852
7ae43363
LK
4853 if (!rates)
4854 return -ENOMEM;
4855
d00d2ba3 4856 memcpy(rates, pstrStaParams->pu8Rates, pstrAddStationMsg->u8NumRates);
057d1e97 4857 pstrAddStationMsg->pu8Rates = rates;
c5c77ba1
JK
4858 }
4859
143eb95a 4860 s32Error = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
2b9d5b48 4861 if (s32Error)
24db713f
LK
4862 PRINT_ER("wilc_mq_send fail\n");
4863
c5c77ba1
JK
4864 return s32Error;
4865}
108b3439 4866
a4ab1ade
TC
4867s32 host_int_set_power_mgmt(struct host_if_drv *hif_drv,
4868 bool bIsEnabled,
4869 u32 u32Timeout)
c5c77ba1 4870{
e6e12661 4871 s32 s32Error = 0;
143eb95a 4872 struct host_if_msg msg;
49e1f81b 4873 struct power_mgmt_param *pstrPowerMgmtParam = &msg.body.pwr_mgmt_info;
c5c77ba1 4874
03b2d5e7 4875 PRINT_INFO(HOSTINF_DBG, "\n\n>> Setting PS to %d <<\n\n", bIsEnabled);
c5c77ba1 4876
a4ab1ade 4877 if (!hif_drv) {
24db713f
LK
4878 PRINT_ER("driver is null\n");
4879 return -EFAULT;
4880 }
c5c77ba1
JK
4881
4882 PRINT_D(HOSTINF_DBG, "Setting Power management message queue params\n");
4883
143eb95a 4884 memset(&msg, 0, sizeof(struct host_if_msg));
c5c77ba1 4885
a9f812a6 4886 msg.id = HOST_IF_MSG_POWER_MGMT;
a4ab1ade 4887 msg.drv = hif_drv;
c5c77ba1
JK
4888
4889 pstrPowerMgmtParam->bIsEnabled = bIsEnabled;
4890 pstrPowerMgmtParam->u32Timeout = u32Timeout;
4891
4892
143eb95a 4893 s32Error = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
2b9d5b48 4894 if (s32Error)
24db713f 4895 PRINT_ER("wilc_mq_send fail\n");
c5c77ba1
JK
4896 return s32Error;
4897}
4898
a4ab1ade
TC
4899s32 host_int_setup_multicast_filter(struct host_if_drv *hif_drv,
4900 bool bIsEnabled,
4901 u32 u32count)
c5c77ba1 4902{
e6e12661 4903 s32 s32Error = 0;
143eb95a 4904 struct host_if_msg msg;
a079cf4d 4905 struct set_multicast *pstrMulticastFilterParam = &msg.body.multicast_info;
c5c77ba1
JK
4906
4907
a4ab1ade 4908 if (!hif_drv) {
24db713f
LK
4909 PRINT_ER("driver is null\n");
4910 return -EFAULT;
4911 }
c5c77ba1
JK
4912
4913 PRINT_D(HOSTINF_DBG, "Setting Multicast Filter params\n");
4914
143eb95a 4915 memset(&msg, 0, sizeof(struct host_if_msg));
c5c77ba1 4916
a9f812a6 4917 msg.id = HOST_IF_MSG_SET_MULTICAST_FILTER;
a4ab1ade 4918 msg.drv = hif_drv;
c5c77ba1
JK
4919
4920 pstrMulticastFilterParam->bIsEnabled = bIsEnabled;
4921 pstrMulticastFilterParam->u32count = u32count;
4922
143eb95a 4923 s32Error = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
2b9d5b48 4924 if (s32Error)
24db713f 4925 PRINT_ER("wilc_mq_send fail\n");
c5c77ba1
JK
4926 return s32Error;
4927}
4928
c5c77ba1
JK
4929static void *host_int_ParseJoinBssParam(tstrNetworkInfo *ptstrNetworkInfo)
4930{
e0a12217 4931 struct join_bss_param *pNewJoinBssParam = NULL;
63d03e47 4932 u8 *pu8IEs;
d85f5326
CL
4933 u16 u16IEsLen;
4934 u16 index = 0;
63d03e47
GKH
4935 u8 suppRatesNo = 0;
4936 u8 extSuppRatesNo;
d85f5326 4937 u16 jumpOffset;
63d03e47
GKH
4938 u8 pcipherCount;
4939 u8 authCount;
4940 u8 pcipherTotalCount = 0;
4941 u8 authTotalCount = 0;
4942 u8 i, j;
c5c77ba1
JK
4943
4944 pu8IEs = ptstrNetworkInfo->pu8IEs;
4945 u16IEsLen = ptstrNetworkInfo->u16IEsLen;
4946
e0a12217 4947 pNewJoinBssParam = kmalloc(sizeof(struct join_bss_param), GFP_KERNEL);
c5c77ba1 4948 if (pNewJoinBssParam != NULL) {
e0a12217 4949 memset(pNewJoinBssParam, 0, sizeof(struct join_bss_param));
c5c77ba1
JK
4950 pNewJoinBssParam->dtim_period = ptstrNetworkInfo->u8DtimPeriod;
4951 pNewJoinBssParam->beacon_period = ptstrNetworkInfo->u16BeaconPeriod;
4952 pNewJoinBssParam->cap_info = ptstrNetworkInfo->u16CapInfo;
d00d2ba3 4953 memcpy(pNewJoinBssParam->au8bssid, ptstrNetworkInfo->au8bssid, 6);
d00d2ba3 4954 memcpy((u8 *)pNewJoinBssParam->ssid, ptstrNetworkInfo->au8ssid, ptstrNetworkInfo->u8SsidLen + 1);
c5c77ba1 4955 pNewJoinBssParam->ssidLen = ptstrNetworkInfo->u8SsidLen;
2cc46837
CL
4956 memset(pNewJoinBssParam->rsn_pcip_policy, 0xFF, 3);
4957 memset(pNewJoinBssParam->rsn_auth_policy, 0xFF, 3);
c5c77ba1 4958
c5c77ba1 4959 while (index < u16IEsLen) {
c5c77ba1 4960 if (pu8IEs[index] == SUPP_RATES_IE) {
c5c77ba1
JK
4961 suppRatesNo = pu8IEs[index + 1];
4962 pNewJoinBssParam->supp_rates[0] = suppRatesNo;
ae4dfa57 4963 index += 2;
c5c77ba1
JK
4964
4965 for (i = 0; i < suppRatesNo; i++) {
4966 pNewJoinBssParam->supp_rates[i + 1] = pu8IEs[index + i];
c5c77ba1
JK
4967 }
4968 index += suppRatesNo;
4969 continue;
ae4dfa57 4970 } else if (pu8IEs[index] == EXT_SUPP_RATES_IE) {
c5c77ba1
JK
4971 extSuppRatesNo = pu8IEs[index + 1];
4972 if (extSuppRatesNo > (MAX_RATES_SUPPORTED - suppRatesNo))
4973 pNewJoinBssParam->supp_rates[0] = MAX_RATES_SUPPORTED;
4974 else
4975 pNewJoinBssParam->supp_rates[0] += extSuppRatesNo;
4976 index += 2;
c5c77ba1
JK
4977 for (i = 0; i < (pNewJoinBssParam->supp_rates[0] - suppRatesNo); i++) {
4978 pNewJoinBssParam->supp_rates[suppRatesNo + i + 1] = pu8IEs[index + i];
c5c77ba1
JK
4979 }
4980 index += extSuppRatesNo;
4981 continue;
ae4dfa57 4982 } else if (pu8IEs[index] == HT_CAPABILITY_IE) {
0be1eb74 4983 pNewJoinBssParam->ht_capable = true;
ae4dfa57 4984 index += pu8IEs[index + 1] + 2;
c5c77ba1 4985 continue;
ae4dfa57 4986 } else if ((pu8IEs[index] == WMM_IE) &&
c5c77ba1 4987 (pu8IEs[index + 2] == 0x00) && (pu8IEs[index + 3] == 0x50) &&
ae4dfa57
LK
4988 (pu8IEs[index + 4] == 0xF2) &&
4989 (pu8IEs[index + 5] == 0x02) &&
4990 ((pu8IEs[index + 6] == 0x00) || (pu8IEs[index + 6] == 0x01)) &&
c5c77ba1 4991 (pu8IEs[index + 7] == 0x01)) {
0be1eb74 4992 pNewJoinBssParam->wmm_cap = true;
c5c77ba1 4993
ffda203c 4994 if (pu8IEs[index + 8] & BIT(7))
0be1eb74 4995 pNewJoinBssParam->uapsd_cap = true;
c5c77ba1
JK
4996 index += pu8IEs[index + 1] + 2;
4997 continue;
ae4dfa57 4998 } else if ((pu8IEs[index] == P2P_IE) &&
c5c77ba1 4999 (pu8IEs[index + 2] == 0x50) && (pu8IEs[index + 3] == 0x6f) &&
ae4dfa57
LK
5000 (pu8IEs[index + 4] == 0x9a) &&
5001 (pu8IEs[index + 5] == 0x09) && (pu8IEs[index + 6] == 0x0c)) {
d85f5326 5002 u16 u16P2P_count;
78c87591 5003
c5c77ba1
JK
5004 pNewJoinBssParam->tsf = ptstrNetworkInfo->u32Tsf;
5005 pNewJoinBssParam->u8NoaEnbaled = 1;
5006 pNewJoinBssParam->u8Index = pu8IEs[index + 9];
5007
ffda203c 5008 if (pu8IEs[index + 10] & BIT(7)) {
c5c77ba1
JK
5009 pNewJoinBssParam->u8OppEnable = 1;
5010 pNewJoinBssParam->u8CtWindow = pu8IEs[index + 10];
5011 } else
5012 pNewJoinBssParam->u8OppEnable = 0;
ae4dfa57 5013
03b2d5e7 5014 PRINT_D(GENERIC_DBG, "P2P Dump\n");
c5c77ba1 5015 for (i = 0; i < pu8IEs[index + 7]; i++)
03b2d5e7 5016 PRINT_D(GENERIC_DBG, " %x\n", pu8IEs[index + 9 + i]);
c5c77ba1
JK
5017
5018 pNewJoinBssParam->u8Count = pu8IEs[index + 11];
5019 u16P2P_count = index + 12;
5020
d00d2ba3 5021 memcpy(pNewJoinBssParam->au8Duration, pu8IEs + u16P2P_count, 4);
c5c77ba1
JK
5022 u16P2P_count += 4;
5023
d00d2ba3 5024 memcpy(pNewJoinBssParam->au8Interval, pu8IEs + u16P2P_count, 4);
c5c77ba1
JK
5025 u16P2P_count += 4;
5026
d00d2ba3 5027 memcpy(pNewJoinBssParam->au8StartTime, pu8IEs + u16P2P_count, 4);
c5c77ba1
JK
5028
5029 index += pu8IEs[index + 1] + 2;
5030 continue;
5031
ae4dfa57 5032 } else if ((pu8IEs[index] == RSN_IE) ||
c5c77ba1
JK
5033 ((pu8IEs[index] == WPA_IE) && (pu8IEs[index + 2] == 0x00) &&
5034 (pu8IEs[index + 3] == 0x50) && (pu8IEs[index + 4] == 0xF2) &&
5035 (pu8IEs[index + 5] == 0x01))) {
d85f5326 5036 u16 rsnIndex = index;
ae4dfa57 5037
c5c77ba1
JK
5038 if (pu8IEs[rsnIndex] == RSN_IE) {
5039 pNewJoinBssParam->mode_802_11i = 2;
ae4dfa57 5040 } else {
c5c77ba1
JK
5041 if (pNewJoinBssParam->mode_802_11i == 0)
5042 pNewJoinBssParam->mode_802_11i = 1;
c5c77ba1
JK
5043 rsnIndex += 4;
5044 }
ae4dfa57
LK
5045
5046 rsnIndex += 7;
c5c77ba1
JK
5047 pNewJoinBssParam->rsn_grp_policy = pu8IEs[rsnIndex];
5048 rsnIndex++;
ae4dfa57 5049 jumpOffset = pu8IEs[rsnIndex] * 4;
c5c77ba1 5050 pcipherCount = (pu8IEs[rsnIndex] > 3) ? 3 : pu8IEs[rsnIndex];
ae4dfa57 5051 rsnIndex += 2;
c5c77ba1 5052
c5c77ba1 5053 for (i = pcipherTotalCount, j = 0; i < pcipherCount + pcipherTotalCount && i < 3; i++, j++) {
c5c77ba1 5054 pNewJoinBssParam->rsn_pcip_policy[i] = pu8IEs[rsnIndex + ((j + 1) * 4) - 1];
c5c77ba1
JK
5055 }
5056 pcipherTotalCount += pcipherCount;
5057 rsnIndex += jumpOffset;
5058
5059 jumpOffset = pu8IEs[rsnIndex] * 4;
5060
c5c77ba1 5061 authCount = (pu8IEs[rsnIndex] > 3) ? 3 : pu8IEs[rsnIndex];
ae4dfa57 5062 rsnIndex += 2;
c5c77ba1
JK
5063
5064 for (i = authTotalCount, j = 0; i < authTotalCount + authCount; i++, j++) {
c5c77ba1
JK
5065 pNewJoinBssParam->rsn_auth_policy[i] = pu8IEs[rsnIndex + ((j + 1) * 4) - 1];
5066 }
5067 authTotalCount += authCount;
5068 rsnIndex += jumpOffset;
ae4dfa57 5069
c5c77ba1
JK
5070 if (pu8IEs[index] == RSN_IE) {
5071 pNewJoinBssParam->rsn_cap[0] = pu8IEs[rsnIndex];
5072 pNewJoinBssParam->rsn_cap[1] = pu8IEs[rsnIndex + 1];
5073 rsnIndex += 2;
5074 }
f717c0eb 5075 pNewJoinBssParam->rsn_found = true;
ae4dfa57 5076 index += pu8IEs[index + 1] + 2;
c5c77ba1
JK
5077 continue;
5078 } else
ae4dfa57 5079 index += pu8IEs[index + 1] + 2;
c5c77ba1
JK
5080
5081 }
5082
5083
5084 }
5085
5086 return (void *)pNewJoinBssParam;
5087
5088}
5089
5090void host_int_freeJoinParams(void *pJoinParams)
5091{
e0a12217
LK
5092 if ((struct bss_param *)pJoinParams != NULL)
5093 kfree((struct bss_param *)pJoinParams);
c5c77ba1
JK
5094 else
5095 PRINT_ER("Unable to FREE null pointer\n");
5096}
c5c77ba1 5097
a4ab1ade 5098s32 host_int_delBASession(struct host_if_drv *hif_drv, char *pBSSID, char TID)
c5c77ba1 5099{
e6e12661 5100 s32 s32Error = 0;
143eb95a 5101 struct host_if_msg msg;
c833b474 5102 struct ba_session_info *pBASessionInfo = &msg.body.session_info;
c5c77ba1 5103
a4ab1ade 5104 if (!hif_drv) {
24db713f
LK
5105 PRINT_ER("driver is null\n");
5106 return -EFAULT;
5107 }
c5c77ba1 5108
143eb95a 5109 memset(&msg, 0, sizeof(struct host_if_msg));
c5c77ba1 5110
a9f812a6 5111 msg.id = HOST_IF_MSG_DEL_BA_SESSION;
c5c77ba1
JK
5112
5113 memcpy(pBASessionInfo->au8Bssid, pBSSID, ETH_ALEN);
5114 pBASessionInfo->u8Ted = TID;
a4ab1ade 5115 msg.drv = hif_drv;
c5c77ba1 5116
143eb95a 5117 s32Error = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
2b9d5b48 5118 if (s32Error)
24db713f 5119 PRINT_ER("wilc_mq_send fail\n");
c5c77ba1 5120
83383ea3 5121 down(&hWaitResponse);
c5c77ba1
JK
5122
5123 return s32Error;
5124}
5125
a4ab1ade
TC
5126s32 host_int_del_All_Rx_BASession(struct host_if_drv *hif_drv,
5127 char *pBSSID,
5128 char TID)
c5c77ba1 5129{
e6e12661 5130 s32 s32Error = 0;
143eb95a 5131 struct host_if_msg msg;
c833b474 5132 struct ba_session_info *pBASessionInfo = &msg.body.session_info;
c5c77ba1 5133
a4ab1ade 5134 if (!hif_drv) {
24db713f
LK
5135 PRINT_ER("driver is null\n");
5136 return -EFAULT;
5137 }
c5c77ba1 5138
143eb95a 5139 memset(&msg, 0, sizeof(struct host_if_msg));
c5c77ba1 5140
a9f812a6 5141 msg.id = HOST_IF_MSG_DEL_ALL_RX_BA_SESSIONS;
c5c77ba1
JK
5142
5143 memcpy(pBASessionInfo->au8Bssid, pBSSID, ETH_ALEN);
5144 pBASessionInfo->u8Ted = TID;
a4ab1ade 5145 msg.drv = hif_drv;
c5c77ba1 5146
143eb95a 5147 s32Error = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
2b9d5b48 5148 if (s32Error)
24db713f 5149 PRINT_ER("wilc_mq_send fail\n");
c5c77ba1 5150
83383ea3 5151 down(&hWaitResponse);
c5c77ba1
JK
5152
5153 return s32Error;
5154}
5155
a4ab1ade 5156s32 host_int_setup_ipaddress(struct host_if_drv *hif_drv, u8 *u16ipadd, u8 idx)
c5c77ba1 5157{
e6e12661 5158 s32 s32Error = 0;
143eb95a 5159 struct host_if_msg msg;
c5c77ba1 5160
c5c77ba1
JK
5161 return 0;
5162
a4ab1ade 5163 if (!hif_drv) {
24db713f
LK
5164 PRINT_ER("driver is null\n");
5165 return -EFAULT;
5166 }
c5c77ba1 5167
143eb95a 5168 memset(&msg, 0, sizeof(struct host_if_msg));
c5c77ba1 5169
a9f812a6 5170 msg.id = HOST_IF_MSG_SET_IPADDRESS;
c5c77ba1 5171
fb2d65ed 5172 msg.body.ip_info.au8IPAddr = u16ipadd;
a4ab1ade 5173 msg.drv = hif_drv;
fb2d65ed 5174 msg.body.ip_info.idx = idx;
c5c77ba1 5175
143eb95a 5176 s32Error = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
2b9d5b48 5177 if (s32Error)
24db713f 5178 PRINT_ER("wilc_mq_send fail\n");
c5c77ba1
JK
5179
5180 return s32Error;
5181
5182
5183}
5184
a4ab1ade 5185s32 host_int_get_ipaddress(struct host_if_drv *hif_drv, u8 *u16ipadd, u8 idx)
c5c77ba1 5186{
e6e12661 5187 s32 s32Error = 0;
143eb95a 5188 struct host_if_msg msg;
c5c77ba1 5189
a4ab1ade 5190 if (!hif_drv) {
24db713f
LK
5191 PRINT_ER("driver is null\n");
5192 return -EFAULT;
5193 }
c5c77ba1 5194
143eb95a 5195 memset(&msg, 0, sizeof(struct host_if_msg));
c5c77ba1 5196
a9f812a6 5197 msg.id = HOST_IF_MSG_GET_IPADDRESS;
c5c77ba1 5198
fb2d65ed 5199 msg.body.ip_info.au8IPAddr = u16ipadd;
a4ab1ade 5200 msg.drv = hif_drv;
fb2d65ed 5201 msg.body.ip_info.idx = idx;
c5c77ba1 5202
143eb95a 5203 s32Error = wilc_mq_send(&gMsgQHostIF, &msg, sizeof(struct host_if_msg));
2b9d5b48 5204 if (s32Error)
24db713f 5205 PRINT_ER("wilc_mq_send fail\n");
c5c77ba1
JK
5206
5207 return s32Error;
5208
5209
5210}