On 3/24/20 12:08 PM, Michael Ellerman wrote:
"Aneesh Kumar K.V" <[email protected]> writes:
THP config can result in compound pages. Make sure kernel enables the
PageCompound() check when only THP is enabled.
Or else what happens ... nothing, rampant data corruption, something in
between?
We can get a stale icache that can result in undefined behavior?
And "when only THP is enabled" is not very clear, AFAIK there is no
relation between CONFIG_TRANSPARENT_HUGEPAGE and CONFIG_HUGETLB_PAGE.
yes, there is no relation between them. But the way current code is
enabled if we have both enabled, we will find that
if (PageCompound(page)) check present which will handle THP case too.
Now with current code if we have CONFIG_HUGETLB_PAGE disabled, we
compile out if (pageCompound(page)) check and hence don't invalidate
compound pages correctly (THP create compound pages here)
You mean when either or both of THP or HUGETLB is enabled right?
cheers
diff --git a/arch/powerpc/mm/mem.c b/arch/powerpc/mm/mem.c
index 9b4f5fb719e0..b03cbddf9054 100644
--- a/arch/powerpc/mm/mem.c
+++ b/arch/powerpc/mm/mem.c
@@ -485,7 +485,7 @@ EXPORT_SYMBOL(flush_dcache_page);
void flush_dcache_icache_page(struct page *page)
{
-#ifdef CONFIG_HUGETLB_PAGE
+#if defined(CONFIG_TRANSPARENT_HUGEPAGE) || defined(CONFIG_HUGETLB_PAGE)
if (PageCompound(page)) {
flush_dcache_icache_hugepage(page);
return;
--
2.25.1