[PATCH 0/1] mm/hugetlb: add more arch-defined huge_pte_xxx functions

From: Gerald Schaefer
Date: Tue Mar 12 2013 - 14:48:56 EST


Using pte_t and pte_xxx functions in mm/hugetlbfs.c for "huge ptes" has
always been confusing and error-prone on architectures that have a
different layout for the pte/pmd/... level entries. That was the reason
for the individual arch header files in <arch>/include/asm/hugetlb.h
containing implementations for various huge_pte_xxx versions of the
original pte_xxx functions, if needed.

Commit abf09bed3c "s390/mm: implement software dirty bits" introduced
another difference in the pte layout vs. the pmd layout on s390,
thoroughly breaking the s390 support for hugetlbfs. This requires
replacing some more pte_xxx functions in mm/hugetlbfs.c with a
huge_pte_xxx version.

This patch introduces those huge_pte_xxx functions and their
implementation on all architectures supporting hugetlbfs. This change
will be a no-op for all architectures other than s390.

I am also thinking about a more complete clean-up patch, replacing all
remaining pte_xxx invocations in mm/hugetlbfs.c and maybe also
introducing a separate type like hpte_t to make this issue more
transparent and prevent future problems. But that may also require some
functional changes, and it probably won't be ready in time for Kernel
3.9. So for now, this patch only fixes the impact of the software dirty
bit changes on s390, hoping that it can be included in Kernel 3.9,
since that will be the first release including the sw dirty bits.

Gerald Schaefer (1):
mm/hugetlb: add more arch-defined huge_pte_xxx functions

arch/ia64/include/asm/hugetlb.h | 36 ++++++++++++++++++++++++
arch/mips/include/asm/hugetlb.h | 36 ++++++++++++++++++++++++
arch/powerpc/include/asm/hugetlb.h | 36 ++++++++++++++++++++++++
arch/s390/include/asm/hugetlb.h | 56 +++++++++++++++++++++++++++++++++++++-
arch/s390/include/asm/pgtable.h | 20 --------------
arch/s390/mm/hugetlbpage.c | 2 +-
arch/sh/include/asm/hugetlb.h | 36 ++++++++++++++++++++++++
arch/sparc/include/asm/hugetlb.h | 36 ++++++++++++++++++++++++
arch/tile/include/asm/hugetlb.h | 36 ++++++++++++++++++++++++
arch/x86/include/asm/hugetlb.h | 36 ++++++++++++++++++++++++
mm/hugetlb.c | 23 ++++++++--------
11 files changed, 320 insertions(+), 33 deletions(-)

--
1.7.12.4

--
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/