Reflect latest interface changes.
2000-02-13 Martin Baulig <martin@home-of-linux.org> * netinfo.c: Reflect latest interface changes.
This commit is contained in:
committed by
Martin Baulig
parent
3fec7a0946
commit
44027f6bd2
@@ -1,3 +1,7 @@
|
|||||||
|
2000-02-13 Martin Baulig <martin@home-of-linux.org>
|
||||||
|
|
||||||
|
* netinfo.c: Reflect latest interface changes.
|
||||||
|
|
||||||
2000-02-13 Martin Baulig <martin@home-of-linux.org>
|
2000-02-13 Martin Baulig <martin@home-of-linux.org>
|
||||||
|
|
||||||
* *.c: kvm_nlist () returns -1 on error, but a positive return value
|
* *.c: kvm_nlist () returns -1 on error, but a positive return value
|
||||||
|
@@ -25,6 +25,7 @@
|
|||||||
|
|
||||||
#include <glibtop.h>
|
#include <glibtop.h>
|
||||||
#include <glibtop/error.h>
|
#include <glibtop/error.h>
|
||||||
|
#include <glibtop/xmalloc.h>
|
||||||
#include <glibtop/netinfo.h>
|
#include <glibtop/netinfo.h>
|
||||||
|
|
||||||
#include <glibtop_suid.h>
|
#include <glibtop_suid.h>
|
||||||
@@ -42,9 +43,7 @@
|
|||||||
|
|
||||||
static const unsigned long _glibtop_sysdeps_netinfo =
|
static const unsigned long _glibtop_sysdeps_netinfo =
|
||||||
(1L << GLIBTOP_NETINFO_IF_FLAGS) +
|
(1L << GLIBTOP_NETINFO_IF_FLAGS) +
|
||||||
(1L << GLIBTOP_NETINFO_MTU) +
|
(1L << GLIBTOP_NETINFO_MTU);
|
||||||
(1L << GLIBTOP_NETINFO_SUBNET) +
|
|
||||||
(1L << GLIBTOP_NETINFO_ADDRESS);
|
|
||||||
|
|
||||||
/* nlist structure for kernel access */
|
/* nlist structure for kernel access */
|
||||||
static struct nlist nlst [] = {
|
static struct nlist nlst [] = {
|
||||||
@@ -65,15 +64,12 @@ glibtop_init_netinfo_p (glibtop *server)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Provides Network statistics. */
|
static int
|
||||||
|
_netinfo_ipv4 (glibtop *server, glibtop_netinfo *buf,
|
||||||
int
|
const char *interface, glibtop_ifaddr *address)
|
||||||
glibtop_get_netinfo_p (glibtop *server, glibtop_netinfo *buf,
|
|
||||||
const char *interface, unsigned transport)
|
|
||||||
{
|
{
|
||||||
struct ifnet ifnet;
|
struct ifnet ifnet;
|
||||||
u_long ifnetaddr, ifnetfound, ifaddraddr;
|
u_long ifnetaddr, ifnetfound, ifaddraddr;
|
||||||
struct sockaddr *sa;
|
|
||||||
char tname [16];
|
char tname [16];
|
||||||
|
|
||||||
union {
|
union {
|
||||||
@@ -81,13 +77,11 @@ glibtop_get_netinfo_p (glibtop *server, glibtop_netinfo *buf,
|
|||||||
struct in_ifaddr in;
|
struct in_ifaddr in;
|
||||||
} ifaddr;
|
} ifaddr;
|
||||||
|
|
||||||
glibtop_init_p (server, (1L << GLIBTOP_SYSDEPS_NETINFO), 0);
|
|
||||||
|
|
||||||
memset (buf, 0, sizeof (glibtop_netinfo));
|
|
||||||
|
|
||||||
if (kvm_read (server->_priv->machine.kd, nlst [0].n_value,
|
if (kvm_read (server->_priv->machine.kd, nlst [0].n_value,
|
||||||
&ifnetaddr, sizeof (ifnetaddr)) != sizeof (ifnetaddr))
|
&ifnetaddr, sizeof (ifnetaddr)) != sizeof (ifnetaddr)) {
|
||||||
glibtop_error_io_r (server, "kvm_read (ifnet)");
|
glibtop_warn_io_r (server, "kvm_read (ifnet)");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
ifaddraddr = 0;
|
ifaddraddr = 0;
|
||||||
while (ifnetaddr || ifaddraddr) {
|
while (ifnetaddr || ifaddraddr) {
|
||||||
@@ -98,13 +92,17 @@ glibtop_get_netinfo_p (glibtop *server, glibtop_netinfo *buf,
|
|||||||
ifnetfound = ifnetaddr;
|
ifnetfound = ifnetaddr;
|
||||||
|
|
||||||
if (kvm_read (server->_priv->machine.kd, ifnetaddr, &ifnet,
|
if (kvm_read (server->_priv->machine.kd, ifnetaddr, &ifnet,
|
||||||
sizeof (ifnet)) != sizeof (ifnet))
|
sizeof (ifnet)) != sizeof (ifnet)) {
|
||||||
glibtop_error_io_r (server, "kvm_read (ifnetaddr)");
|
glibtop_warn_io_r (server, "kvm_read (ifnetaddr)");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
#if defined(__FreeBSD__) || defined(__bsdi__)
|
#if defined(__FreeBSD__) || defined(__bsdi__)
|
||||||
if (kvm_read (server->_priv->machine.kd, (u_long) ifnet.if_name,
|
if (kvm_read (server->_priv->machine.kd, (u_long) ifnet.if_name,
|
||||||
tname, 16) != 16)
|
tname, 16) != 16) {
|
||||||
glibtop_error_io_r (server, "kvm_read (if_name)");
|
glibtop_warn_io_r (server, "kvm_read (if_name)");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
#else
|
#else
|
||||||
strncpy (tname, ifnet.if_xname, 16);
|
strncpy (tname, ifnet.if_xname, 16);
|
||||||
tname [15] = 0;
|
tname [15] = 0;
|
||||||
@@ -120,13 +118,18 @@ glibtop_get_netinfo_p (glibtop *server, glibtop_netinfo *buf,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (ifaddraddr) {
|
if (ifaddraddr) {
|
||||||
|
struct sockaddr *sa;
|
||||||
|
|
||||||
if ((kvm_read (server->_priv->machine.kd, ifaddraddr, &ifaddr,
|
if ((kvm_read (server->_priv->machine.kd, ifaddraddr, &ifaddr,
|
||||||
sizeof (ifaddr)) != sizeof (ifaddr)))
|
sizeof (ifaddr)) != sizeof (ifaddr))) {
|
||||||
glibtop_error_io_r (server, "kvm_read (ifaddraddr)");
|
glibtop_warn_io_r (server, "kvm_read (ifaddraddr)");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
#define CP(x) ((char *)(x))
|
#define CP(x) ((char *)(x))
|
||||||
cp = (CP(ifaddr.ifa.ifa_addr) - CP(ifaddraddr)) +
|
|
||||||
CP(&ifaddr); sa = (struct sockaddr *)cp;
|
cp = (CP(ifaddr.ifa.ifa_addr) - CP(ifaddraddr)) + CP(&ifaddr);
|
||||||
|
sa = (struct sockaddr *)cp;
|
||||||
|
|
||||||
if (!strcmp (interface, tname) && (sa->sa_family == AF_INET)) {
|
if (!strcmp (interface, tname) && (sa->sa_family == AF_INET)) {
|
||||||
sin = (struct sockaddr_in *)sa;
|
sin = (struct sockaddr_in *)sa;
|
||||||
@@ -166,13 +169,19 @@ glibtop_get_netinfo_p (glibtop *server, glibtop_netinfo *buf,
|
|||||||
if (ifnet.if_flags & IFF_MULTICAST)
|
if (ifnet.if_flags & IFF_MULTICAST)
|
||||||
buf->if_flags |= GLIBTOP_IF_FLAGS_MULTICAST;
|
buf->if_flags |= GLIBTOP_IF_FLAGS_MULTICAST;
|
||||||
|
|
||||||
buf->subnet = htonl (ifaddr.in.ia_subnet);
|
|
||||||
buf->address = sin->sin_addr.s_addr;
|
|
||||||
|
|
||||||
buf->mtu = ifnet.if_mtu;
|
buf->mtu = ifnet.if_mtu;
|
||||||
|
|
||||||
buf->flags = _glibtop_sysdeps_netinfo;
|
buf->flags = _glibtop_sysdeps_netinfo;
|
||||||
return -1;
|
|
||||||
|
address->subnet = htonl (ifaddr.in.ia_subnet);
|
||||||
|
address->flags |= (1L << GLIBTOP_IFADDR_SUBNET);
|
||||||
|
|
||||||
|
address->addr_len = 4;
|
||||||
|
memcpy (&address->address, &sin->sin_addr.s_addr, 4);
|
||||||
|
|
||||||
|
address->flags |= (1L << GLIBTOP_IFADDR_ADDRESS);
|
||||||
|
address->flags |= (1L << GLIBTOP_IFADDR_ADDR_LEN);
|
||||||
|
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined(__FreeBSD__) && (__FreeBSD_version >= 300000)
|
#if defined(__FreeBSD__) && (__FreeBSD_version >= 300000)
|
||||||
@@ -195,3 +204,35 @@ glibtop_get_netinfo_p (glibtop *server, glibtop_netinfo *buf,
|
|||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Provides Network statistics. */
|
||||||
|
|
||||||
|
glibtop_ifaddr *
|
||||||
|
glibtop_get_netinfo_p (glibtop *server, glibtop_array *array,
|
||||||
|
glibtop_netinfo *buf, const char *interface,
|
||||||
|
u_int64_t transport)
|
||||||
|
{
|
||||||
|
glibtop_ifaddr address, *retval = NULL;
|
||||||
|
|
||||||
|
glibtop_init_p (server, (1L << GLIBTOP_SYSDEPS_NETINFO), 0);
|
||||||
|
|
||||||
|
memset (buf, 0, sizeof (glibtop_netinfo));
|
||||||
|
memset (&address, 0, sizeof (glibtop_ifaddr));
|
||||||
|
|
||||||
|
if (transport & GLIBTOP_TRANSPORT_IPV4) {
|
||||||
|
/* IPv4 */
|
||||||
|
|
||||||
|
if (!_netinfo_ipv4 (server, buf, interface, &address)) {
|
||||||
|
retval = glibtop_calloc_r (server, 1, sizeof (glibtop_ifaddr));
|
||||||
|
*retval = address;
|
||||||
|
|
||||||
|
array->number = 1;
|
||||||
|
array->size = sizeof (glibtop_ifaddr);
|
||||||
|
array->total = array->number * array->size;
|
||||||
|
|
||||||
|
return retval;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
Reference in New Issue
Block a user