2 * Copyright (c) 2007-2008 Atheros Communications Inc.
4 * Permission to use, copy, modify, and/or distribute this software for any
5 * purpose with or without fee is hereby granted, provided that the above
6 * copyright notice and this permission notice appear in all copies.
8 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
9 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
10 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
11 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
12 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
13 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
14 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
17 /* Module Name : iod.c */
20 /* This module contains OID functions. */
25 /************************************************************************/
27 #include "../hal/hpreg.h"
29 /************************************************************************/
31 /* FUNCTION DESCRIPTION zfiWlanQueryMacAddress */
32 /* Query OWN MAC address. */
35 /* addr : for return MAC address */
41 /* Stephen Chen ZyDAS Technology Corporation 2005.10 */
43 /************************************************************************/
44 void zfiWlanQueryMacAddress(zdev_t
* dev
, u8_t
* addr
)
47 zmw_get_wlan_dev(dev
);
49 vapId
= zfwGetVapId(dev
);
51 addr
[0] = (u8_t
)(wd
->macAddr
[0] & 0xff);
52 addr
[1] = (u8_t
)(wd
->macAddr
[0] >> 8);
53 addr
[2] = (u8_t
)(wd
->macAddr
[1] & 0xff);
54 addr
[3] = (u8_t
)(wd
->macAddr
[1] >> 8);
55 addr
[4] = (u8_t
)(wd
->macAddr
[2] & 0xff);
57 addr
[5] = (u8_t
)(wd
->macAddr
[2] >> 8);
60 #ifdef ZM_VAPMODE_MULTILE_SSID
61 addr
[5] = (u8_t
)(wd
->macAddr
[2] >> 8); // Multiple SSID
63 addr
[5] = vapId
+ 1 + (u8_t
)(wd
->macAddr
[2] >> 8); //VAP
70 void zfiWlanQueryBssList(zdev_t
* dev
, struct zsBssList
* pBssList
)
72 struct zsBssInfo
* pBssInfo
;
73 struct zsBssInfo
* pDstBssInfo
;
78 zmw_get_wlan_dev(dev
);
80 zmw_declare_for_critical_section();
82 pMemList
= (u8_t
*) pBssList
;
83 pMemInfo
= pMemList
+ sizeof(struct zsBssList
);
84 pBssList
->head
= (struct zsBssInfo
*) pMemInfo
;
86 zmw_enter_critical_section(dev
);
88 pBssInfo
= wd
->sta
.bssList
.head
;
89 pDstBssInfo
= (struct zsBssInfo
*) pMemInfo
;
90 pBssList
->bssCount
= wd
->sta
.bssList
.bssCount
;
92 for( i
=0; i
<wd
->sta
.bssList
.bssCount
; i
++ )
94 zfMemoryCopy((u8_t
*)pDstBssInfo
, (u8_t
*)pBssInfo
,
95 sizeof(struct zsBssInfo
));
97 if ( pBssInfo
->next
!= NULL
)
99 pBssInfo
= pBssInfo
->next
;
100 pDstBssInfo
->next
= pDstBssInfo
+ 1;
105 zm_assert(i
==(wd
->sta
.bssList
.bssCount
-1));
109 zmw_leave_critical_section(dev
);
111 zfScanMgrScanAck(dev
);
114 void zfiWlanQueryBssListV1(zdev_t
* dev
, struct zsBssListV1
* bssListV1
)
116 struct zsBssInfo
* pBssInfo
;
117 //struct zsBssInfo* pDstBssInfo;
118 u8_t i
, j
, bdrop
= 0, k
= 0, Same_Count
= 0;
122 zmw_get_wlan_dev(dev
);
123 zmw_declare_for_critical_section();
125 zmw_enter_critical_section(dev
);
127 bssListV1
->bssCount
= wd
->sta
.bssList
.bssCount
;
129 pBssInfo
= wd
->sta
.bssList
.head
;
130 ZM_MAC_WORD_TO_BYTE(wd
->sta
.bssid
, bssid
);
132 for( i
=0; i
<wd
->sta
.bssList
.bssCount
; i
++ )
135 if ( zfStaIsConnected(dev
)
136 && (wd
->wlanMode
== ZM_MODE_INFRASTRUCTURE
) )
138 for (j
= 0; j
< 6; j
++)
140 if ( pBssInfo
->bssid
[j
] != bssid
[j
] )
147 &&((pBssInfo
->ssid
[1] == wd
->sta
.ssidLen
) || (pBssInfo
->ssid
[1] == 0) )&& (pBssInfo
->frequency
== wd
->frequency
) )
149 if(pBssInfo
->ssid
[1] == 0)
150 pBssInfo
->ssid
[1] = wd
->sta
.ssidLen
;
159 bssListV1
->bssCount
--;
167 zfMemoryCopy((u8_t
*)(&bssListV1
->bssInfo
[k
]), (u8_t
*)pBssInfo
,
168 sizeof(struct zsBssInfo
));
172 zfMemoryCopy(&(bssListV1
->bssInfo
[k
].ssid
[2]), wd
->sta
.ssid
, wd
->sta
.ssidLen
);
179 if ( pBssInfo
->next
!= NULL
)
181 pBssInfo
= pBssInfo
->next
;
185 zm_assert(i
==(wd
->sta
.bssList
.bssCount
-1));
189 zmw_leave_critical_section(dev
);
191 zfScanMgrScanAck(dev
);
194 void zfiWlanQueryAdHocCreatedBssDesc(zdev_t
* dev
, struct zsBssInfo
*pBssInfo
)
196 zmw_get_wlan_dev(dev
);
198 zfMemoryCopy((u8_t
*)pBssInfo
, (u8_t
*)&wd
->sta
.ibssBssDesc
, sizeof(struct zsBssInfo
));
201 u8_t
zfiWlanQueryAdHocIsCreator(zdev_t
* dev
)
203 zmw_get_wlan_dev(dev
);
205 return wd
->sta
.ibssBssIsCreator
;
208 u32_t
zfiWlanQuerySupportMode(zdev_t
* dev
)
210 zmw_get_wlan_dev(dev
);
212 return wd
->supportMode
;
215 u32_t
zfiWlanQueryTransmitPower(zdev_t
* dev
)
219 zmw_get_wlan_dev(dev
);
221 if (zfStaIsConnected(dev
)) {
222 ret
= wd
->sta
.connPowerInHalfDbm
;
224 ret
= zfHpGetTransmitPower(dev
);
230 /************************************************************************/
232 /* FUNCTION DESCRIPTION zfiWlanFlushBssList */
233 /* Flush BSSID List. */
236 /* dev : device pointer */
242 /* Stephen Chen Atheros Communications, INC. 2006.12 */
244 /************************************************************************/
245 void zfiWlanFlushBssList(zdev_t
* dev
)
247 zmw_declare_for_critical_section();
249 zmw_enter_critical_section(dev
);
250 /* Call zfBssInfoRefresh() twice to remove all entry */
251 zfBssInfoRefresh(dev
, 1);
252 zmw_leave_critical_section(dev
);
255 void zfiWlanSetWlanMode(zdev_t
* dev
, u8_t wlanMode
)
257 zmw_get_wlan_dev(dev
);
259 zmw_declare_for_critical_section();
261 zmw_enter_critical_section(dev
);
262 wd
->ws
.wlanMode
= wlanMode
;
263 zmw_leave_critical_section(dev
);
266 void zfiWlanSetAuthenticationMode(zdev_t
* dev
, u8_t authMode
)
268 zmw_get_wlan_dev(dev
);
270 zmw_declare_for_critical_section();
272 zmw_enter_critical_section(dev
);
273 wd
->ws
.authMode
= authMode
;
274 zmw_leave_critical_section(dev
);
277 void zfiWlanSetWepStatus(zdev_t
* dev
, u8_t wepStatus
)
279 zmw_get_wlan_dev(dev
);
281 zmw_declare_for_critical_section();
283 zmw_enter_critical_section(dev
);
284 wd
->ws
.wepStatus
= wepStatus
;
285 zmw_leave_critical_section(dev
);
289 void zfiWlanSetSSID(zdev_t
* dev
, u8_t
* ssid
, u8_t ssidLength
)
292 zmw_get_wlan_dev(dev
);
294 zmw_declare_for_critical_section();
296 if ( ssidLength
<= 32 )
298 zmw_enter_critical_section(dev
);
300 wd
->ws
.ssidLen
= ssidLength
;
301 zfMemoryCopy(wd
->ws
.ssid
, ssid
, ssidLength
);
303 if ( ssidLength
< 32 )
305 wd
->ws
.ssid
[ssidLength
] = 0;
308 wd
->ws
.probingSsidList
[0].ssidLen
= ssidLength
;
309 zfMemoryCopy(wd
->ws
.probingSsidList
[0].ssid
, ssid
, ssidLength
);
310 for (i
=1; i
<ZM_MAX_PROBE_HIDDEN_SSID_SIZE
; i
++)
312 wd
->ws
.probingSsidList
[i
].ssidLen
= 0;
315 zmw_leave_critical_section(dev
);
319 void zfiWlanSetFragThreshold(zdev_t
* dev
, u16_t fragThreshold
)
321 zmw_get_wlan_dev(dev
);
323 zmw_declare_for_critical_section();
325 zmw_enter_critical_section(dev
);
327 if (fragThreshold
== 0)
328 { /* fragmentation is disabled */
329 wd
->fragThreshold
= 32767;
331 else if (fragThreshold
< 256)
333 /* Minimum fragment threshold */
334 wd
->fragThreshold
= 256;
336 else if (fragThreshold
> 2346)
338 wd
->fragThreshold
= 2346;
342 wd
->fragThreshold
= fragThreshold
& 0xfffe;
345 zmw_leave_critical_section(dev
);
348 void zfiWlanSetRtsThreshold(zdev_t
* dev
, u16_t rtsThreshold
)
350 zmw_get_wlan_dev(dev
);
352 zmw_declare_for_critical_section();
354 zmw_enter_critical_section(dev
);
355 wd
->rtsThreshold
= rtsThreshold
;
356 zmw_leave_critical_section(dev
);
359 void zfiWlanSetFrequency(zdev_t
* dev
, u32_t frequency
, u8_t bImmediate
)
361 zmw_get_wlan_dev(dev
);
363 zmw_declare_for_critical_section();
367 zmw_enter_critical_section(dev
);
368 wd
->frequency
= (u16_t
) (frequency
/1000);
369 zmw_leave_critical_section(dev
);
370 zfCoreSetFrequency(dev
, wd
->frequency
);
374 zmw_enter_critical_section(dev
);
376 { // Auto select clean channel depend on wireless environment !
377 wd
->ws
.autoSetFrequency
= 0;
379 wd
->ws
.frequency
= (u16_t
) (frequency
/1000);
380 zmw_leave_critical_section(dev
);
384 void zfiWlanSetBssid(zdev_t
* dev
, u8_t
* bssid
)
387 zmw_get_wlan_dev(dev
);
389 zmw_declare_for_critical_section();
391 zmw_enter_critical_section(dev
);
394 wd
->ws
.desiredBssid
[i
] = bssid
[i
];
396 wd
->ws
.bDesiredBssid
= TRUE
;
397 zmw_leave_critical_section(dev
);
401 void zfiWlanSetBeaconInterval(zdev_t
* dev
,
402 u16_t beaconInterval
,
405 zmw_get_wlan_dev(dev
);
407 zmw_declare_for_critical_section();
411 zmw_enter_critical_section(dev
);
412 wd
->beaconInterval
= beaconInterval
;
413 zmw_leave_critical_section(dev
);
415 /* update beacon interval here */
419 zmw_enter_critical_section(dev
);
420 wd
->ws
.beaconInterval
= beaconInterval
;
421 zmw_leave_critical_section(dev
);
426 void zfiWlanSetDtimCount(zdev_t
* dev
, u8_t dtim
)
428 zmw_get_wlan_dev(dev
);
430 zmw_declare_for_critical_section();
432 zmw_enter_critical_section(dev
);
437 zmw_leave_critical_section(dev
);
441 void zfiWlanSetAtimWindow(zdev_t
* dev
, u16_t atimWindow
, u8_t bImmediate
)
443 zmw_get_wlan_dev(dev
);
445 zmw_declare_for_critical_section();
449 zmw_enter_critical_section(dev
);
450 wd
->sta
.atimWindow
= atimWindow
;
451 zmw_leave_critical_section(dev
);
453 /* atim window here */
457 zmw_enter_critical_section(dev
);
458 wd
->ws
.atimWindow
= atimWindow
;
459 zmw_leave_critical_section(dev
);
464 void zfiWlanSetEncryMode(zdev_t
* dev
, u8_t encryMode
)
466 zmw_get_wlan_dev(dev
);
468 zmw_declare_for_critical_section();
470 zmw_enter_critical_section(dev
);
471 if (wd
->wlanMode
== ZM_MODE_AP
)
474 if ((wd
->ws
.encryMode
!= ZM_AES
) && (wd
->ws
.encryMode
!= ZM_TKIP
))
475 wd
->ws
.encryMode
= encryMode
;
478 wd
->ws
.encryMode
= encryMode
;
479 zmw_leave_critical_section(dev
);
482 void zfiWlanSetDefaultKeyId(zdev_t
* dev
, u8_t keyId
)
484 zmw_get_wlan_dev(dev
);
486 wd
->sta
.keyId
= keyId
;
489 u8_t
zfiWlanQueryIsPKInstalled(zdev_t
*dev
, u8_t
*staMacAddr
)
491 u8_t isInstalled
= 0;
493 //#ifdef ZM_ENABLE_IBSS_WPA2PSK
496 zmw_get_wlan_dev(dev
);
498 zmw_declare_for_critical_section();
500 zmw_enter_critical_section(dev
);
501 res
= zfStaFindOppositeByMACAddr(dev
, (u16_t
*)staMacAddr
, &peerIdx
);
504 isInstalled
= wd
->sta
.oppositeInfo
[peerIdx
].pkInstalled
;
506 zmw_leave_critical_section(dev
);
512 u8_t
zfiWlanSetKey(zdev_t
* dev
, struct zsKeyInfo keyInfo
)
514 u16_t broadcast
[3] = {0xffff, 0xffff, 0xffff};
516 u8_t encryMode
= ZM_NO_WEP
;
517 #ifdef ZM_ENABLE_IBSS_WPA2PSK
518 u8_t encryType
= ZM_NO_WEP
;
522 u8_t vapId
, i
, addr
[6];
525 #ifdef ZM_ENABLE_IBSS_WPA2PSK
526 /* Determine opposite exist or not */
530 zmw_get_wlan_dev(dev
);
532 if ( wd
->sta
.ibssWpa2Psk
== 1 )
534 zmw_enter_critical_section(dev
);
535 res
= zfStaFindOppositeByMACAddr(dev
, (u16_t
*)keyInfo
.macAddr
, &peerIdx
);
539 if ( wd
->sta
.oppositeInfo
[userIdx
].camIdx
== 0xff )
540 wd
->sta
.oppositeInfo
[userIdx
].camIdx
= userIdx
;
542 zmw_leave_critical_section(dev
);
545 zmw_get_wlan_dev(dev
);
548 if ( keyInfo
.flag
& ZM_KEY_FLAG_AUTHENTICATOR
)
549 { /* set key by authenticator */
550 /* set pairwise key */
551 if (keyInfo
.flag
& ZM_KEY_FLAG_PK
)
553 /* Find STA's information */
554 id
= zfApFindSta(dev
, keyInfo
.macAddr
);
557 /* Can't STA in the staTable */
558 return ZM_STATUS_FAILURE
;
561 wd
->ap
.staTable
[id
].iv16
= 0;
562 wd
->ap
.staTable
[id
].iv32
= 0;
564 if (keyInfo
.keyLength
== 32)
566 //u8_t KeyRsc[6] = {0, 0, 0, 0, 0, 0};
568 /* In the current AP mode, we set KeyRsc to zero */
569 //zfTkipInit(keyInfo.key, (u8_t*) wd->macAddr,
570 // &(wd->ap.staTable[id].txSeed), KeyRsc);
571 //zfTkipInit(keyInfo.key, (u8_t*) keyInfo.macAddr,
572 // &(wd->ap.staTable[id].rxSeed), KeyRsc);
573 #ifdef ZM_ENABLE_CENC
574 if (keyInfo
.flag
& ZM_KEY_FLAG_CENC
)
576 zm_debug_msg0("Set CENC pairwise Key");
578 wd
->ap
.staTable
[id
].encryMode
= ZM_CENC
;
580 /* Reset txiv and rxiv */
581 wd
->ap
.staTable
[id
].txiv
[0] = 0x5c365c37;
582 wd
->ap
.staTable
[id
].txiv
[1] = 0x5c365c36;
583 wd
->ap
.staTable
[id
].txiv
[2] = 0x5c365c36;
584 wd
->ap
.staTable
[id
].txiv
[3] = 0x5c365c36;
586 wd
->ap
.staTable
[id
].rxiv
[0] = 0x5c365c36;
587 wd
->ap
.staTable
[id
].rxiv
[1] = 0x5c365c36;
588 wd
->ap
.staTable
[id
].rxiv
[2] = 0x5c365c36;
589 wd
->ap
.staTable
[id
].rxiv
[3] = 0x5c365c36;
592 wd
->ap
.staTable
[id
].cencKeyIdx
= keyInfo
.keyIndex
;
594 //zfCoreSetKey(dev, id+1, 1, ZM_CENC, (u16_t *)keyInfo.macAddr,
595 // (u32_t*) &keyInfo.key[16]);
598 #endif //ZM_ENABLE_CENC
600 wd
->ap
.staTable
[id
].encryMode
= ZM_TKIP
;
602 zfMemoryCopy(micKey
, &keyInfo
.key
[16], 8);
603 zfMemoryCopy(&micKey
[8], &keyInfo
.key
[24], 8);
605 //zfCoreSetKey(dev, id+1, 1, ZM_TKIP, (u16_t *)keyInfo.macAddr,
608 /* For fragmentation, we use software MIC */
609 zfMemoryCopy((u8_t
*)&(wd
->ap
.staTable
[id
].txMicKey
), &(keyInfo
.key
[16]), 8);
610 zfMemoryCopy((u8_t
*)&(wd
->ap
.staTable
[id
].rxMicKey
), &(keyInfo
.key
[24]), 8);
614 else if (keyInfo
.keyLength
== 16)
616 wd
->ap
.staTable
[id
].encryMode
= ZM_AES
;
618 else if (keyInfo
.keyLength
== 0)
621 zfApClearStaKey(dev
, (u16_t
*)keyInfo
.macAddr
);
623 return ZM_STATUS_SUCCESS
;
627 return ZM_STATUS_FAILURE
;
630 //zfCoreSetKey(dev, id+1, 0, wd->ap.staTable[id].encryMode,
631 // (u16_t *)keyInfo.macAddr, (u32_t*) keyInfo.key);
632 zfHpSetApPairwiseKey(dev
, (u16_t
*)keyInfo
.macAddr
,
633 wd
->ap
.staTable
[id
].encryMode
, (u32_t
*) keyInfo
.key
,
634 (u32_t
*) &keyInfo
.key
[16], id
+1);
635 wd
->ap
.staTable
[id
].keyIdx
= id
+ 1 + 4;
637 else if (keyInfo
.flag
& ZM_KEY_FLAG_GK
)
639 vapId
= keyInfo
.vapId
;
641 wd
->ap
.iv16
[vapId
] = 0;
642 wd
->ap
.iv32
[vapId
] = 0;
644 if (keyInfo
.keyLength
== 32)
646 //u8_t KeyRsc[6] = {0, 0, 0, 0, 0, 0};
648 //zfTkipInit(keyInfo.key, (u8_t*) wd->macAddr,
649 // &(wd->ap.bcSeed), KeyRsc);
650 #ifdef ZM_ENABLE_CENC
651 if (keyInfo
.flag
& ZM_KEY_FLAG_CENC
)
654 zm_debug_msg0("Set CENC group Key");
656 /* Reset txiv and rxiv */
657 wd
->ap
.txiv
[vapId
][0] = 0x5c365c36;
658 wd
->ap
.txiv
[vapId
][1] = 0x5c365c36;
659 wd
->ap
.txiv
[vapId
][2] = 0x5c365c36;
660 wd
->ap
.txiv
[vapId
][3] = 0x5c365c36;
662 //zfCoreSetKey(dev, 0, 1, ZM_CENC, keyInfo.vapAddr,
663 // (u32_t*) &keyInfo.key[16]);
664 key
= (u32_t
*) keyInfo
.key
;
667 #endif //ZM_ENABLE_CENC
670 key
= (u32_t
*)keyInfo
.key
;
672 /* set MIC key to HMAC */
673 //zfCoreSetKey(dev, 0, 1, ZM_TKIP, broadcast,
674 // (u32_t*) (&keyInfo.key[16]));
675 //zfCoreSetKey(dev, 0, 1, ZM_TKIP, keyInfo.vapAddr,
676 // (u32_t*) (&keyInfo.key[16]));
678 zfMicSetKey(&(keyInfo
.key
[16]), &(wd
->ap
.bcMicKey
[0]));
679 key
= (u32_t
*) keyInfo
.key
;
682 else if (keyInfo
.keyLength
== 16)
685 key
= (u32_t
*)keyInfo
.key
;
686 zm_debug_msg0("CWY - Set AES Group Key");
688 else if (keyInfo
.keyLength
== 0)
691 zfApClearStaKey(dev
, broadcast
);
693 /* Turn off WEP bit in the capability field */
694 wd
->ap
.capab
[vapId
] &= 0xffef;
696 return ZM_STATUS_SUCCESS
;
700 if (keyInfo
.keyLength
== 5)
702 encryMode
= ZM_WEP64
;
704 else if (keyInfo
.keyLength
== 13)
706 encryMode
= ZM_WEP128
;
708 else if (keyInfo
.keyLength
== 29)
710 encryMode
= ZM_WEP256
;
713 key
= (u32_t
*) keyInfo
.key
;
716 // Modification for CAM not support VAP search
717 //zfCoreSetKey(dev, 0, 0, encryMode, broadcast, key);
718 //zfCoreSetKey(dev, 0, 0, encryMode, wd->macAddr, key);
719 //zfCoreSetKey(dev, 0, 0, encryMode, keyInfo.vapAddr, key);
720 zfHpSetApGroupKey(dev
, wd
->macAddr
, encryMode
,
721 key
, (u32_t
*) &keyInfo
.key
[16], vapId
);
723 //zfiWlanSetEncryMode(dev, encryMode);
724 wd
->ws
.encryMode
= encryMode
;
726 /* set the multicast address encryption type */
727 wd
->ap
.encryMode
[vapId
] = encryMode
;
729 /* set the multicast key index */
730 wd
->ap
.bcKeyIndex
[vapId
] = keyInfo
.keyIndex
;
731 wd
->ap
.bcHalKeyIdx
[vapId
] = vapId
+ 60;
733 /* Turn on WEP bit in the capability field */
734 wd
->ap
.capab
[vapId
] |= 0x10;
738 { /* set by supplicant */
740 if ( keyInfo
.flag
& ZM_KEY_FLAG_PK
)
741 { /* set pairwise key */
743 //zfTkipInit(keyInfo.key, (u8_t*) wd->macAddr,
744 // &wd->sta.txSeed, keyInfo.initIv);
745 //zfTkipInit(keyInfo.key, (u8_t*) wd->sta.bssid,
746 // &wd->sta.rxSeed[keyInfo.keyIndex], keyInfo.initIv);
748 #ifdef ZM_ENABLE_IBSS_WPA2PSK
749 if ( wd
->sta
.ibssWpa2Psk
== 1 )
751 /* unicast -- > pairwise key */
752 wd
->sta
.oppositeInfo
[userIdx
].iv16
= 0;
753 wd
->sta
.oppositeInfo
[userIdx
].iv32
= 0;
761 wd
->sta
.oppositeInfo
[userIdx
].pkInstalled
= 1;
766 wd
->sta
.oppositeInfo
[userIdx
].pkInstalled
= 1;
769 if ( keyInfo
.keyLength
== 32 )
771 zfTkipInit(keyInfo
.key
, (u8_t
*) wd
->macAddr
,
772 &wd
->sta
.txSeed
, keyInfo
.initIv
);
773 zfTkipInit(keyInfo
.key
, (u8_t
*) wd
->sta
.bssid
,
774 &wd
->sta
.rxSeed
[keyInfo
.keyIndex
], keyInfo
.initIv
);
776 #ifdef ZM_ENABLE_CENC
777 if (keyInfo
.flag
& ZM_KEY_FLAG_CENC
)
779 zm_debug_msg0("Set CENC pairwise Key");
781 wd
->sta
.encryMode
= ZM_CENC
;
783 /* Reset txiv and rxiv */
784 wd
->sta
.txiv
[0] = 0x5c365c36;
785 wd
->sta
.txiv
[1] = 0x5c365c36;
786 wd
->sta
.txiv
[2] = 0x5c365c36;
787 wd
->sta
.txiv
[3] = 0x5c365c36;
789 wd
->sta
.rxiv
[0] = 0x5c365c37;
790 wd
->sta
.rxiv
[1] = 0x5c365c36;
791 wd
->sta
.rxiv
[2] = 0x5c365c36;
792 wd
->sta
.rxiv
[3] = 0x5c365c36;
795 wd
->sta
.cencKeyId
= keyInfo
.keyIndex
;
797 //zfCoreSetKey(dev, id+1, 1, ZM_CENC, (u16_t *)keyInfo.macAddr,
798 // (u32_t*) &keyInfo.key[16]);
801 #endif //ZM_ENABLE_CENC
803 wd
->sta
.encryMode
= ZM_TKIP
;
805 //zfCoreSetKey(dev, 0, 1, ZM_TKIP, wd->sta.bssid,
806 // (u32_t*) &keyInfo.key[16]);
808 zfMicSetKey(&keyInfo
.key
[16], &wd
->sta
.txMicKey
);
809 zfMicSetKey(&keyInfo
.key
[24],
810 &wd
->sta
.rxMicKey
[keyInfo
.keyIndex
]);
813 else if ( keyInfo
.keyLength
== 16 )
815 #ifdef ZM_ENABLE_IBSS_WPA2PSK
816 if ( wd
->sta
.ibssWpa2Psk
== 1 )
818 wd
->sta
.oppositeInfo
[userIdx
].encryMode
= ZM_AES
;
819 encryType
= wd
->sta
.oppositeInfo
[userIdx
].encryMode
;
823 wd
->sta
.encryMode
= ZM_AES
;
824 encryType
= wd
->sta
.encryMode
;
827 wd
->sta
.encryMode
= ZM_AES
;
832 return ZM_STATUS_FAILURE
;
836 //zfCoreSetKey(dev, 0, 0, wd->sta.encryMode,
837 // wd->sta.bssid, (u32_t*) keyInfo.key);
838 //zfHpSetStaPairwiseKey(dev, wd->sta.bssid, wd->sta.encryMode,
839 // (u32_t*) keyInfo.key, (u32_t*) &keyInfo.key[16]);
841 #ifdef ZM_ENABLE_IBSS_WPA2PSK
842 if ( (keyInfo
.keyLength
==16) && (wd
->sta
.ibssWpa2Psk
==1) )
843 { /* If not AES-CCMP and ibss network , use traditional */
844 zfHpSetPerUserKey(dev
,
846 keyInfo
.keyIndex
, // key id == 0 ( Pairwise key = 0 )
847 (u8_t
*)keyInfo
.macAddr
, // RX need Source Address ( Address 2 )
849 // wd->sta.encryMode,
850 (u32_t
*) keyInfo
.key
, (u32_t
*) &keyInfo
.key
[16]);
852 wd
->sta
.oppositeInfo
[userIdx
].wpaState
= ZM_STA_WPA_STATE_PK_OK
;
855 {/* Big Endian and Little Endian Compatibility */
856 for (i
= 0; i
< 3; i
++)
858 addr
[2 * i
] = wd
->sta
.bssid
[i
] & 0xff;
859 addr
[2 * i
+ 1] = wd
->sta
.bssid
[i
] >> 8;
861 zfHpSetPerUserKey(dev
,
862 ZM_USER_KEY_PK
, // user id
864 addr
,//(u8_t *)wd->sta.bssid,
866 (u32_t
*) keyInfo
.key
, (u32_t
*) &keyInfo
.key
[16]);
871 /* Big Endian and Little Endian Compatibility */
872 for (i
= 0; i
< 3; i
++)
874 addr
[2 * i
] = wd
->sta
.bssid
[i
] & 0xff;
875 addr
[2 * i
+ 1] = wd
->sta
.bssid
[i
] >> 8;
877 zfHpSetPerUserKey(dev
,
878 ZM_USER_KEY_PK
, // user id
880 addr
,//(u8_t *)wd->sta.bssid,
882 (u32_t
*) keyInfo
.key
, (u32_t
*) &keyInfo
.key
[16]);
887 wd
->sta
.wpaState
= ZM_STA_WPA_STATE_PK_OK
;
889 else if ( keyInfo
.flag
& ZM_KEY_FLAG_GK
)
890 { /* set group key */
892 zfTkipInit(keyInfo
.key
, (u8_t
*) wd
->sta
.bssid
,
893 &wd
->sta
.rxSeed
[keyInfo
.keyIndex
], keyInfo
.initIv
);
895 if ( keyInfo
.keyLength
== 32 )
897 #ifdef ZM_ENABLE_CENC
898 if (keyInfo
.flag
& ZM_KEY_FLAG_CENC
)
901 zm_debug_msg0("Set CENC group Key");
903 /* Reset txiv and rxiv */
904 wd
->sta
.rxivGK
[0] = 0x5c365c36;
905 wd
->sta
.rxivGK
[1] = 0x5c365c36;
906 wd
->sta
.rxivGK
[2] = 0x5c365c36;
907 wd
->sta
.rxivGK
[3] = 0x5c365c36;
909 //zfCoreSetKey(dev, 0, 1, ZM_CENC, keyInfo.vapAddr,
910 // (u32_t*) &keyInfo.key[16]);
911 key
= (u32_t
*) keyInfo
.key
;
914 #endif //ZM_ENABLE_CENC
917 key
= (u32_t
*) wd
->sta
.rxSeed
[keyInfo
.keyIndex
].tk
;
919 if ( !(keyInfo
.flag
& ZM_KEY_FLAG_INIT_IV
) )
921 wd
->sta
.rxSeed
[keyInfo
.keyIndex
].iv16
= 0;
922 wd
->sta
.rxSeed
[keyInfo
.keyIndex
].iv32
= 0;
925 /* set MIC key to HMAC */
926 //zfCoreSetKey(dev, 8, 1, ZM_TKIP, broadcast,
927 // (u32_t*) (&keyInfo.key[16]));
929 zfMicSetKey(&keyInfo
.key
[24],
930 &wd
->sta
.rxMicKey
[keyInfo
.keyIndex
]);
933 else if ( keyInfo
.keyLength
== 16 )
936 //key = (u32_t*) wd->sta.rxSeed[keyInfo.keyIndex].tk;
940 if ( keyInfo
.keyLength
== 5 )
942 encryMode
= ZM_WEP64
;
944 else if ( keyInfo
.keyLength
== 13 )
946 encryMode
= ZM_WEP128
;
948 else if ( keyInfo
.keyLength
== 29 )
950 encryMode
= ZM_WEP256
;
953 key
= (u32_t
*) keyInfo
.key
;
957 //zfCoreSetKey(dev, 8, 0, encryMode, broadcast, key);
958 //zfHpSetStaGroupKey(dev, broadcast, encryMode,
959 // (u32_t*) keyInfo.key, (u32_t*) (&keyInfo.key[16]));
961 #ifdef ZM_ENABLE_IBSS_WPA2PSK
962 if ( (keyInfo
.keyLength
==16) && (wd
->sta
.ibssWpa2Psk
==1) )
963 {/* If not AES-CCMP and ibss network , use traditional */
964 zfHpSetPerUserKey(dev
,
966 keyInfo
.keyIndex
, // key id
967 // (u8_t *)broadcast, // for only 2 stations IBSS netwrl ( A2 )
968 (u8_t
*)keyInfo
.macAddr
, // for multiple ( > 2 ) stations IBSS network ( A2 )
970 (u32_t
*) keyInfo
.key
, (u32_t
*) &keyInfo
.key
[16]);
974 zfHpSetPerUserKey(dev
,
975 ZM_USER_KEY_GK
, // user id
979 (u32_t
*) keyInfo
.key
, (u32_t
*) &keyInfo
.key
[16]);
981 wd
->sta
.wpaState
= ZM_STA_WPA_STATE_GK_OK
;
984 zfHpSetPerUserKey(dev
,
985 ZM_USER_KEY_GK
, // user id
989 (u32_t
*) keyInfo
.key
, (u32_t
*) &keyInfo
.key
[16]);
991 wd
->sta
.wpaState
= ZM_STA_WPA_STATE_GK_OK
;
996 zm_debug_msg0("legacy WEP");
998 if ( keyInfo
.keyIndex
>= 4 )
1000 return ZM_STATUS_FAILURE
;
1003 if ( keyInfo
.keyLength
== 5 )
1005 zm_debug_msg0("WEP 64");
1007 encryMode
= ZM_WEP64
;
1009 else if ( keyInfo
.keyLength
== 13 )
1011 zm_debug_msg0("WEP 128");
1013 encryMode
= ZM_WEP128
;
1015 else if ( keyInfo
.keyLength
== 32 )
1019 encryMode
= ZM_TKIP
;
1021 zfTkipInit(keyInfo
.key
, (u8_t
*) wd
->sta
.bssid
,
1022 &wd
->sta
.rxSeed
[keyInfo
.keyIndex
], keyInfo
.initIv
);
1023 zfMicSetKey(&keyInfo
.key
[24],
1024 &wd
->sta
.rxMicKey
[keyInfo
.keyIndex
]);
1026 else if ( keyInfo
.keyLength
== 16 )
1032 else if ( keyInfo
.keyLength
== 29 )
1034 zm_debug_msg0("WEP 256");
1036 encryMode
= ZM_WEP256
;
1037 //zfCoreSetKey(dev, 64, 1, wd->sta.encryMode,
1038 // wd->sta.bssid, (u32_t*) (&keyInfo.key[16]));
1042 return ZM_STATUS_FAILURE
;
1048 zm_debug_msg0("key = ");
1049 for(i
= 0; i
< keyInfo
.keyLength
; i
++)
1051 zm_debug_msg2("", keyInfo
.key
[i
]);
1055 if ( keyInfo
.flag
& ZM_KEY_FLAG_DEFAULT_KEY
)
1057 //for WEP default key 1~3 and ATOM platform--CWYang(+)
1059 wd
->ap
.bcHalKeyIdx
[vapId
] = keyInfo
.keyIndex
;
1060 wd
->ap
.bcKeyIndex
[vapId
] = keyInfo
.keyIndex
;
1061 wd
->sta
.keyId
= keyInfo
.keyIndex
;
1064 if(encryMode
== ZM_TKIP
)
1066 if(wd
->TKIP_Group_KeyChanging
== 0x1)
1068 zm_debug_msg0("Countermeasure : Cancel Old Timer ");
1069 zfTimerCancel(dev
, ZM_EVENT_SKIP_COUNTERMEASURE
);
1073 zm_debug_msg0("Countermeasure : Create New Timer ");
1076 wd
->TKIP_Group_KeyChanging
= 0x1;
1077 zfTimerSchedule(dev
, ZM_EVENT_SKIP_COUNTERMEASURE
, 150);
1082 //------------------------------------------------------------------------
1084 /* use default key */
1085 //zfCoreSetKey(dev, ZM_USER_KEY_DEFAULT+keyInfo.keyIndex, 0,
1086 // wd->sta.encryMode, wd->sta.bssid, (u32_t*) keyInfo.key);
1088 if ( encryMode
== ZM_TKIP
||
1089 encryMode
== ZM_AES
)
1091 zfHpSetDefaultKey(dev
, keyInfo
.keyIndex
, encryMode
,
1092 (u32_t
*) keyInfo
.key
, (u32_t
*) &keyInfo
.key
[16]);
1094 #ifdef ZM_ENABLE_IBSS_WPA2PSK
1095 if ( (keyInfo
.keyLength
==16) && (wd
->sta
.ibssWpa2Psk
==1) )
1096 {/* If not AES-CCMP and ibss network , use traditional */
1097 wd
->sta
.wpaState
= ZM_STA_WPA_STATE_PK_OK
;
1101 if (wd
->sta
.wpaState
== ZM_STA_WPA_STATE_PK_OK
)
1102 wd
->sta
.wpaState
= ZM_STA_WPA_STATE_GK_OK
;
1105 wd
->sta
.wpaState
= ZM_STA_WPA_STATE_PK_OK
;
1106 wd
->sta
.encryMode
= encryMode
;
1107 wd
->ws
.encryMode
= encryMode
;
1111 if (wd
->sta
.wpaState
== ZM_STA_WPA_STATE_PK_OK
)
1112 wd
->sta
.wpaState
= ZM_STA_WPA_STATE_GK_OK
;
1113 else if ( wd
->sta
.wpaState
== ZM_STA_WPA_STATE_INIT
)
1115 wd
->sta
.wpaState
= ZM_STA_WPA_STATE_PK_OK
;
1116 wd
->sta
.encryMode
= encryMode
;
1117 wd
->ws
.encryMode
= encryMode
;
1123 zfHpSetDefaultKey(dev
, keyInfo
.keyIndex
, encryMode
,
1124 (u32_t
*) keyInfo
.key
, NULL
);
1126 /* Save key for software WEP */
1127 zfMemoryCopy(wd
->sta
.wepKey
[keyInfo
.keyIndex
], keyInfo
.key
,
1130 /* TODO: Check whether we need to save the SWEncryMode */
1131 wd
->sta
.SWEncryMode
[keyInfo
.keyIndex
] = encryMode
;
1133 wd
->sta
.encryMode
= encryMode
;
1134 wd
->ws
.encryMode
= encryMode
;
1139 // wd->sta.flagKeyChanging = 1;
1140 return ZM_STATUS_SUCCESS
;
1144 u8_t
zfiWlanPSEUDOSetKey(zdev_t
* dev
, struct zsKeyInfo keyInfo
)
1146 //u16_t broadcast[3] = {0xffff, 0xffff, 0xffff};
1150 zmw_get_wlan_dev(dev
);
1152 switch (keyInfo
.keyLength
)
1155 wd
->sta
.encryMode
= ZM_WEP64
;
1156 /* use default key */
1157 zfCoreSetKey(dev
, 64, 0, ZM_WEP64
, (u16_t
*)keyInfo
.macAddr
, (u32_t
*) keyInfo
.key
);
1161 wd
->sta
.encryMode
= ZM_WEP128
;
1162 /* use default key */
1163 zfCoreSetKey(dev
, 64, 0, ZM_WEP128
, (u16_t
*)keyInfo
.macAddr
, (u32_t
*) keyInfo
.key
);
1167 wd
->sta
.encryMode
= ZM_WEP256
;
1168 /* use default key */
1169 zfCoreSetKey(dev
, 64, 1, ZM_WEP256
, (u16_t
*)keyInfo
.macAddr
, (u32_t
*) (&keyInfo
.key
[16]));
1170 zfCoreSetKey(dev
, 64, 0, ZM_WEP256
, (u16_t
*)keyInfo
.macAddr
, (u32_t
*) keyInfo
.key
);
1174 wd
->sta
.encryMode
= ZM_AES
;
1175 //zfCoreSetKey(dev, 0, 0, ZM_AES, (u16_t *)keyInfo.macAddr, (u32_t*) keyInfo.key);
1176 zfCoreSetKey(dev
, 64, 0, ZM_AES
, (u16_t
*)keyInfo
.macAddr
, (u32_t
*) keyInfo
.key
);
1180 #ifdef ZM_ENABLE_CENC
1181 if (keyInfo
.flag
& ZM_KEY_FLAG_CENC
)
1183 u16_t boardcastAddr
[3] = {0xffff, 0xffff, 0xffff};
1184 u16_t Addr_a
[] = { 0x0000, 0x0080, 0x0901};
1185 u16_t Addr_b
[] = { 0x0000, 0x0080, 0x0902};
1186 /* CENC test: user0,1 and user2 for boardcast */
1187 wd
->sta
.encryMode
= ZM_CENC
;
1188 zfCoreSetKey(dev
, 0, 1, ZM_CENC
, (u16_t
*)Addr_a
, (u32_t
*) (&keyInfo
.key
[16]));
1189 zfCoreSetKey(dev
, 0, 0, ZM_CENC
, (u16_t
*)Addr_a
, (u32_t
*) keyInfo
.key
);
1191 zfCoreSetKey(dev
, 1, 1, ZM_CENC
, (u16_t
*)Addr_b
, (u32_t
*) (&keyInfo
.key
[16]));
1192 zfCoreSetKey(dev
, 1, 0, ZM_CENC
, (u16_t
*)Addr_b
, (u32_t
*) keyInfo
.key
);
1194 zfCoreSetKey(dev
, 2, 1, ZM_CENC
, (u16_t
*)boardcastAddr
, (u32_t
*) (&keyInfo
.key
[16]));
1195 zfCoreSetKey(dev
, 2, 0, ZM_CENC
, (u16_t
*)boardcastAddr
, (u32_t
*) keyInfo
.key
);
1197 /* Initialize PN sequence */
1198 wd
->sta
.txiv
[0] = 0x5c365c36;
1199 wd
->sta
.txiv
[1] = 0x5c365c36;
1200 wd
->sta
.txiv
[2] = 0x5c365c36;
1201 wd
->sta
.txiv
[3] = 0x5c365c36;
1204 #endif //ZM_ENABLE_CENC
1206 wd
->sta
.encryMode
= ZM_TKIP
;
1207 zfCoreSetKey(dev
, 64, 1, ZM_TKIP
, (u16_t
*)keyInfo
.macAddr
, (u32_t
*) micKey
);
1208 zfCoreSetKey(dev
, 64, 0, ZM_TKIP
, (u16_t
*)keyInfo
.macAddr
, (u32_t
*) keyInfo
.key
);
1212 wd
->sta
.encryMode
= ZM_NO_WEP
;
1215 return ZM_STATUS_SUCCESS
;
1218 void zfiWlanSetPowerSaveMode(zdev_t
* dev
, u8_t mode
)
1221 zfPowerSavingMgrSetMode(dev
, mode
);
1224 void zfiWlanSetMacAddress(zdev_t
* dev
, u16_t
* mac
)
1226 zmw_get_wlan_dev(dev
);
1228 wd
->macAddr
[0] = mac
[0];
1229 wd
->macAddr
[1] = mac
[1];
1230 wd
->macAddr
[2] = mac
[2];
1232 zfHpSetMacAddress(dev
, mac
, 0);
1235 u8_t
zfiWlanQueryWlanMode(zdev_t
* dev
)
1237 zmw_get_wlan_dev(dev
);
1239 return wd
->wlanMode
;
1242 u8_t
zfiWlanQueryAdapterState(zdev_t
* dev
)
1244 zmw_get_wlan_dev(dev
);
1249 u8_t
zfiWlanQueryAuthenticationMode(zdev_t
* dev
, u8_t bWrapper
)
1253 zmw_get_wlan_dev(dev
);
1257 authMode
= wd
->ws
.authMode
;
1261 //authMode = wd->sta.authMode;
1262 authMode
= wd
->sta
.currentAuthMode
;
1268 u8_t
zfiWlanQueryWepStatus(zdev_t
* dev
, u8_t bWrapper
)
1272 zmw_get_wlan_dev(dev
);
1276 wepStatus
= wd
->ws
.wepStatus
;
1280 wepStatus
= wd
->sta
.wepStatus
;
1286 void zfiWlanQuerySSID(zdev_t
* dev
, u8_t
* ssid
, u8_t
* pSsidLength
)
1289 zmw_get_wlan_dev(dev
);
1291 if (wd
->wlanMode
== ZM_MODE_AP
)
1293 vapId
= zfwGetVapId(dev
);
1295 if (vapId
== 0xffff)
1297 *pSsidLength
= wd
->ap
.ssidLen
[0];
1298 zfMemoryCopy(ssid
, wd
->ap
.ssid
[0], wd
->ap
.ssidLen
[0]);
1302 *pSsidLength
= wd
->ap
.ssidLen
[vapId
+ 1];
1303 zfMemoryCopy(ssid
, wd
->ap
.ssid
[vapId
+ 1], wd
->ap
.ssidLen
[vapId
+ 1]);
1308 *pSsidLength
= wd
->sta
.ssidLen
;
1309 zfMemoryCopy(ssid
, wd
->sta
.ssid
, wd
->sta
.ssidLen
);
1313 u16_t
zfiWlanQueryFragThreshold(zdev_t
* dev
)
1315 zmw_get_wlan_dev(dev
);
1317 return wd
->fragThreshold
;
1320 u16_t
zfiWlanQueryRtsThreshold(zdev_t
* dev
)
1322 zmw_get_wlan_dev(dev
);
1324 return wd
->rtsThreshold
;
1327 u32_t
zfiWlanQueryFrequency(zdev_t
* dev
)
1329 zmw_get_wlan_dev(dev
);
1331 return (wd
->frequency
*1000);
1334 /***********************************************************
1335 * Function: zfiWlanQueryCurrentFrequency
1337 * - 0 : no validate current frequency
1338 * - (>0): current frequency depend on "qmode"
1341 * 0: return value depend on the support mode, this
1342 qmode is use to solve the bug #31223
1343 * 1: return the actually current frequency
1344 ***********************************************************/
1345 u32_t
zfiWlanQueryCurrentFrequency(zdev_t
* dev
, u8_t qmode
)
1349 zmw_get_wlan_dev(dev
);
1354 if (wd
->sta
.currentFrequency
> 3000)
1356 if (wd
->supportMode
& ZM_WIRELESS_MODE_5
)
1358 frequency
= wd
->sta
.currentFrequency
;
1360 else if (wd
->supportMode
& ZM_WIRELESS_MODE_24
)
1362 frequency
= zfChGetFirst2GhzChannel(dev
);
1371 if (wd
->supportMode
& ZM_WIRELESS_MODE_24
)
1373 frequency
= wd
->sta
.currentFrequency
;
1375 else if (wd
->supportMode
& ZM_WIRELESS_MODE_5
)
1377 frequency
= zfChGetLast5GhzChannel(dev
);
1387 frequency
= wd
->sta
.currentFrequency
;
1394 return (frequency
*1000);
1397 u32_t
zfiWlanQueryFrequencyAttribute(zdev_t
* dev
, u32_t freq
)
1400 u16_t frequency
= (u16_t
) (freq
/1000);
1403 zmw_get_wlan_dev(dev
);
1405 for (i
= 0; i
< wd
->regulationTable
.allowChannelCnt
; i
++)
1407 if ( wd
->regulationTable
.allowChannel
[i
].channel
== frequency
)
1409 ret
= wd
->regulationTable
.allowChannel
[i
].channelFlags
;
1416 /* BandWidth 0=>20 1=>40 */
1417 /* ExtOffset 0=>20 1=>high control 40 3=>low control 40 */
1418 void zfiWlanQueryFrequencyHT(zdev_t
* dev
, u32_t
*bandWidth
, u32_t
*extOffset
)
1420 zmw_get_wlan_dev(dev
);
1422 *bandWidth
= wd
->BandWidth40
;
1423 *extOffset
= wd
->ExtOffset
;
1426 u8_t
zfiWlanQueryCWMode(zdev_t
* dev
)
1428 zmw_get_wlan_dev(dev
);
1430 return wd
->cwm
.cw_mode
;
1433 u32_t
zfiWlanQueryCWEnable(zdev_t
* dev
)
1435 zmw_get_wlan_dev(dev
);
1437 return wd
->cwm
.cw_enable
;
1440 void zfiWlanQueryBssid(zdev_t
* dev
, u8_t
* bssid
)
1444 zmw_get_wlan_dev(dev
);
1446 ZM_MAC_WORD_TO_BYTE(wd
->sta
.bssid
, addr
);
1447 zfMemoryCopy(bssid
, addr
, 6);
1450 u16_t
zfiWlanQueryBeaconInterval(zdev_t
* dev
)
1452 zmw_get_wlan_dev(dev
);
1454 return wd
->beaconInterval
;
1457 u32_t
zfiWlanQueryRxBeaconTotal(zdev_t
* dev
)
1459 zmw_get_wlan_dev(dev
);
1460 wd
->sta
.rxBeaconTotal
+= wd
->sta
.rxBeaconCount
;
1462 return wd
->sta
.rxBeaconTotal
;
1465 u16_t
zfiWlanQueryAtimWindow(zdev_t
* dev
)
1469 zmw_get_wlan_dev(dev
);
1471 atimWindow
= wd
->sta
.atimWindow
;
1476 u8_t
zfiWlanQueryEncryMode(zdev_t
* dev
)
1478 zmw_get_wlan_dev(dev
);
1480 if (wd
->wlanMode
== ZM_MODE_AP
)
1481 return wd
->ap
.encryMode
[0];
1483 return wd
->sta
.encryMode
;
1486 u16_t
zfiWlanQueryCapability(zdev_t
* dev
)
1490 zmw_get_wlan_dev(dev
);
1492 capability
= wd
->sta
.capability
[0] +
1493 (((u16_t
) wd
->sta
.capability
[1]) << 8);
1499 u16_t
zfiWlanQueryAid(zdev_t
* dev
)
1501 zmw_get_wlan_dev(dev
);
1506 void zfiWlanQuerySupportRate(zdev_t
* dev
, u8_t
* rateArray
, u8_t
* pLength
)
1510 zmw_get_wlan_dev(dev
);
1512 for( i
=0; i
<4; i
++ )
1514 if ( wd
->bRate
& (0x1 << i
) )
1516 rateArray
[j
] = zg11bRateTbl
[i
] +
1517 ((wd
->bRateBasic
& (0x1<<i
))<<(7-i
));
1525 void zfiWlanQueryExtSupportRate(zdev_t
* dev
, u8_t
* rateArray
, u8_t
* pLength
)
1529 zmw_get_wlan_dev(dev
);
1531 for( i
=0; i
<8; i
++ )
1533 if ( wd
->gRate
& (0x1 << i
) )
1535 rateArray
[j
] = zg11gRateTbl
[i
] +
1536 ((wd
->gRateBasic
& (0x1<<i
))<<(7-i
));
1544 void zfiWlanQueryRsnIe(zdev_t
* dev
, u8_t
* ie
, u8_t
* pLength
)
1548 zmw_get_wlan_dev(dev
);
1550 len
= wd
->sta
.rsnIe
[1] + 2;
1551 zfMemoryCopy(ie
, wd
->sta
.rsnIe
, len
);
1555 void zfiWlanQueryWpaIe(zdev_t
* dev
, u8_t
* ie
, u8_t
* pLength
)
1559 zmw_get_wlan_dev(dev
);
1561 len
= wd
->sta
.wpaIe
[1] + 2;
1562 zfMemoryCopy(ie
, wd
->sta
.wpaIe
, len
);
1567 u8_t
zfiWlanQueryMulticastCipherAlgo(zdev_t
*dev
)
1569 zmw_get_wlan_dev(dev
);
1571 switch( wd
->sta
.currentAuthMode
)
1573 case ZM_AUTH_MODE_WPA2PSK
:
1574 case ZM_AUTH_MODE_WPA2
:
1575 if ( wd
->sta
.rsnIe
[7] == 2 )
1585 case ZM_AUTH_MODE_WPAPSK
:
1586 case ZM_AUTH_MODE_WPA
:
1587 if ( wd
->sta
.rsnIe
[11] == 2 )
1598 return wd
->sta
.encryMode
;
1602 u8_t
zfiWlanQueryHTMode(zdev_t
* dev
)
1604 zmw_get_wlan_dev(dev
);
1606 return wd
->sta
.EnableHT
;
1609 u8_t
zfiWlanQueryBandWidth40(zdev_t
* dev
)
1611 zmw_get_wlan_dev(dev
);
1613 return wd
->BandWidth40
;
1616 u16_t
zfiWlanQueryRegionCode(zdev_t
* dev
)
1618 zmw_get_wlan_dev(dev
);
1620 return wd
->regulationTable
.regionCode
;
1622 void zfiWlanSetWpaIe(zdev_t
* dev
, u8_t
* ie
, u8_t Length
)
1625 zmw_get_wlan_dev(dev
);
1627 if (wd
->wlanMode
== ZM_MODE_AP
) // AP Mode
1629 vapId
= zfwGetVapId(dev
);
1631 if (vapId
== 0xffff)
1636 zm_assert(Length
< ZM_MAX_WPAIE_SIZE
);
1637 if (Length
< ZM_MAX_WPAIE_SIZE
)
1639 wd
->ap
.wpaLen
[vapId
] = Length
;
1640 zfMemoryCopy(wd
->ap
.wpaIe
[vapId
], ie
, wd
->ap
.wpaLen
[vapId
]);
1646 wd
->sta
.wpaLen
= Length
;
1647 zfMemoryCopy(wd
->sta
.wpaIe
, ie
, wd
->sta
.wpaLen
);
1649 //zfiWlanSetWpaSupport(dev, 1);
1650 if (wd
->wlanMode
== ZM_MODE_AP
) // AP Mode
1652 wd
->ap
.wpaSupport
[vapId
] = 1;
1656 wd
->sta
.wpaSupport
= 1;
1661 void zfiWlanSetWpaSupport(zdev_t
* dev
, u8_t WpaSupport
)
1664 zmw_get_wlan_dev(dev
);
1666 if (wd
->wlanMode
== ZM_MODE_AP
) // AP Mode
1668 vapId
= zfwGetVapId(dev
);
1670 if (vapId
== 0xffff)
1675 wd
->ap
.wpaSupport
[vapId
] = WpaSupport
;
1679 wd
->sta
.wpaSupport
= WpaSupport
;
1684 void zfiWlanSetProtectionMode(zdev_t
* dev
, u8_t mode
)
1686 zmw_get_wlan_dev(dev
);
1688 wd
->sta
.bProtectionMode
= mode
;
1689 if (wd
->sta
.bProtectionMode
== TRUE
)
1691 zfHpSetSlotTime(dev
, 0);
1695 zfHpSetSlotTime(dev
, 1);
1698 zm_msg1_mm(ZM_LV_1
, "wd->protectionMode=", wd
->sta
.bProtectionMode
);
1701 void zfiWlanSetBasicRate(zdev_t
* dev
, u8_t bRateSet
, u8_t gRateSet
,
1704 zmw_get_wlan_dev(dev
);
1706 wd
->ws
.bRateBasic
= bRateSet
;
1707 wd
->ws
.gRateBasic
= gRateSet
;
1708 wd
->ws
.nRateBasic
= nRateSet
;
1711 void zfiWlanSetBGMode(zdev_t
* dev
, u8_t mode
)
1713 zmw_get_wlan_dev(dev
);
1715 wd
->ws
.bgMode
= mode
;
1718 void zfiWlanSetpreambleType(zdev_t
* dev
, u8_t type
)
1720 zmw_get_wlan_dev(dev
);
1722 wd
->ws
.preambleType
= type
;
1725 u8_t
zfiWlanQuerypreambleType(zdev_t
* dev
)
1727 zmw_get_wlan_dev(dev
);
1729 return wd
->ws
.preambleType
;
1732 u8_t
zfiWlanQueryPowerSaveMode(zdev_t
* dev
)
1734 zmw_get_wlan_dev(dev
);
1736 return wd
->sta
.powerSaveMode
;
1739 u8_t
zfiWlanSetPmkidInfo(zdev_t
* dev
, u16_t
* bssid
, u8_t
* pmkid
)
1743 zmw_get_wlan_dev(dev
);
1745 for(i
=0; i
<wd
->sta
.pmkidInfo
.bssidCount
; i
++)
1747 if ( zfMemoryIsEqual((u8_t
*) wd
->sta
.pmkidInfo
.bssidInfo
[i
].bssid
,
1755 if ( i
< wd
->sta
.pmkidInfo
.bssidCount
)
1757 /* overwrite the original one */
1758 zfMemoryCopy(wd
->sta
.pmkidInfo
.bssidInfo
[i
].pmkid
, pmkid
, 16);
1762 if ( i
< ZM_PMKID_MAX_BSS_CNT
)
1764 wd
->sta
.pmkidInfo
.bssidInfo
[i
].bssid
[0] = bssid
[0];
1765 wd
->sta
.pmkidInfo
.bssidInfo
[i
].bssid
[1] = bssid
[1];
1766 wd
->sta
.pmkidInfo
.bssidInfo
[i
].bssid
[2] = bssid
[2];
1768 zfMemoryCopy(wd
->sta
.pmkidInfo
.bssidInfo
[i
].pmkid
, pmkid
, 16);
1769 wd
->sta
.pmkidInfo
.bssidCount
++;
1776 u32_t
zfiWlanQueryPmkidInfo(zdev_t
* dev
, u8_t
* buf
, u32_t len
)
1778 //struct zsPmkidInfo* pPmkidInfo = ( struct zsPmkidInfo* ) buf;
1781 zmw_get_wlan_dev(dev
);
1783 size
= sizeof(u32_t
) +
1784 wd
->sta
.pmkidInfo
.bssidCount
* sizeof(struct zsPmkidBssidInfo
);
1788 return wd
->sta
.pmkidInfo
.bssidCount
;
1791 zfMemoryCopy(buf
, (u8_t
*) &wd
->sta
.pmkidInfo
, (u16_t
) size
);
1796 void zfiWlanSetMulticastList(zdev_t
* dev
, u8_t size
, u8_t
* pList
)
1798 struct zsMulticastAddr
* pMacList
= (struct zsMulticastAddr
*) pList
;
1800 u8_t bAllMulticast
= 0;
1803 zmw_get_wlan_dev(dev
);
1805 wd
->sta
.multicastList
.size
= size
;
1806 for(i
=0; i
<size
; i
++)
1808 zfMemoryCopy(wd
->sta
.multicastList
.macAddr
[i
].addr
,
1809 pMacList
[i
].addr
, 6);
1812 if ( wd
->sta
.osRxFilter
& ZM_PACKET_TYPE_ALL_MULTICAST
)
1814 zfHpSetMulticastList(dev
, size
, pList
, bAllMulticast
);
1818 void zfiWlanRemoveKey(zdev_t
* dev
, u8_t keyType
, u8_t keyId
)
1820 u16_t fakeMacAddr
[3] = {0, 0, 0};
1821 u32_t fakeKey
[4] = {0, 0, 0, 0};
1823 zmw_get_wlan_dev(dev
);
1827 /* remove WEP key */
1828 zm_debug_msg0("remove WEP key");
1829 zfCoreSetKey(dev
, ZM_USER_KEY_DEFAULT
+keyId
, 0,
1830 ZM_NO_WEP
, fakeMacAddr
, fakeKey
);
1831 wd
->sta
.encryMode
= ZM_NO_WEP
;
1833 else if ( keyType
== 1 )
1835 /* remove pairwise key */
1836 zm_debug_msg0("remove pairwise key");
1837 zfHpRemoveKey(dev
, ZM_USER_KEY_PK
);
1838 wd
->sta
.encryMode
= ZM_NO_WEP
;
1842 /* remove group key */
1843 zm_debug_msg0("remove group key");
1844 zfHpRemoveKey(dev
, ZM_USER_KEY_GK
);
1849 void zfiWlanQueryRegulationTable(zdev_t
* dev
, struct zsRegulationTable
* pEntry
)
1851 zmw_get_wlan_dev(dev
);
1853 zfMemoryCopy((u8_t
*) pEntry
, (u8_t
*) &wd
->regulationTable
,
1854 sizeof(struct zsRegulationTable
));
1857 /* parameter "time" is specified in ms */
1858 void zfiWlanSetScanTimerPerChannel(zdev_t
* dev
, u16_t time
)
1860 zmw_get_wlan_dev(dev
);
1862 zm_debug_msg1("scan time (ms) = ", time
);
1864 wd
->sta
.activescanTickPerChannel
= time
/ ZM_MS_PER_TICK
;
1867 void zfiWlanSetAutoReconnect(zdev_t
* dev
, u8_t enable
)
1869 zmw_get_wlan_dev(dev
);
1871 wd
->sta
.bAutoReconnect
= enable
;
1872 //wd->sta.bAutoReconnectEnabled = enable;
1875 void zfiWlanSetStaWme(zdev_t
* dev
, u8_t enable
, u8_t uapsdInfo
)
1877 zmw_get_wlan_dev(dev
);
1879 wd
->ws
.staWmeEnabled
= enable
& 0x3;
1880 if ((enable
& 0x2) != 0)
1882 wd
->ws
.staWmeQosInfo
= uapsdInfo
& 0x6f;
1886 wd
->ws
.staWmeQosInfo
= 0;
1890 void zfiWlanSetApWme(zdev_t
* dev
, u8_t enable
)
1892 zmw_get_wlan_dev(dev
);
1894 wd
->ws
.apWmeEnabled
= enable
;
1897 u8_t
zfiWlanQuerywmeEnable(zdev_t
* dev
)
1899 zmw_get_wlan_dev(dev
);
1901 return wd
->ws
.staWmeEnabled
;
1904 void zfiWlanSetProbingHiddenSsid(zdev_t
* dev
, u8_t
* ssid
, u8_t ssidLen
,
1907 zmw_get_wlan_dev(dev
);
1908 zmw_declare_for_critical_section();
1911 if ((ssidLen
<= 32) && (entry
< ZM_MAX_PROBE_HIDDEN_SSID_SIZE
))
1913 zmw_enter_critical_section(dev
);
1914 wd
->ws
.probingSsidList
[entry
].ssidLen
= ssidLen
;
1915 zfMemoryCopy(wd
->ws
.probingSsidList
[entry
].ssid
, ssid
, ssidLen
);
1916 zmw_leave_critical_section(dev
);
1922 void zfiWlanSetDisableProbingWithSsid(zdev_t
* dev
, u8_t mode
)
1924 zmw_get_wlan_dev(dev
);
1926 wd
->sta
.disableProbingWithSsid
= mode
;
1931 void zfiWlanSetDropUnencryptedPackets(zdev_t
* dev
, u8_t enable
)
1933 zmw_get_wlan_dev(dev
);
1935 wd
->ws
.dropUnencryptedPkts
= enable
;
1938 void zfiWlanSetStaRxSecurityCheckCb(zdev_t
* dev
, zfpStaRxSecurityCheckCb pStaRxSecurityCheckCb
)
1940 zmw_get_wlan_dev(dev
);
1942 wd
->sta
.pStaRxSecurityCheckCb
= pStaRxSecurityCheckCb
;
1945 void zfiWlanSetIBSSJoinOnly(zdev_t
* dev
, u8_t joinOnly
)
1947 zmw_get_wlan_dev(dev
);
1949 wd
->ws
.ibssJoinOnly
= joinOnly
;
1952 /************************************************************************/
1954 /* FUNCTION DESCRIPTION zfiConfigWdsPort */
1955 /* Configure WDS port. */
1958 /* dev : device pointer */
1959 /* wdsPortId : WDS port ID, start from 0 */
1960 /* flag : 0=>disable WDS port, 1=>enable WDS port */
1961 /* wdsAddr : WDS neighbor MAC address */
1962 /* encType : encryption type for WDS port */
1963 /* wdsKey : encryption key for WDS port */
1969 /* Stephen Chen ZyDAS Technology Corporation 2006.6 */
1971 /************************************************************************/
1972 u16_t
zfiConfigWdsPort(zdev_t
* dev
, u8_t wdsPortId
, u16_t flag
, u16_t
* wdsAddr
,
1973 u16_t encType
, u32_t
* wdsKey
)
1978 zmw_get_wlan_dev(dev
);
1980 if (wdsPortId
>= ZM_MAX_WDS_SUPPORT
)
1982 return ZM_ERR_WDS_PORT_ID
;
1987 /* Enable WDS port */
1988 wd
->ap
.wds
.macAddr
[wdsPortId
][0] = wdsAddr
[0];
1989 wd
->ap
.wds
.macAddr
[wdsPortId
][1] = wdsAddr
[1];
1990 wd
->ap
.wds
.macAddr
[wdsPortId
][2] = wdsAddr
[2];
1992 wd
->ap
.wds
.wdsBitmap
|= (1 << wdsPortId
);
1993 wd
->ap
.wds
.encryMode
[wdsPortId
] = (u8_t
) encType
;
1995 zfCoreSetKey(dev
, 10+ZM_MAX_WDS_SUPPORT
, 0, (u8_t
) encType
, wdsAddr
, wdsKey
);
1999 /* Disable WDS port */
2000 addr
[0] = addr
[1] = addr
[2] = 0;
2001 key
[0] = key
[1] = key
[2] = key
[3] = 0;
2002 wd
->ap
.wds
.wdsBitmap
&= (~(1 << wdsPortId
));
2003 zfCoreSetKey(dev
, 10+ZM_MAX_WDS_SUPPORT
, 0, ZM_NO_WEP
, addr
, key
);
2008 #ifdef ZM_ENABLE_CENC
2010 void zfiWlanQueryGSN(zdev_t
* dev
, u8_t
*gsn
, u16_t vapId
)
2012 //struct zsWlanDev* wd = (struct zsWlanDev*) zmw_wlan_dev(dev);
2014 zmw_get_wlan_dev(dev
);
2016 /* convert little endian to big endian for 32 bits */
2017 txiv
[3] = wd
->ap
.txiv
[vapId
][0];
2018 txiv
[2] = wd
->ap
.txiv
[vapId
][1];
2019 txiv
[1] = wd
->ap
.txiv
[vapId
][2];
2020 txiv
[0] = wd
->ap
.txiv
[vapId
][3];
2022 zfMemoryCopy(gsn
, (u8_t
*)txiv
, 16);
2024 #endif //ZM_ENABLE_CENC
2026 void zfiWlanQuerySignalInfo(zdev_t
* dev
, u8_t
*buffer
)
2028 zmw_get_wlan_dev(dev
);
2030 /*Change Signal Strength/Quality Value to Human Sense Here*/
2032 buffer
[0] = wd
->SignalStrength
;
2033 buffer
[1] = wd
->SignalQuality
;
2037 u16_t
zfiStaAddIeWpaRsn(zdev_t
* dev
, zbuf_t
* buf
, u16_t offset
, u8_t frameType
)
2039 return zfStaAddIeWpaRsn(dev
, buf
, offset
, frameType
);
2043 /* cmd value-description */
2044 /* 0 schedule timer */
2045 /* 1 cancel timer */
2050 /* 6 checksum test 0/1 */
2051 /* 7 enableProtectionMode */
2052 /* 8 rx packet content dump 0/1 */
2054 u32_t
zfiDebugCmd(zdev_t
* dev
, u32_t cmd
, u32_t value
)
2058 zmw_get_wlan_dev(dev
);
2060 zmw_declare_for_critical_section();
2063 zmw_enter_critical_section(dev
);
2066 { /* schedule timer */
2067 event
= (u16_t
) ((value
>> 16) & 0xffff);
2068 tick
= value
& 0xffff;
2069 zfTimerSchedule(dev
, event
, tick
);
2071 else if ( cmd
== 1 )
2072 { /* cancel timer */
2073 event
= (u16_t
) (value
& 0xffff);
2074 zfTimerCancel(dev
, event
);
2076 else if ( cmd
== 2 )
2080 else if ( cmd
== 3 )
2082 zfTimerSchedule(dev
, 1, 500);
2083 zfTimerSchedule(dev
, 2, 1000);
2084 zfTimerSchedule(dev
, 3, 1000);
2085 zfTimerSchedule(dev
, 4, 1000);
2086 zfTimerSchedule(dev
, 5, 1500);
2087 zfTimerSchedule(dev
, 6, 2000);
2088 zfTimerSchedule(dev
, 7, 2200);
2089 zfTimerSchedule(dev
, 6, 2500);
2090 zfTimerSchedule(dev
, 8, 2800);
2094 zfTimerSchedule(dev
, 1, 500);
2095 zfTimerSchedule(dev
, 2, 1000);
2096 zfTimerSchedule(dev
, 3, 1000);
2097 zfTimerSchedule(dev
, 4, 1000);
2098 zfTimerSchedule(dev
, 5, 1500);
2099 zfTimerSchedule(dev
, 6, 2000);
2100 zfTimerSchedule(dev
, 7, 2200);
2101 zfTimerSchedule(dev
, 6, 2500);
2102 zfTimerSchedule(dev
, 8, 2800);
2103 zfTimerCancel(dev
, 1);
2104 zfTimerCancel(dev
, 3);
2105 zfTimerCancel(dev
, 6);
2107 else if ( cmd
== 5 )
2109 wd
->sta
.keyId
= (u8_t
) value
;
2111 else if ( cmd
== 6 )
2113 /* 0: normal 1: always set TCP/UDP checksum zero */
2114 wd
->checksumTest
= value
;
2116 else if ( cmd
== 7 )
2118 wd
->enableProtectionMode
= value
;
2119 zm_msg1_mm(ZM_LV_1
, "wd->enableProtectionMode=", wd
->enableProtectionMode
);
2121 else if ( cmd
== 8 )
2123 /* rx packet content dump */
2126 wd
->rxPacketDump
= 1;
2130 wd
->rxPacketDump
= 0;
2135 zmw_leave_critical_section(dev
);
2140 #ifdef ZM_ENABLE_CENC
2141 u8_t
zfiWlanSetCencPairwiseKey(zdev_t
* dev
, u8_t keyid
, u32_t
*txiv
, u32_t
*rxiv
,
2142 u8_t
*key
, u8_t
*mic
)
2144 struct zsKeyInfo keyInfo
;
2149 zmw_get_wlan_dev(dev
);
2151 for (i
= 0; i
< 16; i
++)
2152 cencKey
[i
] = key
[i
];
2153 for (i
= 0; i
< 16; i
++)
2154 cencKey
[i
+ 16] = mic
[i
];
2155 keyInfo
.key
= cencKey
;
2156 keyInfo
.keyLength
= 32;
2157 keyInfo
.keyIndex
= keyid
;
2158 keyInfo
.flag
= ZM_KEY_FLAG_CENC
| ZM_KEY_FLAG_PK
;
2159 for (i
= 0; i
< 3; i
++)
2160 macAddr
[i
] = wd
->sta
.bssid
[i
];
2161 keyInfo
.macAddr
= macAddr
;
2163 zfiWlanSetKey(dev
, keyInfo
);
2165 /* Reset txiv and rxiv */
2166 //wd->sta.txiv[0] = txiv[0];
2167 //wd->sta.txiv[1] = txiv[1];
2168 //wd->sta.txiv[2] = txiv[2];
2169 //wd->sta.txiv[3] = txiv[3];
2171 //wd->sta.rxiv[0] = rxiv[0];
2172 //wd->sta.rxiv[1] = rxiv[1];
2173 //wd->sta.rxiv[2] = rxiv[2];
2174 //wd->sta.rxiv[3] = rxiv[3];
2179 u8_t
zfiWlanSetCencGroupKey(zdev_t
* dev
, u8_t keyid
, u32_t
*rxiv
,
2180 u8_t
*key
, u8_t
*mic
)
2182 struct zsKeyInfo keyInfo
;
2185 u16_t macAddr
[6] = {0xffff, 0xffff, 0xffff};
2187 zmw_get_wlan_dev(dev
);
2189 for (i
= 0; i
< 16; i
++)
2190 cencKey
[i
] = key
[i
];
2191 for (i
= 0; i
< 16; i
++)
2192 cencKey
[i
+ 16] = mic
[i
];
2193 keyInfo
.key
= cencKey
;
2194 keyInfo
.keyLength
= 32;
2195 keyInfo
.keyIndex
= keyid
;
2196 keyInfo
.flag
= ZM_KEY_FLAG_CENC
| ZM_KEY_FLAG_GK
;
2198 for (i
= 0; i
< 3; i
++)
2199 keyInfo
.vapAddr
[i
] = wd
->macAddr
[i
];
2200 keyInfo
.macAddr
= macAddr
;
2202 zfiWlanSetKey(dev
, keyInfo
);
2204 /* Reset txiv and rxiv */
2205 wd
->sta
.rxivGK
[0] = ((rxiv
[3] >> 24) & 0xFF)
2206 + (((rxiv
[3] >> 16) & 0xFF) << 8)
2207 + (((rxiv
[3] >> 8) & 0xFF) << 16)
2208 + ((rxiv
[3] & 0xFF) << 24);
2209 wd
->sta
.rxivGK
[1] = ((rxiv
[2] >> 24) & 0xFF)
2210 + (((rxiv
[2] >> 16) & 0xFF) << 8)
2211 + (((rxiv
[2] >> 8) & 0xFF) << 16)
2212 + ((rxiv
[2] & 0xFF) << 24);
2213 wd
->sta
.rxivGK
[2] = ((rxiv
[1] >> 24) & 0xFF)
2214 + (((rxiv
[1] >> 16) & 0xFF) << 8)
2215 + (((rxiv
[1] >> 8) & 0xFF) << 16)
2216 + ((rxiv
[1] & 0xFF) << 24);
2217 wd
->sta
.rxivGK
[3] = ((rxiv
[0] >> 24) & 0xFF)
2218 + (((rxiv
[0] >> 16) & 0xFF) << 8)
2219 + (((rxiv
[0] >> 8) & 0xFF) << 16)
2220 + ((rxiv
[0] & 0xFF) << 24);
2222 wd
->sta
.authMode
= ZM_AUTH_MODE_CENC
;
2223 wd
->sta
.currentAuthMode
= ZM_AUTH_MODE_CENC
;
2227 #endif //ZM_ENABLE_CENC
2229 u8_t
zfiWlanSetDot11DMode(zdev_t
* dev
, u8_t mode
)
2233 zmw_get_wlan_dev(dev
);
2235 wd
->sta
.b802_11D
= mode
;
2236 if (mode
) //Enable 802.11d
2238 wd
->regulationTable
.regionCode
= NO_ENUMRD
;
2239 for (i
= 0; i
< wd
->regulationTable
.allowChannelCnt
; i
++)
2240 wd
->regulationTable
.allowChannel
[i
].channelFlags
|= ZM_REG_FLAG_CHANNEL_PASSIVE
;
2244 for (i
= 0; i
< wd
->regulationTable
.allowChannelCnt
; i
++)
2245 wd
->regulationTable
.allowChannel
[i
].channelFlags
&= ~ZM_REG_FLAG_CHANNEL_PASSIVE
;
2251 u8_t
zfiWlanSetDot11HDFSMode(zdev_t
* dev
, u8_t mode
)
2253 zmw_get_wlan_dev(dev
);
2255 //zm_debug_msg0("CWY - Enable 802.11h DFS");
2257 // TODO : DFS Enable in 5250 to 5350 MHz and 5470 to 5725 MHz .
2258 //if ( Adapter->ZD80211HSupport &&
2259 // Adapter->CardSetting.NetworkTypeInUse == Ndis802_11OFDM5 &&
2260 // ((ChannelNo >=52 && ChannelNo <= 64) || //5250~5350 MHZ
2261 // (ChannelNo >=100 && ChannelNo <= 140))) //5470~5725 MHZ
2263 // Adapter->ZD80211HSetting.DFSEnable=TRUE;
2267 // Adapter->ZD80211HSetting.DFSEnable=FALSE;
2270 wd
->sta
.DFSEnable
= mode
;
2272 wd
->sta
.capability
[1] |= ZM_BIT_0
;
2274 wd
->sta
.capability
[1] &= (~ZM_BIT_0
);
2279 u8_t
zfiWlanSetDot11HTPCMode(zdev_t
* dev
, u8_t mode
)
2281 zmw_get_wlan_dev(dev
);
2283 // TODO : TPC Enable in 5150~5350 MHz and 5470~5725MHz.
2284 //if ( Adapter->ZD80211HSupport &&
2285 // Adapter->CardSetting.NetworkTypeInUse == Ndis802_11OFDM5 &&
2286 // ((ChannelNo == 36 || ChannelNo == 40 || ChannelNo == 44 || ChannelNo == 48) || //5150~5250 MHZ , Not Japan
2287 // (ChannelNo >=52 && ChannelNo <= 64) || //5250~5350 MHZ
2288 // (ChannelNo >=100 && ChannelNo <= 140))) //5470~5725 MHZ
2290 // Adapter->ZD80211HSetting.TPCEnable=TRUE;
2294 // Adapter->ZD80211HSetting.TPCEnable=FALSE;
2297 wd
->sta
.TPCEnable
= mode
;
2299 wd
->sta
.capability
[1] |= ZM_BIT_0
;
2301 wd
->sta
.capability
[1] &= (~ZM_BIT_0
);
2306 u8_t
zfiWlanSetAniMode(zdev_t
* dev
, u8_t mode
)
2308 zmw_get_wlan_dev(dev
);
2310 wd
->aniEnable
= mode
;
2317 #ifdef ZM_OS_LINUX_FUNC
2318 void zfiWlanShowTally(zdev_t
* dev
)
2320 zmw_get_wlan_dev(dev
);
2322 zm_msg1_mm(ZM_LV_0
, "Hw_UnderrunCnt = ", wd
->commTally
.Hw_UnderrunCnt
);
2323 zm_msg1_mm(ZM_LV_0
, "Hw_TotalRxFrm = ", wd
->commTally
.Hw_TotalRxFrm
);
2324 zm_msg1_mm(ZM_LV_0
, "Hw_CRC32Cnt = ", wd
->commTally
.Hw_CRC32Cnt
);
2325 zm_msg1_mm(ZM_LV_0
, "Hw_CRC16Cnt = ", wd
->commTally
.Hw_CRC16Cnt
);
2326 zm_msg1_mm(ZM_LV_1
, "Hw_DecrypErr_UNI = ", wd
->commTally
.Hw_DecrypErr_UNI
);
2327 zm_msg1_mm(ZM_LV_0
, "Hw_RxFIFOOverrun = ", wd
->commTally
.Hw_RxFIFOOverrun
);
2328 zm_msg1_mm(ZM_LV_1
, "Hw_DecrypErr_Mul = ", wd
->commTally
.Hw_DecrypErr_Mul
);
2329 zm_msg1_mm(ZM_LV_1
, "Hw_RetryCnt = ", wd
->commTally
.Hw_RetryCnt
);
2330 zm_msg1_mm(ZM_LV_0
, "Hw_TotalTxFrm = ", wd
->commTally
.Hw_TotalTxFrm
);
2331 zm_msg1_mm(ZM_LV_0
, "Hw_RxTimeOut = ", wd
->commTally
.Hw_RxTimeOut
);
2332 zm_msg1_mm(ZM_LV_0
, "Tx_MPDU = ", wd
->commTally
.Tx_MPDU
);
2333 zm_msg1_mm(ZM_LV_0
, "BA_Fail = ", wd
->commTally
.BA_Fail
);
2334 zm_msg1_mm(ZM_LV_0
, "Hw_Tx_AMPDU = ", wd
->commTally
.Hw_Tx_AMPDU
);
2335 zm_msg1_mm(ZM_LV_0
, "Hw_Tx_MPDU = ", wd
->commTally
.Hw_Tx_MPDU
);
2337 zm_msg1_mm(ZM_LV_1
, "Hw_RxMPDU = ", wd
->commTally
.Hw_RxMPDU
);
2338 zm_msg1_mm(ZM_LV_1
, "Hw_RxDropMPDU = ", wd
->commTally
.Hw_RxDropMPDU
);
2339 zm_msg1_mm(ZM_LV_1
, "Hw_RxDelMPDU = ", wd
->commTally
.Hw_RxDelMPDU
);
2340 zm_msg1_mm(ZM_LV_1
, "Hw_RxPhyMiscError = ", wd
->commTally
.Hw_RxPhyMiscError
);
2341 zm_msg1_mm(ZM_LV_1
, "Hw_RxPhyXRError = ", wd
->commTally
.Hw_RxPhyXRError
);
2342 zm_msg1_mm(ZM_LV_1
, "Hw_RxPhyOFDMError = ", wd
->commTally
.Hw_RxPhyOFDMError
);
2343 zm_msg1_mm(ZM_LV_1
, "Hw_RxPhyCCKError = ", wd
->commTally
.Hw_RxPhyCCKError
);
2344 zm_msg1_mm(ZM_LV_1
, "Hw_RxPhyHTError = ", wd
->commTally
.Hw_RxPhyHTError
);
2345 zm_msg1_mm(ZM_LV_1
, "Hw_RxPhyTotalCount = ", wd
->commTally
.Hw_RxPhyTotalCount
);
2347 if (!((wd
->commTally
.Tx_MPDU
== 0) && (wd
->commTally
.BA_Fail
== 0)))
2349 zm_debug_msg_p("BA Fail Ratio(%) = ", wd
->commTally
.BA_Fail
* 100,
2350 (wd
->commTally
.BA_Fail
+ wd
->commTally
.Tx_MPDU
));
2353 if (!((wd
->commTally
.Hw_Tx_MPDU
== 0) && (wd
->commTally
.Hw_Tx_AMPDU
== 0)))
2355 zm_debug_msg_p("Avg Agg Number = ",
2356 wd
->commTally
.Hw_Tx_MPDU
, wd
->commTally
.Hw_Tx_AMPDU
);
2361 void zfiWlanSetMaxTxPower(zdev_t
* dev
, u8_t power2
, u8_t power5
)
2363 zmw_get_wlan_dev(dev
);
2365 zmw_declare_for_critical_section();
2367 zmw_enter_critical_section(dev
);
2368 wd
->maxTxPower2
= power2
;
2369 wd
->maxTxPower5
= power5
;
2370 zmw_leave_critical_section(dev
);
2373 void zfiWlanQueryMaxTxPower(zdev_t
* dev
, u8_t
*power2
, u8_t
*power5
)
2375 zmw_get_wlan_dev(dev
);
2377 *power2
= wd
->maxTxPower2
;
2378 *power5
= wd
->maxTxPower5
;
2381 void zfiWlanSetConnectMode(zdev_t
* dev
, u8_t mode
)
2383 zmw_get_wlan_dev(dev
);
2385 zmw_declare_for_critical_section();
2387 zmw_enter_critical_section(dev
);
2388 wd
->connectMode
= mode
;
2389 zmw_leave_critical_section(dev
);
2392 void zfiWlanSetSupportMode(zdev_t
* dev
, u32_t mode
)
2394 zmw_get_wlan_dev(dev
);
2396 zmw_declare_for_critical_section();
2398 zmw_enter_critical_section(dev
);
2399 wd
->supportMode
= mode
;
2400 zmw_leave_critical_section(dev
);
2403 void zfiWlanSetAdhocMode(zdev_t
* dev
, u32_t mode
)
2405 zmw_get_wlan_dev(dev
);
2407 wd
->ws
.adhocMode
= mode
;
2410 u32_t
zfiWlanQueryAdhocMode(zdev_t
* dev
, u8_t bWrapper
)
2414 zmw_get_wlan_dev(dev
);
2418 adhocMode
= wd
->ws
.adhocMode
;
2422 adhocMode
= wd
->wfc
.bIbssGMode
;
2429 u8_t
zfiWlanSetCountryIsoName(zdev_t
* dev
, u8_t
*countryIsoName
, u8_t length
)
2432 zmw_get_wlan_dev(dev
);
2436 buf
[2] = wd
->ws
.countryIsoName
[0] = countryIsoName
[2];
2437 buf
[3] = wd
->ws
.countryIsoName
[1] = countryIsoName
[1];
2438 buf
[4] = wd
->ws
.countryIsoName
[2] = countryIsoName
[0];
2440 else if (length
== 3)
2442 buf
[2] = wd
->ws
.countryIsoName
[0] = countryIsoName
[1];
2443 buf
[3] = wd
->ws
.countryIsoName
[1] = countryIsoName
[0];
2444 buf
[4] = wd
->ws
.countryIsoName
[2] = '\0';
2451 return zfHpGetRegulationTablefromISO(dev
, buf
, length
);
2455 const char* zfiWlanQueryCountryIsoName(zdev_t
* dev
)
2457 zmw_get_wlan_dev(dev
);
2459 return wd
->ws
.countryIsoName
;
2464 void zfiWlanSetRegulatory(zdev_t
* dev
, u8_t CCS
, u16_t Code
, u8_t bfirstChannel
)
2466 zmw_get_wlan_dev(dev
);
2468 zmw_declare_for_critical_section();
2472 /* Reset Regulation Table by Country Code */
2473 zfHpGetRegulationTablefromCountry(dev
, Code
);
2477 /* Reset Regulation Table by Region Code */
2478 zfHpGetRegulationTablefromRegionCode(dev
, Code
);
2481 if (bfirstChannel
) {
2482 zmw_enter_critical_section(dev
);
2483 wd
->frequency
= zfChGetFirstChannel(dev
, NULL
);
2484 zmw_leave_critical_section(dev
);
2485 zfCoreSetFrequency(dev
, wd
->frequency
);
2490 const char* zfiHpGetisoNamefromregionCode(zdev_t
* dev
, u16_t regionCode
)
2492 return zfHpGetisoNamefromregionCode(dev
, regionCode
);
2495 u16_t
zfiWlanChannelToFrequency(zdev_t
* dev
, u8_t channel
)
2497 return zfChNumToFreq(dev
, channel
, 0);
2500 u8_t
zfiWlanFrequencyToChannel(zdev_t
* dev
, u16_t freq
)
2504 return zfChFreqToNum(freq
, &is5GBand
);
2507 void zfiWlanDisableDfsChannel(zdev_t
* dev
, u8_t disableFlag
)
2509 zfHpDisableDfsChannel(dev
, disableFlag
);
2513 void zfiWlanSetLEDCtrlParam(zdev_t
* dev
, u8_t type
, u8_t flag
)
2515 zmw_get_wlan_dev(dev
);
2517 zmw_declare_for_critical_section();
2519 zmw_enter_critical_section(dev
);
2520 wd
->ledStruct
.LEDCtrlType
= type
;
2521 wd
->ledStruct
.LEDCtrlFlagFromReg
= flag
;
2522 zmw_leave_critical_section(dev
);
2525 void zfiWlanEnableLeapConfig(zdev_t
* dev
, u8_t leapEnabled
)
2527 zmw_get_wlan_dev(dev
);
2529 wd
->sta
.leapEnabled
= leapEnabled
;
2532 u32_t
zfiWlanQueryHwCapability(zdev_t
* dev
)
2534 return zfHpCapability(dev
);
2537 u32_t
zfiWlanQueryReceivedPacket(zdev_t
* dev
)
2539 zmw_get_wlan_dev(dev
);
2541 return wd
->sta
.ReceivedPktRatePerSecond
;
2544 void zfiWlanCheckSWEncryption(zdev_t
* dev
)
2546 zmw_get_wlan_dev(dev
);
2548 if (wd
->sta
.SWEncryptEnable
!= 0)
2550 zfHpSWDecrypt(dev
, 1);
2554 u16_t
zfiWlanQueryAllowChannels(zdev_t
* dev
, u16_t
*channels
)
2557 zmw_get_wlan_dev(dev
);
2559 for (ii
= 0; ii
< wd
->regulationTable
.allowChannelCnt
; ii
++)
2561 channels
[ii
] = wd
->regulationTable
.allowChannel
[ii
].channel
;
2564 return wd
->regulationTable
.allowChannelCnt
;
2567 void zfiWlanSetDynamicSIFSParam(zdev_t
* dev
, u8_t val
)
2569 zmw_get_wlan_dev(dev
);
2571 wd
->dynamicSIFSEnable
= val
;
2573 zm_debug_msg1("wd->dynamicSIFSEnable = ", wd
->dynamicSIFSEnable
)
2576 u16_t
zfiWlanGetMulticastAddressCount(zdev_t
* dev
)
2578 zmw_get_wlan_dev(dev
);
2580 return wd
->sta
.multicastList
.size
;
2583 void zfiWlanGetMulticastList(zdev_t
* dev
, u8_t
* pMCList
)
2585 struct zsMulticastAddr
* pMacList
= (struct zsMulticastAddr
*) pMCList
;
2588 zmw_get_wlan_dev(dev
);
2590 for ( i
=0; i
<wd
->sta
.multicastList
.size
; i
++ )
2592 zfMemoryCopy(pMacList
[i
].addr
, wd
->sta
.multicastList
.macAddr
[i
].addr
, 6);
2596 void zfiWlanSetPacketFilter(zdev_t
* dev
, u32_t PacketFilter
)
2598 u8_t bAllMulticast
= 0;
2601 zmw_get_wlan_dev(dev
);
2603 oldFilter
= wd
->sta
.osRxFilter
;
2605 wd
->sta
.osRxFilter
= PacketFilter
;
2607 if ((oldFilter
& ZM_PACKET_TYPE_ALL_MULTICAST
) !=
2608 (wd
->sta
.osRxFilter
& ZM_PACKET_TYPE_ALL_MULTICAST
))
2610 if ( wd
->sta
.osRxFilter
& ZM_PACKET_TYPE_ALL_MULTICAST
)
2612 zfHpSetMulticastList(dev
, wd
->sta
.multicastList
.size
,
2613 (u8_t
*)wd
->sta
.multicastList
.macAddr
, bAllMulticast
);
2617 u8_t
zfiCompareWithMulticastListAddress(zdev_t
* dev
, u16_t
* dstMacAddr
)
2620 u8_t bIsInMCListAddr
= 0;
2622 zmw_get_wlan_dev(dev
);
2624 for ( i
=0; i
<wd
->sta
.multicastList
.size
; i
++ )
2626 if ( zfwMemoryIsEqual((u8_t
*)dstMacAddr
, (u8_t
*)wd
->sta
.multicastList
.macAddr
[i
].addr
, 6) )
2628 bIsInMCListAddr
= 1;
2633 return bIsInMCListAddr
;
2636 void zfiWlanSetSafeModeEnabled(zdev_t
* dev
, u8_t safeMode
)
2638 zmw_get_wlan_dev(dev
);
2640 wd
->sta
.bSafeMode
= safeMode
;
2643 zfStaEnableSWEncryption(dev
, 1);
2645 zfStaDisableSWEncryption(dev
);
2648 void zfiWlanSetIBSSAdditionalIELength(zdev_t
* dev
, u32_t ibssAdditionalIESize
, u8_t
* ibssAdditionalIE
)
2650 zmw_get_wlan_dev(dev
);
2652 if ( ibssAdditionalIESize
)
2654 wd
->sta
.ibssAdditionalIESize
= ibssAdditionalIESize
;
2655 zfMemoryCopy(wd
->sta
.ibssAdditionalIE
, ibssAdditionalIE
, (u16_t
)ibssAdditionalIESize
);
2658 wd
->sta
.ibssAdditionalIESize
= 0;