aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/i915
diff options
context:
space:
mode:
authorVille Syrjälä <ville.syrjala@linux.intel.com>2016-12-07 12:56:47 -0500
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2017-01-12 05:39:07 -0500
commit5652dd3f005d7947c588ced586e09c48d68be7ae (patch)
treeec81854e13aa8ca3b79d245d106a102b27afbea7 /drivers/gpu/drm/i915
parent8f8157c2a72af9cbd0e868ef64b90565b818a445 (diff)
drm/i915: Fix oopses in the overlay code due to i915_gem_active stuff
commit b72eb5ffa6d8601d9ba72619d75fb5b27723743a upstream. The i915_gem_active stuff doesn't like a NULL ->retire hook, but the overlay code can set it to NULL. That obviously ends up oopsing. Fix it by introducing a new helper to assign the retirement callback that will switch out the NULL function pointer with i915_gem_retire_noop. Cc: Chris Wilson <chris@chris-wilson.co.uk> Cc: Joonas Lahtinen <joonas.lahtinen@linux.intel.com> Fixes: 0d9bdd886f29 ("drm/i915: Convert intel_overlay to request tracking") Signed-off-by: Ville Syrjälä <ville.syrjala@linux.intel.com> Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk> Link: http://patchwork.freedesktop.org/patch/msgid/20161207175647.10018-1-chris@chris-wilson.co.uk (cherry picked from commit ecd9caa0522db5a6b03ac8858c42067ef9d8323b) Signed-off-by: Jani Nikula <jani.nikula@intel.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'drivers/gpu/drm/i915')
-rw-r--r--drivers/gpu/drm/i915/i915_gem_request.h19
-rw-r--r--drivers/gpu/drm/i915/intel_overlay.c3
2 files changed, 21 insertions, 1 deletions
diff --git a/drivers/gpu/drm/i915/i915_gem_request.h b/drivers/gpu/drm/i915/i915_gem_request.h
index 974bd7bcc801..59ac90025552 100644
--- a/drivers/gpu/drm/i915/i915_gem_request.h
+++ b/drivers/gpu/drm/i915/i915_gem_request.h
@@ -344,6 +344,25 @@ i915_gem_active_set(struct i915_gem_active *active,
344 rcu_assign_pointer(active->request, request); 344 rcu_assign_pointer(active->request, request);
345} 345}
346 346
347/**
348 * i915_gem_active_set_retire_fn - updates the retirement callback
349 * @active - the active tracker
350 * @fn - the routine called when the request is retired
351 * @mutex - struct_mutex used to guard retirements
352 *
353 * i915_gem_active_set_retire_fn() updates the function pointer that
354 * is called when the final request associated with the @active tracker
355 * is retired.
356 */
357static inline void
358i915_gem_active_set_retire_fn(struct i915_gem_active *active,
359 i915_gem_retire_fn fn,
360 struct mutex *mutex)
361{
362 lockdep_assert_held(mutex);
363 active->retire = fn ?: i915_gem_retire_noop;
364}
365
347static inline struct drm_i915_gem_request * 366static inline struct drm_i915_gem_request *
348__i915_gem_active_peek(const struct i915_gem_active *active) 367__i915_gem_active_peek(const struct i915_gem_active *active)
349{ 368{
diff --git a/drivers/gpu/drm/i915/intel_overlay.c b/drivers/gpu/drm/i915/intel_overlay.c
index a24bc8c7889f..bcde9f6eecf1 100644
--- a/drivers/gpu/drm/i915/intel_overlay.c
+++ b/drivers/gpu/drm/i915/intel_overlay.c
@@ -216,7 +216,8 @@ static void intel_overlay_submit_request(struct intel_overlay *overlay,
216{ 216{
217 GEM_BUG_ON(i915_gem_active_peek(&overlay->last_flip, 217 GEM_BUG_ON(i915_gem_active_peek(&overlay->last_flip,
218 &overlay->i915->drm.struct_mutex)); 218 &overlay->i915->drm.struct_mutex));
219 overlay->last_flip.retire = retire; 219 i915_gem_active_set_retire_fn(&overlay->last_flip, retire,
220 &overlay->i915->drm.struct_mutex);
220 i915_gem_active_set(&overlay->last_flip, req); 221 i915_gem_active_set(&overlay->last_flip, req);
221 i915_add_request(req); 222 i915_add_request(req);
222} 223}