Commit adc7e863 authored by Christian König's avatar Christian König Committed by Alex Deucher

drm/amdgpu: use the new VM backend for clears

And remove the existing code when it is unused.
Signed-off-by: default avatarChristian König <christian.koenig@amd.com>
Reviewed-by: default avatarChunming Zhou <david1.zhou@amd.com>
Reviewed-by: default avatarFelix Kuehling <Felix.Kuehling@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent 37945a3a
...@@ -709,11 +709,9 @@ static int amdgpu_vm_clear_bo(struct amdgpu_device *adev, ...@@ -709,11 +709,9 @@ static int amdgpu_vm_clear_bo(struct amdgpu_device *adev,
{ {
struct ttm_operation_ctx ctx = { true, false }; struct ttm_operation_ctx ctx = { true, false };
unsigned level = adev->vm_manager.root_level; unsigned level = adev->vm_manager.root_level;
struct amdgpu_vm_update_params params;
struct amdgpu_bo *ancestor = bo; struct amdgpu_bo *ancestor = bo;
struct dma_fence *fence = NULL;
unsigned entries, ats_entries; unsigned entries, ats_entries;
struct amdgpu_ring *ring;
struct amdgpu_job *job;
uint64_t addr; uint64_t addr;
int r; int r;
...@@ -748,8 +746,6 @@ static int amdgpu_vm_clear_bo(struct amdgpu_device *adev, ...@@ -748,8 +746,6 @@ static int amdgpu_vm_clear_bo(struct amdgpu_device *adev,
} }
} }
ring = container_of(vm->entity.rq->sched, struct amdgpu_ring, sched);
r = ttm_bo_validate(&bo->tbo, &bo->placement, &ctx); r = ttm_bo_validate(&bo->tbo, &bo->placement, &ctx);
if (r) if (r)
return r; return r;
...@@ -770,12 +766,15 @@ static int amdgpu_vm_clear_bo(struct amdgpu_device *adev, ...@@ -770,12 +766,15 @@ static int amdgpu_vm_clear_bo(struct amdgpu_device *adev,
} }
r = amdgpu_job_alloc_with_ib(adev, 64, &job); memset(&params, 0, sizeof(params));
params.adev = adev;
params.vm = vm;
r = vm->update_funcs->prepare(&params, AMDGPU_FENCE_OWNER_KFD, NULL);
if (r) if (r)
return r; return r;
do { addr = 0;
addr = amdgpu_bo_gpu_offset(bo);
if (ats_entries) { if (ats_entries) {
uint64_t ats_value; uint64_t ats_value;
...@@ -783,8 +782,11 @@ static int amdgpu_vm_clear_bo(struct amdgpu_device *adev, ...@@ -783,8 +782,11 @@ static int amdgpu_vm_clear_bo(struct amdgpu_device *adev,
if (level != AMDGPU_VM_PTB) if (level != AMDGPU_VM_PTB)
ats_value |= AMDGPU_PDE_PTE; ats_value |= AMDGPU_PDE_PTE;
amdgpu_vm_set_pte_pde(adev, &job->ibs[0], addr, 0, r = vm->update_funcs->update(&params, bo, addr, 0, ats_entries,
ats_entries, 0, ats_value); 0, ats_value);
if (r)
return r;
addr += ats_entries * 8; addr += ats_entries * 8;
} }
...@@ -796,34 +798,13 @@ static int amdgpu_vm_clear_bo(struct amdgpu_device *adev, ...@@ -796,34 +798,13 @@ static int amdgpu_vm_clear_bo(struct amdgpu_device *adev,
adev->asic_type >= CHIP_VEGA10) adev->asic_type >= CHIP_VEGA10)
value = AMDGPU_PTE_EXECUTABLE; value = AMDGPU_PTE_EXECUTABLE;
amdgpu_vm_set_pte_pde(adev, &job->ibs[0], addr, 0, r = vm->update_funcs->update(&params, bo, addr, 0, entries,
entries, 0, value); 0, value);
}
bo = bo->shadow;
} while (bo);
amdgpu_ring_pad_ib(ring, &job->ibs[0]);
WARN_ON(job->ibs[0].length_dw > 64);
r = amdgpu_sync_resv(adev, &job->sync, vm->root.base.bo->tbo.resv,
AMDGPU_FENCE_OWNER_KFD, false);
if (r)
goto error_free;
r = amdgpu_job_submit(job, &vm->entity, AMDGPU_FENCE_OWNER_UNDEFINED,
&fence);
if (r) if (r)
goto error_free;
amdgpu_bo_fence(vm->root.base.bo, fence, true);
dma_fence_put(fence);
return 0;
error_free:
amdgpu_job_free(job);
return r; return r;
}
return vm->update_funcs->commit(&params, NULL);
} }
/** /**
...@@ -911,7 +892,7 @@ static int amdgpu_vm_alloc_pts(struct amdgpu_device *adev, ...@@ -911,7 +892,7 @@ static int amdgpu_vm_alloc_pts(struct amdgpu_device *adev,
if (r) if (r)
goto error_free_pt; goto error_free_pt;
return 1; return 0;
error_free_pt: error_free_pt:
amdgpu_bo_unref(&pt->shadow); amdgpu_bo_unref(&pt->shadow);
...@@ -1419,12 +1400,10 @@ static int amdgpu_vm_update_ptes(struct amdgpu_vm_update_params *params, ...@@ -1419,12 +1400,10 @@ static int amdgpu_vm_update_ptes(struct amdgpu_vm_update_params *params,
unsigned shift, parent_shift, mask; unsigned shift, parent_shift, mask;
uint64_t incr, entry_end, pe_start; uint64_t incr, entry_end, pe_start;
struct amdgpu_bo *pt; struct amdgpu_bo *pt;
bool need_to_sync;
r = amdgpu_vm_alloc_pts(params->adev, params->vm, &cursor); r = amdgpu_vm_alloc_pts(params->adev, params->vm, &cursor);
if (r < 0) if (r)
return r; return r;
need_to_sync = (r && params->vm->use_cpu_for_update);
pt = cursor.entry->base.bo; pt = cursor.entry->base.bo;
...@@ -1472,10 +1451,6 @@ static int amdgpu_vm_update_ptes(struct amdgpu_vm_update_params *params, ...@@ -1472,10 +1451,6 @@ static int amdgpu_vm_update_ptes(struct amdgpu_vm_update_params *params,
entry_end += cursor.pfn & ~(entry_end - 1); entry_end += cursor.pfn & ~(entry_end - 1);
entry_end = min(entry_end, end); entry_end = min(entry_end, end);
if (need_to_sync)
r = amdgpu_bo_sync_wait(params->vm->root.base.bo,
AMDGPU_FENCE_OWNER_VM, true);
do { do {
uint64_t upd_end = min(entry_end, frag_end); uint64_t upd_end = min(entry_end, frag_end);
unsigned nptes = (upd_end - frag_start) >> shift; unsigned nptes = (upd_end - frag_start) >> shift;
......
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