staging: vt6656: Get wireless stats qual.qual directly from s_uCalculateLinkQual
Calculate the qual from the tx_packets and wstats.discard.retries and apply to wstats.qual.qual Discard pDevice->scStatistic.LinkQuality. Signed-off-by: Malcolm Priestley <tvboxspy@gmail.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
ae27b1428e
commit
854f775a12
2 changed files with 32 additions and 30 deletions
|
@ -1384,39 +1384,44 @@ static void s_vCheckSensitivity(struct vnt_private *pDevice)
|
||||||
|
|
||||||
static void s_uCalculateLinkQual(struct vnt_private *pDevice)
|
static void s_uCalculateLinkQual(struct vnt_private *pDevice)
|
||||||
{
|
{
|
||||||
|
struct net_device_stats *stats = &pDevice->stats;
|
||||||
unsigned long TxOkRatio, TxCnt;
|
unsigned long TxOkRatio, TxCnt;
|
||||||
unsigned long RxOkRatio, RxCnt;
|
unsigned long RxOkRatio, RxCnt;
|
||||||
unsigned long RssiRatio;
|
unsigned long RssiRatio;
|
||||||
|
unsigned long qual;
|
||||||
long ldBm;
|
long ldBm;
|
||||||
|
|
||||||
TxCnt = pDevice->scStatistic.TxNoRetryOkCount +
|
TxCnt = stats->tx_packets + pDevice->wstats.discard.retries;
|
||||||
pDevice->scStatistic.TxRetryOkCount +
|
|
||||||
pDevice->scStatistic.TxFailCount;
|
RxCnt = pDevice->scStatistic.RxFcsErrCnt +
|
||||||
RxCnt = pDevice->scStatistic.RxFcsErrCnt +
|
|
||||||
pDevice->scStatistic.RxOkCnt;
|
pDevice->scStatistic.RxOkCnt;
|
||||||
TxOkRatio = (TxCnt < 6) ? 4000:((pDevice->scStatistic.TxNoRetryOkCount * 4000) / TxCnt);
|
|
||||||
RxOkRatio = (RxCnt < 6) ? 2000:((pDevice->scStatistic.RxOkCnt * 2000) / RxCnt);
|
TxOkRatio = (TxCnt < 6) ? 4000:((stats->tx_packets * 4000) / TxCnt);
|
||||||
//decide link quality
|
|
||||||
if(pDevice->bLinkPass !=true)
|
RxOkRatio = (RxCnt < 6) ? 2000 :
|
||||||
{
|
((pDevice->scStatistic.RxOkCnt * 2000) / RxCnt);
|
||||||
pDevice->scStatistic.LinkQuality = 0;
|
|
||||||
pDevice->scStatistic.SignalStren = 0;
|
/* decide link quality */
|
||||||
}
|
if (pDevice->bLinkPass != true) {
|
||||||
else
|
pDevice->wstats.qual.qual = 0;
|
||||||
{
|
pDevice->scStatistic.SignalStren = 0;
|
||||||
RFvRSSITodBm(pDevice, (u8)(pDevice->uCurrRSSI), &ldBm);
|
} else {
|
||||||
if(-ldBm < 50) {
|
RFvRSSITodBm(pDevice, (u8)(pDevice->uCurrRSSI), &ldBm);
|
||||||
RssiRatio = 4000;
|
if (-ldBm < 50)
|
||||||
}
|
RssiRatio = 4000;
|
||||||
else if(-ldBm > 90) {
|
else if (-ldBm > 90)
|
||||||
RssiRatio = 0;
|
RssiRatio = 0;
|
||||||
}
|
else
|
||||||
else {
|
RssiRatio = (40-(-ldBm-50)) * 4000 / 40;
|
||||||
RssiRatio = (40-(-ldBm-50))*4000/40;
|
|
||||||
}
|
pDevice->scStatistic.SignalStren = RssiRatio / 40;
|
||||||
pDevice->scStatistic.SignalStren = RssiRatio/40;
|
qual = (RssiRatio + TxOkRatio + RxOkRatio) / 100;
|
||||||
pDevice->scStatistic.LinkQuality = (RssiRatio+TxOkRatio+RxOkRatio)/100;
|
if (qual < 100)
|
||||||
}
|
pDevice->wstats.qual.qual = (u8)qual;
|
||||||
|
else
|
||||||
|
pDevice->wstats.qual.qual = 100;
|
||||||
|
}
|
||||||
|
|
||||||
pDevice->scStatistic.RxFcsErrCnt = 0;
|
pDevice->scStatistic.RxFcsErrCnt = 0;
|
||||||
pDevice->scStatistic.RxOkCnt = 0;
|
pDevice->scStatistic.RxOkCnt = 0;
|
||||||
pDevice->scStatistic.TxFailCount = 0;
|
pDevice->scStatistic.TxFailCount = 0;
|
||||||
|
|
|
@ -58,9 +58,6 @@ struct iw_statistics *iwctl_get_wireless_stats(struct net_device *dev)
|
||||||
long ldBm;
|
long ldBm;
|
||||||
|
|
||||||
pDevice->wstats.status = pDevice->eOPMode;
|
pDevice->wstats.status = pDevice->eOPMode;
|
||||||
if (pDevice->scStatistic.LinkQuality > 100)
|
|
||||||
pDevice->scStatistic.LinkQuality = 100;
|
|
||||||
pDevice->wstats.qual.qual = (u8)pDevice->scStatistic.LinkQuality;
|
|
||||||
RFvRSSITodBm(pDevice, (u8)(pDevice->uCurrRSSI), &ldBm);
|
RFvRSSITodBm(pDevice, (u8)(pDevice->uCurrRSSI), &ldBm);
|
||||||
pDevice->wstats.qual.level = ldBm;
|
pDevice->wstats.qual.level = ldBm;
|
||||||
pDevice->wstats.qual.noise = 0;
|
pDevice->wstats.qual.noise = 0;
|
||||||
|
|
Loading…
Add table
Reference in a new issue