aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMaarten Lankhorst <maarten.lankhorst@canonical.com>2012-11-06 08:39:43 -0500
committerDave Airlie <airlied@redhat.com>2012-11-20 01:17:35 -0500
commit654aa79259a19f0d5e3cf9cb20aff56dc3b041b7 (patch)
tree406029f079300aac57d3463cf952b68d122619e9
parent6c1e963cc5771c93d4ed7aa8bdd4322a7c918e9b (diff)
drm/ttm: alter cpu_writers to return -EBUSY in ttm_execbuf_util reservations
This is similar to other platforms that don't allow command submission to buffers locked on the cpu. Signed-off-by: Maarten Lankhorst <maarten.lankhorst@canonical.com> Reviewed-by: Thomas Hellstrom <thellstrom@vmware.com> Signed-off-by: Dave Airlie <airlied@redhat.com>
-rw-r--r--drivers/gpu/drm/ttm/ttm_bo.c13
-rw-r--r--drivers/gpu/drm/ttm/ttm_execbuf_util.c5
-rw-r--r--include/drm/ttm/ttm_bo_api.h5
-rw-r--r--include/drm/ttm/ttm_bo_driver.h14
4 files changed, 5 insertions, 32 deletions
diff --git a/drivers/gpu/drm/ttm/ttm_bo.c b/drivers/gpu/drm/ttm/ttm_bo.c
index 5f61f133b419..7426fe59108e 100644
--- a/drivers/gpu/drm/ttm/ttm_bo.c
+++ b/drivers/gpu/drm/ttm/ttm_bo.c
@@ -1053,16 +1053,6 @@ int ttm_bo_mem_space(struct ttm_buffer_object *bo,
1053} 1053}
1054EXPORT_SYMBOL(ttm_bo_mem_space); 1054EXPORT_SYMBOL(ttm_bo_mem_space);
1055 1055
1056int ttm_bo_wait_cpu(struct ttm_buffer_object *bo, bool no_wait)
1057{
1058 if ((atomic_read(&bo->cpu_writers) > 0) && no_wait)
1059 return -EBUSY;
1060
1061 return wait_event_interruptible(bo->event_queue,
1062 atomic_read(&bo->cpu_writers) == 0);
1063}
1064EXPORT_SYMBOL(ttm_bo_wait_cpu);
1065
1066int ttm_bo_move_buffer(struct ttm_buffer_object *bo, 1056int ttm_bo_move_buffer(struct ttm_buffer_object *bo,
1067 struct ttm_placement *placement, 1057 struct ttm_placement *placement,
1068 bool interruptible, bool no_wait_reserve, 1058 bool interruptible, bool no_wait_reserve,
@@ -1788,8 +1778,7 @@ EXPORT_SYMBOL(ttm_bo_synccpu_write_grab);
1788 1778
1789void ttm_bo_synccpu_write_release(struct ttm_buffer_object *bo) 1779void ttm_bo_synccpu_write_release(struct ttm_buffer_object *bo)
1790{ 1780{
1791 if (atomic_dec_and_test(&bo->cpu_writers)) 1781 atomic_dec(&bo->cpu_writers);
1792 wake_up_all(&bo->event_queue);
1793} 1782}
1794EXPORT_SYMBOL(ttm_bo_synccpu_write_release); 1783EXPORT_SYMBOL(ttm_bo_synccpu_write_release);
1795 1784
diff --git a/drivers/gpu/drm/ttm/ttm_execbuf_util.c b/drivers/gpu/drm/ttm/ttm_execbuf_util.c
index b227a9961a07..1986d006c264 100644
--- a/drivers/gpu/drm/ttm/ttm_execbuf_util.c
+++ b/drivers/gpu/drm/ttm/ttm_execbuf_util.c
@@ -185,10 +185,7 @@ retry_this_bo:
185 ttm_eu_backoff_reservation_locked(list); 185 ttm_eu_backoff_reservation_locked(list);
186 spin_unlock(&glob->lru_lock); 186 spin_unlock(&glob->lru_lock);
187 ttm_eu_list_ref_sub(list); 187 ttm_eu_list_ref_sub(list);
188 ret = ttm_bo_wait_cpu(bo, false); 188 return -EBUSY;
189 if (ret)
190 return ret;
191 goto retry;
192 } 189 }
193 } 190 }
194 191
diff --git a/include/drm/ttm/ttm_bo_api.h b/include/drm/ttm/ttm_bo_api.h
index 5ff938df5fce..c6cae733ddef 100644
--- a/include/drm/ttm/ttm_bo_api.h
+++ b/include/drm/ttm/ttm_bo_api.h
@@ -424,8 +424,9 @@ extern void ttm_bo_unlock_delayed_workqueue(struct ttm_bo_device *bdev,
424 * @no_wait: Return immediately if buffer is busy. 424 * @no_wait: Return immediately if buffer is busy.
425 * 425 *
426 * Synchronizes a buffer object for CPU RW access. This means 426 * Synchronizes a buffer object for CPU RW access. This means
427 * blocking command submission that affects the buffer and 427 * command submission that affects the buffer will return -EBUSY
428 * waiting for buffer idle. This lock is recursive. 428 * until ttm_bo_synccpu_write_release is called.
429 *
429 * Returns 430 * Returns
430 * -EBUSY if the buffer is busy and no_wait is true. 431 * -EBUSY if the buffer is busy and no_wait is true.
431 * -ERESTARTSYS if interrupted by a signal. 432 * -ERESTARTSYS if interrupted by a signal.
diff --git a/include/drm/ttm/ttm_bo_driver.h b/include/drm/ttm/ttm_bo_driver.h
index 4789beee3b77..dd96442cdc2a 100644
--- a/include/drm/ttm/ttm_bo_driver.h
+++ b/include/drm/ttm/ttm_bo_driver.h
@@ -726,20 +726,6 @@ extern void ttm_bo_mem_put(struct ttm_buffer_object *bo,
726extern void ttm_bo_mem_put_locked(struct ttm_buffer_object *bo, 726extern void ttm_bo_mem_put_locked(struct ttm_buffer_object *bo,
727 struct ttm_mem_reg *mem); 727 struct ttm_mem_reg *mem);
728 728
729/**
730 * ttm_bo_wait_for_cpu
731 *
732 * @bo: Pointer to a struct ttm_buffer_object.
733 * @no_wait: Don't sleep while waiting.
734 *
735 * Wait until a buffer object is no longer sync'ed for CPU access.
736 * Returns:
737 * -EBUSY: Buffer object was sync'ed for CPU access. (only if no_wait == 1).
738 * -ERESTARTSYS: An interruptible sleep was interrupted by a signal.
739 */
740
741extern int ttm_bo_wait_cpu(struct ttm_buffer_object *bo, bool no_wait);
742
743extern void ttm_bo_global_release(struct drm_global_reference *ref); 729extern void ttm_bo_global_release(struct drm_global_reference *ref);
744extern int ttm_bo_global_init(struct drm_global_reference *ref); 730extern int ttm_bo_global_init(struct drm_global_reference *ref);
745 731