Commit 75fa98d6 authored by Philip Yang's avatar Philip Yang Committed by Alex Deucher

drm/amdkfd: clarify the origin of cpages returned by migration functions

cpages is only updated by migrate_vma_setup. So capture its value at
that point to clarify the significance of the number. The next patch
will add counting of actually migrated pages after migrate_vma_pages for
debug purposes.
Signed-off-by: default avatarPhilip Yang <Philip.Yang@amd.com>
Reviewed-by: default avatarFelix Kuehling <Felix.Kuehling@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent e77f0f5c
...@@ -385,6 +385,7 @@ svm_migrate_vma_to_vram(struct amdgpu_device *adev, struct svm_range *prange, ...@@ -385,6 +385,7 @@ svm_migrate_vma_to_vram(struct amdgpu_device *adev, struct svm_range *prange,
struct kfd_process_device *pdd; struct kfd_process_device *pdd;
struct dma_fence *mfence = NULL; struct dma_fence *mfence = NULL;
struct migrate_vma migrate; struct migrate_vma migrate;
unsigned long cpages = 0;
dma_addr_t *scratch; dma_addr_t *scratch;
size_t size; size_t size;
void *buf; void *buf;
...@@ -414,17 +415,17 @@ svm_migrate_vma_to_vram(struct amdgpu_device *adev, struct svm_range *prange, ...@@ -414,17 +415,17 @@ svm_migrate_vma_to_vram(struct amdgpu_device *adev, struct svm_range *prange,
goto out_free; goto out_free;
} }
if (migrate.cpages != npages) cpages = migrate.cpages;
pr_debug("partial migration, 0x%lx/0x%llx pages migrated\n", if (!cpages) {
migrate.cpages, npages);
else
pr_debug("0x%lx pages migrated\n", migrate.cpages);
if (!migrate.cpages) {
pr_debug("failed collect migrate sys pages [0x%lx 0x%lx]\n", pr_debug("failed collect migrate sys pages [0x%lx 0x%lx]\n",
prange->start, prange->last); prange->start, prange->last);
goto out_free; goto out_free;
} }
if (cpages != npages)
pr_debug("partial migration, 0x%lx/0x%llx pages migrated\n",
cpages, npages);
else
pr_debug("0x%lx pages migrated\n", cpages);
r = svm_migrate_copy_to_vram(adev, prange, &migrate, &mfence, scratch); r = svm_migrate_copy_to_vram(adev, prange, &migrate, &mfence, scratch);
migrate_vma_pages(&migrate); migrate_vma_pages(&migrate);
...@@ -437,12 +438,12 @@ svm_migrate_vma_to_vram(struct amdgpu_device *adev, struct svm_range *prange, ...@@ -437,12 +438,12 @@ svm_migrate_vma_to_vram(struct amdgpu_device *adev, struct svm_range *prange,
out_free: out_free:
kvfree(buf); kvfree(buf);
out: out:
if (!r && migrate.cpages) { if (!r && cpages) {
pdd = svm_range_get_pdd_by_adev(prange, adev); pdd = svm_range_get_pdd_by_adev(prange, adev);
if (pdd) if (pdd)
WRITE_ONCE(pdd->page_in, pdd->page_in + migrate.cpages); WRITE_ONCE(pdd->page_in, pdd->page_in + cpages);
return migrate.cpages; return cpages;
} }
return r; return r;
} }
...@@ -619,6 +620,7 @@ svm_migrate_vma_to_ram(struct amdgpu_device *adev, struct svm_range *prange, ...@@ -619,6 +620,7 @@ svm_migrate_vma_to_ram(struct amdgpu_device *adev, struct svm_range *prange,
struct kfd_process_device *pdd; struct kfd_process_device *pdd;
struct dma_fence *mfence = NULL; struct dma_fence *mfence = NULL;
struct migrate_vma migrate; struct migrate_vma migrate;
unsigned long cpages = 0;
dma_addr_t *scratch; dma_addr_t *scratch;
size_t size; size_t size;
void *buf; void *buf;
...@@ -648,17 +650,17 @@ svm_migrate_vma_to_ram(struct amdgpu_device *adev, struct svm_range *prange, ...@@ -648,17 +650,17 @@ svm_migrate_vma_to_ram(struct amdgpu_device *adev, struct svm_range *prange,
goto out_free; goto out_free;
} }
if (migrate.cpages != npages) cpages = migrate.cpages;
pr_debug("partial migration, 0x%lx/0x%llx pages migrated\n", if (!cpages) {
migrate.cpages, npages);
else
pr_debug("0x%lx pages migrated\n", migrate.cpages);
if (!migrate.cpages) {
pr_debug("failed collect migrate device pages [0x%lx 0x%lx]\n", pr_debug("failed collect migrate device pages [0x%lx 0x%lx]\n",
prange->start, prange->last); prange->start, prange->last);
goto out_free; goto out_free;
} }
if (cpages != npages)
pr_debug("partial migration, 0x%lx/0x%llx pages migrated\n",
cpages, npages);
else
pr_debug("0x%lx pages migrated\n", cpages);
r = svm_migrate_copy_to_ram(adev, prange, &migrate, &mfence, r = svm_migrate_copy_to_ram(adev, prange, &migrate, &mfence,
scratch, npages); scratch, npages);
...@@ -670,13 +672,12 @@ svm_migrate_vma_to_ram(struct amdgpu_device *adev, struct svm_range *prange, ...@@ -670,13 +672,12 @@ svm_migrate_vma_to_ram(struct amdgpu_device *adev, struct svm_range *prange,
out_free: out_free:
kvfree(buf); kvfree(buf);
out: out:
if (!r && migrate.cpages) { if (!r && cpages) {
pdd = svm_range_get_pdd_by_adev(prange, adev); pdd = svm_range_get_pdd_by_adev(prange, adev);
if (pdd) if (pdd)
WRITE_ONCE(pdd->page_out, WRITE_ONCE(pdd->page_out, pdd->page_out + cpages);
pdd->page_out + migrate.cpages);
return migrate.cpages; return cpages;
} }
return r; return r;
} }
......
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