Commit df263d9a authored by Mika Penttilä's avatar Mika Penttilä Committed by Andrew Morton

mm/migrate_device: try to handle swapcache pages

Migrating file pages and swapcache pages into device memory is not
supported.  Try to get rid of the swap cache, and if successful, go ahead
as with other anonymous pages.

Link: https://lkml.kernel.org/r/20230607172944.11713-1-mpenttil@redhat.comSigned-off-by: default avatarMika Penttilä <mpenttil@redhat.com>
Reviewed-by: default avatar"Huang, Ying" <ying.huang@intel.com>
Reviewed-by: default avatarAlistair Popple <apopple@nvidia.com>
Cc: John Hubbard <jhubbard@nvidia.com>
Cc: Ralph Campbell <rcampbell@nvidia.com>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
parent d9cfaf40
...@@ -727,13 +727,22 @@ static void __migrate_device_pages(unsigned long *src_pfns, ...@@ -727,13 +727,22 @@ static void __migrate_device_pages(unsigned long *src_pfns,
if (is_device_private_page(newpage) || if (is_device_private_page(newpage) ||
is_device_coherent_page(newpage)) { is_device_coherent_page(newpage)) {
/*
* For now only support anonymous memory migrating to
* device private or coherent memory.
*/
if (mapping) { if (mapping) {
src_pfns[i] &= ~MIGRATE_PFN_MIGRATE; struct folio *folio;
continue;
folio = page_folio(page);
/*
* For now only support anonymous memory migrating to
* device private or coherent memory.
*
* Try to get rid of swap cache if possible.
*/
if (!folio_test_anon(folio) ||
!folio_free_swap(folio)) {
src_pfns[i] &= ~MIGRATE_PFN_MIGRATE;
continue;
}
} }
} else if (is_zone_device_page(newpage)) { } else if (is_zone_device_page(newpage)) {
/* /*
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment