Subject: tuning for small memory machines
To: None <tech-kern@netbsd.org, tech-perform@netbsd.org>
From: Simon Burge <simonb@wasabisystems.com>
List: tech-perform
Date: 11/27/2002 14:11:12
I've been noticing for a while that my 8MB pc532 has been getting slower
and slower. An example is that under 1.5X it takes just over 4 hours to
compile a kernel, with 1.6K it's just over 10 hours. This is with an
identical userland - only the kernel changed.
One benchmark I've been using to compiling pc532/machdep.c in
single-user mode. For the various kernels I had lying around in /,
here's some times:
NetBSD 1.5X: avail mem 6220 KB 55.189u 20.468s 2:06.78 59.6% 0+0k 71+63io 5364pf+0w
NetBSD 1.6C: avail mem 6168 KB 56.360u 482.015s 9:38.15 93.1% 0+0k 75+61io 62491pf+1w
NetBSD 1.6D: avail mem 6168 KB 56.027u 488.959s 9:44.56 93.2% 0+0k 75+59io 63718pf+1w
NetBSD 1.6J: avail mem 6132 KB 56.829u 643.266s 12:26.71 93.7% 0+0k 71+63io 90841pf+1w
NetBSD 1.6K: avail mem 6092 KB 56.683u 219.568s 11:55.53 38.6% 0+0k 71+57io 82888pf+1w
NetBSD 1.6K: avail mem 6232 KB 56.567u 220.508s 10:25.33 44.3% 0+0k 66+59io 76750pf+1w
The last 1.6K kernel has NFS removed to try to bring the available
memory back to what it was around 1.5X.
At Jason's suggestion, I started playing with the ubc tunable
parameters. After trying a couple of different combinations without
much gain, I just set all mins to 5% and all maxs to 10% - and the
compile speed returned back to what we were seeing in the 1.5X days.
Further analysis shows that it's pretty much just vm.anonmax that
affects things (for this particular benchmark). Here's some timings
for various values of anonmax:
vm.anonmax = 80 (default)
56.499u 197.264s 9:38.60 43.8% 0+0k 0+55io 70259pf+1w
56.595u 199.414s 11:03.29 38.5% 0+0k 0+56io 74919pf+1w
56.325u 220.143s 11:06.18 41.4% 0+0k 0+54io 78995pf+1w
vm.anonmax = 90
55.232u 22.921s 2:11.07 59.6% 0+0k 0+54io 6877pf+1w
55.491u 14.919s 1:45.78 66.5% 0+0k 0+55io 4000pf+1w
55.509u 13.182s 1:39.96 68.7% 0+0k 0+66io 3307pf+1w
vm.anonmax = 95
55.647u 8.334s 1:27.26 73.3% 0+0k 0+56io 1797pf+1w
55.735u 7.553s 1:22.23 76.9% 0+0k 0+54io 1408pf+1w
55.795u 8.724s 1:26.39 74.6% 0+0k 0+54io 1926pf+1w
vm.anonmax = 100
55.642u 8.270s 1:24.14 75.9% 0+0k 0+65io 1612pf+1w
55.534u 9.216s 1:27.40 74.0% 0+0k 0+64io 1927pf+1w
55.312u 8.331s 1:24.15 75.6% 0+0k 0+64io 1604pf+1w
I'm running with vm.anonmax=95 now.
Now, the question is should we automatically tune vm.anonmax up high
for low-memory situations? And what would qualify as a "low-memory"
situation?
Simon.
--
Simon Burge <simonb@wasabisystems.com>
NetBSD Development, Support and Service: http://www.wasabisystems.com/