|| ||Christoph Lameter <email@example.com>|
|| ||[RFC3 00/14] Zoned VM stats|
|| ||Wed, 14 Dec 2005 16:14:15 -0800 (PST)|
|| ||firstname.lastname@example.org, Hugh Dickins <email@example.com>,
Nick Piggin <firstname.lastname@example.org>, email@example.com,
Andi Kleen <firstname.lastname@example.org>,
Marcelo Tosatti <email@example.com>,
Christoph Lameter <firstname.lastname@example.org>|
Zone based VM statistics are necessary to be able to determine what the state
of memory in one zone is. In a NUMA system this can be helpful to do local
reclaim and other memory optimizations by shifting VM load to optimize
page allocation. It is also helpful to know how the computing load affects
the memory allocations on various zones.
The patchset introduces a framework for counters that is a cross between the
existing page_stats --which are simply global counters split per cpu-- and the
approach of deferred incremental updates implemented for nr_pagecache.
Small per cpu 8 bit counters are introduced in struct zone. If counting
exceeds certain threshold then the counters are accumulated in an array in
the zone of the page and in a global array. This means that access to
VM counter information for a zone and for the whole machine is possible
by simply indexing an array. [Thanks to Nick Piggin for pointing me
at that approach].
The new statistics are then used to realize zone reclaim.
Patchset is against 2.6.15-rc5-mm2. The patches after zone reclaim are optional.
This is expanding and I hope its complete. But I have not tested it in UP and SMP yet.
There may be yet unforeseen consequences to the changes to various counters.
1 Add some consts for inlines in mm.h
2 Basic counter functionality
3 Convert nr_mapped
4 Convert nr_pagecache
5 Resurrect scan_control.may_swap
6 Zone Reclaim
7 Expanded node and zone statistics
8 Convert nr_slab
9 Convert nr_page_table
10 Convert nr_dirty
11 Convert nr_writeback
12 Convert nr_unstable
13 Remove get_page_state functions
14 Remove wbs