aboutsummaryrefslogtreecommitdiffstats
path: root/net-mgmt
diff options
context:
space:
mode:
authorsylvio <sylvio@FreeBSD.org>2011-02-04 03:34:40 +0800
committersylvio <sylvio@FreeBSD.org>2011-02-04 03:34:40 +0800
commita5bf4c987ccbf7cab3d794a323614ae0e79df703 (patch)
tree0ddace82d663ef51582c26c27c5dc3eb8b140a17 /net-mgmt
parent7230c438f6cbdb972cdc42e1c0463a38cf84e968 (diff)
downloadfreebsd-ports-graphics-a5bf4c987ccbf7cab3d794a323614ae0e79df703.tar.gz
freebsd-ports-graphics-a5bf4c987ccbf7cab3d794a323614ae0e79df703.tar.zst
freebsd-ports-graphics-a5bf4c987ccbf7cab3d794a323614ae0e79df703.zip
- new version of patch-memory_freebsd.c
- right memory statistic output for UCD-SNMP-MIB and HOST_RESOURSE-MIB. PR: ports/153179 Submitted by: "Y.A." <nexther0@gmail.com> Feature safe: yes
Diffstat (limited to 'net-mgmt')
-rw-r--r--net-mgmt/net-snmp/files/patch-memory_freebsd.c71
1 files changed, 62 insertions, 9 deletions
diff --git a/net-mgmt/net-snmp/files/patch-memory_freebsd.c b/net-mgmt/net-snmp/files/patch-memory_freebsd.c
index 3dc734a2943..2db2d6e2c14 100644
--- a/net-mgmt/net-snmp/files/patch-memory_freebsd.c
+++ b/net-mgmt/net-snmp/files/patch-memory_freebsd.c
@@ -1,6 +1,6 @@
---- agent/mibgroup/hardware/memory/memory_freebsd.c.orig 2010-06-29 12:34:48.000000000 +0200
-+++ agent/mibgroup/hardware/memory/memory_freebsd.c 2010-07-01 13:32:34.000000000 +0200
-@@ -43,10 +43,15 @@
+--- agent/mibgroup/hardware/memory/memory_freebsd.c.orig 2008-05-28 14:48:46.000000000 +0300
++++ agent/mibgroup/hardware/memory/memory_freebsd.c 2010-12-15 14:56:48.000000000 +0200
+@@ -43,10 +43,17 @@
u_long phys_mem;
u_long user_mem;
@@ -9,36 +9,85 @@
unsigned int bufspace;
unsigned int maxbufspace;
+ unsigned int inact_count;
++ unsigned int page_count;
size_t mem_size = sizeof(phys_mem);
+ size_t cache_size = sizeof(cache_count);
size_t buf_size = sizeof(bufspace);
+ size_t inact_size = sizeof(inact_count);
++ size_t page_size = sizeof(page_count);
int phys_mem_mib[] = { CTL_HW, HW_PHYSMEM };
int user_mem_mib[] = { CTL_HW, HW_USERMEM };
-@@ -56,9 +61,11 @@
+@@ -56,15 +63,20 @@
sysctl(total_mib, 2, &total, &total_size, NULL, 0);
sysctl(phys_mem_mib, 2, &phys_mem, &mem_size, NULL, 0);
sysctl(user_mem_mib, 2, &user_mem, &mem_size, NULL, 0);
+ sysctlbyname("vm.stats.vm.v_cache_count", &cache_count, &cache_size, NULL, 0);
+ sysctlbyname("vm.stats.vm.v_cache_max", &cache_max, &cache_size, NULL, 0);
+ sysctlbyname("vm.stats.vm.v_inactive_count", &inact_count, &inact_size, NULL, 0);
++ sysctlbyname("vm.stats.vm.v_page_count", &page_count, &page_size, NULL, 0);
sysctlbyname("vfs.bufspace", &bufspace, &buf_size, NULL, 0);
sysctlbyname("vfs.maxbufspace", &maxbufspace, &buf_size, NULL, 0);
- auto_nlist(SUM_SYMBOL, (char *) &vmem, sizeof(vmem));
#ifndef freebsd4
pagesize = 1024;
#else
-@@ -75,7 +82,7 @@
+ pagesize = getpagesize();
+ #endif
+
++ nswap = swapmode(pagesize);
++
+ /*
+ * ... and save this in a standard form.
+ */
+@@ -75,7 +87,7 @@
if (!mem->descr)
mem->descr = strdup("Physical memory");
mem->units = pagesize;
- mem->size = user_mem/pagesize;
-+ mem->size = phys_mem/pagesize;
++ mem->size = page_count;
mem->free = total.t_free;
}
-@@ -129,9 +136,9 @@
+@@ -87,7 +99,7 @@
+ mem->descr = strdup("Real memory");
+ mem->units = pagesize;
+ mem->size = total.t_rm;
+- mem->free = total.t_arm;
++ mem->free = total.t_rm - total.t_arm;
+ }
+
+ mem = netsnmp_memory_get_byIdx( NETSNMP_MEM_TYPE_VIRTMEM, 1 );
+@@ -97,8 +109,8 @@
+ if (!mem->descr)
+ mem->descr = strdup("Virtual memory");
+ mem->units = pagesize;
+- mem->size = total.t_vm;
+- mem->free = total.t_avm;
++ mem->size = page_count + swapTotal;
++ mem->free = total.t_free + swapFree;
+ }
+
+ mem = netsnmp_memory_get_byIdx( NETSNMP_MEM_TYPE_SHARED, 1 );
+@@ -109,7 +121,7 @@
+ mem->descr = strdup("Shared virtual memory");
+ mem->units = pagesize;
+ mem->size = total.t_vmshr;
+- mem->free = total.t_avmshr;
++ mem->free = total.t_vmshr - total.t_avmshr;
+ }
+
+ mem = netsnmp_memory_get_byIdx( NETSNMP_MEM_TYPE_SHARED2, 1 );
+@@ -120,7 +132,7 @@
+ mem->descr = strdup("Shared real memory");
+ mem->units = pagesize;
+ mem->size = total.t_rmshr;
+- mem->free = total.t_armshr;
++ mem->free = total.t_rmshr - total.t_armshr;
+ }
+
+ mem = netsnmp_memory_get_byIdx( NETSNMP_MEM_TYPE_CACHED, 1 );
+@@ -129,12 +141,11 @@
} else {
if (!mem->descr)
mem->descr = strdup("Cached memory");
@@ -46,8 +95,12 @@
- mem->size = vmem.v_cache_max;
- mem->free = vmem.v_cache_max - vmem.v_cache_count;
+ mem->units = pagesize;
-+ mem->size = cache_max + inact_count;
++ mem->size = cache_count + inact_count;
+ mem->free = cache_max - cache_count;
}
- nswap = swapmode(pagesize);
+- nswap = swapmode(pagesize);
+ mem = netsnmp_memory_get_byIdx( NETSNMP_MEM_TYPE_SWAP, 1 );
+ if (!mem) {
+ snmp_log_perror("No Swap info entry");
+