dma-buf: add more reservation object locking wrappers
Complete the abstraction of the ww_mutex inside the reservation object. This allows us to add more handling and debugging to the reservation object in the future. Signed-off-by: Christian König <christian.koenig@amd.com> Reviewed-by: Chris Wilson <chris@chris-wilson.co.uk> Link: https://patchwork.freedesktop.org/patch/320761/
This commit is contained in:
@@ -1288,8 +1288,8 @@ retry:
|
||||
if (contended != -1) {
|
||||
struct drm_gem_object *obj = objs[contended];
|
||||
|
||||
ret = ww_mutex_lock_slow_interruptible(&obj->resv->lock,
|
||||
acquire_ctx);
|
||||
ret = reservation_object_lock_slow_interruptible(obj->resv,
|
||||
acquire_ctx);
|
||||
if (ret) {
|
||||
ww_acquire_done(acquire_ctx);
|
||||
return ret;
|
||||
@@ -1300,16 +1300,16 @@ retry:
|
||||
if (i == contended)
|
||||
continue;
|
||||
|
||||
ret = ww_mutex_lock_interruptible(&objs[i]->resv->lock,
|
||||
acquire_ctx);
|
||||
ret = reservation_object_lock_interruptible(objs[i]->resv,
|
||||
acquire_ctx);
|
||||
if (ret) {
|
||||
int j;
|
||||
|
||||
for (j = 0; j < i; j++)
|
||||
ww_mutex_unlock(&objs[j]->resv->lock);
|
||||
reservation_object_unlock(objs[j]->resv);
|
||||
|
||||
if (contended != -1 && contended >= i)
|
||||
ww_mutex_unlock(&objs[contended]->resv->lock);
|
||||
reservation_object_unlock(objs[contended]->resv);
|
||||
|
||||
if (ret == -EDEADLK) {
|
||||
contended = i;
|
||||
@@ -1334,7 +1334,7 @@ drm_gem_unlock_reservations(struct drm_gem_object **objs, int count,
|
||||
int i;
|
||||
|
||||
for (i = 0; i < count; i++)
|
||||
ww_mutex_unlock(&objs[i]->resv->lock);
|
||||
reservation_object_unlock(objs[i]->resv);
|
||||
|
||||
ww_acquire_fini(acquire_ctx);
|
||||
}
|
||||
|
Reference in New Issue
Block a user