On Mon, May 13, 2013 at 04:14:06PM -0700, akpm@linux-foundation.org wrote: > From: "Aneesh Kumar K.V" > Subject: mm/THP: don't use HPAGE_SHIFT in transparent hugepage code > > For architectures like powerpc that support multiple explicit hugepage > sizes, HPAGE_SHIFT indicate the default explicit hugepage shift. For THP > to work the hugepage size should be same as PMD_SIZE. So use PMD_SHIFT > directly. So move the define outside CONFIG_TRANSPARENT_HUGEPAGE #ifdef > because we want to use these defines in generic code with if > (pmd_trans_huge()) conditional. I would propose to partly revert the patch with the patch bellow. Rationale: PMD_SHIFT is not defined in some configurations like nommu (allnoconfig on ARM). It blocks valid usecases in common code, like: if (PageTransHuge(page)) do_something_with(HPAGE_PMD_SIZE); And requires ugly ifdefs. I also found BUILD_BUG() useful to trigger bugs earlier for !THP configurations. The original patch was proposed as part of THP enabling on PPC. The patch below requires trivial adjustment for PPC THP patchset. Changes required for V10 is attached. diff --git a/include/linux/huge_mm.h b/include/linux/huge_mm.h index cc276d2..e2dbefb 100644 --- a/include/linux/huge_mm.h +++ b/include/linux/huge_mm.h @@ -58,11 +58,12 @@ extern pmd_t *page_check_address_pmd(struct page *page, #define HPAGE_PMD_ORDER (HPAGE_PMD_SHIFT-PAGE_SHIFT) #define HPAGE_PMD_NR (1<