f181dacce2
- Get vmstat via sysctl(3) instead of kvm(3). Approved by: bapt (blanket)
222 lines
5.9 KiB
C++
222 lines
5.9 KiB
C++
--- bsd/kernel.cc.orig 2013-08-23 13:40:35.000000000 +0400
|
|
+++ bsd/kernel.cc 2014-10-03 00:35:05.000000000 +0400
|
|
@@ -28,6 +28,7 @@
|
|
#include <string.h>
|
|
#include <err.h>
|
|
#include <errno.h>
|
|
+#include <ifaddrs.h>
|
|
#include <sysexits.h>
|
|
#include <sys/types.h>
|
|
#include <sys/queue.h>
|
|
@@ -43,7 +44,6 @@
|
|
#if defined(XOSVIEW_FREEBSD) || defined(XOSVIEW_DFBSD)
|
|
static const char ACPIDEV[] = "/dev/acpi";
|
|
static const char APMDEV[] = "/dev/apm";
|
|
-#include <net/if_var.h>
|
|
#include <sys/ioctl.h>
|
|
#include <dev/acpica/acpiio.h>
|
|
#include <machine/apm_bios.h>
|
|
@@ -115,56 +115,41 @@
|
|
// this later on. This keeps the indices within the nlist constant.
|
|
#define DUMMY_SYM "dummy_sym"
|
|
|
|
-#if defined(XOSVIEW_FREEBSD)
|
|
-{ "_cnt" },
|
|
-#define VMMETER_SYM_INDEX 0
|
|
-#else
|
|
-{ DUMMY_SYM },
|
|
-#define DUMMY_0
|
|
-#endif
|
|
-#if !defined(XOSVIEW_OPENBSD)
|
|
-{ "_ifnet" },
|
|
-#define IFNET_SYM_INDEX 1
|
|
-#else
|
|
-{ DUMMY_SYM },
|
|
-#define DUMMY_1
|
|
-#endif
|
|
-
|
|
#if defined(XOSVIEW_OPENBSD)
|
|
{ "_disklist" },
|
|
-#define DISKLIST_SYM_INDEX 2
|
|
+#define DISKLIST_SYM_INDEX 0
|
|
#else
|
|
{ DUMMY_SYM },
|
|
-#define DUMMY_2
|
|
+#define DUMMY_0
|
|
#endif
|
|
#if defined(XOSVIEW_NETBSD)
|
|
{ "_allevents" },
|
|
-#define ALLEVENTS_SYM_INDEX 3
|
|
+#define ALLEVENTS_SYM_INDEX 1
|
|
{ "_bufmem" },
|
|
-#define BUFMEM_SYM_INDEX 4
|
|
+#define BUFMEM_SYM_INDEX 2
|
|
#else
|
|
{ DUMMY_SYM },
|
|
-#define DUMMY_3
|
|
+#define DUMMY_1
|
|
{ DUMMY_SYM },
|
|
-#define DUMMY_4
|
|
+#define DUMMY_2
|
|
#endif
|
|
#if defined(XOSVIEW_FREEBSD)
|
|
{ "_intrnames" },
|
|
-#define INTRNAMES_SYM_INDEX 5
|
|
+#define INTRNAMES_SYM_INDEX 3
|
|
# if __FreeBSD_version >= 900040
|
|
{ "_sintrnames" },
|
|
# else
|
|
{ "_eintrnames" },
|
|
# endif
|
|
-#define EINTRNAMES_SYM_INDEX 6
|
|
+#define EINTRNAMES_SYM_INDEX 4
|
|
{ "_intrcnt" },
|
|
-#define INTRCNT_SYM_INDEX 7
|
|
+#define INTRCNT_SYM_INDEX 5
|
|
# if __FreeBSD_version >= 900040
|
|
{ "_sintrcnt" },
|
|
# else
|
|
{ "_eintrcnt" },
|
|
# endif
|
|
-#define EINTRCNT_SYM_INDEX 8
|
|
+#define EINTRCNT_SYM_INDEX 6
|
|
#endif
|
|
{ NULL }
|
|
};
|
|
@@ -337,7 +322,21 @@
|
|
#else /* HAVE_UVM */
|
|
struct vmmeter vm;
|
|
#if defined(XOSVIEW_FREEBSD)
|
|
- safe_kvm_read_symbol(VMMETER_SYM_INDEX, &vm, sizeof(vm));
|
|
+ size_t size = sizeof(unsigned int);
|
|
+
|
|
+#define GET_VM_STATS(name) \
|
|
+ sysctlbyname("vm.stats.vm." #name, &vm.name, &size, NULL, 0)
|
|
+ GET_VM_STATS(v_active_count);
|
|
+ GET_VM_STATS(v_inactive_count);
|
|
+ GET_VM_STATS(v_wire_count);
|
|
+ GET_VM_STATS(v_cache_count);
|
|
+ GET_VM_STATS(v_free_count);
|
|
+ GET_VM_STATS(v_page_size);
|
|
+ GET_VM_STATS(v_vnodepgsin);
|
|
+ GET_VM_STATS(v_vnodepgsout);
|
|
+ GET_VM_STATS(v_swappgsin);
|
|
+ GET_VM_STATS(v_swappgsout);
|
|
+#undef GET_VM_STATS
|
|
#else /* XOSVIEW_DFBSD */
|
|
struct vmstats vms;
|
|
size_t size = sizeof(vms);
|
|
@@ -421,99 +420,37 @@
|
|
int
|
|
BSDNetInit() {
|
|
OpenKDIfNeeded();
|
|
-#if defined(XOSVIEW_NETBSD)
|
|
- return ValidSymbol(IFNET_SYM_INDEX);
|
|
-#else
|
|
return 1;
|
|
-#endif
|
|
}
|
|
|
|
void
|
|
BSDGetNetInOut(unsigned long long *inbytes, unsigned long long *outbytes, const char *netIface, bool ignored) {
|
|
- char ifname[IFNAMSIZ];
|
|
+ struct ifaddrs *ifap, *ifa;
|
|
*inbytes = 0;
|
|
*outbytes = 0;
|
|
-#if defined(XOSVIEW_OPENBSD)
|
|
- size_t size;
|
|
- char *buf, *next;
|
|
- struct if_msghdr *ifm;
|
|
- struct if_data ifd;
|
|
- struct sockaddr_dl *sdl;
|
|
-
|
|
- if ( sysctl(mib_ifl, 6, NULL, &size, NULL, 0) < 0 )
|
|
- err(EX_OSERR, "BSDGetNetInOut(): sysctl 1 failed");
|
|
- if ( (buf = (char *)malloc(size)) == NULL)
|
|
- err(EX_OSERR, "BSDGetNetInOut(): malloc failed");
|
|
- if ( sysctl(mib_ifl, 6, buf, &size, NULL, 0) < 0 )
|
|
- err(EX_OSERR, "BSDGetNetInOut(): sysctl 2 failed");
|
|
|
|
- for (next = buf; next < buf + size; next += ifm->ifm_msglen) {
|
|
- bool skipif = false;
|
|
- ifm = (struct if_msghdr *)next;
|
|
- if (ifm->ifm_type != RTM_IFINFO || ifm->ifm_addrs & RTAX_IFP == 0)
|
|
- continue;
|
|
- ifd = ifm->ifm_data;
|
|
- sdl = (struct sockaddr_dl *)(ifm + 1);
|
|
- if (sdl->sdl_family != AF_LINK)
|
|
- continue;
|
|
- if ( strncmp(netIface, "False", 5) != 0 ) {
|
|
- memcpy(ifname, sdl->sdl_data, (sdl->sdl_nlen >= IFNAMSIZ ? IFNAMSIZ - 1 : sdl->sdl_nlen));
|
|
- if ( (!ignored && strncmp(sdl->sdl_data, netIface, sdl->sdl_nlen) != 0) ||
|
|
- ( ignored && strncmp(sdl->sdl_data, netIface, sdl->sdl_nlen) == 0) )
|
|
- skipif = true;
|
|
- }
|
|
- if (!skipif) {
|
|
- *inbytes += ifd.ifi_ibytes;
|
|
- *outbytes += ifd.ifi_obytes;
|
|
- }
|
|
- }
|
|
- free(buf);
|
|
-#else /* XOSVIEW_OPENBSD */
|
|
- struct ifnet *ifnetp;
|
|
- struct ifnet ifnet;
|
|
-#if defined (XOSVIEW_NETBSD)
|
|
- struct ifnet_head ifnethd;
|
|
-#else
|
|
- struct ifnethead ifnethd;
|
|
-#endif
|
|
- safe_kvm_read(nlst[IFNET_SYM_INDEX].n_value, &ifnethd, sizeof(ifnethd));
|
|
- ifnetp = TAILQ_FIRST(&ifnethd);
|
|
+ if (getifaddrs(&ifap) != 0)
|
|
+ return;
|
|
|
|
- while (ifnetp) {
|
|
+ for (ifa = ifap; ifa; ifa = ifa->ifa_next) {
|
|
bool skipif = false;
|
|
- // Now, dereference the pointer to get the ifnet struct.
|
|
- safe_kvm_read((u_long)ifnetp, &ifnet, sizeof(ifnet));
|
|
- strlcpy(ifname, ifnet.if_xname, sizeof(ifname));
|
|
-#if defined(XOSVIEW_NETBSD)
|
|
- ifnetp = TAILQ_NEXT(&ifnet, if_list);
|
|
-#else
|
|
- ifnetp = TAILQ_NEXT(&ifnet, if_link);
|
|
-#endif
|
|
- if (!(ifnet.if_flags & IFF_UP))
|
|
+
|
|
+ if (ifa->ifa_addr->sa_family != AF_LINK)
|
|
continue;
|
|
+
|
|
if ( strncmp(netIface, "False", 5) != 0 ) {
|
|
- if ( (!ignored && strncmp(ifname, netIface, 256) != 0) ||
|
|
- ( ignored && strncmp(ifname, netIface, 256) == 0) )
|
|
+ if ( (!ignored && strncmp(ifa->ifa_name, netIface, 256) != 0) ||
|
|
+ ( ignored && strncmp(ifa->ifa_name, netIface, 256) == 0) )
|
|
skipif = true;
|
|
}
|
|
+#define IFA_STAT(s) (((struct if_data *)ifa->ifa_data)->ifi_ ## s)
|
|
if (!skipif) {
|
|
-#if defined(XOSVIEW_DFBSD) && __DragonFly_version > 300304
|
|
- struct ifdata_pcpu *ifdatap = ifnet.if_data_pcpu;
|
|
- struct ifdata_pcpu ifdata;
|
|
- int ncpus = BSDCountCpus();
|
|
- for (int cpu = 0; cpu < ncpus; cpu++) {
|
|
- safe_kvm_read((u_long)ifdatap + cpu * sizeof(ifdata),
|
|
- &ifdata, sizeof(ifdata));
|
|
- *inbytes += ifdata.ifd_ibytes;
|
|
- *outbytes += ifdata.ifd_obytes;
|
|
- }
|
|
-#else
|
|
- *inbytes += ifnet.if_ibytes;
|
|
- *outbytes += ifnet.if_obytes;
|
|
-#endif
|
|
+ *inbytes += IFA_STAT(ibytes);
|
|
+ *outbytes += IFA_STAT(obytes);
|
|
}
|
|
+#undef IFA_STAT
|
|
}
|
|
-#endif /* XOSVIEW_OPENBSD */
|
|
+ freeifaddrs(ifap);
|
|
}
|
|
|
|
|