Re: [PATCH v3 2/5] mm/migrate: add a flags parameter to migrate_vma

2020-07-22 Thread Bharata B Rao
On Tue, Jul 21, 2020 at 02:31:16PM -0700, Ralph Campbell wrote:
> The src_owner field in struct migrate_vma is being used for two purposes,
> it acts as a selection filter for which types of pages are to be migrated
> and it identifies device private pages owned by the caller. Split this
> into separate parameters so the src_owner field can be used just to
> identify device private pages owned by the caller of migrate_vma_setup().
> Rename the src_owner field to pgmap_owner to reflect it is now used only
> to identify which device private pages to migrate.
> 
> Signed-off-by: Ralph Campbell 
> ---
>  arch/powerpc/kvm/book3s_hv_uvmem.c |  4 +++-
>  drivers/gpu/drm/nouveau/nouveau_dmem.c |  4 +++-
>  include/linux/migrate.h| 13 +
>  lib/test_hmm.c |  6 --
>  mm/migrate.c   |  6 --
>  5 files changed, 23 insertions(+), 10 deletions(-)
> 
> diff --git a/arch/powerpc/kvm/book3s_hv_uvmem.c 
> b/arch/powerpc/kvm/book3s_hv_uvmem.c
> index 09d8119024db..6850bd04bcb9 100644
> --- a/arch/powerpc/kvm/book3s_hv_uvmem.c
> +++ b/arch/powerpc/kvm/book3s_hv_uvmem.c
> @@ -400,6 +400,7 @@ kvmppc_svm_page_in(struct vm_area_struct *vma, unsigned 
> long start,
>   mig.end = end;
>   mig.src = _pfn;
>   mig.dst = _pfn;
> + mig.flags = MIGRATE_VMA_SELECT_SYSTEM;
>  
>   /*
>* We come here with mmap_lock write lock held just for
> @@ -577,7 +578,8 @@ kvmppc_svm_page_out(struct vm_area_struct *vma, unsigned 
> long start,
>   mig.end = end;
>   mig.src = _pfn;
>   mig.dst = _pfn;
> - mig.src_owner = _uvmem_pgmap;
> + mig.pgmap_owner = _uvmem_pgmap;
> + mig.flags = MIGRATE_VMA_SELECT_DEVICE_PRIVATE;
>  
>   mutex_lock(>arch.uvmem_lock);

For the kvmppc changes above,
Reviewed-by: Bharata B Rao 


[PATCH v3 2/5] mm/migrate: add a flags parameter to migrate_vma

2020-07-21 Thread Ralph Campbell
The src_owner field in struct migrate_vma is being used for two purposes,
it acts as a selection filter for which types of pages are to be migrated
and it identifies device private pages owned by the caller. Split this
into separate parameters so the src_owner field can be used just to
identify device private pages owned by the caller of migrate_vma_setup().
Rename the src_owner field to pgmap_owner to reflect it is now used only
to identify which device private pages to migrate.

Signed-off-by: Ralph Campbell 
---
 arch/powerpc/kvm/book3s_hv_uvmem.c |  4 +++-
 drivers/gpu/drm/nouveau/nouveau_dmem.c |  4 +++-
 include/linux/migrate.h| 13 +
 lib/test_hmm.c |  6 --
 mm/migrate.c   |  6 --
 5 files changed, 23 insertions(+), 10 deletions(-)

diff --git a/arch/powerpc/kvm/book3s_hv_uvmem.c 
b/arch/powerpc/kvm/book3s_hv_uvmem.c
index 09d8119024db..6850bd04bcb9 100644
--- a/arch/powerpc/kvm/book3s_hv_uvmem.c
+++ b/arch/powerpc/kvm/book3s_hv_uvmem.c
@@ -400,6 +400,7 @@ kvmppc_svm_page_in(struct vm_area_struct *vma, unsigned 
long start,
mig.end = end;
mig.src = _pfn;
mig.dst = _pfn;
+   mig.flags = MIGRATE_VMA_SELECT_SYSTEM;
 
/*
 * We come here with mmap_lock write lock held just for
@@ -577,7 +578,8 @@ kvmppc_svm_page_out(struct vm_area_struct *vma, unsigned 
long start,
mig.end = end;
mig.src = _pfn;
mig.dst = _pfn;
-   mig.src_owner = _uvmem_pgmap;
+   mig.pgmap_owner = _uvmem_pgmap;
+   mig.flags = MIGRATE_VMA_SELECT_DEVICE_PRIVATE;
 
mutex_lock(>arch.uvmem_lock);
/* The requested page is already paged-out, nothing to do */
diff --git a/drivers/gpu/drm/nouveau/nouveau_dmem.c 
b/drivers/gpu/drm/nouveau/nouveau_dmem.c
index e5c230d9ae24..78b9e3c2a5b3 100644
--- a/drivers/gpu/drm/nouveau/nouveau_dmem.c
+++ b/drivers/gpu/drm/nouveau/nouveau_dmem.c
@@ -182,7 +182,8 @@ static vm_fault_t nouveau_dmem_migrate_to_ram(struct 
vm_fault *vmf)
.end= vmf->address + PAGE_SIZE,
.src= ,
.dst= ,
-   .src_owner  = drm->dev,
+   .pgmap_owner= drm->dev,
+   .flags  = MIGRATE_VMA_SELECT_DEVICE_PRIVATE,
};
 
