Commit 1776c0d1 authored by Christoph Hellwig's avatar Christoph Hellwig Committed by Matthew Wilcox (Oracle)

mm: refactor the ZONE_DEVICE handling in migrate_vma_insert_page

Make the flow a little more clear and prepare for adding a new
ZONE_DEVICE memory type.

Link: https://lkml.kernel.org/r/20220210072828.2930359-12-hch@lst.deSigned-off-by: default avatarChristoph Hellwig <hch@lst.de>
Reviewed-by: default avatarAlistair Popple <apopple@nvidia.com>
Tested-by: default avatar"Sierra Guiza, Alejandro (Alex)" <alex.sierra@amd.com>

Cc: Alex Deucher <alexander.deucher@amd.com>
Cc: Ben Skeggs <bskeggs@redhat.com>
Cc: Chaitanya Kulkarni <kch@nvidia.com>
Cc: Christian Knig <christian.koenig@amd.com>
Cc: Dan Williams <dan.j.williams@intel.com>
Cc: Felix Kuehling <Felix.Kuehling@amd.com>
Cc: Jason Gunthorpe <jgg@nvidia.com>
Cc: Karol Herbst <kherbst@redhat.com>
Cc: Logan Gunthorpe <logang@deltatee.com>
Cc: Lyude Paul <lyude@redhat.com>
Cc: Miaohe Lin <linmiaohe@huawei.com>
Cc: Muchun Song <songmuchun@bytedance.com>
Cc: "Pan, Xinhui" <Xinhui.Pan@amd.com>
Cc: Ralph Campbell <rcampbell@nvidia.com>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarMatthew Wilcox (Oracle) <willy@infradead.org>
parent f9f38f78
...@@ -2674,7 +2674,6 @@ static void migrate_vma_insert_page(struct migrate_vma *migrate, ...@@ -2674,7 +2674,6 @@ static void migrate_vma_insert_page(struct migrate_vma *migrate,
*/ */
__SetPageUptodate(page); __SetPageUptodate(page);
if (is_zone_device_page(page)) {
if (is_device_private_page(page)) { if (is_device_private_page(page)) {
swp_entry_t swp_entry; swp_entry_t swp_entry;
...@@ -2687,13 +2686,13 @@ static void migrate_vma_insert_page(struct migrate_vma *migrate, ...@@ -2687,13 +2686,13 @@ static void migrate_vma_insert_page(struct migrate_vma *migrate,
entry = swp_entry_to_pte(swp_entry); entry = swp_entry_to_pte(swp_entry);
} else { } else {
/* /*
* For now we only support migrating to un-addressable * For now we only support migrating to un-addressable device
* device memory. * memory.
*/ */
if (is_zone_device_page(page)) {
pr_warn_once("Unsupported ZONE_DEVICE page type.\n"); pr_warn_once("Unsupported ZONE_DEVICE page type.\n");
goto abort; goto abort;
} }
} else {
entry = mk_pte(page, vma->vm_page_prot); entry = mk_pte(page, vma->vm_page_prot);
if (vma->vm_flags & VM_WRITE) if (vma->vm_flags & VM_WRITE)
entry = pte_mkwrite(pte_mkdirty(entry)); entry = pte_mkwrite(pte_mkdirty(entry));
......
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