提交 6f1ceabb 编写于 作者: C Christian König 提交者: Alex Deucher

drm/amdgpu: fix VM flush for CPU based updates

We don't have any update fence in that case, so the need
for flushing isn't detected automatically.
Signed-off-by: NChristian König <christian.koenig@amd.com>
Reviewed-by: NFelix Kuehling <Felix.Kuehling@amd.com>
Signed-off-by: NAlex Deucher <alexander.deucher@amd.com>
上级 fd971375
...@@ -422,7 +422,7 @@ static int amdgpu_vm_grab_reserved_vmid_locked(struct amdgpu_vm *vm, ...@@ -422,7 +422,7 @@ static int amdgpu_vm_grab_reserved_vmid_locked(struct amdgpu_vm *vm,
struct dma_fence *updates = sync->last_vm_update; struct dma_fence *updates = sync->last_vm_update;
int r = 0; int r = 0;
struct dma_fence *flushed, *tmp; struct dma_fence *flushed, *tmp;
bool needs_flush = false; bool needs_flush = vm->use_cpu_for_update;
flushed = id->flushed_updates; flushed = id->flushed_updates;
if ((amdgpu_vm_had_gpu_reset(adev, id)) || if ((amdgpu_vm_had_gpu_reset(adev, id)) ||
...@@ -543,11 +543,11 @@ int amdgpu_vm_grab_id(struct amdgpu_vm *vm, struct amdgpu_ring *ring, ...@@ -543,11 +543,11 @@ int amdgpu_vm_grab_id(struct amdgpu_vm *vm, struct amdgpu_ring *ring,
} }
kfree(fences); kfree(fences);
job->vm_needs_flush = false; job->vm_needs_flush = vm->use_cpu_for_update;
/* Check if we can use a VMID already assigned to this VM */ /* Check if we can use a VMID already assigned to this VM */
list_for_each_entry_reverse(id, &id_mgr->ids_lru, list) { list_for_each_entry_reverse(id, &id_mgr->ids_lru, list) {
struct dma_fence *flushed; struct dma_fence *flushed;
bool needs_flush = false; bool needs_flush = vm->use_cpu_for_update;
/* Check all the prerequisites to using this VMID */ /* Check all the prerequisites to using this VMID */
if (amdgpu_vm_had_gpu_reset(adev, id)) if (amdgpu_vm_had_gpu_reset(adev, id))
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册