diff options
author | de Dinechin, Christophe (Integrity VM) <christophe.de-dinechin@hp.com> | 2007-12-13 16:03:07 +0100 |
---|---|---|
committer | Tony Luck <tony.luck@intel.com> | 2007-12-19 01:56:50 +0100 |
commit | aec103bfa60e9f72bd66a144236592f54b986a03 (patch) | |
tree | 90c1cf2de8853dd6e3972f295d1aecfe3aee507a /arch/ia64/mm/hugetlbpage.c | |
parent | [IA64] ia32 nopage (diff) | |
download | linux-aec103bfa60e9f72bd66a144236592f54b986a03.tar.xz linux-aec103bfa60e9f72bd66a144236592f54b986a03.zip |
[IA64] Avoid unnecessary TLB flushes when allocating memory
Improve performance of memory allocations on ia64 by avoiding a global TLB
purge to purge a single page from the file cache. This happens whenever we
evict a page from the buffer cache to make room for some other allocation.
Test case: Run 'find /usr -type f | xargs cat > /dev/null' in the
background to fill the buffer cache, then run something that uses memory,
e.g. 'gmake -j50 install'. Instrumentation showed that the number of
global TLB purges went from a few millions down to about 170 over a 12
hours run of the above.
The performance impact is particularly noticeable under virtualization,
because a virtual TLB is generally both larger and slower to purge than
a physical one.
Signed-off-by: Christophe de Dinechin <ddd@hp.com>
Signed-off-by: Tony Luck <tony.luck@intel.com>
Diffstat (limited to 'arch/ia64/mm/hugetlbpage.c')
0 files changed, 0 insertions, 0 deletions