Commit 854f775a authored by Malcolm Priestley's avatar Malcolm Priestley Committed by Greg Kroah-Hartman

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: default avatarMalcolm Priestley <tvboxspy@gmail.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent ae27b142
...@@ -1384,39 +1384,44 @@ static void s_vCheckSensitivity(struct vnt_private *pDevice) ...@@ -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) ...@@ -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;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment