提交 8d2f683f 编写于 作者: I Imre Deak

drm/i915: Factor out i915_ggtt_suspend_vm/i915_ggtt_resume_vm()

Factor out functions that are needed by the next patch to suspend/resume
the memory mappings for DPT FBs.

No functional change, except reordering during suspend the
ggtt->invalidate(ggtt) call wrt. atomic_set(&ggtt->vm.open, open) and
mutex_unlock(&ggtt->vm.mutex). This shouldn't matter due to the i915
suspend sequence being single threaded.

Cc: Chris Wilson <chris@chris-wilson.co.uk>
Cc: Ville Syrjälä <ville.syrjala@linux.intel.com>
Signed-off-by: NImre Deak <imre.deak@intel.com>
Reviewed-by: NChris Wilson <chris@chris-wilson.co.uk>
Reviewed-by: NVille Syrjälä <ville.syrjala@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20211101183551.3580546-1-imre.deak@intel.com
上级 e6d6f689
...@@ -116,17 +116,26 @@ static bool needs_idle_maps(struct drm_i915_private *i915) ...@@ -116,17 +116,26 @@ static bool needs_idle_maps(struct drm_i915_private *i915)
return false; return false;
} }
void i915_ggtt_suspend(struct i915_ggtt *ggtt) /**
* i915_ggtt_suspend_vm - Suspend the memory mappings for a GGTT or DPT VM
* @vm: The VM to suspend the mappings for
*
* Suspend the memory mappings for all objects mapped to HW via the GGTT or a
* DPT page table.
*/
void i915_ggtt_suspend_vm(struct i915_address_space *vm)
{ {
struct i915_vma *vma, *vn; struct i915_vma *vma, *vn;
int open; int open;
mutex_lock(&ggtt->vm.mutex); drm_WARN_ON(&vm->i915->drm, !vm->is_ggtt && !vm->is_dpt);
mutex_lock(&vm->mutex);
/* Skip rewriting PTE on VMA unbind. */ /* Skip rewriting PTE on VMA unbind. */
open = atomic_xchg(&ggtt->vm.open, 0); open = atomic_xchg(&vm->open, 0);
list_for_each_entry_safe(vma, vn, &ggtt->vm.bound_list, vm_link) { list_for_each_entry_safe(vma, vn, &vm->bound_list, vm_link) {
GEM_BUG_ON(!drm_mm_node_allocated(&vma->node)); GEM_BUG_ON(!drm_mm_node_allocated(&vma->node));
i915_vma_wait_for_bind(vma); i915_vma_wait_for_bind(vma);
...@@ -139,11 +148,17 @@ void i915_ggtt_suspend(struct i915_ggtt *ggtt) ...@@ -139,11 +148,17 @@ void i915_ggtt_suspend(struct i915_ggtt *ggtt)
} }
} }
ggtt->vm.clear_range(&ggtt->vm, 0, ggtt->vm.total); vm->clear_range(vm, 0, vm->total);
ggtt->invalidate(ggtt);
atomic_set(&ggtt->vm.open, open);
mutex_unlock(&ggtt->vm.mutex); atomic_set(&vm->open, open);
mutex_unlock(&vm->mutex);
}
void i915_ggtt_suspend(struct i915_ggtt *ggtt)
{
i915_ggtt_suspend_vm(&ggtt->vm);
ggtt->invalidate(ggtt);
intel_gt_check_and_clear_faults(ggtt->vm.gt); intel_gt_check_and_clear_faults(ggtt->vm.gt);
} }
...@@ -1253,37 +1268,59 @@ void i915_ggtt_disable_guc(struct i915_ggtt *ggtt) ...@@ -1253,37 +1268,59 @@ void i915_ggtt_disable_guc(struct i915_ggtt *ggtt)
ggtt->invalidate(ggtt); ggtt->invalidate(ggtt);
} }
void i915_ggtt_resume(struct i915_ggtt *ggtt) /**
* i915_ggtt_resume_vm - Restore the memory mappings for a GGTT or DPT VM
* @vm: The VM to restore the mappings for
*
* Restore the memory mappings for all objects mapped to HW via the GGTT or a
* DPT page table.
*
* Returns %true if restoring the mapping for any object that was in a write
* domain before suspend.
*/
bool i915_ggtt_resume_vm(struct i915_address_space *vm)
{ {
struct i915_vma *vma; struct i915_vma *vma;
bool flush = false; bool write_domain_objs = false;
int open; int open;
intel_gt_check_and_clear_faults(ggtt->vm.gt); drm_WARN_ON(&vm->i915->drm, !vm->is_ggtt && !vm->is_dpt);
/* First fill our portion of the GTT with scratch pages */ /* First fill our portion of the GTT with scratch pages */
ggtt->vm.clear_range(&ggtt->vm, 0, ggtt->vm.total); vm->clear_range(vm, 0, vm->total);
/* Skip rewriting PTE on VMA unbind. */ /* Skip rewriting PTE on VMA unbind. */
open = atomic_xchg(&ggtt->vm.open, 0); open = atomic_xchg(&vm->open, 0);
/* clflush objects bound into the GGTT and rebind them. */ /* clflush objects bound into the GGTT and rebind them. */
list_for_each_entry(vma, &ggtt->vm.bound_list, vm_link) { list_for_each_entry(vma, &vm->bound_list, vm_link) {
struct drm_i915_gem_object *obj = vma->obj; struct drm_i915_gem_object *obj = vma->obj;
unsigned int was_bound = unsigned int was_bound =
atomic_read(&vma->flags) & I915_VMA_BIND_MASK; atomic_read(&vma->flags) & I915_VMA_BIND_MASK;
GEM_BUG_ON(!was_bound); GEM_BUG_ON(!was_bound);
vma->ops->bind_vma(&ggtt->vm, NULL, vma, vma->ops->bind_vma(vm, NULL, vma,
obj ? obj->cache_level : 0, obj ? obj->cache_level : 0,
was_bound); was_bound);
if (obj) { /* only used during resume => exclusive access */ if (obj) { /* only used during resume => exclusive access */
flush |= fetch_and_zero(&obj->write_domain); write_domain_objs |= fetch_and_zero(&obj->write_domain);
obj->read_domains |= I915_GEM_DOMAIN_GTT; obj->read_domains |= I915_GEM_DOMAIN_GTT;
} }
} }
atomic_set(&ggtt->vm.open, open); atomic_set(&vm->open, open);
return write_domain_objs;
}
void i915_ggtt_resume(struct i915_ggtt *ggtt)
{
bool flush;
intel_gt_check_and_clear_faults(ggtt->vm.gt);
flush = i915_ggtt_resume_vm(&ggtt->vm);
ggtt->invalidate(ggtt); ggtt->invalidate(ggtt);
if (flush) if (flush)
......
...@@ -544,6 +544,8 @@ int i915_ppgtt_init_hw(struct intel_gt *gt); ...@@ -544,6 +544,8 @@ int i915_ppgtt_init_hw(struct intel_gt *gt);
struct i915_ppgtt *i915_ppgtt_create(struct intel_gt *gt, struct i915_ppgtt *i915_ppgtt_create(struct intel_gt *gt,
unsigned long lmem_pt_obj_flags); unsigned long lmem_pt_obj_flags);
void i915_ggtt_suspend_vm(struct i915_address_space *vm);
bool i915_ggtt_resume_vm(struct i915_address_space *vm);
void i915_ggtt_suspend(struct i915_ggtt *gtt); void i915_ggtt_suspend(struct i915_ggtt *gtt);
void i915_ggtt_resume(struct i915_ggtt *ggtt); void i915_ggtt_resume(struct i915_ggtt *ggtt);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册