diff options
author | Felix Fietkau <nbd@openwrt.org> | 2012-01-19 17:14:52 +0100 |
---|---|---|
committer | Felix Fietkau <nbd@openwrt.org> | 2012-01-19 17:14:52 +0100 |
commit | fcbec58e1494281dfeb2f19576c52667a512fad2 (patch) | |
tree | f302b217dc2f0d81ad2c39e6430f34420b26ff8f /system-linux.c | |
parent | 395891b0e4c67591523dd0e2c2ac0c8aa22e88e7 (diff) |
export carrier status in device stats
Diffstat (limited to 'system-linux.c')
-rw-r--r-- | system-linux.c | 68 |
1 files changed, 49 insertions, 19 deletions
diff --git a/system-linux.c b/system-linux.c index 4a3de8c..f2ee10a 100644 --- a/system-linux.c +++ b/system-linux.c @@ -639,7 +639,51 @@ system_if_get_parent(struct device *dev) return device_get(devname, true); } -int system_if_dump_stats(struct device *dev, struct blob_buf *b) +static bool +read_int_file(int dir_fd, const char *file, int *val) +{ + char buf[64]; + int len, fd; + bool ret = false; + + fd = openat(dir_fd, file, O_RDONLY); + if (fd < 0) + return false; + +retry: + len = read(fd, buf, sizeof(buf)); + if (len < 0) { + if (errno == EINTR) + goto retry; + } else if (len > 0) { + buf[len] = 0; + *val = strtoul(buf, NULL, 0); + ret = true; + } + + close(fd); + + return ret; +} + +int +system_if_dump_info(struct device *dev, struct blob_buf *b) +{ + char buf[64]; + int dir_fd, val = 0; + + snprintf(buf, sizeof(buf), "/sys/class/net/%s", dev->ifname); + dir_fd = open(buf, O_DIRECTORY); + + if (read_int_file(dir_fd, "carrier", &val)) + blobmsg_add_u8(b, "link", !!val); + + close(dir_fd); + return 0; +} + +int +system_if_dump_stats(struct device *dev, struct blob_buf *b) { const char *const counters[] = { "collisions", "rx_frame_errors", "tx_compressed", @@ -653,30 +697,16 @@ int system_if_dump_stats(struct device *dev, struct blob_buf *b) }; char buf[64]; int stats_dir; - int i, fd, len; + int i, val = 0; snprintf(buf, sizeof(buf), "/sys/class/net/%s/statistics", dev->ifname); stats_dir = open(buf, O_DIRECTORY); if (stats_dir < 0) return -1; - for (i = 0; i < ARRAY_SIZE(counters); i++) { - fd = openat(stats_dir, counters[i], O_RDONLY); - if (fd < 0) - continue; - -retry: - len = read(fd, buf, sizeof(buf)); - if (len < 0) { - if (errno == EINTR) - goto retry; - continue; - } - - buf[len] = 0; - blobmsg_add_u32(b, counters[i], strtoul(buf, NULL, 0)); - close(fd); - } + for (i = 0; i < ARRAY_SIZE(counters); i++) + if (read_int_file(stats_dir, counters[i], &val)) + blobmsg_add_u32(b, counters[i], val); close(stats_dir); return 0; |