diff options
author | Jerome Glisse <jglisse@redhat.com> | 2010-02-18 13:13:29 +0000 |
---|---|---|
committer | Dave Airlie <airlied@redhat.com> | 2010-02-20 07:35:18 +1000 |
commit | 7d404c7b5f4c004712bc15ed6e6edd6779842126 (patch) | |
tree | 1736892b1d1a20eed4422f82fd6b6977253eab4b /drivers/gpu | |
parent | f0e2f38befa787f0267419082b33e8ac72269d77 (diff) | |
download | kernel_samsung_smdk4412-7d404c7b5f4c004712bc15ed6e6edd6779842126.zip kernel_samsung_smdk4412-7d404c7b5f4c004712bc15ed6e6edd6779842126.tar.gz kernel_samsung_smdk4412-7d404c7b5f4c004712bc15ed6e6edd6779842126.tar.bz2 |
drm/radeon/kms: free fence IB if it wasn't emited at IB free time
If at IB free time fence wasn't emited that means the IB wasn't
scheduled because an error occured somewhere, thus we can free
then fence and mark the IB as free.
Signed-off-by: Jerome Glisse <jglisse@redhat.com>
Signed-off-by: Dave Airlie <airlied@redhat.com>
Diffstat (limited to 'drivers/gpu')
-rw-r--r-- | drivers/gpu/drm/radeon/radeon_ring.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/drivers/gpu/drm/radeon/radeon_ring.c b/drivers/gpu/drm/radeon/radeon_ring.c index 694799f..6579eb4 100644 --- a/drivers/gpu/drm/radeon/radeon_ring.c +++ b/drivers/gpu/drm/radeon/radeon_ring.c @@ -100,6 +100,8 @@ void radeon_ib_free(struct radeon_device *rdev, struct radeon_ib **ib) if (tmp == NULL) { return; } + if (!tmp->fence->emited) + radeon_fence_unref(&tmp->fence); mutex_lock(&rdev->ib_pool.mutex); tmp->free = true; mutex_unlock(&rdev->ib_pool.mutex); |