/* $Id$ */ /* Copyright (C) 1998-99 Martin Baulig This file is part of LibGTop 1.0. Contributed by Martin Baulig , October 1998. LibGTop is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. LibGTop is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with LibGTop; see the file COPYING. If not, write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ #include #include #include #include #include #include #include #include #include #include #if !defined (_LIBC) && defined (__GNU_LIBRARY__) && __GNU_LIBRARY__ > 1 /* GNU LibC */ #include #include #include #include #include #include #include #else /* Libc 5 */ #include #include #include #include #include #include #endif static const unsigned long _glibtop_sysdeps_netload = (1L << GLIBTOP_NETLOAD_BYTES_IN) + (1L << GLIBTOP_NETLOAD_BYTES_OUT) + (1L << GLIBTOP_NETLOAD_BYTES_TOTAL) + (1L << GLIBTOP_NETLOAD_PACKETS_IN) + (1L << GLIBTOP_NETLOAD_PACKETS_OUT) + (1L << GLIBTOP_NETLOAD_PACKETS_TOTAL) + (1L << GLIBTOP_NETLOAD_ERRORS_IN) + (1L << GLIBTOP_NETLOAD_ERRORS_OUT) + (1L << GLIBTOP_NETLOAD_ERRORS_TOTAL) + (1L << GLIBTOP_NETLOAD_COLLISIONS); /* Init function. */ void glibtop_init_netload_s (glibtop *server) { server->sysdeps.netload = _glibtop_sysdeps_netload; } /* Provides network statistics. */ void glibtop_get_netload_s (glibtop *server, glibtop_netload *buf, const char *interface) { libgtop_netload_t netload; int skfd; memset (buf, 0, sizeof (glibtop_netload)); skfd = socket (AF_INET, SOCK_DGRAM, 0); if (skfd) { struct ifreq ifr; struct sockaddr_in addr; char *address; unsigned flags; strcpy (ifr.ifr_name, interface); if (!ioctl (skfd, SIOCGIFFLAGS, &ifr)) { buf->flags |= (1L << GLIBTOP_NETLOAD_IF_FLAGS); flags = ifr.ifr_flags; } else flags = 0; 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_MULTICAST) buf->if_flags |= (1L << GLIBTOP_IF_FLAGS_MULTICAST); strcpy (ifr.ifr_name, interface); if (!ioctl (skfd, SIOCGIFADDR, &ifr)) { struct sockaddr_in addr = *(struct sockaddr_in *) &ifr.ifr_addr; buf->address = addr.sin_addr.s_addr; buf->flags |= (1L << GLIBTOP_NETLOAD_ADDRESS); } strcpy (ifr.ifr_name, interface); if (!ioctl (skfd, SIOCGIFNETMASK, &ifr)) { struct sockaddr_in addr = *(struct sockaddr_in *) &ifr.ifr_addr; buf->subnet = addr.sin_addr.s_addr; buf->flags |= (1L << GLIBTOP_NETLOAD_SUBNET); } strcpy (ifr.ifr_name, interface); if (!ioctl (skfd, SIOCGIFMTU, &ifr)) { buf->mtu = ifr.ifr_mtu; buf->flags |= (1L << GLIBTOP_NETLOAD_MTU); } close (skfd); } if (glibtop_get_proc_data_netload_s (server, &netload, interface)) return; buf->bytes_in = netload.rx_bytes; buf->bytes_out = netload.tx_bytes; buf->bytes_total = buf->bytes_in + buf->bytes_out; buf->packets_in = netload.rx_packets; buf->packets_out = netload.tx_packets; buf->packets_total = buf->packets_in + buf->packets_out; buf->errors_in = netload.rx_errors; buf->errors_out = netload.tx_errors; buf->errors_total = buf->errors_in + buf->errors_out; buf->collisions = netload.collisions; buf->flags |= _glibtop_sysdeps_netload; }