diff options
author | kwm <kwm@df743ca5-7f9a-e211-a948-0013205c9059> | 2014-10-15 22:06:28 +0800 |
---|---|---|
committer | kwm <kwm@df743ca5-7f9a-e211-a948-0013205c9059> | 2014-10-15 22:06:28 +0800 |
commit | 4cf305668f62ed5b6dccdd29471cbeeb062cab9c (patch) | |
tree | 82781d7d668ba1d1e43988aca2ba1a10228b72a5 /devel | |
parent | 87d09faf2c081b7d69b2a69914ecca8fb9d68413 (diff) | |
download | marcuscom-ports-4cf305668f62ed5b6dccdd29471cbeeb062cab9c.tar marcuscom-ports-4cf305668f62ed5b6dccdd29471cbeeb062cab9c.tar.gz marcuscom-ports-4cf305668f62ed5b6dccdd29471cbeeb062cab9c.tar.bz2 marcuscom-ports-4cf305668f62ed5b6dccdd29471cbeeb062cab9c.tar.lz marcuscom-ports-4cf305668f62ed5b6dccdd29471cbeeb062cab9c.tar.xz marcuscom-ports-4cf305668f62ed5b6dccdd29471cbeeb062cab9c.tar.zst marcuscom-ports-4cf305668f62ed5b6dccdd29471cbeeb062cab9c.zip |
Fix libgtop after network related breakage in HEAD. And make it future proof
instead of digging though internals.
Submitted by: glebius@
git-svn-id: svn://creme-brulee.marcuscom.com/ports/trunk@19959 df743ca5-7f9a-e211-a948-0013205c9059
Diffstat (limited to 'devel')
-rw-r--r-- | devel/libgtop/Makefile | 2 | ||||
-rw-r--r-- | devel/libgtop/files/patch-sysdeps_freebsd_netload.c | 360 |
2 files changed, 335 insertions, 27 deletions
diff --git a/devel/libgtop/Makefile b/devel/libgtop/Makefile index f75d7f143..86cee1be4 100644 --- a/devel/libgtop/Makefile +++ b/devel/libgtop/Makefile @@ -4,7 +4,7 @@ PORTNAME= libgtop PORTVERSION= 2.30.0 -PORTREVISION= 1 +PORTREVISION= 2 CATEGORIES= devel gnome MASTER_SITES= GNOME DIST_SUBDIR= gnome2 diff --git a/devel/libgtop/files/patch-sysdeps_freebsd_netload.c b/devel/libgtop/files/patch-sysdeps_freebsd_netload.c index 51cc5d237..19d810866 100644 --- a/devel/libgtop/files/patch-sysdeps_freebsd_netload.c +++ b/devel/libgtop/files/patch-sysdeps_freebsd_netload.c @@ -1,32 +1,340 @@ ---- sysdeps/freebsd/netload.c.orig 2013-11-13 14:46:58.000000000 -0500 -+++ sysdeps/freebsd/netload.c 2013-11-13 15:01:52.000000000 -0500 -@@ -37,6 +37,7 @@ - #include <net/if_types.h> - - #ifdef HAVE_NET_IF_VAR_H -+#define _WANT_IFADDR 1 - #include <net/if_var.h> - #endif - -@@ -116,7 +117,7 @@ glibtop_get_netload_p (glibtop *server, - while (ifnetaddr) - { - struct sockaddr_in *sin; +--- sysdeps/freebsd/netload.c.orig 2014-10-02 18:05:51.932132157 +0200 ++++ sysdeps/freebsd/netload.c 2014-10-02 18:06:23.435130545 +0200 +@@ -1,7 +1,8 @@ +-/* Copyright (C) 1998-99 Martin Baulig ++/* Copyright (C) 2014 Gleb Smirnoff ++ Copyright (C) 1998-99 Martin Baulig + This file is part of LibGTop 1.0. + +- Contributed by Martin Baulig <martin@home-of-linux.org>, October 1998. ++ Contributed by Gleb Smirnoff <glebius@FreeBSD.org>, September 2014. + + LibGTop is free software; you can redistribute it and/or modify it + under the terms of the GNU General Public License as published by +@@ -26,22 +27,12 @@ + + #include <glibtop_suid.h> + +-#include <string.h> +- +-#include <sys/types.h> +-#include <sys/socket.h> + #include <sys/ioctl.h> +- ++#include <sys/sockio.h> ++#include <netinet/in.h> + #include <net/if.h> + #include <net/if_dl.h> +-#include <net/if_types.h> +- +-#ifdef HAVE_NET_IF_VAR_H +-#include <net/if_var.h> +-#endif +- +-#include <netinet/in.h> +-#include <netinet/in_var.h> ++#include <ifaddrs.h> + + static const unsigned long _glibtop_sysdeps_netload = + (1L << GLIBTOP_NETLOAD_IF_FLAGS) + +@@ -64,24 +55,9 @@ + (1L << GLIBTOP_NETLOAD_ADDRESS6) + + (1L << GLIBTOP_NETLOAD_SCOPE6); + +-/* nlist structure for kernel access */ +-static struct nlist nlst [] = +- { +- { "_ifnet" +- }, +- { 0 } +- }; +- +-/* Init function. */ +- + void + _glibtop_init_netload_p (glibtop *server) + { +- if (kvm_nlist (server->machine.kd, nlst) < 0) { +- glibtop_warn_io_r (server, "kvm_nlist"); +- return; +- } +- + server->sysdeps.netload = _glibtop_sysdeps_netload; + } + +@@ -91,164 +67,129 @@ + glibtop_get_netload_p (glibtop *server, glibtop_netload *buf, + const char *interface) + { +- struct ifnet ifnet; +- u_long ifnetaddr, ifnetfound; +- struct sockaddr *sa = NULL; +- char name [32]; +- +- union { +- struct ifaddr ifa; +- struct in_ifaddr in; +- } ifaddr; ++ struct ifaddrs *ifap, *ifa; + + glibtop_init_p (server, (1L << GLIBTOP_SYSDEPS_NETLOAD), 0); + + memset (buf, 0, sizeof (glibtop_netload)); + +- if (server->sysdeps.netload == 0) return; ++ if (server->sysdeps.netload == 0) ++ return; + +- if (kvm_read (server->machine.kd, nlst [0].n_value, +- &ifnetaddr, sizeof (ifnetaddr)) != sizeof (ifnetaddr)) { +- glibtop_warn_io_r (server, "kvm_read (ifnet)"); ++ if (getifaddrs(&ifap) != 0) { ++ glibtop_warn_io_r(server, "getifaddrs"); + return; + } + +- while (ifnetaddr) +- { +- struct sockaddr_in *sin; - register char *cp; -+ register uint8_t *cp; - u_long ifaddraddr; +- u_long ifaddraddr; +- +- { +- ifnetfound = ifnetaddr; +- +- if (kvm_read (server->machine.kd, ifnetaddr, &ifnet, +- sizeof (ifnet)) != sizeof (ifnet)) { +- glibtop_warn_io_r (server, +- "kvm_read (ifnetaddr)"); +- continue; +- } ++#define IFA_STAT(s) (((struct if_data *)ifa->ifa_data)->ifi_ ## s) - { -@@ -201,10 +202,10 @@ glibtop_get_netload_p (glibtop *server, - continue; +- g_strlcpy (name, ifnet.if_xname, sizeof(name)); +- ifnetaddr = (u_long) ifnet.if_link.tqe_next; ++ for (ifa = ifap; ifa; ifa = ifa->ifa_next) { + +- if (strcmp (name, interface) != 0) +- continue; ++ if (strcmp(ifa->ifa_name, interface) != 0) ++ continue; + +- ifaddraddr = (u_long) ifnet.if_addrhead.tqh_first; +- } +- if (ifnet.if_flags & IFF_UP) +- buf->if_flags |= (1L << GLIBTOP_IF_FLAGS_UP); +- if (ifnet.if_flags & IFF_BROADCAST) +- buf->if_flags |= (1L << GLIBTOP_IF_FLAGS_BROADCAST); +- if (ifnet.if_flags & IFF_DEBUG) +- buf->if_flags |= (1L << GLIBTOP_IF_FLAGS_DEBUG); +- if (ifnet.if_flags & IFF_LOOPBACK) +- buf->if_flags |= (1L << GLIBTOP_IF_FLAGS_LOOPBACK); +- if (ifnet.if_flags & IFF_POINTOPOINT) +- buf->if_flags |= (1L << GLIBTOP_IF_FLAGS_POINTOPOINT); +-#ifdef IFF_DRV_RUNNING +- if (ifnet.if_drv_flags & IFF_DRV_RUNNING) +-#else +- if (ifnet.if_flags & IFF_RUNNING) +-#endif +- buf->if_flags |= (1L << GLIBTOP_IF_FLAGS_RUNNING); +- if (ifnet.if_flags & IFF_NOARP) +- buf->if_flags |= (1L << GLIBTOP_IF_FLAGS_NOARP); +- if (ifnet.if_flags & IFF_PROMISC) +- buf->if_flags |= (1L << GLIBTOP_IF_FLAGS_PROMISC); +- if (ifnet.if_flags & IFF_ALLMULTI) +- buf->if_flags |= (1L << GLIBTOP_IF_FLAGS_ALLMULTI); +-#ifdef IFF_DRV_OACTIVE +- if (ifnet.if_drv_flags & IFF_DRV_OACTIVE) +-#else +- if (ifnet.if_flags & IFF_OACTIVE) +-#endif +- buf->if_flags |= (1L << GLIBTOP_IF_FLAGS_OACTIVE); +- if (ifnet.if_flags & IFF_SIMPLEX) +- buf->if_flags |= (1L << GLIBTOP_IF_FLAGS_SIMPLEX); +- if (ifnet.if_flags & IFF_LINK0) +- buf->if_flags |= (1L << GLIBTOP_IF_FLAGS_LINK0); +- if (ifnet.if_flags & IFF_LINK1) +- buf->if_flags |= (1L << GLIBTOP_IF_FLAGS_LINK1); +- if (ifnet.if_flags & IFF_LINK2) +- buf->if_flags |= (1L << GLIBTOP_IF_FLAGS_LINK2); +- if (ifnet.if_flags & IFF_ALTPHYS) +- buf->if_flags |= (1L << GLIBTOP_IF_FLAGS_ALTPHYS); +- if (ifnet.if_flags & IFF_MULTICAST) +- buf->if_flags |= (1L << GLIBTOP_IF_FLAGS_MULTICAST); +- +- buf->packets_in = ifnet.if_ipackets; +- buf->packets_out = ifnet.if_opackets; +- buf->packets_total = buf->packets_in + buf->packets_out; +- +- buf->bytes_in = ifnet.if_ibytes; +- buf->bytes_out = ifnet.if_obytes; +- buf->bytes_total = buf->bytes_in + buf->bytes_out; +- +- buf->errors_in = ifnet.if_ierrors; +- buf->errors_out = ifnet.if_oerrors; +- buf->errors_total = buf->errors_in + buf->errors_out; +- +- buf->collisions = ifnet.if_collisions; +- buf->flags = _glibtop_sysdeps_netload; +- +- while (ifaddraddr) { +- if ((kvm_read (server->machine.kd, ifaddraddr, &ifaddr, +- sizeof (ifaddr)) != sizeof (ifaddr))) { +- glibtop_warn_io_r (server, +- "kvm_read (ifaddraddr)"); +- continue; ++ switch (ifa->ifa_addr->sa_family) { ++ case AF_LINK: { ++ struct sockaddr_dl *sdl; ++ struct ifreq ifr; ++ int s, flags; ++ ++ s = socket(AF_INET, SOCK_DGRAM, 0); ++ if (s < 0) { ++ glibtop_warn_io_r(server, "socket(AF_INET)"); ++ break; ++ } ++ memset(&ifr, 0, sizeof(ifr)); ++ (void )strlcpy(ifr.ifr_name, ifa->ifa_name, ++ sizeof(ifr.ifr_name)); ++ if (ioctl(s, SIOCGIFFLAGS, (caddr_t)&ifr) < 0) { ++ glibtop_warn_io_r(server, ++ "ioctl(SIOCGIFFLAGS)"); ++ close(s); ++ break; } ++ close(s); ++ ++ flags = (ifr.ifr_flags & 0xffff) | ++ (ifr.ifr_flagshigh << 16); ++ ++ if (flags & IFF_UP) ++ buf->if_flags |= (1L << GLIBTOP_IF_FLAGS_UP); ++ if (flags & IFF_BROADCAST) ++ buf->if_flags |= (1L << GLIBTOP_IF_FLAGS_BROADCAST); ++ if (flags & IFF_DEBUG) ++ buf->if_flags |= (1L << GLIBTOP_IF_FLAGS_DEBUG); ++ if (flags & IFF_LOOPBACK) ++ buf->if_flags |= (1L << GLIBTOP_IF_FLAGS_LOOPBACK); ++ if (flags & IFF_POINTOPOINT) ++ buf->if_flags |= (1L << GLIBTOP_IF_FLAGS_POINTOPOINT); ++ if (flags & IFF_RUNNING) ++ buf->if_flags |= (1L << GLIBTOP_IF_FLAGS_RUNNING); ++ if (flags & IFF_NOARP) ++ buf->if_flags |= (1L << GLIBTOP_IF_FLAGS_NOARP); ++ if (flags & IFF_PROMISC) ++ buf->if_flags |= (1L << GLIBTOP_IF_FLAGS_PROMISC); ++ if (flags & IFF_ALLMULTI) ++ buf->if_flags |= (1L << GLIBTOP_IF_FLAGS_ALLMULTI); ++ if (flags & IFF_SIMPLEX) ++ buf->if_flags |= (1L << GLIBTOP_IF_FLAGS_SIMPLEX); ++ if (flags & IFF_LINK0) ++ buf->if_flags |= (1L << GLIBTOP_IF_FLAGS_LINK0); ++ if (flags & IFF_LINK1) ++ buf->if_flags |= (1L << GLIBTOP_IF_FLAGS_LINK1); ++ if (flags & IFF_LINK2) ++ buf->if_flags |= (1L << GLIBTOP_IF_FLAGS_LINK2); ++ if (flags & IFF_ALTPHYS) ++ buf->if_flags |= (1L << GLIBTOP_IF_FLAGS_ALTPHYS); ++ if (flags & IFF_MULTICAST) ++ buf->if_flags |= (1L << GLIBTOP_IF_FLAGS_MULTICAST); ++ ++ buf->packets_in = IFA_STAT(ipackets); ++ buf->packets_out = IFA_STAT(opackets); ++ buf->packets_total = buf->packets_in + buf->packets_out; ++ buf->bytes_in = IFA_STAT(ibytes); ++ buf->bytes_out = IFA_STAT(obytes); ++ buf->bytes_total = buf->bytes_in + buf->bytes_out; ++ buf->errors_in = IFA_STAT(ierrors); ++ buf->errors_out = IFA_STAT(oerrors); ++ buf->errors_total = buf->errors_in + buf->errors_out; ++ buf->collisions = IFA_STAT(collisions); ++ buf->flags = _glibtop_sysdeps_netload; ++ ++ sdl = (struct sockaddr_dl *)ifa->ifa_addr; ++ memcpy(buf->hwaddress, LLADDR(sdl), ++ sizeof(buf->hwaddress)); ++ buf->mtu = IFA_STAT(mtu); ++ buf->flags |= GLIBTOP_NETLOAD_HWADDRESS; ++ ++ break; ++ } ++ case AF_INET: { ++ struct sockaddr_in *sin; ++ ++ sin = (struct sockaddr_in *)ifa->ifa_addr; ++ buf->address = sin->sin_addr.s_addr; ++ sin = (struct sockaddr_in *)ifa->ifa_netmask; ++ buf->subnet = sin->sin_addr.s_addr & buf->address; ++ buf->flags |= _glibtop_sysdeps_netload_data; ++ break; ++ } ++ case AF_INET6: { ++ struct sockaddr_in6 *sin6; ++ ++ sin6 = (struct sockaddr_in6 *)ifa->ifa_addr; ++ memcpy(buf->address6, &sin6->sin6_addr, ++ sizeof(buf->address6)); ++ buf->scope6 = (guint8 )sin6->sin6_scope_id; ++ buf->flags |= _glibtop_sysdeps_netload6; ++ sin6 = (struct sockaddr_in6 *)ifa->ifa_netmask; ++ memcpy(buf->prefix6, &sin6->sin6_addr, ++ sizeof(buf->prefix6)); ++ buf->flags |= GLIBTOP_NETLOAD_PREFIX6; ++ break; ++ } ++ } ++ } -#define CP(x) ((char *)(x)) -+#define CP(x) ((uint8_t *)(x)) - cp = (CP(ifaddr.ifa.ifa_addr) - CP(ifaddraddr)) + - CP(&ifaddr); +- cp = (CP(ifaddr.ifa.ifa_addr) - CP(ifaddraddr)) + +- CP(&ifaddr); - sa = (struct sockaddr *)cp; -+ sa = (struct sockaddr *) cp; - - if (sa->sa_family == AF_LINK) { - struct sockaddr_dl *dl = (struct sockaddr_dl *) sa; +- +- if (sa->sa_family == AF_LINK) { +- struct sockaddr_dl *dl = (struct sockaddr_dl *) sa; +- +- memcpy (buf->hwaddress, LLADDR (dl), +- sizeof (buf->hwaddress)); +- buf->flags |= GLIBTOP_NETLOAD_HWADDRESS; +- } else if (sa->sa_family == AF_INET) { +- sin = (struct sockaddr_in *)sa; +- /* Commenting out to "fix" #13345. */ +- buf->subnet = htonl (ifaddr.in.ia_subnet); +- buf->address = sin->sin_addr.s_addr; +- buf->mtu = ifnet.if_mtu; +- +- buf->flags |= _glibtop_sysdeps_netload_data; +- } else if (sa->sa_family == AF_INET6) { +- struct sockaddr_in6 *sin6 = (struct sockaddr_in6 *) sa; +- int in6fd; +- +- memcpy (buf->address6, &sin6->sin6_addr, +- sizeof (buf->address6)); +- buf->scope6 = (guint8) sin6->sin6_scope_id; +- buf->flags |= _glibtop_sysdeps_netload6; +- +- in6fd = socket (AF_INET6, SOCK_DGRAM, 0); +- if (in6fd >= 0) { +- struct in6_ifreq ifr; +- +- memset (&ifr, 0, sizeof (ifr)); +- ifr.ifr_addr = *sin6; +- g_strlcpy (ifr.ifr_name, interface, +- sizeof (ifr.ifr_name)); +- if (ioctl (in6fd, SIOCGIFNETMASK_IN6, +- (char *) &ifr) >= 0) { +- memcpy (buf->prefix6, +- &ifr.ifr_addr.sin6_addr, +- sizeof (buf->prefix6)); +- buf->flags |= GLIBTOP_NETLOAD_PREFIX6; +- } +- close (in6fd); +- } +- } +- ifaddraddr = (u_long) ifaddr.ifa.ifa_link.tqe_next; +- } +- return; +- } ++ freeifaddrs(ifap); + } |