I'd really like to hear what happens when you enable it unconditionally,
and then run various real loads along with things like "lmbench".
Also, when you test forking over a parent, do you test just the fork, or
do you test the "fork+wait" combination that waits for the child to exit
too? The latter is the only really meaningful thing to test.
Anyway, the patch certainly looks pretty simple and small. Great.
> I haven't fully analyzed the locking yet, but I'm beginning to suspect it
> just works as is, i.e., I haven't exposed any new critical regions. I'd be
> happy to be corrected on that though.
What's the protection against two different MM's doing a
"zap_page_range()" concurrently, both thinking that they can just drop the
page table directory entry, and neither actually freeing it? I don't see
any such logic there..
I suspect that the only _good_ way to handle it is to do
pmd_page = ..
if (put_page_testzero(pmd_page)) {
.. free the actual page table entries ..
__free_pages_ok(pmd_page, 0);
}
instead of using the free_page() logic. Maybe you do that already, I
didn't go through the patches _that_ closely.
Ie you'd do a "two-phase" page free - first do the count handling, and if
that indicates you should really free the pmd, you free the lower page
tables before you physically free the pmd page (ie the page is "live" even
though it has a count of zero).
Linus
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/