X-Git-Url: https://git.rohieb.name/openwrt.git/blobdiff_plain/c02a9bd7aaf1e6fbfa829ec2e1b66cefce3268c5..3a1a68de7495b2addfe13cbcbcc842dc0b935cfa:/package/iwinfo/src/iwinfo_madwifi.c diff --git a/package/iwinfo/src/iwinfo_madwifi.c b/package/iwinfo/src/iwinfo_madwifi.c index feb98e25a..732cfe56f 100644 --- a/package/iwinfo/src/iwinfo_madwifi.c +++ b/package/iwinfo/src/iwinfo_madwifi.c @@ -988,25 +988,131 @@ int madwifi_get_mbssid_support(const char *ifname, int *buf) return -1; } +static void madwifi_proc_file(const char *ifname, const char *file, + char *buf, int blen) +{ + int fd; + const char *wifi = madwifi_isvap(ifname, NULL); + + if (!wifi && madwifi_iswifi(ifname)) + wifi = ifname; + + snprintf(buf, blen, "/proc/sys/dev/%s/%s", wifi, file); + + if ((fd = open(buf, O_RDONLY)) > 0) + { + if (read(fd, buf, blen) > 1) + buf[strlen(buf)-1] = 0; + else + buf[0] = 0; + + close(fd); + } + else + { + buf[0] = 0; + } +} + +static int madwifi_startswith(const char *a, const char *b) +{ + int l1 = strlen(a); + int l2 = strlen(b); + int ln = (l1 < l2) ? l1 : l2; + return !strncmp(a, b, ln); +} + int madwifi_get_hardware_id(const char *ifname, char *buf) { - return wext_get_hardware_id(ifname, buf); + char vendor[64]; + char device[64]; + struct iwinfo_hardware_id *ids; + struct iwinfo_hardware_entry *e; + + if (wext_get_hardware_id(ifname, buf)) + { + ids = (struct iwinfo_hardware_id *)buf; + madwifi_proc_file(ifname, "dev_vendor", vendor, sizeof(vendor)); + madwifi_proc_file(ifname, "dev_name", device, sizeof(device)); + + if (vendor[0] && device[0]) + { + for (e = IWINFO_HARDWARE_ENTRIES; e->vendor_name; e++) + { + if (!madwifi_startswith(vendor, e->vendor_name)) + continue; + + if (!madwifi_startswith(device, e->device_name)) + continue; + + ids->vendor_id = e->vendor_id; + ids->device_id = e->device_id; + ids->subsystem_vendor_id = e->subsystem_vendor_id; + ids->subsystem_device_id = e->subsystem_device_id; + + return 0; + } + } + + return -1; + } + + return 0; } -int madwifi_get_hardware_name(const char *ifname, char *buf) +static const struct iwinfo_hardware_entry * +madwifi_get_hardware_entry(const char *ifname) { struct iwinfo_hardware_id id; - struct iwinfo_hardware_entry *hw; if (madwifi_get_hardware_id(ifname, (char *)&id)) - return -1; + return NULL; + + return iwinfo_hardware(&id); +} - hw = iwinfo_hardware(&id); +int madwifi_get_hardware_name(const char *ifname, char *buf) +{ + char vendor[64]; + char device[64]; + const struct iwinfo_hardware_entry *hw; - if (hw) - sprintf(buf, "%s %s", hw->vendor_name, hw->device_name); + if (!(hw = madwifi_get_hardware_entry(ifname))) + { + madwifi_proc_file(ifname, "dev_vendor", vendor, sizeof(vendor)); + madwifi_proc_file(ifname, "dev_name", device, sizeof(device)); + + if (vendor[0] && device[0]) + sprintf(buf, "%s %s", vendor, device); + else + sprintf(buf, "Generic Atheros"); + } else - sprintf(buf, "Generic Atheros"); + { + sprintf(buf, "%s %s", hw->vendor_name, hw->device_name); + } + + return 0; +} + +int madwifi_get_txpower_offset(const char *ifname, int *buf) +{ + const struct iwinfo_hardware_entry *hw; + + if (!(hw = madwifi_get_hardware_entry(ifname))) + return -1; + + *buf = hw->txpower_offset; + return 0; +} + +int madwifi_get_frequency_offset(const char *ifname, int *buf) +{ + const struct iwinfo_hardware_entry *hw; + + if (!(hw = madwifi_get_hardware_entry(ifname))) + return -1; + *buf = hw->frequency_offset; return 0; }