diff options
author | joerg <joerg> | 2006-03-19 22:10:38 +0000 |
---|---|---|
committer | joerg <joerg> | 2006-03-19 22:10:38 +0000 |
commit | 9356f0bea2ca3d304f08f5540553a6c7f8f62d3a (patch) | |
tree | f4f371003ed0b2f75fbbcbedb5981c4ae8fb4be6 /sysutils/gkrellm | |
parent | e4dfb52911c94ad74b168c1d4fcdce7ab8f9ccfe (diff) | |
download | pkgsrc-9356f0bea2ca3d304f08f5540553a6c7f8f62d3a.tar.gz |
Add DragonFly support.
Diffstat (limited to 'sysutils/gkrellm')
-rw-r--r-- | sysutils/gkrellm/Makefile | 4 | ||||
-rw-r--r-- | sysutils/gkrellm/Makefile.common | 3 | ||||
-rw-r--r-- | sysutils/gkrellm/distinfo | 19 | ||||
-rw-r--r-- | sysutils/gkrellm/files/dragonfly.c | 1151 | ||||
-rw-r--r-- | sysutils/gkrellm/files/server.Makefile | 2 | ||||
-rw-r--r-- | sysutils/gkrellm/files/src.Makefile | 3 | ||||
-rw-r--r-- | sysutils/gkrellm/files/top.Makefile.inc | 9 | ||||
-rw-r--r-- | sysutils/gkrellm/patches/patch-aa | 13 | ||||
-rw-r--r-- | sysutils/gkrellm/patches/patch-ae | 39 | ||||
-rw-r--r-- | sysutils/gkrellm/patches/patch-aj | 15 | ||||
-rw-r--r-- | sysutils/gkrellm/patches/patch-ao | 24 | ||||
-rw-r--r-- | sysutils/gkrellm/patches/patch-ap | 32 | ||||
-rw-r--r-- | sysutils/gkrellm/patches/patch-ar | 13 | ||||
-rw-r--r-- | sysutils/gkrellm/patches/patch-au | 13 | ||||
-rw-r--r-- | sysutils/gkrellm/patches/patch-av | 19 | ||||
-rw-r--r-- | sysutils/gkrellm/patches/patch-aw | 13 | ||||
-rw-r--r-- | sysutils/gkrellm/patches/patch-ax | 13 | ||||
-rw-r--r-- | sysutils/gkrellm/patches/patch-ay | 17 |
18 files changed, 1362 insertions, 40 deletions
diff --git a/sysutils/gkrellm/Makefile b/sysutils/gkrellm/Makefile index 1f4401a013a..38d9f7d60f2 100644 --- a/sysutils/gkrellm/Makefile +++ b/sysutils/gkrellm/Makefile @@ -1,4 +1,4 @@ -# $NetBSD: Makefile,v 1.49 2006/02/05 23:10:50 joerg Exp $ +# $NetBSD: Makefile,v 1.50 2006/03/19 22:10:38 joerg Exp $ .include "Makefile.common" GKRELLM_PKGBASE= gkrellm @@ -14,7 +14,7 @@ USE_TOOLS+= pkg-config .include "../../mk/bsd.prefs.mk" # NetBSD 3.99.1 and above don't have to be installed setgid. -.if (${OPSYS} == "FreeBSD" || ${OPSYS} == "OpenBSD" || \ +.if (${OPSYS} == "FreeBSD" || ${OPSYS} == "OpenBSD" || ${OPSYS} == "DragonFly" || \ (${OPSYS} == "NetBSD" && (!empty(OS_VERSION:M[123]*) && empty(OS_VERSION:M3.99.*)))) SPECIAL_PERMS+= ${PREFIX}/bin/gkrellm ${ROOT_USER} kmem 2711 .endif diff --git a/sysutils/gkrellm/Makefile.common b/sysutils/gkrellm/Makefile.common index 3e985b8c964..849d5fd336c 100644 --- a/sysutils/gkrellm/Makefile.common +++ b/sysutils/gkrellm/Makefile.common @@ -1,4 +1,4 @@ -# $NetBSD: Makefile.common,v 1.13 2005/12/05 20:51:00 rillig Exp $ +# $NetBSD: Makefile.common,v 1.14 2006/03/19 22:10:38 joerg Exp $ DISTNAME= ${GKRELLM_DISTBASE} PKGNAME= ${GKRELLM_PKGBASE}-${GKRELLM_VERSION} @@ -35,3 +35,4 @@ post-extract: ${CP} ${FILESDIR}/po.Makefile ${WRKSRC}/po/Makefile ${CP} ${FILESDIR}/server.Makefile ${WRKSRC}/server/Makefile ${CP} ${FILESDIR}/src.Makefile ${WRKSRC}/src/Makefile + ${CP} ${FILESDIR}/dragonfly.c ${WRKSRC}/src/sysdeps diff --git a/sysutils/gkrellm/distinfo b/sysutils/gkrellm/distinfo index db9084a2056..626850385b9 100644 --- a/sysutils/gkrellm/distinfo +++ b/sysutils/gkrellm/distinfo @@ -1,23 +1,28 @@ -$NetBSD: distinfo,v 1.34 2005/09/08 13:19:56 cube Exp $ +$NetBSD: distinfo,v 1.35 2006/03/19 22:10:38 joerg Exp $ SHA1 (gkrellm-2.2.7.tar.bz2) = a6910b6f843868b4d801f7f7873e1e85c4f2039c RMD160 (gkrellm-2.2.7.tar.bz2) = 5388e3fba604a7c4b99a9c134ab6526296fe70d8 Size (gkrellm-2.2.7.tar.bz2) = 673728 bytes -SHA1 (patch-aa) = 9dbffbc0bc95ea3fced7162da0ec55333396d256 +SHA1 (patch-aa) = bc07107ed828a5a86012cae39316c1d35d2d7a4d SHA1 (patch-ab) = 015ed1c6b4d07d2da6aeefab2b746bff3fa1a88e SHA1 (patch-ac) = 8890d5a5e8eaf21508a1bf91de788183fd6f7a75 SHA1 (patch-ad) = 18218e5e9e7a8cfaabb20ec03865670ae66a15bd -SHA1 (patch-ae) = 5f7b1bdfa99bcec9cfdaee3a97b38b27581dd954 +SHA1 (patch-ae) = d9670d5956daaf768276a7b27b1831cbfc5cf4cb SHA1 (patch-ag) = 6791436e17fccd7265cda8b4e3da229c4937c20f SHA1 (patch-ah) = 2018be5c2dd11c22c6d3f7c7fc8607e2c63123f3 SHA1 (patch-ai) = 234e3e1e458e5709157668cf7d18faabdd076071 -SHA1 (patch-aj) = f61f36d1d82388e1d88eb78ec3107be4f8c9cf2b +SHA1 (patch-aj) = 224deaa57e7703f34a7911c63d2e6833862920c5 SHA1 (patch-ak) = b96987c120ca4c37c83075da61e8eb04e41d2023 SHA1 (patch-al) = 4eab3c3757c198dcc3049a63fc3b8adceef7bc1c SHA1 (patch-am) = bf8b01f5e368a5387f8d224ca51ec18a74410b5c SHA1 (patch-an) = 1e63ce0e4fbe9bd22c46d00c6aeac6b3e7cda440 -SHA1 (patch-ao) = 63bf8657fa7707def41b13b3cc74c031098e070a -SHA1 (patch-ap) = b3c89911085e73b8651e35f71b9561046b3cd073 +SHA1 (patch-ao) = afc56bb647c6b3bb9eba90b0b18d918dcf31a100 +SHA1 (patch-ap) = b2c33796fdfdc0166a869e528fcaab1f8f0ab615 SHA1 (patch-aq) = 0799e334333ae072a40cdcb6ccd04ed6a2f52765 -SHA1 (patch-ar) = eae37435d69b277f2542ee5ff26cbc772272689b +SHA1 (patch-ar) = 86ee88c8506c1ceb1d35eb488d209b16306a715d SHA1 (patch-as) = 3df33e28754cf1fee88717b431726bf090c15f70 +SHA1 (patch-au) = 27df64d854cb15202fa984170faeab4c128d5cad +SHA1 (patch-av) = 09cbc2fbb8226f8fe56bff458a4772998cae3f32 +SHA1 (patch-aw) = c32ae045dad9754edb88e375b8893cfe161567d0 +SHA1 (patch-ax) = 4377fa60acbc701c2cb78636574168820af2b936 +SHA1 (patch-ay) = bc512682f19631273a372581c6e091c7465e98d6 diff --git a/sysutils/gkrellm/files/dragonfly.c b/sysutils/gkrellm/files/dragonfly.c new file mode 100644 index 00000000000..990a008b5e6 --- /dev/null +++ b/sysutils/gkrellm/files/dragonfly.c @@ -0,0 +1,1151 @@ +/* GKrellM +| Copyright (C) 1999-2005 Bill Wilson +| +| Author: Bill Wilson bill@gkrellm.net +| Latest versions might be found at: http://gkrellm.net +| +| DragonFly code: Joerg Sonnenberger <joerg@bec.de> +| Derived from FreeBSD code: Hajimu UMEMOTO <ume@FreeBSD.org> +| +| This program is free software which I release under the GNU General Public +| License. You may redistribute and/or modify this program under the terms +| of that license as published by the Free Software Foundation; either +| version 2 of the License, or (at your option) any later version. +| +| This program 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. Version 2 is in the +| COPYRIGHT file in the top level directory of this distribution. +| +| To get a copy of the GNU General Puplic License, write to the Free Software +| Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA +*/ + +#include <kvm.h> + +kvm_t *kvmd = NULL; +char errbuf[_POSIX2_LINE_MAX]; + + +// extern gboolean force_meminfo_update(void); +#if defined(__i386__) +static void scan_for_sensors(); +#endif + + +void +gkrellm_sys_main_init(void) + { + /* We just ignore error, here. Even if GKrellM doesn't have + | kmem privilege, it runs with available information. + */ + kvmd = kvm_openfiles(NULL, NULL, NULL, O_RDONLY, errbuf); + if (setgid(getgid()) != 0) + { + fprintf(stderr, "Can't drop setgid privileges."); + exit(1); + } +#if defined(__i386__) + scan_for_sensors(); +#endif + if (setuid(getuid()) != 0) + { + fprintf(stderr, "Can't drop setuid privileges."); + exit(1); + } + } + +void +gkrellm_sys_main_cleanup(void) + { + } + +#include <sys/param.h> +#include <sys/sysctl.h> + +static int +gk_sysctlnametomib(const char *name, int *mibp, size_t *lenp) + { + static int oid_name2oid[2] = { 0, 3 }; + + if (sysctl(oid_name2oid, 2, mibp, lenp, + (void *)name, strlen(name)) < 0) + return -1; + *lenp /= sizeof(int); + return 0; + } + +/* ===================================================================== */ +/* CPU monitor interface */ + +#include <kinfo.h> +#include <kvm.h> + + +extern kvm_t *kvmd; + +void +gkrellm_sys_cpu_read_data(void) +{ + struct kinfo_cputime cp_time; + + if (kinfo_get_sched_cputime(&cp_time)) + return; + + gkrellm_cpu_assign_data(0, cp_time.cp_user, cp_time.cp_nice, + cp_time.cp_sys, cp_time.cp_idle); +} + +gboolean +gkrellm_sys_cpu_init(void) +{ + gkrellm_cpu_set_number_of_cpus(1); + return TRUE; +} + + +/* ===================================================================== */ +/* Proc monitor interface */ + +#include <osreldate.h> +#include <sys/sysctl.h> +#include <sys/user.h> + +/* + * This is ugly, but we need PID_MAX, in anyway. Since 5.0-RELEASE + * will have vm.stats.vm.v_forks, this will be obsolete in the future. + */ +#define PID_MAX 99999 + +#include <kvm.h> +#include <limits.h> +#include <paths.h> +#include <utmp.h> + +extern kvm_t *kvmd; + +static int oid_v_forks[CTL_MAXNAME + 2]; +static int oid_v_vforks[CTL_MAXNAME + 2]; +static int oid_v_rforks[CTL_MAXNAME + 2]; +static size_t oid_v_forks_len = sizeof(oid_v_forks); +static size_t oid_v_vforks_len = sizeof(oid_v_vforks); +static size_t oid_v_rforks_len = sizeof(oid_v_rforks); + +gboolean +gkrellm_sys_proc_init(void) + { + static const char *name = "vm.stats.vm.v_forks"; + static const char *vname = "vm.stats.vm.v_vforks"; + static const char *rname = "vm.stats.vm.v_rforks"; + + /* check if vm.stats.vm.v_forks is available */ + if (gk_sysctlnametomib(name, oid_v_forks, &oid_v_forks_len) < 0) + return FALSE; + if (gk_sysctlnametomib(vname, oid_v_vforks, &oid_v_vforks_len) < 0) + return FALSE; + if (gk_sysctlnametomib(rname, oid_v_rforks, &oid_v_rforks_len) < 0) + return FALSE; + return TRUE; + } + +void +gkrellm_sys_proc_read_data(void) + { + static int oid_proc[] = { CTL_KERN, KERN_PROC, KERN_PROC_ALL }; + double avenrun; + u_int n_forks, n_vforks, n_rforks, n_processes; + int r_forks, r_vforks, r_rforks; + size_t len; + + if (getloadavg(&avenrun, 1) <= 0) + avenrun = 0; + + /* We don't want to just use sysctlbyname(). Because, + * we call it so often. */ + len = sizeof(n_forks); + r_forks = sysctl(oid_v_forks, oid_v_forks_len, + &n_forks, &len, NULL, 0); + len = sizeof(n_vforks); + r_vforks = sysctl(oid_v_vforks, oid_v_vforks_len, + &n_vforks, &len, NULL, 0); + len = sizeof(n_rforks); + r_rforks = sysctl(oid_v_rforks, oid_v_rforks_len, + &n_rforks, &len, NULL, 0); + if (r_forks >= 0 && r_vforks >= 0 && r_rforks >= 0) + n_forks = n_forks + n_vforks + n_rforks; + else + n_forks = 0; + + if (sysctl(oid_proc, 3, NULL, &len, NULL, 0) >= 0) + n_processes = len / sizeof(struct kinfo_proc); + else + n_processes = 0; + gkrellm_proc_assign_data(n_processes, 0, n_forks, avenrun); + } + +void +gkrellm_sys_proc_read_users(void) + { + gint n_users; + struct stat sb, s; + gchar ttybuf[MAXPATHLEN]; + FILE *ut; + struct utmp utmp; + static time_t utmp_mtime; + + if (stat(_PATH_UTMP, &s) != 0 || s.st_mtime == utmp_mtime) + return; + if ((ut = fopen(_PATH_UTMP, "r")) != NULL) + { + n_users = 0; + while (fread(&utmp, sizeof(utmp), 1, ut)) + { + if (utmp.ut_name[0] == '\0') + continue; + (void)snprintf(ttybuf, sizeof(ttybuf), "%s/%s", + _PATH_DEV, utmp.ut_line); + /* corrupted record */ + if (stat(ttybuf, &sb)) + continue; + ++n_users; + } + (void)fclose(ut); + gkrellm_proc_assign_users(n_users); + } + utmp_mtime = s.st_mtime; + } + + +/* ===================================================================== */ +/* Disk monitor interface */ + +#include <devstat.h> +static struct statinfo statinfo_cur; + +gchar * +gkrellm_sys_disk_name_from_device(gint device_number, gint unit_number, + gint *order) + { + return NULL; /* Not implemented */ + } + +gint +gkrellm_sys_disk_order_from_name(gchar *name) + { + return -1; /* Append as added */ + } + +void +gkrellm_sys_disk_read_data(void) + { + int ndevs; + int num_selected; + int num_selections; + int maxshowdevs = 10; + struct device_selection *dev_select = NULL; + long select_generation; + int dn; + gchar name[32]; + + if (getdevs(&statinfo_cur) < 0) + return; + ndevs = statinfo_cur.dinfo->numdevs; + if (selectdevs(&dev_select, &num_selected, &num_selections, + &select_generation, statinfo_cur.dinfo->generation, + statinfo_cur.dinfo->devices, ndevs, + NULL, 0, NULL, 0, + DS_SELECT_ONLY, maxshowdevs, 1) >= 0) + { + for (dn = 0; dn < ndevs; ++dn) + { + int di; + struct devstat *dev; +// int block_size; +// int blocks_read, blocks_written; + + di = dev_select[dn].position; + dev = &statinfo_cur.dinfo->devices[di]; +// block_size = (dev->block_size > 0) +// ? dev->block_size : 512; +// blocks_read = dev->bytes_read / block_size; +// blocks_written = dev->bytes_written / block_size; + + /* to use gkrellm_disk_assign_data_by_device() would need + gkrellm_sys_disk_name_from_device() implemented */ + snprintf(name, sizeof(name), "%s%d", dev->device_name, + dev->unit_number); + gkrellm_disk_assign_data_by_name(name, + dev->bytes_read, dev->bytes_written, FALSE); + } + free(dev_select); + } + } + +gboolean +gkrellm_sys_disk_init(void) + { + bzero(&statinfo_cur, sizeof(statinfo_cur)); + statinfo_cur.dinfo = (struct devinfo *)malloc(sizeof(struct devinfo)); + bzero(statinfo_cur.dinfo, sizeof(struct devinfo)); + return TRUE; + } + + +/* ===================================================================== */ +/* Inet monitor interface */ + +#include "../inet.h" + +#include <netinet6/ip6_var.h> +#include <netinet/in_pcb.h> +#include <netinet/ip_var.h> +#include <netinet/ip6.h> +#include <netinet/tcp.h> +#include <netinet/tcpip.h> +#include <netinet/tcp_seq.h> +#include <netinet/tcp_fsm.h> +#include <netinet/tcp_timer.h> +#include <netinet/tcp_var.h> + + +void +gkrellm_sys_inet_read_tcp_data(void) + { + void *so_begin, *so_end; + struct xtcpcb *xtp; + struct inpcb *inp; + struct xsocket *so; + const char *varname, *protoname; + size_t len; + void *buf; + int vflag; + ActiveTCP tcp; + gint tcp_status; + + varname = "net.inet.tcp.pcblist"; + protoname = "tcp"; + + vflag = INP_IPV4 | INP_IPV6; + + buf = NULL; + len = 0; + + if (sysctlbyname(varname, NULL, &len, NULL, 0)) { + goto out; + } + if ((buf = malloc(len)) == NULL) + goto out; + if (sysctlbyname(varname, buf, &len, NULL, 0)) { + goto out; + + so_begin = buf; + so_end = (uint8_t *)buf + len; + + for (so_begin = buf, so_end = (uint8_t *)so_begin + len; + (uint8_t *)so_begin + sizeof(size_t) < (uint8_t *)so_end && + (uint8_t *)so_begin + *(size_t *)so_begin <= (uint8_t *)so_end; + so_begin = (uint8_t *)so_begin + *(size_t *)so_begin) { + xtp = (struct xtcpcb *)so_begin; + if (xtp->xt_len != sizeof *xtp) + goto out; + inp = &xtp->xt_inp; + so = &xtp->xt_socket; + if ((inp->inp_vflag & vflag) == 0) + continue; + if (inp->inp_vflag & INP_IPV4) { + tcp.remote_addr.s_addr = inp->inp_faddr.s_addr; + tcp.family = AF_INET; + } else if (inp->inp_vflag & INP_IPV6) { + memcpy(&tcp.remote_addr6, + &inp->in6p_faddr, + sizeof(struct in6_addr)); + tcp.family = AF_INET6; + } + + tcp.remote_port = ntohs(inp->inp_fport); + tcp.local_port = ntohs(inp->inp_lport); + tcp_status = (xtp->xt_tp.t_state == TCPS_ESTABLISHED); + if (tcp_status == TCP_ALIVE) + gkrellm_inet_log_tcp_port_data(&tcp); + } + } +out: + free(buf); + } + + +gboolean +gkrellm_sys_inet_init(void) + { + return TRUE; + } + + +/* ===================================================================== */ +/* Memory/Swap monitor interface */ + +#include <osreldate.h> +#include <kvm.h> +#include <limits.h> +#include <sys/conf.h> +#include <sys/vmmeter.h> +#include <sys/sysctl.h> +#include <vm/vm_param.h> + +extern char errbuf[]; + +static int +swapmode(guint64 *retavail, guint64 *retfree) + { + guint64 used, avail; + static int psize = -1; + struct kvm_swap kvmswap; + + /* + * Counter for error messages. If we reach the limit, + * stop reading information from swap devices and + * return zero. This prevent endless 'bad address' + * messages. + */ + static int warning = 10; + + if (warning <= 0) + { + /* a single warning */ + if (!warning) + { + warning--; + fprintf(stderr, "Too much errors, stop reading swap devices ...\n"); + } + return(0); + } + warning--; /* decrease counter, see end of function */ + + if (kvmd == NULL) + return(0); + if (kvm_getswapinfo(kvmd, &kvmswap, 1, 0) < 0) + { + fprintf(stderr, "kvm_getswapinfo failed\n"); + return(0); + } + + if (psize < 0) + psize = getpagesize(); + *retavail = avail = (quad_t)kvmswap.ksw_total * psize; + used = (quad_t)kvmswap.ksw_used * psize; + *retfree = avail - used; + + /* increase counter, no errors occurs */ + warning++; + + return (int)(((double)used / (double)avail * 100.0) + 0.5); + } + +static int +get_bufspace(guint64 *bufspacep) + { + static const char *name = "vfs.bufspace"; + static int oid_bufspace[CTL_MAXNAME + 2]; + static size_t oid_bufspace_len = sizeof(oid_bufspace); + static gint initialized = 0; + u_int bufspace; + size_t bufspace_len = sizeof(bufspace); + + if (!initialized) + { + if (gk_sysctlnametomib(name, oid_bufspace, + &oid_bufspace_len) < 0) + return 0; + ++initialized; + } + + if (sysctl(oid_bufspace, oid_bufspace_len, + &bufspace, &bufspace_len, 0, 0) < 0) + return 0; + *bufspacep = bufspace; + return 1; + } + +struct mibtab { + char *name; + int oid[CTL_MAXNAME + 2]; + size_t oid_len; + u_int value; + size_t value_len; +}; + +static struct mibtab mibs[] = { +#define MIB_V_PAGE_COUNT 0 + { "vm.stats.vm.v_page_count" }, +#define MIB_V_FREE_COUNT 1 + { "vm.stats.vm.v_free_count" }, +#define MIB_V_WIRE_COUNT 2 + { "vm.stats.vm.v_wire_count" }, +#define MIB_V_ACTIVE_COUNT 3 + { "vm.stats.vm.v_active_count" }, +#define MIB_V_INACTIVE_COUNT 4 + { "vm.stats.vm.v_inactive_count" }, +#define MIB_V_CACHE_COUNT 5 + { "vm.stats.vm.v_cache_count" }, +#define MIB_V_SWAPPGSIN 6 + { "vm.stats.vm.v_swappgsin" }, +#define MIB_V_SWAPPGSOUT 7 + { "vm.stats.vm.v_swappgsout" }, + { NULL } +}; + +#define PROC_MEMINFO_FILE "/compat/linux/proc/meminfo" + +#ifndef VM_TOTAL +#define VM_TOTAL VM_METER +#endif + +static guint64 swapin, + swapout, + swap_total, + swap_used; + +void +gkrellm_sys_mem_read_data(void) + { + static gint psize, pshift = 0; + static gint first_time_done = 0; + guint64 total, used, x_used, free, shared, buffers, cached; + struct vmtotal vmt; + size_t length_vmt = sizeof(vmt); + static int oid_vmt[] = { CTL_VM, VM_TOTAL }; + gint i; + FILE *f; + gchar buf[160]; + +#if 0 + /* mem.c does a force_meminfo_update() before calling this */ + /* Collecting meminfo data is expensive under FreeBSD, so + | take extra precautions to minimize reading it. + */ + if (!GK.ten_second_tick && !force_meminfo_update()) + return; +#endif + + if (pshift == 0) + { + for (psize = getpagesize(); psize > 1; psize >>= 1) + pshift++; + } + + shared = 0; + + if (!first_time_done) + { + for (i = 0; mibs[i].name; ++i) + { + mibs[i].oid_len = sizeof(mibs[i].oid); + if (gk_sysctlnametomib(mibs[i].name, + mibs[i].oid, + &mibs[i].oid_len) < 0) + return; + mibs[i].value_len = sizeof(mibs[i].value); + } + ++first_time_done; + } + for (i = 0; mibs[i].name; ++i) + if (sysctl(mibs[i].oid, mibs[i].oid_len, + &mibs[i].value, + &mibs[i].value_len, 0, 0) < 0) + return; + total = (mibs[MIB_V_PAGE_COUNT].value - + mibs[MIB_V_WIRE_COUNT].value) << pshift; + x_used = (mibs[MIB_V_ACTIVE_COUNT].value + + mibs[MIB_V_INACTIVE_COUNT].value) << pshift; + free = mibs[MIB_V_FREE_COUNT].value << pshift; + if (sysctl(oid_vmt, 2, &vmt, &length_vmt, NULL, 0) == 0) + shared = vmt.t_rmshr << pshift; + get_bufspace(&buffers); + cached = mibs[MIB_V_CACHE_COUNT].value << pshift; + used = x_used - buffers - cached; + gkrellm_mem_assign_data(total, used, free, shared, buffers, cached); + + swapin = mibs[MIB_V_SWAPPGSIN].value; + swapout = mibs[MIB_V_SWAPPGSOUT].value; + + if (kvmd == NULL) { + /* Try linprocfs for swap info */ + if ((f = fopen(PROC_MEMINFO_FILE, "r")) == NULL) + return; + /* total: used: free: shared: buffers: cached: */ + while ((fgets(buf, sizeof(buf), f)) != NULL) + { + if (strncmp(buf, "Swap:", 5) == 0) + { + sscanf(buf, "Swap: %llu %llu", + &swap_total, &swap_used); + break; + } + } + fclose(f); + return; + } + + if (first_time_done == 0) + { + swapmode(&swap_total, &swap_used); + swap_used = swap_total - swap_used; + first_time_done = 1; + } + } + +void +gkrellm_sys_swap_read_data(void) + { + gkrellm_swap_assign_data(swap_total, swap_used, swapin, swapout); + } + +gboolean +gkrellm_sys_mem_init(void) + { + return TRUE; + } + + +/* ===================================================================== */ +/* Battery monitor interface */ + +#if defined(__i386__) +#include <osreldate.h> +#include <machine/apm_bios.h> +#define APMDEV "/dev/apm" + +#define L_NO_BATTERY 0x80 +#define L_ON_LINE 1 +#define L_CHARGING 3 +#define L_UNKNOWN 0xFF + +/* following two definitions are taken from sys/dev/acpica/acpiio.h */ +#define ACPI_BATT_STAT_CHARGING 0x0002 +#define ACPI_BATT_STAT_NOT_PRESENT 0x0007 + +#define ACPI_ACLINE 0 +#define ACPI_BATT_LIFE 1 +#define ACPI_BATT_TIME 2 +#define ACPI_BATT_STATE 3 + +void +gkrellm_sys_battery_read_data(void) + { + static const char *name[] = { "hw.acpi.acline", + "hw.acpi.battery.life", + "hw.acpi.battery.time", + "hw.acpi.battery.state", + NULL }; + static int oid[CTL_MAXNAME + 2][4]; + static size_t oid_len[4] = { sizeof(oid[0]), sizeof(oid[1]), + sizeof(oid[2]), sizeof(oid[3]) }; + static gboolean first_time_done = FALSE; + static gboolean acpi_enabled = FALSE; + size_t size; + int acpi_info[4]; + int i; + int f, r; + struct apm_info info; + gboolean available, on_line, charging; + gint percent, time_left; + gint batt_num = 0; + + if (!first_time_done) + { + first_time_done = TRUE; +#ifdef ACPI_SUPPORTS_MULTIPLE_BATTERIES + /* + * XXX: Disable getting battery information via ACPI + * to support multiple batteries via APM sim until + * ACPI sysctls support multiple batteries. + */ + for (i = 0; name[i] != NULL; ++i) + { + if (gk_sysctlnametomib(name[i], oid[i], + &oid_len[i]) < 0) + break; + } + if (name[i] == NULL) + acpi_enabled = TRUE; +#endif + } + + if (acpi_enabled) + { + for (i = 0; name[i] != NULL; ++i) + { + size = sizeof(acpi_info[i]); + if (sysctl(oid[i], oid_len[i], + &acpi_info[i], &size, NULL, 0) < 0) + return; + } + available = (acpi_info[ACPI_BATT_STATE] != ACPI_BATT_STAT_NOT_PRESENT); + on_line = acpi_info[ACPI_ACLINE]; + charging = (acpi_info[ACPI_BATT_STATE] == ACPI_BATT_STAT_CHARGING); + percent = acpi_info[ACPI_BATT_LIFE]; + if (acpi_info[ACPI_BATT_TIME] == 0 && percent > 0) + time_left = -1; + else + time_left = acpi_info[ACPI_BATT_TIME]; + gkrellm_battery_assign_data( + GKRELLM_BATTERY_COMPOSITE_ID, available, + on_line, charging, percent, time_left); + return; + } + + if ((f = open(APMDEV, O_RDONLY)) == -1) + return; + if ((r = ioctl(f, APMIO_GETINFO, &info)) == -1) { + close(f); + return; + } + + available = (info.ai_batt_stat != L_UNKNOWN || + info.ai_acline == L_ON_LINE); + on_line = (info.ai_acline == L_ON_LINE) ? TRUE : FALSE; + charging = (info.ai_batt_stat == L_CHARGING) ? TRUE : FALSE; + percent = info.ai_batt_life; +#if defined(APM_GETCAPABILITIES) + if (info.ai_batt_time == -1 || (info.ai_batt_time == 0 && percent > 0)) + time_left = -1; + else + time_left = info.ai_batt_time / 60; +#else + time_left = -1; +#endif + gkrellm_battery_assign_data(GKRELLM_BATTERY_COMPOSITE_ID, available, + on_line, charging, percent, time_left); + +#if defined(APMIO_GETPWSTATUS) + if (info.ai_infoversion >= 1 && info.ai_batteries != (u_int) -1 && + info.ai_batteries > 1) + { + gint i; + struct apm_pwstatus aps; + + for (i = 0; i < info.ai_batteries; ++i) + { + bzero(&aps, sizeof(aps)); + aps.ap_device = PMDV_BATT0 + i; + if (ioctl(f, APMIO_GETPWSTATUS, &aps) == -1 || + (aps.ap_batt_flag != 255 && + (aps.ap_batt_flag & APM_BATT_NOT_PRESENT))) + continue; + available = (aps.ap_batt_stat != L_UNKNOWN || + aps.ap_acline == L_ON_LINE); + on_line = (aps.ap_acline == L_ON_LINE) ? TRUE : FALSE; + charging = (aps.ap_batt_stat == L_CHARGING) ? + TRUE : FALSE; + percent = aps.ap_batt_life; + if (aps.ap_batt_time == -1 || + (aps.ap_batt_time == 0 && percent > 0)) + time_left = -1; + else + time_left = aps.ap_batt_time / 60; + gkrellm_battery_assign_data(batt_num++, available, + on_line, charging, percent, + time_left); + } + } +#endif + + close(f); + } + +gboolean +gkrellm_sys_battery_init(void) + { + return TRUE; + } + +#else + +void +gkrellm_sys_battery_read_data(void) + { + } + +gboolean +gkrellm_sys_battery_init(void) + { + return FALSE; + } + +#endif + + +/* ===================================================================== */ +/* Sensor monitor interface */ + +#if defined(__i386__) + +typedef struct + { + gchar *name; + gfloat factor; + gfloat offset; + gchar *vref; + } + VoltDefault; + + /* Tables of voltage correction factors and offsets derived from the + | compute lines in sensors.conf. See the README file. + */ + /* "lm78-*" "lm78-j-*" "lm79-*" "w83781d-*" "sis5595-*" "as99127f-*" */ + /* Values from LM78/LM79 data sheets */ +static VoltDefault voltdefault0[] = + { + { "Vcor1", 1.0, 0, NULL }, + { "Vcor2", 1.0, 0, NULL }, + { "+3.3V", 1.0, 0, NULL }, + { "+5V", 1.68, 0, NULL }, /* in3 ((6.8/10)+1)*@ */ + { "+12V", 4.0, 0, NULL }, /* in4 ((30/10)+1)*@ */ + { "-12V", -4.0, 0, NULL }, /* in5 -(240/60)*@ */ + { "-5V", -1.667, 0, NULL } /* in6 -(100/60)*@ */ + }; + +#include <dirent.h> +#include <osreldate.h> +#include <machine/cpufunc.h> +#include <machine/smb.h> + +/* Interface types */ +#define INTERFACE_IO 0 +#define INTERFACE_SMB 1 +#define INTERFACE_ACPI 2 + +/* Addresses to use for /dev/io */ +#define WBIO1 0x295 +#define WBIO2 0x296 + +/* LM78/79 addresses */ +#define LM78_VOLT(val) (0x20 + (val)) +#define LM78_TEMP 0x27 +#define LM78_FAN(val) (0x28 + (val)) +#define LM78_FANDIV 0x47 + +#define SENSORS_DIR "/dev" + +#define TZ_ZEROC 2732 +#define TZ_KELVTOC(x) ((gfloat)((x) - TZ_ZEROC) / 10.0) + + +static gint +get_data(int iodev, u_char command, int interface, u_char *ret) + { + u_char byte = 0; + + if (interface == INTERFACE_IO) + { + outb(WBIO1, command); + byte = inb(WBIO2); + } + else if (interface == INTERFACE_SMB) + { + struct smbcmd cmd; + + bzero(&cmd, sizeof(cmd)); + cmd.data.byte_ptr = &byte; + cmd.slave = 0x5a; + cmd.cmd = command; + if (ioctl(iodev, SMB_READB, (caddr_t)&cmd) == -1) + { + close(iodev); + return FALSE; + } + } + else + { + return FALSE; + } + if (byte == 0xff) + return FALSE; + *ret = byte; + return TRUE; + } + +gboolean +gkrellm_sys_sensors_get_temperature(gchar *path, gint id, + gint iodev, gint interface, gfloat *temp) + + { + u_char byte; + + if (interface == MBMON_INTERFACE) + { + gkrellm_sys_sensors_mbmon_check(FALSE); + return gkrellm_sys_sensors_mbmon_get_value(path, temp); + } + + if (interface == INTERFACE_ACPI) + { + int value; + size_t size = sizeof(value); + + if (sysctlbyname(path, &value, &size, NULL, 0) < 0) + return FALSE; + if (temp) + *temp = (gfloat) TZ_KELVTOC(value); + return TRUE; + } + if (get_data(iodev, LM78_TEMP, interface, &byte)) + { + if (temp) + *temp = (gfloat) byte; + return TRUE; + } + return FALSE; + } + +gboolean +gkrellm_sys_sensors_get_fan(gchar *path, gint id, + gint iodev, gint interface, gfloat *fan) + { + u_char byte; + + if (interface == MBMON_INTERFACE) + { + gkrellm_sys_sensors_mbmon_check(FALSE); + return gkrellm_sys_sensors_mbmon_get_value(path, fan); + } + + if (get_data(iodev, LM78_FAN(id), interface, &byte)) + { + if (byte == 0) + return FALSE; + if (fan) + *fan = 1.35E6 / (gfloat) byte; + return TRUE; + } + return FALSE; + } + +gboolean +gkrellm_sys_sensors_get_voltage(gchar *path, gint id, + gint iodev, gint interface, gfloat *volt) + { + u_char byte; + + if (interface == MBMON_INTERFACE) + { + gkrellm_sys_sensors_mbmon_check(FALSE); + return gkrellm_sys_sensors_mbmon_get_value(path, volt); + } + + if (get_data(iodev, LM78_VOLT(id), interface, &byte)) + { + if (volt) + *volt = (gfloat) byte / 64.0; + return TRUE; + } + return FALSE; + } + +struct freebsd_sensor { + gint type; + gchar *id_name; + gint id; + gint iodev; + gint inter; + gfloat factor; + gfloat offset; + gchar *default_label; +}; + +static GList *freebsd_sensor_list; + +gboolean +gkrellm_sys_sensors_init(void) + { + gchar mib_name[256], label[8]; + gint interface, id; + int oid_acpi_temp[CTL_MAXNAME + 2]; + size_t oid_acpi_temp_len = sizeof(oid_acpi_temp); + GList *list; + struct freebsd_sensor *sensor; + + /* Do intial daemon reads to get sensors loaded into sensors.c + */ + gkrellm_sys_sensors_mbmon_check(TRUE); + + for (id = 0;;) + { + snprintf(mib_name, sizeof(mib_name), + "hw.acpi.thermal.tz%d.temperature", id); + if (gk_sysctlnametomib(mib_name, oid_acpi_temp, + &oid_acpi_temp_len) < 0) + break; + interface = INTERFACE_ACPI; + if (!gkrellm_sys_sensors_get_temperature(mib_name, 0, 0, + interface, NULL)) + continue; + snprintf(label, sizeof(label), "tz%d", id); + gkrellm_sensors_add_sensor(SENSOR_TEMPERATURE, NULL, + mib_name, 0, 0, + interface, 1.0, 0.0, NULL, label); + } + + if (freebsd_sensor_list) + { + for (list = freebsd_sensor_list; list; list = list->next) + { + sensor = (struct freebsd_sensor *)list->data; + gkrellm_sensors_add_sensor(sensor->type, NULL, + sensor->id_name, sensor->id, + sensor->iodev, sensor->inter, + sensor->factor, sensor->offset, + NULL, sensor->default_label); + } + } + + return (TRUE); + } + +static gboolean +sensors_add_sensor(gint type, gchar *id_name, gint id, gint iodev, gint inter, + gfloat factor, gfloat offset, gchar *default_label) +{ + struct freebsd_sensor *sensor; + + if ((sensor = g_new0(struct freebsd_sensor, 1)) == NULL) + return FALSE; + sensor->type = type; + sensor->id_name = g_strdup(id_name); + sensor->id = id; + sensor->iodev = iodev; + sensor->inter = inter; + sensor->factor = factor; + sensor->offset = offset; + sensor->default_label = default_label ? g_strdup(default_label) : NULL; + if (g_list_append(freebsd_sensor_list, sensor) == NULL) { + g_free(sensor->id_name); + if (sensor->default_label) + g_free(sensor->default_label); + g_free(sensor); + return FALSE; + } + return TRUE; +} + +static void +scan_for_sensors(void) + { + gchar *chip_dir = SENSORS_DIR; + DIR *dir; + struct dirent *dentry; + gchar temp_file[256], id_name[8]; + gint iodev = -1, interface = -1, id; + gint fandiv[3]; + u_char byte; + gboolean found_sensors = FALSE; + + if ((dir = opendir(chip_dir)) != NULL) + { + while ((dentry = readdir(dir)) != NULL) + { + if (dentry->d_name[0] == '.' || dentry->d_ino <= 0) + continue; + if (strncmp(dentry->d_name, "smb", 3) != 0) + continue; + snprintf(temp_file, sizeof(temp_file), "%s/%s", + chip_dir, dentry->d_name); + if ((iodev = open(temp_file, O_RDWR)) == -1) + continue; + sprintf(id_name, "%s%3s", "temp", dentry->d_name + 3); + interface = INTERFACE_SMB; + if (!gkrellm_sys_sensors_get_temperature(NULL, 0, iodev, + interface, NULL)) + { + close(iodev); + continue; + } + sensors_add_sensor(SENSOR_TEMPERATURE, id_name, 0, + iodev, interface, 1.0, 0.0, NULL); + found_sensors = TRUE; + break; + } + closedir(dir); + } + if (!found_sensors) + { + snprintf(temp_file, sizeof(temp_file), "%s/%s", + chip_dir, "io"); + if ((iodev = open(temp_file, O_RDWR)) == -1) + return; + interface = INTERFACE_IO; + if (!gkrellm_sys_sensors_get_temperature(NULL, 0, iodev, + interface, NULL)) + { + close(iodev); + return; + } + sensors_add_sensor(SENSOR_TEMPERATURE, "temp0", 0, iodev, + interface, 1.0, 0.0, NULL); + found_sensors = TRUE; + } + if (found_sensors) + { + if (get_data(iodev, LM78_FANDIV, interface, &byte)) + { + fandiv[0] = 1 << ((byte & 0x30) >> 4); + fandiv[1] = 1 << ((byte & 0xc0) >> 6); + fandiv[2] = 2; + for (id = 0; id < 3; ++id) + { + if (!gkrellm_sys_sensors_get_fan(NULL, id, iodev, + interface, NULL)) + continue; + sprintf(id_name, "%s%d", "fan", id); + sensors_add_sensor(SENSOR_FAN, id_name, id, + iodev, interface, + 1.0 / (gfloat) fandiv[id], 0.0, + NULL); + } + } + for (id = 0; id < 7; ++id) + { + if (!gkrellm_sys_sensors_get_voltage(NULL, id, iodev, + interface, NULL)) + continue; + sprintf(id_name, "%s%d", "in", id); + sensors_add_sensor(SENSOR_VOLTAGE, id_name, id, + iodev, interface, + voltdefault0[id].factor, 0.0, + voltdefault0[id].name); + } + } + } + +#else + +gboolean +gkrellm_sys_sensors_get_temperature(gchar *path, gint id, + gint iodev, gint interface, gfloat *temp) + + { + return FALSE; + } + +gboolean +gkrellm_sys_sensors_get_fan(gchar *path, gint id, + gint iodev, gint interface, gfloat *fan) + { + return FALSE; + } + +gboolean +gkrellm_sys_sensors_get_voltage(gchar *path, gint id, + gint iodev, gint interface, gfloat *volt) + { + return FALSE; + } + +gboolean +gkrellm_sys_sensors_init(void) + { + return FALSE; + } + +#endif diff --git a/sysutils/gkrellm/files/server.Makefile b/sysutils/gkrellm/files/server.Makefile index e46a228284d..9b0c490336a 100644 --- a/sysutils/gkrellm/files/server.Makefile +++ b/sysutils/gkrellm/files/server.Makefile @@ -78,7 +78,7 @@ clean: SYSDEPS = ../src/sysdeps/bsd-common.c ../src/sysdeps/bsd-net-open.c \ ../src/sysdeps/freebsd.c ../src/sysdeps/gtop.c \ - ../src/sysdeps/linux.c ../src/sysdeps/netbsd.c \ + ../src/sysdeps/linux.c ../src/sysdeps/netbsd.c ../src/sysdeps/dragonfly.c \ ../src/sysdeps/openbsd.c ../src/sysdeps/solaris.c ../src/sysdeps/darwin.c main.o: main.c gkrellmd.h diff --git a/sysutils/gkrellm/files/src.Makefile b/sysutils/gkrellm/files/src.Makefile index ebf7c84a003..36e9ebf9142 100644 --- a/sysutils/gkrellm/files/src.Makefile +++ b/sysutils/gkrellm/files/src.Makefile @@ -155,7 +155,8 @@ IMAGES = \ SYSDEPS_SRC = sysdeps/bsd-common.c sysdeps/bsd-net-open.c sysdeps/freebsd.c \ sysdeps/gtop.c sysdeps/linux.c sysdeps/netbsd.c sysdeps/openbsd.c \ - sysdeps/solaris.c sysdeps/darwin.c sysdeps/sensors-common.c + sysdeps/solaris.c sysdeps/darwin.c sysdeps/sensors-common.c \ + sysdeps/dragonfly.c GKRELLM_H = gkrellm.h gkrellm-private.h GKRELLM_H_SYS = gkrellm.h gkrellm-public-proto.h gkrellm-private.h \ diff --git a/sysutils/gkrellm/files/top.Makefile.inc b/sysutils/gkrellm/files/top.Makefile.inc index 62f8bf213f9..da318303394 100644 --- a/sysutils/gkrellm/files/top.Makefile.inc +++ b/sysutils/gkrellm/files/top.Makefile.inc @@ -66,7 +66,7 @@ endif ifeq ($(GTOP),) # OS-specific overrides -SUPPORTED_OSES= Linux NetBSD FreeBSD OpenBSD Darwin Solaris +SUPPORTED_OSES= Linux NetBSD FreeBSD OpenBSD Darwin Solaris DragonFly REALOPSYS= $(shell uname -s) OPSYS= $(if $(findstring $(REALOPSYS),$(SUPPORTED_OSES)),$(REALOPSYS),Linux) @@ -128,6 +128,13 @@ SYS_LIBS+= -lresolv -lX11 SYS_LIBS+= -lnsl endif endif + else + ifeq (${OPSYS},DragonFly) +BINGROUP= kmem +NEED_MD5= no +MD5_LIBS= -lmd +SYS_LIBS= -lkvm -lkinfo -ldevstat + endif endif endif endif diff --git a/sysutils/gkrellm/patches/patch-aa b/sysutils/gkrellm/patches/patch-aa index eb130356750..1dc8ea26296 100644 --- a/sysutils/gkrellm/patches/patch-aa +++ b/sysutils/gkrellm/patches/patch-aa @@ -1,6 +1,6 @@ -$NetBSD: patch-aa,v 1.15 2005/09/06 08:10:59 abs Exp $ +$NetBSD: patch-aa,v 1.16 2006/03/19 22:10:38 joerg Exp $ ---- src/sysdeps/bsd-common.c.orig 2004-05-01 19:46:38.000000000 +0200 +--- src/sysdeps/bsd-common.c.orig 2005-05-24 03:44:21.000000000 +0000 +++ src/sysdeps/bsd-common.c @@ -255,7 +255,11 @@ void gkrellm_sys_fs_get_mounts_list(void) @@ -39,3 +39,12 @@ $NetBSD: patch-aa,v 1.15 2005/09/06 08:10:59 abs Exp $ else gkrellm_fs_assign_fsusage_data(fs, 0, 0, 0, 0); } +@@ -345,7 +361,7 @@ gkrellm_sys_fs_init(void) + } + #endif + +-#if defined(__FreeBSD__) ++#if defined(__FreeBSD__) || defined(__DragonFly__) + gboolean + gkrellm_sys_fs_init(void) + { diff --git a/sysutils/gkrellm/patches/patch-ae b/sysutils/gkrellm/patches/patch-ae index 0aee833fab2..1ee4dd399af 100644 --- a/sysutils/gkrellm/patches/patch-ae +++ b/sysutils/gkrellm/patches/patch-ae @@ -1,8 +1,19 @@ -$NetBSD: patch-ae,v 1.1 2004/07/05 08:42:27 cube Exp $ +$NetBSD: patch-ae,v 1.2 2006/03/19 22:10:38 joerg Exp $ ---- server/gkrellmd-private.h.orig 2004-05-03 04:21:48.000000000 +0200 +--- server/gkrellmd-private.h.orig 2005-05-24 03:46:32.000000000 +0000 +++ server/gkrellmd-private.h -@@ -41,6 +41,7 @@ +@@ -28,6 +28,10 @@ + #endif + #endif + ++#if defined(__DragonFly__) ++#define HAVE_GETADDRINFO 1 ++#endif ++ + #if defined(__FreeBSD__) + #include <sys/param.h> + #if __FreeBSD_version >= 400000 +@@ -41,6 +45,7 @@ #if defined(__NetBSD__) #define HAVE_GETADDRINFO 1 @@ -10,3 +21,25 @@ $NetBSD: patch-ae,v 1.1 2004/07/05 08:42:27 cube Exp $ # if __NetBSD_Version__ <= 105010000 # define sa_family_t unsigned char # endif +@@ -66,12 +71,10 @@ + + #if !defined(__FreeBSD__) && !defined(__linux__) && !defined(__NetBSD__) \ + && !defined(__OpenBSD__) && !defined(__solaris__) && !defined(WIN32) \ +- && !defined(__APPLE__) ++ && !defined(__APPLE__) && !defined(__DragonFly__) + #define USE_LIBGTOP + #endif + +-extern int errno; +- + #define DEBUG_SYSDEP 0x1 + #define DEBUG_MAIL 0x10 + #define DEBUG_NET 0x20 +@@ -88,6 +91,7 @@ extern int errno; + #define SENSOR_GROUP_MAINBOARD 0 + #define SENSOR_GROUP_DISK 1 + ++#include <errno.h> + + struct GkrellmdConfig + { diff --git a/sysutils/gkrellm/patches/patch-aj b/sysutils/gkrellm/patches/patch-aj index a16a59c500c..6693fa366f3 100644 --- a/sysutils/gkrellm/patches/patch-aj +++ b/sysutils/gkrellm/patches/patch-aj @@ -1,8 +1,17 @@ -$NetBSD: patch-aj,v 1.1 2005/03/22 14:57:12 cube Exp $ +$NetBSD: patch-aj,v 1.2 2006/03/19 22:10:38 joerg Exp $ ---- src/mail.c.orig 2005-03-19 17:00:16.000000000 +0100 +--- src/mail.c.orig 2005-05-24 03:38:10.000000000 +0000 +++ src/mail.c -@@ -1297,7 +1297,7 @@ check_mh_dir(Mailbox *mbox) +@@ -33,7 +33,7 @@ + + #include "pixmaps/mail/decal_mail.xpm" + +-#if defined(__FreeBSD__) || defined(__OpenBSD__) || defined(__NetBSD__) ++#if defined(__FreeBSD__) || defined(__OpenBSD__) || defined(__NetBSD__) || defined(__DragonFly__) + #define HAVE_MD5_H + #endif + +@@ -1317,7 +1317,7 @@ check_mh_dir(Mailbox *mbox) while ((name = (gchar *) g_dir_read_name(dir)) != NULL) { /* Files starting with a digit are messages. */ diff --git a/sysutils/gkrellm/patches/patch-ao b/sysutils/gkrellm/patches/patch-ao index aaf6830fed3..f133c76191a 100644 --- a/sysutils/gkrellm/patches/patch-ao +++ b/sysutils/gkrellm/patches/patch-ao @@ -1,15 +1,17 @@ -$NetBSD: patch-ao,v 1.1 2005/03/22 14:57:12 cube Exp $ +$NetBSD: patch-ao,v 1.2 2006/03/19 22:10:38 joerg Exp $ ---- server/sysdeps-unix.c.orig 2005-03-19 17:00:16.000000000 +0100 +--- server/sysdeps-unix.c.orig 2005-03-19 16:00:16.000000000 +0000 +++ server/sysdeps-unix.c -@@ -24,8 +24,10 @@ +@@ -43,6 +43,12 @@ static gint gkrellm_connect_to(gchar *, + #include "../src/sysdeps/sensors-common.c" + #endif - #include "../src/gkrellm-sysdeps.h" - -+#if 0 - static gboolean (*mbmon_check_func)(); - static gint gkrellm_connect_to(gchar *, gint); ++#if defined(__DragonFly__) ++#include "../src/sysdeps/dragonfly.c" ++#include "../src/sysdeps/bsd-common.c" ++#include "../src/sysdeps/sensors-common.c" +#endif - - #if defined(__linux__) - #include "../src/sysdeps/linux.c" ++ + #if defined(__NetBSD__) + #include "../src/sysdeps/netbsd.c" + #include "../src/sysdeps/bsd-net-open.c" diff --git a/sysutils/gkrellm/patches/patch-ap b/sysutils/gkrellm/patches/patch-ap index 94bc0787767..b0d4362c070 100644 --- a/sysutils/gkrellm/patches/patch-ap +++ b/sysutils/gkrellm/patches/patch-ap @@ -1,8 +1,28 @@ -$NetBSD: patch-ap,v 1.1 2005/03/30 15:26:43 cube Exp $ +$NetBSD: patch-ap,v 1.2 2006/03/19 22:10:38 joerg Exp $ ---- src/client.c.orig 2005-03-19 17:00:16.000000000 +0100 +--- src/client.c.orig 2005-05-24 04:28:22.000000000 +0000 +++ src/client.c -@@ -127,7 +127,7 @@ client_cpu_line_from_server(gchar *line) +@@ -24,6 +24,8 @@ + #include "gkrellm-private.h" + #include "gkrellm-sysdeps.h" + ++#include <inttypes.h> ++ + #if !defined(WIN32) + #include <sys/socket.h> + #include <utime.h> +@@ -46,6 +48,10 @@ + #endif + #endif + ++#if defined(__DragonFly__) ++#define HAVE_GETADDRINFO 1 ++#endif ++ + #if defined(__FreeBSD__) + #if __FreeBSD_version >= 400000 + #define HAVE_GETADDRINFO 1 +@@ -145,7 +151,7 @@ client_cpu_line_from_server(gchar *line) gint n; guint64 user, nice, sys, idle; @@ -11,7 +31,7 @@ $NetBSD: patch-ap,v 1.1 2005/03/30 15:26:43 cube Exp $ for (list = cpu_list; list; list = list->next) { cpu = (Cpu *) list->data; -@@ -371,7 +371,7 @@ client_net_line_from_server(gchar *line) +@@ -406,7 +412,7 @@ client_net_line_from_server(gchar *line) gchar name[32]; guint64 rx, tx; @@ -20,7 +40,7 @@ $NetBSD: patch-ap,v 1.1 2005/03/30 15:26:43 cube Exp $ for (list = net_list; list; list = list->next) { net = (NetData *) list->data; -@@ -615,7 +615,7 @@ struct +@@ -680,7 +686,7 @@ struct static void client_mem_line_from_server(gchar *line) { @@ -29,7 +49,7 @@ $NetBSD: patch-ap,v 1.1 2005/03/30 15:26:43 cube Exp $ &mem.total, &mem.used, &mem.free, &mem.shared, &mem.buffers, &mem.cached); } -@@ -623,7 +623,7 @@ client_mem_line_from_server(gchar *line) +@@ -688,7 +694,7 @@ client_mem_line_from_server(gchar *line) static void client_swap_line_from_server(gchar *line) { diff --git a/sysutils/gkrellm/patches/patch-ar b/sysutils/gkrellm/patches/patch-ar index 1bef56d130e..647e280feac 100644 --- a/sysutils/gkrellm/patches/patch-ar +++ b/sysutils/gkrellm/patches/patch-ar @@ -1,7 +1,16 @@ -$NetBSD: patch-ar,v 1.2 2005/09/08 13:19:56 cube Exp $ +$NetBSD: patch-ar,v 1.3 2006/03/19 22:10:38 joerg Exp $ ---- server/monitor.c.orig 2005-05-24 06:29:32.000000000 +0200 +--- server/monitor.c.orig 2005-05-24 04:29:32.000000000 +0000 +++ server/monitor.c +@@ -21,7 +21,7 @@ + + #include "gkrellmd.h" + #include "gkrellmd-private.h" +- ++#include <inttypes.h> + + GList *gkrellmd_monitor_list; + @@ -555,14 +555,14 @@ serve_disk_data(GkrellmdMonitor *mon, gb if (!disk->subdisk_parent) { diff --git a/sysutils/gkrellm/patches/patch-au b/sysutils/gkrellm/patches/patch-au new file mode 100644 index 00000000000..f3487c4582c --- /dev/null +++ b/sysutils/gkrellm/patches/patch-au @@ -0,0 +1,13 @@ +$NetBSD: patch-au,v 1.1 2006/03/19 22:10:38 joerg Exp $ + +--- src/gkrellm.h.orig 2006-03-16 22:33:00.000000000 +0000 ++++ src/gkrellm.h +@@ -52,7 +52,7 @@ + + #if !defined(__FreeBSD__) && !defined(__linux__) && !defined(__NetBSD__) \ + && !defined(__OpenBSD__) && !defined(__solaris__) && !defined(WIN32) \ +- && !defined(__APPLE__) ++ && !defined(__APPLE__) && !defined(__DragonFly__) + #define USE_LIBGTOP + #endif + diff --git a/sysutils/gkrellm/patches/patch-av b/sysutils/gkrellm/patches/patch-av new file mode 100644 index 00000000000..eda36041128 --- /dev/null +++ b/sysutils/gkrellm/patches/patch-av @@ -0,0 +1,19 @@ +$NetBSD: patch-av,v 1.1 2006/03/19 22:10:38 joerg Exp $ + +--- src/gui.c.orig 2006-03-16 22:33:23.000000000 +0000 ++++ src/gui.c +@@ -782,6 +782,14 @@ create_about_tab(GtkWidget *vbox) + g_free(buf); + gtk_box_pack_start(GTK_BOX(vbox), label, TRUE, TRUE, 0); + #endif ++#if defined(__DragonFly__) ++ buf = g_strdup_printf( ++ _("DragonFly system dependent code was contributed by:\n" ++ "Joerg Sonnenberger <joerg@bec.de>")); ++ label = gtk_label_new(buf); ++ g_free(buf); ++ gtk_box_pack_start(GTK_BOX(vbox), label, TRUE, TRUE, 0); ++#endif + #if defined(__NetBSD__) + buf = g_strdup_printf( + _("NetBSD system dependent code was contributed by:\n" diff --git a/sysutils/gkrellm/patches/patch-aw b/sysutils/gkrellm/patches/patch-aw new file mode 100644 index 00000000000..92ca2f157e6 --- /dev/null +++ b/sysutils/gkrellm/patches/patch-aw @@ -0,0 +1,13 @@ +$NetBSD: patch-aw,v 1.1 2006/03/19 22:10:38 joerg Exp $ + +--- src/inet.h.orig 2006-03-16 22:34:00.000000000 +0000 ++++ src/inet.h +@@ -34,7 +34,7 @@ + #endif + #endif /* __linux__ */ + +-#if defined(__FreeBSD__) ++#if defined(__FreeBSD__) || defined(__DragonFly__) + #include <osreldate.h> + #include <sys/types.h> + #include <sys/socket.h> diff --git a/sysutils/gkrellm/patches/patch-ax b/sysutils/gkrellm/patches/patch-ax new file mode 100644 index 00000000000..974b6c16526 --- /dev/null +++ b/sysutils/gkrellm/patches/patch-ax @@ -0,0 +1,13 @@ +$NetBSD: patch-ax,v 1.1 2006/03/19 22:10:38 joerg Exp $ + +--- src/plugins.c.orig 2006-03-17 00:55:53.000000000 +0000 ++++ src/plugins.c +@@ -761,7 +761,7 @@ gkrellm_place_plugin(GList **monitor_lis + if (list == *monitor_list) + *monitor_list = g_list_prepend(list, plugin); + else +- g_list_prepend(list, plugin); ++ list = g_list_prepend(list, plugin); + } + return; + } diff --git a/sysutils/gkrellm/patches/patch-ay b/sysutils/gkrellm/patches/patch-ay new file mode 100644 index 00000000000..19d61995aae --- /dev/null +++ b/sysutils/gkrellm/patches/patch-ay @@ -0,0 +1,17 @@ +$NetBSD: patch-ay,v 1.1 2006/03/19 22:10:38 joerg Exp $ + +--- src/sysdeps-unix.c.orig 2006-03-17 01:00:20.000000000 +0000 ++++ src/sysdeps-unix.c +@@ -43,6 +43,12 @@ static gboolean (*mbmon_check_func)(); + #include "sysdeps/sensors-common.c" + #endif + ++#if defined(__DragonFly__) ++#include "sysdeps/dragonfly.c" ++#include "sysdeps/bsd-common.c" ++#include "sysdeps/sensors-common.c" ++#endif ++ + #if defined(__NetBSD__) + #include "sysdeps/netbsd.c" + #include "sysdeps/bsd-net-open.c" |