diff options
author | Christoph Lameter <clameter@sgi.com> | 2007-05-09 05:35:12 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2007-05-09 15:30:56 -0400 |
commit | d1187ed21026fd512b87851d0ca26d9ae16f9059 (patch) | |
tree | 35d77758f134f3b69d3e00ca042a5d5ca6a59373 /mm/slub.c | |
parent | 455c017ae3934797653549704c286e7bcc3a9397 (diff) |
vmstat: use our own timer events
vmstat is currently using the cache reaper to periodically bring the
statistics up to date. The cache reaper does only exists in SLUB as a way to
provide compatibility with SLAB. This patch removes the vmstat calls from the
slab allocators and provides its own handling.
The advantage is also that we can use a different frequency for the updates.
Refreshing vm stats is a pretty fast job so we can run this every second and
stagger this by only one tick. This will lead to some overlap in large
systems. F.e a system running at 250 HZ with 1024 processors will have 4 vm
updates occurring at once.
However, the vm stats update only accesses per node information. It is only
necessary to stagger the vm statistics updates per processor in each node. Vm
counter updates occurring on distant nodes will not cause cacheline
contention.
We could implement an alternate approach that runs the first processor on each
node at the second and then each of the other processor on a node on a
subsequent tick. That may be useful to keep a large amount of the second free
of timer activity. Maybe the timer folks will have some feedback on this one?
[jirislaby@gmail.com: add missing break]
Cc: Arjan van de Ven <arjan@linux.intel.com>
Signed-off-by: Christoph Lameter <clameter@sgi.com>
Signed-off-by: Jiri Slaby <jirislaby@gmail.com>
Cc: Oleg Nesterov <oleg@tv-sign.ru>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'mm/slub.c')
-rw-r--r-- | mm/slub.c | 1 |
1 files changed, 0 insertions, 1 deletions
@@ -2580,7 +2580,6 @@ static DEFINE_PER_CPU(struct delayed_work, reap_work); | |||
2580 | static void cache_reap(struct work_struct *unused) | 2580 | static void cache_reap(struct work_struct *unused) |
2581 | { | 2581 | { |
2582 | next_reap_node(); | 2582 | next_reap_node(); |
2583 | refresh_cpu_vm_stats(smp_processor_id()); | ||
2584 | schedule_delayed_work(&__get_cpu_var(reap_work), | 2583 | schedule_delayed_work(&__get_cpu_var(reap_work), |
2585 | REAPTIMEOUT_CPUC); | 2584 | REAPTIMEOUT_CPUC); |
2586 | } | 2585 | } |