Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src add two new members to uvmexp_sysctl{}: bootpages and poolp...



details:   https://anonhg.NetBSD.org/src/rev/206c8c6bd9aa
branches:  trunk
changeset: 357902:206c8c6bd9aa
user:      mrg <mrg%NetBSD.org@localhost>
date:      Sat Dec 02 08:15:42 2017 +0000

description:
add two new members to uvmexp_sysctl{}:  bootpages and poolpages.
bootpages is set to the pages allocated via uvm_pageboot_alloc().
poolpages is calculated from the list of pools nr_pages members.

this brings us closer to having a valid total of pages known by
the system, vs actual pages originally managed.

XXX: poolpages needs some handling for PR_RECURSIVE pools still.

diffstat:

 sys/kern/subr_pool.c    |  25 +++++++++++++++++++++++--
 sys/sys/pool.h          |   3 ++-
 sys/uvm/uvm_extern.h    |   6 +++++-
 sys/uvm/uvm_meter.c     |   6 ++++--
 sys/uvm/uvm_page.c      |   5 +++--
 sys/uvm/uvm_stat.c      |  10 ++++++++--
 usr.bin/vmstat/vmstat.c |  25 +++++++++++++++++++++----
 7 files changed, 66 insertions(+), 14 deletions(-)

diffs (261 lines):

diff -r d929d08bdca6 -r 206c8c6bd9aa sys/kern/subr_pool.c
--- a/sys/kern/subr_pool.c      Sat Dec 02 01:36:38 2017 +0000
+++ b/sys/kern/subr_pool.c      Sat Dec 02 08:15:42 2017 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: subr_pool.c,v 1.216 2017/11/14 15:02:06 christos Exp $ */
+/*     $NetBSD: subr_pool.c,v 1.217 2017/12/02 08:15:42 mrg Exp $      */
 
 /*-
  * Copyright (c) 1997, 1999, 2000, 2002, 2007, 2008, 2010, 2014, 2015
@@ -33,7 +33,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: subr_pool.c,v 1.216 2017/11/14 15:02:06 christos Exp $");
+__KERNEL_RCSID(0, "$NetBSD: subr_pool.c,v 1.217 2017/12/02 08:15:42 mrg Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_ddb.h"
@@ -1453,6 +1453,27 @@
 }
 
 /*
+ * Calculate the total number of pages consumed by pools.
+ */
+int
+pool_totalpages(void)
+{
+       struct pool *pp;
+       int total = 0;
+
+       mutex_enter(&pool_head_lock);
+       TAILQ_FOREACH(pp, &pool_head, pr_poollist)
+               /*
+                * XXXMRG
+               if ((pp->pr_roflags & PR_RECURSIVE) == 0)
+                */
+                       total += pp->pr_npages;
+       mutex_exit(&pool_head_lock);
+
+       return total;
+}
+
+/*
  * Diagnostic helpers.
  */
 
diff -r d929d08bdca6 -r 206c8c6bd9aa sys/sys/pool.h
--- a/sys/sys/pool.h    Sat Dec 02 01:36:38 2017 +0000
+++ b/sys/sys/pool.h    Sat Dec 02 08:15:42 2017 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: pool.h,v 1.80 2017/10/28 19:19:10 riastradh Exp $      */
+/*     $NetBSD: pool.h,v 1.81 2017/12/02 08:15:43 mrg Exp $    */
 
 /*-
  * Copyright (c) 1997, 1998, 1999, 2000, 2007 The NetBSD Foundation, Inc.
@@ -307,6 +307,7 @@
 void           pool_sethiwat(struct pool *, int);
 void           pool_sethardlimit(struct pool *, int, const char *, int);
 bool           pool_drain(struct pool **);
+int            pool_totalpages(void);
 
 /*
  * Debugging and diagnostic aides.
diff -r d929d08bdca6 -r 206c8c6bd9aa sys/uvm/uvm_extern.h
--- a/sys/uvm/uvm_extern.h      Sat Dec 02 01:36:38 2017 +0000
+++ b/sys/uvm/uvm_extern.h      Sat Dec 02 08:15:42 2017 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: uvm_extern.h,v 1.206 2017/05/20 07:27:15 chs Exp $     */
+/*     $NetBSD: uvm_extern.h,v 1.207 2017/12/02 08:15:43 mrg Exp $     */
 
 /*
  * Copyright (c) 1997 Charles D. Cranor and Washington University.
@@ -408,6 +408,8 @@
        int pdreanon;   /* anon pages reactivated due to thresholds */
        int pdrefile;   /* file pages reactivated due to thresholds */
        int pdreexec;   /* executable pages reactivated due to thresholds */
