mirror of https://gitee.com/openkylin/linux.git
staging: vt6656: Remove QWORD from source and replace with u64.
Signed-off-by: Malcolm Priestley <tvboxspy@gmail.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
1901ab6292
commit
7c65fa2a4c
|
@ -97,8 +97,9 @@ vMgrEncodeBeacon(
|
||||||
pFrame->pHdr = (PUWLAN_80211HDR)pFrame->pBuf;
|
pFrame->pHdr = (PUWLAN_80211HDR)pFrame->pBuf;
|
||||||
|
|
||||||
/* Fixed Fields */
|
/* Fixed Fields */
|
||||||
pFrame->pqwTimestamp = (PQWORD)(WLAN_HDR_A3_DATA_PTR(&(pFrame->pHdr->sA3))
|
pFrame->pqwTimestamp =
|
||||||
+ WLAN_BEACON_OFF_TS);
|
(u64 *)(WLAN_HDR_A3_DATA_PTR(&(pFrame->pHdr->sA3)) +
|
||||||
|
WLAN_BEACON_OFF_TS);
|
||||||
pFrame->pwBeaconInterval = (PWORD)(WLAN_HDR_A3_DATA_PTR(&(pFrame->pHdr->sA3))
|
pFrame->pwBeaconInterval = (PWORD)(WLAN_HDR_A3_DATA_PTR(&(pFrame->pHdr->sA3))
|
||||||
+ WLAN_BEACON_OFF_BCN_INT);
|
+ WLAN_BEACON_OFF_BCN_INT);
|
||||||
pFrame->pwCapInfo = (PWORD)(WLAN_HDR_A3_DATA_PTR(&(pFrame->pHdr->sA3))
|
pFrame->pwCapInfo = (PWORD)(WLAN_HDR_A3_DATA_PTR(&(pFrame->pHdr->sA3))
|
||||||
|
@ -131,8 +132,9 @@ vMgrDecodeBeacon(
|
||||||
pFrame->pHdr = (PUWLAN_80211HDR)pFrame->pBuf;
|
pFrame->pHdr = (PUWLAN_80211HDR)pFrame->pBuf;
|
||||||
|
|
||||||
/* Fixed Fields */
|
/* Fixed Fields */
|
||||||
pFrame->pqwTimestamp = (PQWORD)(WLAN_HDR_A3_DATA_PTR(&(pFrame->pHdr->sA3))
|
pFrame->pqwTimestamp =
|
||||||
+ WLAN_BEACON_OFF_TS);
|
(u64 *)(WLAN_HDR_A3_DATA_PTR(&(pFrame->pHdr->sA3)) +
|
||||||
|
WLAN_BEACON_OFF_TS);
|
||||||
pFrame->pwBeaconInterval = (PWORD)(WLAN_HDR_A3_DATA_PTR(&(pFrame->pHdr->sA3))
|
pFrame->pwBeaconInterval = (PWORD)(WLAN_HDR_A3_DATA_PTR(&(pFrame->pHdr->sA3))
|
||||||
+ WLAN_BEACON_OFF_BCN_INT);
|
+ WLAN_BEACON_OFF_BCN_INT);
|
||||||
pFrame->pwCapInfo = (PWORD)(WLAN_HDR_A3_DATA_PTR(&(pFrame->pHdr->sA3))
|
pFrame->pwCapInfo = (PWORD)(WLAN_HDR_A3_DATA_PTR(&(pFrame->pHdr->sA3))
|
||||||
|
@ -672,8 +674,9 @@ vMgrEncodeProbeResponse(
|
||||||
pFrame->pHdr = (PUWLAN_80211HDR)pFrame->pBuf;
|
pFrame->pHdr = (PUWLAN_80211HDR)pFrame->pBuf;
|
||||||
|
|
||||||
/* Fixed Fields */
|
/* Fixed Fields */
|
||||||
pFrame->pqwTimestamp = (PQWORD)(WLAN_HDR_A3_DATA_PTR(&(pFrame->pHdr->sA3))
|
pFrame->pqwTimestamp =
|
||||||
+ WLAN_PROBERESP_OFF_TS);
|
(u64 *)(WLAN_HDR_A3_DATA_PTR(&(pFrame->pHdr->sA3)) +
|
||||||
|
WLAN_PROBERESP_OFF_TS);
|
||||||
pFrame->pwBeaconInterval = (PWORD)(WLAN_HDR_A3_DATA_PTR(&(pFrame->pHdr->sA3))
|
pFrame->pwBeaconInterval = (PWORD)(WLAN_HDR_A3_DATA_PTR(&(pFrame->pHdr->sA3))
|
||||||
+ WLAN_PROBERESP_OFF_BCN_INT);
|
+ WLAN_PROBERESP_OFF_BCN_INT);
|
||||||
pFrame->pwCapInfo = (PWORD)(WLAN_HDR_A3_DATA_PTR(&(pFrame->pHdr->sA3))
|
pFrame->pwCapInfo = (PWORD)(WLAN_HDR_A3_DATA_PTR(&(pFrame->pHdr->sA3))
|
||||||
|
@ -707,8 +710,9 @@ vMgrDecodeProbeResponse(
|
||||||
pFrame->pHdr = (PUWLAN_80211HDR)pFrame->pBuf;
|
pFrame->pHdr = (PUWLAN_80211HDR)pFrame->pBuf;
|
||||||
|
|
||||||
/* Fixed Fields */
|
/* Fixed Fields */
|
||||||
pFrame->pqwTimestamp = (PQWORD)(WLAN_HDR_A3_DATA_PTR(&(pFrame->pHdr->sA3))
|
pFrame->pqwTimestamp =
|
||||||
+ WLAN_PROBERESP_OFF_TS);
|
(u64 *)(WLAN_HDR_A3_DATA_PTR(&(pFrame->pHdr->sA3)) +
|
||||||
|
WLAN_PROBERESP_OFF_TS);
|
||||||
pFrame->pwBeaconInterval = (PWORD)(WLAN_HDR_A3_DATA_PTR(&(pFrame->pHdr->sA3))
|
pFrame->pwBeaconInterval = (PWORD)(WLAN_HDR_A3_DATA_PTR(&(pFrame->pHdr->sA3))
|
||||||
+ WLAN_PROBERESP_OFF_BCN_INT);
|
+ WLAN_PROBERESP_OFF_BCN_INT);
|
||||||
pFrame->pwCapInfo = (PWORD)(WLAN_HDR_A3_DATA_PTR(&(pFrame->pHdr->sA3))
|
pFrame->pwCapInfo = (PWORD)(WLAN_HDR_A3_DATA_PTR(&(pFrame->pHdr->sA3))
|
||||||
|
|
|
@ -526,7 +526,7 @@ typedef struct tagWLAN_FR_BEACON {
|
||||||
PBYTE pBuf;
|
PBYTE pBuf;
|
||||||
PUWLAN_80211HDR pHdr;
|
PUWLAN_80211HDR pHdr;
|
||||||
// fixed fields
|
// fixed fields
|
||||||
PQWORD pqwTimestamp;
|
u64 *pqwTimestamp;
|
||||||
PWORD pwBeaconInterval;
|
PWORD pwBeaconInterval;
|
||||||
PWORD pwCapInfo;
|
PWORD pwCapInfo;
|
||||||
/*-- info elements ----------*/
|
/*-- info elements ----------*/
|
||||||
|
@ -683,7 +683,7 @@ typedef struct tagWLAN_FR_PROBERESP {
|
||||||
PBYTE pBuf;
|
PBYTE pBuf;
|
||||||
PUWLAN_80211HDR pHdr;
|
PUWLAN_80211HDR pHdr;
|
||||||
/*-- fixed fields -----------*/
|
/*-- fixed fields -----------*/
|
||||||
PQWORD pqwTimestamp;
|
u64 *pqwTimestamp;
|
||||||
PWORD pwBeaconInterval;
|
PWORD pwBeaconInterval;
|
||||||
PWORD pwCapInfo;
|
PWORD pwCapInfo;
|
||||||
/*-- info elements ----------*/
|
/*-- info elements ----------*/
|
||||||
|
|
|
@ -339,7 +339,7 @@ PKnownBSS BSSpAddrIsInBSSList(void *hDeviceContext,
|
||||||
|
|
||||||
BOOL BSSbInsertToBSSList(void *hDeviceContext,
|
BOOL BSSbInsertToBSSList(void *hDeviceContext,
|
||||||
PBYTE abyBSSIDAddr,
|
PBYTE abyBSSIDAddr,
|
||||||
QWORD qwTimestamp,
|
u64 qwTimestamp,
|
||||||
WORD wBeaconInterval,
|
WORD wBeaconInterval,
|
||||||
WORD wCapInfo,
|
WORD wCapInfo,
|
||||||
BYTE byCurrChannel,
|
BYTE byCurrChannel,
|
||||||
|
@ -380,8 +380,7 @@ BOOL BSSbInsertToBSSList(void *hDeviceContext,
|
||||||
// save the BSS info
|
// save the BSS info
|
||||||
pBSSList->bActive = TRUE;
|
pBSSList->bActive = TRUE;
|
||||||
memcpy( pBSSList->abyBSSID, abyBSSIDAddr, WLAN_BSSID_LEN);
|
memcpy( pBSSList->abyBSSID, abyBSSIDAddr, WLAN_BSSID_LEN);
|
||||||
HIDWORD(pBSSList->qwBSSTimestamp) = cpu_to_le32(HIDWORD(qwTimestamp));
|
pBSSList->qwBSSTimestamp = cpu_to_le64(qwTimestamp);
|
||||||
LODWORD(pBSSList->qwBSSTimestamp) = cpu_to_le32(LODWORD(qwTimestamp));
|
|
||||||
pBSSList->wBeaconInterval = cpu_to_le16(wBeaconInterval);
|
pBSSList->wBeaconInterval = cpu_to_le16(wBeaconInterval);
|
||||||
pBSSList->wCapInfo = cpu_to_le16(wCapInfo);
|
pBSSList->wCapInfo = cpu_to_le16(wCapInfo);
|
||||||
pBSSList->uClearCount = 0;
|
pBSSList->uClearCount = 0;
|
||||||
|
@ -519,7 +518,7 @@ BOOL BSSbInsertToBSSList(void *hDeviceContext,
|
||||||
// TODO: input structure modify
|
// TODO: input structure modify
|
||||||
|
|
||||||
BOOL BSSbUpdateToBSSList(void *hDeviceContext,
|
BOOL BSSbUpdateToBSSList(void *hDeviceContext,
|
||||||
QWORD qwTimestamp,
|
u64 qwTimestamp,
|
||||||
WORD wBeaconInterval,
|
WORD wBeaconInterval,
|
||||||
WORD wCapInfo,
|
WORD wCapInfo,
|
||||||
BYTE byCurrChannel,
|
BYTE byCurrChannel,
|
||||||
|
@ -548,8 +547,8 @@ BOOL BSSbUpdateToBSSList(void *hDeviceContext,
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
|
||||||
|
|
||||||
HIDWORD(pBSSList->qwBSSTimestamp) = cpu_to_le32(HIDWORD(qwTimestamp));
|
pBSSList->qwBSSTimestamp = cpu_to_le64(qwTimestamp);
|
||||||
LODWORD(pBSSList->qwBSSTimestamp) = cpu_to_le32(LODWORD(qwTimestamp));
|
|
||||||
pBSSList->wBeaconInterval = cpu_to_le16(wBeaconInterval);
|
pBSSList->wBeaconInterval = cpu_to_le16(wBeaconInterval);
|
||||||
pBSSList->wCapInfo = cpu_to_le16(wCapInfo);
|
pBSSList->wCapInfo = cpu_to_le16(wCapInfo);
|
||||||
pBSSList->uClearCount = 0;
|
pBSSList->uClearCount = 0;
|
||||||
|
|
|
@ -142,8 +142,8 @@ typedef struct tagKnownBSS {
|
||||||
unsigned int uClearCount;
|
unsigned int uClearCount;
|
||||||
// BYTE abyIEs[WLAN_BEACON_FR_MAXLEN];
|
// BYTE abyIEs[WLAN_BEACON_FR_MAXLEN];
|
||||||
unsigned int uIELength;
|
unsigned int uIELength;
|
||||||
QWORD qwBSSTimestamp;
|
u64 qwBSSTimestamp;
|
||||||
QWORD qwLocalTSF; // local TSF timer
|
u64 qwLocalTSF;/* local TSF timer */
|
||||||
|
|
||||||
CARD_PHY_TYPE eNetworkTypeInUse;
|
CARD_PHY_TYPE eNetworkTypeInUse;
|
||||||
|
|
||||||
|
@ -239,7 +239,7 @@ void BSSvClearBSSList(void *hDeviceContext, BOOL bKeepCurrBSSID);
|
||||||
|
|
||||||
BOOL BSSbInsertToBSSList(void *hDeviceContext,
|
BOOL BSSbInsertToBSSList(void *hDeviceContext,
|
||||||
PBYTE abyBSSIDAddr,
|
PBYTE abyBSSIDAddr,
|
||||||
QWORD qwTimestamp,
|
u64 qwTimestamp,
|
||||||
WORD wBeaconInterval,
|
WORD wBeaconInterval,
|
||||||
WORD wCapInfo,
|
WORD wCapInfo,
|
||||||
BYTE byCurrChannel,
|
BYTE byCurrChannel,
|
||||||
|
@ -256,7 +256,7 @@ BOOL BSSbInsertToBSSList(void *hDeviceContext,
|
||||||
void *pRxPacketContext);
|
void *pRxPacketContext);
|
||||||
|
|
||||||
BOOL BSSbUpdateToBSSList(void *hDeviceContext,
|
BOOL BSSbUpdateToBSSList(void *hDeviceContext,
|
||||||
QWORD qwTimestamp,
|
u64 qwTimestamp,
|
||||||
WORD wBeaconInterval,
|
WORD wBeaconInterval,
|
||||||
WORD wCapInfo,
|
WORD wCapInfo,
|
||||||
BYTE byCurrChannel,
|
BYTE byCurrChannel,
|
||||||
|
|
|
@ -654,28 +654,18 @@ BYTE CARDbyGetPktType(void *pDeviceHandler)
|
||||||
* Return Value: TSF Offset value
|
* Return Value: TSF Offset value
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
QWORD CARDqGetTSFOffset (BYTE byRxRate, QWORD qwTSF1, QWORD qwTSF2)
|
u64 CARDqGetTSFOffset(BYTE byRxRate, u64 qwTSF1, u64 qwTSF2)
|
||||||
{
|
{
|
||||||
QWORD qwTSFOffset;
|
u64 qwTSFOffset = 0;
|
||||||
WORD wRxBcnTSFOffst = 0;
|
WORD wRxBcnTSFOffst = 0;
|
||||||
|
|
||||||
HIDWORD(qwTSFOffset) = 0;
|
wRxBcnTSFOffst = cwRXBCNTSFOff[byRxRate % MAX_RATE];
|
||||||
LODWORD(qwTSFOffset) = 0;
|
|
||||||
|
|
||||||
wRxBcnTSFOffst = cwRXBCNTSFOff[byRxRate%MAX_RATE];
|
qwTSF2 += (u64)wRxBcnTSFOffst;
|
||||||
(qwTSF2).u.dwLowDword += (DWORD)(wRxBcnTSFOffst);
|
|
||||||
if ((qwTSF2).u.dwLowDword < (DWORD)(wRxBcnTSFOffst)) {
|
qwTSFOffset = qwTSF1 - qwTSF2;
|
||||||
(qwTSF2).u.dwHighDword++;
|
|
||||||
}
|
return qwTSFOffset;
|
||||||
LODWORD(qwTSFOffset) = LODWORD(qwTSF1) - LODWORD(qwTSF2);
|
|
||||||
if (LODWORD(qwTSF1) < LODWORD(qwTSF2)) {
|
|
||||||
// if borrow needed
|
|
||||||
HIDWORD(qwTSFOffset) = HIDWORD(qwTSF1) - HIDWORD(qwTSF2) - 1 ;
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
HIDWORD(qwTSFOffset) = HIDWORD(qwTSF1) - HIDWORD(qwTSF2);
|
|
||||||
};
|
|
||||||
return (qwTSFOffset);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -696,32 +686,26 @@ QWORD CARDqGetTSFOffset (BYTE byRxRate, QWORD qwTSF1, QWORD qwTSF2)
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
void CARDvAdjustTSF(void *pDeviceHandler, BYTE byRxRate,
|
void CARDvAdjustTSF(void *pDeviceHandler, BYTE byRxRate,
|
||||||
QWORD qwBSSTimestamp, QWORD qwLocalTSF)
|
u64 qwBSSTimestamp, u64 qwLocalTSF)
|
||||||
{
|
{
|
||||||
|
|
||||||
PSDevice pDevice = (PSDevice) pDeviceHandler;
|
PSDevice pDevice = (PSDevice) pDeviceHandler;
|
||||||
QWORD qwTSFOffset;
|
u64 qwTSFOffset = 0;
|
||||||
DWORD dwTSFOffset1,dwTSFOffset2;
|
|
||||||
BYTE pbyData[8];
|
BYTE pbyData[8];
|
||||||
|
|
||||||
HIDWORD(qwTSFOffset) = 0;
|
|
||||||
LODWORD(qwTSFOffset) = 0;
|
|
||||||
|
|
||||||
qwTSFOffset = CARDqGetTSFOffset(byRxRate, qwBSSTimestamp, qwLocalTSF);
|
qwTSFOffset = CARDqGetTSFOffset(byRxRate, qwBSSTimestamp, qwLocalTSF);
|
||||||
// adjust TSF
|
// adjust TSF
|
||||||
// HW's TSF add TSF Offset reg
|
// HW's TSF add TSF Offset reg
|
||||||
dwTSFOffset1 = LODWORD(qwTSFOffset);
|
|
||||||
dwTSFOffset2 = HIDWORD(qwTSFOffset);
|
|
||||||
|
|
||||||
|
pbyData[0] = (u8)qwTSFOffset;
|
||||||
pbyData[0] = (BYTE)dwTSFOffset1;
|
pbyData[1] = (u8)(qwTSFOffset >> 8);
|
||||||
pbyData[1] = (BYTE)(dwTSFOffset1>>8);
|
pbyData[2] = (u8)(qwTSFOffset >> 16);
|
||||||
pbyData[2] = (BYTE)(dwTSFOffset1>>16);
|
pbyData[3] = (u8)(qwTSFOffset >> 24);
|
||||||
pbyData[3] = (BYTE)(dwTSFOffset1>>24);
|
pbyData[4] = (u8)(qwTSFOffset >> 32);
|
||||||
pbyData[4] = (BYTE)dwTSFOffset2;
|
pbyData[5] = (u8)(qwTSFOffset >> 40);
|
||||||
pbyData[5] = (BYTE)(dwTSFOffset2>>8);
|
pbyData[6] = (u8)(qwTSFOffset >> 48);
|
||||||
pbyData[6] = (BYTE)(dwTSFOffset2>>16);
|
pbyData[7] = (u8)(qwTSFOffset >> 56);
|
||||||
pbyData[7] = (BYTE)(dwTSFOffset2>>24);
|
|
||||||
|
|
||||||
CONTROLnsRequestOut(pDevice,
|
CONTROLnsRequestOut(pDevice,
|
||||||
MESSAGE_TYPE_SET_TSFTBTT,
|
MESSAGE_TYPE_SET_TSFTBTT,
|
||||||
|
@ -745,12 +729,11 @@ void CARDvAdjustTSF(void *pDeviceHandler, BYTE byRxRate,
|
||||||
* Return Value: TRUE if success; otherwise FALSE
|
* Return Value: TRUE if success; otherwise FALSE
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
BOOL CARDbGetCurrentTSF(void *pDeviceHandler, PQWORD pqwCurrTSF)
|
BOOL CARDbGetCurrentTSF(void *pDeviceHandler, u64 *pqwCurrTSF)
|
||||||
{
|
{
|
||||||
PSDevice pDevice = (PSDevice) pDeviceHandler;
|
PSDevice pDevice = (PSDevice) pDeviceHandler;
|
||||||
|
|
||||||
LODWORD(*pqwCurrTSF) = LODWORD(pDevice->qwCurrTSF);
|
*pqwCurrTSF = pDevice->qwCurrTSF;
|
||||||
HIDWORD(*pqwCurrTSF) = HIDWORD(pDevice->qwCurrTSF);
|
|
||||||
|
|
||||||
return(TRUE);
|
return(TRUE);
|
||||||
}
|
}
|
||||||
|
@ -773,8 +756,7 @@ BOOL CARDbClearCurrentTSF(void *pDeviceHandler)
|
||||||
|
|
||||||
MACvRegBitsOn(pDevice,MAC_REG_TFTCTL,TFTCTL_TSFCNTRST);
|
MACvRegBitsOn(pDevice,MAC_REG_TFTCTL,TFTCTL_TSFCNTRST);
|
||||||
|
|
||||||
LODWORD(pDevice->qwCurrTSF) = 0;
|
pDevice->qwCurrTSF = 0;
|
||||||
HIDWORD(pDevice->qwCurrTSF) = 0;
|
|
||||||
|
|
||||||
return(TRUE);
|
return(TRUE);
|
||||||
}
|
}
|
||||||
|
@ -793,7 +775,7 @@ BOOL CARDbClearCurrentTSF(void *pDeviceHandler)
|
||||||
* Return Value: TSF value of next Beacon
|
* Return Value: TSF value of next Beacon
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
QWORD CARDqGetNextTBTT (QWORD qwTSF, WORD wBeaconInterval)
|
u64 CARDqGetNextTBTT(u64 qwTSF, WORD wBeaconInterval)
|
||||||
{
|
{
|
||||||
|
|
||||||
unsigned int uLowNextTBTT;
|
unsigned int uLowNextTBTT;
|
||||||
|
@ -802,18 +784,19 @@ QWORD CARDqGetNextTBTT (QWORD qwTSF, WORD wBeaconInterval)
|
||||||
|
|
||||||
uBeaconInterval = wBeaconInterval * 1024;
|
uBeaconInterval = wBeaconInterval * 1024;
|
||||||
// Next TBTT = ((local_current_TSF / beacon_interval) + 1 ) * beacon_interval
|
// Next TBTT = ((local_current_TSF / beacon_interval) + 1 ) * beacon_interval
|
||||||
uLowNextTBTT = (LODWORD(qwTSF) >> 10) << 10;
|
uLowNextTBTT = ((qwTSF & 0xffffffffU) >> 10) << 10;
|
||||||
uLowRemain = (uLowNextTBTT) % uBeaconInterval;
|
uLowRemain = (uLowNextTBTT) % uBeaconInterval;
|
||||||
uHighRemain = ((0x80000000 % uBeaconInterval)* 2 * HIDWORD(qwTSF))
|
uHighRemain = ((0x80000000 % uBeaconInterval) * 2 * (u32)(qwTSF >> 32))
|
||||||
% uBeaconInterval;
|
% uBeaconInterval;
|
||||||
uLowRemain = (uHighRemain + uLowRemain) % uBeaconInterval;
|
uLowRemain = (uHighRemain + uLowRemain) % uBeaconInterval;
|
||||||
uLowRemain = uBeaconInterval - uLowRemain;
|
uLowRemain = uBeaconInterval - uLowRemain;
|
||||||
|
|
||||||
// check if carry when add one beacon interval
|
// check if carry when add one beacon interval
|
||||||
if ((~uLowNextTBTT) < uLowRemain)
|
if ((~uLowNextTBTT) < uLowRemain)
|
||||||
HIDWORD(qwTSF) ++ ;
|
qwTSF = ((qwTSF >> 32) + 1) << 32;
|
||||||
|
|
||||||
LODWORD(qwTSF) = uLowNextTBTT + uLowRemain;
|
qwTSF = (qwTSF & 0xffffffff00000000U) |
|
||||||
|
(u64)(uLowNextTBTT + uLowRemain);
|
||||||
|
|
||||||
return (qwTSF);
|
return (qwTSF);
|
||||||
}
|
}
|
||||||
|
@ -837,28 +820,22 @@ void CARDvSetFirstNextTBTT(void *pDeviceHandler, WORD wBeaconInterval)
|
||||||
{
|
{
|
||||||
|
|
||||||
PSDevice pDevice = (PSDevice) pDeviceHandler;
|
PSDevice pDevice = (PSDevice) pDeviceHandler;
|
||||||
QWORD qwNextTBTT;
|
u64 qwNextTBTT = 0;
|
||||||
DWORD dwLoTBTT,dwHiTBTT;
|
|
||||||
BYTE pbyData[8];
|
BYTE pbyData[8];
|
||||||
|
|
||||||
HIDWORD(qwNextTBTT) = 0;
|
|
||||||
LODWORD(qwNextTBTT) = 0;
|
|
||||||
CARDbClearCurrentTSF(pDevice);
|
CARDbClearCurrentTSF(pDevice);
|
||||||
//CARDbGetCurrentTSF(pDevice, &qwNextTBTT); //Get Local TSF counter
|
//CARDbGetCurrentTSF(pDevice, &qwNextTBTT); //Get Local TSF counter
|
||||||
qwNextTBTT = CARDqGetNextTBTT(qwNextTBTT, wBeaconInterval);
|
qwNextTBTT = CARDqGetNextTBTT(qwNextTBTT, wBeaconInterval);
|
||||||
// Set NextTBTT
|
// Set NextTBTT
|
||||||
|
|
||||||
dwLoTBTT = LODWORD(qwNextTBTT);
|
pbyData[0] = (u8)qwNextTBTT;
|
||||||
dwHiTBTT = HIDWORD(qwNextTBTT);
|
pbyData[1] = (u8)(qwNextTBTT >> 8);
|
||||||
|
pbyData[2] = (u8)(qwNextTBTT >> 16);
|
||||||
pbyData[0] = (BYTE)dwLoTBTT;
|
pbyData[3] = (u8)(qwNextTBTT >> 24);
|
||||||
pbyData[1] = (BYTE)(dwLoTBTT>>8);
|
pbyData[4] = (u8)(qwNextTBTT >> 32);
|
||||||
pbyData[2] = (BYTE)(dwLoTBTT>>16);
|
pbyData[5] = (u8)(qwNextTBTT >> 40);
|
||||||
pbyData[3] = (BYTE)(dwLoTBTT>>24);
|
pbyData[6] = (u8)(qwNextTBTT >> 48);
|
||||||
pbyData[4] = (BYTE)dwHiTBTT;
|
pbyData[7] = (u8)(qwNextTBTT >> 56);
|
||||||
pbyData[5] = (BYTE)(dwHiTBTT>>8);
|
|
||||||
pbyData[6] = (BYTE)(dwHiTBTT>>16);
|
|
||||||
pbyData[7] = (BYTE)(dwHiTBTT>>24);
|
|
||||||
|
|
||||||
CONTROLnsRequestOut(pDevice,
|
CONTROLnsRequestOut(pDevice,
|
||||||
MESSAGE_TYPE_SET_TSFTBTT,
|
MESSAGE_TYPE_SET_TSFTBTT,
|
||||||
|
@ -887,27 +864,24 @@ void CARDvSetFirstNextTBTT(void *pDeviceHandler, WORD wBeaconInterval)
|
||||||
* Return Value: none
|
* Return Value: none
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
void CARDvUpdateNextTBTT(void *pDeviceHandler, QWORD qwTSF,
|
void CARDvUpdateNextTBTT(void *pDeviceHandler, u64 qwTSF,
|
||||||
WORD wBeaconInterval)
|
WORD wBeaconInterval)
|
||||||
{
|
{
|
||||||
PSDevice pDevice = (PSDevice) pDeviceHandler;
|
PSDevice pDevice = (PSDevice) pDeviceHandler;
|
||||||
DWORD dwLoTBTT,dwHiTBTT;
|
|
||||||
BYTE pbyData[8];
|
BYTE pbyData[8];
|
||||||
|
|
||||||
qwTSF = CARDqGetNextTBTT(qwTSF, wBeaconInterval);
|
qwTSF = CARDqGetNextTBTT(qwTSF, wBeaconInterval);
|
||||||
|
|
||||||
// Set NextTBTT
|
// Set NextTBTT
|
||||||
dwLoTBTT = LODWORD(qwTSF);
|
|
||||||
dwHiTBTT = HIDWORD(qwTSF);
|
|
||||||
|
|
||||||
pbyData[0] = (BYTE)dwLoTBTT;
|
pbyData[0] = (u8)qwTSF;
|
||||||
pbyData[1] = (BYTE)(dwLoTBTT>>8);
|
pbyData[1] = (u8)(qwTSF >> 8);
|
||||||
pbyData[2] = (BYTE)(dwLoTBTT>>16);
|
pbyData[2] = (u8)(qwTSF >> 16);
|
||||||
pbyData[3] = (BYTE)(dwLoTBTT>>24);
|
pbyData[3] = (u8)(qwTSF >> 24);
|
||||||
pbyData[4] = (BYTE)dwHiTBTT;
|
pbyData[4] = (u8)(qwTSF >> 32);
|
||||||
pbyData[5] = (BYTE)(dwHiTBTT>>8);
|
pbyData[5] = (u8)(qwTSF >> 40);
|
||||||
pbyData[6] = (BYTE)(dwHiTBTT>>16);
|
pbyData[6] = (u8)(qwTSF >> 48);
|
||||||
pbyData[7] = (BYTE)(dwHiTBTT>>24);
|
pbyData[7] = (u8)(qwTSF >> 56);
|
||||||
|
|
||||||
CONTROLnsRequestOut(pDevice,
|
CONTROLnsRequestOut(pDevice,
|
||||||
MESSAGE_TYPE_SET_TSFTBTT,
|
MESSAGE_TYPE_SET_TSFTBTT,
|
||||||
|
@ -918,7 +892,8 @@ void CARDvUpdateNextTBTT(void *pDeviceHandler, QWORD qwTSF,
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
||||||
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO"Card:Update Next TBTT[%8xh:%8xh] \n",(int)HIDWORD(qwTSF), (int)LODWORD(qwTSF));
|
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO
|
||||||
|
"Card:Update Next TBTT[%8lx]\n", (unsigned long)qwTSF);
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
|
@ -67,14 +67,14 @@ void CARDvUpdateBasicTopRate(void *pDeviceHandler);
|
||||||
void CARDbAddBasicRate(void *pDeviceHandler, WORD wRateIdx);
|
void CARDbAddBasicRate(void *pDeviceHandler, WORD wRateIdx);
|
||||||
BOOL CARDbIsOFDMinBasicRate(void *pDeviceHandler);
|
BOOL CARDbIsOFDMinBasicRate(void *pDeviceHandler);
|
||||||
void CARDvAdjustTSF(void *pDeviceHandler, BYTE byRxRate,
|
void CARDvAdjustTSF(void *pDeviceHandler, BYTE byRxRate,
|
||||||
QWORD qwBSSTimestamp, QWORD qwLocalTSF);
|
u64 qwBSSTimestamp, u64 qwLocalTSF);
|
||||||
BOOL CARDbGetCurrentTSF(void *pDeviceHandler, PQWORD pqwCurrTSF);
|
BOOL CARDbGetCurrentTSF(void *pDeviceHandler, u64 *pqwCurrTSF);
|
||||||
BOOL CARDbClearCurrentTSF(void *pDeviceHandler);
|
BOOL CARDbClearCurrentTSF(void *pDeviceHandler);
|
||||||
void CARDvSetFirstNextTBTT(void *pDeviceHandler, WORD wBeaconInterval);
|
void CARDvSetFirstNextTBTT(void *pDeviceHandler, WORD wBeaconInterval);
|
||||||
void CARDvUpdateNextTBTT(void *pDeviceHandler, QWORD qwTSF,
|
void CARDvUpdateNextTBTT(void *pDeviceHandler, u64 qwTSF,
|
||||||
WORD wBeaconInterval);
|
WORD wBeaconInterval);
|
||||||
QWORD CARDqGetNextTBTT(QWORD qwTSF, WORD wBeaconInterval);
|
u64 CARDqGetNextTBTT(u64 qwTSF, WORD wBeaconInterval);
|
||||||
QWORD CARDqGetTSFOffset(BYTE byRxRate, QWORD qwTSF1, QWORD qwTSF2);
|
u64 CARDqGetTSFOffset(BYTE byRxRate, u64 qwTSF1, u64 qwTSF2);
|
||||||
BOOL CARDbRadioPowerOff(void *pDeviceHandler);
|
BOOL CARDbRadioPowerOff(void *pDeviceHandler);
|
||||||
BOOL CARDbRadioPowerOn(void *pDeviceHandler);
|
BOOL CARDbRadioPowerOn(void *pDeviceHandler);
|
||||||
BYTE CARDbyGetPktType(void *pDeviceHandler);
|
BYTE CARDbyGetPktType(void *pDeviceHandler);
|
||||||
|
|
|
@ -527,7 +527,7 @@ typedef struct __device_info {
|
||||||
// 802.11 management
|
// 802.11 management
|
||||||
SMgmtObject sMgmtObj;
|
SMgmtObject sMgmtObj;
|
||||||
|
|
||||||
QWORD qwCurrTSF;
|
u64 qwCurrTSF;
|
||||||
unsigned int cbBulkInMax;
|
unsigned int cbBulkInMax;
|
||||||
BOOL bPSRxBeacon;
|
BOOL bPSRxBeacon;
|
||||||
|
|
||||||
|
|
|
@ -328,7 +328,7 @@ RXbBulkInProcessData (
|
||||||
PBYTE pbyRsr;
|
PBYTE pbyRsr;
|
||||||
PBYTE pbyNewRsr;
|
PBYTE pbyNewRsr;
|
||||||
PBYTE pbyRSSI;
|
PBYTE pbyRSSI;
|
||||||
PQWORD pqwTSFTime;
|
u64 *pqwTSFTime;
|
||||||
PBYTE pbyFrame;
|
PBYTE pbyFrame;
|
||||||
BOOL bDeFragRx = FALSE;
|
BOOL bDeFragRx = FALSE;
|
||||||
unsigned int cbHeaderOffset;
|
unsigned int cbHeaderOffset;
|
||||||
|
@ -411,7 +411,7 @@ RXbBulkInProcessData (
|
||||||
|
|
||||||
wPLCPwithPadding = ( (*pwPLCP_Length / 4) + ( (*pwPLCP_Length % 4) ? 1:0 ) ) *4;
|
wPLCPwithPadding = ( (*pwPLCP_Length / 4) + ( (*pwPLCP_Length % 4) ? 1:0 ) ) *4;
|
||||||
|
|
||||||
pqwTSFTime = (PQWORD) (pbyDAddress + 8 + wPLCPwithPadding);
|
pqwTSFTime = (u64 *)(pbyDAddress + 8 + wPLCPwithPadding);
|
||||||
if(pDevice->byBBType == BB_TYPE_11G) {
|
if(pDevice->byBBType == BB_TYPE_11G) {
|
||||||
pby3SQ = pbyDAddress + 8 + wPLCPwithPadding + 12;
|
pby3SQ = pbyDAddress + 8 + wPLCPwithPadding + 12;
|
||||||
pbySQ = pby3SQ;
|
pbySQ = pby3SQ;
|
||||||
|
@ -598,8 +598,7 @@ RXbBulkInProcessData (
|
||||||
pRxPacket->cbMPDULen = FrameSize;
|
pRxPacket->cbMPDULen = FrameSize;
|
||||||
pRxPacket->uRSSI = *pbyRSSI;
|
pRxPacket->uRSSI = *pbyRSSI;
|
||||||
pRxPacket->bySQ = *pbySQ;
|
pRxPacket->bySQ = *pbySQ;
|
||||||
HIDWORD(pRxPacket->qwLocalTSF) = cpu_to_le32(HIDWORD(*pqwTSFTime));
|
pRxPacket->qwLocalTSF = cpu_to_le64(*pqwTSFTime);
|
||||||
LODWORD(pRxPacket->qwLocalTSF) = cpu_to_le32(LODWORD(*pqwTSFTime));
|
|
||||||
if (bIsWEP) {
|
if (bIsWEP) {
|
||||||
// strip IV
|
// strip IV
|
||||||
pbyData1 = WLAN_HDR_A3_DATA_PTR(pbyFrame);
|
pbyData1 = WLAN_HDR_A3_DATA_PTR(pbyFrame);
|
||||||
|
@ -910,7 +909,7 @@ RXbBulkInProcessData (
|
||||||
RSC = dwRxTSC47_16;
|
RSC = dwRxTSC47_16;
|
||||||
RSC <<= 16;
|
RSC <<= 16;
|
||||||
RSC += wRxTSC15_0;
|
RSC += wRxTSC15_0;
|
||||||
memcpy(&(pKey->KeyRSC), &RSC, sizeof(QWORD));
|
memcpy(&(pKey->KeyRSC), &RSC, sizeof(u64));
|
||||||
|
|
||||||
if ( (pDevice->sMgmtObj.eCurrMode == WMAC_MODE_ESS_STA) &&
|
if ( (pDevice->sMgmtObj.eCurrMode == WMAC_MODE_ESS_STA) &&
|
||||||
(pDevice->sMgmtObj.eCurrState == WMAC_STATE_ASSOC)) {
|
(pDevice->sMgmtObj.eCurrState == WMAC_STATE_ASSOC)) {
|
||||||
|
|
|
@ -512,13 +512,11 @@ static int hostap_set_encryption(PSDevice pDevice,
|
||||||
} else {
|
} else {
|
||||||
// 8021x enable, individual key
|
// 8021x enable, individual key
|
||||||
dwKeyIndex |= (1 << 30); // set pairwise key
|
dwKeyIndex |= (1 << 30); // set pairwise key
|
||||||
if (KeybSetKey(pDevice,
|
if (KeybSetKey(pDevice, &(pDevice->sKey),
|
||||||
&(pDevice->sKey),
|
|
||||||
¶m->sta_addr[0],
|
¶m->sta_addr[0],
|
||||||
dwKeyIndex & ~(USE_KEYRSC),
|
dwKeyIndex & ~(USE_KEYRSC),
|
||||||
param->u.crypt.key_len,
|
param->u.crypt.key_len,
|
||||||
(PQWORD) &(KeyRSC),
|
&KeyRSC, (PBYTE)abyKey,
|
||||||
(PBYTE)abyKey,
|
|
||||||
KEY_CTL_WEP
|
KEY_CTL_WEP
|
||||||
) == TRUE) {
|
) == TRUE) {
|
||||||
|
|
||||||
|
@ -574,7 +572,7 @@ static int hostap_set_encryption(PSDevice pDevice,
|
||||||
&(pDevice->sKey),
|
&(pDevice->sKey),
|
||||||
dwKeyIndex,
|
dwKeyIndex,
|
||||||
param->u.crypt.key_len,
|
param->u.crypt.key_len,
|
||||||
(PQWORD) &(KeyRSC),
|
&KeyRSC,
|
||||||
abyKey,
|
abyKey,
|
||||||
byKeyDecMode
|
byKeyDecMode
|
||||||
);
|
);
|
||||||
|
@ -587,7 +585,7 @@ static int hostap_set_encryption(PSDevice pDevice,
|
||||||
¶m->sta_addr[0],
|
¶m->sta_addr[0],
|
||||||
dwKeyIndex,
|
dwKeyIndex,
|
||||||
param->u.crypt.key_len,
|
param->u.crypt.key_len,
|
||||||
(PQWORD) &(KeyRSC),
|
&KeyRSC,
|
||||||
(PBYTE)abyKey,
|
(PBYTE)abyKey,
|
||||||
byKeyDecMode
|
byKeyDecMode
|
||||||
) == TRUE) {
|
) == TRUE) {
|
||||||
|
|
|
@ -179,8 +179,7 @@ void INTnsProcessData(PSDevice pDevice)
|
||||||
NULL);
|
NULL);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
LODWORD(pDevice->qwCurrTSF) = pINTData->dwLoTSF;
|
pDevice->qwCurrTSF = cpu_to_le64(pINTData->qwTSF);
|
||||||
HIDWORD(pDevice->qwCurrTSF) = pINTData->dwHiTSF;
|
|
||||||
/*DBG_PRN_GRP01(("ISR0 = %02x ,
|
/*DBG_PRN_GRP01(("ISR0 = %02x ,
|
||||||
LoTsf = %08x,
|
LoTsf = %08x,
|
||||||
HiTsf = %08x\n",
|
HiTsf = %08x\n",
|
||||||
|
|
|
@ -48,8 +48,7 @@ typedef struct tagSINTData {
|
||||||
BYTE byTSR3;
|
BYTE byTSR3;
|
||||||
BYTE byPkt3;
|
BYTE byPkt3;
|
||||||
WORD wTime3;
|
WORD wTime3;
|
||||||
u32 dwLoTSF;
|
u64 qwTSF;
|
||||||
u32 dwHiTSF;
|
|
||||||
BYTE byISR0;
|
BYTE byISR0;
|
||||||
BYTE byISR1;
|
BYTE byISR1;
|
||||||
BYTE byRTSSuccess;
|
BYTE byRTSSuccess;
|
||||||
|
|
|
@ -224,7 +224,7 @@ BOOL KeybSetKey(
|
||||||
PBYTE pbyBSSID,
|
PBYTE pbyBSSID,
|
||||||
DWORD dwKeyIndex,
|
DWORD dwKeyIndex,
|
||||||
u32 uKeyLength,
|
u32 uKeyLength,
|
||||||
PQWORD pKeyRSC,
|
u64 *KeyRSC,
|
||||||
PBYTE pbyKey,
|
PBYTE pbyKey,
|
||||||
BYTE byKeyDecMode
|
BYTE byKeyDecMode
|
||||||
)
|
)
|
||||||
|
@ -286,13 +286,11 @@ BOOL KeybSetKey(
|
||||||
}
|
}
|
||||||
MACvSetKeyEntry(pDevice, pTable->KeyTable[i].wKeyCtl, i, uKeyIdx, pbyBSSID, (PDWORD)pKey->abyKey);
|
MACvSetKeyEntry(pDevice, pTable->KeyTable[i].wKeyCtl, i, uKeyIdx, pbyBSSID, (PDWORD)pKey->abyKey);
|
||||||
|
|
||||||
if ((dwKeyIndex & USE_KEYRSC) == 0) {
|
if ((dwKeyIndex & USE_KEYRSC) == 0)
|
||||||
// RSC set by NIC
|
pKey->KeyRSC = 0; /* RSC set by NIC */
|
||||||
memset(&(pKey->KeyRSC), 0, sizeof(QWORD));
|
else
|
||||||
}
|
pKey->KeyRSC = *KeyRSC;
|
||||||
else {
|
|
||||||
memcpy(&(pKey->KeyRSC), pKeyRSC, sizeof(QWORD));
|
|
||||||
}
|
|
||||||
pKey->dwTSC47_16 = 0;
|
pKey->dwTSC47_16 = 0;
|
||||||
pKey->wTSC15_0 = 0;
|
pKey->wTSC15_0 = 0;
|
||||||
|
|
||||||
|
@ -356,13 +354,11 @@ BOOL KeybSetKey(
|
||||||
}
|
}
|
||||||
MACvSetKeyEntry(pDevice, pTable->KeyTable[j].wKeyCtl, j, uKeyIdx, pbyBSSID, (PDWORD)pKey->abyKey);
|
MACvSetKeyEntry(pDevice, pTable->KeyTable[j].wKeyCtl, j, uKeyIdx, pbyBSSID, (PDWORD)pKey->abyKey);
|
||||||
|
|
||||||
if ((dwKeyIndex & USE_KEYRSC) == 0) {
|
if ((dwKeyIndex & USE_KEYRSC) == 0)
|
||||||
// RSC set by NIC
|
pKey->KeyRSC = 0; /* RSC set by NIC */
|
||||||
memset(&(pKey->KeyRSC), 0, sizeof(QWORD));
|
else
|
||||||
}
|
pKey->KeyRSC = *KeyRSC;
|
||||||
else {
|
|
||||||
memcpy(&(pKey->KeyRSC), pKeyRSC, sizeof(QWORD));
|
|
||||||
}
|
|
||||||
pKey->dwTSC47_16 = 0;
|
pKey->dwTSC47_16 = 0;
|
||||||
pKey->wTSC15_0 = 0;
|
pKey->wTSC15_0 = 0;
|
||||||
|
|
||||||
|
@ -676,7 +672,7 @@ BOOL KeybSetDefaultKey(
|
||||||
PSKeyManagement pTable,
|
PSKeyManagement pTable,
|
||||||
DWORD dwKeyIndex,
|
DWORD dwKeyIndex,
|
||||||
u32 uKeyLength,
|
u32 uKeyLength,
|
||||||
PQWORD pKeyRSC,
|
u64 *KeyRSC,
|
||||||
PBYTE pbyKey,
|
PBYTE pbyKey,
|
||||||
BYTE byKeyDecMode
|
BYTE byKeyDecMode
|
||||||
)
|
)
|
||||||
|
@ -742,12 +738,12 @@ BOOL KeybSetDefaultKey(
|
||||||
|
|
||||||
MACvSetKeyEntry(pDevice, pTable->KeyTable[MAX_KEY_TABLE-1].wKeyCtl, MAX_KEY_TABLE-1, uKeyIdx, pTable->KeyTable[MAX_KEY_TABLE-1].abyBSSID, (PDWORD) pKey->abyKey);
|
MACvSetKeyEntry(pDevice, pTable->KeyTable[MAX_KEY_TABLE-1].wKeyCtl, MAX_KEY_TABLE-1, uKeyIdx, pTable->KeyTable[MAX_KEY_TABLE-1].abyBSSID, (PDWORD) pKey->abyKey);
|
||||||
|
|
||||||
if ((dwKeyIndex & USE_KEYRSC) == 0) {
|
if ((dwKeyIndex & USE_KEYRSC) == 0)
|
||||||
// RSC set by NIC
|
pKey->KeyRSC = 0; /* RSC set by NIC */
|
||||||
memset(&(pKey->KeyRSC), 0, sizeof(QWORD));
|
else
|
||||||
} else {
|
pKey->KeyRSC = *KeyRSC;
|
||||||
memcpy(&(pKey->KeyRSC), pKeyRSC, sizeof(QWORD));
|
|
||||||
}
|
|
||||||
pKey->dwTSC47_16 = 0;
|
pKey->dwTSC47_16 = 0;
|
||||||
pKey->wTSC15_0 = 0;
|
pKey->wTSC15_0 = 0;
|
||||||
|
|
||||||
|
@ -792,7 +788,7 @@ BOOL KeybSetAllGroupKey(
|
||||||
PSKeyManagement pTable,
|
PSKeyManagement pTable,
|
||||||
DWORD dwKeyIndex,
|
DWORD dwKeyIndex,
|
||||||
u32 uKeyLength,
|
u32 uKeyLength,
|
||||||
PQWORD pKeyRSC,
|
u64 *KeyRSC,
|
||||||
PBYTE pbyKey,
|
PBYTE pbyKey,
|
||||||
BYTE byKeyDecMode
|
BYTE byKeyDecMode
|
||||||
)
|
)
|
||||||
|
@ -847,13 +843,11 @@ BOOL KeybSetAllGroupKey(
|
||||||
|
|
||||||
MACvSetKeyEntry(pDevice, pTable->KeyTable[i].wKeyCtl, i, uKeyIdx, pTable->KeyTable[i].abyBSSID, (PDWORD) pKey->abyKey);
|
MACvSetKeyEntry(pDevice, pTable->KeyTable[i].wKeyCtl, i, uKeyIdx, pTable->KeyTable[i].abyBSSID, (PDWORD) pKey->abyKey);
|
||||||
|
|
||||||
if ((dwKeyIndex & USE_KEYRSC) == 0) {
|
if ((dwKeyIndex & USE_KEYRSC) == 0)
|
||||||
// RSC set by NIC
|
pKey->KeyRSC = 0; /* RSC set by NIC */
|
||||||
memset(&(pKey->KeyRSC), 0, sizeof(QWORD));
|
else
|
||||||
}
|
pKey->KeyRSC = *KeyRSC;
|
||||||
else {
|
|
||||||
memcpy(&(pKey->KeyRSC), pKeyRSC, sizeof(QWORD));
|
|
||||||
}
|
|
||||||
pKey->dwTSC47_16 = 0;
|
pKey->dwTSC47_16 = 0;
|
||||||
pKey->wTSC15_0 = 0;
|
pKey->wTSC15_0 = 0;
|
||||||
|
|
||||||
|
|
|
@ -60,7 +60,7 @@ typedef struct tagSKeyItem
|
||||||
BOOL bKeyValid;
|
BOOL bKeyValid;
|
||||||
u32 uKeyLength;
|
u32 uKeyLength;
|
||||||
BYTE abyKey[MAX_KEY_LEN];
|
BYTE abyKey[MAX_KEY_LEN];
|
||||||
QWORD KeyRSC;
|
u64 KeyRSC;
|
||||||
DWORD dwTSC47_16;
|
DWORD dwTSC47_16;
|
||||||
WORD wTSC15_0;
|
WORD wTSC15_0;
|
||||||
BYTE byCipherSuite;
|
BYTE byCipherSuite;
|
||||||
|
@ -108,7 +108,7 @@ BOOL KeybSetKey(
|
||||||
PBYTE pbyBSSID,
|
PBYTE pbyBSSID,
|
||||||
DWORD dwKeyIndex,
|
DWORD dwKeyIndex,
|
||||||
u32 uKeyLength,
|
u32 uKeyLength,
|
||||||
PQWORD pKeyRSC,
|
u64 *KeyRSC,
|
||||||
PBYTE pbyKey,
|
PBYTE pbyKey,
|
||||||
BYTE byKeyDecMode
|
BYTE byKeyDecMode
|
||||||
);
|
);
|
||||||
|
@ -147,7 +147,7 @@ BOOL KeybSetDefaultKey(
|
||||||
PSKeyManagement pTable,
|
PSKeyManagement pTable,
|
||||||
DWORD dwKeyIndex,
|
DWORD dwKeyIndex,
|
||||||
u32 uKeyLength,
|
u32 uKeyLength,
|
||||||
PQWORD pKeyRSC,
|
u64 *KeyRSC,
|
||||||
PBYTE pbyKey,
|
PBYTE pbyKey,
|
||||||
BYTE byKeyDecMode
|
BYTE byKeyDecMode
|
||||||
);
|
);
|
||||||
|
@ -157,7 +157,7 @@ BOOL KeybSetAllGroupKey(
|
||||||
PSKeyManagement pTable,
|
PSKeyManagement pTable,
|
||||||
DWORD dwKeyIndex,
|
DWORD dwKeyIndex,
|
||||||
u32 uKeyLength,
|
u32 uKeyLength,
|
||||||
PQWORD pKeyRSC,
|
u64 *KeyRSC,
|
||||||
PBYTE pbyKey,
|
PBYTE pbyKey,
|
||||||
BYTE byKeyDecMode
|
BYTE byKeyDecMode
|
||||||
);
|
);
|
||||||
|
|
|
@ -48,18 +48,6 @@ typedef u8 BYTE;
|
||||||
typedef u16 WORD;
|
typedef u16 WORD;
|
||||||
typedef u32 DWORD;
|
typedef u32 DWORD;
|
||||||
|
|
||||||
// QWORD is for those situation that we want
|
|
||||||
// an 8-byte-aligned 8 byte long structure
|
|
||||||
// which is NOT really a floating point number.
|
|
||||||
typedef union tagUQuadWord {
|
|
||||||
struct {
|
|
||||||
u32 dwLowDword;
|
|
||||||
u32 dwHighDword;
|
|
||||||
} u;
|
|
||||||
double DoNotUseThisField;
|
|
||||||
} UQuadWord;
|
|
||||||
typedef UQuadWord QWORD; // 64-bit
|
|
||||||
|
|
||||||
/****** Common pointer types ***********************************************/
|
/****** Common pointer types ***********************************************/
|
||||||
|
|
||||||
typedef u32 ULONG_PTR;
|
typedef u32 ULONG_PTR;
|
||||||
|
@ -73,6 +61,4 @@ typedef WORD * PWORD;
|
||||||
|
|
||||||
typedef DWORD * PDWORD;
|
typedef DWORD * PDWORD;
|
||||||
|
|
||||||
typedef QWORD * PQWORD;
|
|
||||||
|
|
||||||
#endif /* __TTYPE_H__ */
|
#endif /* __TTYPE_H__ */
|
||||||
|
|
|
@ -1740,7 +1740,7 @@ s_vMgrRxBeacon(
|
||||||
|
|
||||||
PKnownBSS pBSSList;
|
PKnownBSS pBSSList;
|
||||||
WLAN_FR_BEACON sFrame;
|
WLAN_FR_BEACON sFrame;
|
||||||
QWORD qwTSFOffset;
|
u64 qwTSFOffset;
|
||||||
BOOL bIsBSSIDEqual = FALSE;
|
BOOL bIsBSSIDEqual = FALSE;
|
||||||
BOOL bIsSSIDEqual = FALSE;
|
BOOL bIsSSIDEqual = FALSE;
|
||||||
BOOL bTSFLargeDiff = FALSE;
|
BOOL bTSFLargeDiff = FALSE;
|
||||||
|
@ -1752,8 +1752,8 @@ s_vMgrRxBeacon(
|
||||||
BYTE byTIMBitOn = 0;
|
BYTE byTIMBitOn = 0;
|
||||||
WORD wAIDNumber = 0;
|
WORD wAIDNumber = 0;
|
||||||
unsigned int uNodeIndex;
|
unsigned int uNodeIndex;
|
||||||
QWORD qwTimestamp, qwLocalTSF;
|
u64 qwTimestamp, qwLocalTSF;
|
||||||
QWORD qwCurrTSF;
|
u64 qwCurrTSF;
|
||||||
WORD wStartIndex = 0;
|
WORD wStartIndex = 0;
|
||||||
WORD wAIDIndex = 0;
|
WORD wAIDIndex = 0;
|
||||||
BYTE byCurrChannel = pRxPacket->byRxChannel;
|
BYTE byCurrChannel = pRxPacket->byRxChannel;
|
||||||
|
@ -2013,26 +2013,14 @@ if(ChannelExceedZoneType(pDevice,byCurrChannel)==TRUE)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
HIDWORD(qwTimestamp) = cpu_to_le32(HIDWORD(*sFrame.pqwTimestamp));
|
qwTimestamp = cpu_to_le64(*sFrame.pqwTimestamp);
|
||||||
LODWORD(qwTimestamp) = cpu_to_le32(LODWORD(*sFrame.pqwTimestamp));
|
qwLocalTSF = pRxPacket->qwLocalTSF;
|
||||||
HIDWORD(qwLocalTSF) = HIDWORD(pRxPacket->qwLocalTSF);
|
|
||||||
LODWORD(qwLocalTSF) = LODWORD(pRxPacket->qwLocalTSF);
|
|
||||||
|
|
||||||
// check if beacon TSF larger or small than our local TSF
|
// check if beacon TSF larger or small than our local TSF
|
||||||
if (HIDWORD(qwTimestamp) == HIDWORD(qwLocalTSF)) {
|
if (qwTimestamp >= qwLocalTSF)
|
||||||
if (LODWORD(qwTimestamp) >= LODWORD(qwLocalTSF)) {
|
|
||||||
bTSFOffsetPostive = TRUE;
|
bTSFOffsetPostive = TRUE;
|
||||||
}
|
else
|
||||||
else {
|
|
||||||
bTSFOffsetPostive = FALSE;
|
bTSFOffsetPostive = FALSE;
|
||||||
}
|
|
||||||
}
|
|
||||||
else if (HIDWORD(qwTimestamp) > HIDWORD(qwLocalTSF)) {
|
|
||||||
bTSFOffsetPostive = TRUE;
|
|
||||||
}
|
|
||||||
else if (HIDWORD(qwTimestamp) < HIDWORD(qwLocalTSF)) {
|
|
||||||
bTSFOffsetPostive = FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (bTSFOffsetPostive) {
|
if (bTSFOffsetPostive) {
|
||||||
qwTSFOffset = CARDqGetTSFOffset(pRxPacket->byRxRate, (qwTimestamp), (qwLocalTSF));
|
qwTSFOffset = CARDqGetTSFOffset(pRxPacket->byRxRate, (qwTimestamp), (qwLocalTSF));
|
||||||
|
@ -2041,10 +2029,8 @@ if(ChannelExceedZoneType(pDevice,byCurrChannel)==TRUE)
|
||||||
qwTSFOffset = CARDqGetTSFOffset(pRxPacket->byRxRate, (qwLocalTSF), (qwTimestamp));
|
qwTSFOffset = CARDqGetTSFOffset(pRxPacket->byRxRate, (qwLocalTSF), (qwTimestamp));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (HIDWORD(qwTSFOffset) != 0 ||
|
if (qwTSFOffset > TRIVIAL_SYNC_DIFFERENCE)
|
||||||
(LODWORD(qwTSFOffset) > TRIVIAL_SYNC_DIFFERENCE )) {
|
|
||||||
bTSFLargeDiff = TRUE;
|
bTSFLargeDiff = TRUE;
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// if infra mode
|
// if infra mode
|
||||||
|
@ -2265,7 +2251,7 @@ void vMgrCreateOwnIBSS(void *hDeviceContext,
|
||||||
WORD wMaxSuppRate;
|
WORD wMaxSuppRate;
|
||||||
BYTE byTopCCKBasicRate;
|
BYTE byTopCCKBasicRate;
|
||||||
BYTE byTopOFDMBasicRate;
|
BYTE byTopOFDMBasicRate;
|
||||||
QWORD qwCurrTSF;
|
u64 qwCurrTSF = 0;
|
||||||
unsigned int ii;
|
unsigned int ii;
|
||||||
BYTE abyRATE[] = {0x82, 0x84, 0x8B, 0x96, 0x24, 0x30, 0x48, 0x6C, 0x0C, 0x12, 0x18, 0x60};
|
BYTE abyRATE[] = {0x82, 0x84, 0x8B, 0x96, 0x24, 0x30, 0x48, 0x6C, 0x0C, 0x12, 0x18, 0x60};
|
||||||
BYTE abyCCK_RATE[] = {0x82, 0x84, 0x8B, 0x96};
|
BYTE abyCCK_RATE[] = {0x82, 0x84, 0x8B, 0x96};
|
||||||
|
@ -2274,9 +2260,6 @@ void vMgrCreateOwnIBSS(void *hDeviceContext,
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
HIDWORD(qwCurrTSF) = 0;
|
|
||||||
LODWORD(qwCurrTSF) = 0;
|
|
||||||
|
|
||||||
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "Create Basic Service Set .......\n");
|
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "Create Basic Service Set .......\n");
|
||||||
|
|
||||||
if (pMgmt->eConfigMode == WMAC_CONFIG_IBSS_STA) {
|
if (pMgmt->eConfigMode == WMAC_CONFIG_IBSS_STA) {
|
||||||
|
@ -2420,12 +2403,12 @@ void vMgrCreateOwnIBSS(void *hDeviceContext,
|
||||||
if (pMgmt->eCurrMode == WMAC_MODE_IBSS_STA) {
|
if (pMgmt->eCurrMode == WMAC_MODE_IBSS_STA) {
|
||||||
|
|
||||||
// BSSID selected must be randomized as spec 11.1.3
|
// BSSID selected must be randomized as spec 11.1.3
|
||||||
pMgmt->abyCurrBSSID[5] = (BYTE) (LODWORD(qwCurrTSF)& 0x000000ff);
|
pMgmt->abyCurrBSSID[5] = (u8)(qwCurrTSF & 0x000000ff);
|
||||||
pMgmt->abyCurrBSSID[4] = (BYTE)((LODWORD(qwCurrTSF)& 0x0000ff00) >> 8);
|
pMgmt->abyCurrBSSID[4] = (u8)((qwCurrTSF & 0x0000ff00) >> 8);
|
||||||
pMgmt->abyCurrBSSID[3] = (BYTE)((LODWORD(qwCurrTSF)& 0x00ff0000) >> 16);
|
pMgmt->abyCurrBSSID[3] = (u8)((qwCurrTSF & 0x00ff0000) >> 16);
|
||||||
pMgmt->abyCurrBSSID[2] = (BYTE)((LODWORD(qwCurrTSF)& 0x00000ff0) >> 4);
|
pMgmt->abyCurrBSSID[2] = (u8)((qwCurrTSF & 0x00000ff0) >> 4);
|
||||||
pMgmt->abyCurrBSSID[1] = (BYTE)((LODWORD(qwCurrTSF)& 0x000ff000) >> 12);
|
pMgmt->abyCurrBSSID[1] = (u8)((qwCurrTSF & 0x000ff000) >> 12);
|
||||||
pMgmt->abyCurrBSSID[0] = (BYTE)((LODWORD(qwCurrTSF)& 0x0ff00000) >> 20);
|
pMgmt->abyCurrBSSID[0] = (u8)((qwCurrTSF & 0x0ff00000) >> 20);
|
||||||
pMgmt->abyCurrBSSID[5] ^= pMgmt->abyMACAddr[0];
|
pMgmt->abyCurrBSSID[5] ^= pMgmt->abyMACAddr[0];
|
||||||
pMgmt->abyCurrBSSID[4] ^= pMgmt->abyMACAddr[1];
|
pMgmt->abyCurrBSSID[4] ^= pMgmt->abyMACAddr[1];
|
||||||
pMgmt->abyCurrBSSID[3] ^= pMgmt->abyMACAddr[2];
|
pMgmt->abyCurrBSSID[3] ^= pMgmt->abyMACAddr[2];
|
||||||
|
|
|
@ -232,7 +232,7 @@ typedef struct tagSTxMgmtPacket {
|
||||||
typedef struct tagSRxMgmtPacket {
|
typedef struct tagSRxMgmtPacket {
|
||||||
|
|
||||||
PUWLAN_80211HDR p80211Header;
|
PUWLAN_80211HDR p80211Header;
|
||||||
QWORD qwLocalTSF;
|
u64 qwLocalTSF;
|
||||||
unsigned int cbMPDULen;
|
unsigned int cbMPDULen;
|
||||||
unsigned int cbPayloadLen;
|
unsigned int cbPayloadLen;
|
||||||
unsigned int uRSSI;
|
unsigned int uRSSI;
|
||||||
|
|
|
@ -74,7 +74,7 @@ int wpa_set_keys(PSDevice pDevice, void *ctx)
|
||||||
DWORD dwKeyIndex = 0;
|
DWORD dwKeyIndex = 0;
|
||||||
BYTE abyKey[MAX_KEY_LEN];
|
BYTE abyKey[MAX_KEY_LEN];
|
||||||
BYTE abySeq[MAX_KEY_LEN];
|
BYTE abySeq[MAX_KEY_LEN];
|
||||||
QWORD KeyRSC;
|
u64 KeyRSC;
|
||||||
BYTE byKeyDecMode = KEY_CTL_WEP;
|
BYTE byKeyDecMode = KEY_CTL_WEP;
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
int uu;
|
int uu;
|
||||||
|
@ -136,9 +136,9 @@ int wpa_set_keys(PSDevice pDevice, void *ctx)
|
||||||
if (param->u.wpa_key.seq_len > 0) {
|
if (param->u.wpa_key.seq_len > 0) {
|
||||||
for (ii = 0 ; ii < param->u.wpa_key.seq_len ; ii++) {
|
for (ii = 0 ; ii < param->u.wpa_key.seq_len ; ii++) {
|
||||||
if (ii < 4)
|
if (ii < 4)
|
||||||
LODWORD(KeyRSC) |= (abySeq[ii] << (ii * 8));
|
KeyRSC |= (abySeq[ii] << (ii * 8));
|
||||||
else
|
else
|
||||||
HIDWORD(KeyRSC) |= (abySeq[ii] << ((ii-4) * 8));
|
KeyRSC |= (abySeq[ii] << ((ii-4) * 8));
|
||||||
}
|
}
|
||||||
dwKeyIndex |= 1 << 29;
|
dwKeyIndex |= 1 << 29;
|
||||||
}
|
}
|
||||||
|
@ -203,7 +203,7 @@ int wpa_set_keys(PSDevice pDevice, void *ctx)
|
||||||
|
|
||||||
if ((KeybSetAllGroupKey(pDevice, &(pDevice->sKey), dwKeyIndex,
|
if ((KeybSetAllGroupKey(pDevice, &(pDevice->sKey), dwKeyIndex,
|
||||||
param->u.wpa_key.key_len,
|
param->u.wpa_key.key_len,
|
||||||
(PQWORD) &(KeyRSC),
|
&KeyRSC,
|
||||||
(PBYTE)abyKey,
|
(PBYTE)abyKey,
|
||||||
byKeyDecMode
|
byKeyDecMode
|
||||||
) == TRUE) &&
|
) == TRUE) &&
|
||||||
|
@ -211,7 +211,7 @@ int wpa_set_keys(PSDevice pDevice, void *ctx)
|
||||||
&(pDevice->sKey),
|
&(pDevice->sKey),
|
||||||
dwKeyIndex,
|
dwKeyIndex,
|
||||||
param->u.wpa_key.key_len,
|
param->u.wpa_key.key_len,
|
||||||
(PQWORD) &(KeyRSC),
|
&KeyRSC,
|
||||||
(PBYTE)abyKey,
|
(PBYTE)abyKey,
|
||||||
byKeyDecMode
|
byKeyDecMode
|
||||||
) == TRUE) ) {
|
) == TRUE) ) {
|
||||||
|
@ -234,7 +234,7 @@ int wpa_set_keys(PSDevice pDevice, void *ctx)
|
||||||
}
|
}
|
||||||
if (KeybSetKey(pDevice, &(pDevice->sKey), ¶m->addr[0],
|
if (KeybSetKey(pDevice, &(pDevice->sKey), ¶m->addr[0],
|
||||||
dwKeyIndex, param->u.wpa_key.key_len,
|
dwKeyIndex, param->u.wpa_key.key_len,
|
||||||
(PQWORD) &(KeyRSC), (PBYTE)abyKey, byKeyDecMode
|
&KeyRSC, (PBYTE)abyKey, byKeyDecMode
|
||||||
) == TRUE) {
|
) == TRUE) {
|
||||||
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "Pairwise Key Set\n");
|
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "Pairwise Key Set\n");
|
||||||
} else {
|
} else {
|
||||||
|
|
Loading…
Reference in New Issue