[PATCH 1/2] topdown support for ppc64

From: Andy Whitcroft
Date: Wed Sep 01 2004 - 08:54:21 EST


Recent patches introduced a top down user process address space
allocation policy; further patches enable this for ppc64.
Although these work correctly for normal maps, the topdown
algorithm does not take into account stringent mixing constraints
for small and large pages on this architecture. These patches
introduce a ppc64 specific arch_get_unused_area_topdown() variant.
The first introduces infrastructure to allow replacement of the
generic arch_get_unused_area_topdown() and the second utilises
this infrastructure.

In this patch I have followed the pattern set by the
arch_get_unused_area() using HAVE_ARCH_UNMAPPED_AREA_TOPDOWN to
be consistent. However, it would also be possible to simply have
a ppc64_get_unused_area_topdown() in the arch/ppc64/mm/mmap.c or
to use weak bindings.

-apw

=== 8< ===
Allow an architecture to override the default definition of
arch_get_unmapped_area_topdown().

Revision: $Rev: 602 $

Signed-off-by: Andy Whitcroft <apw@xxxxxxxxxxxx>

diffstat 090-arch_topdown
---
mmap.c | 2 ++
1 files changed, 2 insertions(+)

diff -X /home/apw/brief/lib/vdiff.excl -rupN reference/mm/mmap.c current/mm/mmap.c
--- reference/mm/mmap.c 2004-08-25 12:33:42.000000000 +0100
+++ current/mm/mmap.c 2004-08-26 12:26:59.000000000 +0100
@@ -1078,6 +1078,7 @@ void arch_unmap_area(struct vm_area_stru
* This mmap-allocator allocates new areas top-down from below the
* stack's low limit (the base):
*/
+#ifndef HAVE_ARCH_UNMAPPED_AREA_TOPDOWN
unsigned long
arch_get_unmapped_area_topdown(struct file *filp, const unsigned long addr0,
const unsigned long len, const unsigned long pgoff,
@@ -1162,6 +1163,7 @@ fail:

return addr;
}
+#endif

void arch_unmap_area_topdown(struct vm_area_struct *area)
{
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/