Re: [PATCH v6v3 02/12] mm: migrate: support non-lru movable page migration
From: Minchan Kim
Date: Tue Jun 14 2016 - 22:32:51 EST
Hi,
On Mon, Jun 13, 2016 at 03:08:19PM +0530, Anshuman Khandual wrote:
> On 05/31/2016 05:31 AM, Minchan Kim wrote:
> > @@ -791,6 +921,7 @@ static int __unmap_and_move(struct page *page, struct page *newpage,
> > int rc = -EAGAIN;
> > int page_was_mapped = 0;
> > struct anon_vma *anon_vma = NULL;
> > + bool is_lru = !__PageMovable(page);
> >
> > if (!trylock_page(page)) {
> > if (!force || mode == MIGRATE_ASYNC)
> > @@ -871,6 +1002,11 @@ static int __unmap_and_move(struct page *page, struct page *newpage,
> > goto out_unlock_both;
> > }
> >
> > + if (unlikely(!is_lru)) {
> > + rc = move_to_new_page(newpage, page, mode);
> > + goto out_unlock_both;
> > + }
> > +
>
> Hello Minchan,
>
> I might be missing something here but does this implementation support the
> scenario where these non LRU pages owned by the driver mapped as PTE into
> process page table ? Because the "goto out_unlock_both" statement above
> skips all the PTE unmap, putting a migration PTE and removing the migration
> PTE steps.
You're right. Unfortunately, it doesn't support right now but surely,
it's my TODO after landing this work.
Could you share your usecase?
It would be helpful for merging when I wll send patchset.
Thanks!