/*
@@ -615,6 +616,7 @@ nouveau_dmem_migrate_vma(struct nouveau_drm *drm,
struct migrate_vma args = {
.vma= vma,
.start  = start,
+   .flags  = MIGRATE_VMA_SELECT_SYSTEM,
};
unsigned long i;
u64 *pfns;
diff --git a/include/linux/migrate.h b/include/linux/migrate.h
index 3e546cbf03dd..aafec0ca7b41 100644
--- a/include/linux/migrate.h
+++ b/include/linux/migrate.h
@@ -180,6 +180,11 @@ static inline unsigned long migrate_pfn(unsigned long pfn)
return (pfn << MIGRATE_PFN_SHIFT) | MIGRATE_PFN_VALID;
 }
 
+enum migrate_vma_direction {
+   MIGRATE_VMA_SELECT_SYSTEM = (1UL << 0),
+   MIGRATE_VMA_SELECT_DEVICE_PRIVATE = (1UL << 1),
+};
+
 struct migrate_vma {
struct vm_area_struct   *vma;
/*
@@ -199,11 +204,11 @@ struct migrate_vma {
 
/*
 * Set to the owner value also stored in page->pgmap->owner for
-* migrating out of device private memory.  If set only device
-* private pages with this owner are migrated.  If not set
-* device private pages are not migrated at all.
+* migrating out of device private memory. The flags also need to
+* be set to MIGRATE_VMA_SELECT_DEVICE_PRIVATE.
 */
-   void*src_owner;
+   void*pgmap_owner;
+   unsigned long   flags;
 };
 
 int migrate_vma_setup(struct migrate_vma *args);
diff --git a/lib/test_hmm.c b/lib/test_hmm.c
index 9aa577afc269..74c6ee66ef15 100644
--- a/lib/test_hmm.c
+++ b/lib/test_hmm.c
@@ -702,7 +702,8 @@ static int dmirror_migrate(struct dmirror *dmirror,
args.dst = dst_pfns;
args.start = addr;
args.end = next;
-   args.src_owner = NULL;
+   args.pgmap_owner = NULL;
+   args.flags = MIGRATE_VMA_SELECT_SYSTEM;
ret = migrate_vma_setup();
if (ret)
goto out;
@@ -1053,7 +1054,8 @@ static vm_fault_t dmirror_devmem_fault(struct vm_fault 
*vmf)
args.end = args.start + PAGE_SIZE;
args.src = _pfns;
args.dst = _pfns;
-   args.src_owner = dmirror->mdevice;
+   args.pgmap_owner = dmirror->mdevice;
+   args.flags = MIGRATE_VMA_SELECT_DEVICE_PRIVATE;
 
if (migrate_vma_setup())
return VM_FAULT_SIGBUS;
diff --git a/mm/migrate.c b/mm/migrate.c
index f37729673558..e3ea68e3a08b 100644
--- a/mm/migrate.c
+++ b/mm/migrate.c
@@ -2287,7 +2287,9 @@ static int migrate_vma_collect_pmd(pmd_t *pmdp,