aboutsummaryrefslogtreecommitdiffstats
path: root/net/pload/files
diff options
context:
space:
mode:
authorpav <pav@FreeBSD.org>2004-10-19 04:41:21 +0800
committerpav <pav@FreeBSD.org>2004-10-19 04:41:21 +0800
commitfcb3d9a697b2570c09a7ea27ad855675797d59d5 (patch)
tree5c3d7383802d3cd7c4f49bf38886d44d585f0fea /net/pload/files
parentabc533dd640e99ae8b8fa4cf0374084962cd8ae5 (diff)
downloadfreebsd-ports-gnome-fcb3d9a697b2570c09a7ea27ad855675797d59d5.tar.gz
freebsd-ports-gnome-fcb3d9a697b2570c09a7ea27ad855675797d59d5.tar.zst
freebsd-ports-gnome-fcb3d9a697b2570c09a7ea27ad855675797d59d5.zip
Add pload, an X11 program to monitor network device statistics.
It graphs information using Athena stripchart widgets. PR: ports/72013 Submitted by: J.R. Oldroyd <fbsd@opal.com>
Diffstat (limited to 'net/pload/files')
-rw-r--r--net/pload/files/patch-Imakefile20
-rw-r--r--net/pload/files/patch-ioctl_stats.c80
-rw-r--r--net/pload/files/patch-pload.c73
-rw-r--r--net/pload/files/patch-pload.man33
4 files changed, 206 insertions, 0 deletions
diff --git a/net/pload/files/patch-Imakefile b/net/pload/files/patch-Imakefile
new file mode 100644
index 000000000000..ae8cc75f98c7
--- /dev/null
+++ b/net/pload/files/patch-Imakefile
@@ -0,0 +1,20 @@
+diff -c Imakefile.orig Imakefile
+*** Imakefile.orig Tue Feb 1 02:11:24 2000
+--- Imakefile Tue Aug 3 10:02:12 2004
+***************
+*** 15,21 ****
+
+ ComplexProgramTarget(pload)
+
+! distclean: clean
+ $(RM) Makefile osdefs.mk core \
+ pload-$(VER).tar.gz \
+ pload-$(VER)-1.i386.rpm \
+--- 15,21 ----
+
+ ComplexProgramTarget(pload)
+
+! distclean:: clean
+ $(RM) Makefile osdefs.mk core \
+ pload-$(VER).tar.gz \
+ pload-$(VER)-1.i386.rpm \
diff --git a/net/pload/files/patch-ioctl_stats.c b/net/pload/files/patch-ioctl_stats.c
new file mode 100644
index 000000000000..ba61ce4d94bc
--- /dev/null
+++ b/net/pload/files/patch-ioctl_stats.c
@@ -0,0 +1,80 @@
+--- ioctl_stat.c.orig Tue Feb 1 08:11:24 2000
++++ ioctl_stat.c Mon Oct 18 22:32:49 2004
+@@ -30,6 +30,12 @@
+ #include <fcntl.h> /* open */
+ #include <sys/ioctl.h> /* ioctl */
+ #include <errno.h>
++#ifdef __FreeBSD__
++#include <sys/sysctl.h>
++#include <sys/socket.h>
++#include <net/if.h>
++#include <net/if_mib.h>
++#endif
+
+ #ifndef STREAMS /* Linux, FreeBSD, NetBSD, Ultrix */
+ # include <sys/socket.h> /* socket */
+@@ -63,6 +69,16 @@
+ struct ifreq ifr;
+ struct ifpppstatsreq req;
+
++#ifdef __FreeBSD__
++ static int if_ix = -1;
++ struct ifmibdata ifmd;
++ size_t ifmd_sz = sizeof(ifmd);
++ int nr_ifs;
++ size_t nr_ifs_sz = sizeof(nr_ifs);
++ int name[6];
++ int i;
++#endif
++
+ if (!ifd->s) getsocket(ifd);
+
+ memset(&ifr, 0, sizeof(ifr));
+@@ -84,18 +100,36 @@
+ #define ifr_name ifr__name
+ #endif
+
+- strncpy(req.ifr_name, ifd->device, sizeof(req.ifr_name));
+- if (ioctl(ifd->s, SIOCGPPPSTATS, &req) != 0)
+- {
+- /* shouldn't fail if SIOCGIFFLAGS worked... */
+- ifd->in_bytes = 0UL;
+- ifd->out_bytes = 0UL;
+- return;
++#ifdef __FreeBSD__
++ name[0] = CTL_NET;
++ name[1] = PF_LINK;
++ name[2] = NETLINK_GENERIC;
++ name[3] = IFMIB_IFDATA;
++ name[5] = IFDATA_GENERAL;
++
++ if (if_ix < 0) {
++ if (sysctlbyname("net.link.generic.system.ifcount", (void *) &nr_ifs, &nr_ifs_sz, (void *) 0, 0) < 0) {
++ return;
++ }
++ for (i = 1; i <= nr_ifs; i++) {
++ name[4] = i; /* row of the ifmib table */
++
++ if (sysctl(name, 6, (void *) &ifmd, &ifmd_sz, (void *) 0, 0) < 0) {
++ continue;
++ }
++ if (strncmp(ifmd.ifmd_name, ifr.ifr_name, strlen(ifr.ifr_name)) == 0) {
++ if_ix = i;
++ break;
++ }
++ }
+ }
+-
+- ifd->in_bytes = (unsigned long)req.stats.p.ppp_ibytes;
+- ifd->out_bytes = (unsigned long)req.stats.p.ppp_obytes;
+-
++ name[4] = if_ix;
++ if (sysctl(name, 6, (void *) &ifmd, &ifmd_sz, (void *) 0, 0) >= 0) {
++ ifd->in_bytes = ifmd.ifmd_data.ifi_ibytes;
++ ifd->out_bytes = ifmd.ifmd_data.ifi_obytes;
++ }
++#endif
++
+ return;
+ }
+
diff --git a/net/pload/files/patch-pload.c b/net/pload/files/patch-pload.c
new file mode 100644
index 000000000000..0fb88df906b1
--- /dev/null
+++ b/net/pload/files/patch-pload.c
@@ -0,0 +1,73 @@
+diff -c pload.c.orig pload.c
+*** pload.c.orig Tue Feb 1 02:11:24 2000
+--- pload.c Wed Sep 22 13:13:46 2004
+***************
+*** 596,608 ****
+ void do_total(char *b, double total)
+ {
+ if (total < 1024.0)
+! sprintf(b, "%s%0.0f b", b, total);
+ else if (total < (1024.0*1024.0))
+! sprintf(b, "%s%0.2f k", b, total/1024.0);
+ else if (total < (1024.0*1024.0*1024.0))
+! sprintf(b, "%s%0.2f M", b, total/1024.0/1024.0);
+ else
+! sprintf(b, "%s%0.2f G", b, total/1024.0/1024.0/1024.0);
+
+ return;
+ }
+--- 596,608 ----
+ void do_total(char *b, double total)
+ {
+ if (total < 1024.0)
+! sprintf(b, "%s%0.0f B", b, total);
+ else if (total < (1024.0*1024.0))
+! sprintf(b, "%s%0.2f kB", b, total/1024.0);
+ else if (total < (1024.0*1024.0*1024.0))
+! sprintf(b, "%s%0.2f MB", b, total/1024.0/1024.0);
+ else
+! sprintf(b, "%s%0.2f GB", b, total/1024.0/1024.0/1024.0);
+
+ return;
+ }
+***************
+*** 610,622 ****
+ void do_rate(char *b, double rate)
+ {
+ if (rate < 1024.0)
+! sprintf(b, "%s%0.0f b/s",b, rate);
+ else if (rate < (1024.0*1024.0))
+! sprintf(b, "%s%0.2f k/s",b, rate/1024.0);
+ else if (rate < (1024.0*1024.0*1024.0))
+! sprintf(b, "%s%0.2f M/s",b, rate/1024.0/1024.0);
+ else
+! sprintf(b, "%s%0.2f G/s", b, rate/1024.0/1024.0/1024.0);
+ return;
+ }
+
+--- 610,622 ----
+ void do_rate(char *b, double rate)
+ {
+ if (rate < 1024.0)
+! sprintf(b, "%s%0.0f B/s",b, rate);
+ else if (rate < (1024.0*1024.0))
+! sprintf(b, "%s%0.2f kB/s",b, rate/1024.0);
+ else if (rate < (1024.0*1024.0*1024.0))
+! sprintf(b, "%s%0.2f MB/s",b, rate/1024.0/1024.0);
+ else
+! sprintf(b, "%s%0.2f GB/s", b, rate/1024.0/1024.0/1024.0);
+ return;
+ }
+
+***************
+*** 643,648 ****
+--- 643,651 ----
+ break;
+ case 'M':
+ do_rate(buff, max);
++ break;
++ case 'd':
++ sprintf(buff, "%s", resources.device);
+ break;
+ case '%': /* literal % */
+ i = strlen(buff);
diff --git a/net/pload/files/patch-pload.man b/net/pload/files/patch-pload.man
new file mode 100644
index 000000000000..61c502ef5e87
--- /dev/null
+++ b/net/pload/files/patch-pload.man
@@ -0,0 +1,33 @@
+--- pload.man.orig Tue Feb 1 02:11:24 2000
++++ pload.man Wed Sep 22 16:44:12 2004
+@@ -18,7 +18,7 @@
+ .TH PLOAD 1 "" "January 2000"
+
+ .SH NAME
+-pload \- display ppp throughput statistics in an X window
++pload \- display network interface statistics in an X window
+
+ .SH SYNOPSIS
+ .ta 6n
+@@ -30,9 +30,9 @@
+ [-iformat \fIfmt\fP] [-oformat \fIfmt\fP]
+
+ .SH DESCRIPTION
+-The \fBpload\fP program displays information about network interface (ppp) statistics.
+-Additionally, for Linux 2.2 it can display statistics for any interface that
+-reports to /proc/net/dev .
++The \fBpload\fP program displays network throughput statistics in an X window
++Athena stripchart graph.
++On FreeBSD, \fBpload\fP can handle any network interface.
+
+ .SH OPTIONS
+ .PP
+@@ -144,7 +144,7 @@
+ .TP 8
+ .B \-iformat \fIfmt\fP
+ Use string \fIfmt\fP for the inbound label. The \fIfmt\fP string will be displayed
+-literally with the special tags %t %r and %M expanding to the interface total, current
++literally with the special tags %d %t %r and %M expanding to the interface name, interface total, current
+ rate, and maximum rate respectively. The default is "%t %r in".
+
+ .TP 8