drm/amdgpu: Verify root PD is mapped into kernel address space (v4)
Problem: When PD/PT update made by CPU root PD was not yet mapped causing page fault. Fix: Verify root PD is mapped into CPU address space. v2: Make sure that we add the root PD to the relocated list since then it's get mapped into CPU address space bt default in amdgpu_vm_update_directories. v3: Drop change to not move kernel type BOs to evicted list. v4: Remove redundant bo move to relocated list. Link: https://bugs.freedesktop.org/show_bug.cgi?id=107065 Signed-off-by: Andrey Grodzovsky <andrey.grodzovsky@amd.com> Reviewed-by: Christian König <christian.koenig@amd.com> Reviewed-by: Junwei Zhang <Jerry.Zhang@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
This commit is contained in:
parent
efaa964639
commit
e85115786a
|
@ -156,6 +156,9 @@ static void amdgpu_vm_bo_base_init(struct amdgpu_vm_bo_base *base,
|
||||||
return;
|
return;
|
||||||
list_add_tail(&base->bo_list, &bo->va);
|
list_add_tail(&base->bo_list, &bo->va);
|
||||||
|
|
||||||
|
if (bo->tbo.type == ttm_bo_type_kernel)
|
||||||
|
list_move(&base->vm_status, &vm->relocated);
|
||||||
|
|
||||||
if (bo->tbo.resv != vm->root.base.bo->tbo.resv)
|
if (bo->tbo.resv != vm->root.base.bo->tbo.resv)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
@ -540,7 +543,6 @@ static int amdgpu_vm_alloc_levels(struct amdgpu_device *adev,
|
||||||
pt->parent = amdgpu_bo_ref(parent->base.bo);
|
pt->parent = amdgpu_bo_ref(parent->base.bo);
|
||||||
|
|
||||||
amdgpu_vm_bo_base_init(&entry->base, vm, pt);
|
amdgpu_vm_bo_base_init(&entry->base, vm, pt);
|
||||||
list_move(&entry->base.vm_status, &vm->relocated);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (level < AMDGPU_VM_PTB) {
|
if (level < AMDGPU_VM_PTB) {
|
||||||
|
|
Loading…
Reference in New Issue