+
+       int bootpages;  /* number of pages stolen at boot */
 };
 
 /*
@@ -493,6 +495,8 @@
        int64_t colorhit;
        int64_t colormiss;
        int64_t ncolors;
+       int64_t bootpages;
+       int64_t poolpages;
 };
 
 #ifdef _KERNEL
diff -r d929d08bdca6 -r 206c8c6bd9aa sys/uvm/uvm_meter.c
--- a/sys/uvm/uvm_meter.c       Sat Dec 02 01:36:38 2017 +0000
+++ b/sys/uvm/uvm_meter.c       Sat Dec 02 08:15:42 2017 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: uvm_meter.c,v 1.66 2017/07/02 16:41:33 joerg Exp $     */
+/*     $NetBSD: uvm_meter.c,v 1.67 2017/12/02 08:15:43 mrg Exp $       */
 
 /*
  * Copyright (c) 1997 Charles D. Cranor and Washington University.
@@ -36,7 +36,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: uvm_meter.c,v 1.66 2017/07/02 16:41:33 joerg Exp $");
+__KERNEL_RCSID(0, "$NetBSD: uvm_meter.c,v 1.67 2017/12/02 08:15:43 mrg Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -177,6 +177,8 @@
        u.colorhit = uvmexp.colorhit;
        u.colormiss = uvmexp.colormiss;
        u.ncolors = uvmexp.ncolors;
+       u.bootpages = uvmexp.bootpages;
+       u.poolpages = pool_totalpages();
 
        node = *rnode;
        node.sysctl_data = &u;
diff -r d929d08bdca6 -r 206c8c6bd9aa sys/uvm/uvm_page.c
--- a/sys/uvm/uvm_page.c        Sat Dec 02 01:36:38 2017 +0000
+++ b/sys/uvm/uvm_page.c        Sat Dec 02 08:15:42 2017 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: uvm_page.c,v 1.194 2017/10/28 00:37:13 pgoyette Exp $  */
+/*     $NetBSD: uvm_page.c,v 1.195 2017/12/02 08:15:43 mrg Exp $       */
 
 /*
  * Copyright (c) 1997 Charles D. Cranor and Washington University.
@@ -66,7 +66,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: uvm_page.c,v 1.194 2017/10/28 00:37:13 pgoyette Exp $");
+__KERNEL_RCSID(0, "$NetBSD: uvm_page.c,v 1.195 2017/12/02 08:15:43 mrg Exp $");
 
 #include "opt_ddb.h"
 #include "opt_uvm.h"
@@ -538,6 +538,7 @@
 
        /* round to page size */
        size = round_page(size);
+       uvmexp.bootpages += atop(size);
 
 #if defined(PMAP_STEAL_MEMORY)
 
diff -r d929d08bdca6 -r 206c8c6bd9aa sys/uvm/uvm_stat.c
--- a/sys/uvm/uvm_stat.c        Sat Dec 02 01:36:38 2017 +0000
+++ b/sys/uvm/uvm_stat.c        Sat Dec 02 08:15:42 2017 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: uvm_stat.c,v 1.38 2016/12/01 01:59:17 mrg Exp $         */
+/*     $NetBSD: uvm_stat.c,v 1.39 2017/12/02 08:15:43 mrg Exp $         */
 
 /*
  * Copyright (c) 1997 Charles D. Cranor and Washington University.
@@ -32,7 +32,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: uvm_stat.c,v 1.38 2016/12/01 01:59:17 mrg Exp $");
+__KERNEL_RCSID(0, "$NetBSD: uvm_stat.c,v 1.39 2017/12/02 08:15:43 mrg Exp $");
 
 #include "opt_readahead.h"
 #include "opt_ddb.h"
@@ -46,6 +46,8 @@
 
 #ifdef DDB
 
+#include <sys/pool.h>
+
 /*
  * uvmexp_print: ddb hook to print interesting uvm counters
  */
