On Tue, 12 Mar 2013 15:00:37 -0400 Chris Metcalf <cmetcalf@xxxxxxxxxx> wrote: > On 3/12/2013 2:48 PM, Gerald Schaefer wrote: > > 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. > > > > [...] > > > > +static inline pte_t mk_huge_pte(struct page *page, pgprot_t pgprot) > > +{ > > + return mk_pte(page, pgprot); > > +} > > Does it make sense to merge this new per-arch function with the existing per-arch arch_make_huge_pte() function? Certainly in the tile case, we could set up our "super" bit in the initial mk_huge_pte() call, and then set "young" and "huge" after that in the platform-independent caller (make_huge_pte). This would allow your change to eliminate some code as well as just introducing code :-) > Yes, I guess there is also some potential of optimizing/eliminating existing code. Apart from the arch_make_huge_pte() that you mentioned, there is also a pte_mkhuge() left over, which looks like it should be merged into the new mk_huge_pte(). But that would probably require more modifications than I'd dare to bring up on rc3+. So the main focus of this patch is to fix the bug on s390 with sw dirty bits before that bug appears in 3.9, and therefore I'd like to keep it as simple as possible and w/o functional changes on any other architecture for now. Thanks, Gerald -- To unsubscribe from this list: send the line "unsubscribe linux-arch" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html