[PATCH] drm/radeon/kms/vm: fix possible bug in radeon_vm_bo_rmv()
Jerome Glisse
j.glisse at gmail.com
Wed Feb 29 09:45:07 PST 2012
On Wed, 2012-02-29 at 11:04 -0500, alexdeucher at gmail.com wrote:
> From: Sebastian Biemueller <sebastian.biemueller at amd.com>
>
> The bo is removed from the list at the top of
> radeon_vm_bo_rmv(), but then the list is used
> in radeon_vm_bo_update_pte() to look up the vm.
> remove the bo_list entry at the end of the
> function instead.
>
> Signed-off-by: Alex Deucher <alexander.deucher at amd.com>
> Cc: Jerome Glisse <j.glisse at gmail.com>
Reviewed-by: Jerome Glisse <jglisse at redhat.com>
> ---
> drivers/gpu/drm/radeon/radeon_gart.c | 2 +-
> 1 files changed, 1 insertions(+), 1 deletions(-)
>
> diff --git a/drivers/gpu/drm/radeon/radeon_gart.c b/drivers/gpu/drm/radeon/radeon_gart.c
> index 010dad8..c58a036 100644
> --- a/drivers/gpu/drm/radeon/radeon_gart.c
> +++ b/drivers/gpu/drm/radeon/radeon_gart.c
> @@ -597,13 +597,13 @@ int radeon_vm_bo_rmv(struct radeon_device *rdev,
> if (bo_va == NULL)
> return 0;
>
> - list_del(&bo_va->bo_list);
> mutex_lock(&vm->mutex);
> radeon_mutex_lock(&rdev->cs_mutex);
> radeon_vm_bo_update_pte(rdev, vm, bo, NULL);
> radeon_mutex_unlock(&rdev->cs_mutex);
> list_del(&bo_va->vm_list);
> mutex_unlock(&vm->mutex);
> + list_del(&bo_va->bo_list);
>
> kfree(bo_va);
> return 0;
More information about the dri-devel
mailing list