mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-09-04 20:19:47 +08:00
At least during hibernation the DPT mappings are lost with all stolen
memory content, so suspend/resume these mappings similarly to GGTT
mappings.
This fixes a problem where the restoring modeset during system resume fails
with pipe faults if a tiled framebuffer was active before suspend.
v2: Clarify the way restore works in intel_dpt_resume()'s Docbook entry.
(Chris)
Cc: Chris Wilson <chris@chris-wilson.co.uk>
Cc: Ville Syrjälä <ville.syrjala@linux.intel.com>
Cc: Vunny Sodhi <vunny.sodhi@intel.com>
Reported-and-tested-by: Vunny Sodhi <vunny.sodhi@intel.com>
Signed-off-by: Imre Deak <imre.deak@intel.com>
Reviewed-by: Chris Wilson <chris@chris-wilson.co.uk>
Reviewed-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20211101183551.3580546-2-imre.deak@intel.com
24 lines
614 B
C
24 lines
614 B
C
/* SPDX-License-Identifier: MIT */
|
|
/*
|
|
* Copyright © 2021 Intel Corporation
|
|
*/
|
|
|
|
#ifndef __INTEL_DPT_H__
|
|
#define __INTEL_DPT_H__
|
|
|
|
struct drm_i915_private;
|
|
|
|
struct i915_address_space;
|
|
struct i915_vma;
|
|
struct intel_framebuffer;
|
|
|
|
void intel_dpt_destroy(struct i915_address_space *vm);
|
|
struct i915_vma *intel_dpt_pin(struct i915_address_space *vm);
|
|
void intel_dpt_unpin(struct i915_address_space *vm);
|
|
void intel_dpt_suspend(struct drm_i915_private *i915);
|
|
void intel_dpt_resume(struct drm_i915_private *i915);
|
|
struct i915_address_space *
|
|
intel_dpt_create(struct intel_framebuffer *fb);
|
|
|
|
#endif /* __INTEL_DPT_H__ */
|