diff options
author | Ville Syrjälä <ville.syrjala@linux.intel.com> | 2016-12-07 12:56:47 -0500 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2017-01-12 05:39:07 -0500 |
commit | 5652dd3f005d7947c588ced586e09c48d68be7ae (patch) | |
tree | ec81854e13aa8ca3b79d245d106a102b27afbea7 /drivers/gpu/drm/i915 | |
parent | 8f8157c2a72af9cbd0e868ef64b90565b818a445 (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.h | 19 | ||||
-rw-r--r-- | drivers/gpu/drm/i915/intel_overlay.c | 3 |
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 | */ | ||
357 | static inline void | ||
358 | i915_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 | |||
347 | static inline struct drm_i915_gem_request * | 366 | static 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 | } |