aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu
diff options
context:
space:
mode:
authorDaniel Vetter <daniel.vetter@ffwll.ch>2012-11-14 11:14:06 -0500
committerDaniel Vetter <daniel.vetter@ffwll.ch>2013-01-20 07:11:15 -0500
commit308887aad14c4ecc3fc10a3c58ec42641c5e4423 (patch)
treee28a0e3c75057a84c1995f92e353001e4cefd071 /drivers/gpu
parent33196deddacc7790defb9a7e84659e0362d4da7a (diff)
drm/i915: fix reset handling in the throttle ioctl
While auditing the code I've noticed one place (the throttle ioctl) which does not yet wait for the reset handler to complete and doesn't properly decode the wedge state into -EAGAIN/-EIO. Fix this up by calling the right helpers. This might explain the oddball "my compositor just died in a successfull gpu reset" reports. Or maybe not, since current mesa doesn't use this ioctl to throttle command submission. The throttle ioctl doesn't take the struct_mutex, so to avoid busy-looping with -EAGAIN while a reset is in process, check for errors first and wait for the handler to complete if a reset is pending by calling i915_gem_wait_for_error. Reviewed-by: Damien Lespiau <damien.lespiau@intel.com> Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Diffstat (limited to 'drivers/gpu')
-rw-r--r--drivers/gpu/drm/i915/i915_gem.c9
1 files changed, 7 insertions, 2 deletions
diff --git a/drivers/gpu/drm/i915/i915_gem.c b/drivers/gpu/drm/i915/i915_gem.c
index 04b2f92eb456..c96a501b8205 100644
--- a/drivers/gpu/drm/i915/i915_gem.c
+++ b/drivers/gpu/drm/i915/i915_gem.c
@@ -3390,8 +3390,13 @@ i915_gem_ring_throttle(struct drm_device *dev, struct drm_file *file)
3390 u32 seqno = 0; 3390 u32 seqno = 0;
3391 int ret; 3391 int ret;
3392 3392
3393 if (atomic_read(&dev_priv->gpu_error.wedged)) 3393 ret = i915_gem_wait_for_error(&dev_priv->gpu_error);
3394 return -EIO; 3394 if (ret)
3395 return ret;
3396
3397 ret = i915_gem_check_wedge(&dev_priv->gpu_error, false);
3398 if (ret)
3399 return ret;
3395 3400
3396 spin_lock(&file_priv->mm.lock); 3401 spin_lock(&file_priv->mm.lock);
3397 list_for_each_entry(request, &file_priv->mm.request_list, client_list) { 3402 list_for_each_entry(request, &file_priv->mm.request_list, client_list) {