[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <48F37190.2020801@linux-foundation.org>
Date: Mon, 13 Oct 2008 09:04:32 -0700
From: Christoph Lameter <cl@...ux-foundation.org>
To: Andy Whitcroft <apw@...dowen.org>
CC: Andrew Morton <akpm@...ux-foundation.org>, linux-mm@...ck.org,
linux-kernel@...r.kernel.org,
Jon Tollefson <kniht@...ux.vnet.ibm.com>,
Mel Gorman <mel@....ul.ie>,
Nick Piggin <nickpiggin@...oo.com.au>
Subject: Re: [PATCH 1/1] hugetlbfs: handle pages higher order than MAX_ORDER
Andy Whitcroft wrote:
> Currently memory hot remove is not supported with VMEMMAP. Obviously
> that should be fixed overall and I am assuming it will. But the fact
> remains that the buddy guarentee is that the mem_map is contigious out
> to MAX_ORDER-1 order pages only beyond that we may not assume
> contiguity. This code is broken under the guarentees that are set out
> by buddy. Yes it is true that we do only have one memory model combination
> currently where a greater guarentee of contigious within a node is
> violated, but right now this code violates the current guarentees.
>
> I assume the objection here is the injection of the additional branch
> into these loops. The later rejig patch removes this for the non-giant
> cases for the non-huge use cases. Are we worried about these same
> branches in the huge cases? If so we could make this support dependant
> on a new configuration option, or perhaps only have two loop chosen
> based on the order of the page.
>
I think we are worried about these additional checks spreading further
because there may be assumptions of contiguity elsewhere (in particular
when new code is added) since the traditional nature of the memmap is to
be linear and not spread out over memory.
A fix for this particular situation may be as simple as making gigantic
pages depend on SPARSE_VMEMMAP? For x86_64 this is certainly sufficient.
> Something like the patch below? This patch is not tested as yet, but if
> this form is acceptable we can get the pair of patches (this plus the
> prep compound update) tested together and I can repost them once that is
> done. This against 2.6.27.
>
What is the difference here to the earlier versions?
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists