提交 24f47acc 编写于 作者: J Jérôme Glisse 提交者: Christian König

drm/radeon: avoid segfault on device open when accel is not working.

When accel is not working on device with virtual address space radeon
segfault because the ib buffer is NULL and trying to map it inside the
virtual address space trigger segfault. This patch only map the ib
buffer if accel is working.

Cc: <stable@vger.kernel.org>
Signed-off-by: NJérôme Glisse <jglisse@redhat.com>
Reviewed-by: NAlex Deucher <alexander.deucher@amd.com>
Signed-off-by: NChristian König <christian.koenig@amd.com>
上级 74ad54f2
...@@ -577,28 +577,29 @@ int radeon_driver_open_kms(struct drm_device *dev, struct drm_file *file_priv) ...@@ -577,28 +577,29 @@ int radeon_driver_open_kms(struct drm_device *dev, struct drm_file *file_priv)
return r; return r;
} }
r = radeon_bo_reserve(rdev->ring_tmp_bo.bo, false); if (rdev->accel_working) {
if (r) { r = radeon_bo_reserve(rdev->ring_tmp_bo.bo, false);
radeon_vm_fini(rdev, &fpriv->vm); if (r) {
kfree(fpriv); radeon_vm_fini(rdev, &fpriv->vm);
return r; kfree(fpriv);
} return r;
}
/* map the ib pool buffer read only into /* map the ib pool buffer read only into
* virtual address space */ * virtual address space */
bo_va = radeon_vm_bo_add(rdev, &fpriv->vm, bo_va = radeon_vm_bo_add(rdev, &fpriv->vm,
rdev->ring_tmp_bo.bo); rdev->ring_tmp_bo.bo);
r = radeon_vm_bo_set_addr(rdev, bo_va, RADEON_VA_IB_OFFSET, r = radeon_vm_bo_set_addr(rdev, bo_va, RADEON_VA_IB_OFFSET,
RADEON_VM_PAGE_READABLE | RADEON_VM_PAGE_READABLE |
RADEON_VM_PAGE_SNOOPED); RADEON_VM_PAGE_SNOOPED);
radeon_bo_unreserve(rdev->ring_tmp_bo.bo); radeon_bo_unreserve(rdev->ring_tmp_bo.bo);
if (r) { if (r) {
radeon_vm_fini(rdev, &fpriv->vm); radeon_vm_fini(rdev, &fpriv->vm);
kfree(fpriv); kfree(fpriv);
return r; return r;
}
} }
file_priv->driver_priv = fpriv; file_priv->driver_priv = fpriv;
} }
...@@ -626,13 +627,15 @@ void radeon_driver_postclose_kms(struct drm_device *dev, ...@@ -626,13 +627,15 @@ void radeon_driver_postclose_kms(struct drm_device *dev,
struct radeon_bo_va *bo_va; struct radeon_bo_va *bo_va;
int r; int r;
r = radeon_bo_reserve(rdev->ring_tmp_bo.bo, false); if (rdev->accel_working) {
if (!r) { r = radeon_bo_reserve(rdev->ring_tmp_bo.bo, false);
bo_va = radeon_vm_bo_find(&fpriv->vm, if (!r) {
rdev->ring_tmp_bo.bo); bo_va = radeon_vm_bo_find(&fpriv->vm,
if (bo_va) rdev->ring_tmp_bo.bo);
radeon_vm_bo_rmv(rdev, bo_va); if (bo_va)
radeon_bo_unreserve(rdev->ring_tmp_bo.bo); radeon_vm_bo_rmv(rdev, bo_va);
radeon_bo_unreserve(rdev->ring_tmp_bo.bo);
}
} }
radeon_vm_fini(rdev, &fpriv->vm); radeon_vm_fini(rdev, &fpriv->vm);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册