aboutsummaryrefslogtreecommitdiff
path: root/slstatus/components/netspeeds.c
diff options
context:
space:
mode:
Diffstat (limited to 'slstatus/components/netspeeds.c')
-rw-r--r--slstatus/components/netspeeds.c139
1 files changed, 0 insertions, 139 deletions
diff --git a/slstatus/components/netspeeds.c b/slstatus/components/netspeeds.c
deleted file mode 100644
index 0029177..0000000
--- a/slstatus/components/netspeeds.c
+++ /dev/null
@@ -1,139 +0,0 @@
-/* See LICENSE file for copyright and license details. */
-#include <stdio.h>
-#include <limits.h>
-
-#include "../util.h"
-
-#if defined(__linux__)
- #include <stdint.h>
-
- const char *
- netspeed_rx(const char *interface)
- {
- uintmax_t oldrxbytes;
- static uintmax_t rxbytes;
- extern const unsigned int interval;
- char path[PATH_MAX];
-
- oldrxbytes = rxbytes;
-
- if (esnprintf(path, sizeof(path),
- "/sys/class/net/%s/statistics/rx_bytes",
- interface) < 0) {
- return NULL;
- }
- if (pscanf(path, "%ju", &rxbytes) != 1) {
- return NULL;
- }
- if (oldrxbytes == 0) {
- return NULL;
- }
-
- return fmt_human((rxbytes - oldrxbytes) * 1000 / interval,
- 1024);
- }
-
- const char *
- netspeed_tx(const char *interface)
- {
- uintmax_t oldtxbytes;
- static uintmax_t txbytes;
- extern const unsigned int interval;
- char path[PATH_MAX];
-
- oldtxbytes = txbytes;
-
- if (esnprintf(path, sizeof(path),
- "/sys/class/net/%s/statistics/tx_bytes",
- interface) < 0) {
- return NULL;
- }
- if (pscanf(path, "%ju", &txbytes) != 1) {
- return NULL;
- }
- if (oldtxbytes == 0) {
- return NULL;
- }
-
- return fmt_human((txbytes - oldtxbytes) * 1000 / interval,
- 1024);
- }
-#elif defined(__OpenBSD__) | defined(__FreeBSD__)
- #include <string.h>
- #include <ifaddrs.h>
- #include <sys/types.h>
- #include <sys/socket.h>
- #include <net/if.h>
-
- const char *
- netspeed_rx(const char *interface)
- {
- struct ifaddrs *ifal, *ifa;
- struct if_data *ifd;
- uintmax_t oldrxbytes;
- static uintmax_t rxbytes;
- extern const unsigned int interval;
- int if_ok = 0;
-
- oldrxbytes = rxbytes;
-
- if (getifaddrs(&ifal) == -1) {
- warn("getifaddrs failed");
- return NULL;
- }
- rxbytes = 0;
- for (ifa = ifal; ifa; ifa = ifa->ifa_next) {
- if (!strcmp(ifa->ifa_name, interface) &&
- (ifd = (struct if_data *)ifa->ifa_data)) {
- rxbytes += ifd->ifi_ibytes, if_ok = 1;
- }
- }
- freeifaddrs(ifal);
- if (!if_ok) {
- warn("reading 'if_data' failed");
- return NULL;
- }
- if (oldrxbytes == 0) {
- return NULL;
- }
-
- return fmt_human((rxbytes - oldrxbytes) * 1000 / interval,
- 1024);
- }
-
- const char *
- netspeed_tx(const char *interface)
- {
- struct ifaddrs *ifal, *ifa;
- struct if_data *ifd;
- uintmax_t oldtxbytes;
- static uintmax_t txbytes;
- extern const unsigned int interval;
- int if_ok = 0;
-
- oldtxbytes = txbytes;
-
- if (getifaddrs(&ifal) == -1) {
- warn("getifaddrs failed");
- return NULL;
- }
- txbytes = 0;
- for (ifa = ifal; ifa; ifa = ifa->ifa_next) {
- if (!strcmp(ifa->ifa_name, interface) &&
- (ifd = (struct if_data *)ifa->ifa_data)) {
- txbytes += ifd->ifi_obytes, if_ok = 1;
- }
- }
- freeifaddrs(ifal);
- if (!if_ok) {
- warn("reading 'if_data' failed");
- return NULL;
- }
- if (oldtxbytes == 0) {
- return NULL;
- }
-
- return fmt_human((txbytes - oldtxbytes) * 1000 / interval,
- 1024);
- }
-#endif