Subject: Re: Can't lock even 4GB on system with 8GB RAM?
To: None <tls@rek.tjls.com>
From: Jonathan Stone <jonathan@Pescadero.dsg.stanford.edu>
List: port-amd64
Date: 01/12/2006 20:27:23
In message <20060113020701.GA5477@panix.com>Thor Lancelot Simon writes
>I have an amd64 system with 8GB of RAM.  I'm trying to run a memory tester,
>and find that even with the datasize, memoryuse, and memorylocked hard and
>soft limits set to unlimited, I can't mlock even 4GB.
>
Below is an ugly 30-second kludge I used yesterday to make progress on
another issue, for which this retardd mlock() limit was a roadblock.
Setting raw pageframe counts with no bounds-check is clearly too
fragile for normal use (let alone commit).  One should instead
allocate a new parameter number in uvm_param.h, add a switch-entry for
that new parameter to update_vm_updateminmax() and route any
userland-initiated sysctl changes via sysctl_vm_updateminmax() for
vetting.
Left as an exercise for the reader... 
Index: uvm_meter.c
===================================================================
RCS file: /cvsroot/src/sys/uvm/uvm_meter.c,v
retrieving revision 1.33
diff -w -u -r1.33 uvm_meter.c
--- uvm_meter.c	10 Oct 2004 09:57:31 -0000	1.33
+++ uvm_meter.c
@@ -411,6 +411,23 @@
 		       SYSCTL_DESCR("Whether try to zero pages in idle loop"),
 		       NULL, 0, &vm_page_zero_enable, 0,
 		       CTL_VM, CTL_CREATE, CTL_EOL);
+
+	/*XXX make wiredmax a percentage via sysctl_vm_updateminmax? */
+ 	sysctl_createv(clog, 0, NULL, NULL,
+		       CTLFLAG_PERMANENT|CTLFLAG_READONLY,
+		       CTLTYPE_INT, "npages",
+		       SYSCTL_DESCR(" count of physical "
+				    "pages managed via uvm"),
+		       NULL, 0, &uvmexp.npages, 0,
+		       CTL_VM, CTL_CREATE, CTL_EOL);
+
+ 	sysctl_createv(clog, 0, NULL, NULL,
+		       CTLFLAG_PERMANENT|CTLFLAG_READWRITE,
+		       CTLTYPE_INT, "wiredmax",
+		       SYSCTL_DESCR("maximum count of physical "
+				    "pages lockable via mlock() and friends"),
+		       NULL, 0, &uvmexp.wiredmax, 0,
+		       CTL_VM, CTL_CREATE, CTL_EOL);
 }
 
 /*