ports/153179: net-snmp corrected memory stats output patch

Y.A. nexther0 at gmail.com
Wed Dec 15 14:00:20 UTC 2010


>Number:         153179
>Category:       ports
>Synopsis:       net-snmp corrected memory stats output patch
>Confidential:   no
>Severity:       serious
>Priority:       low
>Responsible:    freebsd-ports-bugs
>State:          open
>Quarter:        
>Keywords:       
>Date-Required:
>Class:          sw-bug
>Submitter-Id:   current-users
>Arrival-Date:   Wed Dec 15 14:00:19 UTC 2010
>Closed-Date:
>Last-Modified:
>Originator:     Y.A.
>Release:        7.3-RELEASE
>Organization:
>Environment:
FreeBSD test.inernal.net 7.3-RELEASE FreeBSD 7.3-RELEASE #2: Fri Jun 11 13:45:01 EEST 2010 root at test.inernal.net:/usr/obj/usr/src/sys/TEST amd64
>Description:
hi!

I create new version of patch-memory_freebsd.c which give us mostly right memory statistic output for UCD-SNMP-MIB and HOST_RESOURSE-MIB.


>How-To-Repeat:
compare output from snmpwalk memory from host and sysctl vm.stats.vm

>Fix:
take this patch and replace files/patch-memory_freebsd.c from net-snmp port dir

Patch attached with submission follows:

--- 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;
+    unsigned int   cache_count;
+    unsigned int   cache_max;
     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,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
     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  = page_count;
         mem->free  = total.t_free;
     }
 
@@ -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  = phys_mem/pagesize + 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");
-        mem->units = vmem.v_page_size;
-        mem->size  = vmem.v_cache_max;
-        mem->free  = vmem.v_cache_max - vmem.v_cache_count;
+        mem->units = pagesize;
+        mem->size  = cache_count + inact_count;
+        mem->free  = cache_max - cache_count;
     }
 
-    nswap = swapmode(pagesize);
     mem = netsnmp_memory_get_byIdx( NETSNMP_MEM_TYPE_SWAP, 1 );
     if (!mem) {
         snmp_log_perror("No Swap info entry");


>Release-Note:
>Audit-Trail:
>Unformatted:



More information about the freebsd-ports-bugs mailing list