powerpc: Only demote individual slices rather than whole process
authorPaul Mackerras <paulus@samba.org>
Wed, 18 Jun 2008 05:29:12 +0000 (15:29 +1000)
committerPaul Mackerras <paulus@samba.org>
Tue, 1 Jul 2008 01:27:57 +0000 (11:27 +1000)
commit3a8247cc2c856930f34eafce33f6a039227ee175
treeaa8599cdf09893f1150a2bc137878d8b8a661780
parente952e6c4d6635b36c212c056a9427bd93460178c
powerpc: Only demote individual slices rather than whole process

At present, if we have a kernel with a 64kB page size, and some
process maps something that has to be mapped with 4kB pages (such as a
cache-inhibited mapping on POWER5+, or the eHCA infiniband queue-pair
pages), we change the process to use 4kB pages everywhere.  This hurts
the performance of HPC programs that access eHCA from userspace.

With this patch, the kernel will only demote the slice(s) containing
the eHCA or cache-inhibited mappings, leaving the remaining slices
able to use 64kB hardware pages.

This also changes the slice_get_unmapped_area code so that it is
willing to place a 64k-page mapping into (or across) a 4k-page slice
if there is no better alternative, i.e. if the program specified
MAP_FIXED or if there is not sufficient space available in slices that
are either empty or already have 64k-page mappings in them.

Signed-off-by: Paul Mackerras <paulus@samba.org>
Acked-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
arch/powerpc/mm/hash_utils_64.c
arch/powerpc/mm/slice.c
arch/powerpc/platforms/Kconfig.cputype
include/asm-powerpc/page_64.h