Staging: otus: 80211core: Hoist assign from if
Signed-off-by: Joe Perches <joe@perches.com> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
This commit is contained in:
parent
7c2c2eb7b2
commit
92363b529f
|
@ -2485,7 +2485,7 @@ void zfAggTxRetransmit(zdev_t* dev, struct bufInfo *buf_info, struct aggControl
|
||||||
BAW->insert(dev, buf_info->buf, tid_tx->bar_ssn >> 4, aggControl->tid_baw, buf_info->baw_retransmit, &header_r);
|
BAW->insert(dev, buf_info->buf, tid_tx->bar_ssn >> 4, aggControl->tid_baw, buf_info->baw_retransmit, &header_r);
|
||||||
}*/
|
}*/
|
||||||
|
|
||||||
if ((err = zfHpSend(dev,
|
err = zfHpSend(dev,
|
||||||
buf_info->baw_header->header,
|
buf_info->baw_header->header,
|
||||||
buf_info->baw_header->headerLen,
|
buf_info->baw_header->headerLen,
|
||||||
buf_info->baw_header->snap,
|
buf_info->baw_header->snap,
|
||||||
|
@ -2496,7 +2496,8 @@ void zfAggTxRetransmit(zdev_t* dev, struct bufInfo *buf_info, struct aggControl
|
||||||
buf_info->baw_header->removeLen,
|
buf_info->baw_header->removeLen,
|
||||||
ZM_EXTERNAL_ALLOC_BUF,
|
ZM_EXTERNAL_ALLOC_BUF,
|
||||||
(u8_t)tid_tx->ac,
|
(u8_t)tid_tx->ac,
|
||||||
buf_info->baw_header->keyIdx)) != ZM_SUCCESS)
|
buf_info->baw_header->keyIdx);
|
||||||
|
if (err != ZM_SUCCESS)
|
||||||
{
|
{
|
||||||
goto zlError;
|
goto zlError;
|
||||||
}
|
}
|
||||||
|
@ -2797,9 +2798,10 @@ u16_t zfAggTxSendEth(zdev_t* dev, zbuf_t* buf, u16_t port, u16_t bufType, u8_t f
|
||||||
BAW->insert(dev, buf, tid_tx->bar_ssn >> 4, aggControl->tid_baw, 0, &header_r);
|
BAW->insert(dev, buf, tid_tx->bar_ssn >> 4, aggControl->tid_baw, 0, &header_r);
|
||||||
}*/
|
}*/
|
||||||
|
|
||||||
if ((err = zfHpSend(dev, header, headerLen, snap, snapLen,
|
err = zfHpSend(dev, header, headerLen, snap, snapLen,
|
||||||
mic, micLen, frag.buf[i], removeLen,
|
mic, micLen, frag.buf[i], removeLen,
|
||||||
frag.bufType[i], zcUpToAc[up&0x7], keyIdx)) != ZM_SUCCESS)
|
frag.bufType[i], zcUpToAc[up&0x7], keyIdx);
|
||||||
|
if (err != ZM_SUCCESS)
|
||||||
{
|
{
|
||||||
goto zlError;
|
goto zlError;
|
||||||
}
|
}
|
||||||
|
@ -2849,7 +2851,8 @@ u16_t zfAggSendAddbaRequest(zdev_t* dev, u16_t *dst, u16_t ac, u16_t up)
|
||||||
/*
|
/*
|
||||||
* TBD : Maximum size of management frame
|
* TBD : Maximum size of management frame
|
||||||
*/
|
*/
|
||||||
if ((buf = zfwBufAllocate(dev, 1024)) == NULL)
|
buf = zfwBufAllocate(dev, 1024);
|
||||||
|
if (buf == NULL)
|
||||||
{
|
{
|
||||||
zm_msg0_mm(ZM_LV_0, "Alloc mm buf Fail!");
|
zm_msg0_mm(ZM_LV_0, "Alloc mm buf Fail!");
|
||||||
return ZM_SUCCESS;
|
return ZM_SUCCESS;
|
||||||
|
@ -2892,8 +2895,9 @@ u16_t zfAggSendAddbaRequest(zdev_t* dev, u16_t *dst, u16_t ac, u16_t up)
|
||||||
//zm_msg2_mm(ZM_LV_2, "buf->data=", buf->data);
|
//zm_msg2_mm(ZM_LV_2, "buf->data=", buf->data);
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
if ((err = zfHpSend(dev, NULL, 0, NULL, 0, NULL, 0, buf, 0,
|
err = zfHpSend(dev, NULL, 0, NULL, 0, NULL, 0, buf, 0,
|
||||||
ZM_INTERNAL_ALLOC_BUF, 0, 0xff)) != ZM_SUCCESS)
|
ZM_INTERNAL_ALLOC_BUF, 0, 0xff);
|
||||||
|
if (err != ZM_SUCCESS)
|
||||||
{
|
{
|
||||||
goto zlError;
|
goto zlError;
|
||||||
}
|
}
|
||||||
|
@ -3290,7 +3294,8 @@ u16_t zfAggSendAddbaResponse(zdev_t* dev, struct aggBaFrameParameter *bf)
|
||||||
/*
|
/*
|
||||||
* TBD : Maximum size of management frame
|
* TBD : Maximum size of management frame
|
||||||
*/
|
*/
|
||||||
if ((buf = zfwBufAllocate(dev, 1024)) == NULL)
|
buf = zfwBufAllocate(dev, 1024);
|
||||||
|
if (buf == NULL)
|
||||||
{
|
{
|
||||||
zm_msg0_mm(ZM_LV_0, "Alloc mm buf Fail!");
|
zm_msg0_mm(ZM_LV_0, "Alloc mm buf Fail!");
|
||||||
return ZM_SUCCESS;
|
return ZM_SUCCESS;
|
||||||
|
@ -3337,8 +3342,9 @@ u16_t zfAggSendAddbaResponse(zdev_t* dev, struct aggBaFrameParameter *bf)
|
||||||
//zm_msg2_mm(ZM_LV_2, "buf->data=", buf->data);
|
//zm_msg2_mm(ZM_LV_2, "buf->data=", buf->data);
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
if ((err = zfHpSend(dev, NULL, 0, NULL, 0, NULL, 0, buf, 0,
|
err = zfHpSend(dev, NULL, 0, NULL, 0, NULL, 0, buf, 0,
|
||||||
ZM_INTERNAL_ALLOC_BUF, 0, 0xff)) != ZM_SUCCESS)
|
ZM_INTERNAL_ALLOC_BUF, 0, 0xff);
|
||||||
|
if (err != ZM_SUCCESS)
|
||||||
{
|
{
|
||||||
goto zlError;
|
goto zlError;
|
||||||
}
|
}
|
||||||
|
@ -3443,7 +3449,8 @@ u16_t zfAggSendBar(zdev_t* dev, TID_TX tid_tx, struct aggBarControl *aggBarCon
|
||||||
/*
|
/*
|
||||||
* TBD : Maximum size of management frame
|
* TBD : Maximum size of management frame
|
||||||
*/
|
*/
|
||||||
if ((buf = zfwBufAllocate(dev, 1024)) == NULL)
|
buf = zfwBufAllocate(dev, 1024);
|
||||||
|
if (buf == NULL)
|
||||||
{
|
{
|
||||||
zm_msg0_mm(ZM_LV_0, "Alloc mm buf Fail!");
|
zm_msg0_mm(ZM_LV_0, "Alloc mm buf Fail!");
|
||||||
return ZM_SUCCESS;
|
return ZM_SUCCESS;
|
||||||
|
@ -3486,8 +3493,9 @@ u16_t zfAggSendBar(zdev_t* dev, TID_TX tid_tx, struct aggBarControl *aggBarCon
|
||||||
//zm_msg2_mm(ZM_LV_2, "buf->data=", buf->data);
|
//zm_msg2_mm(ZM_LV_2, "buf->data=", buf->data);
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
if ((err = zfHpSend(dev, NULL, 0, NULL, 0, NULL, 0, buf, 0,
|
err = zfHpSend(dev, NULL, 0, NULL, 0, NULL, 0, buf, 0,
|
||||||
ZM_INTERNAL_ALLOC_BUF, 0, 0xff)) != ZM_SUCCESS)
|
ZM_INTERNAL_ALLOC_BUF, 0, 0xff);
|
||||||
|
if (err != ZM_SUCCESS)
|
||||||
{
|
{
|
||||||
goto zlError;
|
goto zlError;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1436,7 +1436,8 @@ u16_t zfiWlanDeauth(zdev_t *dev, u16_t *macAddr, u16_t reason)
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
if ((id = zfApFindSta(dev, macAddr)) != 0xffff)
|
id = zfApFindSta(dev, macAddr);
|
||||||
|
if (id != 0xffff)
|
||||||
{
|
{
|
||||||
u32_t key[8];
|
u32_t key[8];
|
||||||
u16_t nullAddr[3] = { 0x0, 0x0, 0x0 };
|
u16_t nullAddr[3] = { 0x0, 0x0, 0x0 };
|
||||||
|
|
|
@ -1072,7 +1072,8 @@ u16_t zfFindCleanFrequency(zdev_t* dev, u32_t adhocMode)
|
||||||
|
|
||||||
zmw_get_wlan_dev(dev);
|
zmw_get_wlan_dev(dev);
|
||||||
|
|
||||||
if ((pBssInfo = wd->sta.bssList.head) == NULL)
|
pBssInfo = wd->sta.bssList.head;
|
||||||
|
if (pBssInfo == NULL)
|
||||||
{
|
{
|
||||||
if( adhocMode == ZM_ADHOCBAND_B || adhocMode == ZM_ADHOCBAND_G ||
|
if( adhocMode == ZM_ADHOCBAND_B || adhocMode == ZM_ADHOCBAND_G ||
|
||||||
adhocMode == ZM_ADHOCBAND_BG || adhocMode == ZM_ADHOCBAND_ABG )
|
adhocMode == ZM_ADHOCBAND_BG || adhocMode == ZM_ADHOCBAND_ABG )
|
||||||
|
|
|
@ -329,7 +329,8 @@ void zfCoreEvent(zdev_t* dev, u16_t event, u8_t* rsp)
|
||||||
if (wd->wlanMode == ZM_MODE_AP)
|
if (wd->wlanMode == ZM_MODE_AP)
|
||||||
{
|
{
|
||||||
zmw_enter_critical_section(dev);
|
zmw_enter_critical_section(dev);
|
||||||
if ((i=zfApFindSta(dev, (u16_t*)rsp)) != 0xffff)
|
i = zfApFindSta(dev, (u16_t*)rsp);
|
||||||
|
if (i != 0xffff)
|
||||||
{
|
{
|
||||||
zfRateCtrlTxFailEvent(dev, &wd->ap.staTable[i].rcCell, 0,(u32_t)zfPhyCtrlToRate(retryRate));
|
zfRateCtrlTxFailEvent(dev, &wd->ap.staTable[i].rcCell, 0,(u32_t)zfPhyCtrlToRate(retryRate));
|
||||||
}
|
}
|
||||||
|
@ -357,7 +358,8 @@ void zfCoreEvent(zdev_t* dev, u16_t event, u8_t* rsp)
|
||||||
if (wd->wlanMode == ZM_MODE_AP)
|
if (wd->wlanMode == ZM_MODE_AP)
|
||||||
{
|
{
|
||||||
zmw_enter_critical_section(dev);
|
zmw_enter_critical_section(dev);
|
||||||
if ((i=zfApFindSta(dev, (u16_t*)rsp)) != 0xffff)
|
i = zfApFindSta(dev, (u16_t*)rsp);
|
||||||
|
if (i != 0xffff)
|
||||||
{
|
{
|
||||||
zfRateCtrlTxFailEvent(dev, &wd->ap.staTable[i].rcCell, 0,(u32_t)zfPhyCtrlToRate(retryRate));
|
zfRateCtrlTxFailEvent(dev, &wd->ap.staTable[i].rcCell, 0,(u32_t)zfPhyCtrlToRate(retryRate));
|
||||||
}
|
}
|
||||||
|
@ -387,7 +389,8 @@ void zfCoreEvent(zdev_t* dev, u16_t event, u8_t* rsp)
|
||||||
if (wd->wlanMode == ZM_MODE_AP)
|
if (wd->wlanMode == ZM_MODE_AP)
|
||||||
{
|
{
|
||||||
zmw_enter_critical_section(dev);
|
zmw_enter_critical_section(dev);
|
||||||
if ((i=zfApFindSta(dev, (u16_t*)rsp)) != 0xffff)
|
i = zfApFindSta(dev, (u16_t*)rsp);
|
||||||
|
if (i != 0xffff)
|
||||||
{
|
{
|
||||||
zfRateCtrlTxSuccessEvent(dev, &wd->ap.staTable[i].rcCell, zfPhyCtrlToRate(retryRate));
|
zfRateCtrlTxSuccessEvent(dev, &wd->ap.staTable[i].rcCell, zfPhyCtrlToRate(retryRate));
|
||||||
}
|
}
|
||||||
|
|
|
@ -622,7 +622,8 @@ u16_t zfTxGenWlanHeader(zdev_t* dev, zbuf_t* buf, u16_t* header, u16_t seq,
|
||||||
phyCtrl = 0xc0001; //PHY control L
|
phyCtrl = 0xc0001; //PHY control L
|
||||||
|
|
||||||
/* WDS port checking */
|
/* WDS port checking */
|
||||||
if ((wdsPort = (port - 0x20)) >= ZM_MAX_WDS_SUPPORT)
|
wdsPort = port - 0x20;
|
||||||
|
if (wdsPort >= ZM_MAX_WDS_SUPPORT)
|
||||||
{
|
{
|
||||||
wdsPort = 0;
|
wdsPort = 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -83,7 +83,8 @@ u16_t zfFindElement(zdev_t* dev, zbuf_t* buf, u8_t eid)
|
||||||
|
|
||||||
/* Get offset of first element */
|
/* Get offset of first element */
|
||||||
subType = (zmw_rx_buf_readb(dev, buf, 0) >> 4);
|
subType = (zmw_rx_buf_readb(dev, buf, 0) >> 4);
|
||||||
if ((offset = zgElementOffsetTable[subType]) == 0xff)
|
offset = zgElementOffsetTable[subType];
|
||||||
|
if (offset == 0xff)
|
||||||
{
|
{
|
||||||
zm_assert(0);
|
zm_assert(0);
|
||||||
}
|
}
|
||||||
|
@ -107,10 +108,12 @@ u16_t zfFindElement(zdev_t* dev, zbuf_t* buf, u8_t eid)
|
||||||
while ((offset+2)<bufLen) // including element ID and length (2bytes)
|
while ((offset+2)<bufLen) // including element ID and length (2bytes)
|
||||||
{
|
{
|
||||||
/* Search target element */
|
/* Search target element */
|
||||||
if ((id = zmw_rx_buf_readb(dev, buf, offset)) == eid)
|
id = zmw_rx_buf_readb(dev, buf, offset);
|
||||||
|
if (id == eid)
|
||||||
{
|
{
|
||||||
/* Bingo */
|
/* Bingo */
|
||||||
if ((elen = zmw_rx_buf_readb(dev, buf, offset+1))>(bufLen - offset))
|
elen = zmw_rx_buf_readb(dev, buf, offset+1);
|
||||||
|
if (elen > bufLen - offset)
|
||||||
{
|
{
|
||||||
/* Element length error */
|
/* Element length error */
|
||||||
return 0xffff;
|
return 0xffff;
|
||||||
|
@ -151,7 +154,8 @@ u16_t zfFindElement(zdev_t* dev, zbuf_t* buf, u8_t eid)
|
||||||
#if 1
|
#if 1
|
||||||
elen = zmw_rx_buf_readb(dev, buf, offset+1);
|
elen = zmw_rx_buf_readb(dev, buf, offset+1);
|
||||||
#else
|
#else
|
||||||
if ((elen = zmw_rx_buf_readb(dev, buf, offset+1)) == 0)
|
elen = zmw_rx_buf_readb(dev, buf, offset+1);
|
||||||
|
if (elen == 0)
|
||||||
{
|
{
|
||||||
return 0xffff;
|
return 0xffff;
|
||||||
}
|
}
|
||||||
|
@ -194,7 +198,8 @@ u16_t zfFindWifiElement(zdev_t* dev, zbuf_t* buf, u8_t type, u8_t subtype)
|
||||||
/* Get offset of first element */
|
/* Get offset of first element */
|
||||||
subType = (zmw_rx_buf_readb(dev, buf, 0) >> 4);
|
subType = (zmw_rx_buf_readb(dev, buf, 0) >> 4);
|
||||||
|
|
||||||
if ((offset = zgElementOffsetTable[subType]) == 0xff)
|
offset = zgElementOffsetTable[subType];
|
||||||
|
if (offset == 0xff)
|
||||||
{
|
{
|
||||||
zm_assert(0);
|
zm_assert(0);
|
||||||
}
|
}
|
||||||
|
@ -207,10 +212,12 @@ u16_t zfFindWifiElement(zdev_t* dev, zbuf_t* buf, u8_t type, u8_t subtype)
|
||||||
while ((offset+2)<bufLen) // including element ID and length (2bytes)
|
while ((offset+2)<bufLen) // including element ID and length (2bytes)
|
||||||
{
|
{
|
||||||
/* Search target element */
|
/* Search target element */
|
||||||
if ((id = zmw_rx_buf_readb(dev, buf, offset)) == ZM_WLAN_EID_WIFI_IE)
|
id = zmw_rx_buf_readb(dev, buf, offset);
|
||||||
|
if (id == ZM_WLAN_EID_WIFI_IE)
|
||||||
{
|
{
|
||||||
/* Bingo */
|
/* Bingo */
|
||||||
if ((elen = zmw_rx_buf_readb(dev, buf, offset+1))>(bufLen - offset))
|
elen = zmw_rx_buf_readb(dev, buf, offset+1);
|
||||||
|
if (elen > bufLen - offset)
|
||||||
{
|
{
|
||||||
/* Element length error */
|
/* Element length error */
|
||||||
return 0xffff;
|
return 0xffff;
|
||||||
|
@ -229,7 +236,8 @@ u16_t zfFindWifiElement(zdev_t* dev, zbuf_t* buf, u8_t type, u8_t subtype)
|
||||||
{
|
{
|
||||||
if ( subtype != 0xff )
|
if ( subtype != 0xff )
|
||||||
{
|
{
|
||||||
if ( (tmp = zmw_rx_buf_readb(dev, buf, offset+6)) == subtype )
|
tmp = zmw_rx_buf_readb(dev, buf, offset+6);
|
||||||
|
if (tmp == subtype)
|
||||||
{
|
{
|
||||||
return offset;
|
return offset;
|
||||||
}
|
}
|
||||||
|
@ -241,7 +249,8 @@ u16_t zfFindWifiElement(zdev_t* dev, zbuf_t* buf, u8_t type, u8_t subtype)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/* Advance to next element */
|
/* Advance to next element */
|
||||||
if ((elen = zmw_rx_buf_readb(dev, buf, offset+1)) == 0)
|
elen = zmw_rx_buf_readb(dev, buf, offset+1);
|
||||||
|
if (elen == 0)
|
||||||
{
|
{
|
||||||
return 0xffff;
|
return 0xffff;
|
||||||
}
|
}
|
||||||
|
@ -348,7 +357,8 @@ u16_t zfFindSuperGElement(zdev_t* dev, zbuf_t* buf, u8_t type)
|
||||||
|
|
||||||
/* Get offset of first element */
|
/* Get offset of first element */
|
||||||
subType = (zmw_rx_buf_readb(dev, buf, 0) >> 4);
|
subType = (zmw_rx_buf_readb(dev, buf, 0) >> 4);
|
||||||
if ((offset = zgElementOffsetTable[subType]) == 0xff)
|
offset = zgElementOffsetTable[subType];
|
||||||
|
if (offset == 0xff)
|
||||||
{
|
{
|
||||||
zm_assert(0);
|
zm_assert(0);
|
||||||
}
|
}
|
||||||
|
@ -361,10 +371,12 @@ u16_t zfFindSuperGElement(zdev_t* dev, zbuf_t* buf, u8_t type)
|
||||||
while ((offset+2)<bufLen) // including element ID and length (2bytes)
|
while ((offset+2)<bufLen) // including element ID and length (2bytes)
|
||||||
{
|
{
|
||||||
/* Search target element */
|
/* Search target element */
|
||||||
if ((id = zmw_rx_buf_readb(dev, buf, offset)) == ZM_WLAN_EID_VENDOR_PRIVATE)
|
id = zmw_rx_buf_readb(dev, buf, offset);
|
||||||
|
if (id == ZM_WLAN_EID_VENDOR_PRIVATE)
|
||||||
{
|
{
|
||||||
/* Bingo */
|
/* Bingo */
|
||||||
if ((elen = zmw_rx_buf_readb(dev, buf, offset+1))>(bufLen - offset))
|
elen = zmw_rx_buf_readb(dev, buf, offset+1);
|
||||||
|
if (elen > bufLen - offset)
|
||||||
{
|
{
|
||||||
/* Element length error */
|
/* Element length error */
|
||||||
return 0xffff;
|
return 0xffff;
|
||||||
|
@ -389,7 +401,8 @@ u16_t zfFindSuperGElement(zdev_t* dev, zbuf_t* buf, u8_t type)
|
||||||
#if 1
|
#if 1
|
||||||
elen = zmw_rx_buf_readb(dev, buf, offset+1);
|
elen = zmw_rx_buf_readb(dev, buf, offset+1);
|
||||||
#else
|
#else
|
||||||
if ((elen = zmw_rx_buf_readb(dev, buf, offset+1)) == 0)
|
elen = zmw_rx_buf_readb(dev, buf, offset+1);
|
||||||
|
if (elen == 0)
|
||||||
{
|
{
|
||||||
return 0xffff;
|
return 0xffff;
|
||||||
}
|
}
|
||||||
|
@ -411,7 +424,8 @@ u16_t zfFindXRElement(zdev_t* dev, zbuf_t* buf, u8_t type)
|
||||||
|
|
||||||
/* Get offset of first element */
|
/* Get offset of first element */
|
||||||
subType = (zmw_rx_buf_readb(dev, buf, 0) >> 4);
|
subType = (zmw_rx_buf_readb(dev, buf, 0) >> 4);
|
||||||
if ((offset = zgElementOffsetTable[subType]) == 0xff)
|
offset = zgElementOffsetTable[subType];
|
||||||
|
if (offset == 0xff)
|
||||||
{
|
{
|
||||||
zm_assert(0);
|
zm_assert(0);
|
||||||
}
|
}
|
||||||
|
@ -424,10 +438,12 @@ u16_t zfFindXRElement(zdev_t* dev, zbuf_t* buf, u8_t type)
|
||||||
while ((offset+2)<bufLen) // including element ID and length (2bytes)
|
while ((offset+2)<bufLen) // including element ID and length (2bytes)
|
||||||
{
|
{
|
||||||
/* Search target element */
|
/* Search target element */
|
||||||
if ((id = zmw_rx_buf_readb(dev, buf, offset)) == ZM_WLAN_EID_VENDOR_PRIVATE)
|
id = zmw_rx_buf_readb(dev, buf, offset);
|
||||||
|
if (id == ZM_WLAN_EID_VENDOR_PRIVATE)
|
||||||
{
|
{
|
||||||
/* Bingo */
|
/* Bingo */
|
||||||
if ((elen = zmw_rx_buf_readb(dev, buf, offset+1))>(bufLen - offset))
|
elen = zmw_rx_buf_readb(dev, buf, offset+1);
|
||||||
|
if (elen > bufLen - offset)
|
||||||
{
|
{
|
||||||
/* Element length error */
|
/* Element length error */
|
||||||
return 0xffff;
|
return 0xffff;
|
||||||
|
@ -447,7 +463,8 @@ u16_t zfFindXRElement(zdev_t* dev, zbuf_t* buf, u8_t type)
|
||||||
#if 1
|
#if 1
|
||||||
elen = zmw_rx_buf_readb(dev, buf, offset+1);
|
elen = zmw_rx_buf_readb(dev, buf, offset+1);
|
||||||
#else
|
#else
|
||||||
if ((elen = zmw_rx_buf_readb(dev, buf, offset+1)) == 0)
|
elen = zmw_rx_buf_readb(dev, buf, offset+1);
|
||||||
|
if (elen == 0)
|
||||||
{
|
{
|
||||||
return 0xffff;
|
return 0xffff;
|
||||||
}
|
}
|
||||||
|
@ -868,7 +885,8 @@ void zfSendMmFrame(zdev_t* dev, u8_t frameType, u16_t* dst,
|
||||||
|
|
||||||
zm_msg2_mm(ZM_LV_2, "Send mm frame, type=", frameType);
|
zm_msg2_mm(ZM_LV_2, "Send mm frame, type=", frameType);
|
||||||
/* TBD : Maximum size of management frame */
|
/* TBD : Maximum size of management frame */
|
||||||
if ((buf = zfwBufAllocate(dev, 1024)) == NULL)
|
buf = zfwBufAllocate(dev, 1024);
|
||||||
|
if (buf == NULL)
|
||||||
{
|
{
|
||||||
zm_msg0_mm(ZM_LV_0, "Alloc mm buf Fail!");
|
zm_msg0_mm(ZM_LV_0, "Alloc mm buf Fail!");
|
||||||
return;
|
return;
|
||||||
|
@ -1257,7 +1275,8 @@ void zfSendMmFrame(zdev_t* dev, u8_t frameType, u16_t* dst,
|
||||||
{
|
{
|
||||||
vap = (u16_t) p3;
|
vap = (u16_t) p3;
|
||||||
|
|
||||||
if ((aid = zfApFindSta(dev, dst)) != 0xffff)
|
aid = zfApFindSta(dev, dst);
|
||||||
|
if (aid != 0xffff)
|
||||||
{
|
{
|
||||||
zmw_enter_critical_section(dev);
|
zmw_enter_critical_section(dev);
|
||||||
/* Clear STA table */
|
/* Clear STA table */
|
||||||
|
@ -1303,8 +1322,9 @@ void zfSendMmFrame(zdev_t* dev, u8_t frameType, u16_t* dst,
|
||||||
//zm_msg2_mm(ZM_LV_2, "buf->data=", buf->data);
|
//zm_msg2_mm(ZM_LV_2, "buf->data=", buf->data);
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
if ((err = zfHpSend(dev, NULL, 0, NULL, 0, NULL, 0, buf, 0,
|
err = zfHpSend(dev, NULL, 0, NULL, 0, NULL, 0, buf, 0,
|
||||||
ZM_INTERNAL_ALLOC_BUF, 0, 0xff)) != ZM_SUCCESS)
|
ZM_INTERNAL_ALLOC_BUF, 0, 0xff);
|
||||||
|
if (err != ZM_SUCCESS)
|
||||||
{
|
{
|
||||||
goto zlError;
|
goto zlError;
|
||||||
}
|
}
|
||||||
|
@ -1366,7 +1386,8 @@ void zfProcessManagement(zdev_t* dev, zbuf_t* buf, struct zsAdditionInfo* AddInf
|
||||||
if ((ra[0] & 0x1) != 1)
|
if ((ra[0] & 0x1) != 1)
|
||||||
{
|
{
|
||||||
/* AP : Find virtual AP */
|
/* AP : Find virtual AP */
|
||||||
if ((index = zfApFindSta(dev, ta)) != 0xffff)
|
index = zfApFindSta(dev, ta);
|
||||||
|
if (index != 0xffff)
|
||||||
{
|
{
|
||||||
vap = wd->ap.staTable[index].vap;
|
vap = wd->ap.staTable[index].vap;
|
||||||
}
|
}
|
||||||
|
@ -1534,7 +1555,8 @@ void zfProcessProbeReq(zdev_t* dev, zbuf_t* buf, u16_t* src)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* check SSID */
|
/* check SSID */
|
||||||
if ((offset = zfFindElement(dev, buf, ZM_WLAN_EID_SSID)) == 0xffff)
|
offset = zfFindElement(dev, buf, ZM_WLAN_EID_SSID);
|
||||||
|
if (offset == 0xffff)
|
||||||
{
|
{
|
||||||
zm_msg0_mm(ZM_LV_3, "probe req SSID not found");
|
zm_msg0_mm(ZM_LV_3, "probe req SSID not found");
|
||||||
return;
|
return;
|
||||||
|
@ -1561,8 +1583,8 @@ void zfProcessProbeReq(zdev_t* dev, zbuf_t* buf, u16_t* src)
|
||||||
{
|
{
|
||||||
for (j=0; j<len; j++)
|
for (j=0; j<len; j++)
|
||||||
{
|
{
|
||||||
if ((ch = zmw_rx_buf_readb(dev, buf, offset+2+j))
|
ch = zmw_rx_buf_readb(dev, buf, offset+2+j);
|
||||||
!= wd->ap.ssid[i][j])
|
if (ch != wd->ap.ssid[i][j])
|
||||||
{
|
{
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -1814,7 +1836,8 @@ u16_t zfFindATHExtCap(zdev_t* dev, zbuf_t* buf, u8_t type, u8_t subtype)
|
||||||
/* Get offset of first element */
|
/* Get offset of first element */
|
||||||
subType = (zmw_rx_buf_readb(dev, buf, 0) >> 4);
|
subType = (zmw_rx_buf_readb(dev, buf, 0) >> 4);
|
||||||
|
|
||||||
if ((offset = zgElementOffsetTable[subType]) == 0xff)
|
offset = zgElementOffsetTable[subType];
|
||||||
|
if (offset == 0xff)
|
||||||
{
|
{
|
||||||
zm_assert(0);
|
zm_assert(0);
|
||||||
}
|
}
|
||||||
|
@ -1828,10 +1851,12 @@ u16_t zfFindATHExtCap(zdev_t* dev, zbuf_t* buf, u8_t type, u8_t subtype)
|
||||||
while ((offset+2)<bufLen) // including element ID and length (2bytes)
|
while ((offset+2)<bufLen) // including element ID and length (2bytes)
|
||||||
{
|
{
|
||||||
/* Search target element */
|
/* Search target element */
|
||||||
if ((id = zmw_rx_buf_readb(dev, buf, offset)) == ZM_WLAN_EID_WIFI_IE)
|
id = zmw_rx_buf_readb(dev, buf, offset);
|
||||||
|
if (id == ZM_WLAN_EID_WIFI_IE)
|
||||||
{
|
{
|
||||||
/* Bingo */
|
/* Bingo */
|
||||||
if ((elen = zmw_rx_buf_readb(dev, buf, offset+1))>(bufLen - offset))
|
elen = zmw_rx_buf_readb(dev, buf, offset+1);
|
||||||
|
if (elen > bufLen - offset)
|
||||||
{
|
{
|
||||||
/* Element length error */
|
/* Element length error */
|
||||||
return 0xffff;
|
return 0xffff;
|
||||||
|
@ -1850,7 +1875,8 @@ u16_t zfFindATHExtCap(zdev_t* dev, zbuf_t* buf, u8_t type, u8_t subtype)
|
||||||
{
|
{
|
||||||
if ( subtype != 0xff )
|
if ( subtype != 0xff )
|
||||||
{
|
{
|
||||||
if ( (tmp = zmw_rx_buf_readb(dev, buf, offset+6)) == subtype )
|
tmp = zmw_rx_buf_readb(dev, buf, offset+6);
|
||||||
|
if (tmp == subtype )
|
||||||
{
|
{
|
||||||
return offset;
|
return offset;
|
||||||
}
|
}
|
||||||
|
@ -1863,7 +1889,8 @@ u16_t zfFindATHExtCap(zdev_t* dev, zbuf_t* buf, u8_t type, u8_t subtype)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Advance to next element */
|
/* Advance to next element */
|
||||||
if ((elen = zmw_rx_buf_readb(dev, buf, offset+1)) == 0)
|
elen = zmw_rx_buf_readb(dev, buf, offset+1);
|
||||||
|
if (elen == 0)
|
||||||
{
|
{
|
||||||
return 0xffff;
|
return 0xffff;
|
||||||
}
|
}
|
||||||
|
@ -1884,7 +1911,8 @@ u16_t zfFindBrdcmMrvlRlnkExtCap(zdev_t* dev, zbuf_t* buf)
|
||||||
/* Get offset of first element */
|
/* Get offset of first element */
|
||||||
subType = (zmw_rx_buf_readb(dev, buf, 0) >> 4);
|
subType = (zmw_rx_buf_readb(dev, buf, 0) >> 4);
|
||||||
|
|
||||||
if ((offset = zgElementOffsetTable[subType]) == 0xff)
|
offset = zgElementOffsetTable[subType];
|
||||||
|
if (offset == 0xff)
|
||||||
{
|
{
|
||||||
zm_assert(0);
|
zm_assert(0);
|
||||||
}
|
}
|
||||||
|
@ -1898,10 +1926,12 @@ u16_t zfFindBrdcmMrvlRlnkExtCap(zdev_t* dev, zbuf_t* buf)
|
||||||
while ((offset+2)<bufLen) // including element ID and length (2bytes)
|
while ((offset+2)<bufLen) // including element ID and length (2bytes)
|
||||||
{
|
{
|
||||||
/* Search target element */
|
/* Search target element */
|
||||||
if ((id = zmw_rx_buf_readb(dev, buf, offset)) == ZM_WLAN_EID_WIFI_IE)
|
id = zmw_rx_buf_readb(dev, buf, offset);
|
||||||
|
if (id == ZM_WLAN_EID_WIFI_IE)
|
||||||
{
|
{
|
||||||
/* Bingo */
|
/* Bingo */
|
||||||
if ((elen = zmw_rx_buf_readb(dev, buf, offset+1))>(bufLen - offset))
|
elen = zmw_rx_buf_readb(dev, buf, offset+1);
|
||||||
|
if (elen > bufLen - offset)
|
||||||
{
|
{
|
||||||
/* Element length error */
|
/* Element length error */
|
||||||
return 0xffff;
|
return 0xffff;
|
||||||
|
@ -1930,7 +1960,8 @@ u16_t zfFindBrdcmMrvlRlnkExtCap(zdev_t* dev, zbuf_t* buf)
|
||||||
else if ((id = zmw_rx_buf_readb(dev, buf, offset)) == 0x7F)
|
else if ((id = zmw_rx_buf_readb(dev, buf, offset)) == 0x7F)
|
||||||
{
|
{
|
||||||
/* Bingo */
|
/* Bingo */
|
||||||
if ((elen = zmw_rx_buf_readb(dev, buf, offset+1))>(bufLen - offset))
|
elen = zmw_rx_buf_readb(dev, buf, offset+1);
|
||||||
|
if (elen > bufLen - offset)
|
||||||
{
|
{
|
||||||
/* Element length error */
|
/* Element length error */
|
||||||
return 0xffff;
|
return 0xffff;
|
||||||
|
@ -1941,7 +1972,8 @@ u16_t zfFindBrdcmMrvlRlnkExtCap(zdev_t* dev, zbuf_t* buf)
|
||||||
return 0xffff;
|
return 0xffff;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((tmp = zmw_rx_buf_readb(dev, buf, offset+2)) == 0x01)
|
tmp = zmw_rx_buf_readb(dev, buf, offset+2);
|
||||||
|
if (tmp == 0x01)
|
||||||
|
|
||||||
{
|
{
|
||||||
return offset;
|
return offset;
|
||||||
|
@ -1949,7 +1981,8 @@ u16_t zfFindBrdcmMrvlRlnkExtCap(zdev_t* dev, zbuf_t* buf)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Advance to next element */
|
/* Advance to next element */
|
||||||
if ((elen = zmw_rx_buf_readb(dev, buf, offset+1)) == 0)
|
elen = zmw_rx_buf_readb(dev, buf, offset+1);
|
||||||
|
if (elen == 0)
|
||||||
{
|
{
|
||||||
return 0xffff;
|
return 0xffff;
|
||||||
}
|
}
|
||||||
|
@ -1970,7 +2003,8 @@ u16_t zfFindMarvelExtCap(zdev_t* dev, zbuf_t* buf)
|
||||||
/* Get offset of first element */
|
/* Get offset of first element */
|
||||||
subType = (zmw_rx_buf_readb(dev, buf, 0) >> 4);
|
subType = (zmw_rx_buf_readb(dev, buf, 0) >> 4);
|
||||||
|
|
||||||
if ((offset = zgElementOffsetTable[subType]) == 0xff)
|
offset = zgElementOffsetTable[subType];
|
||||||
|
if (offset == 0xff)
|
||||||
{
|
{
|
||||||
zm_assert(0);
|
zm_assert(0);
|
||||||
}
|
}
|
||||||
|
@ -1984,10 +2018,12 @@ u16_t zfFindMarvelExtCap(zdev_t* dev, zbuf_t* buf)
|
||||||
while ((offset+2)<bufLen) // including element ID and length (2bytes)
|
while ((offset+2)<bufLen) // including element ID and length (2bytes)
|
||||||
{
|
{
|
||||||
/* Search target element */
|
/* Search target element */
|
||||||
if ((id = zmw_rx_buf_readb(dev, buf, offset)) == ZM_WLAN_EID_WIFI_IE)
|
id = zmw_rx_buf_readb(dev, buf, offset);
|
||||||
|
if (id == ZM_WLAN_EID_WIFI_IE)
|
||||||
{
|
{
|
||||||
/* Bingo */
|
/* Bingo */
|
||||||
if ((elen = zmw_rx_buf_readb(dev, buf, offset+1))>(bufLen - offset))
|
elen = zmw_rx_buf_readb(dev, buf, offset+1);
|
||||||
|
if (elen>(bufLen - offset))
|
||||||
{
|
{
|
||||||
/* Element length error */
|
/* Element length error */
|
||||||
return 0xffff;
|
return 0xffff;
|
||||||
|
@ -2008,7 +2044,8 @@ u16_t zfFindMarvelExtCap(zdev_t* dev, zbuf_t* buf)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Advance to next element */
|
/* Advance to next element */
|
||||||
if ((elen = zmw_rx_buf_readb(dev, buf, offset+1)) == 0)
|
elen = zmw_rx_buf_readb(dev, buf, offset+1);
|
||||||
|
if (elen == 0)
|
||||||
{
|
{
|
||||||
return 0xffff;
|
return 0xffff;
|
||||||
}
|
}
|
||||||
|
@ -2029,7 +2066,8 @@ u16_t zfFindBroadcomExtCap(zdev_t* dev, zbuf_t* buf)
|
||||||
/* Get offset of first element */
|
/* Get offset of first element */
|
||||||
subType = (zmw_rx_buf_readb(dev, buf, 0) >> 4);
|
subType = (zmw_rx_buf_readb(dev, buf, 0) >> 4);
|
||||||
|
|
||||||
if ((offset = zgElementOffsetTable[subType]) == 0xff)
|
offset = zgElementOffsetTable[subType];
|
||||||
|
if (offset == 0xff)
|
||||||
{
|
{
|
||||||
zm_assert(0);
|
zm_assert(0);
|
||||||
}
|
}
|
||||||
|
@ -2043,10 +2081,12 @@ u16_t zfFindBroadcomExtCap(zdev_t* dev, zbuf_t* buf)
|
||||||
while((offset+2) < bufLen) // including element ID and length (2bytes)
|
while((offset+2) < bufLen) // including element ID and length (2bytes)
|
||||||
{
|
{
|
||||||
/* Search target element */
|
/* Search target element */
|
||||||
if ((id = zmw_rx_buf_readb(dev, buf, offset)) == ZM_WLAN_EID_WIFI_IE)
|
id = zmw_rx_buf_readb(dev, buf, offset);
|
||||||
|
if (id == ZM_WLAN_EID_WIFI_IE)
|
||||||
{
|
{
|
||||||
/* Bingo */
|
/* Bingo */
|
||||||
if ((elen = zmw_rx_buf_readb(dev, buf, offset+1)) > (bufLen - offset))
|
elen = zmw_rx_buf_readb(dev, buf, offset+1);
|
||||||
|
if (elen > (bufLen - offset))
|
||||||
{
|
{
|
||||||
/* Element length error */
|
/* Element length error */
|
||||||
return 0xffff;
|
return 0xffff;
|
||||||
|
@ -2066,7 +2106,8 @@ u16_t zfFindBroadcomExtCap(zdev_t* dev, zbuf_t* buf)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Advance to next element */
|
/* Advance to next element */
|
||||||
if ((elen = zmw_rx_buf_readb(dev, buf, offset+1)) == 0)
|
elen = zmw_rx_buf_readb(dev, buf, offset+1);
|
||||||
|
if (elen == 0)
|
||||||
{
|
{
|
||||||
return 0xffff;
|
return 0xffff;
|
||||||
}
|
}
|
||||||
|
@ -2089,7 +2130,8 @@ u16_t zfFindRlnkExtCap(zdev_t* dev, zbuf_t* buf)
|
||||||
/* Get offset of first element */
|
/* Get offset of first element */
|
||||||
subType = (zmw_rx_buf_readb(dev, buf, 0) >> 4);
|
subType = (zmw_rx_buf_readb(dev, buf, 0) >> 4);
|
||||||
|
|
||||||
if ((offset = zgElementOffsetTable[subType]) == 0xff)
|
offset = zgElementOffsetTable[subType];
|
||||||
|
if (offset == 0xff)
|
||||||
{
|
{
|
||||||
zm_assert(0);
|
zm_assert(0);
|
||||||
}
|
}
|
||||||
|
@ -2103,10 +2145,12 @@ u16_t zfFindRlnkExtCap(zdev_t* dev, zbuf_t* buf)
|
||||||
while((offset+2) < bufLen) // including element ID and length (2bytes)
|
while((offset+2) < bufLen) // including element ID and length (2bytes)
|
||||||
{
|
{
|
||||||
/* Search target element */
|
/* Search target element */
|
||||||
if ((id = zmw_rx_buf_readb(dev, buf, offset)) == 0x7F)
|
id = zmw_rx_buf_readb(dev, buf, offset);
|
||||||
|
if (id == 0x7F)
|
||||||
{
|
{
|
||||||
/* Bingo */
|
/* Bingo */
|
||||||
if ((elen = zmw_rx_buf_readb(dev, buf, offset+1)) > (bufLen - offset))
|
elen = zmw_rx_buf_readb(dev, buf, offset+1);
|
||||||
|
if (elen > bufLen - offset)
|
||||||
{
|
{
|
||||||
/* Element length error */
|
/* Element length error */
|
||||||
return 0xffff;
|
return 0xffff;
|
||||||
|
@ -2117,7 +2161,8 @@ u16_t zfFindRlnkExtCap(zdev_t* dev, zbuf_t* buf)
|
||||||
return 0xffff;
|
return 0xffff;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((tmp = zmw_rx_buf_readb(dev, buf, offset+2)) == 0x01)
|
tmp = zmw_rx_buf_readb(dev, buf, offset+2);
|
||||||
|
if (tmp == 0x01)
|
||||||
|
|
||||||
{
|
{
|
||||||
return offset;
|
return offset;
|
||||||
|
@ -2125,7 +2170,8 @@ u16_t zfFindRlnkExtCap(zdev_t* dev, zbuf_t* buf)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Advance to next element */
|
/* Advance to next element */
|
||||||
if ((elen = zmw_rx_buf_readb(dev, buf, offset+1)) == 0)
|
elen = zmw_rx_buf_readb(dev, buf, offset+1);
|
||||||
|
if (elen == 0)
|
||||||
{
|
{
|
||||||
return 0xffff;
|
return 0xffff;
|
||||||
}
|
}
|
||||||
|
|
|
@ -141,7 +141,8 @@ u16_t zfApGetSTAInfo(zdev_t* dev, u16_t* addr, u16_t* state, u8_t* vap)
|
||||||
|
|
||||||
zmw_enter_critical_section(dev);
|
zmw_enter_critical_section(dev);
|
||||||
|
|
||||||
if ((id = zfApFindSta(dev, addr)) != 0xffff)
|
id = zfApFindSta(dev, addr);
|
||||||
|
if (id != 0xffff)
|
||||||
{
|
{
|
||||||
*vap = wd->ap.staTable[id].vap;
|
*vap = wd->ap.staTable[id].vap;
|
||||||
*state = wd->ap.staTable[id++].state;
|
*state = wd->ap.staTable[id++].state;
|
||||||
|
@ -163,7 +164,8 @@ void zfApGetStaQosType(zdev_t* dev, u16_t* addr, u8_t* qosType)
|
||||||
|
|
||||||
zmw_enter_critical_section(dev);
|
zmw_enter_critical_section(dev);
|
||||||
|
|
||||||
if ((id = zfApFindSta(dev, addr)) != 0xffff)
|
id = zfApFindSta(dev, addr);
|
||||||
|
if (id != 0xffff)
|
||||||
{
|
{
|
||||||
*qosType = wd->ap.staTable[id].qosType;
|
*qosType = wd->ap.staTable[id].qosType;
|
||||||
}
|
}
|
||||||
|
@ -189,7 +191,8 @@ void zfApGetStaTxRateAndQosType(zdev_t* dev, u16_t* addr, u32_t* phyCtrl,
|
||||||
|
|
||||||
zmw_enter_critical_section(dev);
|
zmw_enter_critical_section(dev);
|
||||||
|
|
||||||
if ((id = zfApFindSta(dev, addr)) != 0xffff)
|
id = zfApFindSta(dev, addr);
|
||||||
|
if (id != 0xffff)
|
||||||
{
|
{
|
||||||
rate = (u8_t)zfRateCtrlGetTxRate(dev, &wd->ap.staTable[id].rcCell, rcProbingFlag);
|
rate = (u8_t)zfRateCtrlGetTxRate(dev, &wd->ap.staTable[id].rcCell, rcProbingFlag);
|
||||||
#ifdef ZM_AP_DEBUG
|
#ifdef ZM_AP_DEBUG
|
||||||
|
@ -234,7 +237,8 @@ void zfApGetStaEncryType(zdev_t* dev, u16_t* addr, u8_t* encryType)
|
||||||
|
|
||||||
zmw_enter_critical_section(dev);
|
zmw_enter_critical_section(dev);
|
||||||
|
|
||||||
if ((id = zfApFindSta(dev, addr)) != 0xffff)
|
id = zfApFindSta(dev, addr);
|
||||||
|
if (id != 0xffff)
|
||||||
{
|
{
|
||||||
*encryType = wd->ap.staTable[id].encryMode;
|
*encryType = wd->ap.staTable[id].encryMode;
|
||||||
}
|
}
|
||||||
|
@ -260,7 +264,8 @@ void zfApGetStaWpaIv(zdev_t* dev, u16_t* addr, u16_t* iv16, u32_t* iv32)
|
||||||
|
|
||||||
zmw_enter_critical_section(dev);
|
zmw_enter_critical_section(dev);
|
||||||
|
|
||||||
if ((id = zfApFindSta(dev, addr)) != 0xffff)
|
id = zfApFindSta(dev, addr);
|
||||||
|
if (id != 0xffff)
|
||||||
{
|
{
|
||||||
*iv16 = wd->ap.staTable[id].iv16;
|
*iv16 = wd->ap.staTable[id].iv16;
|
||||||
*iv32 = wd->ap.staTable[id].iv32;
|
*iv32 = wd->ap.staTable[id].iv32;
|
||||||
|
@ -289,7 +294,8 @@ void zfApSetStaWpaIv(zdev_t* dev, u16_t* addr, u16_t iv16, u32_t iv32)
|
||||||
|
|
||||||
zmw_enter_critical_section(dev);
|
zmw_enter_critical_section(dev);
|
||||||
|
|
||||||
if ((id = zfApFindSta(dev, addr)) != 0xffff)
|
id = zfApFindSta(dev, addr);
|
||||||
|
if (id != 0xffff)
|
||||||
{
|
{
|
||||||
wd->ap.staTable[id].iv16 = iv16;
|
wd->ap.staTable[id].iv16 = iv16;
|
||||||
wd->ap.staTable[id].iv32 = iv32;
|
wd->ap.staTable[id].iv32 = iv32;
|
||||||
|
@ -321,7 +327,8 @@ void zfApClearStaKey(zdev_t* dev, u16_t* addr)
|
||||||
|
|
||||||
zmw_enter_critical_section(dev);
|
zmw_enter_critical_section(dev);
|
||||||
|
|
||||||
if ((id = zfApFindSta(dev, addr)) != 0xffff)
|
id = zfApFindSta(dev, addr);
|
||||||
|
if (id != 0xffff)
|
||||||
{
|
{
|
||||||
/* Turn off STA's key information */
|
/* Turn off STA's key information */
|
||||||
zfHpRemoveKey(dev, id+1);
|
zfHpRemoveKey(dev, id+1);
|
||||||
|
@ -348,7 +355,8 @@ void zfApGetStaCencIvAndKeyIdx(zdev_t* dev, u16_t* addr, u32_t *iv, u8_t *keyIdx
|
||||||
|
|
||||||
zmw_enter_critical_section(dev);
|
zmw_enter_critical_section(dev);
|
||||||
|
|
||||||
if ((id = zfApFindSta(dev, addr)) != 0xffff)
|
id = zfApFindSta(dev, addr);
|
||||||
|
if (id != 0xffff)
|
||||||
{
|
{
|
||||||
*iv++ = wd->ap.staTable[id].txiv[0];
|
*iv++ = wd->ap.staTable[id].txiv[0];
|
||||||
*iv++ = wd->ap.staTable[id].txiv[1];
|
*iv++ = wd->ap.staTable[id].txiv[1];
|
||||||
|
@ -379,7 +387,8 @@ void zfApSetStaCencIv(zdev_t* dev, u16_t* addr, u32_t *iv)
|
||||||
|
|
||||||
zmw_enter_critical_section(dev);
|
zmw_enter_critical_section(dev);
|
||||||
|
|
||||||
if ((id = zfApFindSta(dev, addr)) != 0xffff)
|
id = zfApFindSta(dev, addr);
|
||||||
|
if (id != 0xffff)
|
||||||
{
|
{
|
||||||
wd->ap.staTable[id].txiv[0] = *iv++;
|
wd->ap.staTable[id].txiv[0] = *iv++;
|
||||||
wd->ap.staTable[id].txiv[1] = *iv++;
|
wd->ap.staTable[id].txiv[1] = *iv++;
|
||||||
|
@ -539,7 +548,8 @@ u16_t zfApBufferPsFrame(zdev_t* dev, zbuf_t* buf, u16_t port)
|
||||||
{
|
{
|
||||||
zmw_enter_critical_section(dev);
|
zmw_enter_critical_section(dev);
|
||||||
|
|
||||||
if ((id = zfApFindSta(dev, addr)) != 0xffff)
|
id = zfApFindSta(dev, addr);
|
||||||
|
if (id != 0xffff)
|
||||||
{
|
{
|
||||||
if (wd->ap.staTable[id].psMode == 1)
|
if (wd->ap.staTable[id].psMode == 1)
|
||||||
{
|
{
|
||||||
|
@ -603,7 +613,8 @@ u16_t zfApGetSTAInfoAndUpdatePs(zdev_t* dev, u16_t* addr, u16_t* state,
|
||||||
//psMode=0;
|
//psMode=0;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if ((id = zfApFindSta(dev, addr)) != 0xffff)
|
id = zfApFindSta(dev, addr);
|
||||||
|
if (id != 0xffff)
|
||||||
{
|
{
|
||||||
if (psMode != 0)
|
if (psMode != 0)
|
||||||
{
|
{
|
||||||
|
@ -648,7 +659,8 @@ u16_t zfApGetSTAInfoAndUpdatePs(zdev_t* dev, u16_t* addr, u16_t* state,
|
||||||
|
|
||||||
while (1)
|
while (1)
|
||||||
{
|
{
|
||||||
if ((psBuf = zfQueueGetWithMac(dev, wd->ap.uapsdQ, (u8_t*)addr, &mb)) != NULL)
|
psBuf = zfQueueGetWithMac(dev, wd->ap.uapsdQ, (u8_t*)addr, &mb);
|
||||||
|
if (psBuf != NULL)
|
||||||
{
|
{
|
||||||
zfTxSendEth(dev, psBuf, 0, ZM_EXTERNAL_ALLOC_BUF, 0);
|
zfTxSendEth(dev, psBuf, 0, ZM_EXTERNAL_ALLOC_BUF, 0);
|
||||||
}
|
}
|
||||||
|
@ -730,7 +742,8 @@ u16_t zfApAddSta(zdev_t* dev, u16_t* addr, u16_t state, u16_t apId, u8_t type,
|
||||||
|
|
||||||
zmw_enter_critical_section(dev);
|
zmw_enter_critical_section(dev);
|
||||||
|
|
||||||
if ((index = zfApFindSta(dev, addr)) != 0xffff)
|
index = zfApFindSta(dev, addr);
|
||||||
|
if (index != 0xffff)
|
||||||
{
|
{
|
||||||
zm_msg0_mm(ZM_LV_2, "found");
|
zm_msg0_mm(ZM_LV_2, "found");
|
||||||
/* Update STA state */
|
/* Update STA state */
|
||||||
|
@ -963,7 +976,8 @@ void zfApProcessBeacon(zdev_t* dev, zbuf_t* buf)
|
||||||
zm_msg0_mm(ZM_LV_3, "Rx beacon");
|
zm_msg0_mm(ZM_LV_3, "Rx beacon");
|
||||||
|
|
||||||
/* update Non-ERP flag(wd->ap.nonErpObss) */
|
/* update Non-ERP flag(wd->ap.nonErpObss) */
|
||||||
if ((offset = zfFindElement(dev, buf, ZM_WLAN_EID_ERP)) == 0xffff)
|
offset = zfFindElement(dev, buf, ZM_WLAN_EID_ERP);
|
||||||
|
if (offset == 0xffff)
|
||||||
{
|
{
|
||||||
/* 11b OBSS */
|
/* 11b OBSS */
|
||||||
wd->ap.protectedObss++;
|
wd->ap.protectedObss++;
|
||||||
|
@ -1046,7 +1060,8 @@ void zfApProcessAuth(zdev_t* dev, zbuf_t* buf, u16_t* src, u16_t apId)
|
||||||
if (seq == 1)
|
if (seq == 1)
|
||||||
{
|
{
|
||||||
/* AP : update STA to auth */
|
/* AP : update STA to auth */
|
||||||
if ((ret = zfApAddSta(dev, src, ZM_STATE_AUTH, apId, 0, 0, 0)) != 0xffff)
|
ret = zfApAddSta(dev, src, ZM_STATE_AUTH, apId, 0, 0, 0);
|
||||||
|
if (ret != 0xffff)
|
||||||
{
|
{
|
||||||
/* AP : call zfwAuthNotify() for host to judge */
|
/* AP : call zfwAuthNotify() for host to judge */
|
||||||
//zfwAuthNotify(dev, src);
|
//zfwAuthNotify(dev, src);
|
||||||
|
@ -1177,12 +1192,14 @@ void zfApProcessAsocReq(zdev_t* dev, zbuf_t* buf, u16_t* src, u16_t apId)
|
||||||
|
|
||||||
zmw_get_wlan_dev(dev);
|
zmw_get_wlan_dev(dev);
|
||||||
/* AP : check SSID */
|
/* AP : check SSID */
|
||||||
if ((offset = zfFindElement(dev, buf, ZM_WLAN_EID_SSID)) != 0xffff)
|
offset = zfFindElement(dev, buf, ZM_WLAN_EID_SSID);
|
||||||
|
if (offset != 0xffff)
|
||||||
{
|
{
|
||||||
k = 0;
|
k = 0;
|
||||||
for (j = 0; j < wd->ap.vapNumber; j++)
|
for (j = 0; j < wd->ap.vapNumber; j++)
|
||||||
{
|
{
|
||||||
if ((tmp = zmw_buf_readb(dev, buf, offset+1))
|
tmp = zmw_buf_readb(dev, buf, offset+1);
|
||||||
|
if (tmp
|
||||||
!= wd->ap.ssidLen[j])
|
!= wd->ap.ssidLen[j])
|
||||||
{
|
{
|
||||||
k++;
|
k++;
|
||||||
|
@ -1198,7 +1215,8 @@ void zfApProcessAsocReq(zdev_t* dev, zbuf_t* buf, u16_t* src, u16_t apId)
|
||||||
{
|
{
|
||||||
for (i=0; i<wd->ap.ssidLen[j]; i++)
|
for (i=0; i<wd->ap.ssidLen[j]; i++)
|
||||||
{
|
{
|
||||||
if ((tmp = zmw_buf_readb(dev, buf, offset+2+i))
|
tmp = zmw_buf_readb(dev, buf, offset+2+i);
|
||||||
|
if (tmp
|
||||||
!= wd->ap.ssid[j][i])
|
!= wd->ap.ssid[j][i])
|
||||||
{
|
{
|
||||||
break;
|
break;
|
||||||
|
@ -1222,13 +1240,15 @@ void zfApProcessAsocReq(zdev_t* dev, zbuf_t* buf, u16_t* src, u16_t apId)
|
||||||
/* TODO : check capability */
|
/* TODO : check capability */
|
||||||
|
|
||||||
/* AP : check support rate */
|
/* AP : check support rate */
|
||||||
if ((offset = zfFindElement(dev, buf, ZM_WLAN_EID_EXTENDED_RATE)) != 0xffff)
|
offset = zfFindElement(dev, buf, ZM_WLAN_EID_EXTENDED_RATE);
|
||||||
|
if (offset != 0xffff)
|
||||||
{
|
{
|
||||||
/* 11g STA */
|
/* 11g STA */
|
||||||
staType = 1;
|
staType = 1;
|
||||||
}
|
}
|
||||||
//CWYang(+)
|
//CWYang(+)
|
||||||
if ((offset = zfFindElement(dev, buf, ZM_WLAN_EID_HT_CAPABILITY)) != 0xffff)
|
offset = zfFindElement(dev, buf, ZM_WLAN_EID_HT_CAPABILITY);
|
||||||
|
if (offset != 0xffff)
|
||||||
{
|
{
|
||||||
/* 11n STA */
|
/* 11n STA */
|
||||||
staType = 2;
|
staType = 2;
|
||||||
|
@ -1251,7 +1271,8 @@ void zfApProcessAsocReq(zdev_t* dev, zbuf_t* buf, u16_t* src, u16_t apId)
|
||||||
/* AP : check 11h */
|
/* AP : check 11h */
|
||||||
|
|
||||||
/* AP : check WME */
|
/* AP : check WME */
|
||||||
if ((offset = zfFindWifiElement(dev, buf, 2, 0)) != 0xffff)
|
offset = zfFindWifiElement(dev, buf, 2, 0);
|
||||||
|
if (offset != 0xffff)
|
||||||
{
|
{
|
||||||
/* WME STA */
|
/* WME STA */
|
||||||
qosType = 1;
|
qosType = 1;
|
||||||
|
@ -1265,7 +1286,8 @@ void zfApProcessAsocReq(zdev_t* dev, zbuf_t* buf, u16_t* src, u16_t apId)
|
||||||
|
|
||||||
if (wd->ap.wpaSupport[apId] == 1)
|
if (wd->ap.wpaSupport[apId] == 1)
|
||||||
{
|
{
|
||||||
if ( (offset = zfFindElement(dev, buf, ZM_WLAN_EID_WPA_IE)) != 0xffff )
|
offset = zfFindElement(dev, buf, ZM_WLAN_EID_WPA_IE);
|
||||||
|
if (offset != 0xffff)
|
||||||
{
|
{
|
||||||
/* get WPA IE */
|
/* get WPA IE */
|
||||||
u8_t length = zmw_rx_buf_readb(dev, buf, offset+1);
|
u8_t length = zmw_rx_buf_readb(dev, buf, offset+1);
|
||||||
|
@ -1406,12 +1428,14 @@ void zfApStoreAsocReqIe(zdev_t* dev, zbuf_t* buf, u16_t aid)
|
||||||
offset = 28;
|
offset = 28;
|
||||||
|
|
||||||
/* supported rates */
|
/* supported rates */
|
||||||
if ((offset = zfFindElement(dev, buf, ZM_WLAN_EID_SUPPORT_RATE)) == 0xffff)
|
offset = zfFindElement(dev, buf, ZM_WLAN_EID_SUPPORT_RATE);
|
||||||
|
if (offset == 0xffff)
|
||||||
return;
|
return;
|
||||||
length = zmw_rx_buf_readb(dev, buf, offset + 1);
|
length = zmw_rx_buf_readb(dev, buf, offset + 1);
|
||||||
|
|
||||||
/* extended supported rates */
|
/* extended supported rates */
|
||||||
if ((offset = zfFindElement(dev, buf, ZM_WLAN_EID_EXTENDED_RATE)) == 0xffff)
|
offset = zfFindElement(dev, buf, ZM_WLAN_EID_EXTENDED_RATE);
|
||||||
|
if (offset == 0xffff)
|
||||||
return;
|
return;
|
||||||
length = zmw_rx_buf_readb(dev, buf, offset + 1);
|
length = zmw_rx_buf_readb(dev, buf, offset + 1);
|
||||||
|
|
||||||
|
@ -1426,7 +1450,8 @@ void zfApStoreAsocReqIe(zdev_t* dev, zbuf_t* buf, u16_t aid)
|
||||||
/* QoS */
|
/* QoS */
|
||||||
|
|
||||||
/* HT capabilities: 28 octets */
|
/* HT capabilities: 28 octets */
|
||||||
if ((offset = zfFindElement(dev, buf, ZM_WLAN_EID_HT_CAPABILITY)) != 0xffff) {
|
offset = zfFindElement(dev, buf, ZM_WLAN_EID_HT_CAPABILITY);
|
||||||
|
if (offset != 0xffff) {
|
||||||
/* atheros pre n */
|
/* atheros pre n */
|
||||||
htcap = (u8_t *)&wd->ap.ie[aid].HtCap;
|
htcap = (u8_t *)&wd->ap.ie[aid].HtCap;
|
||||||
htcap[0] = zmw_rx_buf_readb(dev, buf, offset);
|
htcap[0] = zmw_rx_buf_readb(dev, buf, offset);
|
||||||
|
@ -1479,7 +1504,8 @@ void zfApProcessDeauth(zdev_t* dev, zbuf_t* buf, u16_t* src, u16_t apId)
|
||||||
|
|
||||||
zmw_enter_critical_section(dev);
|
zmw_enter_critical_section(dev);
|
||||||
/* AP : if SA=associated STA then deauthenticate STA */
|
/* AP : if SA=associated STA then deauthenticate STA */
|
||||||
if ((aid = zfApFindSta(dev, src)) != 0xffff)
|
aid = zfApFindSta(dev, src);
|
||||||
|
if (aid != 0xffff)
|
||||||
{
|
{
|
||||||
/* Clear STA table */
|
/* Clear STA table */
|
||||||
wd->ap.staTable[aid].valid = 0;
|
wd->ap.staTable[aid].valid = 0;
|
||||||
|
@ -1500,7 +1526,8 @@ void zfApProcessDisasoc(zdev_t* dev, zbuf_t* buf, u16_t* src, u16_t apId)
|
||||||
|
|
||||||
zmw_enter_critical_section(dev);
|
zmw_enter_critical_section(dev);
|
||||||
/* AP : if SA=associated STA then deauthenticate STA */
|
/* AP : if SA=associated STA then deauthenticate STA */
|
||||||
if ((aid = zfApFindSta(dev, src)) != 0xffff)
|
aid = zfApFindSta(dev, src);
|
||||||
|
if (aid != 0xffff)
|
||||||
{
|
{
|
||||||
/* Clear STA table */
|
/* Clear STA table */
|
||||||
wd->ap.staTable[aid].valid = 0;
|
wd->ap.staTable[aid].valid = 0;
|
||||||
|
@ -1674,7 +1701,8 @@ u16_t zfApAddIeTim(zdev_t* dev, zbuf_t* buf, u16_t offset, u16_t vap)
|
||||||
dst[0] = zmw_tx_buf_readh(dev, psBuf, 0);
|
dst[0] = zmw_tx_buf_readh(dev, psBuf, 0);
|
||||||
dst[1] = zmw_tx_buf_readh(dev, psBuf, 2);
|
dst[1] = zmw_tx_buf_readh(dev, psBuf, 2);
|
||||||
dst[2] = zmw_tx_buf_readh(dev, psBuf, 4);
|
dst[2] = zmw_tx_buf_readh(dev, psBuf, 4);
|
||||||
if ((aid = zfApFindSta(dev, dst)) != 0xffff)
|
aid = zfApFindSta(dev, dst);
|
||||||
|
if (aid != 0xffff)
|
||||||
{
|
{
|
||||||
if (wd->ap.staTable[aid].psMode != 0)
|
if (wd->ap.staTable[aid].psMode != 0)
|
||||||
{
|
{
|
||||||
|
@ -1896,7 +1924,8 @@ void zfApSendBeacon(zdev_t* dev)
|
||||||
zm_msg1_mm(ZM_LV_2, "Send beacon, vap=", vap);
|
zm_msg1_mm(ZM_LV_2, "Send beacon, vap=", vap);
|
||||||
|
|
||||||
/* TBD : Maximum size of beacon */
|
/* TBD : Maximum size of beacon */
|
||||||
if ((buf = zfwBufAllocate(dev, 1024)) == NULL)
|
buf = zfwBufAllocate(dev, 1024);
|
||||||
|
if (buf == NULL)
|
||||||
{
|
{
|
||||||
zm_msg0_mm(ZM_LV_0, "Alloc beacon buf Fail!");
|
zm_msg0_mm(ZM_LV_0, "Alloc beacon buf Fail!");
|
||||||
return;
|
return;
|
||||||
|
@ -2101,8 +2130,8 @@ u16_t zfIntrabssForward(zdev_t* dev, zbuf_t* buf, u8_t srcVap)
|
||||||
if ((asocFlag == 1) || ((dst[0]&0x1) == 0x1))
|
if ((asocFlag == 1) || ((dst[0]&0x1) == 0x1))
|
||||||
{
|
{
|
||||||
/* Allocate frame */
|
/* Allocate frame */
|
||||||
if ((txBuf = zfwBufAllocate(dev, ZM_RX_FRAME_SIZE))
|
txBuf = zfwBufAllocate(dev, ZM_RX_FRAME_SIZE);
|
||||||
== NULL)
|
if (txBuf == NULL)
|
||||||
{
|
{
|
||||||
zm_msg0_rx(ZM_LV_1, "Alloc intra-bss buf Fail!");
|
zm_msg0_rx(ZM_LV_1, "Alloc intra-bss buf Fail!");
|
||||||
goto zlAllocError;
|
goto zlAllocError;
|
||||||
|
@ -2133,7 +2162,8 @@ u16_t zfIntrabssForward(zdev_t* dev, zbuf_t* buf, u8_t srcVap)
|
||||||
|
|
||||||
/* Transmit frame */
|
/* Transmit frame */
|
||||||
/* Return error if port is disabled */
|
/* Return error if port is disabled */
|
||||||
if ((err = zfTxPortControl(dev, txBuf, vap)) == ZM_PORT_DISABLED)
|
err = zfTxPortControl(dev, txBuf, vap);
|
||||||
|
if (err == ZM_PORT_DISABLED)
|
||||||
{
|
{
|
||||||
err = ZM_ERR_TX_PORT_DISABLED;
|
err = ZM_ERR_TX_PORT_DISABLED;
|
||||||
goto zlTxError;
|
goto zlTxError;
|
||||||
|
@ -2141,7 +2171,8 @@ u16_t zfIntrabssForward(zdev_t* dev, zbuf_t* buf, u8_t srcVap)
|
||||||
|
|
||||||
#if 1
|
#if 1
|
||||||
/* AP : Buffer frame for power saving STA */
|
/* AP : Buffer frame for power saving STA */
|
||||||
if ((ret = zfApBufferPsFrame(dev, txBuf, vap)) == 0)
|
ret = zfApBufferPsFrame(dev, txBuf, vap);
|
||||||
|
if (ret == 0)
|
||||||
{
|
{
|
||||||
/* forward frame if not been buffered */
|
/* forward frame if not been buffered */
|
||||||
#if 1
|
#if 1
|
||||||
|
@ -2177,7 +2208,8 @@ struct zsMicVar* zfApGetRxMicKey(zdev_t* dev, zbuf_t* buf)
|
||||||
macAddr[1] = sa[2] + (sa[3] << 8);
|
macAddr[1] = sa[2] + (sa[3] << 8);
|
||||||
macAddr[2] = sa[4] + (sa[5] << 8);
|
macAddr[2] = sa[4] + (sa[5] << 8);
|
||||||
|
|
||||||
if ((id = zfApFindSta(dev, macAddr)) != 0xffff)
|
id = zfApFindSta(dev, macAddr);
|
||||||
|
if (id != 0xffff)
|
||||||
return (&wd->ap.staTable[id].rxMicKey);
|
return (&wd->ap.staTable[id].rxMicKey);
|
||||||
|
|
||||||
return NULL;
|
return NULL;
|
||||||
|
@ -2369,7 +2401,8 @@ void zfApSendFailure(zdev_t* dev, u8_t* addr)
|
||||||
staAddr[1] = addr[2] + (((u16_t)addr[3])<<8);
|
staAddr[1] = addr[2] + (((u16_t)addr[3])<<8);
|
||||||
staAddr[2] = addr[4] + (((u16_t)addr[5])<<8);
|
staAddr[2] = addr[4] + (((u16_t)addr[5])<<8);
|
||||||
zmw_enter_critical_section(dev);
|
zmw_enter_critical_section(dev);
|
||||||
if ((id = zfApFindSta(dev, staAddr)) != 0xffff)
|
id = zfApFindSta(dev, staAddr);
|
||||||
|
if (id != 0xffff)
|
||||||
{
|
{
|
||||||
/* Send failture : Add 3 minutes to inactive time that will */
|
/* Send failture : Add 3 minutes to inactive time that will */
|
||||||
/* will make STA been kicked out soon */
|
/* will make STA been kicked out soon */
|
||||||
|
|
|
@ -602,7 +602,8 @@ void zfStaProtErpMonitor(zdev_t* dev, zbuf_t* buf)
|
||||||
|
|
||||||
if (zfRxBufferEqualToStr(dev, buf, bssid, ZM_WLAN_HEADER_A2_OFFSET, 6))
|
if (zfRxBufferEqualToStr(dev, buf, bssid, ZM_WLAN_HEADER_A2_OFFSET, 6))
|
||||||
{
|
{
|
||||||
if ( (offset=zfFindElement(dev, buf, ZM_WLAN_EID_ERP)) != 0xffff )
|
offset = zfFindElement(dev, buf, ZM_WLAN_EID_ERP);
|
||||||
|
if (offset != 0xffff)
|
||||||
{
|
{
|
||||||
erp = zmw_rx_buf_readb(dev, buf, offset+2);
|
erp = zmw_rx_buf_readb(dev, buf, offset+2);
|
||||||
|
|
||||||
|
@ -628,7 +629,8 @@ void zfStaProtErpMonitor(zdev_t* dev, zbuf_t* buf)
|
||||||
}
|
}
|
||||||
//Check the existence of Non-N AP
|
//Check the existence of Non-N AP
|
||||||
//Follow the check the "pBssInfo->EnableHT"
|
//Follow the check the "pBssInfo->EnableHT"
|
||||||
if ((offset = zfFindElement(dev, buf, ZM_WLAN_EID_HT_CAPABILITY)) != 0xffff)
|
offset = zfFindElement(dev, buf, ZM_WLAN_EID_HT_CAPABILITY);
|
||||||
|
if (offset != 0xffff)
|
||||||
{}
|
{}
|
||||||
else if ((offset = zfFindElement(dev, buf, ZM_WLAN_PREN2_EID_HTCAPABILITY)) != 0xffff)
|
else if ((offset = zfFindElement(dev, buf, ZM_WLAN_PREN2_EID_HTCAPABILITY)) != 0xffff)
|
||||||
{}
|
{}
|
||||||
|
@ -658,9 +660,11 @@ void zfStaUpdateWmeParameter(zdev_t* dev, zbuf_t* buf)
|
||||||
if (wd->sta.wmeConnected != 0)
|
if (wd->sta.wmeConnected != 0)
|
||||||
{
|
{
|
||||||
/* Find WME parameter element */
|
/* Find WME parameter element */
|
||||||
if ((offset = zfFindWifiElement(dev, buf, 2, 1)) != 0xffff)
|
offset = zfFindWifiElement(dev, buf, 2, 1);
|
||||||
|
if (offset != 0xffff)
|
||||||
{
|
{
|
||||||
if ((len = zmw_rx_buf_readb(dev, buf, offset+1)) >= 7)
|
len = zmw_rx_buf_readb(dev, buf, offset+1);
|
||||||
|
if (len >= 7)
|
||||||
{
|
{
|
||||||
rxWmeParameterSetCount=zmw_rx_buf_readb(dev, buf, offset+8);
|
rxWmeParameterSetCount=zmw_rx_buf_readb(dev, buf, offset+8);
|
||||||
if (rxWmeParameterSetCount != wd->sta.wmeParameterSetCount)
|
if (rxWmeParameterSetCount != wd->sta.wmeParameterSetCount)
|
||||||
|
@ -741,7 +745,8 @@ void zfStaUpdateDot11HDFS(zdev_t* dev, zbuf_t* buf)
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* get EID(Channel Switch Announcement) */
|
/* get EID(Channel Switch Announcement) */
|
||||||
if ( (offset = zfFindElement(dev, buf, ZM_WLAN_EID_CHANNEL_SWITCH_ANNOUNCE)) == 0xffff )
|
offset = zfFindElement(dev, buf, ZM_WLAN_EID_CHANNEL_SWITCH_ANNOUNCE);
|
||||||
|
if (offset == 0xffff)
|
||||||
{
|
{
|
||||||
//zm_debug_msg0("EID(Channel Switch Announcement) not found");
|
//zm_debug_msg0("EID(Channel Switch Announcement) not found");
|
||||||
return;
|
return;
|
||||||
|
@ -1216,7 +1221,8 @@ void zfStaSendBeacon(zdev_t* dev)
|
||||||
//zm_debug_msg0("\n");
|
//zm_debug_msg0("\n");
|
||||||
|
|
||||||
/* TBD : Maximum size of beacon */
|
/* TBD : Maximum size of beacon */
|
||||||
if ((buf = zfwBufAllocate(dev, 1024)) == NULL)
|
buf = zfwBufAllocate(dev, 1024);
|
||||||
|
if (buf == NULL)
|
||||||
{
|
{
|
||||||
zm_debug_msg0("Allocate beacon buffer failed");
|
zm_debug_msg0("Allocate beacon buffer failed");
|
||||||
return;
|
return;
|
||||||
|
@ -1370,7 +1376,8 @@ struct zsBssInfo* zfStaFindBssInfo(zdev_t* dev, zbuf_t* buf, struct zsWlanProbeR
|
||||||
|
|
||||||
zmw_get_wlan_dev(dev);
|
zmw_get_wlan_dev(dev);
|
||||||
|
|
||||||
if ((pBssInfo = wd->sta.bssList.head) == NULL)
|
pBssInfo = wd->sta.bssList.head;
|
||||||
|
if (pBssInfo == NULL)
|
||||||
{
|
{
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
@ -1420,8 +1427,10 @@ struct zsBssInfo* zfStaFindBssInfo(zdev_t* dev, zbuf_t* buf, struct zsWlanProbeR
|
||||||
/* Check channel */
|
/* Check channel */
|
||||||
/* Add check channel to solve the bug #31222 */
|
/* Add check channel to solve the bug #31222 */
|
||||||
if (isMatched) {
|
if (isMatched) {
|
||||||
if ((offset = zfFindElement(dev, buf, ZM_WLAN_EID_DS)) != 0xffff) {
|
offset = zfFindElement(dev, buf, ZM_WLAN_EID_DS);
|
||||||
if ((length = zmw_rx_buf_readb(dev, buf, offset+1)) == 1) {
|
if (offset != 0xffff) {
|
||||||
|
length = zmw_rx_buf_readb(dev, buf, offset+1);
|
||||||
|
if (length == 1) {
|
||||||
channel = zmw_rx_buf_readb(dev, buf, offset+2);
|
channel = zmw_rx_buf_readb(dev, buf, offset+2);
|
||||||
if (zfHpIsAllowedChannel(dev, zfChNumToFreq(dev, channel, 0)) == 0) {
|
if (zfHpIsAllowedChannel(dev, zfChNumToFreq(dev, channel, 0)) == 0) {
|
||||||
frequency = 0;
|
frequency = 0;
|
||||||
|
@ -1473,7 +1482,8 @@ u8_t zfStaInitBssInfo(zdev_t* dev, zbuf_t* buf,
|
||||||
}
|
}
|
||||||
|
|
||||||
/* get SSID */
|
/* get SSID */
|
||||||
if ( (offset = zfFindElement(dev, buf, ZM_WLAN_EID_SSID)) == 0xffff )
|
offset = zfFindElement(dev, buf, ZM_WLAN_EID_SSID);
|
||||||
|
if (offset == 0xffff)
|
||||||
{
|
{
|
||||||
zm_debug_msg0("EID(SSID) not found");
|
zm_debug_msg0("EID(SSID) not found");
|
||||||
goto zlError;
|
goto zlError;
|
||||||
|
@ -1506,7 +1516,8 @@ u8_t zfStaInitBssInfo(zdev_t* dev, zbuf_t* buf,
|
||||||
zfCopyFromRxBuffer(dev, buf, pBssInfo->ssid, offset, length+2);
|
zfCopyFromRxBuffer(dev, buf, pBssInfo->ssid, offset, length+2);
|
||||||
|
|
||||||
/* get DS parameter */
|
/* get DS parameter */
|
||||||
if ( (offset = zfFindElement(dev, buf, ZM_WLAN_EID_DS)) != 0xffff )
|
offset = zfFindElement(dev, buf, ZM_WLAN_EID_DS);
|
||||||
|
if (offset != 0xffff)
|
||||||
{
|
{
|
||||||
length = zmw_rx_buf_readb(dev, buf, offset+1);
|
length = zmw_rx_buf_readb(dev, buf, offset+1);
|
||||||
if ( length != 1 )
|
if ( length != 1 )
|
||||||
|
@ -1590,7 +1601,8 @@ u8_t zfStaInitBssInfo(zdev_t* dev, zbuf_t* buf,
|
||||||
pBssInfo->frameBodysize = accumulateLen;
|
pBssInfo->frameBodysize = accumulateLen;
|
||||||
|
|
||||||
/* get supported rates */
|
/* get supported rates */
|
||||||
if ( (offset = zfFindElement(dev, buf, ZM_WLAN_EID_SUPPORT_RATE)) == 0xffff )
|
offset = zfFindElement(dev, buf, ZM_WLAN_EID_SUPPORT_RATE);
|
||||||
|
if (offset == 0xffff)
|
||||||
{
|
{
|
||||||
zm_debug_msg0("EID(supported rates) not found");
|
zm_debug_msg0("EID(supported rates) not found");
|
||||||
goto zlError;
|
goto zlError;
|
||||||
|
@ -1607,7 +1619,8 @@ u8_t zfStaInitBssInfo(zdev_t* dev, zbuf_t* buf,
|
||||||
|
|
||||||
|
|
||||||
/* get Country information */
|
/* get Country information */
|
||||||
if ( (offset = zfFindElement(dev, buf, ZM_WLAN_EID_COUNTRY)) != 0xffff )
|
offset = zfFindElement(dev, buf, ZM_WLAN_EID_COUNTRY);
|
||||||
|
if (offset != 0xffff)
|
||||||
{
|
{
|
||||||
length = zmw_rx_buf_readb(dev, buf, offset+1);
|
length = zmw_rx_buf_readb(dev, buf, offset+1);
|
||||||
if (length > ZM_MAX_COUNTRY_INFO_SIZE)
|
if (length > ZM_MAX_COUNTRY_INFO_SIZE)
|
||||||
|
@ -1625,13 +1638,15 @@ u8_t zfStaInitBssInfo(zdev_t* dev, zbuf_t* buf,
|
||||||
}
|
}
|
||||||
|
|
||||||
/* get ERP information */
|
/* get ERP information */
|
||||||
if ( (offset = zfFindElement(dev, buf, ZM_WLAN_EID_ERP)) != 0xffff )
|
offset = zfFindElement(dev, buf, ZM_WLAN_EID_ERP);
|
||||||
|
if (offset != 0xffff)
|
||||||
{
|
{
|
||||||
pBssInfo->erp = zmw_rx_buf_readb(dev, buf, offset+2);
|
pBssInfo->erp = zmw_rx_buf_readb(dev, buf, offset+2);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* get extended supported rates */
|
/* get extended supported rates */
|
||||||
if ( (offset = zfFindElement(dev, buf, ZM_WLAN_EID_EXTENDED_RATE)) != 0xffff )
|
offset = zfFindElement(dev, buf, ZM_WLAN_EID_EXTENDED_RATE);
|
||||||
|
if (offset != 0xffff)
|
||||||
{
|
{
|
||||||
length = zmw_rx_buf_readb(dev, buf, offset+1);
|
length = zmw_rx_buf_readb(dev, buf, offset+1);
|
||||||
if (length > ZM_MAX_SUPP_RATES_IE_SIZE)
|
if (length > ZM_MAX_SUPP_RATES_IE_SIZE)
|
||||||
|
@ -1648,7 +1663,8 @@ u8_t zfStaInitBssInfo(zdev_t* dev, zbuf_t* buf,
|
||||||
}
|
}
|
||||||
|
|
||||||
/* get WPA IE */
|
/* get WPA IE */
|
||||||
if ( (offset = zfFindElement(dev, buf, ZM_WLAN_EID_WPA_IE)) != 0xffff )
|
offset = zfFindElement(dev, buf, ZM_WLAN_EID_WPA_IE);
|
||||||
|
if (offset != 0xffff)
|
||||||
{
|
{
|
||||||
length = zmw_rx_buf_readb(dev, buf, offset+1);
|
length = zmw_rx_buf_readb(dev, buf, offset+1);
|
||||||
if (length > ZM_MAX_IE_SIZE)
|
if (length > ZM_MAX_IE_SIZE)
|
||||||
|
@ -1664,7 +1680,8 @@ u8_t zfStaInitBssInfo(zdev_t* dev, zbuf_t* buf,
|
||||||
}
|
}
|
||||||
|
|
||||||
/* get WPS IE */
|
/* get WPS IE */
|
||||||
if ((offset = zfFindWifiElement(dev, buf, 4, 0xff)) != 0xffff)
|
offset = zfFindWifiElement(dev, buf, 4, 0xff);
|
||||||
|
if (offset != 0xffff)
|
||||||
{
|
{
|
||||||
length = zmw_rx_buf_readb(dev, buf, offset+1);
|
length = zmw_rx_buf_readb(dev, buf, offset+1);
|
||||||
if (length > ZM_MAX_WPS_IE_SIZE )
|
if (length > ZM_MAX_WPS_IE_SIZE )
|
||||||
|
@ -1679,19 +1696,22 @@ u8_t zfStaInitBssInfo(zdev_t* dev, zbuf_t* buf,
|
||||||
}
|
}
|
||||||
|
|
||||||
/* get SuperG IE */
|
/* get SuperG IE */
|
||||||
if ((offset = zfFindSuperGElement(dev, buf, ZM_WLAN_EID_VENDOR_PRIVATE)) != 0xffff)
|
offset = zfFindSuperGElement(dev, buf, ZM_WLAN_EID_VENDOR_PRIVATE);
|
||||||
|
if (offset != 0xffff)
|
||||||
{
|
{
|
||||||
pBssInfo->apCap |= ZM_SuperG_AP;
|
pBssInfo->apCap |= ZM_SuperG_AP;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* get XR IE */
|
/* get XR IE */
|
||||||
if ((offset = zfFindXRElement(dev, buf, ZM_WLAN_EID_VENDOR_PRIVATE)) != 0xffff)
|
offset = zfFindXRElement(dev, buf, ZM_WLAN_EID_VENDOR_PRIVATE);
|
||||||
|
if (offset != 0xffff)
|
||||||
{
|
{
|
||||||
pBssInfo->apCap |= ZM_XR_AP;
|
pBssInfo->apCap |= ZM_XR_AP;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* get RSN IE */
|
/* get RSN IE */
|
||||||
if ( (offset = zfFindElement(dev, buf, ZM_WLAN_EID_RSN_IE)) != 0xffff )
|
offset = zfFindElement(dev, buf, ZM_WLAN_EID_RSN_IE);
|
||||||
|
if (offset != 0xffff)
|
||||||
{
|
{
|
||||||
length = zmw_rx_buf_readb(dev, buf, offset+1);
|
length = zmw_rx_buf_readb(dev, buf, offset+1);
|
||||||
if (length > ZM_MAX_IE_SIZE)
|
if (length > ZM_MAX_IE_SIZE)
|
||||||
|
@ -1707,7 +1727,8 @@ u8_t zfStaInitBssInfo(zdev_t* dev, zbuf_t* buf,
|
||||||
}
|
}
|
||||||
#ifdef ZM_ENABLE_CENC
|
#ifdef ZM_ENABLE_CENC
|
||||||
/* get CENC IE */
|
/* get CENC IE */
|
||||||
if ( (offset = zfFindElement(dev, buf, ZM_WLAN_EID_CENC_IE)) != 0xffff )
|
offset = zfFindElement(dev, buf, ZM_WLAN_EID_CENC_IE);
|
||||||
|
if (offset != 0xffff)
|
||||||
{
|
{
|
||||||
length = zmw_rx_buf_readb(dev, buf, offset+1);
|
length = zmw_rx_buf_readb(dev, buf, offset+1);
|
||||||
if (length > ZM_MAX_IE_SIZE )
|
if (length > ZM_MAX_IE_SIZE )
|
||||||
|
@ -1726,7 +1747,8 @@ u8_t zfStaInitBssInfo(zdev_t* dev, zbuf_t* buf,
|
||||||
/* get WME Parameter IE, probe rsp may contain WME parameter element */
|
/* get WME Parameter IE, probe rsp may contain WME parameter element */
|
||||||
//if ( wd->bQoSEnable )
|
//if ( wd->bQoSEnable )
|
||||||
{
|
{
|
||||||
if ((offset = zfFindWifiElement(dev, buf, 2, 1)) != 0xffff)
|
offset = zfFindWifiElement(dev, buf, 2, 1);
|
||||||
|
if (offset != 0xffff)
|
||||||
{
|
{
|
||||||
apQosInfo = zmw_rx_buf_readb(dev, buf, offset+8) & 0x80;
|
apQosInfo = zmw_rx_buf_readb(dev, buf, offset+8) & 0x80;
|
||||||
pBssInfo->wmeSupport = 1 | apQosInfo;
|
pBssInfo->wmeSupport = 1 | apQosInfo;
|
||||||
|
@ -1742,7 +1764,8 @@ u8_t zfStaInitBssInfo(zdev_t* dev, zbuf_t* buf,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
//CWYang(+)
|
//CWYang(+)
|
||||||
if ((offset = zfFindElement(dev, buf, ZM_WLAN_EID_HT_CAPABILITY)) != 0xffff)
|
offset = zfFindElement(dev, buf, ZM_WLAN_EID_HT_CAPABILITY);
|
||||||
|
if (offset != 0xffff)
|
||||||
{
|
{
|
||||||
/* 11n AP */
|
/* 11n AP */
|
||||||
pBssInfo->EnableHT = 1;
|
pBssInfo->EnableHT = 1;
|
||||||
|
@ -1792,7 +1815,8 @@ u8_t zfStaInitBssInfo(zdev_t* dev, zbuf_t* buf,
|
||||||
pBssInfo->EnableHT = 0;
|
pBssInfo->EnableHT = 0;
|
||||||
}
|
}
|
||||||
/* HT information */
|
/* HT information */
|
||||||
if ((offset = zfFindElement(dev, buf, ZM_WLAN_EID_EXTENDED_HT_CAPABILITY)) != 0xffff)
|
offset = zfFindElement(dev, buf, ZM_WLAN_EID_EXTENDED_HT_CAPABILITY);
|
||||||
|
if (offset != 0xffff)
|
||||||
{
|
{
|
||||||
/* atheros pre n */
|
/* atheros pre n */
|
||||||
pBssInfo->extChOffset = zmw_rx_buf_readb(dev, buf, offset+2) & 0x03;
|
pBssInfo->extChOffset = zmw_rx_buf_readb(dev, buf, offset+2) & 0x03;
|
||||||
|
@ -1848,7 +1872,8 @@ u8_t zfStaInitBssInfo(zdev_t* dev, zbuf_t* buf,
|
||||||
}
|
}
|
||||||
|
|
||||||
/* get Marvel Extended Capability */
|
/* get Marvel Extended Capability */
|
||||||
if ((offset = zfFindMarvelExtCap(dev, buf)) != 0xffff)
|
offset = zfFindMarvelExtCap(dev, buf);
|
||||||
|
if (offset != 0xffff)
|
||||||
{
|
{
|
||||||
pBssInfo->marvelAp = 1;
|
pBssInfo->marvelAp = 1;
|
||||||
}
|
}
|
||||||
|
@ -1858,7 +1883,8 @@ u8_t zfStaInitBssInfo(zdev_t* dev, zbuf_t* buf,
|
||||||
}
|
}
|
||||||
|
|
||||||
/* get ATIM window */
|
/* get ATIM window */
|
||||||
if ( (offset = zfFindElement(dev, buf, ZM_WLAN_EID_IBSS)) != 0xffff )
|
offset = zfFindElement(dev, buf, ZM_WLAN_EID_IBSS);
|
||||||
|
if (offset != 0xffff )
|
||||||
{
|
{
|
||||||
pBssInfo->atimWindow = zmw_rx_buf_readh(dev, buf,offset+2);
|
pBssInfo->atimWindow = zmw_rx_buf_readh(dev, buf,offset+2);
|
||||||
}
|
}
|
||||||
|
@ -2017,7 +2043,8 @@ zlUpdateRssi:
|
||||||
pBssInfo->tick = wd->tick;
|
pBssInfo->tick = wd->tick;
|
||||||
|
|
||||||
/* Update ERP information */
|
/* Update ERP information */
|
||||||
if ( (offset = zfFindElement(dev, buf, ZM_WLAN_EID_ERP)) != 0xffff )
|
offset = zfFindElement(dev, buf, ZM_WLAN_EID_ERP);
|
||||||
|
if (offset != 0xffff)
|
||||||
{
|
{
|
||||||
pBssInfo->erp = zmw_rx_buf_readb(dev, buf, offset+2);
|
pBssInfo->erp = zmw_rx_buf_readb(dev, buf, offset+2);
|
||||||
}
|
}
|
||||||
|
@ -2116,7 +2143,8 @@ void zfStaProcessBeacon(zdev_t* dev, zbuf_t* buf, struct zsAdditionInfo* AddInfo
|
||||||
#if 0
|
#if 0
|
||||||
else if ( wd->sta.oppositeCount == 0 )
|
else if ( wd->sta.oppositeCount == 0 )
|
||||||
{ /* IBSS merge if SSID matched */
|
{ /* IBSS merge if SSID matched */
|
||||||
if ( (offset = zfFindElement(dev, buf, ZM_WLAN_EID_SSID)) != 0xffff )
|
offset = zfFindElement(dev, buf, ZM_WLAN_EID_SSID);
|
||||||
|
if (offset != 0xffff)
|
||||||
{
|
{
|
||||||
if ( (wd->sta.ssidLen == zmw_buf_readb(dev, buf, offset+1))&&
|
if ( (wd->sta.ssidLen == zmw_buf_readb(dev, buf, offset+1))&&
|
||||||
(zfRxBufferEqualToStr(dev, buf, wd->sta.ssid,
|
(zfRxBufferEqualToStr(dev, buf, wd->sta.ssid,
|
||||||
|
@ -2410,7 +2438,8 @@ void zfStaProcessAsocRsp(zdev_t* dev, zbuf_t* buf)
|
||||||
if ((wd->sta.wmeEnabled & ZM_STA_WME_ENABLE_BIT) != 0) //WME enabled
|
if ((wd->sta.wmeEnabled & ZM_STA_WME_ENABLE_BIT) != 0) //WME enabled
|
||||||
{
|
{
|
||||||
/* Asoc rsp may contain WME parameter element */
|
/* Asoc rsp may contain WME parameter element */
|
||||||
if ((offset = zfFindWifiElement(dev, buf, 2, 1)) != 0xffff)
|
offset = zfFindWifiElement(dev, buf, 2, 1);
|
||||||
|
if (offset != 0xffff)
|
||||||
{
|
{
|
||||||
zm_debug_msg0("WME enable");
|
zm_debug_msg0("WME enable");
|
||||||
wd->sta.wmeConnected = 1;
|
wd->sta.wmeConnected = 1;
|
||||||
|
@ -2605,7 +2634,8 @@ void zfStaStoreAsocRspIe(zdev_t* dev, zbuf_t* buf)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((offset = zfFindElement(dev, buf, ZM_WLAN_EID_HT_CAPABILITY)) != 0xffff)
|
offset = zfFindElement(dev, buf, ZM_WLAN_EID_HT_CAPABILITY);
|
||||||
|
if (offset != 0xffff)
|
||||||
{
|
{
|
||||||
/* atheros pre n */
|
/* atheros pre n */
|
||||||
zm_debug_msg0("atheros pre n");
|
zm_debug_msg0("atheros pre n");
|
||||||
|
@ -2645,7 +2675,8 @@ void zfStaStoreAsocRspIe(zdev_t* dev, zbuf_t* buf)
|
||||||
asocBw40 = (u8_t)((wd->sta.ie.HtCap.HtCapInfo & HTCAP_SupChannelWidthSet) >> 1);
|
asocBw40 = (u8_t)((wd->sta.ie.HtCap.HtCapInfo & HTCAP_SupChannelWidthSet) >> 1);
|
||||||
|
|
||||||
/* HT information */
|
/* HT information */
|
||||||
if ((offset = zfFindElement(dev, buf, ZM_WLAN_EID_EXTENDED_HT_CAPABILITY)) != 0xffff)
|
offset = zfFindElement(dev, buf, ZM_WLAN_EID_EXTENDED_HT_CAPABILITY);
|
||||||
|
if (offset != 0xffff)
|
||||||
{
|
{
|
||||||
/* atheros pre n */
|
/* atheros pre n */
|
||||||
zm_debug_msg0("atheros pre n HTINFO");
|
zm_debug_msg0("atheros pre n HTINFO");
|
||||||
|
@ -2815,7 +2846,8 @@ void zfStaProcessProbeReq(zdev_t* dev, zbuf_t* buf, u16_t* src)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* check SSID */
|
/* check SSID */
|
||||||
if ((offset = zfFindElement(dev, buf, ZM_WLAN_EID_SSID)) == 0xffff)
|
offset = zfFindElement(dev, buf, ZM_WLAN_EID_SSID);
|
||||||
|
if (offset == 0xffff)
|
||||||
{
|
{
|
||||||
zm_msg0_mm(ZM_LV_3, "probe req SSID not found");
|
zm_msg0_mm(ZM_LV_3, "probe req SSID not found");
|
||||||
return;
|
return;
|
||||||
|
@ -3774,7 +3806,8 @@ static struct zsBssInfo* zfInfraFindAPToConnect(zdev_t* dev,
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Skip if AP in blocking list */
|
/* Skip if AP in blocking list */
|
||||||
if ((ret = zfStaIsApInBlockingList(dev, pBssInfo->bssid)) == TRUE)
|
ret = zfStaIsApInBlockingList(dev, pBssInfo->bssid);
|
||||||
|
if (ret == TRUE)
|
||||||
{
|
{
|
||||||
zm_msg0_mm(ZM_LV_0, "Candidate AP in blocking List, skip if there's stilla choice!");
|
zm_msg0_mm(ZM_LV_0, "Candidate AP in blocking List, skip if there's stilla choice!");
|
||||||
pNowBssInfo = pBssInfo;
|
pNowBssInfo = pBssInfo;
|
||||||
|
@ -5007,7 +5040,8 @@ void zfSendNullData(zdev_t* dev, u8_t type)
|
||||||
|
|
||||||
zmw_get_wlan_dev(dev);
|
zmw_get_wlan_dev(dev);
|
||||||
|
|
||||||
if ((buf = zfwBufAllocate(dev, 1024)) == NULL)
|
buf = zfwBufAllocate(dev, 1024);
|
||||||
|
if (buf == NULL)
|
||||||
{
|
{
|
||||||
zm_msg0_mm(ZM_LV_0, "Alloc mm buf Fail!");
|
zm_msg0_mm(ZM_LV_0, "Alloc mm buf Fail!");
|
||||||
return;
|
return;
|
||||||
|
@ -5056,8 +5090,9 @@ void zfSendNullData(zdev_t* dev, u8_t type)
|
||||||
/*increase unicast frame counter*/
|
/*increase unicast frame counter*/
|
||||||
wd->commTally.txUnicastFrm++;
|
wd->commTally.txUnicastFrm++;
|
||||||
|
|
||||||
if ((err = zfHpSend(dev, header, hlen, NULL, 0, NULL, 0, buf, 0,
|
err = zfHpSend(dev, header, hlen, NULL, 0, NULL, 0, buf, 0,
|
||||||
ZM_INTERNAL_ALLOC_BUF, 0, 0xff)) != ZM_SUCCESS)
|
ZM_INTERNAL_ALLOC_BUF, 0, 0xff);
|
||||||
|
if (err != ZM_SUCCESS)
|
||||||
{
|
{
|
||||||
goto zlError;
|
goto zlError;
|
||||||
}
|
}
|
||||||
|
@ -5083,7 +5118,8 @@ void zfSendPSPoll(zdev_t* dev)
|
||||||
|
|
||||||
zmw_get_wlan_dev(dev);
|
zmw_get_wlan_dev(dev);
|
||||||
|
|
||||||
if ((buf = zfwBufAllocate(dev, 1024)) == NULL)
|
buf = zfwBufAllocate(dev, 1024);
|
||||||
|
if (buf == NULL)
|
||||||
{
|
{
|
||||||
zm_msg0_mm(ZM_LV_0, "Alloc mm buf Fail!");
|
zm_msg0_mm(ZM_LV_0, "Alloc mm buf Fail!");
|
||||||
return;
|
return;
|
||||||
|
@ -5107,8 +5143,9 @@ void zfSendPSPoll(zdev_t* dev)
|
||||||
// goto zlError;
|
// goto zlError;
|
||||||
//}
|
//}
|
||||||
|
|
||||||
if ((err = zfHpSend(dev, header, hlen, NULL, 0, NULL, 0, buf, 0,
|
err = zfHpSend(dev, header, hlen, NULL, 0, NULL, 0, buf, 0,
|
||||||
ZM_INTERNAL_ALLOC_BUF, 0, 0xff)) != ZM_SUCCESS)
|
ZM_INTERNAL_ALLOC_BUF, 0, 0xff);
|
||||||
|
if (err != ZM_SUCCESS)
|
||||||
{
|
{
|
||||||
goto zlError;
|
goto zlError;
|
||||||
}
|
}
|
||||||
|
@ -5134,7 +5171,8 @@ void zfSendBA(zdev_t* dev, u16_t start_seq, u8_t *bitmap)
|
||||||
|
|
||||||
zmw_get_wlan_dev(dev);
|
zmw_get_wlan_dev(dev);
|
||||||
|
|
||||||
if ((buf = zfwBufAllocate(dev, 1024)) == NULL)
|
buf = zfwBufAllocate(dev, 1024);
|
||||||
|
if (buf == NULL)
|
||||||
{
|
{
|
||||||
zm_msg0_mm(ZM_LV_0, "Alloc mm buf Fail!");
|
zm_msg0_mm(ZM_LV_0, "Alloc mm buf Fail!");
|
||||||
return;
|
return;
|
||||||
|
@ -5166,8 +5204,9 @@ void zfSendBA(zdev_t* dev, u16_t start_seq, u8_t *bitmap)
|
||||||
offset++;
|
offset++;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((err = zfHpSend(dev, header, hlen, NULL, 0, NULL, 0, buf, 0,
|
err = zfHpSend(dev, header, hlen, NULL, 0, NULL, 0, buf, 0,
|
||||||
ZM_INTERNAL_ALLOC_BUF, 0, 0xff)) != ZM_SUCCESS)
|
ZM_INTERNAL_ALLOC_BUF, 0, 0xff);
|
||||||
|
if (err != ZM_SUCCESS)
|
||||||
{
|
{
|
||||||
goto zlError;
|
goto zlError;
|
||||||
}
|
}
|
||||||
|
|
|
@ -553,7 +553,8 @@ u8_t zfiWlanSetKey(zdev_t* dev, struct zsKeyInfo keyInfo)
|
||||||
if (keyInfo.flag & ZM_KEY_FLAG_PK)
|
if (keyInfo.flag & ZM_KEY_FLAG_PK)
|
||||||
{
|
{
|
||||||
/* Find STA's information */
|
/* Find STA's information */
|
||||||
if ((id = zfApFindSta(dev, keyInfo.macAddr)) == 0xffff)
|
id = zfApFindSta(dev, keyInfo.macAddr);
|
||||||
|
if (id == 0xffff)
|
||||||
{
|
{
|
||||||
/* Can't STA in the staTable */
|
/* Can't STA in the staTable */
|
||||||
return ZM_STATUS_FAILURE;
|
return ZM_STATUS_FAILURE;
|
||||||
|
|
|
@ -602,7 +602,8 @@ void zfPowerSavingMgrProcessBeacon(zdev_t* dev, zbuf_t* buf)
|
||||||
|
|
||||||
wd->sta.psMgr.isSleepAllowed = 1;
|
wd->sta.psMgr.isSleepAllowed = 1;
|
||||||
|
|
||||||
if ( (offset=zfFindElement(dev, buf, ZM_WLAN_EID_TIM)) != 0xffff )
|
offset = zfFindElement(dev, buf, ZM_WLAN_EID_TIM);
|
||||||
|
if (offset != 0xffff)
|
||||||
{
|
{
|
||||||
length = zmw_rx_buf_readb(dev, buf, offset+1);
|
length = zmw_rx_buf_readb(dev, buf, offset+1);
|
||||||
|
|
||||||
|
|
|
@ -109,7 +109,8 @@ void zfGetRxIvIcvLength(zdev_t* dev, zbuf_t* buf, u8_t vap, u16_t* pIvLen,
|
||||||
addr[2] = zmw_rx_buf_readh(dev, buf, ZM_WLAN_HEADER_A2_OFFSET+4);
|
addr[2] = zmw_rx_buf_readh(dev, buf, ZM_WLAN_HEADER_A2_OFFSET+4);
|
||||||
|
|
||||||
/* Find STA's information */
|
/* Find STA's information */
|
||||||
if ((id = zfApFindSta(dev, addr)) != 0xffff)
|
id = zfApFindSta(dev, addr);
|
||||||
|
if (id != 0xffff)
|
||||||
{
|
{
|
||||||
if (wd->ap.staTable[id].encryMode == ZM_TKIP)
|
if (wd->ap.staTable[id].encryMode == ZM_TKIP)
|
||||||
{
|
{
|
||||||
|
@ -132,7 +133,8 @@ void zfGetRxIvIcvLength(zdev_t* dev, zbuf_t* buf, u8_t vap, u16_t* pIvLen,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/* WDS port checking */
|
/* WDS port checking */
|
||||||
if ((wdsPort = vap - 0x20) >= ZM_MAX_WDS_SUPPORT)
|
wdsPort = vap - 0x20;
|
||||||
|
if (wdsPort >= ZM_MAX_WDS_SUPPORT)
|
||||||
{
|
{
|
||||||
wdsPort = 0;
|
wdsPort = 0;
|
||||||
}
|
}
|
||||||
|
@ -741,8 +743,9 @@ u16_t zfiTxSend80211Mgmt(zdev_t* dev, zbuf_t* buf, u16_t port)
|
||||||
|
|
||||||
zfwBufRemoveHead(dev, buf, 24);
|
zfwBufRemoveHead(dev, buf, 24);
|
||||||
|
|
||||||
if ((err = zfHpSend(dev, header, hlen, NULL, 0, NULL, 0, buf, 0,
|
err = zfHpSend(dev, header, hlen, NULL, 0, NULL, 0, buf, 0,
|
||||||
ZM_EXTERNAL_ALLOC_BUF, 0, 0)) != ZM_SUCCESS)
|
ZM_EXTERNAL_ALLOC_BUF, 0, 0);
|
||||||
|
if (err != ZM_SUCCESS)
|
||||||
{
|
{
|
||||||
goto zlError;
|
goto zlError;
|
||||||
}
|
}
|
||||||
|
@ -799,7 +802,8 @@ u16_t zfiTxSendEth(zdev_t* dev, zbuf_t* buf, u16_t port)
|
||||||
ZM_PERFORMANCE_TX_MSDU(dev, wd->tick);
|
ZM_PERFORMANCE_TX_MSDU(dev, wd->tick);
|
||||||
zm_msg1_tx(ZM_LV_2, "zfiTxSendEth(), port=", port);
|
zm_msg1_tx(ZM_LV_2, "zfiTxSendEth(), port=", port);
|
||||||
/* Return error if port is disabled */
|
/* Return error if port is disabled */
|
||||||
if ((err = zfTxPortControl(dev, buf, port)) == ZM_PORT_DISABLED)
|
err = zfTxPortControl(dev, buf, port);
|
||||||
|
if (err == ZM_PORT_DISABLED)
|
||||||
{
|
{
|
||||||
err = ZM_ERR_TX_PORT_DISABLED;
|
err = ZM_ERR_TX_PORT_DISABLED;
|
||||||
goto zlError;
|
goto zlError;
|
||||||
|
@ -809,7 +813,8 @@ u16_t zfiTxSendEth(zdev_t* dev, zbuf_t* buf, u16_t port)
|
||||||
if ((wd->wlanMode == ZM_MODE_AP) && (port < 0x20))
|
if ((wd->wlanMode == ZM_MODE_AP) && (port < 0x20))
|
||||||
{
|
{
|
||||||
/* AP : Buffer frame for power saving STA */
|
/* AP : Buffer frame for power saving STA */
|
||||||
if ((ret = zfApBufferPsFrame(dev, buf, port)) == 1)
|
ret = zfApBufferPsFrame(dev, buf, port);
|
||||||
|
if (ret == 1)
|
||||||
{
|
{
|
||||||
return ZM_SUCCESS;
|
return ZM_SUCCESS;
|
||||||
}
|
}
|
||||||
|
@ -1119,7 +1124,8 @@ u16_t zfTxSendEth(zdev_t* dev, zbuf_t* buf, u16_t port, u16_t bufType, u16_t fla
|
||||||
i = 0;
|
i = 0;
|
||||||
while( frameLen > 0 )
|
while( frameLen > 0 )
|
||||||
{
|
{
|
||||||
if ((frag.buf[i] = zfwBufAllocate(dev, fragLen+32)) != NULL)
|
frag.buf[i] = zfwBufAllocate(dev, fragLen+32);
|
||||||
|
if (frag.buf[i] != NULL)
|
||||||
{
|
{
|
||||||
frag.bufType[i] = ZM_INTERNAL_ALLOC_BUF;
|
frag.bufType[i] = ZM_INTERNAL_ALLOC_BUF;
|
||||||
frag.seq[i] = frag.seq[0] + i;
|
frag.seq[i] = frag.seq[0] + i;
|
||||||
|
@ -1276,7 +1282,8 @@ void zfCoreRecv(zdev_t* dev, zbuf_t* buf, struct zsAdditionInfo* addInfo)
|
||||||
bssid[2] = zmw_buf_readh(dev, buf, 20);
|
bssid[2] = zmw_buf_readh(dev, buf, 20);
|
||||||
|
|
||||||
/* Validate Rx frame */
|
/* Validate Rx frame */
|
||||||
if ((ret = zfWlanRxValidate(dev, buf)) != ZM_SUCCESS)
|
ret = zfWlanRxValidate(dev, buf);
|
||||||
|
if (ret != ZM_SUCCESS)
|
||||||
{
|
{
|
||||||
zm_msg1_rx(ZM_LV_1, "Rx invalid:", ret);
|
zm_msg1_rx(ZM_LV_1, "Rx invalid:", ret);
|
||||||
goto zlError;
|
goto zlError;
|
||||||
|
@ -1301,7 +1308,8 @@ void zfCoreRecv(zdev_t* dev, zbuf_t* buf, struct zsAdditionInfo* addInfo)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Filter Rx frame */
|
/* Filter Rx frame */
|
||||||
if ((ret = zfWlanRxFilter(dev, buf)) != ZM_SUCCESS)
|
ret = zfWlanRxFilter(dev, buf);
|
||||||
|
if (ret != ZM_SUCCESS)
|
||||||
{
|
{
|
||||||
zm_msg1_rx(ZM_LV_1, "Rx duplicated:", ret);
|
zm_msg1_rx(ZM_LV_1, "Rx duplicated:", ret);
|
||||||
goto zlError;
|
goto zlError;
|
||||||
|
@ -2086,7 +2094,8 @@ void zfiRecv80211(zdev_t* dev, zbuf_t* buf, struct zsAdditionInfo* addInfo)
|
||||||
//zm_msg0_rx(ZM_LV_0, "Rx data");
|
//zm_msg0_rx(ZM_LV_0, "Rx data");
|
||||||
if (wd->wlanMode == ZM_MODE_AP)
|
if (wd->wlanMode == ZM_MODE_AP)
|
||||||
{
|
{
|
||||||
if ((ret = zfApUpdatePsBit(dev, buf, &vap, &uapsdTrig)) != ZM_SUCCESS)
|
ret = zfApUpdatePsBit(dev, buf, &vap, &uapsdTrig);
|
||||||
|
if (ret != ZM_SUCCESS)
|
||||||
{
|
{
|
||||||
zfwBufFree(dev, buf, 0);
|
zfwBufFree(dev, buf, 0);
|
||||||
return;
|
return;
|
||||||
|
@ -2115,7 +2124,8 @@ void zfiRecv80211(zdev_t* dev, zbuf_t* buf, struct zsAdditionInfo* addInfo)
|
||||||
for (ii=0; ii<pktNum; ii++)
|
for (ii=0; ii<pktNum; ii++)
|
||||||
{
|
{
|
||||||
//if ((psBuf = zfQueueGet(dev, wd->ap.uapsdQ)) != NULL)
|
//if ((psBuf = zfQueueGet(dev, wd->ap.uapsdQ)) != NULL)
|
||||||
if ((psBuf = zfQueueGetWithMac(dev, wd->ap.uapsdQ, src, &mb)) != NULL)
|
psBuf = zfQueueGetWithMac(dev, wd->ap.uapsdQ, src, &mb);
|
||||||
|
if (psBuf != NULL)
|
||||||
{
|
{
|
||||||
if ((ii+1) == pktNum)
|
if ((ii+1) == pktNum)
|
||||||
{
|
{
|
||||||
|
@ -2232,7 +2242,8 @@ void zfiRecv80211(zdev_t* dev, zbuf_t* buf, struct zsAdditionInfo* addInfo)
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if ( (buf = zfDefragment(dev, buf, &bIsDefrag, addInfo)) == NULL )
|
buf = zfDefragment(dev, buf, &bIsDefrag, addInfo);
|
||||||
|
if (buf == NULL)
|
||||||
{
|
{
|
||||||
/* In this case, the buffer has been freed in zfDefragment */
|
/* In this case, the buffer has been freed in zfDefragment */
|
||||||
return;
|
return;
|
||||||
|
@ -2836,7 +2847,8 @@ void zfiRecv80211(zdev_t* dev, zbuf_t* buf, struct zsAdditionInfo* addInfo)
|
||||||
zfwBufRemoveHead(dev, buf, 18+offset);
|
zfwBufRemoveHead(dev, buf, 18+offset);
|
||||||
#endif // ZM_ENABLE_NATIVE_WIFI
|
#endif // ZM_ENABLE_NATIVE_WIFI
|
||||||
#if 1
|
#if 1
|
||||||
if ((ret = zfIntrabssForward(dev, buf, vap)) == 1)
|
ret = zfIntrabssForward(dev, buf, vap);
|
||||||
|
if (ret == 1)
|
||||||
{
|
{
|
||||||
/* Free Rx buffer if intra-BSS unicast frame */
|
/* Free Rx buffer if intra-BSS unicast frame */
|
||||||
zm_msg0_rx(ZM_LV_2, "Free intra-BSS unicast frame");
|
zm_msg0_rx(ZM_LV_2, "Free intra-BSS unicast frame");
|
||||||
|
@ -3037,7 +3049,8 @@ u16_t zfWlanRxValidate(zdev_t* dev, zbuf_t* buf)
|
||||||
}
|
}
|
||||||
else if ( wd->wlanMode != ZM_MODE_PSEUDO )
|
else if ( wd->wlanMode != ZM_MODE_PSEUDO )
|
||||||
{
|
{
|
||||||
if ( (ret=zfStaRxValidateFrame(dev, buf))!=ZM_SUCCESS )
|
ret = zfStaRxValidateFrame(dev, buf);
|
||||||
|
if (ret != ZM_SUCCESS)
|
||||||
{
|
{
|
||||||
//zm_debug_msg1("discard frame, code = ", ret);
|
//zm_debug_msg1("discard frame, code = ", ret);
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -3787,12 +3800,14 @@ void zfPushVtxq(zdev_t* dev)
|
||||||
/* 2006.12.20, Serve Management queue */
|
/* 2006.12.20, Serve Management queue */
|
||||||
while( zfHpGetFreeTxdCount(dev) > 0 )
|
while( zfHpGetFreeTxdCount(dev) > 0 )
|
||||||
{
|
{
|
||||||
if ((buf = zfGetVmmq(dev)) != 0)
|
buf = zfGetVmmq(dev);
|
||||||
|
if (buf != 0)
|
||||||
{
|
{
|
||||||
txed = 1;
|
txed = 1;
|
||||||
//zm_debug_msg2("send buf = ", buf);
|
//zm_debug_msg2("send buf = ", buf);
|
||||||
if ((err = zfHpSend(dev, NULL, 0, NULL, 0, NULL, 0, buf, 0,
|
err = zfHpSend(dev, NULL, 0, NULL, 0, NULL, 0, buf, 0,
|
||||||
ZM_INTERNAL_ALLOC_BUF, 0, 0xff)) != ZM_SUCCESS)
|
ZM_INTERNAL_ALLOC_BUF, 0, 0xff);
|
||||||
|
if (err != ZM_SUCCESS)
|
||||||
{
|
{
|
||||||
zfwBufFree(dev, buf, 0);
|
zfwBufFree(dev, buf, 0);
|
||||||
}
|
}
|
||||||
|
@ -3831,9 +3846,11 @@ void zfPushVtxq(zdev_t* dev)
|
||||||
/* Service VTxQ[3] */
|
/* Service VTxQ[3] */
|
||||||
for (i=0; i<4; i++)
|
for (i=0; i<4; i++)
|
||||||
{
|
{
|
||||||
if ((freeTxd = zfHpGetFreeTxdCount(dev)) >= 3)
|
freeTxd = zfHpGetFreeTxdCount(dev);
|
||||||
|
if (freeTxd >= 3)
|
||||||
{
|
{
|
||||||
if ((buf = zfGetVtxq(dev, 3)) != 0)
|
buf = zfGetVtxq(dev, 3);
|
||||||
|
if (buf != 0)
|
||||||
{
|
{
|
||||||
txed = 1;
|
txed = 1;
|
||||||
//zm_debug_msg2("send buf = ", buf);
|
//zm_debug_msg2("send buf = ", buf);
|
||||||
|
@ -3850,9 +3867,11 @@ void zfPushVtxq(zdev_t* dev)
|
||||||
/* Service VTxQ[2] */
|
/* Service VTxQ[2] */
|
||||||
for (i=0; i<3; i++)
|
for (i=0; i<3; i++)
|
||||||
{
|
{
|
||||||
if ((freeTxd = zfHpGetFreeTxdCount(dev)) >= (zfHpGetMaxTxdCount(dev)*1/4))
|
freeTxd = zfHpGetFreeTxdCount(dev);
|
||||||
|
if (freeTxd >= (zfHpGetMaxTxdCount(dev)*1/4))
|
||||||
{
|
{
|
||||||
if ((buf = zfGetVtxq(dev, 2)) != 0)
|
buf = zfGetVtxq(dev, 2);
|
||||||
|
if (buf != 0)
|
||||||
{
|
{
|
||||||
txed = 1;
|
txed = 1;
|
||||||
zfTxSendEth(dev, buf, 0, ZM_EXTERNAL_ALLOC_BUF, 0);
|
zfTxSendEth(dev, buf, 0, ZM_EXTERNAL_ALLOC_BUF, 0);
|
||||||
|
@ -3860,7 +3879,8 @@ void zfPushVtxq(zdev_t* dev)
|
||||||
}
|
}
|
||||||
if (wd->sta.ac0PriorityHigherThanAc2 == 1)
|
if (wd->sta.ac0PriorityHigherThanAc2 == 1)
|
||||||
{
|
{
|
||||||
if ((buf = zfGetVtxq(dev, 0)) != 0)
|
buf = zfGetVtxq(dev, 0);
|
||||||
|
if (buf != 0)
|
||||||
{
|
{
|
||||||
txed = 1;
|
txed = 1;
|
||||||
zfTxSendEth(dev, buf, 0, ZM_EXTERNAL_ALLOC_BUF, 0);
|
zfTxSendEth(dev, buf, 0, ZM_EXTERNAL_ALLOC_BUF, 0);
|
||||||
|
@ -3877,9 +3897,11 @@ void zfPushVtxq(zdev_t* dev)
|
||||||
/* Service VTxQ[0] */
|
/* Service VTxQ[0] */
|
||||||
for (i=0; i<2; i++)
|
for (i=0; i<2; i++)
|
||||||
{
|
{
|
||||||
if ((freeTxd = zfHpGetFreeTxdCount(dev)) >= (zfHpGetMaxTxdCount(dev)*2/4))
|
freeTxd = zfHpGetFreeTxdCount(dev);
|
||||||
|
if (freeTxd >= (zfHpGetMaxTxdCount(dev)*2/4))
|
||||||
{
|
{
|
||||||
if ((buf = zfGetVtxq(dev, 0)) != 0)
|
buf = zfGetVtxq(dev, 0);
|
||||||
|
if (buf != 0)
|
||||||
{
|
{
|
||||||
txed = 1;
|
txed = 1;
|
||||||
zfTxSendEth(dev, buf, 0, ZM_EXTERNAL_ALLOC_BUF, 0);
|
zfTxSendEth(dev, buf, 0, ZM_EXTERNAL_ALLOC_BUF, 0);
|
||||||
|
@ -3894,9 +3916,11 @@ void zfPushVtxq(zdev_t* dev)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Service VTxQ[1] */
|
/* Service VTxQ[1] */
|
||||||
if ((freeTxd = zfHpGetFreeTxdCount(dev)) >= (zfHpGetMaxTxdCount(dev)*3/4))
|
freeTxd = zfHpGetFreeTxdCount(dev);
|
||||||
|
if (freeTxd >= (zfHpGetMaxTxdCount(dev)*3/4))
|
||||||
{
|
{
|
||||||
if ((buf = zfGetVtxq(dev, 1)) != 0)
|
buf = zfGetVtxq(dev, 1);
|
||||||
|
if (buf != 0)
|
||||||
{
|
{
|
||||||
txed = 1;
|
txed = 1;
|
||||||
zfTxSendEth(dev, buf, 0, ZM_EXTERNAL_ALLOC_BUF, 0);
|
zfTxSendEth(dev, buf, 0, ZM_EXTERNAL_ALLOC_BUF, 0);
|
||||||
|
@ -3983,9 +4007,10 @@ void zf80211FrameSend(zdev_t* dev, zbuf_t* buf, u16_t* header, u16_t snapLen,
|
||||||
}
|
}
|
||||||
wd->ledStruct.txTraffic++;
|
wd->ledStruct.txTraffic++;
|
||||||
|
|
||||||
if ((err = zfHpSend(dev, header, headerLen, snap, snapLen,
|
err = zfHpSend(dev, header, headerLen, snap, snapLen,
|
||||||
tail, tailLen, buf, offset,
|
tail, tailLen, buf, offset,
|
||||||
bufType, ac, keyIdx)) != ZM_SUCCESS)
|
bufType, ac, keyIdx);
|
||||||
|
if (err != ZM_SUCCESS)
|
||||||
{
|
{
|
||||||
if (bufType == ZM_EXTERNAL_ALLOC_BUF)
|
if (bufType == ZM_EXTERNAL_ALLOC_BUF)
|
||||||
{
|
{
|
||||||
|
|
|
@ -31,8 +31,9 @@ struct zsQueue* zfQueueCreate(zdev_t* dev, u16_t size)
|
||||||
{
|
{
|
||||||
struct zsQueue* q;
|
struct zsQueue* q;
|
||||||
|
|
||||||
if ((q = (struct zsQueue*)zfwMemAllocate(dev, sizeof(struct zsQueue)
|
q = (struct zsQueue*)zfwMemAllocate(dev, sizeof(struct zsQueue)
|
||||||
+ (sizeof(struct zsQueueCell)*(size-1)))) != NULL)
|
+ (sizeof(struct zsQueueCell)*(size-1)));
|
||||||
|
if (q != NULL)
|
||||||
{
|
{
|
||||||
q->size = size;
|
q->size = size;
|
||||||
q->sizeMask = size-1;
|
q->sizeMask = size-1;
|
||||||
|
|
|
@ -538,7 +538,8 @@ u16_t zfRateCtrlGetTxRate(zdev_t* dev, struct zsRcCell* rcCell, u16_t* probing)
|
||||||
((rcCell->currentRate <= 16) &&
|
((rcCell->currentRate <= 16) &&
|
||||||
((wd->PER[rcCell->currentRate]/2) <= ZM_RATE_PROBING_THRESHOLD)))
|
((wd->PER[rcCell->currentRate]/2) <= ZM_RATE_PROBING_THRESHOLD)))
|
||||||
{
|
{
|
||||||
if ((newRate=zfRateCtrlGetHigherRate(rcCell)) != rcCell->currentRate)
|
newRate = zfRateCtrlGetHigherRate(rcCell);
|
||||||
|
if (newRate != rcCell->currentRate)
|
||||||
{
|
{
|
||||||
*probing = 1;
|
*probing = 1;
|
||||||
wd->probeCount++;
|
wd->probeCount++;
|
||||||
|
|
Loading…
Reference in New Issue