Re: PATCH? introduce get_compound_page (Was: process 'stuck' at exit)

From: Andrea Arcangeli
Date: Fri Dec 13 2013 - 12:34:44 EST


On Fri, Dec 13, 2013 at 05:22:40PM +0100, Oleg Nesterov wrote:
> Andrea. Thanks a lot for the detailed reply.
>
> On 12/13, Andrea Arcangeli wrote:
> >
> > On Wed, Dec 11, 2013 at 08:18:55PM +0100, Oleg Nesterov wrote:
> >
> > get_huge_page_tail checks different invariants in the VM_BUG_ON and is
> > only used by gup.c not sure why to call that here.
>
> Compared to __get_page_tail_foll(get_page_head => F) get_huge_page_tail()
> lacks the ->first_page->_count, but it is called right after
> get_page_unless_zero(page_head) so to me get_huge_page_tail() looks a bit
> better.
>
> Personally, I think that even this change
>
> --- x/kernel/events/../../mm/internal.h
> +++ x/kernel/events/../../mm/internal.h
> @@ -47,11 +47,9 @@ static inline void __get_page_tail_foll(
> * page_cache_get_speculative()) on tail pages.
> */
> VM_BUG_ON(atomic_read(&page->first_page->_count) <= 0);
> - VM_BUG_ON(atomic_read(&page->_count) != 0);
> - VM_BUG_ON(page_mapcount(page) < 0);
> if (get_page_head)
> atomic_inc(&page->first_page->_count);
> - atomic_inc(&page->_mapcount);
> + get_huge_page_tail(page);
> }
>
> /*
>
> makes sense. But this is minor and subjective, I am not going to argue.

The above diff looks a straightforward cleanup you could submit it as
a separate patch in a v2 series. This more clearly shows the
difference between the two functions, so there is less overlap
too.

Feel free to change it further if you want, but the current model was
to have get_huge_page_tail only for arch/*/mm/gup.c (in mm.h) and
__get_page_tail_foll in internal.h for mm/*.c and with the ability to
obtain the head page too (needed in some of the mm/*.c cases, and
never needed for arch/*/mm/gup.c).

> I'll try to make v2 based on -mm and your suggestions.

Ok great!

Thanks,
Andrea
--
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/