Re: [PATCH v3 00/10] Introduce huge zero page

From: Andrea Arcangeli
Date: Tue Oct 02 2012 - 18:59:30 EST


Hi Andrew,

On Tue, Oct 02, 2012 at 03:31:48PM -0700, Andrew Morton wrote:
> From reading the code, it appears that we initially allocate a huge
> page and point the pmd at that. If/when there is a write fault against
> that page we then populate the mm with ptes which point at the normal
> 4k zero page and populate the pte at the fault address with a newly
> allocated page? Correct and complete? If not, please fix ;)

During the cow, we never use 4k ptes, unless the 2m page allocation
fails.

> Also, IIRC, the early versions of the patch did not allocate the
> initial huge page at all - it immediately filled the mm with ptes which
> point at the normal 4k zero page. Is that a correct recollection?
> If so, why the change?

That was a different design yes. The design in this patchset will not
do that.

> Also IIRC, Andrea had a little test app which demonstrated the TLB
> costs of the inital approach, and they were high?

Yes we run the benchmarks yesterday, this version is the one that will
decrease the TLB cost and that seems the safest tradeoff.

> Please, let's capture all this knowledge in a single place, right here
> in the changelog. And in code comments, where appropriate. Otherwise
> people won't know why we made these decisions unless they go off and
> find lengthy, years-old and quite possibly obsolete email threads.

Agreed ;).

> Also, you've presented some data on the memory savings, but no
> quantitative testing results on the performance cost. Both you and
> Andrea have run these tests and those results are important. Let's
> capture them here. And when designing such tests we should not just
> try to demonstrate the benefits of a code change - we should think of
> test cases whcih might be adversely affected and run those as well.

Right.

> It's not an appropriate time to be merging new features - please plan
> on preparing this patchset against 3.7-rc1.

Ok, I assume Kirill will take care of it.

Thanks,
Andrea
--
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/