aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/gpu')
-rw-r--r--drivers/gpu/drm/i915/i915_dma.c10
-rw-r--r--drivers/gpu/drm/i915/i915_gem.c43
-rw-r--r--drivers/gpu/drm/i915/i915_gem_evict.c6
3 files changed, 22 insertions, 37 deletions
diff --git a/drivers/gpu/drm/i915/i915_dma.c b/drivers/gpu/drm/i915/i915_dma.c
index 35d121c70a1f..1ffeb1c5e7c4 100644
--- a/drivers/gpu/drm/i915/i915_dma.c
+++ b/drivers/gpu/drm/i915/i915_dma.c
@@ -132,8 +132,7 @@ static int i915_dma_cleanup(struct drm_device * dev)
132 132
133 mutex_lock(&dev->struct_mutex); 133 mutex_lock(&dev->struct_mutex);
134 intel_cleanup_ring_buffer(dev, &dev_priv->render_ring); 134 intel_cleanup_ring_buffer(dev, &dev_priv->render_ring);
135 if (HAS_BSD(dev)) 135 intel_cleanup_ring_buffer(dev, &dev_priv->bsd_ring);
136 intel_cleanup_ring_buffer(dev, &dev_priv->bsd_ring);
137 mutex_unlock(&dev->struct_mutex); 136 mutex_unlock(&dev->struct_mutex);
138 137
139 /* Clear the HWS virtual address at teardown */ 138 /* Clear the HWS virtual address at teardown */
@@ -1199,9 +1198,6 @@ static int i915_load_modeset_init(struct drm_device *dev,
1199 /* Basic memrange allocator for stolen space (aka mm.vram) */ 1198 /* Basic memrange allocator for stolen space (aka mm.vram) */
1200 drm_mm_init(&dev_priv->mm.vram, 0, prealloc_size); 1199 drm_mm_init(&dev_priv->mm.vram, 0, prealloc_size);
1201 1200
1202 /* We're off and running w/KMS */
1203 dev_priv->mm.suspended = 0;
1204
1205 /* Let GEM Manage from end of prealloc space to end of aperture. 1201 /* Let GEM Manage from end of prealloc space to end of aperture.
1206 * 1202 *
1207 * However, leave one page at the end still bound to the scratch page. 1203 * However, leave one page at the end still bound to the scratch page.
@@ -1271,6 +1267,10 @@ static int i915_load_modeset_init(struct drm_device *dev,
1271 goto cleanup_irq; 1267 goto cleanup_irq;
1272 1268
1273 drm_kms_helper_poll_init(dev); 1269 drm_kms_helper_poll_init(dev);
1270
1271 /* We're off and running w/KMS */
1272 dev_priv->mm.suspended = 0;
1273
1274 return 0; 1274 return 0;
1275 1275
1276cleanup_irq: 1276cleanup_irq:
diff --git a/drivers/gpu/drm/i915/i915_gem.c b/drivers/gpu/drm/i915/i915_gem.c
index f6a615ea3025..56153685d145 100644
--- a/drivers/gpu/drm/i915/i915_gem.c
+++ b/drivers/gpu/drm/i915/i915_gem.c
@@ -1795,8 +1795,7 @@ void i915_gem_reset(struct drm_device *dev)
1795 int i; 1795 int i;
1796 1796
1797 i915_gem_reset_ring_lists(dev_priv, &dev_priv->render_ring); 1797 i915_gem_reset_ring_lists(dev_priv, &dev_priv->render_ring);
1798 if (HAS_BSD(dev)) 1798 i915_gem_reset_ring_lists(dev_priv, &dev_priv->bsd_ring);
1799 i915_gem_reset_ring_lists(dev_priv, &dev_priv->bsd_ring);
1800 1799
1801 /* Remove anything from the flushing lists. The GPU cache is likely 1800 /* Remove anything from the flushing lists. The GPU cache is likely
1802 * to be lost on reset along with the data, so simply move the 1801 * to be lost on reset along with the data, so simply move the
@@ -1918,8 +1917,7 @@ i915_gem_retire_requests(struct drm_device *dev)
1918 } 1917 }
1919 1918
1920 i915_gem_retire_requests_ring(dev, &dev_priv->render_ring); 1919 i915_gem_retire_requests_ring(dev, &dev_priv->render_ring);
1921 if (HAS_BSD(dev)) 1920 i915_gem_retire_requests_ring(dev, &dev_priv->bsd_ring);
1922 i915_gem_retire_requests_ring(dev, &dev_priv->bsd_ring);
1923} 1921}
1924 1922
1925static void 1923static void
@@ -1942,8 +1940,7 @@ i915_gem_retire_work_handler(struct work_struct *work)
1942 1940
1943 if (!dev_priv->mm.suspended && 1941 if (!dev_priv->mm.suspended &&
1944 (!list_empty(&dev_priv->render_ring.request_list) || 1942 (!list_empty(&dev_priv->render_ring.request_list) ||
1945 (HAS_BSD(dev) && 1943 !list_empty(&dev_priv->bsd_ring.request_list)))
1946 !list_empty(&dev_priv->bsd_ring.request_list))))
1947 queue_delayed_work(dev_priv->wq, &dev_priv->mm.retire_work, HZ); 1944 queue_delayed_work(dev_priv->wq, &dev_priv->mm.retire_work, HZ);
1948 mutex_unlock(&dev->struct_mutex); 1945 mutex_unlock(&dev->struct_mutex);
1949} 1946}
@@ -2181,8 +2178,7 @@ i915_gpu_idle(struct drm_device *dev)
2181 2178
2182 lists_empty = (list_empty(&dev_priv->mm.flushing_list) && 2179 lists_empty = (list_empty(&dev_priv->mm.flushing_list) &&
2183 list_empty(&dev_priv->render_ring.active_list) && 2180 list_empty(&dev_priv->render_ring.active_list) &&
2184 (!HAS_BSD(dev) || 2181 list_empty(&dev_priv->bsd_ring.active_list));
2185 list_empty(&dev_priv->bsd_ring.active_list)));
2186 if (lists_empty) 2182 if (lists_empty)
2187 return 0; 2183 return 0;
2188 2184
@@ -2191,11 +2187,9 @@ i915_gpu_idle(struct drm_device *dev)
2191 if (ret) 2187 if (ret)
2192 return ret; 2188 return ret;
2193 2189
2194 if (HAS_BSD(dev)) { 2190 ret = i915_ring_idle(dev, &dev_priv->bsd_ring);
2195 ret = i915_ring_idle(dev, &dev_priv->bsd_ring); 2191 if (ret)
2196 if (ret) 2192 return ret;
2197 return ret;
2198 }
2199 2193
2200 return 0; 2194 return 0;
2201} 2195}
@@ -4349,10 +4343,7 @@ i915_gem_idle(struct drm_device *dev)
4349 4343
4350 mutex_lock(&dev->struct_mutex); 4344 mutex_lock(&dev->struct_mutex);
4351 4345
4352 if (dev_priv->mm.suspended || 4346 if (dev_priv->mm.suspended) {
4353 (dev_priv->render_ring.gem_object == NULL) ||
4354 (HAS_BSD(dev) &&
4355 dev_priv->bsd_ring.gem_object == NULL)) {
4356 mutex_unlock(&dev->struct_mutex); 4347 mutex_unlock(&dev->struct_mutex);
4357 return 0; 4348 return 0;
4358 } 4349 }
@@ -4491,8 +4482,7 @@ i915_gem_cleanup_ringbuffer(struct drm_device *dev)
4491 drm_i915_private_t *dev_priv = dev->dev_private; 4482 drm_i915_private_t *dev_priv = dev->dev_private;
4492 4483
4493 intel_cleanup_ring_buffer(dev, &dev_priv->render_ring); 4484 intel_cleanup_ring_buffer(dev, &dev_priv->render_ring);
4494 if (HAS_BSD(dev)) 4485 intel_cleanup_ring_buffer(dev, &dev_priv->bsd_ring);
4495 intel_cleanup_ring_buffer(dev, &dev_priv->bsd_ring);
4496 if (HAS_PIPE_CONTROL(dev)) 4486 if (HAS_PIPE_CONTROL(dev))
4497 i915_gem_cleanup_pipe_control(dev); 4487 i915_gem_cleanup_pipe_control(dev);
4498} 4488}
@@ -4522,11 +4512,11 @@ i915_gem_entervt_ioctl(struct drm_device *dev, void *data,
4522 } 4512 }
4523 4513
4524 BUG_ON(!list_empty(&dev_priv->render_ring.active_list)); 4514 BUG_ON(!list_empty(&dev_priv->render_ring.active_list));
4525 BUG_ON(HAS_BSD(dev) && !list_empty(&dev_priv->bsd_ring.active_list)); 4515 BUG_ON(!list_empty(&dev_priv->bsd_ring.active_list));
4526 BUG_ON(!list_empty(&dev_priv->mm.flushing_list)); 4516 BUG_ON(!list_empty(&dev_priv->mm.flushing_list));
4527 BUG_ON(!list_empty(&dev_priv->mm.inactive_list)); 4517 BUG_ON(!list_empty(&dev_priv->mm.inactive_list));
4528 BUG_ON(!list_empty(&dev_priv->render_ring.request_list)); 4518 BUG_ON(!list_empty(&dev_priv->render_ring.request_list));
4529 BUG_ON(HAS_BSD(dev) && !list_empty(&dev_priv->bsd_ring.request_list)); 4519 BUG_ON(!list_empty(&dev_priv->bsd_ring.request_list));
4530 mutex_unlock(&dev->struct_mutex); 4520 mutex_unlock(&dev->struct_mutex);
4531 4521
4532 ret = drm_irq_install(dev); 4522 ret = drm_irq_install(dev);
@@ -4582,10 +4572,8 @@ i915_gem_load(struct drm_device *dev)
4582 INIT_LIST_HEAD(&dev_priv->mm.deferred_free_list); 4572 INIT_LIST_HEAD(&dev_priv->mm.deferred_free_list);
4583 INIT_LIST_HEAD(&dev_priv->render_ring.active_list); 4573 INIT_LIST_HEAD(&dev_priv->render_ring.active_list);
4584 INIT_LIST_HEAD(&dev_priv->render_ring.request_list); 4574 INIT_LIST_HEAD(&dev_priv->render_ring.request_list);
4585 if (HAS_BSD(dev)) { 4575 INIT_LIST_HEAD(&dev_priv->bsd_ring.active_list);
4586 INIT_LIST_HEAD(&dev_priv->bsd_ring.active_list); 4576 INIT_LIST_HEAD(&dev_priv->bsd_ring.request_list);
4587 INIT_LIST_HEAD(&dev_priv->bsd_ring.request_list);
4588 }
4589 for (i = 0; i < 16; i++) 4577 for (i = 0; i < 16; i++)
4590 INIT_LIST_HEAD(&dev_priv->fence_regs[i].lru_list); 4578 INIT_LIST_HEAD(&dev_priv->fence_regs[i].lru_list);
4591 INIT_DELAYED_WORK(&dev_priv->mm.retire_work, 4579 INIT_DELAYED_WORK(&dev_priv->mm.retire_work,
@@ -4848,9 +4836,8 @@ i915_gpu_is_active(struct drm_device *dev)
4848 int lists_empty; 4836 int lists_empty;
4849 4837
4850 lists_empty = list_empty(&dev_priv->mm.flushing_list) && 4838 lists_empty = list_empty(&dev_priv->mm.flushing_list) &&
4851 list_empty(&dev_priv->render_ring.active_list); 4839 list_empty(&dev_priv->render_ring.active_list) &&
4852 if (HAS_BSD(dev)) 4840 list_empty(&dev_priv->bsd_ring.active_list);
4853 lists_empty &= list_empty(&dev_priv->bsd_ring.active_list);
4854 4841
4855 return !lists_empty; 4842 return !lists_empty;
4856} 4843}
diff --git a/drivers/gpu/drm/i915/i915_gem_evict.c b/drivers/gpu/drm/i915/i915_gem_evict.c
index 3d7fbf32bb18..d2733a1e2bcc 100644
--- a/drivers/gpu/drm/i915/i915_gem_evict.c
+++ b/drivers/gpu/drm/i915/i915_gem_evict.c
@@ -215,8 +215,7 @@ i915_gem_evict_everything(struct drm_device *dev)
215 lists_empty = (list_empty(&dev_priv->mm.inactive_list) && 215 lists_empty = (list_empty(&dev_priv->mm.inactive_list) &&
216 list_empty(&dev_priv->mm.flushing_list) && 216 list_empty(&dev_priv->mm.flushing_list) &&
217 list_empty(&dev_priv->render_ring.active_list) && 217 list_empty(&dev_priv->render_ring.active_list) &&
218 (!HAS_BSD(dev) 218 list_empty(&dev_priv->bsd_ring.active_list));
219 || list_empty(&dev_priv->bsd_ring.active_list)));
220 if (lists_empty) 219 if (lists_empty)
221 return -ENOSPC; 220 return -ENOSPC;
222 221
@@ -234,8 +233,7 @@ i915_gem_evict_everything(struct drm_device *dev)
234 lists_empty = (list_empty(&dev_priv->mm.inactive_list) && 233 lists_empty = (list_empty(&dev_priv->mm.inactive_list) &&
235 list_empty(&dev_priv->mm.flushing_list) && 234 list_empty(&dev_priv->mm.flushing_list) &&
236 list_empty(&dev_priv->render_ring.active_list) && 235 list_empty(&dev_priv->render_ring.active_list) &&
237 (!HAS_BSD(dev) 236 list_empty(&dev_priv->bsd_ring.active_list));
238 || list_empty(&dev_priv->bsd_ring.active_list)));
239 BUG_ON(!lists_empty); 237 BUG_ON(!lists_empty);
240 238
241 return 0; 239 return 0;