@@ -54,10 +56,12 @@
     __attribute__((__format__(__printf__,1,2))))
 {
        int active, inactive;
+       int poolpages;
        CPU_INFO_ITERATOR cii;
        struct cpu_info *ci;
 
        uvm_estimatepageable(&active, &inactive);
+       poolpages = pool_totalpages();
 
        (*pr)("Current UVM status:\n");
        (*pr)("  pagesize=%d (0x%x), pagemask=0x%x, pageshift=%d, ncolors=%d\n",
@@ -72,6 +76,8 @@
            uvmexp.freemin, uvmexp.freetarg, uvmexp.wiredmax);
        (*pr)("  resv-pg=%d, resv-kernel=%d, zeropages=%d\n",
            uvmexp.reserve_pagedaemon, uvmexp.reserve_kernel, uvmexp.zeropages);
+       (*pr)("  bootpages=%d, poolpages=%d\n",
+           uvmexp.bootpages, poolpages);
 
        for (CPU_INFO_FOREACH(cii, ci)) {
                (*pr)("  cpu%u:\n", cpu_index(ci));
diff -r d929d08bdca6 -r 206c8c6bd9aa usr.bin/vmstat/vmstat.c
--- a/usr.bin/vmstat/vmstat.c   Sat Dec 02 01:36:38 2017 +0000
+++ b/usr.bin/vmstat/vmstat.c   Sat Dec 02 08:15:42 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: vmstat.c,v 1.220 2017/11/03 22:45:14 pgoyette Exp $ */
+/* $NetBSD: vmstat.c,v 1.221 2017/12/02 08:15:43 mrg Exp $ */
 
 /*-
  * Copyright (c) 1998, 2000, 2001, 2007 The NetBSD Foundation, Inc.
@@ -70,7 +70,7 @@
 #if 0
 static char sccsid[] = "@(#)vmstat.c   8.2 (Berkeley) 3/1/95";
 #else
-__RCSID("$NetBSD: vmstat.c,v 1.220 2017/11/03 22:45:14 pgoyette Exp $");
+__RCSID("$NetBSD: vmstat.c,v 1.221 2017/12/02 08:15:43 mrg Exp $");
 #endif
 #endif /* not lint */
 
@@ -892,6 +892,10 @@
                        warn("sysctl vm.uvmexp2 failed");
        } else {
                struct uvmexp uvmexp_kernel;
+               struct pool pool, *pp = &pool;
+               TAILQ_HEAD(,pool) pool_head;
+               void *addr;
+
                kread(namelist, X_UVMEXP, &uvmexp_kernel, sizeof(uvmexp_kernel));
 #define COPY(field) uvmexp.field = uvmexp_kernel.field
                COPY(pagesize);
@@ -955,7 +959,18 @@
                COPY(pdbusy);
                COPY(pdpending);
                COPY(pddeact);
+               COPY(bootpages);
 #undef COPY
+               kread(namelist, X_POOLHEAD, &pool_head, sizeof(pool_head));
+               addr = TAILQ_FIRST(&pool_head);
+               for (; addr != NULL; addr = TAILQ_NEXT(pp, pr_poollist)) {
+                       deref_kptr(addr, pp, sizeof(*pp), "pool chain trashed");
+                       /*
+                        * XXXMRG
+                       if ((pp->pr_roflags & PR_RECURSIVE) == 0)
+                        */
+                               uvmexp.poolpages += pp->pr_npages;
+               }
        }
 
 
@@ -976,6 +991,8 @@
        (void)printf("%9" PRIu64 " reserve pagedaemon pages\n",
            uvmexp.reserve_pagedaemon);
        (void)printf("%9" PRIu64 " reserve kernel pages\n", uvmexp.reserve_kernel);
+       (void)printf("%9" PRIu64 " boot kernel pages\n", uvmexp.bootpages);
+       (void)printf("%9" PRIu64 " kernel pool pages\n", uvmexp.poolpages);
        (void)printf("%9" PRIu64 " anonymous pages\n", uvmexp.anonpages);
        (void)printf("%9" PRIu64 " cached file pages\n", uvmexp.filepages);
        (void)printf("%9" PRIu64 " cached executable pages\n", uvmexp.execpages);
@@ -2251,9 +2268,9 @@
  /*
   * Actually dump the history buffer at the specified KVA.
   */
- void
+void
 hist_dodump_sysctl(int mib[], unsigned int miblen)
- {
+{
        struct sysctl_history *hist;
        struct timeval tv;
        struct sysctl_history_event *e;



Home | Main Index | Thread Index | Old Index