Re: FW: [PATCH] powerpc/mm: Export HPAGE_SHIFT

From: Andrew Morton
Date: Wed Feb 04 2009 - 16:24:04 EST


On Wed, 04 Feb 2009 11:11:22 -0800
Roland Dreier <rdreier@xxxxxxxxx> wrote:

> > > > huge_page_size(page_hstate(page))
>
> > > That would suit. I assume the intention is for that to be usable by
> > > driver modules on any architecture?
>
> > erm, you overestimate the amount of planning and forethought which goes
> > into these things ;)
>
> > The lack of any EXPORT_SYMBOL(size_to_hstate) is a broadish hint.
>
> Heh. Looking into the implementation, it seems that I could actually do
>
> PAGE_SIZE << compound_order(page)
>
> directly (since there's no reason to go from size to hstate and back to
> size. I don't know all the details of these VM internals, but that
> seems to only work on the first (small) page of a giant page? Which
> causes problems for what we're trying to do here...
>
> To summarize the goal, we are mapping user memory to a device that has
> its own page tables, where the device's page tables can also use
> multiple page sizes. Using big pages on the device leads to similar
> efficiencies as hugetlb pages do on the CPU, and in fact if a user has
> used hugetlb pages for the memory they're giving to the device, that's a
> very strong hint that the device should use big pages too.
>
> But one valid situation we have to handle in the driver is if, say,
> userspace has a hugetlb mapped at virtual address 0x200000, and wants to
> map 0x80000 bytes at 0x280000 to the device. In that case, we're going
> to do essentially
>
> get_user_pages(..., 0x280000, 0x80000 / PAGE_SIZE, ...)
>
> and get_user_pages() is going to give us a bunch of normal PAGE_SIZE
> pages starting at offset 0x800000 within the compound page that makes up
> the huge page mapped at 0x200000.
>
> get_user_pages() also gives us the vma back, and we can see from
> is_vm_hugetlb_page() (-- BTW can I just say that a function
> is_xxx_page() that operates on vmas is horribly misnamed --) that these
> pages all come from a hugetlb mapping, but figuring out the size of that
> mapping is I guess a challenge.

compound_head() will convert any page* inside a hugepage into a pointer
to the head page. It should work OK for regular pages as well as
CONFIG_HUGETLB=n.

So..

PAGE_SIZE << compound_order(compound_head(page))

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