Commit e4e80625 authored by Maarten Lankhorst's avatar Maarten Lankhorst

drm/i915: Change shrink ordering to use locking around unbinding.

Call drop_pages with the gem object lock held, instead of the other
way around. This will allow us to drop the vma bindings with the
gem object lock held.

We plan to require the object lock for unpinning in the future,
and this is an easy target.
Signed-off-by: default avatarMaarten Lankhorst <maarten.lankhorst@linux.intel.com>
Reviewed-by: default avatarNiranjana Vishwanathapura <niranjana.vishwanathapura@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20211216142749.1966107-3-maarten.lankhorst@linux.intel.com
parent ad5c99e0
...@@ -36,8 +36,8 @@ static bool can_release_pages(struct drm_i915_gem_object *obj) ...@@ -36,8 +36,8 @@ static bool can_release_pages(struct drm_i915_gem_object *obj)
return swap_available() || obj->mm.madv == I915_MADV_DONTNEED; return swap_available() || obj->mm.madv == I915_MADV_DONTNEED;
} }
static bool unsafe_drop_pages(struct drm_i915_gem_object *obj, static int drop_pages(struct drm_i915_gem_object *obj,
unsigned long shrink, bool trylock_vm) unsigned long shrink, bool trylock_vm)
{ {
unsigned long flags; unsigned long flags;
...@@ -214,26 +214,24 @@ i915_gem_shrink(struct i915_gem_ww_ctx *ww, ...@@ -214,26 +214,24 @@ i915_gem_shrink(struct i915_gem_ww_ctx *ww,
spin_unlock_irqrestore(&i915->mm.obj_lock, flags); spin_unlock_irqrestore(&i915->mm.obj_lock, flags);
err = 0; /* May arrive from get_pages on another bo */
if (unsafe_drop_pages(obj, shrink, trylock_vm)) { if (!ww) {
/* May arrive from get_pages on another bo */ if (!i915_gem_object_trylock(obj))
if (!ww) { goto skip;
if (!i915_gem_object_trylock(obj)) } else {
goto skip; err = i915_gem_object_lock(obj, ww);
} else { if (err)
err = i915_gem_object_lock(obj, ww); goto skip;
if (err)
goto skip;
}
if (!__i915_gem_object_put_pages(obj)) {
if (!try_to_writeback(obj, shrink))
count += obj->base.size >> PAGE_SHIFT;
}
if (!ww)
i915_gem_object_unlock(obj);
} }
if (drop_pages(obj, shrink, trylock_vm) &&
!__i915_gem_object_put_pages(obj) &&
!try_to_writeback(obj, shrink))
count += obj->base.size >> PAGE_SHIFT;
if (!ww)
i915_gem_object_unlock(obj);
scanned += obj->base.size >> PAGE_SHIFT; scanned += obj->base.size >> PAGE_SHIFT;
skip: skip:
i915_gem_object_put(obj); i915_gem_object_put(obj);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment