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!