libs: remove cbi folder
[project/luci.git] / libs / iwinfo / src / iwinfo_wext.c
index 387cb13..2a1b685 100644 (file)
@@ -373,17 +373,18 @@ int wext_get_txpwrlist(const char *ifname, char *buf, int *len)
        ) {
                for( i = 0; i < range.num_txpower; i++ )
                {
-                       if( range.txpower_capa & IW_TXPOW_MWATT )
-                       {
-                               entry.dbm = wext_mw2dbm(range.txpower[i]);
-                               entry.mw  = range.txpower[i];
-                       }
-                       else
+                       if( range.txpower_capa & IW_TXPOW_DBM )
                        {
                                entry.dbm = range.txpower[i];
                                entry.mw  = wext_dbm2mw(range.txpower[i]);
                        }
 
+                       else if( range.txpower_capa & IW_TXPOW_MWATT )
+                       {
+                               entry.dbm = wext_mw2dbm(range.txpower[i]);
+                               entry.mw  = range.txpower[i];
+                       }
+
                        memcpy(&buf[i*sizeof(entry)], &entry, sizeof(entry));
                }
 
@@ -394,6 +395,37 @@ int wext_get_txpwrlist(const char *ifname, char *buf, int *len)
        return -1;      
 }
 
+int wext_get_freqlist(const char *ifname, char *buf, int *len)
+{
+       struct iwreq wrq;
+       struct iw_range range;
+       struct iwinfo_freqlist_entry entry;
+       int i, bl;
+
+       wrq.u.data.pointer = (caddr_t) &range;
+       wrq.u.data.length  = sizeof(struct iw_range);
+       wrq.u.data.flags   = 0;
+
+       if(wext_ioctl(ifname, SIOCGIWRANGE, &wrq) >= 0)
+       {
+               bl = 0;
+
+               for(i = 0; i < range.num_frequency; i++)
+               {
+                       entry.mhz     = wext_freq2mhz(&range.freq[i]);
+                       entry.channel = range.freq[i].i;
+
+                       memcpy(&buf[bl], &entry, sizeof(struct iwinfo_freqlist_entry));
+                       bl += sizeof(struct iwinfo_freqlist_entry);
+               }
+
+               *len = bl;
+               return 0;
+       }
+
+       return -1;
+}
+
 int wext_get_mbssid_support(const char *ifname, int *buf)
 {
        /* No multi bssid support atm */