Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit c82297fc authored by Chris Wilson's avatar Chris Wilson
Browse files

drm/i915: Flush everything on switching to the kernel_context



Even though all rendering should have been flushed at the end of the
previous requests, add an extra flush after switching to the
kernel_context. As the switch to the kernel_context is used when idling
the gpu (e.g. suspend), having an extra layer of paranoia to ensure
everything is flushed to memory seems sensible.

Signed-off-by: default avatarChris Wilson <chris@chris-wilson.co.uk>
Cc: Joonas Lahtinen <joonas.lahtinen@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20171126214856.23702-1-chris@chris-wilson.co.uk


Reviewed-by: default avatarJoonas Lahtinen <joonas.lahtinen@linux.intel.com>
parent fd94d53e
Loading
Loading
Loading
Loading
+8 −1
Original line number Diff line number Diff line
@@ -620,7 +620,14 @@ int i915_gem_switch_to_kernel_context(struct drm_i915_private *dev_priv)
								 GFP_KERNEL);
		}

		i915_add_request(req);
		/*
		 * Force a flush after the switch to ensure that all rendering
		 * and operations prior to switching to the kernel context hits
		 * memory. This should be guaranteed by the previous request,
		 * but an extra layer of paranoia before we declare the system
		 * idle (on suspend etc) is advisable!
		 */
		__i915_add_request(req, true);
	}

	return 0;