Re: page fault scalability patch V10: [2/7] defer/omit takingpage_table_lock

From: Christoph Lameter
Date: Mon Oct 18 2004 - 11:01:50 EST


On Fri, 15 Oct 2004, Marcelo Tosatti wrote:

> The comment above, which is a few lines down on do_swap_page() is now
> bogus (the "while we released the page table lock").

Ok. I also modified the second occurence of that comment.

> > if (write_access) {
> > /* Allocate our own private page. */
> > pte_unmap(page_table);
> > - spin_unlock(&mm->page_table_lock);
> >
> > if (unlikely(anon_vma_prepare(vma)))
> > goto no_mem;
> > @@ -1434,30 +1428,39 @@
> > goto no_mem;
> > clear_user_highpage(page, addr);
> >
> > - spin_lock(&mm->page_table_lock);
> > + lock_page(page);
>
> Question: Why do you need to hold the pagelock now?
>
> I can't seem to figure that out myself.

Hmm.. I cannot see a good reason for it either. The page is new
and thus no references can exist yet. Removed.

> > + if (write_access) {
> > + /*
> > + * The following two functions are safe to use without
> > + * the page_table_lock but do they need to come before
> > + * the cmpxchg?
> > + */
>
> They do need to come after AFAICS - from the point they are in the reverse map
> and the page is on the LRU try_to_unmap() can come in and try to
> unmap the pte (now that we dont hold page_table_lock anymore).

Ahh. Thanks.

> > - return do_no_page(mm, vma, address, write_access, pte, pmd);
> > + return do_no_page(mm, vma, address, write_access, pte, pmd, entry);
> > if (pte_file(entry))
> > - return do_file_page(mm, vma, address, write_access, pte, pmd);
> > + return do_file_page(mm, vma, address, write_access, pte, pmd, entry);
> > return do_swap_page(mm, vma, address, pte, pmd, entry, write_access);
> > }
>
> I wonder what happens if kswapd, through try_to_unmap_one(), unmap's the
> pte right here ?
>
> Aren't we going to proceed with the "pte_mkyoung(entry)" of a potentially
> now unmapped pte? Isnt that case possible now?

The pte value is saved in entry. If the pte is umapped then its value is
changed. Thus the cmpxchg will fail and the page fault handler will return
without doing anything.

try_to_unmap_one was modified to handle the pte's in an atomic way using
ptep_xchg.

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