Re: [PATCH]: Handling spurious page fault for hugetlb region for2.6.14-rc4-git5

From: Andrew Morton
Date: Tue Oct 18 2005 - 19:25:52 EST


Rohit Seth <rohit.seth@xxxxxxxxx> wrote:
>
> On Tue, 2005-10-18 at 14:34 -0700, Andrew Morton wrote:
> > "Seth, Rohit" <rohit.seth@xxxxxxxxx> wrote:
> > >
> > > Linus,
> > >
> > > [PATCH]: Handle spurious page fault for hugetlb region
> > >
> > > The hugetlb pages are currently pre-faulted. At the time of mmap of
> > > hugepages, we populate the new PTEs. It is possible that HW has already cached
> > > some of the unused PTEs internally.
> >
> > What's an "unused pte"? One which maps a regular-sized page at the same
> > virtual address? How can such a thing come about, and why isn't it already
> > a problem for regular-sized pages? From where does the hardware prefetch
> > the pte contents?
> >
>
> Unsused pte is where *pte == 0. Basically entries in leaf page table
> that does not map anything.

Oh. Then I'm still not understanding.

> If such a pte ends up mapping a normal page
> then you get a page fault and HW/handler does the right thing (in terms
> of purging old entries).

For starters, we don't actually _use_ pte's for the hugepage. We use an
entry in a pmd page. Does that concept still apply for ia64?

If so, are you saying that the hardware prefetching is happening at the pmd
level? If not, how can it happen at the pte level when the hardware
doesn't know where the pte page _is_?

Has this problem been observed in testing?

>
> > IOW: please tell us more about this hardware pte-fetcher.
> >
> > > These stale entries never get a chance to
> > > be purged in existing control flow.
> >
> > I'd have thought that invalidating those ptes at mmap()-time would be a
> > more consistent approach.
>
> That would be adding too many unconditional purges (which are very
> expensive operations) during mmap. And as we are only talking of
> speculative pre-fetches that are done by HW so IMO we should do this as
> lazily as possible (only if required).

Is an mmap of a hugepage region very common? I guess it is, on ia32, or on
64-bit apps which are (poorly?) designed to also run on ia32.

> > If the low-level code has purged the stale pte then it knows what's
> > happening. Perhaps it shouldn't call into handle_mm_fault() at all?
>
> Well, at that time the code does not know if the address belong to
> hugetlbfile. The archs that needs those purges in low level code need
> them for all (for example) page not present faults.

I still don't understand what's different about hugepages here. If the
prefetching problem also occurs on regular pages and is handled OK for
regular pages, why do hugepages need special treatment?
-
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/