fix noise/signal level display (fixes #20)
authorFelix Fietkau <nbd@openwrt.org>
Fri, 11 Nov 2005 16:04:02 +0000 (16:04 +0000)
committerFelix Fietkau <nbd@openwrt.org>
Fri, 11 Nov 2005 16:04:02 +0000 (16:04 +0000)
SVN-Revision: 2421

openwrt/target/linux/package/wlcompat/wlcompat.c

index 07e8db0884ce3875dfc74cdf25fbf83e5702faf2..3baeb431789bbf3d11a0ea6e51d32a7518cad9ae 100644 (file)
@@ -225,7 +225,7 @@ struct iw_statistics *wlcompat_get_wireless_stats(struct net_device *dev)
 {
        wl_bss_info_t *bss_info = (wl_bss_info_t *) buf;
        get_pktcnt_t pkt;
-       int rssi, noise;
+       int rssi, noise, ap;
        
        memset(&wstats, 0, sizeof(wstats));
        memset(&pkt, 0, sizeof(pkt));
@@ -234,12 +234,18 @@ struct iw_statistics *wlcompat_get_wireless_stats(struct net_device *dev)
        wl_ioctl(dev, WLC_GET_BSS_INFO, bss_info, WLC_IOCTL_MAXLEN);
        wl_ioctl(dev, WLC_GET_PKTCNTS, &pkt, sizeof(pkt));
 
-       // somehow the structure doesn't fit here
-       noise = buf[0x50];
-       rssi = buf[0x52];
+       wl_ioctl(dev, WLC_GET_AP, &ap, sizeof(ap));
+       if (!ap) {
+               // somehow the structure doesn't fit here
+               rssi = buf[82];
+               noise = buf[84];
+       } else {
+               noise = 0;
+               rssi = 0;
+       }
 
        wstats.qual.level = rssi;
-       wstats.qual.noise = -100 + noise;
+       wstats.qual.noise = noise;
        wstats.discard.misc = pkt.rx_bad_pkt;
        wstats.discard.retries = pkt.tx_bad_pkt;