mirror of https://gitee.com/openkylin/linux.git
drm/i915/shrinker: Only shmemfs objects are backed by swap
Since we can only swap out shmemfs objects, those are the only ones that can influence the ability of the shrinker to free pages. Currently, all non-shmemfs objects have a raised pages_pin_count to protect them from the shrinker, so this just makes the logic for can_release_pages() clearer (and safer in future so that we don't over estimate our ability to free up pages from future non-swappable objects). Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk> Cc: Joonas Lahtinen <joonas.lahtinen@linux.intel.com> Link: http://patchwork.freedesktop.org/patch/msgid/1461150592-27818-3-git-send-email-chris@chris-wilson.co.uk Reviewed-by: Joonas Lahtinen <joonas.lahtinen@linux.intel.com> Reviewed-by: Mika Kuoppala <mika.kuoppala@intel.com>
This commit is contained in:
parent
1768d4550c
commit
1bec9b0bda
|
@ -70,6 +70,10 @@ static bool swap_available(void)
|
||||||
|
|
||||||
static bool can_release_pages(struct drm_i915_gem_object *obj)
|
static bool can_release_pages(struct drm_i915_gem_object *obj)
|
||||||
{
|
{
|
||||||
|
/* Only shmemfs objects are backed by swap */
|
||||||
|
if (!obj->base.filp)
|
||||||
|
return false;
|
||||||
|
|
||||||
/* Only report true if by unbinding the object and putting its pages
|
/* Only report true if by unbinding the object and putting its pages
|
||||||
* we can actually make forward progress towards freeing physical
|
* we can actually make forward progress towards freeing physical
|
||||||
* pages.
|
* pages.
|
||||||
|
@ -349,18 +353,12 @@ i915_gem_shrinker_oom(struct notifier_block *nb, unsigned long event, void *ptr)
|
||||||
*/
|
*/
|
||||||
unbound = bound = unevictable = 0;
|
unbound = bound = unevictable = 0;
|
||||||
list_for_each_entry(obj, &dev_priv->mm.unbound_list, global_list) {
|
list_for_each_entry(obj, &dev_priv->mm.unbound_list, global_list) {
|
||||||
if (!obj->base.filp) /* not backed by a freeable object */
|
|
||||||
continue;
|
|
||||||
|
|
||||||
if (!can_release_pages(obj))
|
if (!can_release_pages(obj))
|
||||||
unevictable += obj->base.size >> PAGE_SHIFT;
|
unevictable += obj->base.size >> PAGE_SHIFT;
|
||||||
else
|
else
|
||||||
unbound += obj->base.size >> PAGE_SHIFT;
|
unbound += obj->base.size >> PAGE_SHIFT;
|
||||||
}
|
}
|
||||||
list_for_each_entry(obj, &dev_priv->mm.bound_list, global_list) {
|
list_for_each_entry(obj, &dev_priv->mm.bound_list, global_list) {
|
||||||
if (!obj->base.filp)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
if (!can_release_pages(obj))
|
if (!can_release_pages(obj))
|
||||||
unevictable += obj->base.size >> PAGE_SHIFT;
|
unevictable += obj->base.size >> PAGE_SHIFT;
|
||||||
else
|
else
|
||||||
|
|
Loading…
Reference in New Issue