Re: [PATCH 3/4] Check whether pages are poisoned before copying
From: Andrea Arcangeli
Date: Thu Mar 17 2011 - 12:13:10 EST
On Thu, Mar 17, 2011 at 04:25:59PM +0100, Andi Kleen wrote:
> > isn't 100% correct and probably it's impossible to make it 100%
> > correct across the whole kernel (for example the compound_head is safe
> > for THP but it's still unsafe for hugetlbfs while the page is being
> > tear down), so it's probably ok that it tends to work in practice 100%
> I would like to fix known oopses in the existing paths, so that should
> be probably fixed.
I agree with that. And still an oops is better than silent memory
> We measured KSM some time ago on some simple workloads (a couple
> of window guests) and it turned out that KSM memory tends to be
> only a very small fraction of total physical memory. So it was
> deemed not very important for hwpoison.
So it's your choice, I'm fine either ways...
What I can tell is with the default khugepaged scan rate, the
collapse_huge_page will have an impact much smaller than KSM. It could
have more impact than KSM if you increase khugepaged load to 100% with
sysfs (because of the more memory that is covered by khugepaged
compared to only the shared portion of KSM). Then the window gets much
bigger, but still minor, if you can't trigger it with the testsuite
it's even less likely to ever happen in practice.
Did you try the testsuite with khugepaged at 100% load? I think that's
good indication if this window has any practical significance.
But note that 100% khugepaged is unrealistic, because of how fast
khugepaged is, even a 10% CPU scan background load would be too
extreme even for huge amounts of memory.
So it's mostly up to you..
I think it needs more comments to explain why there are more loops
(only the lock_page has the comment) otherwise I guess over time it'll
get optimized away back again from people reading the code and not
checking ancient history in the git comments. Best would also be to
make it conditional to CONFIG_MEMORY_FAILURE=y but doing that for the
loops is a mess, at least the lock_page is doable (not that it matters
much but it's almost like a comment..).
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/